《eda技術(shù)及應(yīng)用實踐》課程設(shè)計報告_第1頁
已閱讀1頁,還剩14頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p>  《EDA技術(shù)及應(yīng)用實踐》課程設(shè)計報告</p><p><b>  目錄</b></p><p>  1.電子密碼鎖整體設(shè)計.....................................3</p><p>  1.1 設(shè)計要求............................................

2、.3</p><p>  1.2 設(shè)計思路.............................................3</p><p>  1.2.1輸入模塊.........................................3</p><p>  1.2.2控制模塊...................................

3、......3</p><p>  1.3設(shè)計結(jié)構(gòu)總圖.........................................4</p><p>  1.4整體設(shè)計的仿真結(jié)果...................................5</p><p>  2、各個功能模塊的設(shè)計..................................

4、..6</p><p>  2.1按鍵輸入模塊.........................................6</p><p>  2.1.1按鍵輸入與對應(yīng)的編碼輸出之間的關(guān)系...............6</p><p>  2.1.2輸入模塊程序.....................................7</p>

5、<p>  2.1.3輸入模塊仿真結(jié)果.................................8</p><p>  2.1.4生成元件..........................................8</p><p>  2.2系統(tǒng)控制模塊..........................................9</p>

6、<p>  2.2.1控制模塊程序....................................10</p><p>  2.2.2控制模塊仿真結(jié)果................................13</p><p>  2.2.3生成元件........................................13</p>&l

7、t;p>  3、下載與硬件測試.........................................14</p><p>  4、課程設(shè)計感想...........................................14</p><p>  5、參考文獻(xiàn)...............................................15</

8、p><p><b>  電子密碼鎖設(shè)計</b></p><p>  隨著人們生活水平的提高,如何實現(xiàn)家庭防盜這一問題也變的尤其的突出,傳統(tǒng)的機(jī)械鎖由于其構(gòu)造的簡單,被撬的事件屢見不鮮,電子鎖由于其保密性高,使用靈活性好,安全系數(shù)高,受到了廣大用戶的青睞。</p><p>  本次課程設(shè)計采用VHDL語言,利用Maxplus軟件完成相應(yīng)的電子密碼鎖功

9、能設(shè)計。</p><p>  1、電子密碼鎖整體設(shè)計</p><p><b>  1.1設(shè)計要求:</b></p><p>  設(shè)計一個電子密碼鎖,在鎖開的狀態(tài)下輸入密碼,密碼共4位,用數(shù)據(jù)開關(guān)K1~K10分別代表數(shù)字1、2、…、9、0,輸入的密碼用數(shù)碼管顯示,最后輸入的密碼顯示在最右邊的數(shù)碼管上,即每輸入一位數(shù),密碼在數(shù)碼管上的顯示左移一位。

10、可刪除輸入的數(shù)字,刪除的是最后輸入的數(shù)字,每刪除一位,密碼在數(shù)碼管的顯示右移一位,并在左邊空出的位上補(bǔ)充“0”。用一位輸出電平的狀態(tài)代表鎖的開閉狀態(tài)。為保證密碼鎖主人能打開密碼鎖,設(shè)置一個萬能密碼,在主人忘記密碼時使用。</p><p><b>  1.2設(shè)計思路:</b></p><p>  總的來說,設(shè)計成2個模塊,即輸入模塊,控制模塊,最后顯示管靜態(tài)顯示。<

11、;/p><p>  1.2.1輸入模塊:</p><p>  在輸入模塊,我是用時鐘脈沖clk來控制什么時候輸入一位密碼,即每來一個上升沿,輸入一個數(shù),且輸入的數(shù)只在上升沿到來時有效,在其他時候視為無效。如果clk信號為系統(tǒng)設(shè)置的,那么很難做到自己輸入密碼的頻率能與clk信號同步,因此本設(shè)計決定將clk信號設(shè)為手動,即輸入好一位密碼后,讓clk信號由0到1,則該密碼輸入成功。</p>

12、;<p>  1.2.2控制模塊:</p><p>  在密碼控制模塊中,主要實現(xiàn)以下功能:</p><p>  每輸入一位數(shù),數(shù)碼管左移一位,設(shè)置刪除信號back,每按一次,刪除最后輸入的數(shù)字,密碼在數(shù)碼管顯示右移一位,左邊空處0。</p><p>  設(shè)置密碼確認(rèn)信號set,在四位密碼輸入完畢后,按下set,則密碼被送到寄存器鎖存,比較器模塊得到數(shù)

13、據(jù)A,同時密碼顯示電路清零。</p><p>  設(shè)置密碼鎖狀態(tài)顯示信號lock。Lock=0表示鎖未開,lock=1表示鎖開,設(shè)置關(guān)鎖信號close,當(dāng)密碼送到寄存器模塊鎖存后,按下close,則lock=0。</p><p>  設(shè)置密碼檢驗信號compare ,在lock=0下從數(shù)據(jù)開關(guān)輸入四位開鎖數(shù)據(jù),按下compare,則開鎖數(shù)碼送寄存器鎖存,數(shù)據(jù)比較模塊得到數(shù)據(jù)B,若A=B,則

14、觸發(fā)器被置”1”。</p><p>  1.3設(shè)計結(jié)構(gòu)總圖:</p><p>  圖1(G1模塊表示輸入模塊,G2表示控制模塊)</p><p>  1.4整體設(shè)計的仿真結(jié)果如下圖</p><p>  2、各個功能模塊的設(shè)計</p><p>  2.1按鍵輸入模塊:</p><p>  2.1.

15、1按鍵輸入與對應(yīng)的編碼輸出之間的關(guān)系如表2-1所示</p><p><b>  表2-1 按鍵編碼</b></p><p>  2.1.2輸入模塊程序:</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all; </p><p>

16、  use ieee.std_logic_unsigned.all;</p><p>  entity g1 is</p><p>  port( data:in std_logic_vector(9 downto 0);clk:in std_logic; </p><p>  dout:out std_logic_vector

17、(3 downto 0)); </p><p><b>  end g1;</b></p><p>  architecture at of g1 is </p><p>  signal temp:std_logic_vecto

18、r(3 downto 0);</p><p><b>  begin</b></p><p>  process(clk)</p><p><b>  begin</b></p><p>  if clk'event and clk='1' then</p>&

19、lt;p>  case data is </p><p>  when "0000000001"=>temp<="0001";</p><p>  when "0000000010"=>temp<=&quo

20、t;0010";</p><p>  when "0000000100"=>temp<="0011";</p><p>  when "0000001000"=>temp<="0100";</p><p>  when "0000010000&

21、quot;=>temp<="0101";</p><p>  when "0000100000"=>temp<="0110";</p><p>  when "0001000000"=>temp<="0111";</p><p> 

22、 when "0010000000"=>temp<="1000";</p><p>  when "0100000000"=>temp<="1001";</p><p>  when "1000000000"=>temp<="0000"

23、;</p><p>  when others=>temp<="1111";</p><p><b>  end case;</b></p><p><b>  end if;</b></p><p>  end process;</p><p&g

24、t;  dout<=temp; </p><p><b>  end at;</b></p><p>  2.1.3輸入模塊仿真結(jié)果:</p><p>  2.1.4選擇FILE中creat default symbol選項創(chuàng)建元件符號如下:</p><p><b>  2.2系統(tǒng)控制模塊</b&g

25、t;</p><p>  密碼鎖的控制電路是整個電路的控制中心。</p><p>  設(shè)置set為密碼設(shè)置端口,compare為密碼檢驗端口,close為關(guān)鎖端口,back為刪除密碼端口,clk1時鐘輸入端口,db[3..0]為3位數(shù)字輸入端口,sout[15..0]為16位輸出端口,lock密碼鎖狀態(tài)顯示端口。</p><p>  在此電路中每輸一位數(shù),密碼在數(shù)碼

26、管上左移一位。</p><p>  設(shè)置刪除密碼back,每按下一次back,刪除最后輸入的數(shù)字,左邊空處補(bǔ)0。</p><p>  設(shè)置密碼確認(rèn)信號set,當(dāng)四位密碼輸入完畢,按下set,設(shè)置的密碼被存儲。</p><p>  設(shè)置密碼鎖狀態(tài)信號lock, lock=0表示鎖未開,lock=1表示鎖開。</p><p>  設(shè)置關(guān)鎖信號cl

27、ose,按下close,則鎖關(guān)閉。</p><p>  設(shè)置密碼檢驗信號compare,在lock=0下從數(shù)據(jù)開關(guān)輸入四位開鎖數(shù)字,按下compare,若數(shù)據(jù)等于設(shè)置的密碼或萬能密碼,則lock=1。</p><p>  模塊程序流程圖如圖:</p><p>  2.2.1控制部分程序:</p><p>  library ieee;

28、 </p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic_unsigned.all; </p><p>  entity g2 is</p><p>  port(

29、set,compare,close,back,clk:in std_logic; </p><p>  db:in std_logic_vector(3 downto 0);</p><p>  dout:out std_logic_vector(15 downto 0); </p><p>  lock:out

30、 std_logic); </p><p><b>  end g2; </b></p><p>  architecture aa of g2 is </p><p>  signal ch:st

31、d_logic;</p><p><b>  begin</b></p><p>  process(clk,db) </p><p>  variable lock1:std_logic;</p><p>  variable mima:s

32、td_logic_vector(15 downto 0);</p><p>  variable temp1,temp2,temp3,temp4:std_logic_vector(3 downto 0);</p><p><b>  begin </b></p><p>  ch<=not(db(0) and db(1) and db(

33、2) and db(3)); </p><p>  lock1:='0';</p><p>  if clk'event and clk='1' then</p><p>  if ch='1' then

34、 </p><p>  temp4:=temp3; </p><p>  temp3:=temp2;</p><p>  temp2:=temp1;</p><p>  temp1:=db;</p><p><b>  end if;</b></p><p>  

35、if back='1' then </p><p>  temp1:=temp2; </p><p>  temp2:=temp3;</p><p>  temp3:=temp4;</p><p>  temp4:="0000";&l

36、t;/p><p>  lock1:='0';</p><p><b>  end if;</b></p><p>  if set='1' then </p><p>  mima:=temp4&

37、temp3&temp2&temp1;</p><p>  lock1:='0';</p><p><b>  end if;</b></p><p>  if compare='1' then </p>

38、;<p>  if mima=temp4&temp3&temp2&temp1 then lock1:='1';</p><p>  elsif temp4="1000" and temp3="1000" and temp2="1000" and temp1="1000" the

39、n</p><p>  lock1:='1'; </p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  if close ='1' then</p><p>  lock1

40、:='0'; </p><p>  temp1:="0000";</p><p>  temp2:="0000";</p><p>  temp3:="0000";</p><p>

41、  temp4:="0000";</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  dout<=temp4&temp3&temp2&temp1;</p><p>  lock&

42、lt;=lock1;</p><p>  end process;</p><p><b>  end aa;</b></p><p>  2.2.2控制模塊仿真結(jié)果:</p><p>  2.2.3選擇FILE中creat default symbol選項創(chuàng)建元件符號如下:</p><p> 

43、 3、下載與硬件測試:</p><p>  根據(jù)實驗箱實際邏輯器件選擇“Assign”|“Device”|“MAX7000S”|“EPM7128SLC84-6”/【“Assign”|“Device”|“FLEX10K”|“EPF10K10LC84-3”】/【“Assign”|“Device”|“FLEX10KA”|“EPF30AQC208-1”】,并根據(jù)下載板上的標(biāo)識對管腳進(jìn)行配置。然后下載,進(jìn)行硬件測試,檢驗結(jié)

44、果是否正確。我選擇的是“Assign”|“Device”|“FLEX10K”|“EPF10K10LC84-3”,管腳安排如下:</p><p>  KEY0:K0 KEY1:K2 KEY2:K2 KEY3:K4</p><p>  KEY4:K5 KEY5:K6 KEY:6:K7 KEY7:K8</p>

45、<p>  KEY8:K9 KEY9:K10</p><p>  SET::K11 CLOSE:K12 BACK:K13</p><p>  CLK1:K14 COMPARE:K15 LOCK:L4</p><p>  其顯示的方式為靜態(tài)顯示,一次性直接顯示4位密碼,這與動態(tài)顯示的原理有較大的不同。本次

46、硬件測試的結(jié)果正確。</p><p><b>  4、課程設(shè)計感想:</b></p><p>  做課程設(shè)計的第一天,我們在網(wǎng)上找了一些資料,了解了整體的設(shè)計思路后,我們決定根據(jù)自己的理解以及網(wǎng)上和參考資料上提供的一些思路,自己編寫程序。經(jīng)過兩天的努力,我們終于寫好了自己的程序??墒切量鄬懗龅某绦騾s漏洞百出,一開始由于編寫程序時的粗心大意,以及一些編程方法不懂,導(dǎo)致程

47、序編譯出現(xiàn)很多錯誤,經(jīng)過翻閱資料,我們進(jìn)行了修改,最后雖然程序編譯沒啥問題了,可是仿真波形卻不對。不管怎么找錯,我們都覺得自己的程序沒有問題,所以不知道怎么修改。問了很多同學(xué),他們也各自有各自的一些見解,面對他們不統(tǒng)一的說法,我們也不知到底怎么做好。于是請教了老師,在老師的點(diǎn)撥下,我們終于有了自己的思路,于是修改好了自己的程序。最后通過仿真下載后,準(zhǔn)確無誤。</p><p>  這次課程設(shè)計讓我受益匪淺。它給了我

48、們一個將所學(xué)理論靈活運(yùn)用的機(jī)會,讓我知道光學(xué)習(xí)理論知識是遠(yuǎn)遠(yuǎn)不夠的,要將所學(xué)運(yùn)用于實踐,否則所學(xué)理論就是徒勞的。除此之外,它也讓我深刻體會到EDA編程的思想,也增加了我好好扎實學(xué)習(xí)的決心,因為學(xué)的踏實,才更會靈活運(yùn)用,也讓我明白求學(xué)不僅需要認(rèn)真、踏實、嚴(yán)謹(jǐn)、細(xì)心、耐心的態(tài)度,而且需要協(xié)作配合,因為龐大的工作單靠一個人的力量是不夠的,人多,思路多,遇到問題也能想出更多一個的解決辦法。此外這次課程設(shè)計也培養(yǎng)了我思考問題,分析問題,解決問題的

49、能力。最后,感謝老師對我們的指導(dǎo)。</p><p><b>  5、參考文獻(xiàn)</b></p><p>  [1]譚會生,《EDA技術(shù)及應(yīng)用實踐》長沙湖南大學(xué)出版社,2010.9</p><p>  [2]潘松,黃繼業(yè)編著.《EDA技術(shù)實用教程》.清華大學(xué)出版社. 2007</p><p>  [3]閻石編著,《

溫馨提示

  • 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

提交評論