- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
EDA课程设计_数字钟
数字钟
原理图:
模块说明:
该模块实现分频即将24M时钟源分频为1HZ信号。该分频器由D触发器和计数器构成,每个D触发器的输出信号频率为输入信号频率的一半从而实现分频,COUNTER为计数器,配合D触发器进行进一步分频最终达到合适的频率。
对二分频器进行波形仿真为
对COUNTER即87计数器仿真为
即输入89个时钟脉冲后输出才为一。
对COUNTER1即80计数器仿真为
即输入80个时钟脉冲后输出为一。
Second模块实现秒计数为六十进制计数模式,当计数达到59后如再来一个时钟脉冲则进位即分钟加一,秒位清零即为00。
Minute模块实现分计数也为六十进制计数模式,当计数达到59时再来一个脉冲则进位即时钟加一,分位清零即为00。
Hour模块实现时计数为二十四进制计数模式,当计数达到23时再来一个脉冲则复位即为00。
Link模块实现隔离即将分与秒,时与分隔开。分隔符表现形式为“-”,用了此模块后时钟显示更直观。
Sel_clock模块实现扫描显示即每一瞬间输出的数据为秒的个位或十位,或者为分的个位或十位,或者时的个位或十位。因该试验增加了一些功能,所以该模块要做相应修改――增加为八位显示。此时连线时应注意各模块的个位十位接线和分隔符接线。
Deled模块为字符译码模块即将十六进制字符翻译为七段数码管相应段位亮灭从而实现字符译码。该模块也要作少许修改,如把hf =1,0,0,0,1,1,1;改为了hf =0,0,0,0,0,0,1;这样显示后就起到分隔的作用了。当然这也不是唯一的修改方法,关键是修改要和你的link模块相匹配。
Alert为整点报时模块,呐叭发声为脉冲激发,不同频率的信号会得到不同音调的声音,如果不停的改变信号频率就会得到一串抑扬顿挫的声音。
对second模块仿真为
对minute模块进行仿真为:
对hour模块进行仿真:
对deled字符译码模块仿真
该模块将字符转换成数码管相应的段码以便数码管能显示为人们习惯的字符。
三、管脚分配:
四、AHDL源程序:
1:counter,tdf
SUBDESIGN counter
(
CLK : INPUT;
CLKOUT : OUTPUT;
)
VARIABLE
count1[3..0] : DFF;
count2[3..0] : DFF;
SS :DFF;
BEGIN
count1[].clk = clk;
count2[].clk = clk;
SS.CLK = CLK;
SS = B0;
IF
COUNT1[]==B0111 AND
COUNT2[]==B1000 then
SS=B1;
END IF;
IF count1[]==B1001 THEN
count1[] =B0000;
ELSE
count1[].d = count1[].q + 1;
END IF;
IF count1[]==B1001 THEN
IF count2[]==B1000 THEN
count2[] =B0000;
ELSE
count2[].d = count2[].q + 1;
END if;
ELSE
count2[].d = count2[].q;
END IF;
clkout=ss;
END;
2:counter1.tdf
SUBDESIGN counter1
(
CLK : INPUT;
CLKOUT : OUTPUT;
)
VARIABLE
count1[3..0] : DFF;
count2[3..0] : DFF;
SS :DFF;
BEGIN
count1[].clk = clk;
count2[].clk = clk;
SS.CLK = CLK;
SS = B0;
IF
COUNT1[]==B1001 AND
COUNT2[]==B0111 then
SS=B1;
END IF;
IF count1[]==B1001 THEN
count1[] =B0000;
ELSE
count1[].d = count1[].q + 1;
END IF;
IF count1[
原创力文档


文档评论(0)