eda課程設(shè)計(jì)--樂(lè)曲硬件演奏電路設(shè)計(jì)_第1頁(yè)
已閱讀1頁(yè),還剩20頁(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>  電子課程設(shè)計(jì)</b></p><p>  ——樂(lè)曲硬件演奏電路設(shè)計(jì)</p><p>  學(xué)院 太原科技大學(xué)華科學(xué)院</p><p>  專業(yè)、班級(jí) 電子信息工程</p><p><b>  姓名 </b></p><p><b>  學(xué)

2、號(hào) </b></p><p><b>  指導(dǎo)教師 </b></p><p><b>  2011年12月</b></p><p><b>  目錄</b></p><p>  一、設(shè)計(jì)任務(wù)與要求 …………………………… 3</p>&

3、lt;p>  二、總框體圖    …………………………… 3</p><p>  三、選擇器件     …………………………… 4</p><p>  四、功能模塊    …………………………… 4</p><p>  1、音樂(lè)數(shù)據(jù)模塊 …………………………… 4</p

4、><p>  2、音符控制輸出模塊   …………………………… 7</p><p>  3、音符譯碼模塊  …………………………… 8</p><p>  4、數(shù)控分頻器模塊 ……………………………11</p><p>  5、分頻

5、器模塊 ……………………………12</p><p>  6、譯碼模塊 ………………………… 13</p><p>  五、總體設(shè)計(jì)電路圖  ……………………………15</p><p>  1、總體電路原理圖 ………

6、……………………15</p><p>  2、管腳分配圖 ……………………………15 </p><p>  3、電路仿真結(jié)果 ……………………………15</p><p>  4、硬件驗(yàn)證 ……………………………16&

7、lt;/p><p>  六、設(shè)計(jì)心得   ……………………………17</p><p>  七、附錄    ……………………………19</p><p>  樂(lè)曲硬件演奏電路設(shè)計(jì)</p><p><b>  設(shè)計(jì)任務(wù)與要求:</b></p><p><b&g

8、t;  1、實(shí)驗(yàn)內(nèi)容</b></p><p>  利用可編程邏輯器件FPGA,設(shè)計(jì)樂(lè)曲硬件演奏電路,可自動(dòng)演奏樂(lè)曲。</p><p>  2、實(shí)驗(yàn)要求(1)利用數(shù)控分頻器設(shè)計(jì)硬件樂(lè)曲演奏電路。(2)利用給定的音符數(shù)據(jù)定制ROM“music”。 (3)設(shè)計(jì)乘法器邏輯框圖,并在QuartusII上完成全部設(shè)計(jì)。(4)將音樂(lè)通過(guò)實(shí)驗(yàn)箱上的喇叭播放出來(lái)。(5)與演奏發(fā)音相對(duì)應(yīng)

9、的簡(jiǎn)譜碼輸出在數(shù)碼管上顯示。</p><p><b>  總體框圖</b></p><p><b>  設(shè)計(jì)思路:</b></p><p><b>  C調(diào)音階頻率表:</b></p><p>  在《EDA技術(shù)實(shí)用教程》課程中,已經(jīng)學(xué)習(xí)過(guò)數(shù)控分頻器設(shè)計(jì),即輸入不同的預(yù)置數(shù)即可

10、發(fā)出不同頻率的聲音。由此,可以以此為設(shè)計(jì)基礎(chǔ)。設(shè)計(jì)一功能模塊,能夠?qū)?lè)曲中的音符逐一以對(duì)應(yīng)的頻率以預(yù)置數(shù)的形式置入數(shù)控分頻計(jì)中,即可利用該數(shù)控分頻計(jì)產(chǎn)生不同的聲音,演奏出設(shè)定好的音樂(lè)。</p><p>  ROM中的音樂(lè)數(shù)據(jù)文件剛可由編輯好的音符填入MIF文件中再定制LPM_ROM將音符數(shù)據(jù)加載入ROM中,并設(shè)計(jì)程序在運(yùn)行時(shí)自動(dòng)讀取ROM中的文件并置入數(shù)控分頻器中。</p><p>  當(dāng)

11、采用四四拍曲子時(shí),每節(jié)拍持續(xù)時(shí)間為0.5秒。置入數(shù)控分頻器的速度也應(yīng)與此同步或一致,避免音樂(lè)過(guò)快或過(guò)快慢而失真。</p><p>  由已知的C調(diào)音階頻率表,各頻率對(duì)應(yīng)的預(yù)置數(shù)就與數(shù)控分頻推動(dòng)蜂鳴器發(fā)出聲音的頻率對(duì)應(yīng)。在編寫(xiě)數(shù)控分頻器時(shí),不僅要考慮預(yù)置數(shù)的輸入方式,還要考慮輸入的速度,以及驅(qū)動(dòng)蜂鳴器發(fā)聲的頻率。</p><p>  為了顯示高音音調(diào),可在音符預(yù)置數(shù)的譯碼過(guò)程中,同時(shí)譯出高音

12、音階的信號(hào),并利用LED燈輸出信號(hào)。同時(shí),也可利用該譯碼模塊,將當(dāng)前演奏的音符簡(jiǎn)譜表達(dá)出來(lái)。</p><p><b>  總體框圖</b></p><p><b>  選擇器件</b></p><p>  1.EP1C12Q240C8芯片及相應(yīng)的連接設(shè)備</p><p><b>  2.外

13、置揚(yáng)聲器</b></p><p><b>  3.7段數(shù)碼管</b></p><p><b>  4.LED燈一個(gè)</b></p><p><b>  5.計(jì)算機(jī)</b></p><p><b>  功能模塊</b></p>&l

14、t;p>  1、音樂(lè)數(shù)據(jù)ROM模塊:</p><p>  該模塊為音樂(lè)曲譜的存放文件。其利用LPM_ROM宏模塊將共設(shè)定512個(gè)音符,每個(gè)音符寬度為5位,可存放高、中、低三階21個(gè)音符的數(shù)據(jù)。文件名為music.mif.</p><p>  其中[0..127]存放第一首歌《揮著翅膀的女孩》,</p><p>  [127..255]存放第二首歌《菊花臺(tái)》,&

15、lt;/p><p>  [256..383]存放第三首歌《兩只老虎》,</p><p>  [384..512]存放第四首歌《世上只有媽媽好》,</p><p>  在該數(shù)據(jù)中,每個(gè)字符持續(xù)時(shí)間為0.25秒(由音符控制輸出模塊的時(shí)鐘源4HZ信號(hào)確定),故在根據(jù)樂(lè)譜中音符的實(shí)際持續(xù)時(shí)間進(jìn)行編寫(xiě)。如四四拍的則每拍時(shí)間為0.5秒,則此處對(duì)應(yīng)數(shù)據(jù)應(yīng)該持續(xù)兩個(gè)字符。</p&

16、gt;<p>  MIF文件內(nèi)容如下:</p><p>  WIDTH=5; DEPTH=512;</p><p>  音樂(lè)數(shù)據(jù)ROM模塊不生成模塊,通過(guò)定制LPM_ROM,以備下一個(gè)模塊的使用。</p><p>  2、音符控制輸出模塊NOTETABS:</p><p>  該模塊利用已定制完成的music.mif文件,通過(guò)

17、給出LPM_ROM的數(shù)據(jù)地址,使LPM_ROM輸出對(duì)應(yīng)的音符,再送入音符譯碼電路,最終演奏出編好的音樂(lè)。</p><p>  VHDL語(yǔ)句描述如下:</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic_unsig

18、ned.all;</p><p>  entity notetabs is </p><p>  port(clk1:in std_logic;</p><p>  toneindex:out std_logic_vector(4 downto 0));</p><p><b>  end;</b></p>

19、<p>  architecture one of notetabs is</p><p>  component music</p><p>  port(address:in std_logic_vector(8 downto 0);</p><p>  clock:in std_logic;</p><p>  q:out

20、std_logic_vector(4 downto 0));</p><p>  end component;</p><p>  signal counter:std_logic_vector(8 downto 0);</p><p><b>  begin</b></p><p>  cnt8:process(clk

21、1,counter)</p><p><b>  begin</b></p><p>  if counter=512then counter<="000000000";</p><p>  elsif(clk1'event and clk1='1')then </p><p

22、>  counter<=counter+1;</p><p><b>  end if;</b></p><p>  end process;</p><p><b>  u1:music</b></p><p>  port map(address=>counter,q=>

23、toneindex,clock=>clk1);</p><p><b>  end;</b></p><p><b>  其生成項(xiàng)目符號(hào)為:</b></p><p>  該模塊時(shí)序仿真圖如下:</p><p>  時(shí)序仿真說(shuō)明:根據(jù)時(shí)序圖可看出,當(dāng)輸入clock1時(shí),toneindex也相應(yīng)的

24、改變,即完成在同一ROM內(nèi)存放多首歌曲。</p><p>  3、音符譯碼電路TONETABS模塊:</p><p>  該模塊將NOTETABS模塊輸出的音符譯成輸出電路的數(shù)控分頻所需要預(yù)置數(shù),并將對(duì)應(yīng)的簡(jiǎn)譜數(shù)字用數(shù)碼管顯示出來(lái),同時(shí)根據(jù)輸出的音符,判斷其高、中、低特性,并通過(guò)一個(gè)LED燈將高音顯示出來(lái)。其所輸出的預(yù)置數(shù)由最后一級(jí)的數(shù)控頻器所決定,參考值如下表:</p>&

25、lt;p>  其計(jì)算公式如下:由于所設(shè)計(jì)的數(shù)控分頻計(jì)采用12MHZ作為時(shí)鐘源,并通過(guò)一次12分頻給出頻率為1MHZ的脈沖溢出信號(hào),再對(duì)該1MHZ的溢出信號(hào)進(jìn)行12位2進(jìn)制碼的帶預(yù)置數(shù)進(jìn)行計(jì)數(shù),并給出一個(gè)頻率隨預(yù)置數(shù)變化的脈沖信號(hào)。由于該脈沖信號(hào)不具有驅(qū)動(dòng)蜂鳴器的能力,故對(duì)此脈沖信號(hào)進(jìn)行2分頻以推動(dòng)蜂鳴器發(fā)聲,故最終輸出信號(hào)的頻率與預(yù)置數(shù)的關(guān)系如下:</p><p>  其中為音階對(duì)應(yīng)的頻率。</p&g

26、t;<p>  模塊VHDL語(yǔ)句描述如下:</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  entity ToneTaba is</p><p>  port( Index : in std_logic_vector(4 downt

27、o 0);</p><p>  CODE : out std_logic_vector(3 downto 0);</p><p>  HIGH : out std_logic;</p><p>  Tone : out std_logic_vector(11 downto 0));</p><p><b>  end;</b&

28、gt;</p><p>  architecture one of ToneTaba is </p><p><b>  begin</b></p><p>  Search: process(Index)</p><p><b>  begin</b></p><p>  

29、case Index is </p><p>  When "00000"=>tone<="111111111111";code<="0000";high<='0';--4095</p><p>  When "00001"=>tone<="0110

30、00001000";code<="0001";high<='0';--1544</p><p>  When "00010"=>tone<="011100011110";code<="0010";high<='0';--1822</p><

31、;p>  When "00011"=>tone<="100000010110";code<="0011";high<='0';--2070</p><p>  When "00100"=>tone<="100010001000";code<="

32、;0100";high<='0';--2184</p><p>  When "00101"=>tone<="100101011001";code<="0101";high<='0';--2393</p><p>  When "00110"

33、;=>tone<="101000010010";code<="0110";high<='0';--2578</p><p>  When "00111"=>tone<="101001100111";code<="0111";high<='0&#

34、39;;--2663</p><p>  When "01000"=>tone<="101100000100";code<="0001";high<='1';--2820</p><p>  When "01001"=>tone<="10111000

35、1111";code<="0010";high<='1';--2959</p><p>  When "01010"=>tone<="110000001001";code<="0011";high<='1';--3081</p><p&g

36、t;  When "01011"=>tone<="110001000100";code<="0100";high<='1';--3140</p><p>  When "01100"=>tone<="110010101100";code<="010

37、1";high<='1';--3244</p><p>  When "01101"=>tone<="110100001001";code<="0110";high<='1';--3337</p><p>  When "01110"=&g

38、t;tone<="110100110011";code<="0001";high<='1';--3379</p><p>  When "01111"=>tone<="110110000001";code<="0010";high<='1';

39、--3457</p><p>  When "10000"=>tone<="110111000111";code<="0010";high<='1';--3527</p><p>  When "10001"=>tone<="111000000101

40、";code<="0010";high<='1';--3589</p><p>  When "10010"=>tone<="111000100001";code<="0010";high<='1';--3617</p><p>  

41、When "10011"=>tone<="111001010101";code<="0010";high<='1';--3669</p><p>  When "10100"=>tone<="111010000100";code<="0010&qu

42、ot;;high<='1';--3716</p><p>  When "10101"=>tone<="111010011001";code<="0010";high<='1';--3737</p><p>  When "10110"=>to

43、ne<="111011000000";code<="0010";high<='1';--3776</p><p>  When "10111"=>tone<="111011100011";code<="0010";high<='1';--38

44、11</p><p>  When "11000"=>tone<="111100000010";code<="0010";high<='1';--3842</p><p>  When "11001"=>tone<="111100010000&quo

45、t;;code<="0010";high<='1';--3856</p><p>  When "11010"=>tone<="111100101010";code<="0010";high<='1';--3882</p><p>  When

46、 "11011"=>tone<="111101000001";code<="0010";high<='1';--3905</p><p>  When "11100"=>tone<="111101001100";code<="0010";

47、high<='1';--3916</p><p>  When others => null;</p><p>  end case;</p><p>  end process;</p><p><b>  end;</b></p><p><b>

48、  其生成項(xiàng)目符號(hào)為:</b></p><p>  該模塊時(shí)序仿真圖如下:</p><p>  時(shí)序仿真說(shuō)明:將NOTETABS模塊輸出的音符譯成輸出電路的數(shù)控分頻所需要預(yù)置數(shù),并將高音輸出。</p><p>  4、數(shù)控分頻器計(jì)輸出模塊SPEAKERA:</p><p>  該模塊主體為一個(gè)12位的可預(yù)置數(shù)計(jì)數(shù)器。其通過(guò)NOTE

49、TABS得到預(yù)置數(shù),并對(duì)些進(jìn)行計(jì)數(shù)。當(dāng)計(jì)滿時(shí)便給出一個(gè)溢出信號(hào)。再對(duì)此溢出信號(hào)進(jìn)行二分頻得到能驅(qū)動(dòng)蜂鳴器且頻率符合C大調(diào)的21個(gè)音階的頻率。由此發(fā)出不同信號(hào)。</p><p>  其VHDL語(yǔ)言描述如下:</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p&g

50、t;  use ieee.std_logic_unsigned.all;</p><p>  entity speakera is</p><p>  port(clk:in std_logic;</p><p>  tone:in std_logic_vector(11 downto 0);</p><p>  spks:out std_l

51、ogic);</p><p><b>  end;</b></p><p>  architecture one of speakera is</p><p>  signal preclk,fullspks:std_logic;</p><p><b>  begin</b></p>

52、<p>  divideclk:process(clk)--對(duì)12MHZ時(shí)鐘源進(jìn)行12分頻,輸出1MHZ的脈沖信號(hào)。</p><p>  variable count4:std_logic_vector(3 downto 0);</p><p><b>  begin</b></p><p>  preclk<='0&

53、#39;;</p><p>  if count4>11 then preclk<='1';count4:="0000";</p><p>  elsif clk'event and clk='1' then count4:=count4+1;</p><p><b>  end if

54、;</b></p><p>  end process;</p><p>  genspks:process(preclk,tone)--12位預(yù)置數(shù)數(shù)控分頻器</p><p>  variable count11:std_logic_vector(11 downto 0);</p><p><b>  begin<

55、;/b></p><p>  if preclk'event and preclk='1' then </p><p>  if count11="111111111111"then count11:=tone; fullspks<='1';</p><p>  else count11:=co

56、unt11+1;fullspks<='0';end if;</p><p><b>  end if;</b></p><p>  end process;</p><p>  delayspks:process(fullspks)--2分頻,蜂鳴器推動(dòng)電路。</p><p>  variable

57、count2 :std_logic;</p><p><b>  begin</b></p><p>  if fullspks'event and fullspks ='1' then count2:=not count2;</p><p>  if count2='1' then spks<=&

58、#39;1';</p><p>  else spks<='0';end if;</p><p><b>  end if;</b></p><p>  end process;</p><p><b>  end;</b></p><p>&l

59、t;b>  其生成項(xiàng)目符號(hào)為:</b></p><p>  該模塊時(shí)序仿真圖如下:</p><p>  時(shí)序仿真說(shuō)明:根據(jù)預(yù)置數(shù)的不同,其輸出的頻率也有規(guī)律性的變化。</p><p>  5、分頻器模塊div_clk:</p><p>  該模塊主要是把從實(shí)驗(yàn)箱接入的50MHZ的頻率進(jìn)行分頻,得到12MHZ的脈沖,以備后面的

60、模塊使用</p><p>  模塊VHDL語(yǔ)句描述如下:</p><p>  LIBRARY ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic_unsigned.all;</p><p>  ENTITY div_clk

61、IS</p><p>  PORT(clk_in : INstd_logic;</p><p>  div_out: OUT std_logic);</p><p>  END div_clk;</p><p>  ARCHITECTURE a OF div_clk IS</p><p>  SIGNAL fre

62、_N : integer range 0 to 2;</p><p>  SIGNAL clk_tmp: std_logic;</p><p><b>  BEGIN</b></p><p>  div_out <= clk_tmp;</p><p>  process(clk_in)</p><

63、;p><b>  begin</b></p><p>  if falling_edge(clk_in) then</p><p>  if fre_N >= 1 then</p><p>  fre_N <= 0;</p><p>  clk_tmp <= not clk_tmp;</p&

64、gt;<p><b>  else</b></p><p>  fre_N <= fre_N + 1;</p><p><b>  end if;</b></p><p><b>  end if;</b></p><p>  end process;<

65、;/p><p><b>  END a;</b></p><p><b>  其生成項(xiàng)目符號(hào)為:</b></p><p>  該模塊時(shí)序仿真圖如下:</p><p>  時(shí)序仿真說(shuō)明:將50MHZ分成12MHZ的脈沖</p><p>  6、譯碼模塊deled</p>

66、<p>  該模塊將歌曲對(duì)應(yīng)的簡(jiǎn)譜通過(guò)七段數(shù)碼管顯示。</p><p>  模塊VHDL語(yǔ)句描述如下:</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic_unsigned.all;</p&g

67、t;<p>  use ieee.std_logic_arith.all;</p><p>  entity deled is </p><p>  port(num:in std_logic_vector(3 downto 0);</p><p>  led:out std_logic_vector(6 downto 0));</p>

68、<p>  end deled;</p><p>  architecture fun of deled is </p><p>  --signal count:std_logic_vector(2 downto 0);</p><p><b>  begin</b></p><p>  led<=&q

69、uot;1111110" when num="0000" else</p><p>  "0110000" when num="0001" else</p><p>  "1101101" when num="0010" else</p><p>  &qu

70、ot;1111001" when num="0011" else</p><p>  "0110011" when num="0100" else</p><p>  "1011011" when num="0101" else</p><p>  &quo

71、t;1011111" when num="0110" else</p><p>  "1110000" when num="0111" else</p><p>  "1111111" when num="1000" else</p><p>  "

72、;1111011" when num="1001" else</p><p>  "1110111" when num="1010" else</p><p>  "0011111" when num="1011" else</p><p>  "

73、1001110" when num="1100" else</p><p>  "0111101" when num="1101" else</p><p>  "1001111" when num="1110" else</p><p>  "1

74、000111" when num="1111" ;</p><p><b>  end fun;</b></p><p><b>  其生成項(xiàng)目符號(hào)為:</b></p><p>  該模塊時(shí)序仿真圖如下:</p><p>  時(shí)序仿真說(shuō)明:對(duì)應(yīng)的簡(jiǎn)譜變化時(shí),數(shù)碼管顯示相

75、應(yīng)的發(fā)生變化,顯示相應(yīng)的簡(jiǎn)譜。</p><p><b>  總體設(shè)計(jì)電路圖:</b></p><p><b>  1、總體電路原理圖</b></p><p><b>  2、管腳分配圖</b></p><p><b>  3、電路仿真結(jié)果</b></

76、p><p>  時(shí)序仿真說(shuō)明:當(dāng)輸入clk信號(hào)后,程序運(yùn)行,數(shù)碼管顯示相應(yīng)的簡(jiǎn)譜,揚(yáng)聲器播放歌曲,當(dāng)輸出為高音時(shí),LED燈亮。</p><p><b>  4、硬件驗(yàn)證</b></p><p>  【1】IO3接in_clock</p><p>  【2】IO5接揚(yáng)聲器</p><p>  【3】IO

77、9接LED燈</p><p>  下載完成后,揚(yáng)聲器即發(fā)出聲音,演奏出樂(lè)曲,同時(shí)數(shù)碼管顯示相應(yīng)的簡(jiǎn)譜,當(dāng)輸出為高音是,IO9連接的LED燈亮。</p><p><b>  六、設(shè)計(jì)心得</b></p><p>  通過(guò)兩周的努力,終于完成了此次課程設(shè)計(jì)。此次課程設(shè)計(jì)主要參考了教材中基于FPGA的硬件演奏電路的設(shè)計(jì),并根據(jù)課題要求,對(duì)其進(jìn)行加工與

78、改進(jìn),并最達(dá)到課題的要求,使其在QUARTUSП上選用目標(biāo)芯片仿真實(shí)現(xiàn)了音樂(lè)硬件演奏電路的功能。實(shí)踐證明:采用FPGA設(shè)計(jì)實(shí)現(xiàn)音樂(lè)硬件演奏電路的可行性和可靠性,而且更改樂(lè)曲容易,可根據(jù)需要修改ROM中的音符數(shù)據(jù)文件,從而使電路實(shí)現(xiàn)任一曲子的播放。</p><p>  這種基于FPGA的音樂(lè)硬件演奏電路的設(shè)計(jì)與實(shí)現(xiàn),不僅通過(guò)VHDL層次化和模塊化設(shè)計(jì)方法,同時(shí)采用數(shù)控分頻和定制LPM-ROM的設(shè)計(jì)思想,更好的優(yōu)化了

79、樂(lè)曲演奏數(shù)字電路的設(shè)計(jì),在此基礎(chǔ)上不必變化頂層文件架構(gòu)可隨意變更樂(lè)曲,有效縮短了產(chǎn)品開(kāi)發(fā)周期、減少了設(shè)計(jì)芯片的數(shù)量、降低了功耗、提高了設(shè)計(jì)的靈活性、可靠性和可擴(kuò)展性。</p><p>  在課程設(shè)計(jì)開(kāi)始之前,我就廣泛查找關(guān)于此類的文檔或者其他相關(guān)的資料,一開(kāi)始的時(shí)候當(dāng)查找到這些相關(guān)的資料之后就以為萬(wàn)事大吉了,只有將相關(guān)的程序復(fù)制下,再以前做實(shí)驗(yàn)?zāi)菢?,保存、建立?xiàng)目工程、運(yùn)行程序、建立頂層模塊等等類型的就行了,覺(jué)得

80、很簡(jiǎn)單。</p><p>  可是當(dāng)真的操作起來(lái)就發(fā)現(xiàn)遇到了許多的困難,首先填寫(xiě)MUSIC文件表格里的512個(gè)數(shù)字就很累,不過(guò)這只是體力活,不是很傷腦筋,可是那個(gè)剛弄完了之后我卻又遇到了問(wèn)題,不得不求助老師。在做課程設(shè)計(jì)的時(shí)候發(fā)現(xiàn)很多看似很簡(jiǎn)單的事情,只要錯(cuò)了一點(diǎn)點(diǎn)這個(gè)程序也無(wú)法運(yùn)行,但當(dāng)做出來(lái)了成果,看到了頂層模塊的仿真圖形之后我一種無(wú)法形容的喜悅,增強(qiáng)了自己做好它的自信心。</p><p&

81、gt;  通過(guò)這次實(shí)驗(yàn),我也學(xué)習(xí)到了如何利用可編程邏輯設(shè)計(jì)器件進(jìn)行設(shè)計(jì),并學(xué)習(xí)了宏模塊的設(shè)計(jì)與應(yīng)用的基礎(chǔ)。并能夠在LPM_ROM中寫(xiě)入自己需要的數(shù)據(jù)。得用該ROM模塊,還可進(jìn)行函數(shù)信號(hào)發(fā)生器等電路功能的實(shí)現(xiàn)。</p><p>  在計(jì)算C大調(diào)頻率對(duì)應(yīng)的預(yù)置數(shù)過(guò)程,應(yīng)用了單片機(jī)定時(shí)器的相關(guān)知識(shí)進(jìn)行理解并加以計(jì)算,并得出了可直接計(jì)算的功能。但這些計(jì)算也需要對(duì)應(yīng)正確的電路,才可最終例蜂鳴器發(fā)出正確的頻率。在設(shè)計(jì)選擇歌曲

82、的功能時(shí),考慮到需要面一塊ROM中寫(xiě)入多首歌的數(shù)據(jù),則在選擇時(shí),即應(yīng)給出每首歌正確的地址。由此想到了在微機(jī)芯片中,RAM的數(shù)據(jù)采用段基址加變址的實(shí)現(xiàn)方法。由此設(shè)計(jì)出在同一ROM中,同時(shí)存放多首歌。</p><p>  在分頻計(jì)的設(shè)計(jì)過(guò)程中,由于經(jīng)驗(yàn)不足,未意識(shí)到,分頻計(jì)在溢出后輸出的僅為一單脈沖波,該脈沖波不足以驅(qū)動(dòng)蜂鳴器,故需要再加一分頻電路,拓寬信號(hào)的脈沖,使其擁有驅(qū)動(dòng)蜂鳴器的能力</p>&l

83、t;p>  在向ROM中填寫(xiě)音樂(lè)文件數(shù)據(jù)時(shí),應(yīng)當(dāng)首選了解樂(lè)譜中每個(gè)音符的持續(xù)時(shí)間。再根據(jù)程序中設(shè)定好的節(jié)拍速度,適當(dāng)修改樂(lè)譜,使音樂(lè)的演奏能夠連貫,并不失真。</p><p>  這次的課程設(shè)計(jì)不單是做出一個(gè)硬件演奏樂(lè)曲電路出來(lái),更重要的是鍛煉自己學(xué)習(xí)的能力?;仡櫞舜握n程設(shè)計(jì),從書(shū)籍,網(wǎng)絡(luò)不斷的尋找到設(shè)計(jì)電路,從拿到題目到完成整個(gè)設(shè)計(jì),從理論到實(shí)踐,可以學(xué)到很多很多的的東西。對(duì)課本知識(shí)的進(jìn)一步加深的同時(shí)學(xué)到

84、了很多在書(shū)本上沒(méi)有學(xué)到過(guò)的知識(shí)。能夠自己學(xué)習(xí)QUARTUSⅡ的新功能,或結(jié)合其他電路仿真設(shè)計(jì)電路一同設(shè)計(jì)。。同時(shí),可以利用網(wǎng)上的資源,查找相關(guān)資料,以幫助自己完成電路的設(shè)計(jì)。</p><p>  通過(guò)這次課程設(shè)計(jì)使我懂得了理論與實(shí)際相結(jié)合是很重要的,只有理論知識(shí)是遠(yuǎn)遠(yuǎn)不夠的。把所學(xué)的理論知識(shí)與實(shí)踐相結(jié)合起來(lái),從理論中得出結(jié)論,才能真正提高自己的實(shí)際動(dòng)手能力和獨(dú)立思考的能力。在設(shè)計(jì)的過(guò)程難免會(huì)遇到過(guò)各種各樣的問(wèn)題,

溫馨提示

  • 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)論