eda課程設(shè)計——病房呼叫系統(tǒng)_第1頁
已閱讀1頁,還剩20頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  課程設(shè)計說明書</b></p><p>  課程:EDA技術(shù)基礎(chǔ)</p><p><b>  組號:B8組</b></p><p>  題 目:病房呼叫系統(tǒng)</p><p><b>  組 員:</b></p><p

2、>  專 業(yè):電子信息科學(xué)與技術(shù)</p><p><b>  指導(dǎo)教師:</b></p><p><b>  2010年1月8日</b></p><p><b>  B8組整體設(shè)計報告</b></p><p><b>  目 錄</b><

3、;/p><p>  一、課程設(shè)計思路………………………………………………………1</p><p>  1、設(shè)計題目……………………………………………………1</p><p>  2、設(shè)計要求……………………………………………………1</p><p>  3、設(shè)計想法……………………………………………………1</p><p>

4、;  二、課程設(shè)計過程………………………………………………………2</p><p>  1、模塊分配……………………………………………………2</p><p>  2、模塊具體設(shè)計………………………………………………2</p><p>  三、課程設(shè)計綜合介紹…………………………………………………4</p><p>  1、整體原理圖…………

5、………………………………………4</p><p>  2、引腳配置……………………………………………………5</p><p>  3、整體設(shè)計實現(xiàn)………………………………………………5</p><p>  參考文獻…………………………………………………………………6</p><p>  附件(病房呼叫系統(tǒng)整體程序)……………………………………

6、…7</p><p><b>  一、課程設(shè)計思路</b></p><p>  一)、設(shè)計題目:病房呼叫系統(tǒng)</p><p><b>  二)、設(shè)計要求:</b></p><p>  用8個開關(guān)模擬8個病房的呼叫輸入信號,1號優(yōu)先級最高;1~8優(yōu)先級依次降低;</p><p>

7、;  用一個數(shù)碼管顯示呼叫信號的號碼;沒信號時顯示0;有多個信號呼叫時,顯示優(yōu)先級最高的呼叫號(其他呼叫用指示燈顯示);用四個數(shù)碼管顯示呼叫等待時間(mm ss)。</p><p>  凡有呼叫發(fā)出5秒的提示聲;呼叫3分鐘未處理輸出報警信號。</p><p>  發(fā)揮部分:對低優(yōu)先級的呼叫進行存儲,處理完高優(yōu)先級的呼叫,再進行低優(yōu)先級呼叫的處理。</p><p>&

8、lt;b>  三)、設(shè)計想法:</b></p><p>  1、整體設(shè)計思路:根據(jù)設(shè)計要求,我們將設(shè)計分為幾個模塊來設(shè)計,分別為:鎖存模塊、選優(yōu)模塊(對病房選優(yōu))、選優(yōu)模塊2(對復(fù)位選優(yōu))、計時模塊、顯示模塊、蜂鳴模塊。</p><p><b>  2、整體設(shè)計流程:</b></p><p>  (1)、鎖存器:對病房呼叫的信

9、號進行存儲并處理信號,需要用一個對所有的呼叫信號進行存儲的鎖存器。</p><p>  (2)、數(shù)據(jù)選擇器(選優(yōu)):對發(fā)出呼叫的病房進行優(yōu)先選擇,選擇優(yōu)先級最高的一個病房號,病房號從1到8優(yōu)先級一次降低。</p><p>  (3)、數(shù)據(jù)選擇器2(選優(yōu)2):對時間控制信號進優(yōu)先選擇,這樣就是的數(shù)碼管顯示器顯示的時間為當(dāng)前優(yōu)先級最高的病房所呼叫的時間。</p><p>

10、; ?。?)、計時器:病房呼叫系統(tǒng)中要求凡有呼叫發(fā)出,呼叫3分種未處理輸出報警信號,即要求一個模塊對呼叫時間計時,因此我們設(shè)計一個分秒計時器,對呼叫時間計時。實驗箱中時鐘頻率為20MHZ,故計時部分需加入分頻,我們使之為1s。</p><p> ?。?)、顯示器:用一個數(shù)碼管顯示呼叫信號的號碼,用四個數(shù)碼管顯示呼叫等待時間(mm ss),設(shè)計一七段數(shù)碼顯示器,數(shù)碼片選為低電平有效,掃描信號定為1KHZ。</

11、p><p><b>  二、課程設(shè)計過程</b></p><p><b>  一)、模塊分配</b></p><p><b> ?。烘i存模塊</b></p><p> ?。哼x優(yōu)模塊、對復(fù)位選優(yōu)模塊</p><p><b> ?。河嫊r模塊</b

12、></p><p><b> ?。猴@示模塊</b></p><p>  :連接模塊、蜂鳴器模塊</p><p><b>  二)、模塊具體設(shè)計</b></p><p>  鎖存模塊:由于有8個病房所以設(shè)計了8個輸入信號且高電平時為信號輸入,另外考慮到時間模塊顯示的是當(dāng)前等待時間,所以小組討論后

13、決定時間顯示當(dāng)前等待時間為最好,所以在鎖存模塊,把復(fù)位加到鎖存模塊,高電平的時候表示復(fù)位不工作,低電平的時候表示復(fù)位。鎖存器的一個輸入信號與LED燈相連,使得有呼叫信號時,與病房相對應(yīng)的燈亮。另外一個相同的輸出信號連接選優(yōu)器,對信號進行選優(yōu),還有一個相同輸出信號控制計時模塊中的SP信號。</p><p>  選優(yōu)模塊:由設(shè)計要求,數(shù)碼管要顯示優(yōu)先級最高的病房的呼叫信號,所以我們須得對病房呼叫信號進行選優(yōu),還考慮到

14、對時間的優(yōu)先級的問題,所以設(shè)計了兩個優(yōu)先輸出信號。程序功能部分按優(yōu)先病房號順序依次輸出BCD碼代表的1、2、3、4、5、6、7、8.</p><p>  選優(yōu)2:考慮到復(fù)位鍵一一對應(yīng)的問題,我們的時間模塊又只用了一個,顯示當(dāng)前最優(yōu)先病房的等待時間,所以選優(yōu)2模塊連在選優(yōu)模塊的后面以及和8個位寬的復(fù)位信號相連,然后通過選優(yōu)模塊,使得輸出地復(fù)位信號為當(dāng)前最優(yōu)先的病房所對應(yīng)的復(fù)位信號。鎖存器模塊的一個輸出信號也在這時進

15、行選優(yōu),選出來的優(yōu)先級最高的信號與時間模塊中的SP信號對應(yīng)。</p><p>  計時模塊:由設(shè)計要求計時用四個數(shù)碼管顯示mmss, 所以時間方面采用的是以秒進位,實驗箱中的時間頻率為20MHZ,所以選擇了0:20000000即一秒的分頻,另外由于有呼叫信號時,SP=1,我們得立即計時,所以定義了每個1秒之內(nèi)出現(xiàn)一個上升沿,當(dāng)上升沿到來時時間加計1s,另外mmss之中前一個m代表的是分的十位,后一個m代表的是分的

16、個位,前一個s代表的是秒的十位,后一個s代表的是秒的個位。</p><p>  顯示模塊:顯示模塊所要顯示的就是優(yōu)先級最高的呼叫病房的號碼以及呼叫等待的時間mmss,所以在模塊的設(shè)計當(dāng)中,我們用中間的六個數(shù)碼管依次顯示當(dāng)前最優(yōu)先呼叫病房號,分的十位,分的個位,再一個數(shù)碼管顯示一橫杠,和秒計位區(qū)分開來。在依次是秒的十位,秒的個位。</p><p>  連接模塊:由于各個模塊成功之后進行頂層設(shè)

17、計時,時間模塊和蜂鳴器模塊的位寬不相等,故我設(shè)計了一個連接模塊,使得兩模塊能夠順利銜接起來。連接模塊的輸出部分和時間模塊的mmss各部分相互對應(yīng),模塊輸出部分位寬的15-12位與記秒的個位的3-0位對應(yīng),位寬的11-8位與記秒的十位的3-0相對應(yīng),位寬的7-4位與記分的個位的3-0相對應(yīng),位寬的3-0位與記分的十位的3-0位相對應(yīng)。</p><p>  蜂鳴器模塊:考慮到計時后發(fā)出5秒的提示聲以及燈亮3分鐘后進行

18、報警,所以我設(shè)計的報警器模塊和時間的鏈接模塊是聯(lián)系起來的,當(dāng)輸入為0000 0001 0000 0000表示的是1秒,0000 0010 0000 0000表示的是2秒,以此類推,當(dāng)表示的時間是1-5秒時令蜂鳴器響,此時輸出為低電平,表是的是蜂鳴器工作。當(dāng)時間在6秒到3分鐘之間的時候,編寫程序另輸出為高電平,此時蜂鳴器不工作。超過三分鐘時再令蜂鳴器工作5秒,進行報警工作,此時已經(jīng)達到設(shè)計要求。 </p><p>

19、;  三、課程設(shè)計綜合介紹</p><p>  我們對這個模塊剛開始設(shè)計了和現(xiàn)在不同的方案,然后頂層設(shè)計時發(fā)現(xiàn)并不好實現(xiàn),而且連接之后模塊也比較復(fù)雜,所以我們重新思考之后就有了現(xiàn)在模塊的初稿,但是在頂層設(shè)定好之后,跑實驗箱是顯示的結(jié)果并不如預(yù)期的,多次調(diào)試沒出結(jié)果之后,我選擇了排除錯誤,首先從自身下手,我把頂層的連接改成了用系統(tǒng)框圖表示,選它的優(yōu)點是比較直觀,設(shè)想正確的話基本上不會出現(xiàn)什么錯誤,所以,當(dāng)問題再次出

20、現(xiàn)時我考慮到了每個模塊的邏輯問題,經(jīng)過一個一個找出現(xiàn)的問題,從時間模塊的SP的高低電平的修改,在到蜂鳴器和時間表示對應(yīng)的修改,在到對選優(yōu)模塊最后執(zhí)行語句YOU歸零的修改,解決了計時器一直計時、蜂鳴器不工作、病房顯示號不歸零等問題,終于圓滿的完成了實驗的要求。</p><p>  一)、病房呼叫系統(tǒng)框圖如下:</p><p><b>  引腳配置如圖:</b></

21、p><p>  二)、綜合引腳配置如下:</p><p>  三)、整體設(shè)計實現(xiàn)描述:</p><p>  實驗箱上有8個7段數(shù)碼管、16個用戶LED燈(8個大LED燈,8個小LED燈)、16個開關(guān)量輸入端口、8個撥碼開關(guān)、 蜂鳴器等。工程引腳鎖定下載完后,將其下載進FPGA中,進行硬件測試。具體實現(xiàn)如下:實驗箱中有8個7段數(shù)碼管,我們只用到了其中的6個,除前兩個外從左

22、到右分別顯示:病房號碼、minitue2、minitue1、——(橫杠)、second2、 second1。對應(yīng)病房號指示燈我們用8個小LED。接通電源,計時程序已下載進實驗箱,蜂鳴器開始時不響,6個數(shù)碼管顯示000--00,撥碼開關(guān)從SW1-SW7依次表示的是病房號1-7,當(dāng)按下?lián)艽a開關(guān)SW1時表示2號病房開始計時,蜂鳴器接著響5秒鐘然后不響,到時間記為三分鐘時又開始報警。當(dāng)同時按開關(guān)SW2與SW3時,病房號顯示的還是2,因為病房2的

23、優(yōu)先級比病房三的要高,另外病房相應(yīng)的撥碼開關(guān)打開后,相應(yīng)的指示燈也開始亮,小燈從左到右依次顯示優(yōu)先級從低到高的8個病房的呼叫情況。我們的實驗的一個特色是設(shè)置了8個復(fù)位信號,我們主要考慮到一個實際問題,每一個復(fù)位鍵對應(yīng)了當(dāng)時優(yōu)先級最高的一個病房的燈控和時間控制,當(dāng)護士去處理優(yōu)先級最高病房的呼叫信號</p><p><b>  參考文獻</b></p><p>  FPG

24、A實驗指導(dǎo)書(5萬門).doc </p><p>  EDA技術(shù)與VHDL 清華大學(xué)出版社 黃繼業(yè) </p><p>  www.eetop.cn</p><p>  (VHDL_與數(shù)字電路設(shè)計</p><p>  硬件語言描述與數(shù)字邏輯電路設(shè)計 侯伯亨 、顧新 編著)</p><p><b>  附件

25、:</b></p><p>  病房呼叫系統(tǒng)整體程序</p><p><b>  一、鎖存器</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY SUOCUNQI IS&

26、lt;/p><p>  PORT(REST:IN STD_LOGIC_VECTOR(7 DOWNTO 0); </p><p>  SIN:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  SOUT1:OUT STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  SOUT2

27、:OUT STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  SOUT3:OUT STD_LOGIC_VECTOR(7 DOWNTO 0));</p><p>  END SUOCUNQI;</p><p>  ARCHITECTURE bhv OF SUOCUNQI IS</p><p>  SIGNAL SOU

28、T:STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  PROCESS(REST,SIN)</p><p><b>  BEGIN</b></p><p>  IF REST(0)='1' AND SIN(0

29、)='0' THEN SOUT(0)<='1';</p><p>  ELSE SOUT(0)<='0';</p><p><b>  END IF;</b></p><p>  IF REST(1)='1' AND SIN(1)='0' THEN S

30、OUT(1)<='1';</p><p>  ELSE SOUT(1)<='0';</p><p><b>  END IF;</b></p><p>  IF REST(2)='1' AND SIN(2)='0' THEN SOUT(2)<='1'

31、;;</p><p>  ELSE SOUT(2)<='0';</p><p><b>  END IF;</b></p><p>  IF REST(3)='1' AND SIN(3)='0' THEN SOUT(3)<='1';</p><p&g

32、t;  ELSE SOUT(3)<='0';</p><p><b>  END IF;</b></p><p>  IF REST(4)='1' AND SIN(4)='0' THEN SOUT(4)<='1';</p><p>  ELSE SOUT(4)<=

33、'0';</p><p><b>  END IF;</b></p><p>  IF REST(5)='1' AND SIN(5)='0' THEN SOUT(5)<='1';</p><p>  ELSE SOUT(5)<='0';</p>

34、;<p><b>  END IF;</b></p><p>  IF REST(6)='1' AND SIN(6)='0' THEN SOUT(6)<='1';</p><p>  ELSE SOUT(6)<='0';</p><p><b>

35、;  END IF;</b></p><p>  IF REST(7)='1' AND SIN(7)='0' THEN SOUT(7)<='1';</p><p>  ELSE SOUT(7)<='0';</p><p><b>  END IF;</b>

36、</p><p>  END PROCESS;</p><p>  SOUT1<=SOUT;</p><p>  SOUT2<=SOUT;</p><p>  SOUT3<=SOUT;</p><p>  END ARCHITECTURE bhv;</p><p><b&

37、gt;  二、選優(yōu)模塊</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY XUANYOU IS</p><p>  PORT(SOUT:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p&

38、gt;<p>  YOU1:OUT STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  YOU2:OUT STD_LOGIC_VECTOR(3 DOWNTO 0));</p><p>  END XUANYOU;</p><p>  ARCHITECTURE bhv OF XUANYOU IS</p><

39、p>  SIGNAL YOU:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  PROCESS(SOUT,YOU)</p><p><b>  BEGIN</b></p><p>  IF SOUT(0)='

40、1' THEN YOU<="0001";</p><p>  ELSE IF SOUT(1)='1' THEN YOU<="0010";</p><p>  ELSE IF SOUT(2)='1' THEN YOU<="0011";</p><p>

41、  ELSE IF SOUT(3)='1' THEN YOU<="0100";</p><p>  ELSE IF SOUT(4)='1' THEN YOU<="0101";</p><p>  ELSE IF SOUT(5)='1' THEN YOU<="0110"

42、;;</p><p>  ELSE IF SOUT(6)='1' THEN YOU<="0111";</p><p>  ELSE IF SOUT(7)='1' THEN YOU<="1000";</p><p>  ELSE YOU1<="0000";&l

43、t;/p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b

44、>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><

45、;p>  YOU1<=YOU;</p><p>  YOU2<=YOU;</p><p>  END ARCHITECTURE bhv;</p><p><b>  三、計時選優(yōu)模塊</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.S

46、TD_LOGIC_1164.ALL;</p><p>  ENTITY XUANYOU2 IS</p><p>  PORT(REST:IN STD_LOGIC_VECTOR(7 DOWNTO 0); </p><p>  SOUT3:IN STD_LOGIC_VECTOR(7 DOWNTO 0); </p><p>  YOU

47、1:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  ZQ:OUT STD_LOGIC;</p><p>  LJ:OUT STD_LOGIC);</p><p>  END XUANYOU2;</p><p>  ARCHITECTURE bhv OF XUANYOU2 IS</p><

48、;p><b>  BEGIN</b></p><p>  PROCESS(YOU1)</p><p><b>  BEGIN</b></p><p>  IF YOU1="0001" THEN LJ<=REST(0);</p><p>  ELSE IF YOU1=&

49、quot;0010" THEN LJ<=REST(1);</p><p>  ELSE IF YOU1="0011" THEN LJ<=REST(2);</p><p>  ELSE IF YOU1="0100" THEN LJ<=REST(3);</p><p>  ELSE IF YOU1=&q

50、uot;0101" THEN LJ<=REST(4);</p><p>  ELSE IF YOU1="0110" THEN LJ<=REST(5);</p><p>  ELSE IF YOU1="0111" THEN LJ<=REST(6);</p><p>  ELSE IF YOU1=&qu

51、ot;1000" THEN LJ<=REST(7);</p><p><b>  END IF; </b></p><p><b>  END IF; </b></p><p><b>  END IF; </b></p><p><b>  END

52、 IF; </b></p><p><b>  END IF; </b></p><p><b>  END IF; </b></p><p><b>  END IF; </b></p><p>  END IF; </p><p

53、>  END PROCESS;</p><p>  PROCESS(SOUT3)</p><p><b>  BEGIN</b></p><p>  IF YOU1="0001" THEN ZQ<=SOUT3(0);</p><p>  ELSE IF YOU1="0010&qu

54、ot; THEN ZQ<=SOUT3(1);</p><p>  ELSE IF YOU1="0011" THEN ZQ<=SOUT3(2);</p><p>  ELSE IF YOU1="0100" THEN ZQ<=SOUT3(3);</p><p>  ELSE IF YOU1="0101&

55、quot; THEN ZQ<=SOUT3(4);</p><p>  ELSE IF YOU1="0110" THEN ZQ<=SOUT3(5);</p><p>  ELSE IF YOU1="0111" THEN ZQ<=SOUT3(6);</p><p>  ELSE IF YOU1="100

56、0" THEN ZQ<=SOUT3(7);</p><p><b>  END IF; </b></p><p><b>  END IF; </b></p><p><b>  END IF; </b></p><p><b>  END IF;

57、</b></p><p><b>  END IF; </b></p><p><b>  END IF; </b></p><p><b>  END IF; </b></p><p>  END IF; </p><p> 

58、 END PROCESS; </p><p>  END ARCHITECTURE bhv;</p><p><b>  四、時間模塊</b></p><p>  LIBRARY IEEE; </p><p>  USE IEEE.STD_LOGIC_1164.ALL</p><p>  USE

59、 IEEE.STD_LOGIC_UNSIGNED.ALL</p><p>  ENTITY TIME IS</p><p>  PORT(REST,SP,CLK :IN STD_LOGIC;</p><p>  SECOND1,SECOND2,MINITUE1,MINITUE2:OUT STD_LOGIC_VECTOR(3 DOWNTO 0));</p&

60、gt;<p><b>  END TIME;</b></p><p>  ARCHITECTURE ONE OF TIME IS</p><p>  SIGNAL TIMECLK,MINI:STD_LOGIC;</p><p>  SIGNAL SEC1,SEC2:STD_LOGIC_VECTOR(3 DOWNTO 0);<

61、/p><p>  SIGNAL MINI1,MINI2:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  MINITUE1(3 DOWNTO 0)<=MINI1(3 DOWNTO 0);MINITUE2(3 DOWNTO 0)<=MINI2(3 DOWNTO

62、0);</p><p>  SECOND1(3 DOWNTO 0)</p><p>  PROCESS(CLK,SP)</p><p>  VARIABLE CNT:INTEGER RANGE 0 TO 20000000;--分頻 1S</p><p><b>  BEGIN</b></p><p&g

63、t;  IF CLK'EVENT AND CLK='1'AND SP='1' THEN CNT:=CNT+1;</p><p>  IF CNT<10000000 THEN TIMECLK<='1';</p><p>  ELSIF CNT<20000000 THEN TIMECLK<='0';

64、</p><p>  ELSE CNT:=0;TIMECLK<='0';</p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  -----

65、---------</p><p>  PROCESS(TIMECLK,REST) --計時部分程序</p><p><b>  BEGIN </b></p><p>  IF(REST='0') THEN </p><p>  MINI2 <="0000"; MINI1 <

66、;="0000"; SEC2<="0000"; SEC1<="0000";</p><p>  ELSIF (TIMECLK'EVENT AND TIMECLK='1')THEN --檢驗時鐘上升沿</p><p>  IF SEC1<"1001"THEN SEC1&l

67、t;=SEC1+1;</p><p><b>  ELSE</b></p><p>  SEC1<="0000";</p><p>  IF SEC2<"0101"THEN SEC2<=SEC2+1;</p><p><b>  ELSE</b&g

68、t;</p><p>  SEC2<="0000";</p><p>  IF MINI1<"1001"THEN MINI1<=MINI1+1;</p><p><b>  ELSE</b></p><p>  MINI1<="0000"

69、;</p><p>  IF MINI2<"0101"THEN MINI2<=MINI2+1;</p><p><b>  ELSE</b></p><p>  MINI2<="0000";</p><p><b>  END IF;</b>

70、</p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  E

71、ND PROCESS; </p><p><b>  END ONE;</b></p><p><b>  五、連接模塊</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p> 

72、 ENTITY SQU IS</p><p>  PORT(SECOND1:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  SECOND2:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  MINITUE1:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p>

73、<p>  MINITUE2:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  JISHI:OUT STD_LOGIC_VECTOR(15 DOWNTO 0));</p><p><b>  END SQU;</b></p><p>  ARCHITECTURE ONE OF SQU IS<

74、/p><p><b>  BEGIN</b></p><p>  JISHI(15 DOWNTO 12)<=SECOND1;</p><p>  JISHI(11 DOWNTO 8)<=SECOND2;</p><p>  JISHI(7 DOWNTO 4)<=MINITUE1;</p>&l

75、t;p>  JISHI(3 DOWNTO 0)<=MINITUE2;</p><p>  END ARCHITECTURE ONE;</p><p><b>  六、 蜂鳴模塊</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL

76、;</p><p>  ENTITY FENGMING IS</p><p>  PORT( </p><p>  BCD:IN STD_LOGIC_VECTOR(15 DOWNTO 0);</p><p>  MING:OUT STD_LOGIC);</p><p>  END FENGMING;<

77、/p><p>  ARCHITECTURE bhv OF FENGMING IS</p><p>  SIGNAL ING:STD_LOGIC;</p><p><b>  BEGIN</b></p><p>  PROCESS(BCD)</p><p><b>  BEGIN</b&

78、gt;</p><p>  IF BCD="0000000000000000" THEN ING<='1';</p><p>  ELSE IF BCD="0001000000000000" THEN ING<='0';</p><p>  ELSE IF BCD="001

79、0000000000000" THEN ING<='0';</p><p>  ELSE IF BCD="0011000000000000" THEN ING<='0';</p><p>  ELSE IF BCD="0100000000000000" THEN ING<='0

80、9;;</p><p>  ELSE IF BCD="0101000000000000" THEN ING<='0';</p><p>  ELSE ING<='1';</p><p>  IF BCD="0000000000110000" THEN ING<='0&#

81、39;;</p><p>  ELSE IF BCD="0001000000110000" THEN ING<='0'; </p><p>  ELSE IF BCD="0010000000110000" THEN ING<='0';</p><p>  ELSE IF BCD=&

82、quot;0011000000110000" THEN ING<='0';</p><p>  ELSE IF BCD="0100000000110000" THEN ING<='0';</p><p><b>  END IF;</b></p><p><b>

83、;  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b><

84、/p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p><b&g

85、t;  END IF;</b></p><p>  MING<=ING;</p><p>  END PROCESS;</p><p>  END ARCHITECTURE bhv;</p><p><b>  七、顯示模塊</b></p><p>  USE IEEE.STD

86、_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p>  USE IEEE.STD_LOGIC_ARITH.ALL;</p><p>  ENTITY DISPLAY IS</p><p><b>  PORT(</b></p>

87、<p>  CLK:IN STD_LOGIC;</p><p>  SECOND1,SECOND2,MINITUE1,MINITUE2:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  YOU:IN STD_LOGIC_VECTOR(3 DOWNTO 0);--顯示病房</p><p>  DISP:OUT STD_

88、LOGIC_VECTOR(7 DOWNTO 0);--顯示代碼</p><p>  LEDCS:OUT STD_LOGIC_VECTOR(7 DOWNTO 0)--數(shù)碼管片選</p><p><b>  );</b></p><p>  END DISPLAY;</p><p>  ARCHITECTURE ONE OF

89、 DISPLAY IS</p><p>  SIGNAL CLK_1K:STD_LOGIC; </p><p>  SIGNAL DATA:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  CLK_1KHZ:PROCESS(CLK)--產(chǎn)生1k

90、的掃描信號</p><p>  VARIABLE CNT:INTEGER RANGE 0 TO 20000;</p><p><b>  BEGIN</b></p><p>  IF RISING_EDGE(CLK)THEN CNT:=CNT+1;</p><p>  IF CNT<10000THEN CLK_1K

91、<='1';</p><p>  ELSIF CNT<20000THEN CLK_1K<='0';</p><p>  ELSE CNT:=0;CLK_1K<='0';</p><p><b>  END IF;</b></p><p><b&

92、gt;  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS (CLK_1K) --顯示</p><p>  VARIABLE CNT2:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  VARIABLE CNT3:INTEGER RANGE 0

93、 TO 2;</p><p>  VARIABLE CNT:INTEGER RANGE 0 TO 2500000;</p><p><b>  BEGIN</b></p><p>  IF CLK_1K'EVENT AND CLK_1K='1'THEN CNT2:=CNT2+1;</p><p>

94、  IF CNT2="0001"THEN </p><p>  LEDCS<="00010000";</p><p>  DATA<=MINITUE2;</p><p>  ELSIF CNT2="0010" THEN</p><p>  LEDCS<="

95、00001000";</p><p>  DATA<=MINITUE1; </p><p>  ELSIF CNT2="0011" THEN</p><p>  LEDCS<="00000100";</p><p>  DATA<="1010"; <

96、;/p><p>  ELSIF CNT2="0100" THEN </p><p>  LEDCS<="00000010";</p><p>  DATA<=SECOND2;</p><p>  ELSIF CNT2="0101" THEN</p><p&

97、gt;  LEDCS<="00000001";</p><p>  DATA<=SECOND1;</p><p>  ELSIF CNT2="0110" THEN </p><p>  LEDCS<="00100000";</p><p>  DATA<=YO

98、U; </p><p>  CNT2:="0000";</p><p><b>  END IF;</b></p><p><b>  END IF;</b></p><p>  END PROCESS;</p><p>  PROCESS(DATA)&l

99、t;/p><p><b>  BEGIN</b></p><p>  CASE DATA IS</p><p>  WHEN "0000"=>DISP<="11000000";--0</p><p>  WHEN "0001"=>DISP<=

100、"11111001";--1</p><p>  WHEN "0010"=>DISP<="10100100";--2</p><p>  WHEN "0011"=>DISP<="10110000";--3</p><p>  WHEN &quo

101、t;0100"=>DISP<="10011001";--4</p><p>  WHEN "0101"=>DISP<="10010010";--5</p><p>  WHEN "0110"=>DISP<="10000010";--6</p

102、><p>  WHEN "0111"=>DISP<="11111000";--7</p><p>  WHEN "1000"=> DISP <="10000000";--8</p><p>  WHEN "1001"=> DISP <=

103、"10010000";--9</p><p>  WHEN "1010"=> DISP <="10111111";--間隔橫杠</p><p>  WHEN "1011"=> DISP <="10111111";--間隔橫杠</p><p> 

104、 WHEN "1100"=> DISP <="11111111";--超出范圍就不顯示停住,直到正確為止</p><p>  WHEN OTHERS=>NULL; ---千萬注意?。。。。?!不能為11111111,否則出錯,會有空顯示產(chǎn)生</p><p><b>  END CASE;</b></p>

105、;<p>  END PROCESS;</p><p><b>  END ONE;</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_UNSIGNED.ALL;&

106、lt;/p><p>  USE IEEE.STD_LOGIC_ARITH.ALL;</p><p>  ENTITY XITONG IS</p><p>  PORT ( SIN_AIN: IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  RST_AIN:IN STD_LOGIC_VECTOR(7 DOWNTO

107、 0);</p><p>  CLK_AIN:IN STD_LOGIC;</p><p>  MING_OUT: OUT STD_LOGIC;</p><p>  SCOUT: OUT STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  LEDCS_OUT: STD_LOGIC_VECTOR(7 DOWNTO 0)

108、;</p><p>  DISP_OUT:STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  END XITONG;</p><p>  ARCHITECTURE F1 OF XITONG </p><p>  COMPONENT SUOCUNQI </p><p>  PORT(REST:

109、IN STD_LOGIC_VECTOR(7 DOWNTO 0); </p><p>  SIN:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  SOUT1:OUT STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  SOUT2:OUT STD_LOGIC_VECTOR(7 DOWNTO 0

110、);</p><p>  SOUT3:OUT STD_LOGIC_VECTOR(7 DOWNTO 0));</p><p>  END COMPONENT;</p><p>  COMPONENT XUANYOU</p><p>  PORT(SOUT:IN STD_LOGIC_VECTOR(7 DOWNTO 0);</p>&

111、lt;p>  YOU1:OUT STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  YOU2:OUT STD_LOGIC_VECTOR(3 DOWNTO 0));</p><p>  END COMPONENT;</p><p>  COMPONENT XUANYOU2</p><p>  PORT(REST

112、:IN STD_LOGIC_VECTOR(7 DOWNTO 0); </p><p>  SOUT3:IN STD_LOGIC_VECTOR(7 DOWNTO 0); </p><p>  YOU1:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  ZQ:OUT STD_LOGIC;</p><p

113、>  LJ:OUT STD_LOGIC);</p><p>  END COMPONENT;</p><p>  COMPONENT TIME</p><p>  PORT(REST,SP,CLK :IN STD_LOGIC;</p><p>  SECOND1,SECOND2,MINITUE1,MINITUE2:OUT STD_

114、LOGIC_VECTOR(3 DOWNTO 0));</p><p>  END COMPONENT;</p><p>  COMPONENT SOU</p><p>  PORT(SECOND1:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  SECOND2:IN STD_LOGIC_VECTOR(3

115、DOWNTO 0);</p><p>  MINITUE1:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  MINITUE2:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  JISHI:OUT STD_LOGIC_VECTOR(15 DOWNTO 0));</p><p&

116、gt;  END COMPONENT;</p><p>  COMPONENT FENGMING</p><p>  PORT( BCD:IN STD_LOGIC_VECTOR(15 DOWNTO 0);</p><p>  MING:OUT STD_LOGIC);</p><p>  END COMPONENT;</p>

117、<p>  COMPONENT FENGMING</p><p><b>  PORT(</b></p><p>  CLK:IN STD_LOGIC;</p><p>  SECOND1,SECOND2,MINITUE1,MINITUE2:IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p>&

118、lt;p>  YOU:IN STD_LOGIC_VECTOR(3 DOWNTO 0);--顯示病房</p><p>  DISP:OUT STD_LOGIC_VECTOR(7 DOWNTO 0);--顯示代碼</p><p>  LEDCS:OUT STD_LOGIC_VECTOR(7 DOWNTO 0)--數(shù)碼管片選</p><p><b>  )

119、;</b></p><p>  END COMPONENT;</p><p>  SIGNAL A: STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  SIGNAL B: STD_LOGIC_VECTOR(15 DOWNTO 0);</p><p>  SIGNAL C: STD_LOGIC&

120、lt;/p><p>  SIGNAL D: STD_LOGIC</p><p>  SIGNAL E: STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>  SIGNAL F: STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  SIGNAL G:STD_LOGIC_VECTOR(3

121、DOWNTO 0);</p><p>  SIGNAL H:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  SIGNAL I:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  SIGNAL J: STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  

122、SIGNAL K:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p><b>  BEGIN </b></p><p>  U1:SUOCUNQI PORT MAP(SIN=>SIN_AIN,OUT1=>A,REST=>RST_AIN,</p><p>  SOUT3=>E,SOUT2=>

123、SCOUT);</p><p>  U2: XUANYOU PORT MAP ( SOUT=>A,YOU1=>F,YOU2=>G);</p><p>  U3: XUANYOU2 PORT MAP ( LJ=>C,ZQ=>D,REST=>RST_AIN,SOUT3=>E,</p><p><b>  YOU1=&g

124、t;F);</b></p><p>  U4: TIME PORT MAP (REST=>C, SP=>D,CLK=>CLK.AIN,SECOND1=>H,</p><p>  SECOND2=>I,MINITUE1=>J,MINITUE2=>K);</p><p>  U5:SOU PORT MAP ( JIS

125、HI=>B,SECOND1=>H,SECOND2=>I,</p><p>  MINITUE1=>J,MINITUE2=>K);</p><p>  U6: FENGMING PORT MAP(BCD=>B,MING=>,MING_OUT);</p><p>  U7:DISPLAY PORT MAP (DISP=>D

126、ISP_OUT,LEDCS=>LEDCS_OUT,YOU=>G,</p><p>  CLK=>CLK_AIN,SECOND1=>H,SECOND2=>I,</p><p>  MINITUE1=>J,MINITUE2=>K);</p><p>  END ARCHITECTURE F1;</p><p

127、>  LIBRARY IEEE; </p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p>  ENTITY TIME IS</p><p>  PORT(REST,SP,CLK :IN STD_LOGIC;

128、</p><p>  TI:OUT STD_LOGIC;</p><p>  SECOND1,SECOND2,MINITUE1,MINITUE2:OUT STD_LOGIC_VECTOR(3 DOWNTO 0));</p><p><b>  END TIME;</b></p><p>  ARCHITECTURE ON

129、E OF TIME IS</p><p>  SIGNAL TIMECLK:STD_LOGIC;</p><p>  SIGNAL CLK12:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  SIGNAL SEC1,SEC2:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>  SIG

130、NAL MINI1,MINI2:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  MINITUE1(3 DOWNTO 0)<=MINI1(3 DOWNTO 0);</p><p>  MINITUE2(3 DOWNTO 0)<=MINI2(3 DOWNTO

131、 0);</p><p>  SECOND1(3 DOWNTO 0)<=SEC1(3 DOWNTO 0);</p><p>  SECOND2(3 DOWNTO 0)<=SEC2(3 DOWNTO 0);</p><p>  PROCESS(CLK,SP)</p><p>  VARIABLE CNT:INTEGER RANGE

132、0 TO 120; --分頻 1S</p><p><b>  BEGIN</b></p><p>  IF (CLK'EVENT AND CLK='1') AND SP='1' THEN CNT:=CNT+1;</p><p>  IF CNT<60 THEN TIMECLK<='1

133、';</p><p>  ELSIF CNT<120 THEN TIMECLK<='0';</p><p>  ELSE CNT:=0;TIMECLK<='0';</p><p><b>  END IF;</b></p><p><b>  END I

134、F;</b></p><p>  IF(REST='0') THEN </p><p>  MINI2 <="0000"; MINI1 <="0000"; SEC2<="0000"; SEC1<="0000";</p><p><

135、b>  ELSE </b></p><p>  IF (TIMECLK'EVENT AND TIMECLK='1') THEN --檢驗時鐘上升沿</p><p>  IF SEC1<"1001"THEN SEC1<=SEC1+1;</p><p><b>  ELSE</b&

136、gt;</p><p>  SEC1<="0000";</p><p>  IF SEC2<"0101"THEN SEC2<=SEC2+1;</p><p><b>  ELSE</b></p><p>  SEC2<="0000";&l

溫馨提示

  • 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. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論