版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 目 錄</b></p><p> 1 設(shè)計(jì)任務(wù)和要求2</p><p> 1.1 設(shè)計(jì)任務(wù)2</p><p> 1.2 交通燈控制器的基本要求2</p><p> 2 工作原理及方案設(shè)計(jì)3</p><p> 2.1 交通燈控制器的設(shè)計(jì)原理3&
2、lt;/p><p> 2.2交通燈控制器的基本方案3</p><p><b> 3 系統(tǒng)設(shè)計(jì)4</b></p><p> 3.1 計(jì)數(shù)器的設(shè)計(jì)4</p><p> 3.2 控制器的設(shè)計(jì)4</p><p> 3.3 分位器的設(shè)計(jì)5</p><p> 3.4
3、 交通燈控制器的頂層原理5</p><p><b> 4 參考程序6</b></p><p> 4.1 計(jì)數(shù)器的程序6</p><p> 4.2 控制器的程序7</p><p> 4.3 分位電路程序11</p><p> 4.4. 七段譯碼電路的程序12</p&g
4、t;<p> 5系統(tǒng)調(diào)試與性能分析13</p><p> 5.1 交通燈計(jì)數(shù)器波形圖13</p><p> 5.2控制器的波形圖13</p><p> 5.3 分位的波形圖14</p><p> 5.4 七段譯碼電路的波形圖14</p><p> 1 設(shè)計(jì)任務(wù)和要求</p&g
5、t;<p><b> 1.1 設(shè)計(jì)任務(wù)</b></p><p> 用FPGA實(shí)現(xiàn)一個(gè)智能交通燈系統(tǒng),根據(jù)設(shè)計(jì)要求分析智能交通燈系統(tǒng)的基本原理,設(shè)計(jì)系統(tǒng)框圖,設(shè)計(jì)完成后給出FPGA占用資源分析。</p><p> 1.2 交通燈控制器的基本要求</p><p> ?。?)道路足夠?qū)挘须p向六通道。車(chē)輛直行不允許車(chē)輛左拐,允許右
6、拐。須另設(shè)左拐時(shí)間。針對(duì)上述通行規(guī)則,車(chē)輛控制燈有直行(↑)、左拐(←)和右拐(→)三個(gè)綠色指示燈、黃燈以及一個(gè)紅色指示燈。紅色指示燈亮,代表禁止車(chē)輛通行、一個(gè)方向燈亮的順序?yàn)榫G燈、黃燈、左拐燈、紅燈,前三種燈亮?xí)r間等于另一側(cè)的紅燈亮?xí)r間。</p><p> (2)車(chē)輛正常通行時(shí)間為40秒,黃燈為5秒,左拐為10秒,由各方向設(shè)置的倒計(jì)時(shí)顯示器顯示時(shí)間,向司機(jī)提剩余時(shí)間。當(dāng)一個(gè)方向車(chē)流量加大時(shí),自動(dòng)調(diào)節(jié)。<
7、/p><p> ?。?)行人過(guò)馬路需提出申請(qǐng),且只在車(chē)輛直行時(shí)才能響應(yīng)行人的請(qǐng)求,行人在申請(qǐng)得到響應(yīng)后方可穿越,穿越時(shí)間為60秒。</p><p> ?。?)交通警察有權(quán)隨時(shí)指定系統(tǒng)停在某個(gè)狀態(tài),確保某個(gè)方向的車(chē)輛流通。</p><p> 2 工作原理及方案設(shè)計(jì)</p><p> 2.1 交通燈控制器的設(shè)計(jì)原理</p><
8、;p> 交通燈控制器的核心范圍是一個(gè)計(jì)數(shù)范圍為0~59共(60秒)的計(jì)數(shù)器和一個(gè)根據(jù)計(jì)數(shù)值做出規(guī)定反映的控制器。另外,還需要輸入CLK時(shí)鐘信號(hào)。最后,要驅(qū)動(dòng)七段數(shù)碼管,顯然還需要一個(gè)譯碼電路。 </p><p> 圖2.1交通燈控制器原理圖</p><p> 2.2 交通燈控制器的基本方案</p><p> 交通燈控制器的核心范圍是一個(gè)計(jì)數(shù)范圍為0~
9、59共(60秒)的計(jì)數(shù)器和一個(gè)根據(jù)計(jì)數(shù)值做出規(guī)定反映的控制器。另外,作者所用的實(shí)驗(yàn)儀配備的晶振為50MHZ,因此還需要一個(gè)分頻電路。最后,要驅(qū)動(dòng)七段數(shù)碼管,顯然還需要一個(gè)譯碼電路。 </p><p> 圖2.2 交通燈控制器系統(tǒng)框圖</p><p><b> 3 系統(tǒng)設(shè)計(jì)</b></p><p> 3.1 計(jì)數(shù)器的設(shè)計(jì)</p&
10、gt;<p> 這里需要的計(jì)數(shù)器的計(jì)數(shù)范圍為0~59。計(jì)到59后,下一個(gè)時(shí)鐘沿恢復(fù)到0,開(kāi)始下一輪計(jì)數(shù)。此外,當(dāng)檢測(cè)到特殊情況(hold=1)發(fā)生時(shí),計(jì)數(shù)器暫停計(jì)數(shù),而系統(tǒng)恢復(fù)信號(hào)則使計(jì)數(shù)器異步清0。</p><p> 3.2 控制器的設(shè)計(jì)</p><p> 控制器的作用是根據(jù)計(jì)數(shù)器控制發(fā)光二極管的亮、滅,以及輸出倒計(jì)時(shí)數(shù)值給七段數(shù)譯管的分位譯碼電路。此外,當(dāng)檢測(cè)到特殊
11、情況時(shí),無(wú)條件點(diǎn)亮紅色的發(fā)光二極管。</p><p> 由于控制器要對(duì)于數(shù)值進(jìn)行判斷,很容易想到用IF語(yǔ)句來(lái)實(shí)現(xiàn)。本設(shè)計(jì)采用利用時(shí)鐘沿的下降沿讀取前級(jí)計(jì)數(shù)器的計(jì)數(shù)植,然后做出反應(yīng)。</p><p> 圖3.2控制器符號(hào)框圖</p><p> 3.3 分位器的設(shè)計(jì)</p><p> 因?yàn)榭刂破鬏敵龅牡褂?jì)時(shí)數(shù)值可能是1位或2位十進(jìn)制數(shù),所
12、以在七段數(shù)碼管的譯碼電路前要加上分位電路(即將其分為2個(gè)1位的十進(jìn)制數(shù)。(如25分為2和 5,7分為0和7)</p><p> 與控制器一樣,分位電路同樣可以由時(shí)鐘驅(qū)動(dòng),也可以設(shè)計(jì)成純組合邏輯電路??刂破髦校肓思拇嫫?。為了讓讀者開(kāi)拓眼界,分位電路就用組合邏輯電路實(shí)現(xiàn)。</p><p> 3.4 交通燈控制器的頂層原理</p><p> 交通燈控制
13、器的核心范圍是一個(gè)計(jì)數(shù)范圍為0~59共(60秒)的計(jì)數(shù)器和一個(gè)根據(jù)計(jì)數(shù)值做出規(guī)定反映的控制器。另外,還需要輸入CLK時(shí)鐘信號(hào)。最后,要驅(qū)動(dòng)七段數(shù)碼管,顯然還需要一個(gè)譯碼電路來(lái)完成交通燈控制器的設(shè)計(jì)。</p><p> 圖3.4交通燈控制器的頂層原理圖</p><p><b> 4 參考程序</b></p><p> 4.1 計(jì)數(shù)器的程序
14、</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity cnt120 is</p><p> port(clk,rst,hol
15、d :in std_logic;</p><p> cq :out std_logic_vector(6 downto 0));</p><p> end cnt120;</p><p> architecture behav of cnt120 is</p><p><b> begin</b></p&g
16、t;<p> process(clk,rst,hold)</p><p> variable cqi:std_logic_vector(6 downto 0);</p><p><b> begin</b></p><p> if rst='1' then cqi:=(others=>'0
17、39;);</p><p> elsif clk'event and clk='1' then</p><p> if hold='1' then</p><p> cqi:=cqi+0; ——當(dāng)出現(xiàn)緊急情況時(shí),計(jì)數(shù)器暫停計(jì)數(shù)</p><p><b> else</b>&l
18、t;/p><p> if cqi<119 then cqi:=cqi+1;</p><p> else cqi:=(others=>'0');</p><p><b> end if;</b></p><p><b> end if;</b></p>&
19、lt;p><b> end if;</b></p><p><b> cq<=cqi;</b></p><p> end process;</p><p> end behav; </p><p> 4.2 控制器的程序</p><p> li
20、brary ieee;</p><p> use ieee.std_logic_1164.all;</p><p> entity controller is</p><p><b> port</b></p><p> (clock:in std_logic;</p><p> cou
21、ntnum:in integer range 0 to 119;</p><p> numa,numb:out integer range 0 to 59;</p><p> reda,greena,yellowa,lefta,reda1,greena1,yellowa1,lefta1:out std_logic;</p><p> redb,greenb,y
22、ellowb,leftb,redb1,greenb1,yellowb1,leftb1:out std_logic);</p><p><b> end;</b></p><p> architecture behavior of controller is</p><p><b> begin</b></p&g
23、t;<p> process(clock)</p><p><b> begin</b></p><p> if falling_edge (clock) then</p><p> if countnum<=39 then</p><p> numa<=40-countnum;<
24、;/p><p> reda<='0';</p><p> greena<='1';</p><p> yellowa<='0';</p><p> lefta<='0';</p><p> reda1<='0
25、39;;</p><p> greena1<='1';</p><p> yellowa1<='0';</p><p> lefta1<='0';</p><p> elsif (countnum<=44) then</p><p> n
26、uma<=45-countnum;</p><p> reda<='0';</p><p> greena<='0';</p><p> yellowa<='1';</p><p> lefta<='0';</p><p&
27、gt; reda1<='0';</p><p> greena1<='0';</p><p> yellowa1<='1';</p><p> lefta1<='0';</p><p> elsif (countnum<=59) then&
28、lt;/p><p> numa<=59-countnum;</p><p> reda<='0';</p><p> greena<='0';</p><p> yellowa<='0';</p><p> lefta<='1&
29、#39;; </p><p> reda1<='0';</p><p> greena1<='0';</p><p> yellowa1<='0';</p><p> lefta1<='1'; </p><p><
30、;b> else</b></p><p> numa<=119-countnum;</p><p> reda<='1';</p><p> greena<='0';</p><p> yellowa<='0';</p><
31、p> lefta<='0';</p><p> reda1<='1';</p><p> greena1<='0';</p><p> yellowa1<='0';</p><p> lefta1<='0';</
32、p><p><b> end if;</b></p><p> if countnum<=59 then</p><p> numb<=59-countnum;</p><p> redb<='1';</p><p> greenb<='0
33、39;;</p><p> yellowb<='0';</p><p> leftb<='0';</p><p> redb1<='1';</p><p> greenb1<='0';</p><p> yellowb1&
34、lt;='0';</p><p> leftb1<='0';</p><p> elsif countnum<=99 then</p><p> numb<=100-countnum;</p><p> redb<='0';</p><p>
35、; greenb<='1';</p><p> yellowb<='0';</p><p> leftb<='0';</p><p> redb1<='0';</p><p> greenb1<='1';</p>
36、<p> yellowb1<='0';</p><p> leftb1<='0';</p><p> elsif countnum<=104 then</p><p> numb<=105-countnum;</p><p> redb<='0
37、9;;</p><p> greenb<='0';</p><p> yellowb<='1';</p><p> leftb<='0';</p><p> redb1<='0';</p><p> greenb1<
38、='0';</p><p> yellowb1<='1';</p><p> leftb1<='0';</p><p><b> else</b></p><p> numb<=119-countnum;</p><p>
39、 redb<='0';</p><p> greenb<='0';</p><p> yellowb<='0';</p><p> leftb<='1'; </p><p> redb1<='0';</p>&
40、lt;p> greenb1<='0';</p><p> yellowb1<='0';</p><p> leftb1<='1';</p><p><b> end if;</b></p><p><b> end if;<
41、/b></p><p> end process;</p><p><b> end;</b></p><p> 4.3 分位電路程序</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p>&
42、lt;p> entity fenwei is</p><p> port(numin:in integer range 0 to 60;</p><p> numa:out integer range 0 to 9;</p><p> numb:out integer range 0 to 9);</p><p><b&g
43、t; end;</b></p><p> architecture behavior of fenwei is</p><p><b> begin</b></p><p> process(numin)</p><p><b> begin</b></p>&l
44、t;p> if numin>=50 then</p><p><b> numa<=5;</b></p><p> numb<=numin-50;</p><p> elsif numin>=40 then</p><p><b> numa<=4;</b&g
45、t;</p><p> numb<=numin-40;</p><p> elsif numin>=30 then</p><p><b> numa<=3;</b></p><p> numb<=numin-30;</p><p> elsif numin>
46、;=20 then</p><p><b> numa<=2;</b></p><p> numb<=numin-20;</p><p> elsif numin>=10 then</p><p><b> numa<=1;</b></p><p&
47、gt; numb<=numin-10;</p><p><b> else</b></p><p><b> numa<=0;</b></p><p> numb<=numin;</p><p><b> end if;</b></p>
48、<p> end process;</p><p><b> end;</b></p><p> 4.4 七段譯碼電路的程序</p><p> library ieee; </p><p> use ieee.std_logic_1164.all; </p><p> e
49、ntity ymq is </p><p> port(ain:in std_logic_vector(3 downto 0); </p><p> yout: out std_logic_vector(6 downto 0)); </p><p><b> end; </b></p><p> archit
50、ecture one of ymq is </p><p><b> begin </b></p><p> process(ain) </p><p><b> begin </b></p><p> case ain is </p><p> when &q
51、uot;0000"=> yout<="0111111"; </p><p> when "0001"=> yout<="0000110"; </p><p> when "0010"=> yout<="1011011"; </p>
52、<p> when "0011"=> yout<="1001111"; </p><p> when "0100"=> yout<="1101101"; </p><p> when "0101"=> yout<="11111
53、01"; </p><p> when "0110"=> yout<="0000111"; </p><p> when "0111"=> yout<="1111111"; </p><p> when "1000"=>
54、yout<="1101111"; </p><p> when others => yout<="0000000"; </p><p> end case; </p><p> end process; </p><p><b> end;</b><
55、/p><p> 5 系統(tǒng)調(diào)試與性能分析</p><p> 5.1 交通燈計(jì)數(shù)器波形圖</p><p> Clk為輸入頻率,上升沿有效。cq為輸出的計(jì)數(shù)值,最大為120。當(dāng)hold為低電平時(shí),cq數(shù)值保持不變,當(dāng)rst為低電平時(shí)cq數(shù)值復(fù)位。</p><p> 5.2 控制器的波形圖</p><p> Clock
56、為輸入頻率,當(dāng)下降沿來(lái)時(shí)有效。Greena到leftb1為東西南北的控制燈亮暗情況。Numa,numb分別為東西,南北的控制燈的倒計(jì)時(shí)。</p><p> 5.3 分位的波形圖</p><p> Numin的輸入數(shù)值拆成個(gè)位numa和百位numb</p><p> 5.4 七段譯碼電路的波形圖</p><p> 譯碼器顧名思義,把qi
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- eda交通燈課程設(shè)計(jì)
- eda交通燈課程設(shè)計(jì)
- eda交通燈課程設(shè)計(jì)報(bào)告(eda)
- eda交通燈課程設(shè)計(jì)論文
- eda交通燈課程設(shè)計(jì)論文
- eda課程設(shè)計(jì)--交通燈控制
- eda交通燈課程設(shè)計(jì)---交通燈控制系統(tǒng)
- eda交通燈課程設(shè)計(jì)---交通燈控制系統(tǒng)的設(shè)計(jì)
- eda交通燈課程設(shè)計(jì)--cpld實(shí)現(xiàn)交通燈控制系統(tǒng)
- 基于sopc交通燈的eda課程設(shè)計(jì)
- eda課程設(shè)計(jì)--交通燈控制器
- eda課程設(shè)計(jì)(交通燈控制器)
- eda課程設(shè)計(jì)---交通燈控制器
- eda技術(shù)及應(yīng)用課程設(shè)計(jì)---交通燈
- eda課程設(shè)計(jì)交通燈控制器
- eda課程設(shè)計(jì)交通燈控制器
- eda課程設(shè)計(jì)--交通燈控制器設(shè)計(jì)
- eda課程設(shè)計(jì)--交通燈控制系統(tǒng)設(shè)計(jì)
- eda課程設(shè)計(jì)報(bào)告-- 交通燈控制器
- eda課程設(shè)計(jì)---交通燈信號(hào)控制器
評(píng)論
0/150
提交評(píng)論