基于VHDL的多功能数字钟设计报告剖析Word文档下载推荐.docx
《基于VHDL的多功能数字钟设计报告剖析Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《基于VHDL的多功能数字钟设计报告剖析Word文档下载推荐.docx(16页珍藏版)》请在冰豆网上搜索。
(1)“小时”校准状态:
在“小时”校准状态下,显示“小时”的数码管以2Hz闪烁,并按下“set”键时以2Hz的频率递增计数。
(2)“分”校准状态:
在“分”校准状态下,显示“分”的数码管以2Hz闪烁,并按下“set”键时以2Hz的频率递增计数。
(3)“秒”校准状态:
在“秒复零”状态下,显示“秒”的数码管以2Hz闪烁,并以1Hz的频率递增计数。
(4)闹钟“小时”校准状态:
在闹钟“小时”校准状态下,显示“小时”的数码管以2Hz闪烁,并按下“set”键时以2Hz的频率递增计数。
(5)闹钟“分”校准状态:
在闹钟“分”校准状态下,显示“分”的数码管以2Hz闪烁,并按下“set”键时以2Hz的频率递增计数。
(三)整点报时:
蜂鸣器在“59”分钟的第“51”、“53”、“55”、“57”秒发频率为500Hz的低音,在“59”分钟的第“59”秒发频率为1000Hz的高音,结束时为整点。
(四)显示:
采用扫描显示方式驱动4个LED数码管显示小时、分,秒由两组led灯以4位BCD码显示。
(五)闹钟:
闹钟定时时间到,蜂鸣器发出频率为1000Hz的高音,持续时间为60秒。
四、各个模块分析说明
1、分频器模块(freq.vhd)
(1)模块说明:
输入一个频率为50MHz的CLK,利用计数器分出
1KHz的q1KHz,500Hz的q500Hz,2Hz的q2Hz和1Hz的q1Hz。
(2)源程序:
libraryieee;
useieee.std_logic_1164.all;
useieee.std_logic_unsigned.all;
entityfreqis
port(CLK:
instd_logic;
--输入时钟信号
q1KHz:
bufferstd_logic;
q500Hz:
q2Hz:
q1Hz:
outstd_logic);
endfreq;
architecturebhvoffreqis
begin
P1KHZ:
process(CLK)
variablecout:
integer:
=0;
begin
ifCLK'
eventandCLK='
1'
then
cout:
=cout+1;
--每来个时钟上升沿时cout开始计数
ifcout<
=25000thenq1KHz<
='
0'
;
--当cout<
=25000时,q1KHz输出“0”
elsifcout<
50000thenq1KHz<
--当25000<
cout<
=50000时,q1KHz
elsecout:
--输出“1”,完成1KHz频率输出
endif;
endprocess;
P500HZ:
process(q1KHz)--q1KHz作为输入信号,分出q500Hz
ifq1KHz'
eventandq1KHz='
then
ifcout=1thenq500Hz<
--二分频
elsifcout=2thencout:
q500Hz<
P2HZ:
process(q500Hz)
ifq500Hz'
eventandq500Hz='
=125thenq2Hz<
250thenq2Hz<
P1HZ:
process(q2Hz)
ifq2Hz'
eventandq2Hz='
ifcout=1thenq1Hz<
q1Hz<
endbhv;
(3)模块图:
2、控制器模块(contral.vhd)
输入端口k,set键来控制6个状态,这六个状态分别是:
显示计时时间状态,调计时的时、分、秒的3个状态,调闹铃的时、分的3个状态,reset键是复位键,用来回到显示计时时间的状态。
(2)波形仿真图:
(3)模块图:
3、二选一模块(mux21a.vhd)
(1)源程序:
entitymux21ais
port(a,b,s:
inbit;
y:
outbit);
endentitymux21a;
architectureoneofmux21ais
process(a,b,s)
ifs='
y<
=a;
--若s=0,y输出a,反之输出b。
elsey<
=b;
endarchitectureone;
(2)仿真波形图:
4、计时模块
a.秒计时(second.vhd)
(1)仿真波形图:
(2)模块图:
b.分计时(minute.vhd)
c.小时计时(hour.vhd)
(1)仿真波形图:
d.闹钟分计时(cntm60b.vhd)
e.闹钟小时计时(cnth24b.vhd)
(2)模块图:
5、闹钟比较模块(compare.vhd)
比较正常计数时间与闹钟定时时间是否相等,若相等,compout输出“1”,反之输出“0”。
6、报时模块(bell.vhd)
该模块既实现了整点报时的功能,又实现了闹铃的功能,蜂鸣器通过所选频率的不同,而发出不同的声音。
7、控制显示模块(show_con.vhd)
该模块实现了数码管既可以显示正常时间,又可以显示闹钟时间的功能;
调时过程的定时闪烁功能也在此模块中真正实现。
entityshow_conis
port(th1,tm1,ts1:
instd_logic_vector(7downto4);
th0,tm0,ts0:
instd_logic_vector(3downto0);
bh1,bm1:
bh0,bm0:
sec1,min1,h1:
outstd_logic_vector(7downto4);
sec0,min0,h0:
outstd_logic_vector(3downto0);
q2Hz,flashs,flashh,flashm,sel_show:
instd_logic);
endshow_con;
architecturertlofshow_conis
process(th1,tm1,ts1,th0,tm0,ts0,bh1,bm1,bh0,bm0,q2Hz,flashs,flashh,flashm,sel_show)
begin
ifsel_show='
then
if(flashh='
andq2Hz='
)then
h1<
="
1111"
h0<
--显示小时数码管以2Hz闪烁
min1<
=tm1;
min0<
=tm0;
sec1<
=ts1;
sec0<
=ts0;
elsif(flashm='
=th1;
=th0;
elsif(flashs='
else
endif;
elsifsel_show='
then--若sel_show为“1”,数码管显示闹钟时间
if(flashh='
andq2Hz='
=bm1;
=bm0;
0000"
elsif(flashm='
=bh1;
=bh0;
endif;
endprocess;
endrtl;
8、动态扫描显示模块(scan_led.vhd)
由4组输入信号和输出信号进而实现了时钟时、分的动态显示。
entityscan_ledis
port(clk1:
instd_logic;
h0:
h1:
min0:
min1:
ML:
outstd_logic_vector(7downto0);
MH:
HL:
HH:
outstd_logic_vector(7downto0)
);
endscan_led;
architectureoneofscan_ledis
signalcnt4:
std_logic_vector(1downto0);
signala:
std_logic_vector(3downto0);
p1:
process(clk1)
ifclk1'
eventandclk1='
cnt4<
=cnt4+1;
ifcnt4=3then
00"
endprocessp1;
p2:
process(cnt4,h1,h0,min1,min0)
casecnt4is--控制数码管位选
when"
=>
casemin0is
when"
ML<
11000000"
0001"
11111001"
0010"
10100100"
when"
0011"
10110000"
0100"
10011001"
0101"
10010010"
0110"
10000010"
0111"
11111000"
1000"
10000000"
1001"
10010000"
whenothers=>
NULL;
endcase;
01"
casemin1is
MH<
10"
caseh0is
HL<
11"
caseh1is
HH<
whenothers=>
null;
endcase;
endprocessp2;
endone;
5、端口设定
k:
button2,set:
button1,reset:
button0;
Bell:
SW1用于开关蜂鸣器;
六、顶层电路图
7、心得体会
此次的数字钟设计重在于按键的控制和各个模块代码的编写,虽然能把键盘接口和各个模块的代码编写出来,并能正常显示,但对于各个模块的优化设计还有一定的缺陷和不足,比如对按键消抖等细节处并未作出优化。
经过此次数字钟的设计,我确实从中学到很多的东西。
首先,通过VHDL硬件语言的学习,我充分认识到了功能模块如何用语言实现,让我初步了解到了一个数字电路用硬件语言设计的方式和设计思想。
其次,也让我深深地体会到实践的重要性,起初我学VHDL语言的时候,只是学得书本上的知识,经过这次课程设计,通过对模块的语言实现,对于VHDL语言我有了更深的认识。
而且在程序错误的发现和改正的过程中,我得到了更多的收获,也确实让我进步了不少。
再次,当我遇到一些问题的时候,请教老师,和同学们一起讨论,令我受益颇多!
最后,这个多功能数字电子钟是自我创造与吸取借鉴共同作用的产物,是自我努力的结果。
这让我对数字电路的设计充满了信心。
虽然课程设计已经结束,但这并不代表着我已经真正掌握了VHDL语言,仍需继续学习!