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

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quá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è):電子信息科學與技術(shù)</p><p><b>  指導教師:</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> ?。?)、鎖存器:對病房呼叫的信

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ù)碼管顯示器顯示的時間為當前優(yōu)先級最高的病房所呼叫的時間。</p><p>

10、;  (4)、計時器:病房呼叫系統(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>  :選優(yōu)模塊、對復(fù)位選優(yōu)模塊</p><p><b> ?。河嫊r模塊</b

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

13、決定時間顯示當前等待時間為最好,所以在鎖存模塊,把復(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)的問題,我們的時間模塊又只用了一個,顯示當前最優(yōu)先病房的等待時間,所以選優(yōu)2模塊連在選優(yōu)模塊的后面以及和8個位寬的復(fù)位信號相連,然后通過選優(yōu)模塊,使得輸出地復(fù)位信號為當前最優(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)一個上升沿,當上升沿到來時時間加計1s,另外mmss之中前一個m代表的是分的十位,后一個m代表的是分的

16、個位,前一個s代表的是秒的十位,后一個s代表的是秒的個位。</p><p>  顯示模塊:顯示模塊所要顯示的就是優(yōu)先級最高的呼叫病房的號碼以及呼叫等待的時間mmss,所以在模塊的設(shè)計當中,我們用中間的六個數(shù)碼管依次顯示當前最優(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)系起來的,當輸入為0000 0001 0000 0000表示的是1秒,0000 0010 0000 0000表示的是2秒,以此類推,當表示的時間是1-5秒時令蜂鳴器響,此時輸出為低電平,表是的是蜂鳴器工作。當時間在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)什么錯誤,所以,當問題再次出

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,當按下?lián)艽a開關(guān)SW1時表示2號病房開始計時,蜂鳴器接著響5秒鐘然后不響,到時間記為三分鐘時又開始報警。當同時按開關(guān)SW2與SW3時,病房號顯示的還是2,因為病房2的

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

24、A實驗指導書(5萬門).doc </p><p>  EDA技術(shù)與VHDL 清華大學出版社 黃繼業(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; ---千萬注意?。。。。。〔荒転?1111111,否則出錯,會有空顯示產(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)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論