fpga乒乓球游戲機設計----畢業(yè)論文_第1頁
已閱讀1頁,還剩65頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、<p><b>  摘 要</b></p><p>  在電子技術獲得了飛速的發(fā)展的今天,現(xiàn)代電子產品幾乎滲透了社會的各個領域,有力地推動了社會生產力的發(fā)展和社會信息化程度的提高,同時也使現(xiàn)代電子產品性能進一步提高,產品更新?lián)Q代的節(jié)奏也越來越快。而電子游戲因其攜帶方便、互動性高、無場地限制等優(yōu)勢,成為了人們休閑時很好的選擇。</p><p>  本設計將采用

2、FPGA對“乒乓球”游戲機進行實現(xiàn)。FPGA具有功能強、可靠性高、使用方便、體積小及重量輕等優(yōu)點。近年來,國內的FPGA技術與產品開發(fā)應用方面的發(fā)展也很快,各種電子產品已越來越多地采用FPGA控制系統(tǒng)且性價比高。然后以FPGA為平臺,VHDL硬件描述語言編程實現(xiàn),實驗箱驗證。最后在硬件上調試并實現(xiàn)實現(xiàn)“乒乓球”游戲機功能。</p><p>  關鍵字:EDA,F(xiàn)PGA,VHDL,游戲機</p>&l

3、t;p><b>  ABSTRACT</b></p><p>  The electronic technology has obtained the rapid development in the modern, the electronic products penetrated almost every field of the society, a strong impetu

4、s to the development of social productive forces and the social informationization degree is improved, simultaneously also makes the modern electronic products to further improve the performance, product replacement are

5、increasingly fast pace. Electronic games because of its portability, interactive high, no site limitation and other adv</p><p>  This design will use the FPGA on the "ping pong" Electronic game mac

6、hine. FPGA has the advantages of strong function, high reliability, convenient use, small volume and light weight etc.. In recent years, the development of FPGA technology and product development and application of domes

7、tic too soon, all kinds of electronic products have been increasingly adopted in FPGA control system and high cost performance. Then taking FPGA as the platform, VHDL hardware description language programming, ve</p&g

8、t;<p>  Key Words:EDA, FPGA, VHDL, Game machine</p><p><b>  目 錄</b></p><p><b>  第1章 引言1</b></p><p>  1.1 選題背景1</p><p>  1.2 研究設計主要內容1

9、</p><p>  第2章 開發(fā)工具描述3</p><p>  2.1 EDA基礎3</p><p>  2.1.1 EDA技術的發(fā)展歷程3</p><p>  2.1.2 EDA技術的發(fā)展趨勢5</p><p>  2.1.3 EDA技術的基本工具5</p><p>  2.2 硬

10、件描述語言—VHDL6</p><p>  2.3 Quartus Ⅱ簡介7</p><p>  第3章 功能實現(xiàn)與設計思路10</p><p>  3.1 功能實現(xiàn)10</p><p>  3.2 設計方案10</p><p>  第4章 各模塊程序設計12</p><p>  4

11、.1 主控制程序設計12</p><p>  4.1.1 桌臺模塊程序設計12</p><p>  4.1.2 譯碼模塊程序13</p><p>  4.2 分頻器模塊設計14</p><p>  4.3 防抖動模塊設計15</p><p>  4.4 顯示控制和輸出模塊17</p><

12、p>  第5章 系統(tǒng)的整合與仿真20</p><p>  5.1 上層模塊設計20</p><p>  5.2 系統(tǒng)的仿真21</p><p>  5.3 引腳分配與器件編程24</p><p>  5.3.1 引腳分配24</p><p>  5.3.2 器件編程24</p><

13、p><b>  第6章 總結28</b></p><p><b>  參考文獻29</b></p><p><b>  致謝30</b></p><p><b>  附錄31</b></p><p>  附錄一:桌臺模塊程序31</p

14、><p>  附錄二:分頻器模塊程序35</p><p>  附錄三:防抖動模塊程序36</p><p>  附錄四:顯示控制和輸出模塊程序37</p><p>  附錄五:上層模塊程序39</p><p>  附錄六:譯碼模塊程序41</p><p><b>  外文資料原文

15、43</b></p><p><b>  譯文53</b></p><p><b>  引言</b></p><p><b>  選題背景</b></p><p>  電子技術的飛速發(fā)展,現(xiàn)代電子產品幾乎滲透了社會的各個領域,有力地推動了社會生產力的發(fā)展和社會信息

16、化程度的提高,同時也使現(xiàn)代電子產品性能進一步提高,產品更新?lián)Q代的節(jié)奏也越來越快。而休閑時間越來越少的人們越來越沒太多的時間出去搞戶外活動,于是眾多電子游戲應運而生,滿足大家休閑時的娛樂需求。由此設計了這個兩人的乒乓球游戲。</p><p>  本設計將采用FPGA對“乒乓球”游戲機進行實現(xiàn)。FPGA具有功能強、可靠性高、使用方便、體積小及重量輕等優(yōu)點。近年來,國內的FPGA技術與產品開發(fā)應用方面的發(fā)展也很快,各種

17、電子產品已越來越多地采用FPGA控制系統(tǒng)且性價比高。而電子信息類產品的開發(fā)明顯地出現(xiàn)了兩個特點:一是開發(fā)產品的復雜程度加深;二是開發(fā)產品的上市時限緊迫。而伴隨著如上兩個特點的產生,相應的出現(xiàn)了設計上的兩個問題。其一,在電子系統(tǒng)日趨數(shù)字化、復雜化和大規(guī)模集成化的今天,電子廠商們越加迫切地追求電子產品的高功能、優(yōu)品質、低成本、微功耗和微小封裝尺寸,從而使得電子設計日趨復雜。那么如何去完成這些高復雜度的電子設計呢?其二,電子產品設計周期短和上

18、市快是電子廠商們堅持不懈的追求,那么面對日趨復雜的設計,又如何能夠縮短開發(fā)時間呢?解決以上兩個問題的唯一途徑是電子設計自動化(EDA),即用計算機幫助設計人員完成繁瑣的設計工作。</p><p><b>  研究設計主要內容</b></p><p>  兩人乒乓球游戲機是用8個發(fā)光二級管代表乒乓球臺,中間兩個發(fā)光二極管兼做乒乓球網,用點亮的發(fā)光二極管按一定方向移動來表

19、示球的運動。在游戲機的兩側各設置發(fā)球和擊球開關,甲乙雙方按乒乓球比賽規(guī)則來操作開關。當甲方按動發(fā)球開關時,靠近甲方的第一個發(fā)光二極管亮,然后發(fā)光二極管由甲方向乙方依次點亮,代表乒乓球的移動。當球過網后按照設計者規(guī)定的球位乙方就可以擊球。若乙方提前擊球或者未擊到球,則甲方得分。然后重新發(fā)球進行比賽,知道一方記分達到21分為止,記分清零,重新開始新一局比賽。</p><p><b>  開發(fā)工具描述<

20、/b></p><p><b>  EDA基礎</b></p><p>  EDA是電子設計自動化(Electronic Design Automation)縮寫,是90年代初從CAD(計算機輔助設計)、CAM(計算機輔助制造)、CAT(計算機輔助測試)和CAE(計算機輔助工程)的概念發(fā)展而來的。EDA技術是以計算機為工具,根據(jù)硬件描述語言HDL( Hardwa

21、re Description language)完成的設計文件,自動地完成邏輯編譯、化簡、分割、綜合及優(yōu)化、布局布線、仿真以及對于特定目標芯片的適配編譯和編程下載等工作。典型的EDA工具中必須包含兩個特殊的軟件包,即綜合器和適配器。綜合器的功能就是將設計者在EDA平臺上完成的針對某個系統(tǒng)項目的HDL、原理圖或狀態(tài)圖形描述,針對給定的硬件系統(tǒng)組件,進行編譯、優(yōu)化、轉換和綜合,最終獲得我們欲實現(xiàn)功能的描述文件。綜合器在工作前,必須給定所要實

22、現(xiàn)的硬件結構參數(shù),它的功能就是將軟件描述與給定的硬件結構用一定的方式聯(lián)系起來。也就是說,綜合器是軟件描述與硬件實現(xiàn)的一座橋梁。綜合過程就是將電路的高級語言描述轉換低級的、可與目標器件FPGA/CPLD相映射的網表文件。</p><p>  硬件描述語言HDL是相對于一般的計算機軟件語言,如:C、PASCAL而言的。HDL語言使用與設計硬件電子系統(tǒng)的計算機語言,它能描述電子系統(tǒng)的邏輯功能、電路結構和連接方式。設計者

23、可利用HDL程序來描述所希望的電路系統(tǒng),規(guī)定器件結構特征和電路的行為方式;然后利用綜合器和適配器將此程序編程能控制FPGA和CPLD內部結構,并實現(xiàn)相應邏輯功能的的門級或更底層的結構網表文件或下載文件。目前,就FPGA/CPLD開發(fā)來說,比較常用和流行的HDL主要有ABEL-HDL、AHDL和VHDL。</p><p>  EDA技術的發(fā)展歷程</p><p>  集成電路的飛快發(fā)展不斷給

24、EDA技術提出更高的要求,對EDA技術的發(fā)展起了巨大的推動作用。從20世紀60年代中期開始,人們不斷地開發(fā)出各種計算機輔助設計工具來幫助設計人員進行集成電路和電子系統(tǒng)的設計。經歷了計算機輔助設計、計算機輔助工程設計和電子系統(tǒng)設計自動化這3個階段,如圖2-1所示。</p><p><b>  EDA發(fā)展歷程</b></p><p><b> ?。?)CAD階段

25、</b></p><p>  20世紀70年代,隨著中、小規(guī)模集成電路的興起和應用,傳統(tǒng)的手工設計印刷電路板和集成電路的方法已經不能滿足設計精度和效率的要求,于是電子設計工程師們開始在二維平面圖形上進行計算機輔助設計,這樣就產生了第一代EDA工具,設計者從繁雜、機械的、手工布局和布線工作中解放了出來。</p><p><b> ?。?)CAE階段</b>&

26、lt;/p><p>  20世紀80年代以后,集成電路的規(guī)模越來越大,電子系統(tǒng)設計的復雜也在增加,電子設計自動化的工具逐步完善和發(fā)展起來,設計者們尤其在設計方法、設計工具集成化方面取得了很大的進步。為了適應電子產品在規(guī)模和制作上的需要,以計算機仿真和自動布線為核心的第二代EDA技術應運而生。其特點是以軟件設計工具為核心,通過軟件完成產品的開發(fā)、設計、分析、生產和測試等工作。</p><p>&

27、lt;b> ?。?)ESDA階段</b></p><p>  20世紀90年代,設計師們逐步從使用硬件轉向去設計硬件,從單個電子產品開發(fā)轉向系統(tǒng)級電子產品開發(fā)(及片上系統(tǒng)集成)。因此,這時的EDA工具是以系統(tǒng)級設計為核心,包括結構綜合與系統(tǒng)行為級描述,系統(tǒng)仿真與測試驗證,系統(tǒng)決策與文件生成,系統(tǒng)劃分與指標分配等一整套的電子系統(tǒng)設計工具。這時的EDA工具不僅具有電子系統(tǒng)設計的能力,而且具有獨立于生

28、產工藝和廠家的系統(tǒng)級設計能力。第三代EDA工具的出現(xiàn),極大地提高了電子系統(tǒng)設計的效率,讓設計工程師們開始能夠以概念來驅動設計工程的夢想。</p><p>  EDA技術的發(fā)展趨勢</p><p>  隨著微電子技術的不斷發(fā)展與進步和市場需求的不斷增長,EDA技術在21世紀后得到了迅猛的發(fā)展,這一發(fā)展趨勢表現(xiàn)在以下幾個方面:</p><p>  (1)軟件IP核在微電

29、子的產業(yè)領域、設計應用領域和技術領域得到進一步的鞏固與發(fā)展。</p><p> ?。?)使支持硬件描述語言仿真和設計的EDA軟件不斷地強大起來。</p><p> ?。?)EDA使得系統(tǒng)與器件、專用集成電路ASIC與FPGA、模擬與數(shù)字、行為與結構、軟件與硬件等的界限越來越模糊。</p><p>  (4) EDA技術保護了設計者的電子設計成果的知識產權。</

30、p><p>  (5)大規(guī)模的電子系統(tǒng)都是以EDA為工具設計的,正以飛快的速度滲透到IP核模塊。</p><p>  (6)更大規(guī)模的可編程邏輯器件正在推向市場,使得設計更為廣泛與便捷。</p><p>  EDA技術的基本工具</p><p>  集成電路技術的不斷發(fā)展對EDA技術提出了更高的要求,促進了EDA技術向更高的層次發(fā)展。但實際來說,

31、EDA系統(tǒng)的設計能力一直難以滿足集成電路的要求。EDA工具的發(fā)展經歷了兩個階段,即物理工具階段和邏輯工具階段?,F(xiàn)在,人們已經開發(fā)了很多計算機輔助設計工具來幫助設計集成電路,常見的EDA工具有編輯器、仿真器、檢查/分析工具和優(yōu)化/綜合工具等,如圖2-2所示。</p><p>  EDA設計工具的分類</p><p>  硬件描述語言—VHDL</p><p>  V

32、HDL的英文全名是Very-High-Speed Integrated Circuit Hardware Description Language,誕生于1982年。1987年底,VHDL被IEEE和美國國防部確認為標準硬件描述語言 。自IEEE公布了VHDL的標準版本,IEEE-1076(簡稱87版)之后,各EDA公司相繼推出了自己的VHDL設計環(huán)境,或宣布自己的設計工具可以和VHDL接口。此后VHDL在電子設計領域得到了廣泛的接受,

33、并逐步取代了原有的非標準的硬件描述語言。1993年,IEEE對VHDL進行了修訂,從更高的抽象層次和系統(tǒng)描述能力上擴展VHDL的內容,公布了新版本的VHDL,即IEEE標準的1076-1993版本,(簡稱93版)?,F(xiàn)在,VHDL和Verilog作為IEEE的工業(yè)標準硬件描述語言,又得到眾多EDA公司的支持,在電子工程領域,已成為事實上的通用硬件描述語言。有專家認為,在新的世紀中,VHDL與Verilog語言將承擔起大部分的數(shù)字系統(tǒng)設計任

34、務。</p><p>  VHDL主要用于描述數(shù)字系統(tǒng)的結構,行為,功能和接口。除了含有許多具有硬件特征的語句外,VHDL的語言形式和描述風格與句法是十分類似于一般的計算機高級語言。VHDL的程序結構特點是將一項工程設計,或稱設計實體[4](可以是一個元件,一個電路模塊或一個系統(tǒng))分成外部(或稱可是部分,及端口)和內部(或稱不可視部分),既涉及實體的內部功能和算法完成部分。在對一個設計實體定義了外部界面后,一旦其

35、內部開發(fā)完成后,其他的設計就可以直接調用這個實體。這種將設計實體分成內外部分的概念是VHDL系統(tǒng)設計的基本點。應用VHDL進行工程設計的優(yōu)點是多方面的。 </p><p>  (1) 與其他的硬件描述語言相比,VHDL具有更強的行為描述能力,從而決定了他成為系統(tǒng)設計領域最佳的硬件描述語言。強大的行為描述能力是避開具體的器件結構,從邏輯行為上描述和設計大規(guī)模電子系統(tǒng)的重要保證。 </p><p&

36、gt;  (2) VHDL豐富的仿真語句和庫函數(shù),使得在任何大系統(tǒng)的設計早期就能查驗設計系統(tǒng)的功能可行性,隨時可對設計進行仿真模擬。 </p><p>  (3) VHDL語句的行為描述能力和程序結構決定了他具有支持大規(guī)模設計的分解和已有設計的再利用功能。符合市場需求的大規(guī)模系統(tǒng)高效,高速的完成必須有多人甚至多個代發(fā)組共同并行工作才能實現(xiàn)。</p><p>  (4)對于用VHDL完成的一

37、個確定的設計,可以利用EDA工具進行邏輯綜合和優(yōu)化,并自動的把VHDL描述設計轉變成門級網表。 </p><p>  (5) VHDL對設計的描述具有相對獨立性,設計者可以不懂硬件的結構,也不必管理最終設計實現(xiàn)的目標器件是什么,而進行獨立的設計。</p><p>  QuartusⅡ簡介</p><p>  Quartus II 是Altera公司的綜合性PLD/F

38、PGA開發(fā)軟件,支持原理圖、VHDL、VerilogHDL以及AHDL(Altera Hardware Description Language)等多種設計輸入形式,內嵌自有的綜合器以及仿真器,可以完成從設計輸入到硬件配置的完整PLD設計流程。</p><p>  Quartus II 可在以XP、Linux以及Unix上使用,除了可以使用Tcl腳本完成設計流程外,提供了完善的用戶圖形界面設計方式。具有運行速度快

39、,界面統(tǒng)一,功能集中,易學易用等特點。 </p><p>  Quartus II 支持Altera的IP核,包含了LPM/MegaFunction宏功能模塊庫,使用戶可以充分利用成熟的模塊,簡化了設計的復雜性、加快了設計速度。對第三方EDA工具的良好支持也使用戶可以在設計流程的各個階段使用熟悉的第三方EDA工具。 </p><p>  此外,Quartus II 通過和DSP Build

40、er工具與Matlab/Simulink相結合,可以方便地實現(xiàn)各種DSP應用系統(tǒng);支持Altera的片上可編程系統(tǒng)(SOPC)開發(fā),集系統(tǒng)級設計、嵌入式軟件開發(fā)、可編程邏輯設計于一體,是一種綜合性的開發(fā)平臺。</p><p>  Quartus II 軟件具有以下很多突出的特點。</p><p>  (1)開放式的多平臺設計環(huán)境 Quartus II 提供了完整的

41、多平臺設計環(huán)境,能滿足各種特定設計的需求,也是可編程片上系統(tǒng)設計的綜合性環(huán)境和SOPC開發(fā)的基本設計工具,并為Attera DSP開發(fā)包進行系統(tǒng)模型設計提供了集成綜合環(huán)境。</p><p> ?。?)設計與結構無關</p><p> ?。?)可在多種平臺運行</p><p> ?。?)層次化設計Quartus

42、II支持層次化設計,可以在一個新的編輯輸入環(huán)境中對使用不同輸入設計方式完成的模塊進行調用,從而解決了原理圖與HDL混合輸入設計的問題。</p><p> ?。?)模塊化工具設計者可以從各種設計輸入、編輯、校驗及器件編程工具中做出選擇,形成用戶風格的開發(fā)環(huán)境,必要時還可在保留原始功能的基礎上添加新的功能。</p><p> ?。?)支持硬件描述語言

43、Quartus II軟件支持多種硬件描述語言的設計輸入,包括標準的VHDL,Verilog HDL及Atera公司自己開發(fā)的硬件描述語言AHDL。</p><p>  (7)豐富的PLM模塊</p><p> ?。?)MegaCore功能MegaCore是經過預先校驗的為實現(xiàn)復雜的系統(tǒng)功能而提供的HDL網表文件。<

44、;/p><p> ?。?)OpenCore</p><p>  Quartus II軟件具有開放性內核的特點,OpenCore可供設計者在購買產品前來對自己的設計進行評估。</p><p>  功能實現(xiàn)與設計思路 </p><p><b>  功能實現(xiàn)</b></p><p>  兩人乒乓游戲機能夠模

45、擬乒乓球比賽的基本過程和規(guī)則,并能自動裁判和計分。乒乓游戲機是用8個發(fā)光二極管代表乒乓球臺,中間兩個發(fā)光二極管兼作乒乓球網,用點亮的發(fā)光二極管按一定的方向移動來表示球的運動。在游戲機的兩側設置擊球開關。甲乙兩人按乒乓球比賽的規(guī)則來操作開關。</p><p>  當甲方按動發(fā)球開關,發(fā)光二極管由甲方向乙方依次點亮,代表球在移動。當球過網后,按設計者規(guī)定的球位乙方就可以擊球。若乙方提前擊球或者沒有擊著球,則判乙方失分

46、,甲方計分牌自動加分。然后重新發(fā)球,比賽繼續(xù)進行。比賽一直進行到一方計分到21分,該局結束,計分牌清零,可以進行新的一局比賽。</p><p><b>  具體功能如下:</b></p><p>  (1)使用乒乓球游戲機的甲乙雙方在不同的位置發(fā)球或者擊球。</p><p> ?。?)乒乓球的位置和移動的方向由燈亮及依次點亮的方向決定,球移動的

47、速度為0.1~0.5s移動一位。游戲者根據(jù)球的位置發(fā)出相應的動作,提前擊球或出界均判失分。</p><p> ?。?)比賽用21分為一局來進行,甲乙雙方設置各自的記分牌,任何一方計滿21分,該方就算勝了此局。計分牌清零,開始新的一局比賽。</p><p><b>  設計方案</b></p><p>  根據(jù)乒乓游戲機功能的要求,我們可以分成5

48、個模塊來實現(xiàn)。分別為控制模塊、顯示控制和輸出模塊、譯碼模塊、分頻模塊、防抖模塊。在設計中,控制模塊為tennis模塊,它實現(xiàn)了乒乓球游戲機的的全部邏輯功能;顯示控制和輸出模塊為countyima模塊,它實現(xiàn)乒乓球游戲機七段數(shù)碼管的片選;7段譯碼器模塊為yima模塊,它將送來的分數(shù)進行譯碼,實現(xiàn)數(shù)據(jù)的顯示,即計分牌的分數(shù);分頻模塊將系統(tǒng)時鐘按照設計所需進行分頻;防抖模塊為fangdou模塊,機械開關易引入抖動干擾,為了消除抖動干擾,需要使

49、用防抖動電路。乒乓球游戲機總體框圖如圖3-1所示。</p><p>  乒乓球游戲機總體框圖</p><p><b>  各模塊程序設計 </b></p><p><b>  主控制程序設計</b></p><p>  主控制模塊程序作為該設計的核心,控制乒乓球在LED上的移動和甲乙雙方的計分的作

50、用。該主控制程序包括了桌臺模塊和譯碼模塊兩個部分。</p><p><b>  桌臺模塊程序設計</b></p><p>  設計該乒乓球游戲機的輸入/輸出端口。首先考慮輸入端口,設置一個異步置位端口restart,用于在系統(tǒng)不正常時或重開一局時回到初始狀態(tài);兩個擊球輸入端accep1和accep2,分別表示甲擊球鍵輸入和乙擊球鍵輸入;一個時鐘輸入端口clk1。<

51、;/p><p>  其次考慮輸出端口,芯片應該有8個輸出端口來控制8個發(fā)光二極管,輸出一個電平,可以使發(fā)光二極管點亮;另外,要直觀地表示雙方的得分,就得用到七段譯碼器,每方用到2個,可以表示0~21的數(shù)字。實體的設計如下:</p><p>  entity tennis is</p><p>  port(restart : in std_logic;</p&g

52、t;<p>  clk1 : in std_logic;</p><p>  accep1,accep2 : in std_logic;</p><p>  table : out std_logic_vector(1 to 8);</p><p>  score11 : out std_logic_vector(1 to 8);<

53、;/p><p>  score12 : out std_logic_vector(1 to 8);</p><p>  score21 : out std_logic_vector(1 to 8);</p><p>  score22 : out std_logic_vector(1 to 8));</p><p>  end tennis

54、;</p><p>  控制模塊設置了7個狀態(tài),分別是等待發(fā)球狀態(tài)(waitfor)、第一盞燈亮狀態(tài)(begin1)、第八盞燈亮狀態(tài)(begin2)、球向乙移動狀態(tài)(to2)、球向甲移動狀態(tài)(to1)、允許甲擊球狀態(tài)(allowreceive1)和允許乙擊球狀態(tài)(allowreceive2)。</p><p>  乒乓球游戲機中有兩個計數(shù)器scor1和scor2,分別記憶甲的得分和乙的得分

55、;一個a信號,用它的數(shù)值來控制狀態(tài)機外8個發(fā)光二極管的亮和暗,比如當a=1時表示第一個發(fā)光二極管亮,用發(fā)光二級管的輪流發(fā)光表示球的移動軌跡。控制模塊結構體代碼見附錄一。</p><p>  程序在Quartus II軟件上編譯、運行并生成tennis模塊元件如圖4-1所示。</p><p>  Tennis模塊元件</p><p><b>  譯碼模塊程序

56、</b></p><p>  譯碼模塊是將傳輸進入的分數(shù)信號進行譯碼,然后輸出讓LED數(shù)碼管顯示。七段譯碼器是在數(shù)字電路設計中經常用到的顯示電路。所謂七段譯碼器,其實是由7段發(fā)光二極管組成的用于顯示數(shù)字的器件。常見的數(shù)碼管有共陰和共陽2種。本設計用的是共陽極顯示數(shù)碼管,共陽數(shù)碼管是將8個發(fā)光二極管連接在一起作為公共端。公共端常被稱作位碼,而降其他8位稱作段碼,這8位是a,b,c,d,e,f,g及h,他

57、們對應數(shù)碼管的七個段位和一個小數(shù)點。a,b,c,d,e,f,g這七段是控制字型顯示的,因此也將LED數(shù)碼管稱為7段數(shù)碼管。</p><p>  由此我們可以得到0~9的7段譯碼值,加上小數(shù)點將是8位顯示代碼。0~9可以用4位二進制BCD碼來表示。</p><p>  譯碼模塊詳細程序見附錄六。下面是該譯碼模塊的部分程序:</p><p><b>  beg

58、in</b></p><p>  temp<=bcdin;</p><p>  case temp is</p><p>  when"00000"=>bcdout1<="00000011";bcdout2<="00000010";</p><p>

59、;  when"00001"=>bcdout1<="00000011";bcdout2<="10011110";</p><p><b>  ... ...</b></p><p>  when"10101"=>bcdout1<="00100101&

60、quot;;bcdout2<="10011110"; </p><p>  when others =>bcdout1<="11111101";bcdout2<="00000010"; </p><p><b>  end case;</b></p><p>

61、  end process; </p><p><b>  end ccc; </b></p><p>  譯碼程序在Quartus II軟件上編譯、運行,譯碼模塊仿真如圖4-2所示。</p><p><b>  譯碼模塊仿真</b></p><p><b>  分頻器模塊設計</b

62、></p><p>  本設計所用到的系統(tǒng)時鐘頻率為50Mhz。時鐘分頻模塊的功能是將輸入的外部時鐘信號進行分頻,產生本設計所用到的小于50Mhz的信號。</p><p>  其中,c1要求為1Khz,所以50Mhz/1Khz=50000,因此要一個50000分頻器產生1Khz的信號。c2要求為5hz,利用信號c1,所以1Khz/5hz=200,因此要一個200分頻器產生5hz的信號

63、。</p><p>  該分頻器的工作原理為計數(shù)器從0~n-1循環(huán)計數(shù),當計數(shù)值達到n-1時歸零,并且使計數(shù)器在n-1時輸出一個脈沖。分頻器模塊程序見附錄二。</p><p>  程序在Quartus II軟件上編譯、運行并生成fenpin模塊元件如圖4-3所示。</p><p>  Fenpin模塊元件</p><p>  分頻器模塊編譯、

64、運行之后進行仿真,該仿真將時鐘信號進行分頻,結果如圖4-4所示。</p><p><b>  分頻模塊仿真</b></p><p><b>  防抖動模塊設計</b></p><p>  本設計會用到機械按鍵,機械開關在開關切換的瞬間在接觸點會出現(xiàn)來回彈跳的現(xiàn)象,雖然只是一次按鍵然后放開,而實際產生的按鍵信號不止彈跳一次,

65、因此必須加上消除彈跳的電路。</p><p>  本設計采用計數(shù)器型防抖電路。設置一個模值為4的控制計數(shù)器,在人工按鍵key=’1’時,執(zhí)行加1計數(shù);key=’0’時,計數(shù)器進入狀態(tài)0。計數(shù)器只有在狀態(tài)1時有輸出。計數(shù)器進入狀態(tài)3,處于保持狀態(tài)。按鍵一次,計數(shù)器只有一個單脈沖輸出。</p><p>  按鍵key是產生抖動的根源,按照設計,只有按鍵持續(xù)時間大于3個時鐘周期,計數(shù)器輸出才可能

66、產生有效正跳變,輸出一個單脈沖。只要選擇時鐘周期大于機械開關抖動的產生的毛刺寬度,那么毛刺作用就不可能使計數(shù)器有輸出,防抖動目的就可以實現(xiàn)。</p><p>  防抖模塊的詳細程序見附錄三。以下是該模塊的部分程序:</p><p>  d :process(clk)</p><p><b>  begin</b></p><

67、p>  if(clk'event and clk='1')then</p><p>  if key='1' then</p><p>  if jsq=3 then</p><p>  cp<='1';jsq<=jsq;</p><p><b>  else

68、</b></p><p>  cp<='0';jsq<=jsq+1;</p><p><b>  end if;</b></p><p><b>  ... ... </b></p><p>  end process;</p><p>

69、;<b>  end;</b></p><p>  程序在Quartus II 軟件上編譯、運行并生成fangfou模塊元件如圖4-5所示。</p><p>  Fangdou模塊元件</p><p>  防抖模塊編譯、運行之后進行仿真,當輸入信號持續(xù)時間不足時沒有信號輸出,輸入信號持續(xù)時間達到時有一個信號輸出。如圖4-6所示。</p&g

70、t;<p><b>  防抖模塊仿真</b></p><p><b>  顯示控制和輸出模塊</b></p><p>  顯示控制和輸出模塊的功能就是要產生數(shù)碼管的使能信號,以控制哪一個數(shù)碼管亮,并完成譯碼的功能。</p><p>  該模塊描述了數(shù)碼管的4種狀態(tài)。當q等于0時,點亮第一個數(shù)碼管;q等于1時,

71、點亮第二個數(shù)碼管;當q等于2時,點亮第三個數(shù)碼管;當q等于3時,點亮第四個數(shù)碼管。并且將得分信號送出。選通信號一個1khz的信號控制4個數(shù)碼管的點亮。</p><p>  顯示控制和輸出模塊詳細程序見附錄四。以下是顯示控制和輸出模塊的部分程序:</p><p><b>  begin</b></p><p>  process(clk2)<

72、;/p><p><b>  begin</b></p><p>  if(clk2'event and clk2='1')then</p><p>  if q=3 then</p><p><b>  q<=0;</b></p><p><b

73、>  else</b></p><p><b>  q<=q+1;</b></p><p><b>  end if;</b></p><p><b>  end if;</b></p><p><b>  case q is</b>

74、;</p><p>  when 0=>sel<="1110";oscore<=score11;</p><p>  when 1=>sel<="1101";oscore<=score12;</p><p>  when 2=>sel<="1011";osco

75、re<=score21;</p><p>  when 3=>sel<="0111";oscore<=score22;</p><p><b>  end case;</b></p><p>  end process;</p><p><b>  end</b

76、></p><p>  程序在Quartus II軟件上編譯、運行并生成countyima模塊元件如圖4-7所示。</p><p>  Countyima模塊元件</p><p>  顯示控制和輸出模塊程序編譯、運行之后,進行仿真,仿真結果如圖4-8所示。</p><p>  顯示控制和輸出模塊仿真</p><p&

77、gt;<b>  系統(tǒng)的整合與仿真</b></p><p><b>  上層模塊設計</b></p><p>  上層模塊的作用是將下層模塊連接起來,可以用圖形輸入法,也可以用文本輸入法。本設計使用文本輸入法將下層模塊連接起來。在任何一個自頂向下的設計描述中,上層模塊都包括系統(tǒng)的接口,即輸入、輸出信號和數(shù)據(jù)類型。</p><p

78、>  該設計的上層接口信號為:</p><p>  reset 復位開關</p><p>  clk 時鐘信號,50Mhz</p><p>  accept1f,accept2f 擊球信號</p><p>  tablef 桌球臺燈</p>

79、<p>  scoref 數(shù)碼管的輸入信號</p><p>  selectf 數(shù)碼管的片選信號</p><p>  上層模塊調用了4個下層模塊:tennis桌臺模塊、fangdou防抖模塊、fenpin分頻模塊和countyima顯示控制和輸出模塊,利用位置映射的方法可將4個模塊連接起來。</p><p&g

80、t;  上層模塊詳細程序見附錄五。以下是上層模塊的部分程序:</p><p>  architecture link of ctrl is</p><p>  component fenpin</p><p>  port(clk : in std_logic;</p><p>  c1,c2 : out std_logic);</p

81、><p>  end component;</p><p><b>  ... ...</b></p><p>  signal clk1,clk2 : std_logic;</p><p><b>  begin</b></p><p>  u1 : fenpin port

82、 map (clk,clk1,clk2);</p><p>  u2 : fangdou port map (clk1,accept1f,accept1);</p><p>  u3 : fangdou port map (clk1,accept2f,accept2);</p><p>  u4 : tennis port map (reset,clk2,accep

83、t1,accept2,tablef,s11,s12,s21,s22);</p><p>  u5 :countyima port map(clk1,s11,s12,s21,s22,selectf,scoref);</p><p><b>  end link;</b></p><p>  所有模塊編輯輸入完成后,在quartusⅡ軟件上編譯、運

84、行并生成該設計的頂層模塊如圖5-1所示。</p><p><b>  頂層模塊</b></p><p>  在程序編譯運行成功后,仔細檢查是否與自己設計符合后就可以進行程序的仿真了。</p><p><b>  系統(tǒng)的仿真</b></p><p>  仿真的目的就是在軟件環(huán)境下,驗證電路的行為和設想

85、中的是否一致。</p><p>  可以使用Quartus II Simulator仿真任何設計。根據(jù)所需的信息類型,可以進行功能仿真以測試設計的邏輯功能,也可以進行時序仿真,在目標器件中測試設計的邏輯功能和最壞情況下的時序,或者采用FAST Timing模型進行時序仿真,在最快的器件速率等級上仿真盡可能快的時序條件。</p><p>  由于本系統(tǒng)的狀態(tài)情況比較的多,下面就幾種典型的情

86、況進行系統(tǒng)的綜合和仿真:</p><p> ?。?)當甲方先發(fā)球,乙方在恰當?shù)臅r刻擊球成功,當球回到甲方時,甲方沒有及時接到球的仿真波形。在圖中可以看到乒乓球的運動軌跡和打球的狀態(tài),此時乙方得一分。仿真波形如圖5-2所示。</p><p><b>  比賽過程仿真</b></p><p>  (2)當甲方兩次成功發(fā)球后乙方都沒有接到球,甲方得2

87、分的仿真波形圖。如圖5-3所示。</p><p><b>  比賽過程仿真</b></p><p> ?。?)當甲成功發(fā)球后,乙方提前擊球導致未擊中的情況,此時,甲方得1分。然后,甲方又成功發(fā)球,而乙方沒有在規(guī)定的時間接到球,此時甲方又得了1分。如圖5-4所示。</p><p><b>  比賽過程仿真</b></p

88、><p> ?。?)當甲方發(fā)過三次球之后,乙方發(fā)球。如圖5-5所示。</p><p><b>  交換發(fā)球權仿真</b></p><p><b>  引腳分配與器件編程</b></p><p><b>  引腳分配</b></p><p>  建立工程和設計

89、之后,需要指定目標器件并進行引腳分配。選擇好目標器件后就可以使用分配編輯器指定引腳分配。</p><p>  使用分配編輯器可以在Quartus II進行引腳分配。分配用于在設計中為邏輯指定的各種選項和設置,包括位置、I/O標準、時序、邏輯選項、參數(shù)、仿真和引腳分配。</p><p>  本設計采用以Cyclone系列EP1C3T144C8作為芯片的開發(fā)板,根據(jù)賣家提供的開發(fā)板引腳分配圖就

90、可以完成引腳分配。引腳分配如圖5-6所示。</p><p><b>  引腳分配</b></p><p><b>  器件編程</b></p><p>  使用Quartus II軟件成功編譯工程和引腳分配后,就可以對Altera器件進行編程或配置。Quartus II Compiler的Assembler模塊生成編程文件

91、,結合Atera編程硬件,Quartus II Programmer可以對器件進行編程或配置。</p><p>  Programmer使用Assembler生成的Programmer Object文件(.pof)或SRAM Object文件(.sof)對Quartus II軟件支持的器件進行編程或配置。</p><p>  Programmer具有四種編程模式:</p>&

92、lt;p> ?。?)Passive Serial模式;</p><p> ?。?)JTAG模式;</p><p> ?。?)Active Serial Programming模式;</p><p> ?。?)In-Socket Programming模式。</p><p>  Prassive Serial和JTAG編程模式允許使用CD

93、F和Altera編程硬件對單個或多個器件進行編程??梢允褂肁ctive Serial Programming模式和Altera編程硬件對單個EPCS1或EPCS4串行配置器件進行編程。</p><p>  編輯器窗口上的Mode下拉列表用于設置編程模式,默認是JTAG模式,如圖5-7所示。</p><p><b>  設置編程模式</b></p>&l

94、t;p>  完成設置之后,勾選編程文件后方的選項,單擊Start按鈕即可啟動編程器,Progress顯示編程進度,如圖5-8所示。</p><p><b>  完成器件編程</b></p><p>  完成器件編程之后,就可以進行硬件驗證了。程序下載到硬件后就可以進行硬件調試,看硬件的測試效果與設想的是否一致。</p><p>  硬件程

95、序下載完成之后,初始狀態(tài)甲乙雙方分數(shù)為零,由甲方發(fā)球。如圖5-9所示。</p><p><b>  游戲機初始狀態(tài)</b></p><p>  甲方發(fā)完三球之后,將發(fā)球權交給乙方,硬件效果如圖5-10所示。</p><p><b>  交換發(fā)球權</b></p><p>  乒乓球游戲機在比賽過程中

96、的效果如圖5-11所示。</p><p>  乒乓球游戲機比賽過程中</p><p><b>  總結</b></p><p>  本文進行乒乓游戲機軟件設計,并用EDA實驗箱進行驗證,目標芯片是Altera公司Cyclone系列的EP1C3T114C8,本設計由桌臺模塊、分頻模塊、譯碼模塊、按鍵防抖等模塊組成。采用VHDL語言編程,基于FPG

97、A成功設計了一款乒乓球比賽的游戲機,通過仿真驗證可知,結果滿足了設計的要求。系統(tǒng)能夠模擬兩人乒乓球比賽的基本過程和規(guī)則,并能自動裁判和計分,能有效模擬實際的乒乓球比賽。該系統(tǒng)可進一步改進,使用人體感應器官來采集擊球信號,采用FPGA產生視頻信號送到電視機,更直觀地展示乒乓球運動軌跡,從而真正實現(xiàn)人機互動,優(yōu)化虛擬效果。</p><p><b>  參考文獻</b></p>&l

98、t;p>  [1]聶小燕, 魯才. 數(shù)字電路EDA設計與應用. 人民郵電出版社, 2010</p><p>  [2]尹常永. EDA技術與數(shù)字系統(tǒng)設計. 西安電子科技大學出版社, 2004</p><p>  [3]李國麗, 朱維勇, 欒銘. EDA與數(shù)字系統(tǒng)設計. 機械工業(yè)出版社, 2007</p><p>  [4]延明, 張亦華. 數(shù)字電路EDA技術入

99、門.北京郵電大學出版社, 2006</p><p>  [5]江國強. EDA技術與應用[M]. 電子工業(yè)出版社, 2004</p><p>  [6]張文愛. EDA技術與FPGA應用設計[M]. 電子工業(yè)出版社, 2012</p><p>  [7]譚慧生 張昌凡. EDA技術與應用[M]. 西安電子科技大學出版社, 2001</p><p&

100、gt;  [8]漢澤西. EDA技術及其應用[M]. 北京航空航天大學出版社, 2004</p><p>  [9]王振紅. VHDL數(shù)字電路設計與應用教程[M]. 機械工業(yè)出版社, 2003</p><p>  [10]付家才. EDA技術與FPGA應用設計[M]. 電子工業(yè)出版社, 2012</p><p><b>  致謝</b><

101、/p><p><b>  附錄</b></p><p>  附錄一:桌臺模塊程序</p><p>  library ieee;</p><p>  use ieee.std_logic_1164.all;</p><p>  use ieee.std_logic_arith.all;</p&g

102、t;<p>  use ieee.std_logic_unsigned.all;</p><p>  entity tennis is</p><p>  port(restart : in std_logic;</p><p>  clk1 : in std_logic;</p><p>  accep1,accep

103、2 : in std_logic;</p><p>  table : out std_logic_vector(1 to 8);</p><p>  score11 : out std_logic_vector(1 to 8);</p><p>  score12 : out std_logic_vector(1 to 8);</p>&l

104、t;p>  score21 : out std_logic_vector(1 to 8);</p><p>  score22 : out std_logic_vector(1 to 8));</p><p>  end tennis;</p><p>  architecture rt1 of tennis is</p><p>

105、  type ttennis is ( waitfor, begin1,to2,allowreceive2,begin2,to1,allowreceive1);</p><p>  signal state :ttennis;</p><p>  signal a :integer range 0 to 8;</p><p>  signal scor1,sc

106、or2: std_logic_vector(1 to 4) :="0000";</p><p>  signal send : std_logic;</p><p>  signal m : integer range 0 to 3;</p><p>  component yima is</p><p>  por

107、t(bcdin : in std_logic_vector(1 to 4);</p><p>  bcdout1 : out std_logic_vector(1 to 8);</p><p>  bcdout2 : out std_logic_vector(1 to 8));</p><p>  end component;</p>

108、<p><b>  begin</b></p><p>  process(clk1)</p><p><b>  begin</b></p><p>  if clk1'event and clk1='1' then</p><p>  if(m=3) then

109、</p><p><b>  m<=0;</b></p><p>  send<=not send;</p><p><b>  end if;</b></p><p>  if scor1="1011"or scor2="1011" then&l

110、t;/p><p><b>  a<=0;</b></p><p>  scor1<="0000";</p><p>  scor2<="0000";</p><p>  elsif restart='0' then</p><p&g

111、t;  a<=0;scor1<="0000";scor2<="0000";m<=0;send<='0';state<=waitfor;</p><p><b>  else</b></p><p>  case state is</p><p>  wh

112、en waitfor =></p><p>  case send is</p><p>  --when "00" => a<=0;</p><p>  when'0'=>a<=1;state<=begin1;</p><p>  when'1'=>

113、;a<=8;state<=begin2;</p><p>  -- when "11" => a<=0;</p><p>  when others=>a<=0;</p><p><b>  end case;</b></p><p>  when begin1 =

114、></p><p>  if accep1='0'then</p><p><b>  a<=2;</b></p><p>  if accep2='0'then</p><p><b>  a<=0;</b></p><p>

115、;  scor1<=scor1+1;state<=waitfor;</p><p><b>  else</b></p><p>  state<=to2;</p><p><b>  end if;</b></p><p><b>  else</b><

116、;/p><p>  state<=waitfor;</p><p><b>  end if;</b></p><p>  when begin2=></p><p>  if accep2='0' then</p><p><b>  a<=7;</

117、b></p><p>  if accep1='0' then</p><p><b>  a<=0;</b></p><p>  scor2<=scor2+1;state<=waitfor;</p><p><b>  else</b></p>

118、<p>  state<=to1;</p><p><b>  end if;</b></p><p><b>  else</b></p><p>  state<=waitfor;</p><p><b>  end if;</b></p>

119、;<p>  when to1 =></p><p>  if accep1='0' then</p><p><b>  a<=0;</b></p><p>  scor2<=scor2+1;m<=m+1;state<=waitfor;</p><p>  e

120、lsif a=2 then a<=1;</p><p>  state<=allowreceive1;</p><p><b>  else</b></p><p><b>  a<=a-1;</b></p><p><b>  end if;</b><

121、/p><p>  when to2 =></p><p>  if accep2='0' then</p><p><b>  a<=0;</b></p><p>  scor1<=scor1+1;m<=m+1;state<=waitfor;</p><p&g

122、t;  elsif a=7 then a<=8;</p><p>  state <=allowreceive2;</p><p><b>  else</b></p><p><b>  a<=a+1;</b></p><p><b>  end if;</b&g

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論