電子鐘課程設(shè)計(jì)報告--數(shù)字鐘設(shè)計(jì)_第1頁
已閱讀1頁,還剩7頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p><b>  題目:數(shù)字鐘設(shè)計(jì)</b></p><p><b>  一、實(shí)驗(yàn)?zāi)康?lt;/b></p><p>  學(xué)習(xí)并掌握數(shù)字鐘的原理、設(shè)計(jì)方法。</p><p><b>  二、實(shí)驗(yàn)內(nèi)容</b></p><p>  計(jì)數(shù)時鐘由模60秒計(jì)數(shù)器、模60分計(jì)數(shù)器、模2

2、4小時計(jì)數(shù)器、報時模塊、分、時校定模塊及輸出顯示模塊構(gòu)成。可以采用同步計(jì)數(shù)器或異步計(jì)數(shù)器設(shè)計(jì)方法。</p><p><b>  三、實(shí)驗(yàn)要求</b></p><p>  1. 計(jì)時范圍為0小時0分0秒至23小時59分59秒</p><p>  2. 采用6個8段數(shù)碼管分別顯示小時十位,小時個位、分鐘十位、分鐘個位、秒十位、秒個位。</p&

3、gt;<p>  3. 整點(diǎn)報時,蜂鳴器響5聲,每秒1聲。</p><p>  4. 校時功能,能夠單獨(dú)校分、校時。用按鍵控制。</p><p>  5. 具有清零、啟動/停止計(jì)數(shù)的功能。用按鍵控制。</p><p><b>  四、實(shí)驗(yàn)原理</b></p><p>  數(shù)字鐘的基本原理是采用時鐘源提供的頻

4、率作為秒模塊的時鐘進(jìn)行計(jì)數(shù),當(dāng)秒模塊計(jì)數(shù)達(dá)到59秒時為分模塊提供時鐘,該時鐘通過狀態(tài)選擇模塊送到分模塊,同理,分模塊向小時模塊提供時鐘時也是如此。整點(diǎn)報時模塊是利用分鐘向小時的進(jìn)位時鐘脈沖作為觸發(fā)源,利用秒的個位計(jì)時以及實(shí)驗(yàn)板提供的時鐘源頻率達(dá)到報時五秒的目的。譯碼顯示模塊則通過8421BCD碼與數(shù)碼管各段的關(guān)系進(jìn)行轉(zhuǎn)化,由于實(shí)驗(yàn)板不支持動態(tài)掃描所以需在秒,分,時的個位與十位都添加譯碼顯示模塊。</p><p>

5、<b>  原理框圖如下:</b></p><p><b>  五、模塊設(shè)計(jì)</b></p><p><b>  秒計(jì)數(shù)模塊</b></p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p>

6、<p>  use ieee.std_logic_unsigned.all;</p><p>  entity second is</p><p>  port(clk,rst:in std_logic;</p><p>  enmin:out std_logic;</p><p>  shiwei:out std_logic_

7、vector(3 downto 0);</p><p>  gewei:out std_logic_vector(3 downto 0));</p><p>  end entity second;</p><p>  architecture rtl of second is</p><p>  signal a,b:std_logic_

8、vector(3 downto 0);</p><p>  signal c:std_logic_vector(7 downto 0);</p><p><b>  begin</b></p><p>  c<=b&a; </p><p>  process(clk,rst,c)</p&

9、gt;<p><b>  begin</b></p><p>  if(rst='1')then</p><p>  a<="0000";</p><p>  b<="0000";</p><p>  enmin<='0

10、9;;</p><p>  elsif(clk'event and clk='1')then</p><p><b>  a<=a+1;</b></p><p>  if(a="1001")then</p><p>  a<="0000";<

11、;/p><p><b>  b<=b+1;</b></p><p>  if(b="0101")then</p><p>  b<="0000";</p><p><b>  end if;</b></p><p><b&

12、gt;  end if;</b></p><p><b>  end if;</b></p><p><b>  case c is</b></p><p>  when "01011001"=>enmin<='1';</p><p>  

13、when others=>enmin<=null;</p><p>  end case; </p><p>  end process;</p><p><b>  gewei<=a;</b></p><p>  shiwei<=b;</p><p>  end arc

14、hitecture rtl;</p><p><b>  其模塊仿真圖為:</b></p><p><b>  分計(jì)數(shù)模塊</b></p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p> 

15、 use ieee.std_logic_unsigned.all;</p><p>  entity minute is</p><p>  port(clk,rst:in std_logic;</p><p>  enhour:out std_logic;</p><p>  mshiwei:out std_logic_vector(3 d

16、ownto 0);</p><p>  mgewei:out std_logic_vector(3 downto 0));</p><p>  end entity minute;</p><p>  architecture rtl of minute is</p><p>  signal m,n:std_logic_vector(3 d

17、ownto 0);</p><p>  signal c:std_logic_vector(7 downto 0);</p><p><b>  begin</b></p><p>  c<=n&m; </p><p>  process(clk,rst,c)</p><p>

18、<b>  begin</b></p><p>  if(rst='1')then</p><p>  m<="0000";</p><p>  n<="0000";</p><p>  enhour<='0';</p>

19、<p>  elsif(clk'event and clk='1')then</p><p><b>  m<=m+1;</b></p><p>  if(m="1001")then</p><p>  m<="0000";</p><

20、p><b>  n<=n+1;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  if(c="01011001")then </p><p>  n<=&qu

21、ot;0000";</p><p>  m<="0000";</p><p><b>  end if;</b></p><p><b>  case c is</b></p><p>  when "01011001"=>enhour&

22、lt;='1';</p><p>  when others=>enhour<=null;</p><p>  end case; </p><p>  end process; </p><p>  mgewei<=m;</p><p>  msh

23、iwei<=n;</p><p>  end architecture rtl;</p><p><b>  其模塊仿真圖為:</b></p><p><b>  時計(jì)數(shù)模塊</b></p><p>  library ieee;</p><p>  use ieee.

24、std_logic_1164.all;</p><p>  use ieee.std_logic_unsigned.all;</p><p>  entity hour is</p><p>  port(clk,rst:in std_logic;</p><p>  hshiwei:out std_logic_vector(3 downto

25、 0);</p><p>  hgewei:out std_logic_vector(3 downto 0));</p><p>  end entity hour;</p><p>  architecture rtl of hour is</p><p>  signal p,q:std_logic_vector(3 downto 0)

26、;</p><p><b>  begin</b></p><p>  process(clk,rst)</p><p><b>  begin</b></p><p>  if(rst='1')then</p><p>  p<="0000&

27、quot;;</p><p>  q<="0000";</p><p>  elsif(clk'event and clk='1')then</p><p><b>  p<=p+1;</b></p><p>  if(p="1001")then

28、</p><p>  p<="0000";</p><p><b>  q<=q+1; </b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  

29、if(q="0010" and p="0100")then</p><p>  p<="0000";</p><p>  q<="0000"; </p><p><b>  end if;</b></p><p> 

30、 end process;</p><p>  hgewei<=p;</p><p>  hshiwei<=q;</p><p>  end architecture rtl; </p><p><b>  其模塊仿真圖為:</b></p><p><b>  狀態(tài)選擇模塊

31、</b></p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic_unsigned.all;</p><p>  entity set is</p><p>  port(sel:

32、in std_logic;</p><p>  clk:in std_logic;</p><p>  key:in std_logic;</p><p>  y:out std_logic);</p><p>  end entity set;</p><p>  architecture rtl of set is

33、</p><p>  signal a:std_logic;</p><p><b>  begin</b></p><p>  process(sel)is</p><p><b>  begin</b></p><p>  case sel is</p>&

34、lt;p>  when '0'=>a<=clk;</p><p>  when '1'=>a<=key;</p><p>  when others=>a<=clk;</p><p><b>  end case;</b></p><p><

35、b>  y<=a;</b></p><p>  end process;</p><p>  end architecture rtl;</p><p><b>  其模塊仿真圖為:</b></p><p><b>  整點(diǎn)報時模塊</b></p><p&

36、gt;  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic_unsigned.all;</p><p>  entity alert is</p><p>  port(clk:in std_logic;</p>&

37、lt;p>  d:in std_logic_vector(3 downto 0);</p><p>  en:in std_logic;</p><p>  alarm:out std_logic);</p><p>  end entity alert;</p><p>  architecture rtl of alert is&l

38、t;/p><p>  signal enalarm:std_logic;</p><p><b>  begin</b></p><p>  alarm<=enalarm;</p><p>  process(clk,en,d)</p><p><b>  begin</b>

39、;</p><p>  if(en='1')then</p><p>  enalarm<=clk;</p><p><b>  end if;</b></p><p>  if(d="0101")then</p><p>  enalarm<=&#

40、39;0'; </p><p><b>  end if;</b></p><p>  end process;</p><p>  end architecture rtl;</p><p><b>  其模塊仿真圖為:</b></p><p><b> 

41、 譯碼顯示模塊</b></p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic_unsigned.all;</p><p>  entity deled is</p><p>  

42、port(num: in std_logic_vector(3 downto 0);</p><p>  led:out std_logic_vector(6 downto 0));</p><p>  end entity deled;</p><p>  architecture rtl of deled is</p><p><b

43、>  begin</b></p><p>  led<="1111110"when num="0000"else</p><p>  "0110000"when num="0001"else </p><p>  "1101101"when n

44、um="0010"else</p><p>  "1111001"when num="0011"else</p><p>  "0110011"when num="0100"else</p><p>  "1011011"when num=&quo

45、t;0101"else</p><p>  "1011111"when num="0110"else</p><p>  "1110000"when num="0111"else</p><p>  "1111111"when num="1000&

46、quot;else</p><p>  "1111011"when num="1001"else</p><p>  "1110111"when num="1010"else</p><p>  "0011111"when num="1011"el

47、se</p><p>  "1001110"when num="1100"else</p><p>  "0111101"when num="1101"else</p><p>  "1001111"when num="1110"else</

48、p><p>  "1000111"when num="1111";</p><p>  end architecture rtl;</p><p><b>  其模塊仿真圖為:</b></p><p><b>  總仿真圖為:</b></p><

49、;p><b>  六、總結(jié)</b></p><p>  這次數(shù)字鐘的設(shè)計(jì)綜合運(yùn)用了VHDL語言,提高與加強(qiáng)了自己的VHDL語言的運(yùn)用能力,加強(qiáng)了對語法,詞法,結(jié)構(gòu)的理解,以及對硬件結(jié)構(gòu)的理解。同時,認(rèn)識到課程設(shè)計(jì)是一個細(xì)致,需要耐心的過程,如果考慮不夠可能導(dǎo)致能個結(jié)構(gòu)錯誤,所以設(shè)計(jì)前需要認(rèn)真的思考結(jié)構(gòu),語句是否有錯誤,及時改正才能提高效率,所以嚴(yán)謹(jǐn)?shù)膽B(tài)度與扎實(shí)的知識是設(shè)計(jì)成功的關(guān)鍵。&

溫馨提示

  • 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. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論