基于VHDL的多功能数字钟设计报告Word格式文档下载.docx
《基于VHDL的多功能数字钟设计报告Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《基于VHDL的多功能数字钟设计报告Word格式文档下载.docx(16页珍藏版)》请在冰豆网上搜索。
(二)校时:
在计时显示状态下,按下“k”键,进入“小时”待校准状态,若此时按下“set”键,小时开始校准;
之后按下“k”键则进入“分”待校准状态;
继续按下“k”键则进入“秒”待复零状态;
再次按下“k”键数码管显示闹钟时间,并进入闹钟“小时”待校准状态;
再次按下“k”键则进入闹钟“分”待校准状态;
若再按下“k”键恢复到正常计时显示状态。
若校时过程中按下“reset”键,则系统恢复到正常计数状态。
(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组输入信号和输出信号进而实现了时钟时、分的动态显示。
useieee.std_log