課程設(shè)計--基于fpga的數(shù)字鐘設(shè)計_第1頁
已閱讀1頁,還剩34頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  課程設(shè)計</b></p><p>  名稱 基于FPGA的數(shù)字鐘設(shè)計</p><p>  姓名 </p><p>  專業(yè)班級 通信工程(1)班</p><p>  學(xué)院 信息與機電工程學(xué)院 </p><p>

2、;  完成日期 2017年6月</p><p><b>  摘 要</b></p><p>  VHDL是一種用形式化方法來描述數(shù)字化電路和設(shè)計數(shù)字邏輯系統(tǒng)的語言,設(shè)計者可以利用這種語言來描述自己的設(shè)計思想,然后利用電子設(shè)計自動化工具進行仿真,再自動綜合到門級電路,最后用PLD實現(xiàn)其功能。與傳統(tǒng)設(shè)計方法相比,VHDL描述電路行為的算法設(shè)計層次較高、用于較復(fù)雜的計算時

3、,能盡早發(fā)現(xiàn)存在的問題,縮短設(shè)計周期,可獨立實現(xiàn),修改方便,系統(tǒng)硬件描述能力強,語言標準、規(guī)范、移植性強,是多層次的硬件描述語言具有很好的實用。</p><p>  本文是基于VHDL語言的簡易電子數(shù)字鐘的設(shè)計。設(shè)計主要是由數(shù)碼管結(jié)合按鍵來顯示相應(yīng)的時間,可以對時、分進行單獨校時,使其顯示標準時間,并且具有設(shè)置鬧鐘以及整點半點報時的功能??偟某绦蛴蓭讉€各具不同功能的單元模塊組,其中包括分頻模塊、時分秒計數(shù)和設(shè)置模

4、塊、比較器模塊、譯碼顯示等模塊。</p><p>  關(guān)鍵詞:數(shù)字鐘、VHDL、狀態(tài)機</p><p><b>  一、緒論</b></p><p><b>  1.1 前言</b></p><p>  隨著生產(chǎn)和科學(xué)技術(shù)發(fā)展的需要,現(xiàn)在電子技術(shù)的應(yīng)用已經(jīng)滲透到了人類生活和生產(chǎn)的各個方面,有力地推動

5、了社會生產(chǎn)力的發(fā)展和社會信息化程度的提高,同時也使現(xiàn)代電子產(chǎn)品性能進一步提高,產(chǎn)品更新?lián)Q代的節(jié)奏也越來越快。</p><p>  在這個生活節(jié)奏飛快的社會,時間概念對人們來說尤為重要。在我們現(xiàn)代的生活中,早已離不開鐘表的身影。原始的機械鐘只能實現(xiàn)走時報時的功能早已不能滿足人們的需求。數(shù)字鐘是一種數(shù)字電路實現(xiàn)時、分、秒計時的裝置,通過計時精度很高的石英晶振,采用相應(yīng)進制的計數(shù)器,轉(zhuǎn)化為二進制數(shù),通過譯碼和顯示電路準

6、確的將時間“時”“分”“秒”用數(shù)字的方式顯示出來。與傳統(tǒng)的機械時鐘相比具有更高的準確性與直觀性,且無機械裝置,具有更高的使用壽命。</p><p>  鐘表的數(shù)字化給人們生產(chǎn)生活帶來了極大的方便,而且大大地擴展了鐘表原先的報時功能。諸如定時自動報警、按時自動打鈴、時間程序自動控制、定時廣播、定時啟閉電路、定時開關(guān)烘箱、通斷動力設(shè)備,甚至各種定時電氣的自動啟用等,所有這些,都是以鐘表數(shù)字化為基礎(chǔ)的。因此,研究數(shù)字鐘

7、及擴大其應(yīng)用,有著非?,F(xiàn)實的意義。</p><p><b>  FPGA概述</b></p><p><b>  FPGA簡介</b></p><p>  FPGA是英文Field-Programmable Gate Array的縮寫,即現(xiàn)場可編程門陣列,是由存放在片內(nèi)RAM中的程序來設(shè)置其工作狀態(tài)的,因此,工作時需要對片

8、內(nèi)的RAM進行編程。用戶可以根據(jù)不同的配置模式,采用不同的編程方式。加電時,F(xiàn)PGA芯片將EPROM中數(shù)據(jù)讀入片內(nèi)編程RAM中,配置完成后,F(xiàn)PGA進入工作狀態(tài)。掉電后,F(xiàn)PGA恢復(fù)成白片,內(nèi)部邏輯關(guān)系消失,因此,F(xiàn)PGA能夠反復(fù)使用。FPGA的編程無須專用的FPGA編程器,只須用通用的EPROM、PROM編程器即可。當(dāng)需要修改FPGA功能時,只需換一片EPROM即可。這樣,同一片F(xiàn)PGA,不同的編程數(shù)據(jù),可以產(chǎn)生不同的電路功能。因此,

9、FPGA的使用非常靈活。 FPGA有多種配置模式:并行主模式為一片F(xiàn)PGA加一片EPROM的方式;主從模式可以支持一片PROM編程多片F(xiàn)PGA;串行模式可以采用串行PROM編程FPGA;外設(shè)模式可以將FPGA作為微處理器的外設(shè),由微處理器對其編程。</p><p>  1.2.2用FPGA設(shè)計數(shù)字鐘的優(yōu)點</p><p>  FPGA的邏輯功能全部用硬件電路實現(xiàn),內(nèi)部有豐富的觸發(fā)器和I/O

10、引腳,是ASIC電路中設(shè)計周期最短、開發(fā)費用最低、風(fēng)險最小的器件之一,并且FPGA采用高速CHMOS工藝,功耗低,可以與CMOS、TTL電平兼容。因此,F(xiàn)PGA芯片是小批量系統(tǒng)提高系統(tǒng)集成度、可靠性的最佳選擇之一。使用FPGA 可以實現(xiàn)你想實現(xiàn)的任何數(shù)字電路,可以定制各種電路,減少受制于專用芯片的束縛,在設(shè)計過程中可以靈活的更改設(shè)計。因此,利用FPGA 設(shè)計數(shù)字鐘更加靈活方便。</p><p>  1.3硬件描述

11、語言VHDL</p><p>  VHDL,即超高速集成電路硬件描述語言,是最早被接納為IEEE標準的硬件描述語言。它是一種多層次的硬件描述語言,覆蓋面廣,描述能力強,具有良好的可讀性,既可以被計算機接受,也容易被理解。因為VHDL的硬件描述與工藝技術(shù)無關(guān),因此其本身的生命期長,工藝改變時,只需修改相應(yīng)程序中的屬性參數(shù)即可,VHDL支持大規(guī)模設(shè)計的分解與已有設(shè)計的再利用,事實上已經(jīng)成為通用硬件描述語言。</

12、p><p>  1.4 QuartusⅡ軟件</p><p>  QuartusⅡ是Altera公司推出的新一代FPGA/CPLD開發(fā)軟件,適合于大規(guī)模復(fù)雜的邏輯電路設(shè)計。它是Altera公司的第四代可編程邏輯器件集成開發(fā)環(huán)境,提供了從設(shè)計輸入到器件編程的全部功能,同低三代設(shè)計工具MAXPLUS Ⅱ相比,QuartusⅡ設(shè)計軟件增加了網(wǎng)絡(luò)編輯功能,提升了調(diào)試能力,解決了潛在的設(shè)計延遲,同時其強

13、大的設(shè)計能力和直觀易用的接口,越來越受到數(shù)字系統(tǒng)設(shè)計者的歡迎。</p><p>  二、數(shù)字鐘總體設(shè)計方案</p><p><b>  2.1總體結(jié)構(gòu)</b></p><p><b>  圖 1 系統(tǒng)結(jié)構(gòu)圖</b></p><p><b>  2.2 設(shè)計思路</b></

14、p><p>  數(shù)字鐘的設(shè)計模塊包括:分頻器、“時、分、秒”計數(shù)器、設(shè)置時間模塊、設(shè)置鬧鐘、比較模塊、選擇模塊、控制模塊和譯碼顯示電路。每一個功能模塊作為一個實體單獨進行設(shè)計,最后再將各個模塊的原理圖連接起來。</p><p> ?。?)開關(guān)EN(SW0)控制數(shù)碼管顯示,SW0關(guān)閉時顯示學(xué)號,打開后24h計時制計時并顯示。</p><p>  (2)校時以及設(shè)置鬧鐘:按

15、下TIMESET鍵開始設(shè)置時間,按下SHIFT鍵表示移位,按下ADD鍵對應(yīng)數(shù)字加一,再次按下TIMESET鍵回到走時狀態(tài)。分鐘和時鐘校準時,下方LED發(fā)光表示提示。</p><p>  (3)鬧鐘:鬧鐘定時時間到,對應(yīng)LED閃爍,持續(xù)60s。</p><p> ?。?)整點、半點報時:當(dāng)分鐘時間為00或30 時,對應(yīng)不同的LED發(fā)光。</p><p> ?。?)顯示

16、: 6個LED數(shù)碼管顯示小時、分、秒。</p><p><b>  2.4 RTL圖</b></p><p><b>  圖2 系統(tǒng)RTL圖</b></p><p>  三、數(shù)字鐘各功能模塊介紹</p><p><b>  3.1 分頻模塊</b></p>&l

17、t;p>  3.1.1引腳說明及功能介紹</p><p>  圖3 分頻模塊bdf圖 </p><p>  表1 分頻模塊引腳說明</p><p>  3.1.2核心源代碼及解釋</p><p>  PROCESS(CLK,EN)</p><p>  VARIABLE TEMP1 : INTEGER RANGE

18、 24999999 DOWNTO 0;</p><p>  VARIABLE TEMP50 : INTEGER RANGE 499999 DOWNTO 0;</p><p><b>  BEGIN </b></p><p>  IF EN='1' THEN </p><p>  IF CLK'E

19、VENT AND CLK='1'THEN </p><p>  IF TEMP1=24999999 THEN TEMP1:=0;Q1<=NOT Q1;</p><p>  ELSE TEMP1:=TEMP1+1;</p><p><b>  END IF;</b></p><p>  IF TE

20、MP50=499999 THEN TEMP50:=0;Q50<=NOT Q50;</p><p>  ELSE TEMP50:=TEMP50+1; ---通過計數(shù)將較高頻率的時鐘分頻,得到得到較低頻率的時鐘信號</p><p><b>  END IF;</b></p><p><b>  END IF;</b>

21、</p><p><b>  ELSE </b></p><p>  TEMP1:=0;Q1<='0';</p><p>  TEMP50:=0;Q50<='0';</p><p><b>  END IF;</b></p><p>

22、;  END PROCESS;</p><p>  PROCESS(QUICK)</p><p><b>  BEGIN</b></p><p>  IF QUICK='0' THEN CLK_OUT1OR50<=Q1;---通過按鍵選擇輸出的頻率</p><p>  ELSE CLK_OUT1

23、OR50<=Q50;</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p><b>  3.2 控制模塊</b></p><p>  3.2.1引腳說明及功能介紹</p><p>  圖4 控制模塊bdf圖&l

24、t;/p><p>  表2 控制模塊引腳說明</p><p>  3.2.2部分源代碼及解釋</p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p>

25、<p>  ENTITY COUTROL IS</p><p>  PORT ( ALARM,EN:IN STD_LOGIC;</p><p>  COUT:OUT STD_LOGIC_VECTOR(1 DOWNTO 0)</p><p><b>  );</b></p><p>  END ENTITY;

26、</p><p>  ARCHITECTURE ONE OF COUTROL IS</p><p>  SIGNAL TEMP1:STD_LOGIC:='0'; ——設(shè)置變量TEMP1表示KEY0的狀態(tài)</p><p><b>  BEGIN </b></p><p>  PROCESS(ALARM)

27、</p><p><b>  BEGIN</b></p><p>  IF ALARM'EVENT AND ALARM='1' THEN </p><p>  TEMP1<=NOT TEMP1; </p><p><b>  END IF;</b></p>

28、<p>  END PROCESS;</p><p>  PROCESS(TEMP1) ——TEMP1=0時,輸出狀態(tài)為計時(01);TEMP1=1 </p><p>  BEGIN時,輸出狀態(tài)為鬧鐘設(shè)置(10)</p><p>  IF TEMP1<='0' THEN </p><

29、;p>  COUT<="01";</p><p>  ELSE COUT<="10";</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  END ARCHITECTURE ONE;</p&g

30、t;<p>  3.3 時、分、秒模塊</p><p>  3.3.1 引腳說明及功能介紹</p><p>  圖5 秒模塊bdf圖 圖6 分模塊bdf圖 圖7 時模塊bdf圖</p><p>  表3 時/分/秒模塊引腳說明</p><p>  3.3.2部分源代碼及解釋&l

31、t;/p><p><b>  以秒鐘模塊為例:</b></p><p>  ARCHITECTURE ONE OF SEC IS</p><p>  SIGNAL S0,S1:STD_LOGIC_VECTOR(3 DOWNTO 0);--定義兩個變量表示秒鐘高位和低位</p><p><b>  BEGIN<

32、/b></p><p>  PROCESS(CLK)</p><p><b>  BEGIN</b></p><p>  IF CLK'EVENT AND CLK='1' THEN</p><p><b>  S0<=S0+1;</b></p>&l

33、t;p>  IF S0=9 THEN S0<=(OTHERS=>'0');</p><p><b>  S1<=S1+1;</b></p><p><b>  END IF;</b></p><p>  IF S1=5 AND S0=9 THEN </p><p&

34、gt;  S1<="0000";S0<="0000";COUT<='1';</p><p>  ELSE COUT<='0'; --60進制計數(shù)器,即滿六十則賦0且進位信號加一</p><p><b>  END IF;</b></p><p&

35、gt;<b>  END IF;</b></p><p>  END PROCESS;</p><p>  SEC0<=S0;SEC1<=S1;</p><p><b>  END;</b></p><p>  3.4 設(shè)置時間模塊</p><p>  3.4.1

36、 引腳說明及功能介紹</p><p>  圖8 設(shè)置時間模塊bdf圖</p><p>  表4 設(shè)置時間模塊引腳說明</p><p>  3.4.2部分源代碼及解釋</p><p>  ARCHITECTURE BEHAV OF ST IS</p><p>  SIGNAL TEMP1: STD_LOGIC_VECT

37、OR (1 DOWNTO 0):="00";--表示SHIFT按鍵按下產(chǎn)生的三種不同狀態(tài)</p><p>  SIGNAL TEMP2: STD_LOGIC:='0'; --檢測TIMESET是否按下的變量</p><p><b>  BEGIN</b></p><p>  PROCESS(SHIFT,ADD

38、)</p><p><b>  BEGIN</b></p><p>  IF EN='1' THEN </p><p>  IF TIMESET'EVENT AND TIMESET='1' THEN </p><p>  TEMP2<=NOT TEMP2;</p>

39、<p><b>  END IF;</b></p><p>  IF TEMP2='1' THEN </p><p>  IF SHIFT'EVENT AND SHIFT='1' THEN </p><p>  TEMP1<=TEMP1+1;</p><p>&

40、lt;b>  END IF;</b></p><p><b>  ELSE </b></p><p>  TEMP1<="00"; </p><p><b>  END IF;</b></p><p><b>  END IF;</b&g

41、t;</p><p>  CASE TEMP1 IS</p><p>  WHEN "00"=>CO1<=SEC;CO2<=MIN; --shift鍵沒有按下,屬于走時狀態(tài) </p><p>  LED13<='0';LED16<='0';</p><p> 

42、 WHEN "01"=>CO1<=ADD;CO2<='0'; --shift按下一次,分鐘可設(shè)置</p><p>  LED13<='1';LED16<='0';</p><p>  WHEN "10"=>CO1<='0';CO2<=

43、ADD; -- shift按下兩次,時鐘可設(shè)置 </p><p>  LED13<='0';LED16<='1'; </p><p>  WHEN OTHERS=>NULL;</p><p><b>  END CASE;</b></p><p>  E

44、ND PROCESS;</p><p><b>  END;</b></p><p>  3.5 設(shè)置鬧鐘模塊</p><p>  3.5.1 引腳說明及功能介紹</p><p>  圖9 設(shè)置鬧鐘模塊bdf圖</p><p>  表5 時/分/秒模塊引腳說明</p><p&

45、gt;  3.5.2部分源代碼及解釋</p><p>  ARCHITECTURE BEHAV OF SA IS</p><p>  SIGNAL TEMP1: STD_LOGIC:='0'; --表示SHIFT鍵是否按下的變量</p><p>  SIGNAL TEMP2: STD_LOGIC:='0';--表示CLOCKSET鍵是

46、否按下的變量</p><p><b>  BEGIN</b></p><p>  PROCESS(SHIFT,ADD)</p><p><b>  BEGIN</b></p><p>  IF EN='1' THEN </p><p>  IF CLOCKSE

47、T'EVENT AND CLOCKSET='1' THEN </p><p>  TEMP2<=NOT TEMP2;</p><p><b>  END IF;</b></p><p>  IF TEMP2='1' THEN </p><p>  IF SHIFT'E

48、VENT AND SHIFT='1' THEN </p><p>  TEMP1<=NOT TEMP1;</p><p><b>  END IF;</b></p><p><b>  ELSE </b></p><p>  TEMP1<='0'; &l

49、t;/p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  IF TEMP2='1' THEN </p><p>  CASE TEMP1 IS</p><p>  WHEN '0'

50、=>CO1<=ADD;CO2<='0'; --分鐘可設(shè)置</p><p>  LED14<='1';LED17<='0';</p><p>  WHEN '1'=>CO1<='0';CO2<=ADD; --時鐘可設(shè)置</p><p>  

51、LED14<='0';LED17<='1'; </p><p>  WHEN OTHERS=>NULL;</p><p><b>  END CASE;</b></p><p><b>  END IF;</b></p><p>  END

52、 PROCESS;</p><p><b>  END;</b></p><p>  3.6 比較鬧鐘模塊</p><p>  3.6.1 引腳說明及功能介紹</p><p>  圖10 鬧鐘比較模塊</p><p>  表6 比較鬧鐘模塊引腳說明</p><p>  3.

53、6.2部分源代碼及解釋</p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p>  ENTITY COMPARE IS</p><p>  PORT

54、 ( TH1,TH0,TM1,TM0,SAH1,SAH0,SAM1,SAM0:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  LED:OUT STD_LOGIC</p><p><b>  );</b></p><p>  END ENTITY;</p><p>  ARCHITEC

55、TURE BAHAV OF COMPARE IS</p><p><b>  BEGIN</b></p><p>  PROCESS(TH1,TH0,TM1,TM0,SAH1,SAH0,SAM1,SAM0)</p><p>  BEGIN——時間顯示與設(shè)置的鬧鐘時間相等時,LED燈亮</p><p>  IF TH

56、1=SAH1 AND TH0=SAH0 AND TM1=SAM1 AND TM0=SAM0 THEN </p><p><b>  LED<='1';</b></p><p>  ELSE LED<='0';</p><p><b>  END IF;</b></p>

57、<p>  END PROCESS;</p><p>  END ARCHITECTURE;</p><p><b>  3.7 選擇模塊</b></p><p>  3.7.1 引腳說明及功能介紹</p><p>  圖11選擇模塊bdf圖</p><p>  表7 選擇模塊引腳

58、說明</p><p>  3.7.2部分源代碼及解釋</p><p>  ARCHITECTURE BAHAV OF CHOOSE IS</p><p><b>  BEGIN</b></p><p>  PROCESS(CONTROL)</p><p><b>  BEGIN</

59、b></p><p>  CASE CONTROL IS </p><p>  WHEN "01"=>HOUR1<=TH1;HOUR0<=TH0;MIN1<=TM1;MIN0<=TM0;SEC1<=TS1;SEC0<=TS0; --當(dāng)control為01時,顯示正常走時以及設(shè)置時鐘的時間</p><p&

60、gt;  WHEN "10"=>HOUR1<=SAH1;HOUR0<=SAH0;MIN1<=SAM1;MIN0<=SAM0;SEC1<="1111";SEC0<="1111";--當(dāng)control為10時,時、分顯示設(shè)置鬧鐘的時間,秒鐘不顯示</p><p>  WHEN OTHERS=>HOUR1<

61、=TH1;HOUR0<=TH0;MIN1<=TM1;MIN0<=TM0;SEC1<=TS1;SEC0<=TS0; </p><p><b>  END CASE;</b></p><p>  END PROCESS;</p><p>  END ARCHITECTURE;</p><p>&

62、lt;b>  3.8 譯碼模塊</b></p><p>  3.8.1 引腳說明及功能介紹</p><p><b>  圖12 譯碼模塊</b></p><p>  表8 譯碼模塊引腳說明</p><p>  3.8.2部分源代碼及解釋</p><p>  ARCHITECTUR

63、E BAHAV OF DISPLAY IS</p><p>  SIGNAL REG7_0: STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p>  SIGNAL REG7_1: STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p>  SIGNAL REG7_2: STD_LOGIC_VECTOR(6 DOWNTO

64、 0);</p><p>  SIGNAL REG7_3: STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p>  SIGNAL REG7_4: STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p>  SIGNAL REG7_5: STD_LOGIC_VECTOR(6 DOWNTO 0);</p><

65、;p>  SIGNAL REG7_6: STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p>  SIGNAL REG7_7: STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p>  SIGNAL REG7_8: STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p>  SIGNAL REG7

66、_9: STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p>  SIGNAL REG7_NULL: STD_LOGIC_VECTOR(6 DOWNTO 0);-- --定義10個信號表示數(shù)字0~9</p><p>  SIGNAL LEDX:STD_LOGIC;</p><p><b>  BEGIN</b></p

67、><p>  REG7_0<="1000000";</p><p>  REG7_1<="1111001";</p><p>  REG7_2<="0100100";</p><p>  REG7_3<="0110000";</p>

68、<p>  REG7_4<="0011001";</p><p>  REG7_5<="0010010";</p><p>  REG7_6<="0000010";</p><p>  REG7_7<="1111000";</p>&l

69、t;p>  REG7_8<="0000000";</p><p>  REG7_9<="0010000";</p><p>  REG7_NULL<="1111111";</p><p>  PROCESS(H1,EN)--小時高位譯碼,初始為1</p><

70、p><b>  BEGIN</b></p><p>  IF EN='1' THEN</p><p>  CASE H1 IS</p><p>  WHEN "0000"=>HOUR1<=REG7_0;</p><p>  WHEN "0001"=

71、>HOUR1<=REG7_1;</p><p>  WHEN "0010"=>HOUR1<=REG7_2;</p><p>  WHEN "0011"=>HOUR1<=REG7_3;</p><p>  WHEN "0100"=>HOUR1<=REG7_4;&

72、lt;/p><p>  WHEN "0101"=>HOUR1<=REG7_5;</p><p>  WHEN "0110"=>HOUR1<=REG7_6;</p><p>  WHEN "0111"=>HOUR1<=REG7_7;</p><p>  

73、WHEN "1000"=>HOUR1<=REG7_8;</p><p>  WHEN "1001"=>HOUR1<=REG7_9;</p><p>  WHEN OTHERS=>HOUR1<=REG7_NULL;</p><p><b>  END CASE;</b>&

74、lt;/p><p><b>  ELSE </b></p><p>  HOUR1<=REG7_1;</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS(H0,EN)--小時低位譯碼,初始

75、為5</p><p><b>  BEGIN</b></p><p>  IF EN='1' THEN</p><p>  CASE H0 IS</p><p>  WHEN "0000"=>HOUR0<=REG7_0;</p><p>  WHEN

76、 "0001"=>HOUR0<=REG7_1;</p><p>  WHEN "0010"=>HOUR0<=REG7_2;</p><p>  WHEN "0011"=>HOUR0<=REG7_3;</p><p>  WHEN "0100"=>

77、HOUR0<=REG7_4;</p><p>  WHEN "0101"=>HOUR0<=REG7_5;</p><p>  WHEN "0110"=>HOUR0<=REG7_6;</p><p>  WHEN "0111"=>HOUR0<=REG7_7;</

78、p><p>  WHEN "1000"=>HOUR0<=REG7_8;</p><p>  WHEN "1001"=>HOUR0<=REG7_9;</p><p>  WHEN OTHERS=>HOUR0<=REG7_NULL;</p><p><b>  EN

79、D CASE;</b></p><p><b>  ELSE </b></p><p>  HOUR0<=REG7_5;</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS(M

80、1,EN)--分鐘高位譯碼,初始為3</p><p><b>  BEGIN</b></p><p>  IF EN='1' THEN </p><p>  CASE M1 IS</p><p>  WHEN "0000"=>MIN1<=REG7_0;</p&g

81、t;<p>  WHEN "0001"=>MIN1<=REG7_1;</p><p>  WHEN "0010"=>MIN1<=REG7_2;</p><p>  WHEN "0011"=>MIN1<=REG7_3;</p><p>  WHEN "

82、;0100"=>MIN1<=REG7_4;</p><p>  WHEN "0101"=>MIN1<=REG7_5;</p><p>  WHEN "0110"=>MIN1<=REG7_6;</p><p>  WHEN "0111"=>MIN1<=

83、REG7_7;</p><p>  WHEN "1000"=>MIN1<=REG7_8;</p><p>  WHEN "1001"=>MIN1<=REG7_9;</p><p>  WHEN OTHERS=>MIN1<=REG7_NULL;</p><p><

84、b>  END CASE;</b></p><p><b>  ELSE</b></p><p>  MIN1<=REG7_3;</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PR

85、OCESS(M0,EN)--分鐘低位譯碼,初始為8</p><p><b>  BEGIN</b></p><p>  IF EN='1' THEN </p><p>  CASE M0 IS</p><p>  WHEN "0000"=>MIN0<=REG7_0;&

86、lt;/p><p>  WHEN "0001"=>MIN0<=REG7_1;</p><p>  WHEN "0010"=>MIN0<=REG7_2;</p><p>  WHEN "0011"=>MIN0<=REG7_3;</p><p>  WHE

87、N "0100"=>MIN0<=REG7_4;</p><p>  WHEN "0101"=>MIN0<=REG7_5;</p><p>  WHEN "0110"=>MIN0<=REG7_6;</p><p>  WHEN "0111"=>MI

88、N0<=REG7_7;</p><p>  WHEN "1000"=>MIN0<=REG7_8;</p><p>  WHEN "1001"=>MIN0<=REG7_9;</p><p>  WHEN OTHERS=>MIN0<=REG7_NULL;</p><p&

89、gt;<b>  END CASE;</b></p><p><b>  ELSE</b></p><p>  MIN0<=REG7_8;</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p&

90、gt;  PROCESS(S1,EN)--秒鐘高位譯碼,初始為4</p><p><b>  BEGIN</b></p><p>  IF EN='1' THEN </p><p>  CASE S1 IS</p><p>  WHEN "0000"=>SEC1<=R

91、EG7_0;</p><p>  WHEN "0001"=>SEC1<=REG7_1;</p><p>  WHEN "0010"=>SEC1<=REG7_2;</p><p>  WHEN "0011"=>SEC1<=REG7_3;</p><p&g

92、t;  WHEN "0100"=>SEC1<=REG7_4;</p><p>  WHEN "0101"=>SEC1<=REG7_5;</p><p>  WHEN "0110"=>SEC1<=REG7_6;</p><p>  WHEN "0111"

93、=>SEC1<=REG7_7;</p><p>  WHEN "1000"=>SEC1<=REG7_8;</p><p>  WHEN "1001"=>SEC1<=REG7_9;</p><p>  WHEN OTHERS=> SEC1<=REG7_NULL;</p>

94、<p><b>  END CASE;</b></p><p><b>  ELSE </b></p><p>  SEC1<=REG7_4;</p><p><b>  END IF;</b></p><p>  END PROCESS;</p>

95、;<p>  PROCESS(S0,EN)--秒鐘低位譯碼,初始為5</p><p><b>  BEGIN</b></p><p>  IF EN='1' THEN </p><p>  CASE S0 IS</p><p>  WHEN "0000"=>S

96、EC0<=REG7_0;</p><p>  WHEN "0001"=>SEC0<=REG7_1;</p><p>  WHEN "0010"=>SEC0<=REG7_2;</p><p>  WHEN "0011"=>SEC0<=REG7_3;</p>

97、<p>  WHEN "0100"=>SEC0<=REG7_4;</p><p>  WHEN "0101"=>SEC0<=REG7_5;</p><p>  WHEN "0110"=>SEC0<=REG7_6;</p><p>  WHEN "0

98、111"=>SEC0<=REG7_7;</p><p>  WHEN "1000"=>SEC0<=REG7_8;</p><p>  WHEN "1001"=>SEC0<=REG7_9;</p><p>  WHEN OTHERS=> SEC0<=REG7_NULL;&

99、lt;/p><p><b>  END CASE;</b></p><p><b>  ELSE</b></p><p>  SEC0<=REG7_5;</p><p><b>  END IF;</b></p><p>  END PROCESS;&

100、lt;/p><p>  END ARCHITECTURE;</p><p><b>  3.9 報時模塊</b></p><p>  3.9.1 引腳說明及功能介紹</p><p>  圖13報時模塊bdf圖</p><p>  表7 報時模塊引腳說明</p><p>  3.

101、9.2部分源代碼及解釋</p><p>  ARCHITECTURE BEHAV OF TIMER IS</p><p><b>  BEGIN</b></p><p>  PROCESS(M0,M1)</p><p><b>  BEGIN</b></p><p>  IF

102、 M0="0000" AND M1="0000" THEN --分鐘為00即整點時,燈LEDR1 </p><p>  LEDR1<=CLK;閃爍提示</p><p>  ELSE LEDR1<='0';</p><p><b>  END IF;</b>&

103、lt;/p><p>  IF M0="0000" AND M1="0011" THEN ----分鐘為30即半點時,燈LEDR0</p><p>  LEDR0<=CLK;閃爍提示</p><p>  ELSE LEDR0<='0';</p><p><

104、b>  END IF;</b></p><p>  END PROCESS;</p><p><b>  END;</b></p><p><b>  四、設(shè)計結(jié)果圖示</b></p><p><b>  EN=0,顯示學(xué)號</b></p>&l

105、t;p>  圖13 顯示學(xué)號153845</p><p>  EN=1,初始狀態(tài),開始計時。</p><p>  圖14 初始狀態(tài),開始計時</p><p>  按下TIMESET鍵(kye3), 開始設(shè)置時間,再次按下表示設(shè)置結(jié)束;按下SHIFT鍵(key2),進行小時和分鐘的移位,從高向低,同時指示燈亮;按下ADD鍵(key1),對應(yīng)數(shù)字加一。<

106、/p><p>  圖15 設(shè)置分鐘,ledr13燈亮</p><p>  圖16 設(shè)置小時,ledr16燈亮</p><p>  按下ALARMSET鍵(KEY3),開始設(shè)置鬧鐘,再次按下表示設(shè)置結(jié)束;按下SHIFT鍵(KEY2),進行小時和分鐘的移位,從高向低;按下ADD鍵(KEY1),設(shè)置鬧鐘的每一位數(shù)字:0~9</p><p>  圖1

107、7 設(shè)置鬧鐘時間</p><p>  圖18 鬧鐘提醒,ledg2燈亮</p><p>  整點報時、半點報時,LED燈閃爍。</p><p>  圖19 整點報時,ledr2燈亮</p><p>  圖20 半點報時,ledr1燈亮</p><p><b>  五、結(jié)論</b></

108、p><p>  5.1遇到的問題和改進</p><p><b>  (1)問題1:</b></p><p>  在設(shè)置時間的時候,按下TIMESET鍵之后開始設(shè)置時間,再次按下TIMESET 鍵回到走時狀態(tài),顯示的時間仍為未設(shè)置前的時間,即設(shè)置的時間并不會反饋到走時狀態(tài)。</p><p>  解決辦法:在設(shè)置時間模塊以及走時

109、模塊之間增加聯(lián)系,即將走時模塊的進位輸出作為設(shè)置時間的輸入,設(shè)置時間模塊輸出信號作為時、分模塊的clk。</p><p> ?。?)問題2: 已經(jīng)設(shè)置完時間之后再設(shè)置鬧鐘時間的時候,按下ADD鍵,對鬧鐘時間的小時和分鐘位進行調(diào)整后,發(fā)現(xiàn)計時狀態(tài)下的小時和分鐘位也被進行了相應(yīng)的調(diào)整,不能完成設(shè)置鬧鐘時間和正常計時的功能。</p><p>  解決辦法:增加設(shè)置時的限制條件,如只有在TIMES

110、ET按鍵按下的情況下才能更改走時時間。 </p><p><b>  5.2工作分配比例</b></p><p><b>  六、附錄</b></p><p><b>  6.1分頻模塊</b></p><p>  LIBRARY IEEE;</p><p&

111、gt;  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p>  ENTITY FD IS</p><p>  PORT (CLK,EN,QUICK:IN STD_LOGIC;</p><p>  CLK_OUT1OR50:OUT ST

112、D_LOGIC);</p><p>  END ENTITY FD;</p><p>  ARCHITECTURE BAHAV OF FD IS</p><p>  SIGNAL Q1,Q50:STD_LOGIC;</p><p><b>  BEGIN</b></p><p>  PROCESS

113、(CLK,EN)</p><p>  VARIABLE TEMP1 : INTEGER RANGE 24999999 DOWNTO 0;</p><p>  VARIABLE TEMP50 : INTEGER RANGE 499999 DOWNTO 0;</p><p>  --VARIABLE TEMP2: INTEGER RANGE 12499999 DOWNT

114、O 0;</p><p><b>  BEGIN </b></p><p>  IF EN='1' THEN </p><p>  IF CLK'EVENT AND CLK='1'THEN </p><p>  IF TEMP1=24999999 THEN TEMP1:=0;Q

115、1<=NOT Q1;</p><p>  ELSE TEMP1:=TEMP1+1;</p><p><b>  END IF;</b></p><p>  IF TEMP50=499999 THEN TEMP50:=0;Q50<=NOT Q50;</p><p>  ELSE TEMP50:=TEMP50

116、+1;</p><p><b>  END IF;</b></p><p>  --IF TEMP2=12499999 THEN TEMP2:=0;Q2<=NOT Q2;</p><p>  --ELSE TEMP2:=TEMP2+1;</p><p>  --END IF;</p&g

117、t;<p><b>  END IF;</b></p><p><b>  ELSE </b></p><p>  TEMP1:=0;Q1<='0';</p><p>  TEMP50:=0;Q50<='0';</p><p>  --T

118、EMP2:=0;Q2<='0';</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS(QUICK)</p><p><b>  BEGIN</b></p><p>  IF

119、 QUICK='0' THEN CLK_OUT1OR50<=Q1;</p><p>  ELSE CLK_OUT1OR50<=Q50;</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  --CLK_OUT2<=Q2;

120、</p><p>  END ARCHITECTURE;</p><p><b>  6.2控制模塊</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_UN

121、SIGNED.ALL;</p><p>  ENTITY COUTROL IS</p><p>  PORT ( ALARM,EN:IN STD_LOGIC;</p><p>  COUT:OUT STD_LOGIC_VECTOR(1 DOWNTO 0)</p><p><b>  );</b></p>&

122、lt;p>  END ENTITY;</p><p>  ARCHITECTURE ONE OF COUTROL IS</p><p>  SIGNAL TEMP1:STD_LOGIC:='0';</p><p><b>  BEGIN </b></p><p>  PROCESS(ALARM)&

123、lt;/p><p><b>  BEGIN</b></p><p>  IF ALARM'EVENT AND ALARM='1' THEN </p><p>  TEMP1<=NOT TEMP1; </p><p><b>  END IF;</b></p>

124、<p>  END PROCESS;</p><p>  PROCESS(TEMP1)</p><p><b>  BEGIN</b></p><p>  IF TEMP1<='0' THEN </p><p>  COUT<="01";</p>&

125、lt;p>  ELSE COUT<="10";</p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  END ARCHITECTURE ONE;</p><p><b>  6.3秒模塊</b></

126、p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p>  ENTITY SEC IS</p><p>  PORT(CLK:IN STD_LOGIC;&l

127、t;/p><p>  SEC0,SEC1:OUT STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  COUT:OUT STD_LOGIC);</p><p><b>  END SEC;</b></p><p>  ARCHITECTURE ONE OF SEC IS</p>&l

128、t;p>  SIGNAL S0,S1:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  PROCESS(CLK)</p><p><b>  BEGIN</b></p><p>  IF CLK'EVENT

129、AND CLK='1' THEN</p><p><b>  S0<=S0+1;</b></p><p>  IF S0=9 THEN S0<=(OTHERS=>'0');</p><p><b>  S1<=S1+1;</b></p><p>

130、;<b>  END IF;</b></p><p>  IF S1=5 AND S0=9 THEN </p><p>  S1<="0000";S0<="0000";COUT<='1';</p><p>  ELSE COUT<='0';</

131、p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  SEC0<=S0;SEC1<=S1;</p><p><b>  END;</b>

132、;</p><p><b>  6.4分模塊</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p>  ENTITY

133、 MIN IS</p><p>  PORT(CLK:IN STD_LOGIC;</p><p>  MIN0,MIN1:OUT STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  COUT:OUT STD_LOGIC);</p><p><b>  END MIN;</b></p>

134、;<p>  ARCHITECTURE ONE OF MIN IS</p><p>  SIGNAL M0,M1:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  PROCESS(CLK)</p><p><b>  B

135、EGIN</b></p><p>  IF CLK'EVENT AND CLK='1' THEN</p><p><b>  M0<=M0+1;</b></p><p>  IF M0=9 THEN M0<=(OTHERS=>'0');</p><p>

136、;<b>  M1<=M1+1;</b></p><p><b>  END IF;</b></p><p>  IF M1=5 AND M0=9 THEN </p><p>  M1<="0000";M0<="0000";COUT<='1';

137、</p><p>  ELSE COUT<='0';</p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  MIN0<=M0;MIN

138、1<=M1;</p><p><b>  END;</b></p><p><b>  6.5時模塊</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEE

139、E.STD_LOGIC_UNSIGNED.ALL;</p><p>  ENTITY HOUR IS</p><p>  PORT(CLK:IN STD_LOGIC;</p><p>  HOUR0,HOUR1:OUT STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  COUT:OUT STD_LOGIC);&l

140、t;/p><p><b>  END HOUR;</b></p><p>  ARCHITECTURE ONE OF HOUR IS</p><p>  SIGNAL H0,H1:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p><b>  BEGIN</b></p>

141、;<p>  PROCESS(CLK)</p><p><b>  BEGIN</b></p><p>  IF CLK'EVENT AND CLK='1' THEN</p><p><b>  H0<=H0+1;</b></p><p>  IF H0=

142、9 THEN H0<=(OTHERS=>'0');</p><p><b>  H1<=H1+1;</b></p><p><b>  END IF;</b></p><p>  IF H1=2 AND H0=3 THEN </p><p>  H1<=&qu

溫馨提示

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

評論

0/150

提交評論