- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
秒表的VHDL實现
引言
§1.1设计任务
设计一简易数字秒表,其基本要求是:
测量时间范围0.01—59.99
显示方式为4位十进制数显示。
使用Max+Plus II进行仿真。
具有启动/停止计数功能。
§1.2简介
数字秒表是数字电路中的一个典型应用,实际的硬件设计用到的器件较多,连线比较复杂,而且会产生比较大的延时,造成测量误差、可靠性差。随着可编程ASIC的广泛应用,以EDA工具作为开发手段,基于VHDL语言,将使整个系统大大简化,提高整体的性能和可靠性。用可编程器件设计数字秒表的途径很多。本文介绍针对实验教学所使用的一种方法,使用的器件均是在实验中最常用的,包括Altera公司的FLEX10K系列,而且外部设备也很简单。通时间的长短对被测信号正脉冲进行计数;2)静态显示模块,对计数的结果进行显示,从而完成整个计数的过程。系统的工作原理是,将系统信号两次10倍分频,达到需要精度。利用键盘对秒表计数进行控制,开始/暂停。使用简便,精确。
第二章 方案设计及总体原理论述
本系统分为时钟输入部分,键盘部分,分频器部分,计数,显示部分。其中分频器和计数部分合成在一个FPGA芯片之中。时钟部分来自实验箱10KHZ方波。
键盘部分利用实验箱本身的键盘,显示部分由计数器的输出直接给实验箱的数码管静态显示部分。(如图1所示)
图1总体设计
2.1 分频器部分
工作原理:当CLK上升沿到来时,60分频器COUNT加一,当加到60时与之相连的管脚CLK60取反。为节省资源10分频器与60分频器共用,当COUNT加到10的整数倍时CLK10取反。
波形图如下:
2.2 计数部分
工作原理:当CLK上升沿到来时,T0加一,当T0=9时,下一上升沿到来时将T0清零,T1加一。当T1=9时,下一上升沿到来时将T1清零,T2加一。当T2=9时,下一上升沿到来时将T2清零,T3加一。这样就实现了百分秒,十分秒,秒和十秒的进位关系。
波形图如下:
第三章 程序实现
整个程序分为两个部分组成,每个部分定义成一个独立器件。
3.1 分频器部分
library ieee;
use ieee.std_logic_1164.all;
-----------------------------------------------------
entity count60 is
port( clk,en : in std_logic;
clock60,clock10 : buffer std_logic);
end count60;
--------------------------------------------------
architecture count60_arc of count60 is
begin
----------------------
process(clk,en)
variable count:integer range 0 to 60 :=0;
begin
if en=0 then
NULL;
elsif (rising_edge(clk)) then
count:=count+1;
if count=60 then
clock60=not clock60;
count:=0;
end if;
if(count=10 or count=20 or count=30 or count=40 or count=50 or count=0)then
clock10 = not clock10;
end if;
end if;
end process;
end count60_arc;
3.2 计数器部分
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity list is
port( clk : in std_logic;
q0,q1,q2,q3 : out std_logic_vector(3 downto 0));
end list;
architecture a of list is
signal t0,t1,t2,t3 : std_logic_vector(3 downto 0);
begin
process(clk)
begin
if rising_edge(clk) then
if(t0=9)then
t0=0000;
t1=t1+1;
else
t0=t0+1;
end if;
if(t1=9)then
t1=0000;
t2=t2+1;
end if;
if(t2=9)then
t2=00
文档评论(0)