版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 交通信號(hào)燈控制器</b></p><p> 一、課程設(shè)計(jì)的要求及目的:</p><p> 1.了解電子設(shè)計(jì)的具體流程和方法。</p><p> 2. 掌握電子設(shè)計(jì)的基本要求,能夠運(yùn)用所學(xué)的知識(shí)解決生活中的一些問(wèn)題。</p><p> 3. 初步掌握VHDL語(yǔ)言編程,并設(shè)計(jì)出一個(gè)有意義
2、的小型系統(tǒng)。</p><p> 4. 掌握Altium Designer6軟件的應(yīng)用,并且了解相關(guān)硬件的組成和功能。</p><p> 二、設(shè)計(jì)的功能要求:</p><p> 1、交通燈分南北方向和東西方向紅綠燈安排,SN為主</p><p> 干道,EW為支干道。此交通燈分為正常模式和緊急</p><p>
3、 模式,在正常模式下分為白天模式和夜間模式。</p><p> 2、交通燈可以根據(jù)時(shí)鐘的時(shí)間自動(dòng)從白天模式轉(zhuǎn)為黑夜模式,交通燈緊急模式和正常模式之間的轉(zhuǎn)換通過(guò)開(kāi)關(guān)控制,且當(dāng)從緊急模式回復(fù)到正常模式時(shí),數(shù)碼管顯示回到最初狀態(tài)。</p><p> 3、白天模式:主干道工作時(shí):SN(南北直走)綠燈40秒,黃燈5秒;SWNE(南拐西、北拐東)綠燈20秒,黃燈5秒。支干道工作時(shí):EW(東西直走)
4、綠燈20秒,黃燈5秒,WNES(西拐北、東拐南)綠燈20秒,黃燈5秒。(設(shè)計(jì)直走與左拐的功能是為了防止左拐與對(duì)面直走的車輛相撞)</p><p> 4、黑夜模式:主干道工作時(shí):SN(南北直走)綠燈20秒,黃燈5秒;SWNE(南拐西、北拐東)綠燈10秒,黃燈5秒。支干道工作時(shí):EW(東西直走)綠燈15秒,黃燈5秒,WNES(西拐北、東拐南)綠燈10秒,黃燈5秒。</p><p> 5、緊
5、急模式:主干道與支干道全亮紅燈且顯示為00。</p><p><b> 三、模塊說(shuō)明</b></p><p><b> 原理圖:</b></p><p><b> 1、信號(hào)模塊</b></p><p> 說(shuō)明:從器件庫(kù)提出的,提供20M赫茲的脈沖信號(hào)。</p>
6、;<p><b> 2、開(kāi)關(guān)模塊</b></p><p> 說(shuō)明:從器件庫(kù)提出,控制下載JTDLCD上燈的顯示,控制主控 模塊上CM的選擇,CM為0時(shí)為正常模式,CM為1時(shí)為緊 急模式。控制鍵盤(pán)模塊的復(fù)位R,鍵盤(pán)只有在復(fù)位后才能 正常使用,R為1有效。</p><p><b> 3、鍵盤(pán)模塊</b
7、></p><p> 說(shuō)明:KEYPAD器件從器件庫(kù)提出,將板上鍵盤(pán)變?yōu)?6個(gè)按鍵, 從左上到右下,按鍵按下時(shí),對(duì)應(yīng)輸出為1,松開(kāi)為0。 支持多個(gè)按鍵(必須是同一行)同時(shí)按下,帶防抖,與 NANOBOARD庫(kù)中器件KEYPAD直接相連。</p><p> 管腳說(shuō)明: ICOL[3..0]、OROW[3..0]連接KEYPAD器件,</p&g
8、t;<p> 輸入:CPIN 時(shí)鐘脈沖輸入 按20MHz設(shè)計(jì),鏈接脈沖發(fā)生器。</p><p> 復(fù)位R鏈接開(kāi)關(guān)O4。</p><p> 輸出:Y[15..0] 16個(gè)按鍵輸出。當(dāng)按下Y1時(shí),JTD模塊、時(shí)鐘模塊和JTDLCD模塊復(fù)位,Y1鏈接JTD模塊R、時(shí)鐘模塊R、R1和JTDLCD模塊R。</p><p> 模塊程序VHDL語(yǔ)言如下:&l
9、t;/p><p> LIBRARY IEEE;</p><p> USE IEEE.STD_LOGIC_1164.ALL;</p><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p> entity PADTOKEY is</p><p> port (CPIN,R :IN
10、 STD_LOGIC;</p><p> Y: OUT STD_LOGIC_VECTOR(15 DOWNTO 0);</p><p> ICOL : IN STD_LOGIC_VECTOR(3 DOWNTO 0); --ICOL[3..0]連接KEYPAD器件 </p><p> OROW : OUT STD_LOGIC_VECTOR(
11、3 DOWNTO 0) --ROW[3..0]連接KEYPAD器件 </p><p><b> );</b></p><p> END ENTITY;</p><p> architecture JGT of PADTOKEY is</p><p> TYPE STATES IS (S
12、0,S1,S2,S3,S4);</p><p> SIGNAL S: STATES;</p><p> SIGNAL SROW : STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p> SIGNAL CPCT : INTEGER RANGE 0 TO 255;</p><p> SIGNAL CTDELAY:
13、 INTEGER RANGE 0 TO 511;</p><p> SIGNAL CP:STD_LOGIC;</p><p> BEGIN --KEY分頻 </p><p> PROCESS(CPIN)</p><p><b> BEGIN</b&g
14、t;</p><p> IF CPIN='1' AND CPIN 'EVENT THEN</p><p> IF CPCT=255 THEN</p><p> CPCT<=0;CP<= NOT CP;</p><p><b> ELSE</b></p><p
15、> CPCT<=CPCT+1;</p><p><b> END IF;</b></p><p><b> END IF;</b></p><p> END PROCESS;</p><p> PROCESS(CP,R)</p><p> VARIAB
16、LE N:INTEGER RANGE 0 TO 12; --整數(shù)變量 </p><p><b> BEGIN</b></p><p> IF R='1' THEN</p><p> S<=S0;Y<="0000000000000000";SROW<="1110&q
17、uot;;N:=0;</p><p> ELSIF CP='1' AND CP'EVENT THEN</p><p><b> CASE S IS</b></p><p> WHEN S0=>S<=S1;</p><p> WHEN S1=>OROW<=SROW;S
18、<=S2;</p><p> WHEN S2=>S<=S3;</p><p><b> CASE N IS</b></p><p> WHEN 0 =>Y(3 DOWNTO 0)<=NOT ICOL;</p><p> WHEN 4 =>Y(7 DOWNTO 4)<=NO
19、T ICOL;</p><p> WHEN 8 =>Y(11 DOWNTO 8)<=NOT ICOL;</p><p> WHEN 12 =>Y(15 DOWNTO 12)<=NOT ICOL;</p><p> WHEN OTHERS=>NULL;</p><p><b> END CASE;
20、</b></p><p> WHEN S3=>IF N=12 THEN</p><p> N:=0;S<=S4;CTDELAY<=0;SROW<="1110";</p><p><b> ELSE</b></p><p> N:=N+4;S<=S1;S
21、ROW<=SROW(2 DOWNTO 0)&SROW(3);</p><p><b> END IF;</b></p><p> WHEN S4=>IF CTDELAY=511 THEN</p><p> S<=S1;CTDELAY<=0;</p><p><b> EL
22、SE</b></p><p> CTDELAY<=CTDELAY+1;</p><p><b> END IF;</b></p><p><b> END CASE;</b></p><p><b> END IF;</b></p>&l
23、t;p> END PROCESS;</p><p><b> END JGT;</b></p><p><b> 4、JTD模塊</b></p><p> 說(shuō)明: 此為主控模塊,在此模塊中將20MHZ的脈沖分頻為2.6HZ的脈沖,實(shí)現(xiàn)交通燈紅黃綠的變換,實(shí)現(xiàn)紅黃綠燈分秒的計(jì)數(shù),實(shí)現(xiàn)正常模式與緊急模式的轉(zhuǎn)換,接
24、收來(lái)自時(shí)鐘的脈沖,實(shí)現(xiàn)白天模式與黑夜模式的自動(dòng)轉(zhuǎn)換。</p><p><b> 管腳說(shuō)明:</b></p><p> 輸入:CM:為0時(shí)選擇正常模式,為1時(shí)選擇緊急模式,連接開(kāi)關(guān)O2。</p><p> CPIN:脈沖輸入,連接脈沖端口。</p><p> SWITCH:為1時(shí)選擇白天模式,為0時(shí)選擇黑夜模式,連
25、接時(shí)鐘模塊的MICOUT1。</p><p> R:復(fù)位,連接鍵盤(pán)模塊KEY0。</p><p> 輸出:EW[7..0]:輸出東西直走方向分秒信號(hào)。</p><p> EWRYG[2..0]:輸出東西直走方紅黃綠燈狀態(tài)信號(hào)。</p><p> SN[7..0]: 輸出南北直走方向分秒信號(hào)。</p><p>
26、 SNRYG[2..0]: 輸出南北直走方紅黃綠燈狀態(tài)信號(hào)</p><p> SWNE[7..0]: 輸出南拐西、北拐東方向分秒信號(hào)。</p><p> SWNERYG[2..0]: 輸出南拐西、北拐東紅黃綠燈狀態(tài)信號(hào)</p><p> WNES[7..0]:輸出西拐北、東拐南方向分秒信號(hào)。</p><p> WNESRYG[2..0
27、]: 輸出西拐北、東拐南方紅黃綠燈狀態(tài)信號(hào)。</p><p> 程序VHDL語(yǔ)言如下:</p><p> LIBRARY IEEE;</p><p> USE IEEE.STD_LOGIC_1164.ALL;</p><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p>
28、 USE IEEE.STD_LOGIC_ARITH.ALL;</p><p> entity JTD is</p><p> port (CPIN,R ,SWITCH,CM:IN STD_LOGIC;</p><p> SN,SWNE,EW,WNES :OUT STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p>
29、 EWRYG,SNRYG,SWNERYG,WNESRYG : OUT STD_LOGIC_VECTOR(2 DOWNTO 0)</p><p><b> );</b></p><p> end entity ;</p><p> architecture JGT of JTD is</p><p> SIGNA
30、L CTEW,CTSN,CTSWNE,CTWNES: STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p> SIGNAL CTFP: INTEGER RANGE 0 TO 4000000;</p><p> SIGNAL CP: STD_LOGIC;</p><p> TYPE STATES IS (S0,S1,S2,S3,S4,S5
31、,S6,S7);</p><p> SIGNAL S: STATES;</p><p><b> BEGIN</b></p><p> PROCESS(CPIN)</p><p><b> BEGIN</b></p><p> IF CPIN='1'
32、 AND CPIN 'EVENT THEN</p><p> IF CTFP=4000000 THEN</p><p> CTFP<=0;CP<=NOT CP;</p><p><b> ELSE</b></p><p> CTFP<=CTFP+1;</p><p&g
33、t;<b> END IF;</b></p><p><b> END IF;</b></p><p> END PROCESS;</p><p> PROCESS(SWITCH,CM,CP,R)</p><p><b> BEGIN</b></p>&
34、lt;p> IF CM='0' THEN -- 正常模式 </p><p> IF SWITCH='1' THEN -- 白天</p><p> -- SN SWNE EW WNES</p><p> --S0:
35、G40 R70 00</p><p> --S1:Y05 R30</p><p> --S2: 00 G20 R25</p><p> --S3: Y05 R05</p><p> --S4:R50 00 G20</p><p> --S5:
36、R30 Y05</p><p> --S6:R25 00 G20</p><p> --S7:R05 Y05</p><p> IF R='1' THEN --復(fù)位 </p><p> S<
37、=S0;CTSN<=X"28";CTEW<=X"46";CTWNES<=X"00"; SNRYG<="001";EWRYG<="100";</p><p> ELSIF CP='1' AND CP 'EVENT THEN</p><p>
38、;<b> CASE S IS</b></p><p> WHEN S0=>IF CTSN=X"01" THEN</p><p> S<=S1;CTSN<=X"05";CTEW<=X"1E";SNRYG<="010";EWRYG<="10
39、0";</p><p><b> ELSE</b></p><p> CTSN<=CTSN-1;CTEW<=CTEW-1;</p><p><b> END IF;</b></p><p> WHEN S1=>IF CTSN=X"01" THE
40、N</p><p> S<=S2;CTEW<=X"19";CTSN<=X"00";CTSWNE<=X"14";SWNERYG<="001";EWRYG<="001";</p><p><b> ELSE</b></p>
41、<p> CTSN<=CTSN-1;CTEW<=CTEW-1;</p><p><b> END IF;</b></p><p> WHEN S2=>IF CTSWNE=X"01" THEN</p><p> S<=S3;CTSWNE<=X"05";CT
42、EW<=X"05";SWNERYG<="010";EWRYG<="100";</p><p><b> ELSE</b></p><p> CTSWNE<=CTSWNE-1;CTEW<=CTEW-1;</p><p><b> END IF
43、;</b></p><p> WHEN S3=>IF CTSWNE=X"01" THEN</p><p> S<=S4;CTSN<=X"32";CTSWNE<=X"00";CTEW<=X"14";SNRYG<="100";EWRYG<
44、="001";</p><p><b> ELSE</b></p><p> CTSWNE<=CTSWNE-1;CTEW<=CTEW-1;</p><p><b> END IF;</b></p><p> WHEN S4=>IF CTEW=X"
45、;01" THEN</p><p> S<=S5;CTSN<=X"1E";CTEW<=X"05";SNRYG<="100";EWRYG<="010";</p><p><b> ELSE</b></p><p> CTS
46、N<=CTSN-1;CTEW<=CTEW-1;</p><p><b> END IF;</b></p><p> WHEN S5=>IF CTEW=X"01" THEN</p><p> S<=S6;CTSN<=X"19";CTWNES<=X"14&q
47、uot;;CTEW<=X"00";SNRYG<="100";WNESRYG<="001";</p><p><b> ELSE</b></p><p> CTSN<=CTSN-1;CTEW<=CTEW-1;</p><p><b> END
48、 IF;</b></p><p> WHEN S6=>IF CTWNES=X"01" THEN</p><p> S<=S7;CTSN<=X"05";CTWNES<=X"05";SNRYG<="100";EWRYG<="010";</
49、p><p><b> ELSE</b></p><p> CTSN<=CTSN-1;CTWNES<=CTWNES-1;</p><p><b> END IF;</b></p><p> WHEN S7=>IF CTWNES=X"01" THEN</p
50、><p> S<=S0;CTSN<=X"28";CTEW<=X"46";CTWNES<=X"00"; SNRYG<="001";EWRYG<="100";</p><p><b> ELSE</b></p><p&
51、gt; CTSN<=CTSN-1;CTWNES<=CTWNES-1;</p><p><b> END IF;</b></p><p> WHEN OTHERS=>NULL;</p><p><b> END CASE;</b></p><p><b> END
52、 IF;</b></p><p> ELSIF SWITCH='0' THEN --黑夜</p><p> -- SN SWNE EW WNES</p><p> --S0:G20 R40 00</p><p> --S1:
53、Y05 R20</p><p> --S2:00 G10 R15</p><p> --S3: Y05 R05</p><p> --S4:R35 00 G15</p><p> --S5:R20 Y05</p><p> --S6:R15
54、 00 G10</p><p> --S7:R05 Y05</p><p> IF R='1' THEN --復(fù)位 </p><p> S<=S0;CTSN<=X"14";CTEW<=X"28
55、";CTWNES<=X"00"; SNRYG<="001";EWRYG<="100";</p><p> ELSIF CP='1' AND CP 'EVENT THEN</p><p><b> CASE S IS</b></p><
56、p> WHEN S0=>IF CTSN=X"01" THEN</p><p> S<=S1;CTSN<=X"05";CTEW<=X"14";SNRYG<="010";EWRYG<="100";</p><p><b> ELSE<
57、;/b></p><p> CTSN<=CTSN-1;CTEW<=CTEW-1;</p><p><b> END IF;</b></p><p> WHEN S1=>IF CTSN=X"01" THEN</p><p> S<=S2;CTEW<=X&quo
58、t;05";CTSN<=X"00";CTSWNE<=X"0F";SWNERYG<="001";EWRYG<="001";</p><p><b> ELSE</b></p><p> CTSN<=CTSN-1;CTEW<=CTEW-1;&l
59、t;/p><p><b> END IF;</b></p><p> WHEN S2=>IF CTSWNE=X"01" THEN</p><p> S<=S3;CTSWNE<=X"05";CTEW<=X"05";SWNERYG<="010&qu
60、ot;;EWRYG<="100";</p><p><b> ELSE</b></p><p> CTSWNE<=CTSWNE-1;CTEW<=CTEW-1;</p><p><b> END IF;</b></p><p> WHEN S3=>I
61、F CTSWNE=X"01" THEN</p><p> S<=S4;CTSN<=X"23";CTSWNE<=X"00";CTEW<=X"0F";SNRYG<="100";EWRYG<="001";</p><p><b>
62、 ELSE</b></p><p> CTSWNE<=CTSWNE-1;CTEW<=CTEW-1;</p><p><b> END IF;</b></p><p> WHEN S4=>IF CTEW=X"01" THEN</p><p> S<=S5;C
63、TSN<=X"14";CTEW<=X"05";SNRYG<="100";EWRYG<="010";</p><p><b> ELSE</b></p><p> CTSN<=CTSN-1;CTEW<=CTEW-1;</p><p&
64、gt;<b> END IF;</b></p><p> WHEN S5=>IF CTEW=X"01" THEN</p><p> S<=S6;CTSN<=X"0F";CTEW<=X"00";CTWNES<=X"0A";SNRYG<="1
65、00";WNESRYG<="001";</p><p><b> ELSE</b></p><p> CTSN<=CTSN-1;CTEW<=CTEW-1;</p><p><b> END IF;</b></p><p> WHEN S6=&g
66、t;IF CTWNES=X"01" THEN</p><p> S<=S7;CTSN<=X"05";CTWNES<=X"05";SNRYG<="100";EWRYG<="010";</p><p><b> ELSE</b></p
67、><p> CTSN<=CTSN-1;CTWNES<=CTWNES-1;</p><p><b> END IF;</b></p><p> WHEN S7=>IF CTWNES=X"01" THEN</p><p> S<=S0;CTSN<=X"14&qu
68、ot;;CTEW<=X"28";CTWNES<=X"00"; SNRYG<="001";EWRYG<="100";</p><p><b> ELSE</b></p><p> CTSN<=CTSN-1;CTWNES<=CTWNES-1;</p
69、><p><b> END IF;</b></p><p> WHEN OTHERS=>NULL;</p><p><b> END CASE;</b></p><p><b> END IF;</b></p><p><b> E
70、ND IF;</b></p><p> ELSIF CM='1'THEN --緊急模式 SN EW 亮紅燈</p><p> CTSN<=X"00" ;CTEW<=X"00";CTSWNE<=X"00" ;CTWNES<=X&quo
71、t;00";EWRYG<="100";SNRYG<="100";WNESRYG<="100";SWNERYG<="100" ;</p><p><b> END IF;</b></p><p> END PROCESS;</p><
72、p> PROCESS(CTEW,CTSN,CTSWNE,CTWNES) --將16進(jìn)制轉(zhuǎn)換為BCD碼</p><p><b> BEGIN</b></p><p> IF CTEW<X"0A" THEN</p><p><b> EW<=CTEW;</b><
73、;/p><p> ELSIF CTEW<X"14" THEN</p><p> EW<=CTEW+6;</p><p> ELSIF CTEW<X"1E" THEN</p><p> EW<=CTEW+12;</p><p> ELSIF CTEW&
74、lt;X"28" THEN</p><p> EW<=CTEW+18;</p><p> ELSIF CTEW<X"32" THEN</p><p> EW<=CTEW+24;</p><p> ELSIF CTEW<X"3C" THEN</p&
75、gt;<p> EW<=CTEW+30;</p><p> ELSIF CTEW<X"46" THEN</p><p> EW<=CTEW+36;</p><p><b> ELSE</b></p><p> EW<=CTEW+42;</p>
76、<p><b> END IF;</b></p><p> IF CTSN<X"0A" THEN</p><p><b> SN<=CTSN;</b></p><p> ELSIF CTSN<X"14" THEN</p><
77、p> SN<=CTSN+6;</p><p> ELSIF CTSN<X"1E" THEN</p><p> SN<=CTSN+12;</p><p> ELSIF CTSN<X"28" THEN</p><p> SN<=CTSN+18;</p>
78、;<p> ELSIF CTSN<X"32" THEN</p><p> SN<=CTSN+24;</p><p> ELSIF CTSN<X"3C" THEN</p><p> SN<=CTSN+30;</p><p> ELSIF CTSN<X&
79、quot;46" THEN</p><p> SN<=CTSN+36;</p><p><b> ELSE</b></p><p> SN<=CTSN+40;</p><p><b> END IF;</b></p><p> IF CTSWN
80、E<X"0A" THEN</p><p> SWNE<=CTSWNE;</p><p> ELSIF CTSWNE<X"14" THEN</p><p> SWNE<=CTSWNE+6;</p><p> ELSIF CTSWNE<X"1E" T
81、HEN</p><p> SWNE<=CTSWNE+12;</p><p> ELSIF CTSWNE<X"28" THEN</p><p> SWNE<=CTSWNE+18;</p><p> ELSIF CTSWNE<X"32" THEN</p><
82、;p> SWNE<=CTSWNE+24;</p><p> ELSIF CTSWNE<X"3C" THEN</p><p> SWNE<=CTSWNE+30;</p><p><b> ELSE</b></p><p> SWNE<=CTSWNE+36;<
83、/p><p><b> END IF;</b></p><p> IF CTWNES<X"0A" THEN</p><p> WNES<=CTWNES;</p><p> ELSIF CTWNES<X"14" THEN</p><p>
84、 WNES<=CTWNES+6;</p><p> ELSIF CTWNES<X"1E" THEN</p><p> WNES<=CTWNES+12;</p><p> ELSIF CTWNES<X"28" THEN</p><p> WNES<=CTWNES+1
85、8;</p><p> ELSIF CTWNES<X"32" THEN</p><p> WNES<=CTWNES+24;</p><p> ELSIF CTWNES<X"3C" THEN</p><p> WNES<=CTWNES+30;</p><
86、p><b> ELSE</b></p><p> WNES<=CTWNES+36;</p><p><b> END IF;</b></p><p> END PROCESS;</p><p><b> END JGT;</b></p>&l
87、t;p><b> 5、時(shí)鐘模塊</b></p><p> 說(shuō)明:將20MHZ的脈沖分頻為2.6HZ,由此脈沖作為分秒的計(jì)數(shù),秒計(jì)數(shù)為60進(jìn)制,分計(jì)數(shù)為5進(jìn)制。當(dāng)分秒從00計(jì)數(shù)到20時(shí),MICOUT1輸出為1;當(dāng)分秒從20計(jì)數(shù)到40時(shí),MICOUT1輸出為0。</p><p><b> 管腳說(shuō)明:</b></p><
88、p> 輸入:CPIN:連接脈沖端口。</p><p> R、R1:復(fù)位,連接鍵盤(pán)模塊KEY0,為1有效。</p><p> 輸出:MICOUT:輸出信號(hào),連接SWITCH。</p><p> 程序WHDL語(yǔ)言如下:</p><p> LIBRARY IEEE;</p><p> USE IEEE.
89、STD_LOGIC_1164.ALL;</p><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p> USE IEEE.STD_LOGIC_ARITH.ALL;</p><p> ENTITY CLOCK1 IS</p><p> PORT(CPIN,R,R1:IN STD_LOGIC;<
90、/p><p> MICOUT1: OUT STD_LOGIC);</p><p> END CLOCK1;</p><p> ARCHITECTURE JGT OF CLOCK1 IS</p><p> TYPE STATES IS (S0,S1,S2); --3個(gè)狀態(tài):分秒:00 20 40</
91、p><p> SIGNAL S:STATES;</p><p> SIGNAL MICC:STD_LOGIC_VECTOR( 3 DOWNTO 0);</p><p> SIGNAL SCE:STD_LOGIC_VECTOR( 7 DOWNTO 0);</p><p> SIGNAL CTFP: INTEGER RANGE 0 TO 40
92、00000;</p><p> SIGNAL CP:STD_LOGIC;</p><p><b> BEGIN</b></p><p> PROCESS(CPIN) --分頻到2.6HZ, T=0.38S </p><p><b> B
93、EGIN</b></p><p> IF CPIN='1' AND CPIN 'EVENT THEN</p><p> IF CTFP=4000000 THEN</p><p> CTFP<=0;CP<=NOT CP;</p><p><b> ELSE</b>&l
94、t;/p><p> CTFP<=CTFP+1;</p><p><b> END IF;</b></p><p><b> END IF;</b></p><p> END PROCESS;</p><p> PROCESS(CP,R)</p>&l
95、t;p><b> BEGIN</b></p><p> IF R='1' THEN --復(fù)位到00</p><p> MICOUT1<='1';</p><p> S<=S0;
96、 -- 分秒 輸出</p><p> ELSIF RISING_EDGE(CP) THEN --S0 00 1</p><p> CASE S IS --S1 20 0</p><p> WHEN S0=>MICOUT1<='
97、;1'; --S2 40 1</p><p><b> S<=S1;</b></p><p> WHEN S1=>IF MICC="0010" THEN</p><p> MICOUT1<='0';</p><p>
98、;<b> S<=S2;</b></p><p><b> END IF;</b></p><p> WHEN S2=>IF MICC="0100" THEN</p><p><b> S<=S0;</b></p><p><
99、b> END IF;</b></p><p><b> END CASE;</b></p><p><b> END IF;</b></p><p> END PROCESS;</p><p> PROCESS(CP,R1)</p><p><
100、;b> BEGIN</b></p><p> IF R1='1' THEN --復(fù)位</p><p> SCE<="00000000";</p><p> MICC<="0000";</p><p> EL
101、SIF RISING_EDGE(CP) THEN --若秒為*9則變*0,在此情況下: </p><p> IF SCE(3 DOWNTO 0)="1001" THEN --若*=5則秒為00,在此情況下:</p><p> SCE(3 DOWNTO 0)<="0000&quo
102、t;; --若分為4則分0;否則分++ </p><p> IF SCE(7 DOWNTO 4)="0101" THEN</p><p> SCE<="00000000";</p><p> IF MICC="0100" THEN</p><
103、p> MICC<="0000";</p><p><b> ELSE</b></p><p> MICC<=MICC+1;</p><p><b> END IF;</b></p><p><b> ELSE</b></p&
104、gt;<p> SCE( 7 DOWNTO 4)<=SCE(7 DOWNTO 4)+1; --若*!=5則*++ </p><p><b> END IF ;</b></p><p><b> ELSE</b></p><p> SCE(3 DOWNTO 0)<=SCE(3 DO
105、WNTO 0)+1; --若秒個(gè)位不為9,則個(gè)位++ </p><p><b> END IF;</b></p><p><b> END IF;</b></p><p> END PROCESS;</p><p><b> END JGT;</b><
106、/p><p> 6、JTDLCD模塊</p><p> 說(shuō)明:將主控模塊輸入的交通燈狀態(tài),數(shù)字轉(zhuǎn)換為數(shù)碼管可識(shí)別的BCD碼,并在數(shù)碼管上顯示。</p><p><b> 管腳說(shuō)明:</b></p><p> 輸入:R:復(fù)位為1有效,連接鍵盤(pán)模塊KEY0。</p><p> CPIN:連接脈沖
107、發(fā)生器。</p><p> EW[7..0]:輸入東西直走方向分秒信號(hào),連接主控模塊。 EWRYG[2..0]:輸入東西直走方紅黃綠燈狀態(tài)信號(hào),連接主控模 塊。</p><p> SN[7..0]: 輸入南北直走方向分秒信號(hào),連接主控模塊。</p><p> SNRYG[2..0]: 輸入南北直走方紅黃綠燈狀態(tài)信號(hào),連接主控模塊。
108、</p><p> SWNE[7..0]: 輸入南拐西、北拐東方向分秒信號(hào),連接主控模塊。</p><p> SWNERYG[2..0]: 輸入南拐西、北拐東紅黃綠燈狀態(tài)信號(hào),連接主控模塊。</p><p> WNES[7..0]:輸入西拐北、東拐南方向分秒信號(hào),連接主控模塊。</p><p> WNESRYG[2..0]: 輸入西拐
109、北、東拐南方紅黃綠燈狀態(tài)信號(hào),連接主控模塊。</p><p> BUSY:連接顯示端口BUSY,判斷數(shù)碼管是否忙碌。</p><p> 輸出:CLK:給顯示端口脈沖。</p><p> REST:給顯示端口復(fù)位信號(hào)。</p><p> DATA[7..0]:輸出顯示端口可識(shí)別的分秒計(jì)數(shù)。</p><p> A
110、DDR[3..0]:給顯示端口可識(shí)別的交通燈狀態(tài)顯示。</p><p><b> OUTLINE:</b></p><p> STORBE:輸出顯示端口的數(shù)據(jù)輸入信號(hào),1有效。</p><p> 程序VHDL語(yǔ)言如下:</p><p> LIBRARY IEEE;</p><p> US
111、E IEEE.STD_LOGIC_1164.ALL;</p><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p> entity JTDLCD is</p><p> port (CPIN,R,BUSY :IN STD_LOGIC;</p><p> EW,SWNE,WNES,SN :IN ST
112、D_LOGIC_VECTOR(7 DOWNTO 0);</p><p> EWRYG,SWNERYG,WNESRYG,SNRYG : IN STD_LOGIC_VECTOR(2 DOWNTO 0);</p><p> CLK,RST,STROBE,OUTLINE : OUT STD_LOGIC;</p><p> DATA : OUT STD_LOGIC_VE
113、CTOR(7 DOWNTO 0);</p><p> ADDR : OUT STD_LOGIC_VECTOR(3 DOWNTO 0)</p><p><b> );</b></p><p> end entity ;</p><p> architecture JGT of JTDLCD is</p>
114、<p> TYPE STATES IS (S0,S1,S2,S3,S4);</p><p> SIGNAL S: STATES;</p><p> SIGNAL LCDPT : INTEGER RANGE 0 TO 24;</p><p> SIGNAL CPCT : INTEGER RANGE 0 TO 65535;</p>&
115、lt;p> SIGNAL CP: STD_LOGIC;</p><p> SIGNAL ASCEW,ASCSWNE,ASCWNES,ASCSN : STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p><b> begin</b></p><p> PROCESS(CPIN,R)</p><
116、;p><b> BEGIN</b></p><p> CLK<=CPIN; --分頻為500US周期 </p><p> IF R='1' THEN</p><p> CPCT<=65535;</p><p> ELSIF
117、 CPIN='1' AND CPIN 'EVENT THEN</p><p> IF CPCT=0 THEN</p><p> CPCT<=65535;CP<=NOT CP;</p><p><b> ELSE</b></p><p> CPCT<=CPCT-1;<
118、/p><p><b> END IF;</b></p><p><b> END IF;</b></p><p> END PROCESS;</p><p> PROCESS(CP,R) --主進(jìn)程:擬采用500us時(shí)鐘,即在500u
119、s后完成狀態(tài)轉(zhuǎn)換,修改LCDPT指針</p><p> BEGIN --S1,S2完成初始化固定顯示的功能</p><p> IF R='1' THEN</p><p> S<=S0;LCDPT<=0;RST<='1';</p&
120、gt;<p> ELSIF CP='1' AND CP 'EVENT THEN --S0:初始狀態(tài),在R=1時(shí),處于S0狀態(tài),LCDPT=0</p><p><b> CASE S IS</b></p><p> WHEN S0=> S<=S1;LCDPT<=0;RST<=&
121、#39;1'; --輸出rst=1, 轉(zhuǎn)S1 </p><p> WHEN S1=> RST<='0';STROBE<='0'; --S1:輸出RST=0;LCD數(shù)據(jù)輸入無(wú)效</p><p> IF BUSY='0' THEN --判斷BUSY=0?&
122、lt;/p><p> LCDPT<=LCDPT+1; --Y: LCDPT+1; </p><p> IF LCDPT=13 THEN --LCDPT到固定最后? ¿</p><p> S<=S3; --是:到最后就到動(dòng)態(tài)掃描S3 &l
123、t;/p><p> ELSE --否: ->S2</p><p><b> S<=S2;</b></p><p><b> END IF;</b></p><p> END IF;
124、 --N; NULL</p><p> WHEN S2=> S<=S1;STROBE<='1'; --S2:給出STROBE信號(hào)。轉(zhuǎn)S1 </p><p> --S3~S4完成掃描顯示功能 </p><p> WHEN S3=> STROBE<='0';
125、 --S3:BUSY=0? :Y: LCDPT循環(huán)+1 ,轉(zhuǎn)S4 </p><p> IF BUSY='0' THEN</p><p> IF LCDPT=24 THEN</p><p> LCDPT<=13;</p><p><b> ELSE</b></p>
126、<p> LCDPT<=LCDPT+1;</p><p><b> END IF;</b></p><p><b> S<=S4;</b></p><p><b> END IF;</b></p><p> WHEN S4=> STRO
127、BE<='1';S<=S3; --S4:給出STROBE信號(hào),輸入數(shù)據(jù),轉(zhuǎn)S3 </p><p> WHEN OTHERS=> NULL;</p><p><b> END CASE;</b></p><p><b> END IF;</b></p&
128、gt;<p> END PROCESS;</p><p> PROCESS(LCDPT)</p><p><b> BEGIN</b></p><p> CASE LCDPT IS --選擇輸出進(jìn)程(LCDPT)</p>
129、<p> WHEN 0 => NULL; --LCDPT=0,NULL </p><p> --LCDPT=1~12 顯示SN SWNE EW WNES </p><p> WHEN 1=> DATA<="01010011";ADDR&l
130、t;="0001";OUTLINE<='0'; --S</p><p> WHEN 2=> DATA<="01001110";ADDR<="0010";OUTLINE<='0'; --N</p><p> WHEN 3=> DATA<="
131、;01010011";ADDR<="0100";OUTLINE<='0'; --S</p><p> WHEN 4=> DATA<="01010111";ADDR<="0101";OUTLINE<='0'; --W</p><p> WHEN
132、 5=> DATA<="01001110";ADDR<="0110";OUTLINE<='0'; --N</p><p> WHEN 6=> DATA<="01000101";ADDR<="0111";OUTLINE<='0'; --E</
133、p><p> WHEN 7=> DATA<="01000101";ADDR<="1000";OUTLINE<='0'; --E</p><p> WHEN 8=> DATA<="01010111";ADDR<="1001";OUTLINE<=&
134、#39;0'; --W</p><p> WHEN 9=> DATA<="01010111";ADDR<="1011";OUTLINE<='0'; --W</p><p> WHEN 10=> DATA<="01001110";ADDR<="1
135、100";OUTLINE<='0'; --N</p><p> WHEN 11=> DATA<="01000101";ADDR<="1101";OUTLINE<='0'; --E</p><p> WHEN 12=> DATA<="0101001
136、1";ADDR<="1110";OUTLINE<='0'; --S</p><p> WHEN 13=>DATA<=ASCSN;ADDR<="0001";OUTLINE<='1'; --SN:GYR 計(jì)數(shù) </p><p>
137、WHEN 14=>DATA<="0011"&SN(7 DOWNTO 4);ADDR<="0010";OUTLINE<='1';</p><p> WHEN 15=>DATA<="0011"&SN(3 DOWNTO 0);ADDR<="0011";OUTLINE
138、<='1';</p><p> WHEN 16=>DATA<=ASCSWNE;ADDR<="0100";OUTLINE<='1'; --SWNE:GYR 計(jì)數(shù) WHEN 17=>DATA<="0011"&SWNE(7 DOWNTO 4);ADDR<="
139、;0101";OUTLINE<='1';</p><p> WHEN 18=>DATA<="0011"&SWNE(3 DOWNTO 0);ADDR<="0110";OUTLINE<='1';</p><p> WHEN 19=>DATA<=ASCEW;AD
140、DR<="1000";OUTLINE<='1'; -- EW: GYR 計(jì)數(shù) </p><p> WHEN 20=>DATA<="0011"&EW(7 DOWNTO 4);ADDR<="1001";OUTLINE<='1';</p>
141、;<p> WHEN 21=>DATA<="0011"&EW(3 DOWNTO 0);ADDR<="1010";OUTLINE<='1';</p><p> WHEN 22=>DATA<=ASCWNES;ADDR<="1011";OUTLINE<='1
142、9;; -- WNES: GYR 計(jì)數(shù) WHEN 23=>DATA<="0011"&WNES(7 DOWNTO 4);ADDR<="1100";OUTLINE<='1';</p><p> WHEN 24=>DATA<="0011"&WNES(3 DOWNT
143、O 0);ADDR<="1101";OUTLINE<='1';</p><p> WHEN OTHERS=> NULL;</p><p><b> END CASE;</b></p><p> END PROCESS;</p><p> PROCESS(EWR
144、YG)</p><p> BEGIN --EW :RYG 顯示 </p><p> CASE EWRYG IS</p><p> WHEN "100" => ASCEW<="01010010";</p>
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)電交通信號(hào)燈課程設(shè)計(jì)---交通信號(hào)燈控制器仿真設(shè)計(jì)
- 交通信號(hào)燈課程設(shè)計(jì)---交通信號(hào)燈系統(tǒng)設(shè)計(jì)
- 信號(hào)燈課程設(shè)計(jì)---簡(jiǎn)易交通信號(hào)燈控制器
- eda課程設(shè)計(jì)--交通信號(hào)燈控制器
- 數(shù)電課程設(shè)計(jì)---交通信號(hào)燈控制器
- 交通信號(hào)燈課程設(shè)計(jì)--交通信號(hào)燈控制電路的設(shè)計(jì)
- eda課程設(shè)計(jì)---交通信號(hào)燈控制器設(shè)計(jì)
- 數(shù)電交通信號(hào)燈課程設(shè)計(jì)
- 課程設(shè)計(jì)---交通信號(hào)燈控制器
- 課程設(shè)計(jì)---交通信號(hào)燈控制器
- 交通信號(hào)燈控制器課程設(shè)計(jì)
- 課程設(shè)計(jì)---交通信號(hào)燈控制器
- eda課程設(shè)計(jì)報(bào)告交通信號(hào)燈控制
- eda課程設(shè)計(jì)報(bào)告--交通信號(hào)燈控制
- 交通信號(hào)燈控制課程設(shè)計(jì)
- 數(shù)電課程設(shè)計(jì)--簡(jiǎn)易交通信號(hào)燈
- 數(shù)電課程設(shè)計(jì)報(bào)告——交通信號(hào)燈
- 課程設(shè)計(jì)交通信號(hào)燈
- 交通信號(hào)燈課程設(shè)計(jì)
- 交通信號(hào)燈控制課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論