vhdl課程設(shè)計(電子鐘+鬧鈴)_第1頁
vhdl課程設(shè)計(電子鐘+鬧鈴)_第2頁
vhdl課程設(shè)計(電子鐘+鬧鈴)_第3頁
vhdl課程設(shè)計(電子鐘+鬧鈴)_第4頁
vhdl課程設(shè)計(電子鐘+鬧鈴)_第5頁
已閱讀5頁,還剩10頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、數(shù)字鐘的設(shè)計一、系統(tǒng)功能概述(一)、系統(tǒng)實現(xiàn)的功能:1、具有“時”、“分”、“秒”的十進制數(shù)字顯示(小時從00 23)。2、具有手動校時、校分、校秒的功能。3、有定時和鬧鐘功能,能夠在設(shè)定的時間發(fā)出鬧鈴聲。4、能進行整點報時。從59分50秒起,每隔2秒發(fā)一次低音“嘟”的信號,連續(xù)5次,最后一次為高音“嘀”的信號。(二)、各項設(shè)計指標:1、顯示部分采用的6個LED顯示器,從高位至低位分別顯示時、分、秒。2、有一個設(shè)置調(diào)鬧鐘定時時間、正常時間的按鈕,選擇調(diào)的對象。3、有三個按鈕分別調(diào)時、分、秒的時間。4、有一個按鈕用作開啟/關(guān)閉鬧鈴。5、另外需要兩個時鐘信號來給系統(tǒng)提供脈沖信號,使時鐘和鬧鐘正常工

2、作,分別為1Hz、1kHz的脈沖。二、系統(tǒng)組成以及系統(tǒng)各部分的設(shè)計1、系統(tǒng)結(jié)構(gòu)描述 /要求:系統(tǒng)(或頂層文件)結(jié)構(gòu)描述,各個模塊(或子程序)的功能描述;(一) 系統(tǒng)的頂層文件:1、 頂層文件圖:(見下頁)2、 各模塊的解釋:(1)、7個輸入量clk_1khz、clk_1hz、key_slt、key_alarm、sec_set、min_set、hour_set:其中clk_1khz為鬧鈴模塊提供時鐘,處理后能產(chǎn)生“嘟”、“嘀”和變化的鬧鈴聲音;clk_1hz為計時模塊提供時鐘信號,每秒計數(shù)一次;key_slt選擇設(shè)置對象:定時或正常時間;key_alarm能夠開啟和關(guān)閉鬧鈴;sec_set、mi

3、n_set、hour_set用于設(shè)置時間或定時,與key_slt相關(guān)聯(lián)。各按鍵輸出為脈沖信號。(2)、CNT60_A_SEC模塊: 這個模塊式將clk_1hz這個時鐘信號進行60進制計數(shù),并產(chǎn)生一個分鐘的觸發(fā)信號。該模塊能將當(dāng)前計數(shù)值實時按BCD碼的格式輸出。將該輸出接到兩位LED數(shù)碼后能時時顯示秒的狀態(tài)。通過alarm_clk可以選擇設(shè)置對象為時間還是定時值。在設(shè)置時間模式上,key上的一個輸入脈沖可以將clk的輸入信號加一。在設(shè)置定時模式上,key上的脈沖只修改定時值,不影響時間脈沖clk的狀態(tài)。同時該模塊具有兩個輸出口out_do、out_di來觸發(fā)整點報時的“嘟”、“嘀”聲音。(3)、

4、CNT60_A_MIN模塊: 這個模塊式將CNT60_A_SEC的輸出信號進行60進制計數(shù),并產(chǎn)生一個時位的觸發(fā)信號。該模塊能將當(dāng)前計數(shù)值實時按BCD碼的格式輸出。將該輸出接到兩位LED數(shù)碼后能時時顯示分的狀態(tài)。通過alarm_clk可以選擇設(shè)置對象為時間還是定時值。在設(shè)置時間模式上,key上的一個輸入脈沖可以將clk的輸入信號加一。在設(shè)置定時模式上,key上的脈沖只修改定時值,不影響時間脈沖clk的狀態(tài)。 同時該模塊具有三個輸出口out_do、out_di、out_alarm來觸發(fā)整點報時的“嘟”、“嘀”、鬧鈴聲音。(4)、CNT24_A_HOUR模塊: 這個模塊式將CNT60_A_MIN的

5、輸出信號做24進制計數(shù)。該模塊能將當(dāng)前計數(shù)值實時按BCD碼的格式輸出。將該輸出接到兩位LED數(shù)碼后能時時顯示時的狀態(tài)。通過alarm_clk可以選擇設(shè)置對象為時間還是定時值。在設(shè)置時間模式上,key上的一個輸入脈沖可以將clk的輸入信號加一。在設(shè)置定時模式上,key上的脈沖只修改定時值,不影響時間脈沖clk的狀態(tài)。同時該模塊具有一個輸出口out_alarm來觸發(fā)整點報時的鬧鈴聲音。(5)、PWM_OUT模塊:該模塊為PWM產(chǎn)生模塊,通過EN可開啟和關(guān)閉PWM輸出。模塊根據(jù)CLK信號二分頻產(chǎn)生的高低音,并組合,能輸出三種聲音狀態(tài)“嘟”、“嘀”、鬧鈴。而該三種聲音要被秒、分、時的輸出觸發(fā)才能輸出P

6、WM。(二) 系統(tǒng)各個模塊的VHDL程序:(1)、CNT60_A_SEC模塊:程序源代碼如下:library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity cnt60_a_sec isport( clk,clr,enb: in std_logic;-clk:時鐘輸入信號,clr:清零端,enb:使能端 key: in std_logic;-輸入按鍵脈沖,調(diào)整鬧鈴定時或時間 alarm_clk: in std_logic;-1:alarm 0:clk -設(shè)置模式選擇:鬧鈴調(diào)節(jié)模式、時間調(diào)節(jié)模式 qo

7、ut_sl: out std_logic_vector(3 downto 0); -顯示輸出秒的低位 qout_sh: out std_logic_vector(3 downto 0);-顯示輸出秒的高位 co: out std_logic; -進位輸出,觸發(fā)分計數(shù)模塊 out_do: out std_logic;-在整點報時中輸出“嘟”觸發(fā)信號out_di: out std_logic -在整點報時中輸出“嘀”觸發(fā)信號);end;architecture a of cnt60_a_sec issignal qout2_l:std_logic_vector(3 downto 0);signal

8、 qout2_h:std_logic_vector(3 downto 0);signal alarm_l:std_logic_vector(3 downto 0);signal alarm_h:std_logic_vector(3 downto 0);signal clk1,clk2,tclk,aclk,ac_slt: std_logic;beginprocess(alarm_clk) -當(dāng)該端口輸入一個脈沖時,修改設(shè)置模式:時間調(diào)整或鬧鈴模式切換beginif alarm_clk'event and alarm_clk='1' thenif ac_slt='0

9、' then-如果為定時模式,將改為鬧鈴模式ac_slt<='1'elseac_slt<='0'end if;end if;end process;process(key,clk,ac_slt)-根據(jù)設(shè)置模式,處理key上的脈沖信號beginif ac_slt='0' then -時間調(diào)整模式aclk<='0'if clk='1' and key='1' then -clk=1則tclk<=0,通過挖洞方式添加一個脈沖tclk<='0'elsif

10、 clk='0' and key='1' then -clk=0,則tclk<=1,產(chǎn)生一個高電平,添加一脈沖tclk<='1'elsetclk<=clk;end if;elsif ac_slt='1' then -鬧鈴調(diào)整模式tclk<=clk;aclk<=key; -key上的脈沖直接修改鬧鈴定時值end if;end process;process(tclk,clr,enb) -60進制計數(shù),個位、十位放在兩個臨時變量中,表示秒的狀態(tài)beginif clr='1' then-cl

11、earing works at the state of high voltageqout2_l<="0000"qout2_h<="0000"elsif tclk'event and tclk='1' thenif enb='1' then-enable works at high voltageif qout2_l="1001" and qout2_h="0101" thenqout2_l<="0000"-a full mode is

12、completed and a carryout is generatedqout2_h<="0000"elsif qout2_l="1001" thenqout2_l<="0000"qout2_h<=qout2_h+1;elseqout2_l<=qout2_l+1;- in process of countingend if;end if;end if;end process; process(aclk,clr,enb)-修改鬧鈴的定時值beginif clr='1' then-clearin

13、g works at the state of high voltagealarm_l<="0000"alarm_h<="0000"elsif aclk'event and aclk='1' thenif enb='1' then-enable works at high voltageif alarm_l="1001" and alarm_h="0101" thenalarm_l<="0000"-a full mode is compl

14、eted and a carryout is generatedalarm_h<="0000"elsif alarm_l="0101" thenalarm_l<="0000"alarm_h<=alarm_h+1;elsealarm_l<=alarm_l+1;- in process of countingend if;end if;end if;end process; process(qout2_l,qout2_h,alarm_l,alarm_h,alarm_clk)- 產(chǎn)生進位,顯示時間或鬧鈴定時值begi

15、n if qout2_l="0000" and qout2_h="0000" thenco<='1'else co<='0'end if;if ac_slt='0' then - 顯示時間qout_sl<=qout2_l;qout_sh<=qout2_h;else - 顯示定時值qout_sh<=alarm_h;qout_sl<=alarm_l;end if;end process;process(qout2_l,qout2_h) - 根據(jù)秒的狀態(tài)輸出“嘟”、“嘀”觸發(fā)信

16、號beginif qout2_h="0101" thenif qout2_l="0000" thenout_do<='1'elsif qout2_l="0010" thenout_do<='1'elsif qout2_l="0100" thenout_do<='1'elsif qout2_l="0110" thenout_do<='1'elsif qout2_l="1000" thenou

17、t_do<='1'elseout_do<='0'end if;elsif qout2_h="0000" thenif qout2_l="0000" thenout_di<='1'out_do<='0'else out_di<='0'end if;elseout_do<='0'out_di<='0'end if;end process;end;(2)、CNT60_A_MIN模塊:library ieee;

18、use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity cnt60_a_min isport( clk,clr,enb: in std_logic; -clk:時鐘輸入信號,clr:清零端,enb:使能端 key: in std_logic; -輸入按鍵脈沖,調(diào)整鬧鈴定時或時間 alarm_clk: in std_logic; -1:alarm 0:clk -設(shè)置模式選擇:鬧鈴調(diào)節(jié)模式、時間調(diào)節(jié)模式 qout_ml: out std_logic_vector(3 downto 0); -顯示輸出分的低位 qout_m

19、h: out std_logic_vector(3 downto 0); -顯示輸出分的高位 co: out std_logic; -進位輸出,觸發(fā)時計數(shù)模塊 out_alarm:out std_logic;-鬧鈴觸發(fā)信號,時間到后輸出高電平觸發(fā)鬧鈴out_do,out_di: out std_logic-在整點報時中輸出“嘟”“嘀”觸發(fā)信號);end;architecture a of cnt60_a_min issignal qout2_l:std_logic_vector(3 downto 0);signal qout2_h:std_logic_vector(3 downto 0);si

20、gnal alarm_l:std_logic_vector(3 downto 0);signal alarm_h:std_logic_vector(3 downto 0);signal clk1,clk2,tclk,aclk,ac_slt: std_logic;beginprocess(alarm_clk) -當(dāng)該端口輸入一個脈沖時,修改設(shè)置模式:時間調(diào)整或鬧鈴模式切換beginif alarm_clk'event and alarm_clk='1' thenif ac_slt='0' then-如果為定時模式,將改為鬧鈴模式ac_slt<=

21、9;1'elseac_slt<='0'end if;end if;end process;process(key,clk,ac_slt) -根據(jù)設(shè)置模式,處理key上的脈沖信號beginif ac_slt='0' then -時間調(diào)整模式aclk<='0'if clk='1' and key='1' then-clk=1則tclk<=0,通過挖洞方式添加一個脈沖tclk<='0'elsif clk='0' and key='1' the

22、n-clk=0,則tclk<=1,產(chǎn)生一個高電平,添加一脈沖tclk<='1'elsetclk<=clk;end if;elsif ac_slt='1' then -鬧鈴調(diào)整模式tclk<=clk;aclk<=key; -key上的脈沖直接修改鬧鈴定時值end if;end process; process(tclk,clr,enb) -60進制計數(shù),個位、十位放在兩個臨時變量中,表示分的狀態(tài)beginif clr='1' then-clearing works at the state of high voltag

23、eqout2_l<="0000"qout2_h<="0000"elsif tclk'event and tclk='1' thenif enb='1' then-enable works at high voltageif qout2_l="1001" and qout2_h="0101" thenqout2_l<="0000"-a full mode is completed and a carryout is generatedqou

24、t2_h<="0000"elsif qout2_l="1001" thenqout2_l<="0000"qout2_h<=qout2_h+1;elseqout2_l<=qout2_l+1;- in process of countingend if;end if;end if;end process; process(aclk,clr,enb) -修改鬧鈴的定時值beginif clr='1' then-clearing works at the state of high voltageala

25、rm_l<="0000"alarm_h<="0000"elsif aclk'event and aclk='1' thenif enb='1' then-enable works at high voltageif alarm_l="1001" and alarm_h="0101" thenalarm_l<="0000"-a full mode is completed and a carryout is generatedalarm_h

26、<="0000"elsif alarm_l="0101" thenalarm_l<="0000"alarm_h<=alarm_h+1;elsealarm_l<=alarm_l+1;- in process of countingend if;end if;end if;end process; process(qout2_l,qout2_h,alarm_l,alarm_h,alarm_clk) - 產(chǎn)生進位,顯示時間或鬧鈴定時值of high voltagebegin if qout2_l="0000

27、" and qout2_h="0000" thenco<='1'else co<='0'end if;if ac_slt='0' thenqout_ml<=qout2_l;qout_mh<=qout2_h;elseqout_mh<=alarm_h;qout_ml<=alarm_l;end if;end process;process(qout2_l,qout2_h,alarm_l,alarm_h) 判斷定時值與時間值相等,輸出鬧鈴觸發(fā)信號begin if qout2_l=alarm

28、_l and qout2_h=alarm_h thenout_alarm<='1'elseout_alarm<='0'end if;end process;process(qout2_l,qout2_h) - 根據(jù)分的狀態(tài)輸出“嘟”、“嘀”觸發(fā)信號beginif qout2_l="1001" and qout2_h="0101" thenout_do<='1'elseout_do<='0'end if;if qout2_l="0000" and q

29、out2_h="0000" thenout_di<='1'elseout_di<='0'end if;end process;end;(3)、CNT24_A_HOUR模塊:library ieee;use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;entity cnt24_a_hour isport( clk,clr,enb: in std_logic; -clk:時鐘輸入信號,clr:清零端,enb:使能端 key: in std_logic; -輸入按鍵脈沖

30、,調(diào)整鬧鈴定時或時間 alarm_clk: in std_logic;-1:alarm 0:clk-設(shè)置模式選擇:鬧鈴調(diào)節(jié)模式、時間調(diào)節(jié)模式 qout_hl: out std_logic_vector(3 downto 0); -顯示輸出時的低位 qout_hh: out std_logic_vector(3 downto 0); -顯示輸出時的高位 co: out std_logic; -進位輸出 out_alarm:out std_logi-鬧鈴觸發(fā)信號輸出);end;architecture a of cnt24_a_hour issignal qout2_l:std_logic_vec

31、tor(3 downto 0);signal qout2_h:std_logic_vector(3 downto 0);signal alarm_l:std_logic_vector(3 downto 0);signal alarm_h:std_logic_vector(3 downto 0);signal clk1,clk2,tclk,aclk,ac_slt: std_logic;beginprocess(alarm_clk) -當(dāng)該端口輸入一個脈沖時,修改設(shè)置模式:時間調(diào)整或鬧鈴模式切換beginif alarm_clk'event and alarm_clk='1'

32、; thenif ac_slt='0' then-如果為定時模式,將改為鬧鈴模式ac_slt<='1' elseac_slt<='0'end if;end if;end process;process(key,clk,ac_slt) -根據(jù)設(shè)置模式,處理key上的脈沖信號beginif ac_slt='0' then -時間調(diào)整模式aclk<='0'if clk='1' and key='1' then-clk=1則tclk<=0,通過挖洞方式添加一個脈沖tc

33、lk<='0'elsif clk='0' and key='1' then-clk=0,則tclk<=1,產(chǎn)生一個高電平,添加一脈沖tclk<='1'elsetclk<=clk;end if;elsif ac_slt='1' then -鬧鈴調(diào)整模式tclk<=clk;aclk<=key; -key上的脈沖直接修改鬧鈴定時值end if;end process; process(tclk,clr,enb) -24進制計數(shù),個位、十位放在兩個臨時變量中,表示時的狀態(tài)beginif

34、clr='1' then-clearing works at the state of high voltageqout2_l<="0000"qout2_h<="0000"elsif tclk'event and tclk='1' thenif enb='1' then-enable works at high voltageif qout2_l="1001" thenqout2_l<="0000"-a full mode is comple

35、ted and a carryout is generatedqout2_h<=qout2_h+1;elsif qout2_l="0011" and qout2_h="0010" thenqout2_l<="0000"qout2_h<="0000"elseqout2_l<=qout2_l+1;- in process of countingend if;end if;end if;end process; process(aclk,clr,enb) -修改鬧鈴的定時值beginif clr=

36、'1' then-clearing works at the state of high voltagealarm_l<="0000"alarm_h<="0000"elsif aclk'event and aclk='1' thenif enb='1' then-enable works at high voltageif alarm_l="1001" thenalarm_l<="0000"-a full mode is completed

37、and a carryout is generatedalarm_h<=qout2_h+1;elsif alarm_l="0011" and alarm_h="0010" thenalarm_l<="0000"alarm_h<="0000"elsealarm_l<=alarm_l+1;- in process of countingend if;end if;end if;end process; process(qout2_l,qout2_h,alarm_l,alarm_h,alarm_c

38、lk) - 產(chǎn)生進位,顯示時間或鬧鈴定時值of high voltagebegin if qout2_l="0000" and qout2_h="0000" thenco<='1'else co<='0'end if;if ac_slt='0' thenqout_hl<=qout2_l;qout_hh<=qout2_h;elseqout_hh<=alarm_h;qout_hl<=alarm_l;end if;end process;process(qout2_l,qout

39、2_h,alarm_l,alarm_h)-定時值與時間值相等,則輸出鬧鐘觸發(fā)信號begin if qout2_l=alarm_l and qout2_h=alarm_h thenout_alarm<='1'elseout_alarm<='0'end if;end process;end;2、系統(tǒng)以及各個模塊的仿真波形(1)、系統(tǒng)仿真波形:注:由于下面的模塊仿真存在毛刺,導(dǎo)致系統(tǒng)的仿真圖有一定的問題。(2)、CNT60_A_SEC模塊:注:在50、52、54、56、58處有嘟觸發(fā)輸出,00處有嘀觸發(fā)輸出等。(3)、CNT60_A_MIN模塊:注:本圖展示了按鍵調(diào)節(jié)時間值和定時值的仿真波形(部分仿真圖)。注:該模塊的仿真波形圖,具有嘟、嘀聲音觸發(fā)輸出,定時與時間相等時有鬧鈴觸發(fā)輸出等。(4)、CNT24_A_HOUR模塊注:該模塊的仿真圖,包含按鍵調(diào)整時間、定時值,鬧鐘觸發(fā)輸出等。(5)、PWM_OUT模塊(分三段剪切下來的,展

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論