eda課程設(shè)計——汽車尾燈控制器設(shè)計_第1頁
已閱讀1頁,還剩14頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p>  課 程 設(shè) 計</p><p>  課程設(shè)計名稱: EDA課程設(shè)計 </p><p>  專 業(yè) 班 級 </p><p>  學(xué) 生 姓 名 : </p><p>  學(xué) 號 :

2、 </p><p>  指 導(dǎo) 教 師 : </p><p>  課程設(shè)計時間: </p><p>  電子信息科學(xué)與技術(shù)專業(yè)課程設(shè)計任務(wù)書</p><p>  說明:本表由指導(dǎo)教師填寫,由教研室主任審核后下達(dá)給選題學(xué)生,裝訂在設(shè)計(論文)首頁<

3、;/p><p><b>  汽車尾燈控制器設(shè)計</b></p><p><b>  引言</b></p><p>  隨著集成電路和計算機(jī)技術(shù)的飛速發(fā)展,EDA技術(shù)應(yīng)運(yùn)而生,它是一種高級、快速、有效的電子設(shè)計自動化技術(shù)。EDA將大量的電路功能集成到一個芯片中,并且可以由用戶自行設(shè)計邏輯功能,提高了系統(tǒng)的集成度和可靠性。運(yùn)用ED

4、A技術(shù)可以方便、快捷設(shè)計電路系統(tǒng)。 本文基于EDA系統(tǒng),在MAX+plusII軟件平臺上,完成了汽車尾燈電路的設(shè)計。采用VHDL硬件描述語言描述汽車尾燈電路,完成對電路的功能仿真。在設(shè)計過程中,重點(diǎn)探討了汽車尾燈電路的設(shè)計思路和功能模塊劃分,通過分析仿真波形表明設(shè)計的汽車尾燈電路完成了預(yù)期的功能。</p><p><b>  1 設(shè)計任務(wù)及要求</b></p><

5、p><b>  1.1設(shè)計內(nèi)容</b></p><p>  根據(jù)計算機(jī)中狀態(tài)機(jī)原理,利用VHDL設(shè)計汽車尾燈控制器的各個模塊,并使用EDA 工具對各模塊進(jìn)行仿真驗(yàn)證。汽車尾燈控制器的設(shè)計分為4個模塊:時鐘分頻模塊、汽車尾燈主控模塊,左邊燈控制模塊和右邊燈控制模塊。把各個模塊整合后就形成了汽車尾燈控制器。通過輸入系統(tǒng)時鐘信號和相關(guān)的汽車控制信號,汽車尾燈將正確顯示當(dāng)前汽車的控制狀態(tài)。&l

6、t;/p><p><b>  1.2設(shè)計要求</b></p><p>  (1)汽車尾部左右兩側(cè)各有多盞指示燈。</p><p> ?。?)汽車正常行駛時指示燈都不亮。</p><p> ?。?)汽車右轉(zhuǎn)彎時,右側(cè)的一盞指示燈亮。</p><p> ?。?)汽車左轉(zhuǎn)彎時,左側(cè)的一盞指示燈亮。</

7、p><p>  (5)汽車剎車時,左右兩側(cè)的一盞指示燈同時亮。</p><p> ?。?)汽車在夜間行駛時,左右兩側(cè)有指示燈同時一直亮,供照明使用。</p><p>  2設(shè)計原理及總體框圖</p><p>  汽車尾燈控制器就是一個狀態(tài)機(jī)的實(shí)例。當(dāng)汽車正常行駛時所有指示燈都不亮;當(dāng)汽車向右轉(zhuǎn)彎時,汽車右側(cè)的指示燈ldright亮;當(dāng)汽車向左側(cè)轉(zhuǎn)

8、彎時,汽車左側(cè)的指示燈ldleft亮;當(dāng)汽車剎車時,汽車右側(cè)的指示燈ldbrake1和汽車左側(cè)的指示燈ldbrake2同時亮;當(dāng)汽車在夜間行駛時,汽車右側(cè)的指示燈ldnight1和汽車左側(cè)的指示燈ldnight2同時一直亮;當(dāng)于大霧天行駛時右側(cè)指示燈ldfoggy1和左側(cè)指示燈ldfoggy2同時亮。</p><p>  通過設(shè)置系統(tǒng)的輸入信號:系統(tǒng)時鐘信號clk,汽車左轉(zhuǎn)彎控制信號left,汽車右轉(zhuǎn)彎控制信號r

9、ight,剎車信號brake,夜間行駛信號night,霧燈信號foggy和系統(tǒng)的輸出信號:汽車左側(cè)4盞指示燈ldleft,dbrake1,dnight1,dfoggy1和汽車右側(cè)4盞指示燈ldright,ldbrake2,ldnight2,ldfoggy2實(shí)現(xiàn)以上功能。</p><p>  系統(tǒng)的整體組裝設(shè)計原理如圖所示:</p><p><b>  3 程序設(shè)計</b&g

10、t;</p><p>  根據(jù)系統(tǒng)設(shè)計要求,系統(tǒng)設(shè)計采用自頂向下的設(shè)計方法,頂層設(shè)計采用原理圖設(shè)計方案,它是由時鐘分頻模塊、汽車尾燈主控模塊、左邊燈控制模塊、右邊燈控制模塊四部分組成。</p><p>  系統(tǒng)的輸入信號包括:系統(tǒng)時鐘信號CLK,汽車左轉(zhuǎn)彎控制信號LEFT,汽車右轉(zhuǎn)彎控制信號RIGHT,剎車信號BRAKE,夜間行駛信號NIGHT。</p><p> 

11、 系統(tǒng)的輸入信號包括:汽車左側(cè)4 盞指示燈LLED1,LLED2,LLED3,LLED4和汽車右側(cè)4 盞指示燈RLED1,RLED2,RLED3,RLED4。</p><p>  當(dāng)汽車正常行駛時所有的指示燈都不亮,當(dāng)汽車向左轉(zhuǎn)時,汽車左邊的指示燈LLED1亮,當(dāng)汽車向右轉(zhuǎn)時,汽車右邊的指示燈RLED1亮,當(dāng)汽車剎車時,左右的LLED2、RLED2亮,當(dāng)汽車夜間行駛時,汽車左右的LLED3、LLED4、RLED3

12、 、RLED4一直亮。</p><p>  3.1各組成模塊原理及程序</p><p>  3.1.1汽車尾燈主控模塊</p><p>  VHDL程序(CTRL.VHD)</p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p>

13、<p>  ENTITY CTRL IS</p><p>  PORT(LEFT,RIGHT,BRAKE,NIGHT: IN STD_LOGIC; </p><p>  LP,RP,LR,BRAKE_LED,NIGHT_LED: OUT STD_LOGIC);</p><p>  END ENTITY CTRL;</p><p>

14、  ARCHITECTURE ART OF CTRL IS</p><p><b>  BEGIN</b></p><p>  NIGHT_LED<=NIGHT;</p><p>  BRAKE_LED<=BRAKE;</p><p>  PROCESS(LEFT,RIGHT)</p><

15、p>  VARIABLE TEMP:STD_LOGIC_VECTOR(1 DOWNTO 0);</p><p><b>  BEGIN</b></p><p>  TEMP:=LEFT&RIGHT;</p><p>  CASE TEMP IS</p><p>  WHEN "00"=&

16、gt;LP<='0';RP<='0';LR<='0'; --當(dāng)汽車直行時,左右燈都不亮</p><p>  WHEN "01"=>LP<='0';RP<='1';LR<='0';; --當(dāng)汽車右拐時,右拐指示燈亮</p><p>

17、;  WHEN "10"=>LP<='1';RP<='0';LR<='0'; --當(dāng)汽車左拐時,左指示燈亮</p><p>  WHEN OTHERS=>LP<='0';RP<='0';LR<='1'; --當(dāng)汽車剎車時,左右燈都亮</p>

18、;<p><b>  END CASE;</b></p><p>  END PROCESS;</p><p>  END ARCHITECTURE ART;</p><p><b>  功能:</b></p><p>  該段程序用于對汽車尾燈進(jìn)行整體控制,當(dāng)輸入為左轉(zhuǎn)信號時,輸出左

19、側(cè)燈控制信號;當(dāng)輸入為右轉(zhuǎn)信號時,輸出右側(cè)燈控制信號;當(dāng)同時輸入LEFT和RIGHT信號時,輸出錯誤控制信號。當(dāng)輸入為剎車信號時,輸出剎車控制信號;當(dāng)輸入為夜間行駛信號時,輸出為夜間行駛控制信號。 </p><p>  3.1.2左邊燈控制模塊</p><p>  VHDL程序(LC.VHD)</p><p>  LIBRARY IEEE;</p>&

20、lt;p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY LC IS</p><p>  PORT(CLK,LP,LR,BRAKE,NIGHT: IN STD_LOGIC;</p><p>  LEDL,LEDB,LEDN: OUT STD_LOGIC);</p><p>  END EN

21、TITY LC;</p><p>  ARCHITECTURE ART OF LC IS</p><p><b>  BEGIN</b></p><p>  LEDB<=BRAKE;</p><p>  LEDN<=NIGHT;</p><p>  PROCESS(CLK,LP,LR)

22、</p><p><b>  BEGIN</b></p><p>  IF CLK'EVENT AND CLK='1' THEN --時鐘上升沿有效</p><p>  IF(LR='0') THEN --沒有剎車信號時</p><p>  IF(LP=&

23、#39;0')THEN --沒有左拐信號時</p><p>  LEDL<='0'; --左信號燈不亮</p><p>  ELSE --相反情況</p><p>  LEDL<='1';</p><p><b>  END IF;</b>

24、;</p><p><b>  ELSE</b></p><p>  LEDL<='0';</p><p><b>  END IF;</b></p><p><b>  END IF; </b></p><p>  END PR

25、OCESS;</p><p>  END ARCHITECTURE ART;</p><p><b>  功能:</b></p><p>  本程序用于控制左側(cè)燈的亮、滅和閃爍情況,當(dāng)時鐘上升沿信號和左側(cè)燈控制信號或剎車控制信號或夜間行駛信號同時出現(xiàn)時,左側(cè)相應(yīng)的燈亮或出現(xiàn)閃爍。當(dāng)錯誤控制信號出現(xiàn)時,LD1燈不亮。</p><

26、;p>  3.1.3右邊燈控制模塊</p><p>  VHDL程序(RC.VHD)</p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY RC IS</p><p>  PORT(CLK,RP,LR,BRA

27、KE,NIGHT: IN STD_LOGIC;</p><p>  LEDR,LEDB,LEDN: OUT STD_LOGIC);</p><p>  END ENTITY RC;</p><p>  ARCHITECTURE ART OF RC IS</p><p><b>  BEGIN</b></p>

28、<p>  LEDB<=BRAKE;</p><p>  LEDN<=NIGHT;</p><p>  PROCESS(CLK,RP,LR)</p><p><b>  BEGIN</b></p><p>  IF CLK'EVENT AND CLK='1' THEN

29、 --檢測時鐘上升沿</p><p>  IF(LR='0') THEN</p><p>  IF(RP='0') THEN</p><p>  LEDR<='0';</p><p><b>  ELSE</b></p>&l

30、t;p>  LEDR<='1';</p><p><b>  END IF;</b></p><p><b>  ELSE</b></p><p>  LEDR<='0';</p><p><b>  END IF;</b>&l

31、t;/p><p><b>  END IF; </b></p><p>  END PROCESS;</p><p>  END ARCHITECTURE ART;</p><p><b>  功能:</b></p><p>  本描述用于控制右側(cè)燈的亮、滅和閃爍情況,當(dāng)時鐘上

32、升沿信號和右側(cè)燈控制信號或剎車控制信號或夜間行駛信號同時出現(xiàn)時,右側(cè)相應(yīng)的燈亮或出現(xiàn)閃爍。當(dāng)錯誤控制信號出現(xiàn)時,RD1燈不亮。</p><p>  3.1.4時鐘分頻模塊</p><p>  VHDL程序(SZ.VHD)</p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL

33、;</p><p>  USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p>  ENTITY SZ IS</p><p>  PORT(CLK: IN STD_LOGIC; --時鐘輸入</p><p>  CP: OUT STD_LOGIC);</p&g

34、t;<p>  END ENTITY SZ;</p><p>  ARCHITECTURE ART OF SZ IS</p><p>  SIGNAL COUNT:STD_LOGIC_VECTOR(7 DOWNTO 0); --定義八位標(biāo)準(zhǔn)邏輯位矢量數(shù)據(jù)類型</p><p><b>  BEGIN</b></p>

35、<p>  PROCESS(CLK)</p><p><b>  BEGIN</b></p><p>  IF CLK'EVENT AND CLK='1' THEN --檢測時鐘上升沿</p><p>  COUNT<=COUNT+1;</p><p&g

36、t;<b>  END IF;</b></p><p>  END PROCESS;</p><p>  CP<=COUNT(3); --輸出第五位</p><p>  END ARCHITECTURE ART;</p><p><

37、;b>  功能:</b></p><p>  這塊的功能是對左右兩邊的LLED1、RLED1的閃爍時間間隔,以CLK為輸入信號,CP為輸出信號,在程序中定義一個八位節(jié)點(diǎn)信號COUNT來放計數(shù)值,當(dāng)CLK的上升沿到來時就開始計數(shù),最后將COUNT(3)給CP,實(shí)現(xiàn)對CLK的八分頻。</p><p>  再將CP的電平信號分別和LEDL、LEDR電平與,最后用輸出的電平來控制

38、汽車左右的LLED1、RLED1,實(shí)現(xiàn)左右轉(zhuǎn)的指示功能。 </p><p><b>  3.1.5原理圖</b></p><p>  頂層文件VHDL程序(tp.VHD)</p><p>  Library ieee;</p><p>  Use ieee.std_logic_1164.all;</p>&

39、lt;p>  Use ieee.std_logic_unsigned.all;</p><p>  Entity tp is</p><p>  Port(clk:in std_logic;</p><p>  Left:in std_logic;</p><p>  Right:in std_logic;</p><

40、;p>  Brake:in std_logic;</p><p>  Night:in std_logic;</p><p>  Ld1,ld2,ld3:out std_logic;</p><p>  Rd1,rd2,rd3:out std_logic);</p><p><b>  End;</b></p

41、><p>  Architecture bh of tp is</p><p>  Component sz is</p><p>  Port(clk:in std_logic;</p><p>  Cp:out std_logic);</p><p>  End component;</p><p&

42、gt;  Component ctrl is</p><p>  Port(left,right,brake,night:in std_logic;</p><p>  Lp,rp,lr,brake_led,night_led:out std_logic);</p><p>  End component;</p><p>  Compone

43、nt lc is</p><p>  Port(clk,lp,lr,brake,night:in std_logic;</p><p>  Ledl,ledb,ledn:out std_logic);</p><p>  End component;</p><p>  Component rc is</p><p>

44、  Port(clk,rp,lr,brake,night:in std_logic;</p><p>  Ledr,ledb,ledn:out std_logic);</p><p>  End component;</p><p>  Signal tmp0,tmp1,tmp2,tmp3,tmp4:std_logic;</p><p>  

45、Signal err0,err1,err2,err3,err4,err5:std_logic;</p><p>  signal bm:std_logic;</p><p><b>  Begin</b></p><p>  U1:sz port map(clk,bm);</p><p>  U2:ctrl port m

46、ap(left,right,brake,night,tmp0,tmp1,tmp2,tmp3,tmp4);</p><p>  U3:lc port map(clk,tmp0,tmp2,tmp3,tmp4,err0,err1,err2);</p><p>  U4:rc port map(clk,tmp1,tmp2,tmp3,tmp4,err3,err4,err5);</p>

47、<p>  Ld1<=err0 and bm;</p><p>  Ld2<=err1;</p><p>  Ld3<=err2;</p><p>  Rd1<=err3 and bm;</p><p>  Rd2<=err4;</p><p>  Rd3<=err5;&l

48、t;/p><p><b>  End;</b></p><p><b>  4 編譯及仿真</b></p><p>  4.1 主控模塊的時序仿真及原理圖</p><p><b>  數(shù)據(jù)入口:</b></p><p>  RIGHT:右轉(zhuǎn)信號;</p

49、><p>  LEFT:左轉(zhuǎn)信號;</p><p>  BRAKE:剎車信號;</p><p>  NIGHT:夜間行駛信號;</p><p><b>  數(shù)據(jù)出口:</b></p><p>  LP:左側(cè)燈控制信號;</p><p>  RP:右側(cè)燈控制信號;</p&g

50、t;<p>  LR:錯誤控制信號;</p><p>  BRAKE_LED:剎車控制信號;</p><p>  NIGHT_LED:夜間行駛控制信號;</p><p><b>  仿真波形</b></p><p>  4.2 左邊燈模塊的時序仿真及原理圖</p><p><

51、b>  數(shù)據(jù)入口:</b></p><p>  CLK:時鐘控制信號;</p><p>  LP:左側(cè)燈控制信號;</p><p>  LR:錯誤控制信號;</p><p>  BRAKE:剎車控制信號;</p><p>  NIGHT:夜間行駛控制信號;</p><p>&l

52、t;b>  數(shù)據(jù)出口:</b></p><p>  LEDL:左側(cè)LD1燈控制信號;</p><p>  LEDB:左側(cè)LD2燈控制信號;</p><p>  LEDN:左側(cè)LD3燈控制信號;</p><p><b>  仿真波形</b></p><p>  4.3 右邊燈模塊的

53、時序仿真及原理圖</p><p><b>  數(shù)據(jù)入口:</b></p><p>  CLK:時鐘控制信號;</p><p>  RP:右側(cè)燈控制信號;</p><p>  LR:錯誤控制信號;</p><p>  BRAKE:剎車控制信號;</p><p>  NIGHT

54、:夜間行駛控制信號;</p><p><b>  數(shù)據(jù)出口:</b></p><p>  LEDR:右側(cè)RD1燈控制信號;</p><p>  LEDB:右側(cè)RD2燈控制信號;</p><p>  LEDN:右側(cè)RD3燈控制信號;</p><p><b>  仿真波形</b>

55、</p><p>  4.4 時鐘分頻模塊的時序仿真及原理圖</p><p><b>  仿真波形</b></p><p>  4.5 頂層文件的時序仿真及原理圖</p><p><b>  仿真波形</b></p><p>  4.6 整體組裝設(shè)計原理圖</p>

56、<p><b>  整體組裝設(shè)計原理圖</b></p><p>  5 硬件調(diào)試與結(jié)果分析</p><p>  器件選擇ACEX1系列的EP1K30TC144-1。選擇后對原理圖進(jìn)行引腳鎖定。因?yàn)樽约簺]有寫16進(jìn)制到10進(jìn)制譯碼器,所以選擇模式5自帶譯碼器的方式進(jìn)行硬件驗(yàn)證。</p><p>  編譯以后對程序進(jìn)行配置,打開電源,

57、在實(shí)驗(yàn)板上選擇模式5,打開下載鎖定后開始配置。配置完成后,進(jìn)行調(diào)試,完成功能要求。</p><p><b>  6 參考文獻(xiàn)</b></p><p>  [1] 焦素敏.EDA課程設(shè)計指導(dǎo)書.鄭州:河南工業(yè)大學(xué),2008</p><p>  [2] 焦素敏.EDA應(yīng)用技術(shù),清華大學(xué)出版社,2007</p><p>  [

58、3] 曹昕燕,周鳳成等,EDA技術(shù)實(shí)驗(yàn)與課程設(shè)計,清華大學(xué)出版社,2006</p><p>  [4] 盧杰,賴毅.VHDL與數(shù)字電路設(shè)計.北京:科學(xué)出版社,2001社,2006</p><p><b>  7 心得體會</b></p><p>  通過兩星期的緊張工作,最后完成了我的設(shè)計任務(wù)——汽車尾燈控制器的設(shè)計。通過本次課程設(shè)計的學(xué)習(xí),我

59、深深的體會到設(shè)計課的重要性和目的性。本次設(shè)計課不僅僅培養(yǎng)了我們實(shí)際操作能力,也培養(yǎng)了我們靈活運(yùn)用課本知識,理論聯(lián)系實(shí)際,獨(dú)立自主的進(jìn)行設(shè)計的能力。它不僅僅是一個學(xué)習(xí)新知識新方法的好機(jī)會,同時也是對我所學(xué)知識的一次綜合的檢驗(yàn)和復(fù)習(xí),使我明白了自己的缺陷所在,從而查漏補(bǔ)缺。希望學(xué)校以后多安排一些類似的實(shí)踐環(huán)節(jié),讓同學(xué)們學(xué)以致用。</p><p>  在設(shè)計中要求我要有耐心和毅力,還要細(xì)心,稍有不慎,一個小小的錯誤就會

60、導(dǎo)致結(jié)果的不正確,而對錯誤的檢查要求我要有足夠的耐心,通過這次設(shè)計和設(shè)計中遇到的問題,也積累了一定的經(jīng)驗(yàn),對以后從事集成電路設(shè)計工作會有一定的幫助。在應(yīng)用VHDL的過程中讓我真正領(lǐng)會到了其并行運(yùn)行與其他軟件順序執(zhí)行的差別及其在電路設(shè)計上的優(yōu)越性。用VHDL硬件描述語言的形式來進(jìn)行數(shù)字系統(tǒng)的設(shè)計方便靈活,利用EDA軟件進(jìn)行編譯優(yōu)化仿真極大地減少了電路設(shè)計時間和可能發(fā)生的錯誤,降低了開發(fā)成本,這種設(shè)計方法必將在未來的數(shù)字系統(tǒng)設(shè)計中發(fā)揮越來越

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論