eda課程設(shè)計--乒乓球游戲機_第1頁
已閱讀1頁,還剩16頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  《基于FPGA的數(shù)字系統(tǒng)設(shè)計》項目設(shè)計文檔</p><p>  項目名稱: 乒乓球比賽游戲機 </p><p>  姓 名: </p><p>  院 系: 應(yīng)用技術(shù)學(xué)院 </p><p>  專 業(yè): 電子信息工程(應(yīng)電應(yīng)本)

2、 </p><p>  學(xué) 號: </p><p>  指導(dǎo)教師: </p><p>  完成時間: 2012年 06月19日</p><p>  基于FPGA的數(shù)字系統(tǒng)設(shè)計項目成績評價表</p><p>  指導(dǎo)教師:

3、 年 月 日</p><p>  目 錄</p><p>  1 項目名稱、內(nèi)容與要求 ………………………………………04頁</p><p>  1.1 設(shè)計內(nèi)容…………………………………………………04頁</p><p>  1.2 具體要求………………

4、…………………………………04頁</p><p>  2 系統(tǒng)整體架構(gòu)(Architecture Description) ……………04頁</p><p>  2.1 設(shè)計思路…………………………………………………04頁</p><p>  2.2 系統(tǒng)原理(包含:框圖等闡述與設(shè)計說明等內(nèi)容)…04頁</p><p>  3 系統(tǒng)設(shè)計 (含

5、HDL或原理圖輸入設(shè)計)………………………05頁</p><p>  3.1 HDL 代碼…………………………………………………05頁</p><p>  3.2 系統(tǒng)整體電路圖(或RTL級電路圖)…………………12頁</p><p>  4 系統(tǒng)仿真(Simulation Waveform)…………………………13頁</p><p>  5

6、FPGA實現(xiàn)(FPGA Implementation) ………………………14頁</p><p>  總結(jié)(Closing)………………………………………………16頁</p><p>  參考書目(Reference):…………………………………………16頁</p><p>  一、項目名稱、內(nèi)容與要求</p><p><b> 

7、 1.1項目名稱</b></p><p><b>  乒乓球比賽游戲機</b></p><p><b>  1.2設(shè)計內(nèi)容</b></p><p>  設(shè)計一個由甲乙雙方參賽,二人乒乓球游戲機。</p><p>  用8個(或更多個)LED排成一條直線,以中點為界,兩邊各代表參賽雙方的位

8、置,其中一只點亮的LED指示球的當(dāng)前位置,點亮的LED依次從左到右,或從右到左,其移動的速度應(yīng)能調(diào)節(jié)。</p><p>  當(dāng)“球”(點亮的那只LED)運動到某方的最后一位時,參賽者應(yīng)能果斷地按下位于自己一方的按紐開關(guān),即表示啟動球拍擊球,若擊中,則球向相反方向運動;若未中,球掉出桌外,則對方得一分。</p><p>  設(shè)置自動記分電路,甲乙雙方各用兩位數(shù)碼管進(jìn)行記分顯示,每計滿11分為

9、1局。</p><p>  甲乙雙方各設(shè)一個發(fā)光二極管表示擁有發(fā)球權(quán),每隔2次自動交換發(fā)球權(quán),擁有發(fā)球權(quán)的一方發(fā)球才有效。</p><p><b>  1.3具體要求</b></p><p>  (1)使用乒乓球游戲機的雙方在不同位置發(fā)球或擊球。</p><p> ?。?)乒乓球的位置和移動方向由燈亮和依次亮的方向決定。

10、使用者根據(jù)球的位置發(fā)出相應(yīng)的動作。</p><p>  (3)比賽用11分為一局來進(jìn)行,雙方設(shè)置各自的記分牌,任意一方先記滿21分就獲勝此局。當(dāng)記分牌清零后,開始新的一局比賽。</p><p> ?。?)比賽結(jié)束后音樂自動響起。</p><p>  二、系統(tǒng)整體架構(gòu)(Architecture Description)</p><p><

11、b>  2.1設(shè)計思路</b></p><p>  根據(jù)系統(tǒng)設(shè)計的要求,乒乓球比賽游戲機的電路原理框圖如下:</p><p>  三、系統(tǒng)設(shè)計 (含HDL或原理圖輸入設(shè)計)</p><p>  3.1 VHDL 代碼</p><p><b>  比賽模塊</b></p><p>

12、  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic_arith.all;</p><p>  use ieee.std_logic_unsigned.all; --引用必要的庫函數(shù)和包集合</p><p>  entit

13、y compete is --實體名為pingpong</p><p>  port(reset:in std_logic;</p><p>  clk_1:in std_logic;</p><p>  startbutton:in std_logic; --開始游戲輸入端口</p><p>  serve:in std_logic_

14、vector(1 downto 0); --發(fā)球輸入端口</p><p>  hit1,hit2:in std_logic; --甲和乙的擊球輸入端口</p><p>  light:out std_logic_vector(1 to 8); --控制8個發(fā)光二極管的輸出端口</p><p>  music_begin:out std_l

15、ogic;--控制音樂開始的輸出端口</p><p>  counta,countb:out std_logic_vector(3 downto 0)); --2個用于控制4個7段譯碼器的輸出端口</p><p>  end compete;</p><p>  architecture one of compete is</p><

16、p>  type pingpong is (waitserve,light1on,ballmoveto2,allow2hit,</p><p>  light8on,ballmoveto1,allow1hit);</p><p>  ---設(shè)置7個狀態(tài),為枚舉數(shù)據(jù)類型,記為pingpong </p><p>  signal state:pingpong;&l

17、t;/p><p>  signal i:integer range 0 to 8;</p><p>  signal count1,count2,count3,count4:std_logic_vector(3 downto 0):="0000";</p><p>  ---內(nèi)部計數(shù)器,是4位二進(jìn)制變量</p><p><

18、;b>  begin</b></p><p>  process(clk_1) </p><p><b>  begin </b></p><p>  if(clk_1'event and clk_1='1') then </p><p>  if count3="00

19、01" or count4="0001" then </p><p>  music_begin<='1';</p><p><b>  end if; </b></p><p>  if(reset='1')then </p><p>  music

20、_begin<='0'; </p><p><b>  end if; </b></p><p><b>  end if; </b></p><p>  end process; </p><p>  process(clk_1) --狀態(tài)機進(jìn)程</p>

21、<p>  --clk_1作為敏感信號觸發(fā)進(jìn)程</p><p>  begin --進(jìn)程開始</p><p>  if reset='1' then --異步置位</p><p>  i<=0;count1<="0000";count2<="0000";cou

22、nt3<="0000";count4<="0000";</p><p>  elsif clk_1'event and clk_1='1' then --當(dāng)處于時鐘inclock上升沿時 </p><p>  if count1="1011" then</p><p&g

23、t;  i<=0;count1<="0000";count2<="0000";count3<=count3+1;</p><p>  elsif count2="1011" then </p><p>  i<=0;count1<="0000";count2<=&quo

24、t;0000";count4<=count4+1;</p><p>  elsif startbutton='0' then</p><p>  i<=0;count1<="0000";count2<="0000";count3<="0000";count4<=&quo

25、t;0000";</p><p>  else --以下case語句是程序中最關(guān)鍵的狀態(tài)機部分</p><p>  case state is</p><p>  when waitserve=> --進(jìn)程處于等待發(fā)球狀態(tài)</p><p>  case serve is</p><p&g

26、t;  when "01"=> i<=1;state<=light1on;</p><p>  when "10"=> i<=8;state<=light8on;</p><p>  when "11"=>i<=0;</p><p>  when others

27、=> i<=0;</p><p><b>  end case;</b></p><p>  when light1on=> --進(jìn)程處于第一盞燈亮狀態(tài)</p><p><b>  i<=2;</b></p><p>  if hit2='1' the

28、n</p><p><b>  i<=0;</b></p><p>  count1<=count1+1;state<=waitserve; </p><p><b>  else</b></p><p>  state<=ballmoveto2;</p>

29、<p><b>  end if;</b></p><p>  when light8on=> --進(jìn)程處于第八盞燈亮狀態(tài)</p><p><b>  i<=7;</b></p><p>  if hit1='1' then</p><p><b&

30、gt;  i<=0;</b></p><p>  count2<=count2+1;state<=waitserve;</p><p><b>  else</b></p><p>  state<=ballmoveto1;</p><p><b>  end if; <

31、;/b></p><p>  when ballmoveto1=> --進(jìn)程處于球向乙移動狀態(tài)</p><p>  if hit1='1' then</p><p><b>  i<=0;</b></p><p>  count2<=count2+1;state<

32、=waitserve;</p><p>  elsif i=2 then i<=1;</p><p>  state<=allow1hit;</p><p>  else i<=i-1;</p><p><b>  end if;</b></p><p>  when ballm

33、oveto2=> --進(jìn)程處于球向乙移動狀態(tài)</p><p>  if hit2='1'then</p><p><b>  i<=0;</b></p><p>  count1<=count1+1;state<=waitserve;</p><p>  elsif i=

34、7 then i<=8;</p><p>  state<=allow2hit;</p><p>  else i<=i+1;</p><p><b>  end if;</b></p><p>  when allow1hit=> --進(jìn)程處于允許甲擊球狀態(tài)</p>&

35、lt;p>  if hit1='1' then i<=2;</p><p>  state<=ballmoveto2;</p><p>  else count2<=count2+1;i<=0;</p><p>  state<=waitserve;</p><p><b>  e

36、nd if;</b></p><p>  when allow2hit=> --進(jìn)程處于允許乙擊球狀態(tài)</p><p>  if hit2='1'then i<=7;state<=ballmoveto1;</p><p>  else count1<=count1+1;i<=0;</p>

37、<p>  state<=waitserve;</p><p><b>  end if;</b></p><p><b>  end case;</b></p><p><b>  end if;</b></p><p><b>  end if

38、;</b></p><p>  end process;</p><p>  counta<=count1;countb<=count2;</p><p>  --進(jìn)程處i信號控制發(fā)光二極管的亮暗</p><p>  light<="10000000"when(i=1) else</p&

39、gt;<p>  "01000000" when(i=2) else</p><p>  "00100000" when(i=3) else</p><p>  "00010000" when(i=4) else</p><p>  "00001000" when(i=5)

40、 else</p><p>  "00000100" when(i=6) else</p><p>  "00000010" when(i=7) else</p><p>  "00000001" when(i=8) else</p><p>  "00000000&quo

41、t;; --其他情況所有發(fā)光二極管都暗</p><p><b>  end one;</b></p><p><b>  分頻模塊</b></p><p>  library IEEE; </p><p>  use IEEE.std_logic_1164.all;</p>

42、<p>  use ieee.std_logic_arith.all;</p><p>  use IEEE.std_logic_unsigned.all;</p><p>  entity division16 is</p><p>  port( cp:in std_logic; </p><p>  clk_4:out st

43、d_logic );</p><p>  end division16;</p><p>  architecture division_body of division16 is</p><p>  signal count:std_logic_vector(3 downto 0);</p><p><b>  begin<

44、/b></p><p>  process(cp)</p><p><b>  begin</b></p><p>  if(cp'event and cp='1')then </p><p>  if(count="1111")then</p><p

45、>  count<=(others=>'0');</p><p><b>  else</b></p><p>  count<=count+1;</p><p><b>  end if;</b></p><p><b>  end if;<

46、/b></p><p>  end process;</p><p>  process(cp)</p><p><b>  begin</b></p><p>  if(cp'event and cp='1')then </p><p>  if(count=&qu

47、ot;1111")then</p><p>  clk_4<='1';</p><p><b>  else</b></p><p>  clk_4<='0';</p><p><b>  end if;</b></p><p

48、><b>  end if;</b></p><p>  end process;</p><p>  end division_body;</p><p><b>  譯碼器部分</b></p><p>  library ieee; </p><p>  use i

49、eee.std_logic_1164.all; </p><p>  entity disp is </p><p>  port(d:in std_logic_vector(3 downto 0); </p><p>  q:out std_logic_vector(6 downto 0)); </p><p>  end disp; &l

50、t;/p><p>  architecture disp_arc of disp is </p><p><b>  begin </b></p><p>  process(d) </p><p><b>  begin </b></p><p>  case d is <

51、;/p><p>  when "0000"=>q<="0111111"; </p><p>  when "0001"=>q<="0000110"; </p><p>  when "0010"=>q<="1011011&qu

52、ot;; </p><p>  when "0011"=>q<="1001111"; </p><p>  when "0100"=>q<="1100110"; </p><p>  when "0101"=>q<="11

53、01101"; </p><p>  when "0110"=>q<="1111101"; </p><p>  when "0111"=>q<="0100111"; </p><p>  when "1000"=>q<=

54、"1111111"; </p><p>  when "1001"=>q<="1101111"; </p><p>  when others=>q<="0000000"; </p><p>  end case; </p><p>  e

55、nd process; </p><p>  end disp_arc;</p><p><b>  數(shù)碼管選擇</b></p><p>  LIBRARY IEEE;</p><p>  USE IEEE.STD_LOGIC_1164.ALL;</p><p>  ENTITY mux2 IS&

56、lt;/p><p>  PORT(a,b: IN STD_LOGIC_VECTOR(6 downto 0);</p><p>  sel: IN STD_LOGIC;</p><p>  c:OUT STD_LOGIC_VECTOR(6 downto 0));</p><p><b>  END mux2;</b></

57、p><p>  ARCHITECTURE example OF mux2 IS</p><p><b>  BEGIN</b></p><p>  PROCESS(sel)</p><p><b>  BEGIN</b></p><p>  IF(SEL='1')

58、THEN</p><p><b>  c<=a;</b></p><p><b>  ELSE</b></p><p><b>  c<=b;</b></p><p><b>  END IF;</b></p><p>

59、  END PROCESS;</p><p>  END example;</p><p>  音樂模塊(兩只老虎)</p><p>  library IEEE; </p><p>  use IEEE.std_logic_1164.all; </p><p>  use IEEE.std_logic_unsigne

60、d.all;</p><p>  entity music is </p><p>  port ( music_begin:in std_logic; </p><p>  clk_4:in std_logic; </p><p>  clk:in std_logic; </p><p>  music_out:ou

61、t std_logic ); </p><p>  end music;</p><p>  architecture music_body of music is </p><p>  constant m1:integer:=637;--955; </p><p>  constant m2:integer:=587;--851; <

62、;/p><p>  constant m3:integer:=505;--758; </p><p>  constant m4:integer:=468;--716; </p><p>  constant m5:integer:=425;--639; </p><p>  constant m6:integer:=379;--569; <

63、;/p><p>  constant m7:integer:=330;--506; </p><p>  constant m0:integer:=0; </p><p>  signal counter:integer range 0 to 67; </p><p>  signal count:integer range 0 to 1000;

64、 </p><p>  signal sub:integer range 0 to 1000; </p><p>  signal carrier:std_logic; </p><p>  signal pat,pat1,pat2:std_logic;</p><p><b>  begin</b></p>

65、<p>  process(clk) </p><p><b>  begin </b></p><p>  if(clk'event and clk='1')then </p><p>  if(carrier='1') then </p><p>  sub<

66、;=count; </p><p><b>  else </b></p><p>  sub<=sub-1; </p><p><b>  end if; </b></p><p><b>  end if; </b></p><p>  end

67、 process;</p><p>  process(sub) </p><p><b>  begin </b></p><p>  if(sub=0) then </p><p>  pat<='1'; </p><p><b>  else </b&g

68、t;</p><p>  pat<='0'; </p><p><b>  end if; </b></p><p>  carrier<=pat; </p><p>  end process; </p><p>  process(clk) </p>

69、<p><b>  begin </b></p><p>  if(clk'event and clk='1')then </p><p>  pat1<=pat; </p><p><b>  end if; </b></p><p>  end proce

70、ss;</p><p>  process(pat1) </p><p><b>  begin </b></p><p>  if(pat1'event and pat1='1') then </p><p>  pat2<= not pat2; </p><p>

71、<b>  end if; </b></p><p>  music_out<=pat2; </p><p>  end process; </p><p>  process(clk_4) </p><p><b>  begin </b></p><p>  if(

72、clk_4'event and clk_4='1') then </p><p>  if(music_begin='1') then </p><p>  counter<=counter+1; </p><p><b>  else </b></p><p>  coun

73、ter<=0; </p><p><b>  end if; </b></p><p><b>  end if; </b></p><p>  end process; </p><p>  process(counter) </p><p><b>  b

74、egin </b></p><p>  case counter is </p><p>  when 0=>count<=m0; when 1=>count<=m1;</p><p>  when 2=>count<=m1; when 3=>count<=m2;</p>

75、<p>  when 4=>count<=m2; when 5=>count<=m3;</p><p>  when 6=>count<=m3; when 7=>count<=m1;</p><p>  when 8=>count<=m1; when 9=>count<

76、=m1;</p><p>  when 10=>count<=m2; when 11=>count<=m2;</p><p>  when 12=>count<=m3; when 13=>count<=m3;</p><p>  when 14=>count<=m1; when

77、 15=>count<=m1;</p><p>  when 16=>count<=m3; when 17=>count<=m3;</p><p>  when 18=>count<=m4; when 19=>count<=m4;</p><p>  when 20=>count&l

78、t;=m5; when 21=>count<=m5;</p><p>  when 22=>count<=m5; when 23=>count<=m5;</p><p>  when 24=>count<=m3; when 25=>count<=m3;</p><p>  wh

79、en 26=>count<=m4; when 27=>count<=m5;</p><p>  when 28=>count<=m5; when 29=>count<=m5;</p><p>  when 30=>count<=m5; when 31=>count<=m5;</p&g

80、t;<p>  when 32=>count<=m5; when 33=>count<=m6;</p><p>  when 34=>count<=m5;when 35=>count<=m4;</p><p>  when 36=>count<=m3;when 37=>count<=m3

81、;</p><p>  when 38=>count<=m1;when 39=>count<=m1;</p><p>  when 40=>count<=m5;when 41=>count<=m6;</p><p>  when 42=>count<=m5;when 43=>count&l

82、t;=m4;</p><p>  when 44=>count<=m3;when 45=>count<=m3;</p><p>  when 46=>count<=m1;when 47=>count<=m1;</p><p>  when 48=>count<=m0; when 49=>

83、;count<=m1;</p><p>  when 50=>count<=m1;when 51=>count<=m5;</p><p>  when 52=>count<=m5;when 53=>count<=m1;</p><p>  when 54=>count<=m1;when 5

84、5=>count<=m1;</p><p>  when 56=>count<=m1;when 57=>count<=m0;</p><p>  when 58=>count<=m1;when 59=>count<=m1;</p><p>  when 60=>count<=m5;w

85、hen 61=>count<=m5;</p><p>  when 62=>count<=m1;when 63=>count<=m1;</p><p>  when 64=>count<=m1;when 65=>count<=m5;</p><p>  when 66=>count<=m

86、0;when 67=>count<=m0; </p><p>  end case; </p><p>  end process; </p><p>  end music_body;</p><p>  3.2 系統(tǒng)整體電路圖(或RTL級電路圖)</p><p>  四、系統(tǒng)仿真(Simulati

87、on Waveform)</p><p><b>  功能仿真波形圖</b></p><p><b>  時序仿真波形圖</b></p><p>  五、FPGA實現(xiàn)(FPGA Implementation)</p><p>  將程序下載到EDA2000實驗箱</p><p&

88、gt;  然后按照設(shè)定的管腳在EDA2000實驗箱上連接好實物圖</p><p>  輸入脈沖,驗證其功能</p><p>  六、總結(jié)(Closing)</p><p>  經(jīng)過一學(xué)期的學(xué)習(xí),在陳強老師的教導(dǎo)下,我對在系統(tǒng)編程技術(shù)這門課有了很深刻的理解,并能結(jié)合所學(xué)的知識設(shè)計了這次的乒乓球游戲機。由于實驗箱上脈沖端有限,于是我又想到了要設(shè)計一個分頻器,我開始設(shè)計的

89、是16分頻和64分頻,因為我需要一個4Hz和1Hz的脈沖信號,但是,這樣做對整個電路而言沒有任何效果,無論怎樣都仿真不出波形,但是代碼沒錯,單獨仿真分頻器也有波形輸出。當(dāng)我準(zhǔn)備放棄時,我又抱著僥幸心理只設(shè)計一個16分頻的分頻器,我把分頻器接入電路,然后仿真,結(jié)果仿真波形出來了。然后下載到實驗箱驗證時,結(jié)果甲乙兩位選手的得分不能再同一排數(shù)碼管上顯示,后經(jīng)過我冷靜的分析,我想到了曾經(jīng)做過的60進(jìn)制計數(shù)器,于是我便加了個數(shù)碼管選擇器,這樣甲乙

90、二人的分?jǐn)?shù)可以再同一排數(shù)碼上顯示了。</p><p>  經(jīng)過這次實訓(xùn),我收獲頗豐,學(xué)到了很多知識,特別是提高了綜合分析應(yīng)用的能力。我學(xué)會了如何去完成一個任務(wù),懂得了享受過程。當(dāng)遇到問題,冷靜,想辦法一點一點的排除障礙,到最后獲取成功,一種自信心由然而生。實訓(xùn)是對每個人綜合能力的檢驗。要想做好任何事,除了自己平時要有一定的功底外,我們還需要一定的實踐動手能力,操作能力。此次實訓(xùn),我深深體會到了積累知識的重要性。在

91、短暫的實訓(xùn)過程中,讓我深深的感覺到自己在實際運用中的知識的匱乏這時才真正領(lǐng)悟到“學(xué)無止境”的含義。</p><p>  參考書目(Reference):</p><p>  李國麗 朱維勇 《電子技術(shù)實驗指導(dǎo)書》 中國科技大學(xué)出版社</p><p>  潘松 黃繼 《EDA技術(shù)實用教程》 科學(xué)出版社</p><p>  王金明 《Verilo

溫馨提示

  • 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

提交評論