用Verilog语言编写的多功能数字钟.docx

用Verilog语言编写的多功能数字钟.docx

ID:55278810

大小:132.03 KB

页数:12页

时间:2020-05-08

用Verilog语言编写的多功能数字钟.docx_第1页
用Verilog语言编写的多功能数字钟.docx_第2页
用Verilog语言编写的多功能数字钟.docx_第3页
用Verilog语言编写的多功能数字钟.docx_第4页
用Verilog语言编写的多功能数字钟.docx_第5页
资源描述:

《用Verilog语言编写的多功能数字钟.docx》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、2009—2010学年第二学期《数字电子技术课程设计》报告专业班级:电气-08-1姓名:曹操学号:08051127设计日期:2010年8月23日~27日12一.设计题目多功能数字钟电路设计二.设计任务及要求多功能数字钟应该具有的功能有:显示时—分—秒、整点报时、小时和分钟可调等基本功能。整个钟表的工作应该是在1Hz信号的作用下进行,这样每来一个时钟信号,秒增加1秒,当秒从59秒跳转到00秒时,分钟增加1分,同时当分钟从59分跳转到00分时,小时增加1小时,小时的范围为0~23时。在实验中为了显示的方便,由于分钟和秒钟显示的范围都是从0~5

2、9,所以可以用一个3位的二进制码显示十位,用一个四位的二进制码(BCD码)显示个位,对于小时因为他的范围是从0~23,所以可以用一个2位的二进制码显示十位,用一个4位的二进制码(BCD码)显示个位。实验中由于七段码管是扫描的方式显示,所以虽然时钟需要的是1Hz时钟信号,但是扫描需要一个比较高频率的信号,因此为了得到准确的1Hz信号,必须对输入的系统时钟50Mhz进行分频。对于整点报时功能,本实验设计的是当进行正点的倒计时5秒时,让LED来闪烁进行整点报时的提示。调整时间的按键用按键模块的S1和S2,S1调节小时,每按下一次,小时增加一个小

3、时;S2调整分钟,每按下一次,分钟增加一分钟。另外用S812按键作为系统时钟复位,复位后全部显示00—00—00。管脚分配如下表:端口名使用模块信号对应FPGA管脚说明S1按键开关S1R16调整小时S2按键开关S2P14调整分钟RST按键开关S8M15复位LEDLED模块D1L14整点倒计时LEDAG0数码管模块A段N4时间显示LEDAG1数码管模块B段G4LEDAG2数码管模块C段H4LEDAG3数码管模块D段L5LEDAG4数码管模块E段L4LEDAG5数码管模块F段K4LEDAG6数码管模块G段K5SEL0数码管选择位1M48个数码

4、管的选择位SEL1数码管选择位2F3SEL2数码管选择位3F4CP脉冲源J350Mhz脉冲三.基于VerilogHDL语言的电路设计、仿真与综合12(一)顶层模块本程序采用结构化设计方法,将其分为彼此独立又有一定联系的三个模块,如图1所示:图1:顶层结构框图(二)子模块1.分频器分频器的作用是对50Mhz的系统时钟信号进行分频,得到频率为1000hz的信号,作为显示器的输入信号。源程序如下:modulefenpin(inputCP,outputCPout);regCPout;reg[31:0]Cout;regCP_En;always@(p

5、osedgeCP)//将50MHz分频为1kHzbeginCout<=(Cout==32'd50000)?32'd0:(Cout+32'd1);CP_En<=(Cout==32'd50000)?1'd1:1'd0;CPout<=CP_En;12endendmodule功能仿真波形如图2所示(以五分频为例):2.控制器和计数器控制器的作用是,调整小时和分钟的值,并能实现清零功能。计数器的作用是实现分钟和秒钟满60进1,小时则由23跳到00。当到达59分55秒的时候,LED灯会闪烁来进行报时。因为控制器和计数器的驱动信号频率均为1Hz,故从分

6、频器输出的信号进入控制器后,要进行二次分频,由1Khz变为1Hz。源程序如下:modulekongzhiqi(CPout,S1,S2,RET,Hour,Minute,Second,LED);inputCPout,S1,S2,RET;output[5:0]Hour;output[5:0]Minute;output[5:0]Second;outputLED;reg[5:0]Hour;reg[5:0]Minute;reg[5:0]Second;regR1;regR2,R8,LED;reg[10:0]Cout;regClk_En;12always

7、@(posedgeCPout)beginif(S1==0)beginR1=1;endif(S2==0)beginR2=1;endif(RET==0)beginR8=1;endCout=(Cout==32'd1000)?32'd0:(Cout+32'd1);Clk_En=(Cout==32'd1000)?1'd1:1'd0;if(Clk_En)beginif(R1==1)beginif(Hour<24)Hour=Hour+1;if(Hour==24)beginHour=0;endR1=0;endif(R2==1)beginif(Minute

8、<60)Minute=Minute+1;if(Minute==60)beginMinute=0;if(Hour<24)Hour=Hour+1;if(Hour==24)beginHour=0;e

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。