數(shù)電課程設(shè)計(jì)--帶左轉(zhuǎn)功能的紅綠燈控制電路_第1頁
已閱讀1頁,還剩19頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、<p><b>  數(shù)電課程設(shè)計(jì)</b></p><p>  帶左轉(zhuǎn)功能的紅綠燈控制系統(tǒng)</p><p>  一.設(shè)計(jì)任務(wù)與要求:</p><p>  設(shè)計(jì)一個(gè)帶左轉(zhuǎn)功能的紅綠燈控制電路。 </p><p>  (1)設(shè)東、西方向?yàn)橹髀贰⒛?、北方向?yàn)檩o路;</p><p>  (2)當(dāng)東

2、、西方向綠燈亮?xí)r(表示允許東西方向車輛直行或左拐能過十字路口),南、北方向亮紅燈;反之,當(dāng)南、北方向綠燈時(shí),東、西方向應(yīng)亮紅燈;</p><p>  (3)在信號(hào)燈交替亮滅之前,應(yīng)有黃燈信號(hào)作為緩沖提示</p><p>  (4)綠燈紅燈黃燈及左拐信號(hào)燈各有一定的作用維持時(shí)間,東西方向紅燈維持時(shí)間65秒,南北方向維持55秒,并且利用數(shù)碼管倒計(jì)時(shí)顯示。</p><p>

3、;<b>  二.系統(tǒng)整體設(shè)計(jì)</b></p><p><b>  1.系統(tǒng)設(shè)計(jì)分析</b></p><p>  將交通道路抽象模型如下:</p><p>  交通燈的顯示有很多方式,如十字路口、丁字路口等,而對(duì)于同一個(gè)路口又有很多不同的顯示要求,比如十字路口,車子如果只要東西和南北方向通行就很簡(jiǎn)單,但本實(shí)驗(yàn)要求車輛要帶左

4、轉(zhuǎn)功能,則較為復(fù)雜</p><p>  要完成本實(shí)驗(yàn),首先必須了解交通路燈的亮滅規(guī)律。本實(shí)驗(yàn)需要用到實(shí)驗(yàn)箱上交通燈模塊中的發(fā)光二極管,即紅、黃、綠各三個(gè)。依人們的交通常規(guī),“紅燈停,綠燈行,黃燈提醒”。其交通燈的亮滅規(guī)律為:初始態(tài)是兩個(gè)路口的紅燈全亮,之后東西路口的綠燈亮,南北路口的紅燈亮,東西方向通車,延時(shí)一段時(shí)間后,通過黃燈提示要進(jìn)行左拐動(dòng)作,左拐時(shí)間設(shè)定由數(shù)碼管顯示。當(dāng)東西路口紅燈來臨,同樣要由黃燈進(jìn)行緩沖

5、提示,之后東西路口紅燈亮,而同時(shí)南北路口的綠燈亮,南北方向開始通車,重復(fù)上述過程。為簡(jiǎn)易表示起見,本設(shè)計(jì)抽象模型如上,東西為A方向,南北為B方向。</p><p>  由題可知,A方向和B方向的交通燈應(yīng)有四種狀態(tài),分別表示可信號(hào)燈的亮滅情況,狀態(tài)轉(zhuǎn)換圖如下:</p><p>  圖中中1表示燈亮,0 表示燈滅,A方向和B方向的紅、黃、綠和左拐燈分別用R1、Y1、G1、L1和R2、Y2、G2

6、、L2來表示。這樣,就每個(gè)方向的等就按要求的順序依次點(diǎn)亮了,并且我們就可以由狀態(tài)設(shè)置變量來分別為每個(gè)信號(hào)進(jìn)行有效控制。2.系統(tǒng)設(shè)計(jì)思路</p><p>  因?yàn)槊總€(gè)方向相對(duì)的信號(hào)燈狀態(tài)及倒計(jì)時(shí)的現(xiàn)實(shí)完全一致,根據(jù)設(shè)計(jì)要求和系統(tǒng)所具有的功能,紅綠燈控制系統(tǒng)設(shè)計(jì)框圖如下:</p><p>  首先要通過以使能信號(hào)選通A方向或B方向,并且有時(shí)鐘控制信號(hào)來觸發(fā)控制電路。通過讀取狀態(tài)變量的狀態(tài)來點(diǎn)

7、亮對(duì)應(yīng)信號(hào)燈,并且通過掃描顯示電路來控制數(shù)碼管的顯示及倒計(jì)時(shí)。</p><p>  應(yīng)注意兩個(gè)方向各種燈亮的時(shí)間應(yīng)該能夠非常方便地進(jìn)行設(shè)置和修改,此外假設(shè)A方向是主干道,車流量大,因此A方向通行的時(shí)間應(yīng)比B方向長(zhǎng)一些,并且每個(gè)方向紅燈亮的時(shí)間應(yīng)該與另一方向綠、黃、左拐、黃燈亮的時(shí)間相等。</p><p><b>  三.單元模塊設(shè)計(jì):</b></p>&

8、lt;p><b>  1.硬件電路實(shí)現(xiàn)</b></p><p>  根據(jù)交通燈系統(tǒng)的控制要求,該電路包含了一個(gè)CPLD芯片,兩個(gè)LED數(shù)碼顯示器,二十個(gè)分別表示各個(gè)方向的紅黃綠燈,以及相應(yīng)的限流電路。</p><p>  實(shí)驗(yàn)板仿真芯片用Altera FLEX6000系列的EPF10K10LC84型可編程邏輯芯片。按照如下的管腳定義,分配好管腳,編譯成可下載的文

9、件,下載到實(shí)驗(yàn)板上。經(jīng)驗(yàn)證,符合要求。</p><p><b>  實(shí)驗(yàn)板的引腳定義:</b></p><p><b>  2.主控程序如下:</b></p><p>  module traffic(CLK,EN,LAMPA,LAMPB,ACOUNT,BCOUNT);</p><p>  outp

10、ut[7:0] ACOUNT,BCOUNT;</p><p>  output[3:0] LAMPA,LAMPB;</p><p>  input CLK,EN;</p><p>  reg[7:0] numa,numb;</p><p>  reg tempa,tempb;</p><p>  reg[2:0] co

11、unta,countb;</p><p>  reg[7:0] ared,ayellow,agreen,aleft,bred,byellow,bgreen,bleft;</p><p>  reg[3:0] LAMPA,LAMPB;</p><p>  always @(EN)</p><p><b>  if(!EN)</b

12、></p><p><b>  begin </b></p><p>  ared <=8'd55; </p><p>  ayellow <=8'd5;</p><p>  agreen <=8'd40; </p><p>  aleft <

13、=8'd15; </p><p>  bred <=8'd65; </p><p>  byellow <=8'd5; </p><p>  bleft <=8'd15; </p><p>  bgreen <=8'd30; </p><p><b&

14、gt;  end</b></p><p>  assign ACOUNT=numa;</p><p>  assign BCOUNT=numb;</p><p>  always @(posedge CLK)</p><p><b>  begin</b></p><p><b&

15、gt;  if(EN)</b></p><p><b>  begin</b></p><p>  if(!tempa)</p><p><b>  begin</b></p><p><b>  tempa<=1;</b></p><p&

16、gt;  case(counta) </p><p><b>  0: begin </b></p><p>  numa<=agreen; </p><p>  LAMPA<=2; </p><p>  counta<=1;</p><p><b>  end<

17、/b></p><p><b>  1: begin </b></p><p>  numa<=ayellow;</p><p><b>  LAMPA<=4;</b></p><p>  counta<=2; </p><p><b>  

18、end</b></p><p><b>  2: begin</b></p><p>  numa<=aleft;</p><p><b>  LAMPA<=1;</b></p><p>  counta<=3;</p><p><b>

19、;  end</b></p><p><b>  3: begin</b></p><p>  numa<=ayellow;</p><p>  LAMPA<=4; </p><p>  counta<=4; </p><p><b>  end</b

20、></p><p><b>  4: begin</b></p><p>  numa<=ared;</p><p>  LAMPA<=8; </p><p>  counta<=0;</p><p><b>  end</b></p>

21、<p><b>  default:</b></p><p><b>  LAMPA<=8;</b></p><p><b>  endcase</b></p><p><b>  end</b></p><p>  else begin

22、//倒計(jì)時(shí)</p><p>  if(numa>1)</p><p>  if(numa[3:0]==0)</p><p><b>  begin</b></p><p>  numa[3:0]<=4'b1001;</p><p>  numa[7:4]<=numa[7:

23、4]-1;</p><p><b>  end</b></p><p>  else numa[3:0]<=numa[3:0]-1;</p><p>  if (numa==2) tempa<=0;</p><p><b>  end</b></p><p>&l

24、t;b>  end</b></p><p>  else begin</p><p>  LAMPA<=4'b1000;</p><p>  counta<=0; tempa<=0;</p><p><b>  end</b></p><p><b

25、>  end</b></p><p>  always @(posedge CLK) </p><p><b>  begin</b></p><p><b>  if (EN)</b></p><p><b>  begin</b></p>&

26、lt;p>  if(!tempb)</p><p><b>  begin</b></p><p><b>  tempb<=1;</b></p><p>  case (countb) </p><p><b>  0: begin</b></p>

27、<p>  numb<=bred;</p><p><b>  LAMPB<=8;</b></p><p>  countb<=1;</p><p><b>  end</b></p><p><b>  1: begin </b></p>

28、;<p>  numb<=bgreen;</p><p><b>  LAMPB<=2;</b></p><p>  countb<=2; </p><p><b>  end</b></p><p><b>  2: begin </b><

29、;/p><p>  numb<=byellow;</p><p>  LAMPB<=4; </p><p>  countb<=3;</p><p><b>  end</b></p><p><b>  3: begin</b></p><

30、p>  numb<=bleft;</p><p>  LAMPB<=1; </p><p>  countb<=4; </p><p><b>  end</b></p><p><b>  4: begin </b></p><p>  numb&l

31、t;=byellow;</p><p><b>  LAMPB<=4;</b></p><p>  countb<=0; </p><p><b>  end</b></p><p><b>  default:</b></p><p>&l

32、t;b>  LAMPB<=8;</b></p><p><b>  endcase</b></p><p><b>  end</b></p><p><b>  else</b></p><p>  begin //倒計(jì)時(shí)</p><

33、;p>  if(numb>1)</p><p>  if(!numb[3:0]) begin</p><p>  numb[3:0]<=9;</p><p>  numb[7:4]<=numb[7:4]-1;</p><p><b>  end</b></p><p>  

34、else numb[3:0]<=numb[3:0]-1;</p><p>  if(numb==2) tempb<=0;</p><p><b>  end</b></p><p><b>  end</b></p><p>  else begin</p><p&g

35、t;  LAMPB<=4'b1000;</p><p>  tempb<=0; countb<=0;</p><p><b>  end</b></p><p><b>  end</b></p><p><b>  endmodule</b><

36、/p><p><b>  。</b></p><p>  3. 對(duì)象控制模塊:</p><p>  根據(jù)交通燈系統(tǒng)的要實(shí)現(xiàn)的功能,考慮用兩個(gè)并行的always模塊來控制A和B兩個(gè)方向的四盞燈,這兩個(gè)always 模塊用一個(gè)時(shí)鐘信號(hào)已進(jìn)行同步。如對(duì)A方向的程序控制模塊描述如下:</p><p>  always@(posedg

37、e CLK)//該always模塊控制A方向的4種燈beginif(EN)beginif(!tempa)begintempa<= 1;……</p><p>  4.循環(huán)控制切換模塊:</p><p>  每個(gè)always模塊控制1個(gè)方向的4種燈按如下順序點(diǎn)亮,并往復(fù)循環(huán):綠燈→黃燈→左拐燈→黃燈→紅燈。程序描述如下:……case(counta)</p>

38、<p><b>  0:begin</b></p><p>  numa<=agreen;</p><p><b>  LAMPA<=2;</b></p><p>  counta<=1;</p><p>  end1:begin </p><p

39、>  numa<=ayellow;</p><p><b>  LAMPA<=4;</b></p><p>  counta<=2;</p><p>  end2:begin</p><p>  numa<=alert;</p><p><b>  LAM

40、PA<=1;</b></p><p>  counta<=3;</p><p>  end3:begin</p><p>  numa<=ayellow;</p><p><b>  LAMPA<=4;</b></p><p>  counta<=4;&

41、lt;/p><p>  end4:begin</p><p>  numa<=ared;</p><p><b>  LAMPA<=8;</b></p><p>  counta<=0;</p><p>  enddefault:LAMPA<= 8;endcase……&

42、lt;/p><p>  5.時(shí)間顯示控制模塊:</p><p>  每盞燈亮的時(shí)間采用一個(gè)減法計(jì)數(shù)器進(jìn)行計(jì)數(shù),該計(jì)數(shù)器采用同步預(yù)置法設(shè)計(jì),這樣只需改變預(yù)置數(shù)據(jù),就可以改變計(jì)數(shù)器的模,因此每個(gè)方向只需要1個(gè)計(jì)數(shù)器進(jìn)行計(jì)時(shí)即可。為便于顯示燈亮的時(shí)間,計(jì)數(shù)器的輸出均采用BCD碼,顯示由4個(gè)數(shù)碼管來完成,A方向和B方向各用兩個(gè)數(shù)碼管。可用如下程序描述:…… else begin//倒計(jì)時(shí)

43、 if(numa>1) if(numa[3:0]==0)begin numa[-3:0]<=4'b1001; numa[7:4]<=numa[7:4]-1; end else numa[3:0]<=numa[3:0]-1; if(numa==2) tempa<=0; end</p><p>  6.信號(hào)的有效維持時(shí)間模

44、塊</p><p>  設(shè)定A方向紅、綠、黃、左拐燈亮的時(shí)間分別為65秒、40秒、5秒和15秒,B方向紅、綠、黃、左拐燈亮的時(shí)間分別為:55秒、30秒、5秒和15秒。假如要改變這些時(shí)間只須改變計(jì)數(shù)器的預(yù)置數(shù)即可。程序描述如下:……begin//設(shè)置各種燈的計(jì)數(shù)器的預(yù)置數(shù)ared<=8'b01010101;//65sayellow <=8'b00000101;//5sagree

45、n <=8'b01000000; //40saleft <=8'b00010101; //15sbred <=8'b01100101; //55sbyellow <=8'b00000101; //5sbleft <=8'b00010101; //15sbgreen <=8'b00110000; //30send</p><

46、p>  四.EDA系統(tǒng)原理仿真設(shè)計(jì)</p><p><b>  1、仿真環(huán)境</b></p><p>  EDA軟件Quartus II 9.1軟件環(huán)境下。</p><p><b>  2、EDA設(shè)計(jì)仿真</b></p><p> ?。?)RTL門級(jí)模塊實(shí)現(xiàn):</p><p

47、> ?。?)程序綜合成功:</p><p> ?。?)生成網(wǎng)表文件:</p><p><b> ?。?)仿真波形:</b></p><p>  (5)電路輸入輸出實(shí)例化模塊</p><p><b>  3.輸出驗(yàn)證仿真:</b></p><p>  由狀態(tài)轉(zhuǎn)換表可知,對(duì)

48、A方向通道,當(dāng)在當(dāng)前時(shí)刻定義變量LAMP=1000時(shí),紅燈會(huì)被點(diǎn)亮,此時(shí)在波形中對(duì)其輸入控制如下:</p><p>  經(jīng)仿真驗(yàn)證,在當(dāng)前時(shí)刻,顯示A方向上紅燈的數(shù)碼管會(huì)輸出時(shí)間顯示。而有題目要求,當(dāng)A方向亮紅燈時(shí),B方向會(huì)按綠燈—黃燈—左拐—黃燈順序依次點(diǎn)亮,且顯示時(shí)間如下圖示,可知滿足要求。</p><p>  4.對(duì)仿真結(jié)果的分析:</p><p> ?。?)

49、、在波形仿真中,由于分頻模塊的數(shù)目太大,且電路的時(shí)間延時(shí),未能去抖,在時(shí)間顯示模塊會(huì)遇到某個(gè)計(jì)數(shù)值不太準(zhǔn)確,但其前后值都準(zhǔn)確。</p><p> ?。?)當(dāng)A或B方向當(dāng)紅燈亮?xí)r,在另一方向會(huì)各信號(hào)燈循環(huán)點(diǎn)亮,這是在波形仿真中具體什么燈點(diǎn)亮以及顯示時(shí)間不能直觀的表現(xiàn)出來。</p><p><b>  五、設(shè)計(jì)心得與總結(jié)</b></p><p> 

50、 經(jīng)過幾周的努力,帶左轉(zhuǎn)功能的紅綠燈控制系統(tǒng)終于有了較滿意的結(jié)果。從最初的選題到確定思路,從模型抽象到實(shí)例設(shè)計(jì),從源代碼的編寫到仿真分析,我們參閱了數(shù)本教材,查閱了很多網(wǎng)上資料,也請(qǐng)教了指導(dǎo)老師與學(xué)長(zhǎng),在此對(duì)他們表示深深的感謝。</p><p>  書到用時(shí)方恨少。在這個(gè)過程中,我們真切的感受到自己的知識(shí)的缺乏,甚者學(xué)過的東西我們都不能融會(huì)貫通,靈活運(yùn)用?;诓划?dāng)初!</p><p>  但

51、一路走下來,雖然艱辛,卻收獲頗豐。我們不僅回顧了數(shù)電模電知識(shí),更深層次的運(yùn)用了quartsⅡ仿真工具,也鍛煉了自己的抽象理解,建造模型模,動(dòng)手實(shí)踐的能力。在這個(gè)過程中,我也深刻體會(huì)到團(tuán)隊(duì)合作的重要性,一個(gè)人的力量總是有限的,但通過互幫互助,我們會(huì)將自己的作用最大化。</p><p>  由于自己的能力實(shí)在有限,有做的不完善的地方希望老師理解,指教,謝謝!</p><p><b>

52、  六、參考文獻(xiàn):</b></p><p>  《數(shù)字電子技術(shù)基礎(chǔ)》 閻石 主編 高等教育出版社</p><p>  《模擬電子技術(shù)基礎(chǔ)》 童詩白 華成英主編 高等教育出版社</p><p>  《Verilog數(shù)字設(shè)計(jì)與綜合》 夏宇文 主編 科學(xué)

53、出版社</p><p>  《可編程邏輯器件開發(fā)軟件》 鄭亞民 董曉丹 國(guó)防工業(yè)出版社</p><p><b>  附件:</b></p><p><b>  1.程序變量說明</b></p><p>  CLK: 為同步時(shí)鐘;</p><p>  EN

54、: 使能信號(hào),為 1 的話,則控制器開始工作;</p><p>  LAMPA: 控制 A 方向四盞燈的亮滅;其中,LAMPA0~LAMPA3,分別控制A 方向的</p><p>  左拐燈、綠燈、黃燈和紅燈;</p><p>  LAMPB: 控制 B 方向四盞燈的亮滅;其中,LAMPB0 ~ LAMPB3,分別控制B 方向的</p><p&g

55、t;  左拐燈、綠燈、黃燈和紅燈;</p><p>  ACOUNT: 用于 A 方向燈的時(shí)間顯示,8 位,可驅(qū)動(dòng)兩個(gè)數(shù)碼管;</p><p>  BCOUNT: 用于 B 方向燈的時(shí)間顯示,8 位,可驅(qū)動(dòng)兩個(gè)數(shù)碼管</p><p>  2.LED 數(shù)碼管顯示掃描模塊</p><p>  module LED(clk , segout , b

56、itout , D1 , D2 , D3 , D4);</p><p>  input clk ; </p><p>  input [6 : 0] D1 , D2 , D3 , D4 ; </p><p>  output [3 : 0] segout ; </p><

57、p>  output [6 : 0] bitout ; </p><p>  reg [3 : 0] segout ;</p><p>  reg [6 : 0] bitout ;</p><p>  reg [14 : 0] count_for_clk ; </p><p>  always

58、@(posedge clk) begin </p><p>  count_for_clk <= count_for_clk + 14'd1 ;</p><p><b>  end</b></p><p>  always @(posedge clk) begin</p><p>  case(

59、 count_for_clk[14 : 13] )</p><p>  2'b00 :begin segout <= 4'b0001; bitout <= D1; end </p><p>  2'b01 :begin segout <= 4'b0010; bitout <= D2; end </p>

60、<p>  2'b10 :begin segout <= 4'b0100; bitout <= D3; end </p><p>  2'b11 :begin segout <= 4'b1000; bitout <= D4; end </p><p><b>  endcase</b>&l

61、t;/p><p><b>  end</b></p><p><b>  endmodule</b></p><p>  3.CPLD硬件調(diào)試數(shù)碼管輸出模塊</p><p>  module control(en, clk, lampa, lampb, acount, bcount,segout,bit

62、out);</p><p>  input en , bcount , acount ; </p><p>  input clk; </p><p>  output[2 :0] lampa , lampb ; </p><p>  output[3 :0] segout ; </p><p&

63、gt;  output[6 :0] bitout ; </p><p>  reg [2 : 0] lampa ,lampb ;</p><p>  reg [31: 0] clk_for_1HZ ; </p><p>  reg clk_1HZ ; </p><p>  reg [6

64、: 0] moutg , mouts , noutg , nouts ;</p><p>  reg [7 : 0] numm , numn ;</p><p>  reg tempm = 0 , tempn = 0 ;</p><p>  reg [1 : 0] countm = 2'b00 , countn = 2'b00

65、 ; </p><p>  reg [7 : 0] mred , mgreen , myellow, nred, ngreen, nyellow; </p><p>  task shown;</p><p>  input[3:0] in;</p><p>  output[6:0] out;</p><p>

66、;<b>  begin</b></p><p>  case(in) </p><p>  0 : out = 7'b0000001 ; </p><p>  1 : out = 7'b1001111 ;</p><p>  2 : out = 7'b0010010 ;<

67、/p><p>  3 : out = 7'b0000110 ;</p><p>  4 : out = 7'b1001100 ;</p><p>  5 : out = 7'b0100100 ; </p><p>  6 : out = 7'b0100000 ;</p><p>  

68、7 : out = 7'b0001111 ;</p><p>  8 : out = 7'b0000000 ;</p><p>  9 : out = 7'b0000100 ;</p><p>  default : out <= 7'bzzzzzzz ;</p><p><b>  en

69、dcase</b></p><p><b>  end</b></p><p>  endtask </p><p>  always @(numm or numn)</p><p><b>  begin</b></p><p>  sho

70、wn(numm[3:0],moutg); </p><p>  shown(numm[7:4],mouts);</p><p>  shown(numn[3:0],noutg);</p><p>  shown(numn[7:4],nouts);</p><p><b>  end</b><

71、;/p><p>  always @(posedge clk) begin </p><p>  if (clk_for_1HZ == 32'd25_000_000) begin</p><p>  clk_for_1HZ = 32'd0 ;</p><p>  clk_1HZ = ~clk_1HZ ;</p>

72、<p>  end </p><p>  else </p><p>  clk_for_1HZ = clk_for_1HZ + 1 ; </p><p><b>  end</b></p><p>  always @(posedge clk_1HZ) be

73、gin </p><p><b>  if(!en)</b></p><p><b>  begin</b></p><p>  if(!tempm) </p><p><b>  begin</b></p><p>  tempm <=

74、1; </p><p>  if(countn == 2'b00 && countm == 2'b00) </p><p><b>  begin</b></p><p>  if(bcount == 0) </p><p>  mgreen <= 8'b0101_0

75、000 ;</p><p><b>  else</b></p><p>  mgreen <= 8'b0011_0000 ;</p><p>  if(acount == 0)</p><p>  mred <= 8'b0011_0000 ;</p><p>&l

76、t;b>  else</b></p><p>  mred <= 8'b0010_0000 ;</p><p>  myellow<= 8'b0000_0101 ;</p><p><b>  end</b></p><p>  case(countm) &

77、lt;/p><p>  2'b00: begin </p><p>  numm <= mgreen; </p><p>  lampa <= 3'b101; </p><p>  countm <= 2'b01; </p><p><b&g

78、t;  end</b></p><p>  2'b01: begin </p><p>  numm <= myellow; </p><p>  lampa <= 3'b110;</p><p>  countm <= 2'b10;</p><p>  e

79、nd </p><p>  2'b10: begin </p><p>  numm <= mred; </p><p>  lampa <= 3'b011; </p><p>  countm <= 2'b00; </p>&

80、lt;p><b>  end</b></p><p>  default: begin numm <= mgreen; lampa <= 3'b101; countm <= 2'b01; end </p><p><b>  endcase </b></p><p><b&

81、gt;  end</b></p><p>  else begin // tempm = 1</p><p>  if(numm > 1) </p><p>  if(numm[3:0]==0) </p><p>  begin

82、 numm[3:0]<=4'b1001; numm[7:4] <= numm[7:4]-4'd1; </p><p><b>  end</b></p&

83、gt;<p>  else </p><p>  numm[3:0] <= numm[3:0]-4'd1;</p><p>  if(numm == 2)</p><p><b>  tempm<=0;</b></p><p><b>  end<

84、/b></p><p><b>  end</b></p><p>  else begin </p><p>  lampa <= 3'b100;</p><p>  countm <= 0;</p><p>  tempm <= 0; </p

85、><p><b>  end</b></p><p><b>  end </b></p><p>  always @(posedge clk_1HZ) begin </p><p><b>  if(!en)</b></p>&l

86、t;p><b>  begin</b></p><p>  if(!tempn) </p><p><b>  begin</b></p><p>  tempn<=1; </p><p>  if (countn == 2'b00 &&

87、; countm == 2'b00 )</p><p><b>  begin</b></p><p>  if(bcount == 0) </p><p>  nred <= 8'b0101_0101 ; </p><p><b>  else</b></p>

88、<p>  nred <= 8'b0011_0101 ;</p><p>  if(acount == 0)</p><p>  ngreen <= 8'b0010_0101 ;</p><p><b>  else</b></p><p>  ngreen <= 8&

89、#39;b0001_0101 ;</p><p>  nyellow<= 8'b0000_0101 ;</p><p>  end case(countn) </p><p>  2'b00: begin </p><p>  numn <= nred;

90、 </p><p>  lampb <= 3'b011; </p><p>  countn<= 2'b01; </p><p><b>  end</b></p><p>  2

91、9;b01: begin </p><p>  numn <= ngreen; </p><p>  lampb <= 3'b101; </p><p>  countn <= 2'b10; </p><p><b>  end</b>&

92、lt;/p><p>  2'b10: begin </p><p>  numn <= nyellow; </p><p>  lampb <= 3'b110 ;</p><p>  countn <= 2'b00 ;</p><p><b>  end

93、</b></p><p>  default: begin numn<= nred; lampb <= 3'b011;countn<= 2'b01; </p><p><b>  end </b></p><p>  endcase end

94、 </p><p>  else begin </p><p>  if(numn >1)</p><p>  if(!numn[3:0]) begin</p><p>  numn[3:0] <= 4'b1001;

95、 </p><p>  numn[7:4]<=numn[7:4]-4'd1; end</p><p><b>  else</b></p><p>  numn[3:0] <= numn[3

96、:0]-4'd1;</p><p>  if (numn == 2)</p><p>  tempn <= 0;</p><p><b>  end</b></p><p><b>  end</b></p><p>  else begin</p>

97、<p>  lampb <=3'b100;</p><p>  tempn <=0;</p><p>  countn <=0;</p><p><b>  end</b></p><p><b>  end </b></p><p&

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(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)論