用Verilog语言编写的多功能数字钟docx.docx
- 文档编号:1389983
- 上传时间:2022-10-21
- 格式:DOCX
- 页数:13
- 大小:253.44KB
用Verilog语言编写的多功能数字钟docx.docx
《用Verilog语言编写的多功能数字钟docx.docx》由会员分享,可在线阅读,更多相关《用Verilog语言编写的多功能数字钟docx.docx(13页珍藏版)》请在冰豆网上搜索。
用Verilog语言编写的多功能数字钟docx
2009—2010学年第二学期
《数字电子技术课程设计》报告
专业班级:
电气-08-1
姓名:
曹操
学号:
08051127
设计日期:
2010年8月23日~27日
设计题目
多功能数字钟电路设计
二.设计任务及要求
多功能数字钟应该具有的功能有:
显示时—分—秒、整点报时、小时和分钟可调等基本功能。
整个钟表的工作应该是在1Hz信号的作用下进行,这样每来一个时钟信号,秒增加1秒,当秒从59秒跳转到00秒时,分钟增加1分,同时当分钟从59分跳转到00分时,小时增加1小时,小时的范围为0~23时。
在实验中为了显示的方便,由于分钟和秒钟显示的范围都是从0~59,
所以可以用一个3位的二进制码显示十位,用一个四位的二进制码(BCD码)显示个位,对于小时因为他的范围是从0~23,所以可以用一个2位的二进制码显示十位,用一个4位的二进制码(BCD码)显示个位。
实验中由于七段码管是扫描的方式显示,所以虽然时钟需要的是1Hz时钟信号,但是扫描需要一个比较高频率的信号,因此为了得到准确的1Hz信号,必须对输入的系统时钟50Mhz进行分频。
对于整点报时功能,本实验设计的是当进行正点的倒计时5秒时,让
LED来闪烁进行整点报时的提示。
调整时间的按键用按键模块的S1和S2,S1调节小时,每按下一次,小时增加一个小时;S2调整分钟,每按下一次,分钟增加一分钟。
另外用
S8按键作为系统时钟复位,复位后全部显示00—00—00
管脚分配如下表:
端口名
使用模块信号
对应FPGA管脚
说明
S1
按键开关S1
R16
调整小时
S2
按键开关S2
P14
调整分钟
RST
按键开关S8
M15
复位
LED
LED模块D1
L14
整点倒计时
LEDAG0
数码管模块A段
N4
LEDAG1
数码管模块B段
G4
LEDAG2
数码管模块C段
H4
LEDAG3
数码管模块D段
L5
时间显示
LEDAG4
数码管模块E段
L4
LEDAG5
数码管模块F段
K4
LEDAG6
数码管模块G段
K5
SEL0
数码管选择位1
M4
8个数码管
SEL1
数码管选择位2
F3
的选择位
SEL2
数码管选择位3
F4
CP
脉冲源
J3
50Mhz脉冲
三.基于VerilogHDL语言的电路设计、仿真与综合
(一)顶层模块
本程序采用结构化设计方法,将其分为彼此独立又有一定联系的三个模块,
如图1所示:
图1:
顶层结构框图
(二)子模块
1.分频器
分频器的作用是对50Mhz的系统时钟信号进行分频,得到频率为1000hz的信
源程序如下:
modulefenpin(inputCP,outputCPout);
regCPout;
reg[31:
0]Cout;
regCP_En;
always@(posedgeCP)//将50MHz分频为1kHz
begin
Cout<=(Cout==32'd50000)?
32'dO:
(Cout+32'd1);
CP_En<=(Cout==32'd50000)?
1'd1:
1'd0;
CPout<=CP_En;
end
endmodule
功能仿真波形如图2所示(以五分频为例):
CP
B0
AnnnnmnfmnonmjWLrLrLrLnrLnnnnjmnnjmnnR
°■rr—Pr—r
a
CFont
B0
i—|:
:
i—ii—ii—Ii—I:
:
l
JJ■1■■■1'I'l''iiiIIiIIl1■1■iii■1■1■ii■1
iiiiiiiiIi■1i1i・iii■■■■■■h%“iiIaiiii1ru
2.控制器和计数器
控制器的作用是,调整小时和分钟的值,并能实现清零功能。
计数器的
作用是实现分钟和秒钟满60进1,小时则由23跳到00。
当到达59分55秒的时
候,LED灯会闪烁来进行报时。
因为控制器和计数器的驱动信号频率均为1Hz,
故从分频器输出的信号进入控制器后,要进行二次分频,由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;
always@(posedgeCPout)
begin
if(S1==0)
begin
R1=1;
end
if(S2==0)
begin
R2=1;
end
if(RET==0)
begin
R8=1;
end
Cout=(Cout==32'd1000)?
32'd0:
(Cout+32'd1);Clk_En=(Cout==32'd1000)?
1'd1:
1'd0;if(Clk_En)
begin
if(R1==1)
begin
if(Hour<24)Hour=Hour+1;
if(Hour==24)
begin
Hour=0;
end
R1=0;
end
if(R2==1)
begin
if(Minute<60)
Minute=Minute+1;
if(Minute==60)
begin
Minute=0;
if(Hour<24)
Hour=Hour+1;if(Hour==24)begin
Hour=0;
end
end
R2=0;
end
if(Second<60)
Second=Second+1;
if(Second==60)
begin
Second=0;
if(Minute<60)
Minute=Minute+1;
if(Minute==60)
begin
Minute=0;
if(Hour<24)
Hour=Hour+1;
if(Hour==24)
begin
Hour=0;
end
end
end
if((Minute==59)&&(Second>55))//整点倒计时begin
if(LED==1)
LED=0;
else
LED=1;
end
else
LED=0;
if(R8==1)〃清零
begin
Hour=0;
Minute=0;
Second=0;
R8=0;
end
end
end
endmodule
功能仿真波形如图3所示:
3.显示器
显示器的作用是将时一分一秒的值在数码管上依次显示出来。
从分频器输出的1Khz的信号作为数码管的扫描信号。
SEL表示三个数码管选择位,它的取值表示八个数码管,从左至右依次是111~000。
LEDGA表示七段数码管,它的取值
决定特定位数上显示的数字。
■i・・
...B
Aiarishi
■i・b
z.__
__
CPfiutSLL[2..0)
irrAtiifnm
SU——J)注
_.jAUWAUMUWUKMM-MMLUlUUUUUUULMMaUMWUWU&BHMMWWUWUMMUi
^*r>LJ7F.rri、i可亦■需ii
1Hour[s..-Jj
「1
iWinutBlL.q
r■■
Lua
'S&c&rKj[5..0i]
-»--
i
i…
1…
i…•
inst
源程序如下:
modulexianshi(CPout,Hour,Minute,Second,SEL,LEDAG);
inputCPout;
inputHour,Minute,Second;outputSEL,LEDAG;
reg[2:
0]SEL;
reg[6:
0]Led;
reg[3:
0]shi1,ge1,shi2,ge2,shi3,ge3;
always@(posedgeCPout)begin
shiwei1=Hour/10;gewei仁Hour%10;
shiwei2=Minute/10;gewei2=Minute%10;shiwei3=Second/10;
gewei3=Second%10;if(SEL==3'b110)case(shiwei1)
//判断位选SEL勺值,并将此位上的值输出到数码管
4'b0000:
4'b0001:
4'b0010:
4'b0011:
4'b0100:
4'b0101:
4'b0110:
4'b0111:
4'b1000:
4'b1001:
default:
endcase
Led=7'b0111_111;
Led=7'b0000_110;
Led=7'b1011_011;
Led=7'b1001_111;
Led=7'b1100_110;
Led=7'b1101_101;
Led=7'b1111_101;
Led=7'b0000_111;
Led=7'b1111_111;
Led=7'b1101_111;
Led=7'b0000_000;
if(SEL==3'b101)
case(gewei1)
4'b0000:
4'b0001:
4'b0010:
4'b0011:
4'b0100:
4'b0101:
4'b0110:
4'b0111:
4'b1000:
4'b1001:
default:
endcase
Led=7'b0111_111;
Led=7'b0000_110;
Led=7'b1011_011;
Led=7'b1001_111;
Led=7'b1100_110;
Led=7'b1101_101;
Led=7'b1111_101;
Led=7'b0000_111;
Led=7'b1111_111;
Led=7'b1101_111;
Led=7'b0000_000;
if(SEL==3'b100)
Led=7'b1000_000;
if(SEL==3'b011)
case(shiwei2)
4'b0000:
4'b0001:
4'b0010:
4'b0011:
4'b0100:
4'b0101:
4'b0110:
4'b0111:
Led=7'b0111_111;
Led=7'b0000_110;
Led=7'b1011_011;
Led=7'b1001_111;
Led=7'b1100_110;
Led=
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Verilog 语言 编写 多功能 数字 docx
![提示](https://static.bdocx.com/images/bang_tan.gif)