eda課程設(shè)計(jì)交通燈帶左拐_第1頁(yè)
已閱讀1頁(yè),還剩13頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論