vhdl課程設(shè)計---樂曲演奏電路設(shè)計_第1頁
已閱讀1頁,還剩13頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  VHDL課程設(shè)計</b></p><p><b>  樂曲演奏電路設(shè)計</b></p><p><b>  一、概述</b></p><p>  在電子設(shè)計技術(shù)領(lǐng)域,可編程邏輯器件的廣泛應(yīng)用,為數(shù)字系統(tǒng)的設(shè)計帶來了極大的靈活性。由于該器件可以通過軟件編程而對其硬件的結(jié)構(gòu)和

2、工作方式進行重構(gòu),使得硬件的設(shè)計可以如同軟件設(shè)計那樣方便快捷。這一切極大的改變了傳統(tǒng)的數(shù)字系統(tǒng)設(shè)計方法、設(shè)計過程乃至設(shè)計觀念。在傳統(tǒng)的數(shù)字系統(tǒng)設(shè)計中,用戶能夠通過編程方式改變器件邏輯功能只有兩種途徑,即微處理器的軟件編程(如單片機)和特定器件的控制字配置(如8255)。在傳統(tǒng)的設(shè)計概念中,器件引腳功能的硬件方式的任意確定是不可能的。而對于系統(tǒng)構(gòu)成的設(shè)計過程只能對器件功能和電路板圖分別進行設(shè)計和確定,通過設(shè)計電路板來規(guī)劃系統(tǒng)功能。在此期間

3、,大量的時間和精力花在元件選配和系統(tǒng)結(jié)構(gòu)的可行性定位上。但若采用可編程邏輯器件,便可以利用計算機軟件的方式對目標進行設(shè)計,而以硬件的形式既定的系統(tǒng)功能。在設(shè)計過程中,設(shè)計者若可根據(jù)需要,隨時改變器件的內(nèi)部邏輯功能和管腳的信號方式。借助于大規(guī)模集成的可編程器件和高效的設(shè)計軟件,用戶不僅可通過直接對芯片結(jié)構(gòu)的設(shè)計實現(xiàn)多種數(shù)字邏輯器件和高效的設(shè)計軟件,用戶不僅可通過直接對芯片結(jié)構(gòu)的設(shè)計實現(xiàn)多種數(shù)字邏輯功能,而且由于管腳定義的靈活性,大大<

4、;/p><p>  EDA是電子設(shè)計自動化(Electronic Design Automation)的縮寫,是20世紀90年代初,從CAD(計算機輔助設(shè)計)、CAM(計算機輔助制造)、CAT(計算機輔助測試)和CAE(計算機輔助工程)的概念發(fā)展而是來的。EDA技術(shù)就是以計算機為工具,在EDA軟件平臺上,對以硬件描述HDL為系統(tǒng)邏輯描述手段完成的設(shè)計文件自動地完成邏輯編譯、邏輯分割、邏輯綜合及優(yōu)化、邏輯布局、邏輯仿真

5、,直至對于特定目標芯片的甜酸編譯、邏輯遇敵和編程下載等工作。設(shè)計者的工作僅限于利用軟件的方式,即利用硬件描述評議來完成對系統(tǒng)硬件功能的描述,在EDA工具的幫助下就可以得到最后的設(shè)計結(jié)果。盡管目標系統(tǒng)是硬件,但整個設(shè)計和修改過程如同完成軟件設(shè)計一樣的方便和高效。</p><p>  EDA技術(shù)中最為矚目的功能,即最具現(xiàn)代電子設(shè)計技術(shù)特征的功能就是日益強大的邏輯設(shè)計仿真測試技術(shù)。EDA仿真測試技術(shù)只需通過計算機就能對

6、所設(shè)計的電子系統(tǒng)從各種不同屋次的系統(tǒng)性能特點完成一系列準確的測試與仿真操作在完成實際系統(tǒng)的安裝后還能對系統(tǒng)上的目標器件進行所謂邊界掃描測試。這一切都極大地提高了大規(guī)模系統(tǒng)電子設(shè)計的自動化程度。</p><p>  另一方面高速發(fā)展的CPLD/FPGA器件又為EDA技術(shù)的不斷進步奠定了堅實的物質(zhì)基礎(chǔ)。CPLD/FPGA器件更廣泛的應(yīng)用及廠商間的競爭,使得普通的設(shè)計人員獲得廉價的器件和EDA軟件成為可能。</p

7、><p>  現(xiàn)代的EDA工具軟件已突破了早期僅能進行PCB版圖設(shè)計,或類似某些僅限于電路功能模擬的、純軟件范圍的局限,以最終實現(xiàn)可靠的硬件系統(tǒng)為目標,配備了系統(tǒng)設(shè)計自動化的全部工具。如配置了各種常用的硬件描述語言平臺VHDL、Verilog HDL、ABEL-HDL等;配置了多種功能兼用和混合使用的邏輯描述輸入工具,如硬件描述語言文本輸入法(其中包括布爾方程描述方式、原理圖描述方式、狀態(tài)圖描述方式等)以及原理圖輸入

8、法、波形輸入法等;同時還培植了高性能的邏輯綜合、優(yōu)化和仿真模擬工具。</p><p>  近十年由于超大規(guī)模集成電路和軟件技術(shù)的快速發(fā)展,使數(shù)字系統(tǒng)集成到一片集成電路內(nèi)成為可能,Altera、Xilinx、AMD等公司都推出了非常好的CPLD和FPGA產(chǎn)品,并為這些產(chǎn)品的設(shè)計配備了設(shè)計、下載軟件,這些軟件除了支持圖形方式設(shè)計數(shù)字系統(tǒng)外,還支持設(shè)計多種數(shù)字系統(tǒng)的設(shè)計語言,使數(shù)字系統(tǒng)設(shè)計起來更加容易,可以說數(shù)字電子技

9、術(shù)的設(shè)計進入了一個新時代。</p><p>  美國國防部開發(fā)的VHDL語言成為了IEEE. STD_1076標準,VHDL作為IEEE標準的硬件描述語言和EDA的重要組成部分,經(jīng)過十幾年的發(fā)展、應(yīng)用和完善,以及強大的系統(tǒng)描述能力、 規(guī)范的程序設(shè)計結(jié)構(gòu)、靈活的語句表達風(fēng)格和多層次的仿真測試手段,受到業(yè)界的普遍認同和廣泛的接受,從數(shù)十種國際流行的硬件描述語言中脫穎而出,成為EDA領(lǐng)域的首選硬件設(shè)計計算機語言,而且目

10、前流行的EDA工具軟件全部支持VHDL。該語言集成了各種HDL語言的優(yōu)點,使數(shù)字系統(tǒng)設(shè)計更加簡單和容易,是一個規(guī)模龐大的語言。</p><p>  VHDL語言通常包含實體(Entity),構(gòu)造體(Architecture),配置(Configuration),包集合(Package),和庫(Library)五部分.其中實體用于描述所設(shè)計的系統(tǒng)的外部接口信號;構(gòu)造體用于描述系統(tǒng)內(nèi)部的結(jié)構(gòu)和行為;建立輸入和輸出之間

11、的關(guān)系;配置語句安裝具體元件到實體—結(jié)構(gòu)體對,可以被看作是設(shè)計的零件清單;包集合存放各個設(shè)計模塊共享的數(shù)據(jù)類型、常數(shù)和子程序等;庫是專門存放預(yù)編譯程序包的地方。VHDL主要用于描述數(shù)字系統(tǒng)的結(jié)構(gòu),行為,功能和接口。除了含有許多具有硬件特征的語句外,VHDL的語言形式和描述風(fēng)格與句法是十分類似于一般的計算機高級語言。VHDL的程序結(jié)構(gòu)特點是將一項工程設(shè)計,或稱設(shè)計實體(可以是一個元件,一個電路模塊或一個系統(tǒng))分成外部(或稱可是部分,及端口

12、)和內(nèi)部(或稱不可視部分),既涉及實體的內(nèi)部功能和算法完成部分。在對一個設(shè)計實體定義了外部界面后,一旦其內(nèi)部開發(fā)完成后,其他的設(shè)計就可以直接調(diào)用這個實體。這種將設(shè)計實體分成內(nèi)外部分的概念是VHDL系統(tǒng)設(shè)計的基本點。應(yīng)用VHDL進行工程設(shè)計的優(yōu)點有以下幾個方面:(1)與其他的硬件描述語言相比,</p><p>  MAX+PLUSII軟件是一個功能強大,容易使用的軟件包,它可以以圖形方式、文字輸入方式(AHDL、V

13、HDL和VERILOG)、和波形方式輸入設(shè)計文件,可以編譯并形成各種能。其主要功能為:</p><p>  (1) 原理圖輸入(Graphic Editor)</p><p>  MAX+PLUSII軟件具有圖形輸入能力,用戶可以方便的使用圖形編輯器輸入電路圖,圖中的元器件可以調(diào)用元件庫中元器件,除調(diào)用庫中的元件以外,還可以調(diào)用該軟件中的符號功能形成的功能塊。夠下裝到EPROM和各種ALT

14、ERA器件的文件,還可以進行仿真以檢驗設(shè)計的準確性。</p><p>  波形編輯器(waveform Editor)</p><p>  在進行邏輯電路的行為仿真時,需要在所設(shè)計電路的輸入端加入一定的波形,波形編輯器可以生成和編輯仿真用的波形(*.SCF文件),使用該編輯器的工具條可以容易方便的生成波形和編輯波形。</p><p>  管腳(底層)編輯窗口(Flo

15、orplan Editor)</p><p>  該窗口用于將已設(shè)計好邏輯電路的輸入輸出節(jié)點賦予實際芯片的引腳,通過鼠標的拖拉,方便的定義管腳的功能。</p><p><b>  自動錯誤定位</b></p><p>  在編譯源文件的過程中,若源文件有錯誤,Max+Plus2軟件可以自動指出錯誤類型和錯誤所在的位置。</p>&

16、lt;p><b>  邏輯綜合與適配</b></p><p>  該軟件在編譯過程中,通過邏輯綜合 (Logic Synthesizer)和適配(Fitter) 模塊,可以把最簡單的邏輯表達式自動的吻合在合適的器件中。</p><p><b>  設(shè)計規(guī)則檢查</b></p><p>  選取Compile\Proc

17、essing\Design Doctor菜單,將調(diào)出規(guī)則檢查醫(yī)生,該醫(yī)生可以按照三種規(guī)則中的一個規(guī)則檢查各個設(shè)計文件,以保證設(shè)計的可靠性。一旦選擇該菜單,在編譯窗口將顯示出醫(yī)生,用鼠標點擊醫(yī)生,該醫(yī)生可以告訴你程序文件的健康情況。 </p><p>  多器件劃分(Partitioner)</p><p>  如果設(shè)計不能完全裝入一個器件,編譯器中的多器件劃分模塊,可自動的將一個設(shè)計分

18、成幾個部分并分別裝入幾個器件中,并保證器件之間的連線最少。</p><p><b>  編程文件的產(chǎn)生</b></p><p>  編譯器中的裝配程序(Assembler)將編譯好的程序創(chuàng)建一個或多個編程目標文件:</p><p>  EPROM配置文件(*.POF)例如,MAX7000系列;</p><p>  SRA

19、M文件(*.SCF)例如,FLEX8000系列的配置芯片EPROM;</p><p>  JEDEC文件(*.JED);</p><p>  十六進制文件(*.HEX);</p><p>  文本文件(*.TTF);</p><p>  串行BIT流文件(*.SBF);</p><p><b>  (10)仿

20、真</b></p><p>  當設(shè)計文件被編譯好,并在波形編輯器中將輸入波形編輯完畢后,就可以進行行為仿真了,通過仿真可以檢驗設(shè)計的邏輯關(guān)系是否準確。</p><p>  (11)分析時間(Analyze Timing)</p><p>  該功能可以分析各個信號到輸出端的時間延遲,可以給出延遲矩陣和最高工作頻率。</p><p&g

21、t;<b>  (12)器件編程</b></p><p>  當設(shè)計全部完成后,就可以將形成的目標文件下載到芯片中,實際驗證設(shè)計的準確性。</p><p><b>  (13)設(shè)計過程</b></p><p>  1)進入Max+plus2軟件環(huán)境</p><p>  2)輸入項目文件名(File/

22、Project/Name)</p><p>  3)輸入源文件(圖形、VHDL、AHDL、Verlog和波形輸入方式)</p><p>  4)(Max+plusⅡ/graphic Editor, Max+plusⅡ/Text Editor, Max+plusⅡ/Waveform Editor)</p><p>  5)指定CPLD型號(Assign/Device)

23、</p><p>  6)設(shè)置管腳、下載方式和邏輯綜合的方式</p><p>  (Assign/Global Project Device Option,Assign/Global Logic Synthesis)</p><p>  保存并檢查源文件(File/project/Save & Check)</p><p>  8)指

24、定管腳(Max+plusⅡ/Floorplan Editor)</p><p>  9)保存和編譯源文件(File/project/Save & Compile)</p><p>  10)生成波形文件(Max+plusⅡ/Waveform Editor)</p><p>  11)仿真(Max+plusⅡ/Simulator)</p><

25、;p>  12)下載配置(Max+plusⅡ/Programmer)</p><p><b>  二、設(shè)計</b></p><p>  下面設(shè)計一首《友誼天長地久》樂曲演奏電路,通過查詢相關(guān)資料,得知音高與頻率的對應(yīng)關(guān)系,具體見下表:</p><p><b>  音高頻率對照表</b></p><

26、p>  此程序使用4MHZ時鐘,如果經(jīng)時鐘不同修改一下常數(shù)即好。</p><p>  模塊及模塊功能設(shè)計:</p><p>  1、模塊PAIA 見圖1。該模塊控制每一個音的長短,送初值給FANA模塊,從而控制音高.</p><p><b>  圖1</b></p><p>  2、模塊FANA見圖2。該模塊的功能

27、是根據(jù)PAIA送來的初值倒計時,每次計到0時就使信號Q反轉(zhuǎn),由于初值不同,從而產(chǎn)生不同的音高。</p><p><b>  圖2 </b></p><p>  本設(shè)計的總體框圖如下圖3所示:</p><p><b>  圖3</b></p><p><b>  三、程序清單:</

28、b></p><p>  1、 PAIA模塊的程序:</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  entity paia is </p><p>  port(clk:in std_logic;</p>

29、;<p>  q:out integer range 0 to 10204);</p><p><b>  end paia;</b></p><p>  architecture paia_1 of paia is</p><p><b>  begin</b></p><p>  

30、process(clk)</p><p>  variable cnt1:integer range 0 to 1500000;</p><p>  variable cnt2:integer range 0 to 8;</p><p>  variable n:integer range 0 to 45;</p><p><b>

31、  begin</b></p><p>  if clk'event and clk='1' then</p><p>  if cnt1<1500000 then</p><p>  cnt1:=cnt1+1;</p><p><b>  else</b></p>

32、<p><b>  cnt1:=0;</b></p><p><b>  case n is</b></p><p>  when 0=>q<=10204;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p&g

33、t;<p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=1;</b></p><p><b>  end if;</b></p><p>  when 1=>q&

34、lt;=7634;</p><p>  if cnt2<6 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=2;&l

35、t;/b></p><p><b>  end if;</b></p><p>  when 2=>q<=6061;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b

36、></p><p><b>  cnt2:=0;</b></p><p><b>  n:=3;</b></p><p><b>  end if;</b></p><p>  when 3=>q<=6803;</p><p>  if

37、 cnt2<3 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=4;</b></p><p><b

38、>  end if;</b></p><p>  when 4=>q<=7634;</p><p><b>  n:=5;</b></p><p>  when 5=>q<=6803;</p><p>  if cnt2<1 then</p><p>

39、;  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=6;</b></p><p><b>  end if;</b></p>

40、<p>  when 6=>q<=6061;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><

41、;p><b>  n:=7;</b></p><p><b>  end if;</b></p><p>  when 7=>q<=7634;</p><p>  if cnt2<4 then</p><p>  cnt2:=cnt2+1;</p><p&

42、gt;<b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=8;</b></p><p><b>  end if;</b></p><p>  when 8=>q<=6061;&

43、lt;/p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=9;</b>&l

44、t;/p><p><b>  end if;</b></p><p>  when 9=>q<=5089;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p

45、><p><b>  cnt2:=0;</b></p><p><b>  n:=10;</b></p><p><b>  end if;</b></p><p>  when 10=>q<=4535;</p><p>  if cnt2<

46、;9 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=11;</b></p><p><b>  e

47、nd if;</b></p><p>  when 11=>q<=5089;</p><p>  if cnt2<3 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2

48、:=0;</b></p><p><b>  n:=12;</b></p><p><b>  end if;</b></p><p>  when 12=>q<=6061;</p><p>  if cnt2<2 then</p><p>  

49、cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=13;</b></p><p><b>  end if;</b></p>&l

50、t;p>  when 13=>q<=7634;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><

51、p><b>  n:=14;</b></p><p><b>  end if;</b></p><p>  when 14=>q<=6803;</p><p>  if cnt2<3 then</p><p>  cnt2:=cnt2+1;</p><p

52、><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=15;</b></p><p><b>  end if;</b></p><p>  when 15=>q<=763

53、4;</p><p><b>  n:=16;</b></p><p>  when 16=>q<=6803;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b>&l

54、t;/p><p><b>  cnt2:=0;</b></p><p><b>  n:=17;</b></p><p><b>  end if;</b></p><p>  when 17=>q<=6061;</p><p>  if cnt

55、2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=18;</b></p><p><b>

56、;  end if;</b></p><p>  when 18=>q<=7634;</p><p>  if cnt2<3 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  

57、cnt2:=0;</b></p><p><b>  n:=19;</b></p><p><b>  end if;</b></p><p>  when 19=>q<=9050;</p><p>  if cnt2<2 then</p><p&g

58、t;  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=20;</b></p><p><b>  end if;</b></p>

59、<p>  when 20=>q<=10204;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p>

60、<p><b>  n:=21;</b></p><p><b>  end if;</b></p><p>  when 21=>q<=7634;</p><p>  if cnt2<7 then</p><p>  cnt2:=cnt2+1;</p>

61、<p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=22;</b></p><p><b>  end if;</b></p><p>  when 22=>q<

62、;=4535;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=23;<

63、;/b></p><p><b>  end if;</b></p><p>  when 23=>q<=5089;</p><p>  if cnt2<3 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b

64、></p><p><b>  cnt2:=0;</b></p><p><b>  n:=24;</b></p><p><b>  end if;</b></p><p>  when 24=>q<=6061;</p><p>  

65、if cnt2<2 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=25;</b></p><p>&l

66、t;b>  end if;</b></p><p>  when 25=>q<=7634;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b

67、>  cnt2:=0;</b></p><p><b>  n:=26;</b></p><p><b>  end if;</b></p><p>  when 26=>q<=6083;</p><p>  if cnt2<3 then</p>&

68、lt;p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=27;</b></p><p><b>  end if;</b><

69、/p><p>  when 27=>q<=7634;</p><p><b>  n:=28;</b></p><p>  when 28=>q<=6803;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p&g

70、t;<p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=29;</b></p><p><b>  end if;</b></p><p>  when 29=>

71、q<=4535;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=30

72、;</b></p><p><b>  end if;</b></p><p>  when 30=>q<=5089;</p><p>  if cnt2<3 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else&l

73、t;/b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=31;</b></p><p><b>  end if;</b></p><p>  when 31=>q<=6061;</p><p&g

74、t;  if cnt2<2 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=32;</b></p><p&g

75、t;<b>  end if;</b></p><p>  when 32=>q<=5089;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p>&

76、lt;b>  cnt2:=0;</b></p><p><b>  n:=33;</b></p><p><b>  end if;</b></p><p>  when 33=>q<=4535;</p><p>  if cnt2<7 then</p>

77、;<p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=34;</b></p><p><b>  end if;</b>

78、</p><p>  when 34=>q<=3089;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b>&l

79、t;/p><p><b>  n:=35;</b></p><p><b>  end if;</b></p><p>  when 35=>q<=5089;</p><p>  if cnt2<3 then</p><p>  cnt2:=cnt2+1;<

80、;/p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=36;</b></p><p><b>  end if;</b></p><p>  when 36

81、=>q<=6061;</p><p>  if cnt2<2 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  

82、n:=37;</b></p><p><b>  end if;</b></p><p>  when 37=>q<=7634;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  e

83、lse</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=38;</b></p><p><b>  end if;</b></p><p>  when 38=>q<=6803;</p>&l

84、t;p>  if cnt2<3 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=39;</b></p>&l

85、t;p><b>  end if;</b></p><p>  when 39=>q<=7634;</p><p><b>  n:=40;</b></p><p>  when 40=>q<=6803;</p><p>  if cnt2<1 then</

86、p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=41;</b></p><p><b>  end if;</b

87、></p><p>  when 41=>q<=6061;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b&g

88、t;</p><p><b>  n:=42;</b></p><p><b>  end if;</b></p><p>  when 42=>q<=7634;</p><p>  if cnt2<3 then</p><p>  cnt2:=cnt2+1

89、;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=43;</b></p><p><b>  end if;</b></p><p>  whe

90、n 43=>q<=9050;</p><p>  if cnt2<2 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b&g

91、t;  n:=44;</b></p><p><b>  end if;</b></p><p>  when 44=>q<=10204;</p><p>  if cnt2<1 then</p><p>  cnt2:=cnt2+1;</p><p><b&g

92、t;  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=45;</b></p><p><b>  end if;</b></p><p>  when 45=>q<=7634;</p>

93、;<p>  if cnt2<7 then</p><p>  cnt2:=cnt2+1;</p><p><b>  else</b></p><p><b>  cnt2:=0;</b></p><p><b>  n:=0;</b></p>

94、<p><b>  end if;</b></p><p><b>  end case;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  end proce

95、ss;</p><p>  end paia_1;</p><p>  2、FANA模塊程序清單:</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  entity fana is</p><p>  

96、port(a:in integer range 0 to 10204;</p><p>  clk:in std_logic;</p><p>  q:out std_logic);</p><p><b>  end fana;</b></p><p>  architecture fana_1 of fana is&

97、lt;/p><p><b>  begin</b></p><p>  process(clk)</p><p>  variable b,d:std_logic;</p><p>  variable c:integer range 0 to 10204;</p><p><b>  be

98、gin</b></p><p>  if clk'event and clk='1' then</p><p>  if b='0' then</p><p><b>  c:=a;</b></p><p><b>  b:='1';</

99、b></p><p><b>  else</b></p><p>  if c=0 then</p><p><b>  b:='0';</b></p><p><b>  d:=not d;</b></p><p><b&

100、gt;  else</b></p><p><b>  c:=C-1;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></

溫馨提示

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

評論

0/150

提交評論