版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、<p> 用VHDL語言設(shè)計智能搶答器鑒別和計時模塊</p><p><b> 摘要</b></p><p> 伴隨著集成電路(IC)技術(shù)的發(fā)展,EDA技術(shù)已經(jīng)成為現(xiàn)代電子設(shè)計的發(fā)展趨勢,并在各大公司、企事業(yè)單位和科研教學(xué)部門廣泛使用。VHDL是一種全方位的硬件描述語言,幾乎覆蓋了以往各種硬件描述語言的功能,整個自頂向下或自底向上的電路設(shè)計過程都可以用
2、VHDL來完成。本文闡述了EDA的概念和發(fā)展、VHDL語言的優(yōu)點和語法結(jié)構(gòu)并分析講解了智能搶答器的各模塊的功能要求、基本原理以及實現(xiàn)方法。本系統(tǒng)的設(shè)計就是采用VHDL硬件描述語言編程,基于Quartus II平臺進(jìn)行編譯和仿真來實現(xiàn)的,其采用的模塊化、逐步細(xì)化的設(shè)計方法有利于系統(tǒng)的分工合作,并且能夠及早發(fā)現(xiàn)各子模塊及系統(tǒng)中的錯誤,提高系統(tǒng)設(shè)計的效率。本設(shè)計主要的功能是:1.對第一搶答信號的鑒別和鎖存功能; 2.限時功能3.記分功能4.數(shù)
3、碼顯示。</p><p> 關(guān)鍵詞 電子設(shè)計自動化(EDA);VHDL;搶答器;自頂向下的設(shè)計方法</p><p> The identification and timing module of the Answering</p><p> snatches based on VHDL</p><p><b> ABST
4、RACT</b></p><p> As the fast development of the integrated circuit technology,Electronic design automation (EDA)technology has become the trend of modern electronic design,what's more,it has been
5、widely used by each big company, the enterprises and Scientific Institutions .VHDL is a kind of hardware description language,which is all-rounds, nearly covers the function of each other kind of hardware description lan
6、guage .Both the entire top-down and bottom-Up circuit design process could be accomplished by VHDL.Th</p><p> KEY WORDS EDA;VHDL;the answering snatches;top-down design method</p><p><b>
7、 目 錄</b></p><p> 中文摘要.............................................Ⅰ</p><p> ABSTRACT...............................................Ⅱ</p><p><b> 1 緒 論1</b><
8、/p><p> 1.1 EDA技術(shù)的發(fā)展1</p><p> 1.2 智能搶答器的市場現(xiàn)狀和EDA技術(shù)的應(yīng)用1</p><p> 1.3 EDA技術(shù)的設(shè)計優(yōu)勢2</p><p> 1.4 論文結(jié)構(gòu)2</p><p> 2 系統(tǒng)的設(shè)計元素3</p><p> 2.1 傳統(tǒng)的數(shù)字系
9、統(tǒng)設(shè)計方法和現(xiàn)代的數(shù)字系統(tǒng)設(shè)計方法比較3</p><p> 2.2 VHDL硬件描述語言概述4</p><p> 2.3硬件平臺QuartusII概述5</p><p> 2.3.1 Quartus II介紹5</p><p> 2.3.2 Quartus II設(shè)計流程及注意事項6</p><p>
10、 2.3.3 Quartus II的設(shè)計優(yōu)勢應(yīng)用舉例……………………………………………7</p><p> 2.4 實驗開發(fā)系統(tǒng)及芯片簡述7</p><p> 3 智能搶答器系統(tǒng)的設(shè)計與實現(xiàn)9</p><p> 3.1 搶答器系統(tǒng)設(shè)計要求9</p><p> 3.2系統(tǒng)總體設(shè)計思想9</p><p>
11、 3.3子模塊的設(shè)計思想和實現(xiàn)11</p><p> 3.3.1 鑒別模塊的設(shè)計與實現(xiàn)11</p><p> 3.3.2 計時模塊的設(shè)計與實現(xiàn)12</p><p> 3.3.3 計分模塊的設(shè)計與實現(xiàn)14</p><p> 3.3.4 譯碼顯示模塊的設(shè)計與實現(xiàn)..16</p><p> 3.3.5 搶
12、答器的系統(tǒng)實現(xiàn)16</p><p> 4 智能搶答器子模塊的仿真驗證19</p><p> 4.1 鑒別模塊的仿真驗證19</p><p> 4.2 計時模塊的仿真驗證20</p><p> 4.3 計分模塊的仿真驗證21</p><p> 4.4 數(shù)顯模塊的仿真驗證22</p>&
13、lt;p><b> 結(jié)束語24</b></p><p><b> 致 謝25</b></p><p><b> 參考文獻(xiàn)26</b></p><p> (附錄)..........................................................2
14、6</p><p><b> 1 緒 論</b></p><p> 1.1 EDA技術(shù)的發(fā)展</p><p> 人類社會已進(jìn)入到高度發(fā)達(dá)的信息化社會,信息社會的發(fā)展離不開電子產(chǎn)品的進(jìn)步。現(xiàn)代電子產(chǎn)品在性能提高、復(fù)雜度增大的同時,價格卻一直呈下降趨勢,而且產(chǎn)品更新?lián)Q代的步伐也越來越快,實現(xiàn)這種進(jìn)步的主要原因就是生產(chǎn)制造技術(shù)和電子設(shè)計技術(shù)的發(fā)
15、展。前者以微細(xì)加工技術(shù)為代表,目前已進(jìn)展到深亞微米階段,可以在幾平方厘米的芯片上集成數(shù)千萬個晶體管;后者的核心就是EDA技術(shù)?!?】EDA是指以計算機(jī)為工作平臺,融合了應(yīng)用電子技術(shù)、計算機(jī)技術(shù)、智能化技術(shù)最新成果而研制成的電子CAD通用軟件包,主要能輔助進(jìn)行三方面的設(shè)計工作:IC設(shè)計,電子電路設(shè)計以及PCB設(shè)計。沒有EDA技術(shù)的支持,想要完成上述超大規(guī)模集成電路的設(shè)計制造是不可想象的,但是面對當(dāng)今飛速發(fā)展的電子產(chǎn)品市場,設(shè)計師需要更加實
16、用、快捷的EDA工具,使用統(tǒng)一的集體化設(shè)計黃精,改變傳統(tǒng)的設(shè)計思路,將精力集中到設(shè)計構(gòu)想、方案比較和尋找優(yōu)化設(shè)計等方面,需要以最快的速度,開發(fā)出性能優(yōu)良、質(zhì)量一流的電子產(chǎn)品,對EDA技術(shù)提出了更高的要求。未來的EDA技術(shù)將在仿真、時序分析、集成電路自動測試、高速印刷版設(shè)計及開發(fā)操作平臺的擴(kuò)展等方面取得新的突破,向著功能強(qiáng)大、簡單易</p><p> 1.2 智能搶答器的市場現(xiàn)狀和EDA技術(shù)的應(yīng)用</p&g
17、t;<p> 智力競賽是“快樂學(xué)習(xí)”這一教育模式的典范,它采用在規(guī)定的一段時間內(nèi)搶答和必答等方式,在給人們的生活帶來樂趣的同時,也使參與者和觀眾在愉悅的氛圍中學(xué)到一些科學(xué)知識和生活知識,因此很受大家的喜歡。智力搶答器在智力競賽中起到很重要的角色,能夠準(zhǔn)確、公正、直觀地判斷出首輪搶答者,并且通過搶答器的數(shù)碼顯示和警示蜂鳴等方式指示出首輪搶答者。</p><p> EDA技術(shù)是在電子CAD技術(shù)基礎(chǔ)上
18、發(fā)展起來的計算機(jī)軟件系統(tǒng),是指以計算機(jī)為工作平臺,融合了應(yīng)用電子技術(shù)、計算機(jī)技術(shù)、信息處理及智能化技術(shù)的最新成果,進(jìn)行電子產(chǎn)品的自動設(shè)計。利用EDA工具,電子設(shè)計師可以從概念、算法、協(xié)議等開始設(shè)計電子系統(tǒng),大量工作可以通過計算機(jī)完成,并可以將電子產(chǎn)品從電路設(shè)計、性能分析到設(shè)計出IC版圖或PCB版圖的整個過程在計算機(jī)上自動處理完成?,F(xiàn)在對EDA的概念或范疇用得很寬。包括在機(jī)械、電子、通信、航空航天、化工、礦產(chǎn)、生物、醫(yī)學(xué)、軍事等各個領(lǐng)域,
19、都有EDA的應(yīng)用。目前EDA 技術(shù)已在各大公司、企事業(yè)單位和科研教學(xué)部門廣泛使用。例如在飛機(jī)制造過程中,從設(shè)計、性能測試及特性分析直到飛行模擬,都可能涉及到EDA技術(shù)。</p><p> 所以從目前的市場情況來看,這個課題的研究很有發(fā)展前景。</p><p> 1.3 EDA技術(shù)的設(shè)計優(yōu)勢</p><p> 傳統(tǒng)的設(shè)計方法采用自底向上的設(shè)計方法,一般先按電子系
20、統(tǒng)的具體功能要求進(jìn)行功能劃分,然后對每個子模塊畫出真值表,用卡諾圖進(jìn)行手工邏輯簡化,寫出布爾表達(dá)式,畫出相應(yīng)的邏輯線路圖,再據(jù)此選擇元器件,設(shè)計電路板,最后進(jìn)行實測與調(diào)試,由于無法進(jìn)行硬件系統(tǒng)功能仿真,如果某一過程存在錯誤,查找和修改十分不便,所以這是一種費時、費力的設(shè)計方法,而現(xiàn)代電子設(shè)計技術(shù)(EDA)是自頂向下且先進(jìn)高效的。在電子產(chǎn)品的設(shè)計理念、設(shè)計方式、系統(tǒng)硬件構(gòu)成、設(shè)計的重用性、知識產(chǎn)權(quán)、設(shè)計周期等方面,EDA技術(shù)具有一定的優(yōu)勢
21、。所以本次設(shè)計的搶答器拋棄了傳統(tǒng)的設(shè)計方法,選擇了采用主流的EDA技術(shù)進(jìn)行設(shè)計。</p><p><b> 1.4 論文結(jié)構(gòu)</b></p><p> ※第一章 緒論部分,介紹了該課題的發(fā)展前景、現(xiàn)狀以及EDA技術(shù)的設(shè)計優(yōu)勢等;</p><p> ※第二章 概述整個系統(tǒng)設(shè)計的設(shè)計元素;</p><p> ※第三章
22、 詳細(xì)介紹用VHDL語言對智能搶答器的設(shè)計和實現(xiàn);</p><p> ※第四章 各功能模塊的仿真。</p><p><b> 2 系統(tǒng)的設(shè)計元素</b></p><p> 此次設(shè)計是按照"自頂向下"的設(shè)計方法,對整個系統(tǒng)進(jìn)行方案設(shè)計和功能劃分,系統(tǒng)的關(guān)鍵電路用一片或幾片專用集成電路(ASIC)實現(xiàn),然后采用硬件描述語言
23、(VHDL)完成系統(tǒng)行為級設(shè)計,最后通過綜合器和適配器生成最終的目標(biāo)器件。這樣的設(shè)計方法被稱為高層次的電子設(shè)計方法。具體介紹如下:</p><p> 2.1 傳統(tǒng)的數(shù)字系統(tǒng)設(shè)計方法和現(xiàn)代的數(shù)字系統(tǒng)設(shè)計方法比較</p><p> 傳統(tǒng)的數(shù)字系統(tǒng)設(shè)計方法:基于電路板的設(shè)計方法——采用固定功能的器件(通用型器件),通過設(shè)計電路板來實現(xiàn)系統(tǒng)功能,在系統(tǒng)硬件設(shè)計的后期進(jìn)行仿真和調(diào)試 </p
24、><p> 現(xiàn)代的數(shù)字系統(tǒng)設(shè)計方法:基于芯片——采用PLD,利用EDA開發(fā)工具,通過芯片設(shè)計來實現(xiàn)系統(tǒng)功能,在系統(tǒng)硬件設(shè)計的早期進(jìn)行仿真。此系統(tǒng)的設(shè)計就是采用的現(xiàn)代的數(shù)字系統(tǒng)設(shè)計方法——EDA的設(shè)計方法。兩種設(shè)計方法的具體步驟如下:</p><p> 圖2-1兩種設(shè)計方法的具體步驟</p><p> 其與傳統(tǒng)的設(shè)計方法的具體優(yōu)劣比較如下表:</p>
25、<p> 表2-1 傳統(tǒng)設(shè)計方法 vs EDA設(shè)計方法 </p><p> 由以上兩對比圖、表可知,智能搶答器的設(shè)計采用自頂向下的設(shè)計方法較優(yōu)。而傳統(tǒng)的電子設(shè)計的基本思路還是選擇標(biāo)準(zhǔn)集成電路"自底向上"(Bottom-Up)地構(gòu)造出一個新的系統(tǒng),這樣的設(shè)計方法就如同一磚一瓦地建造金字塔,不僅效率低、成本高而且還容易出錯。</p><p> 2.2 VHD
26、L硬件描述語言概述</p><p> 硬件描述語言(HDL-Hardware Description Language)是一種用于設(shè)計硬件電子系統(tǒng)的計算機(jī)語言,早期的硬件描述語言,如ABEL-HDL、AHDL,是由不同的EDA廠商開發(fā)的,互相不兼容,而且不支持多層次設(shè)計,層次間翻譯工作要由人工完成。為了克服以上缺陷,1985年美國國防部正式推出VHDL(Very High Speed IC Hardware D
27、escription Language)語言,1987年IEEE采納VHDL為硬件描述語言標(biāo)準(zhǔn)(IEEE STD-1076)。【2】</p><p> VHDL對系統(tǒng)進(jìn)行設(shè)計,可以在電子設(shè)計的各個階段、各個層次對于編輯好的程序,在Altera公司提供的QuartusII平臺上進(jìn)行編譯、仿真,然后通過時序圖可以看出了此編程是否符合預(yù)想的設(shè)計功能,如果不符合,在硬件測試前就可以及早發(fā)現(xiàn)各子模塊及系統(tǒng)中的錯誤,這樣的
28、設(shè)計特點無疑將提高系統(tǒng)設(shè)計的效率。</p><p> 除此之外,用VHDL進(jìn)行電子系統(tǒng)設(shè)計的一個很大的優(yōu)點是設(shè)計者可以專心致力于其功能的實現(xiàn),而不需要對不影響功能的與工藝有關(guān)的因素花費過多的時間和精力。</p><p> 2.3硬件平臺QuartusII概述</p><p> 2.3.1 Quartus II介紹</p><p> Q
29、uartus II是Altera 公司單芯片可編程系統(tǒng)(SOPC) 設(shè)計的綜合性環(huán)境,也是適合SOPC的最全面的設(shè)計環(huán)境。它擁有現(xiàn)場可編程門陣列(FPGA) 和復(fù)雜可編程邏輯器件(CPLD) 設(shè)計的所有階段的解決方案。Quartus II 設(shè)計軟件改進(jìn)了性能、提升了功能性、解決了潛在的設(shè)計延遲等,在工業(yè)領(lǐng)域率先提供FPGA與mask-programmed devices開發(fā)的統(tǒng)一工作流程。同時,Altera的Quartus II可編程邏
30、輯軟件還屬于第四代PLD開發(fā)平臺。該平臺支持一個工作組環(huán)境下的設(shè)計要求,其中包括支持VHDL、Verilog的設(shè)計流程,其內(nèi)部嵌有VHDL、Verilog邏輯綜合器。同樣,Quartus II具備仿真功能,同時也支持第三方的仿真工具。Quartus II支持層次化設(shè)計,可以在一個新的編輯輸入環(huán)境中對使用不同</p><p> 輸入設(shè)計方式完成的模塊進(jìn)行調(diào)用,從而解決了原理圖與HDL混合輸入設(shè)計的問題,并且在設(shè)計
31、輸入之后,Quartus II的編譯器將給出設(shè)計輸入的錯誤報告。</p><p> 2.3.2 Quartus II設(shè)計流程及注意事項</p><p> 基于 Quartus II的VHDL文本輸入設(shè)計流程如下圖所示:</p><p> 圖2-2基于 Quartus II的VHDL文本輸入設(shè)計流程</p><p> 由上圖可以看出,這
32、樣的設(shè)計方法對于電子設(shè)計的各個階段、各個層次的操作都在Altera公司提供的QuartusII平臺上進(jìn)行編譯、仿真測試,然后通過仿真時序圖可以看出了此編程是否符合預(yù)想的設(shè)計功能,如果不符合,在硬件測試前就可以及早發(fā)現(xiàn)各子模塊及系統(tǒng)中的錯誤,這樣的設(shè)計特點無疑將提高系統(tǒng)設(shè)計的效率。</p><p> 在設(shè)計實驗過程中有以下幾點需要注意:</p><p> 1.在編程時要注意信號與變量的區(qū)
33、別,并能正確定義和應(yīng)用。</p><p> 2.在創(chuàng)建工程時,要注意工程名和文件名和實體名要保持一致;</p><p> 3.設(shè)計結(jié)束時間時最好是時間周期的15倍,否則可能會出現(xiàn)時序圖圖像重疊不好識別的現(xiàn)象;</p><p> 4.仿真中,適當(dāng)進(jìn)制的轉(zhuǎn)換有時候可以更使觀察者更明顯地看出來時序圖的功能。</p><p> 2.3.3 Q
34、uartus II的設(shè)計優(yōu)勢應(yīng)用舉例</p><p> 隨著邏輯設(shè)計復(fù)雜性的不斷增加,僅依賴于軟件方式的仿真測試來了解設(shè)計系統(tǒng)的硬件功能已經(jīng)遠(yuǎn)遠(yuǎn)不夠了,而需要重復(fù)進(jìn)行硬件系統(tǒng)測試的測試也變得更為困難。嵌入式邏輯分析儀SignalTapII的使用就解決了這一問題。它可以隨設(shè)計文件一并下載于目標(biāo)芯片中,用以捕捉目標(biāo)芯片內(nèi)部系統(tǒng)信號節(jié)點處的信息或總線上的數(shù)據(jù)流,而又不影響原硬件系統(tǒng)的正常工作?!?】嵌入式邏輯分析儀S
35、ignalTapII有很多的優(yōu)點:(1)允許對設(shè)計層次的模塊的信號節(jié)點進(jìn)行測試,可以使用多時鐘驅(qū)動;(2)利用Signal Tap II成功的采集了FPGA內(nèi)部信號的波形,不占用額外的I/O引腳;(3)Signal Tap II為硬件板級調(diào)試工具,它采集的波形是工程下載后的實時波形,方便設(shè)計者查找引起設(shè)計缺陷的原因;(4)節(jié)約成本。Signal Tap II集成在Quartus II軟件中,無需另外付費;(5)能通過設(shè)置以確定前后觸發(fā)捕
36、捉信號信息的比例.</p><p> 除此之外,應(yīng)用Signal Tap II還能解決各種各樣的問題,如外部存儲器的雙向數(shù)據(jù)口的實時波形檢測、驅(qū)動模塊的并串轉(zhuǎn)換波形等。</p><p> 2.4 實驗開發(fā)系統(tǒng)及芯片簡述</p><p> 本設(shè)計采用的實驗箱為GW48-PK型EDA/SOC實驗開發(fā)系統(tǒng),選用的芯片為ALTERA公司的型號為EP1C3T144C8的
37、Cyclone系列芯片,該芯片是ALTERA推出的低價格、高容量的FPGA,其以較低的價格、優(yōu)良的特性以及豐富的片上資源在實際應(yīng)用中被廣泛的采用,這些都是其他同類產(chǎn)品無法相比的。</p><p> 這款芯片的資源利用率最佳為85%左右,QuartusⅡ軟件包的編程器是系統(tǒng)的核心,提供功能強(qiáng)大的設(shè)計處理,設(shè)計者可以添加特定的約束條件來提高芯片的利用率。 </p><p> 關(guān)于FPGA/
38、CPLD器件的配置:</p><p> 當(dāng)在Quartus Ⅱ中完成設(shè)計后,就應(yīng)當(dāng)將所設(shè)計的電路下載到CPLD芯片中,結(jié)合用戶系統(tǒng)進(jìn)行統(tǒng)一的調(diào)試。針對CPLD器件不同的內(nèi)部結(jié)構(gòu),Altera公司提供了不同的器件配置方式。Altera可編程邏輯器件的配置可通過編程器、JATG接口在線編程及Altera在線配置三種方式進(jìn)行?!?】</p><p> Altera器件編程的連接硬件包括Byt
39、eBlaster并口下載電纜,ByteBlasterMV并口下載電纜,MasterBlaster串行/USB 通信電纜,BitBlaster串口下載電纜。Altera公司提供的EPC1、EPC2、EPC16和EPC1441等PROM配置芯片。</p><p> ByteBlaster 并口下載電纜連接示意圖如下圖所示:</p><p> 圖2-3 ByteBlaster 并口下載電纜連
40、接示意圖</p><p> ByteBlaster并口下載電纜提供兩種下載模式:</p><p> ?。?)被動串行模式(PS模式)——用于配置FLEX 10K、FLEX 8000和FLEX 6000器件;</p><p> ?。?)JTAG模式——具有工業(yè)標(biāo)準(zhǔn)的JTAG邊界掃描測試電路(符合IEEE 1149.1:1990標(biāo)準(zhǔn)),用于配置FLEX 10K或?qū)A
41、X 9000、MAX 7000S和MAX 7000A器件進(jìn)行編程。</p><p> 3 智能搶答器系統(tǒng)的設(shè)計與實現(xiàn)</p><p> 3.1 搶答器系統(tǒng)設(shè)計要求 </p><p> 一般來說,設(shè)計一臺智能搶答器,必須能夠準(zhǔn)確判斷出第一位搶答者,并且通過數(shù)顯、蜂鳴這些途徑能讓人們很容易得知誰是搶答成功者,并設(shè)置一定的回答限制時間,讓搶答者在規(guī)定時間內(nèi)答
42、題,主持人根據(jù)答題結(jié)果實行增減分的操作,并將分?jǐn)?shù)顯示在屏幕上,評出最終贏家。所以我們在設(shè)計智能搶答器的模塊需要滿足鑒別、計時、計分、數(shù)顯等功能,具體設(shè)計要求如下:</p><p> ?。?)搶答器可容納四組選手,并為每組選手設(shè)置一個按鈕供搶答者使用;為主持人設(shè)置一個控制按鈕,用來控制系統(tǒng)清零(組別顯示數(shù)碼管滅燈)和搶答開始;</p><p> ?。?)電路具有對第一搶答信號的鎖存、鑒別和顯
43、示等功能。在主持人將系統(tǒng)復(fù)位并發(fā)出搶答指令后,蜂鳴器提示搶答開始,計時顯示器顯示初始時間并開始倒計時,若參賽選手按下?lián)尨鸢粹o,則該組別的信號立即被鎖存,并在組別顯示器上顯示該組別,同時揚(yáng)聲器也給出音響提示,此時,電路具備自鎖功能,使其他搶答按鈕不起作用。</p><p> ?。?)如果無人搶答,計時器倒計時到零,蜂鳴器有搶答失敗提示,主持人可以按復(fù)位鍵,開始新一輪的搶答。</p><p>
44、 ?。?)搶答器具有限時搶答的功能,且一次搶答的時間由主持人設(shè)定,本搶答時間設(shè)定為60秒。當(dāng)主持人啟動開始鍵后,要求計時器采用倒計時,同時最后十秒揚(yáng)聲器會發(fā)出聲響提示;</p><p> ?。?)參賽選手在設(shè)定的時間內(nèi)搶答,則搶答有效,定時器停止工作,主持人根據(jù)搶答結(jié)果給出分?jǐn)?shù),并由數(shù)碼管顯示選手的組別、搶答分?jǐn)?shù),并一直保持到主持人將系統(tǒng)清零為止。【6】</p><p> 3.2系統(tǒng)總體
45、設(shè)計思想</p><p> 本設(shè)計為四路智能搶答器,所以這種搶答器要求有四路不同組別的搶答輸入信號,并能識別最先搶答的信號,直觀地通過數(shù)顯和蜂鳴等方式顯示出組別;對回答問題所用的時間進(jìn)行計時、顯示、超時報警、預(yù)置答題時間,同時該系統(tǒng)還應(yīng)有復(fù)位、倒計時啟動功能。</p><p> 搶答過程:主持人按下系統(tǒng)復(fù)位鍵(RST),系統(tǒng)進(jìn)入搶答狀態(tài),計時模塊和計分模塊輸出初始信號給數(shù)碼顯示模塊并顯
46、示出初始值。當(dāng)某參賽組搶先將搶答鍵按下時,系統(tǒng)將其余三路搶答信號封鎖,同時揚(yáng)聲器發(fā)出聲音提示,組別顯示模塊送出信號給數(shù)碼顯示模塊,從而顯示出該搶答成功組臺號,并一直保持到下一輪主持人將系統(tǒng)清零為止。主持人對搶答結(jié)果進(jìn)行確認(rèn),隨后,計時模塊送出倒計時計數(shù)允許信號,開始回答問題,計時顯示器則從初始值開始以計時,在規(guī)定的時間內(nèi)根據(jù)答題的正誤來確定加分或減分,并通過數(shù)碼顯示模塊將成績顯示出來。計時至0時,停止計時,揚(yáng)聲器發(fā)出超時報警信號,以中止
47、未回答完問題。當(dāng)主持人給出倒計時停止信號時,揚(yáng)聲器停止鳴叫。若參賽者在規(guī)定時間內(nèi)回答完為題,主持人可給出倒計時計數(shù)停止信號,以免揚(yáng)聲器鳴叫。主持人按下復(fù)位鍵,即RST為高電平有效狀態(tài),清除前一次的搶答組別,又可開始新的一輪的搶答。</p><p> 此搶答器的設(shè)計中采用自頂向下的設(shè)計思路,運用VHDL硬件描述語言對各個模塊進(jìn)行層次化、系統(tǒng)化的描述,并且先設(shè)計一個頂層文件,再把各個模塊連接起來?!?】系統(tǒng)的總體框
48、圖如下:</p><p> 圖3-1系統(tǒng)的總體框圖</p><p> 3.3子模塊的設(shè)計思想和實現(xiàn)</p><p> 根據(jù)對搶答器的功能要求,把要設(shè)計的系統(tǒng)劃分為五個功能模塊:搶答信號鑒別模塊、計時模塊、計分模塊、數(shù)碼顯示模塊和揚(yáng)聲器控制電路,具體的說,顯示模塊又包含最先搶答的組別顯示電路、計時值顯示電路和計分顯示電路。計時模塊、計分模塊、數(shù)碼顯示模塊和揚(yáng)聲器
49、控制電路,具體的說,顯示模塊又包含最先搶答的組別顯示電路、計時值顯示電路和計分顯示電路?!?】</p><p> 3.3.1 鑒別模塊的設(shè)計與實現(xiàn)</p><p> 搶答鑒別模塊用來準(zhǔn)確直觀地判斷A、B、C、D四組搶答者誰最先按下按鈕,并為顯示端送出信號,通過數(shù)顯和蜂鳴等途徑使觀眾能夠清楚地知道是哪一組搶答成功,是整個系統(tǒng)的核心部分。同時組別顯示端為下一模塊輸入信號,以方便主持人為該組
50、搶答成功者進(jìn)行加減分的操作。</p><p> 搶答鑒別模塊的元件圖如下圖所示:</p><p> 圖3-2 鑒別模塊元件框圖</p><p><b> 引腳作用:</b></p><p> 輸入信號:各組的搶答按鈕A、B、C、D,系統(tǒng)清零信號INI。</p><p> 輸出信號: 各組
51、的搶答按鈕顯示端A1、B1、C1、D1,組別顯示端G[3..0]。</p><p> 原理:第一個按下鍵的小組,搶答信號判定電路LOCK通過緩沖輸出信號的反饋將本參賽組搶先按下按鍵的信號鎖存,并且以異步清零的方式將其他參賽組的鎖存器清零,組別顯示、計時和計分會保存到主持人對系統(tǒng)進(jìn)行清零操作時為止。當(dāng)INI=1時系統(tǒng)復(fù)位,使組別顯示信號G=0000,各組的指示燈信號A1=0,B1=0,C1=0,D1=0;當(dāng)INI
52、=0,即低電平有效,使其進(jìn)入搶答鑒別狀態(tài),到CLK的上升沿到來時,以A組搶答成功為例,當(dāng)輸入信號為A=1,B=0,C=0,D=0,輸出信號G=1000,A1=1,即為鑒別出A組搶答成功,同時屏蔽其他組的輸入信號,以免發(fā)生錯誤。同理其他組別搶答成功也是這樣的鑒別過程。【9】</p><p> 備注:理論上來說,A、B、C、D四組搶答,應(yīng)該有從0000—1111等16種可能情況,但是由于時鐘信號的頻率很高而且是在時
53、鐘信號上升沿的狀況下才做出的鑒別,所以在這里兩組以上同時搶答成功的可能性非常小,因此可以只設(shè)計四種情況,即A、B、C、D分別為1000、0100、0010、0001,這大大簡化了電路的設(shè)計復(fù)雜性。</p><p> 其用VHDL語言進(jìn)行編程的流程圖如下圖所示:</p><p> 圖3-3 搶答鑒別模塊的流程圖</p><p> 3.3.2 計時模塊的設(shè)計與實現(xiàn)
54、</p><p> 當(dāng)搶答鑒別模塊成功判別出最先按下?lián)尨鸢粹o的參賽組后,在成功鑒別出哪組最先搶答后,主持人按下計時信號,則進(jìn)入計時狀態(tài)。計時模塊可分作兩部分:(1)預(yù)置數(shù);(2)60秒倒計時。60秒時間用兩個數(shù)碼管QA,QB顯示,其中QA表示60秒的個位,QB表示60秒的十位。計時模塊開始工作從預(yù)置初始值開始以秒計時,計時至0秒時停止,時間耗盡時,揚(yáng)聲器會發(fā)出超時報警信號,以中止答題。</p>&
55、lt;p> 圖3-4 計時模塊的元件圖</p><p> 該系統(tǒng)輸入信號有:系統(tǒng)清零信號CLR,計時預(yù)置控制端LDN,計時使能端EN,系統(tǒng)時鐘信號CLK,計時預(yù)置數(shù)據(jù)調(diào)整按鈕TA、TB。系統(tǒng)輸出信號有:倒計時輸出端QA[3..0]、QB[3..0]。</p><p> 當(dāng)清零信號CLR=1時,模塊輸出信號QA=0000 ,QB=0000。當(dāng)預(yù)置數(shù)控制信號LDN=1可通過TA來調(diào)
56、整QA,TA來一次高電平,則QA的數(shù)值就加1;用TB來調(diào)整QB,通過這兩個調(diào)整信號可調(diào)整參賽者答題所需要的時間。在CLR=0,LDN=0,EN=1時,通過時鐘信號CLK的上升沿來進(jìn)行60秒到計時。【10】其用VHDL語言進(jìn)行編程的流程圖如下: </p><p> 圖3-5 搶答計時模塊的流程圖</p><p> 3.3.3 計分模塊的設(shè)計與實現(xiàn)</p><p
57、> 計分模塊的運行方式是按照十進(jìn)制進(jìn)行加減,即當(dāng)時鐘出現(xiàn)上升沿時就進(jìn)行加一或者減一的操作。</p><p> 記分模塊為哪組進(jìn)行記分取決于鑒別模塊的輸入信號G,當(dāng)G=1000時表示A組最先搶答,則在此模塊中為A組記分,當(dāng)G=0100時表示B組最先搶答,則在此模塊中為B組記分,當(dāng)G=0010時表示C組最先搶答,則在此模塊中為C組記分,當(dāng)G=0001時表示D組最先搶答,則在此模塊中為D組記分。</p&
58、gt;<p> 以A組為例來說明此模塊的設(shè)計,當(dāng)復(fù)位信號RST=1時,系統(tǒng)復(fù)位且A組的分值顯示初始值,為100分。當(dāng)RST=0時,如果該組選手答題正確,則主持人按下加分鍵,即ADD=1,此時對該組進(jìn)行加分操作;如果該組選手答題錯誤,則主持人按下減分鍵,即SUB=1,此時對該組進(jìn)行減分操作。</p><p> 計分模塊的元件圖如下圖所示:</p><p> 圖3-6 計分
59、模塊的元件圖</p><p> 系統(tǒng)的輸入信號有:計分復(fù)位端RST,加分按鈕端ADD,減分按鈕端SUB,組別號輸入端CHOS[3..0]。系統(tǒng)的輸出信號有:A組分?jǐn)?shù)輸出端AA2[3..0]、AA1[3..0]、AA0[3..0],B組分?jǐn)?shù)輸出端BB2[3..0]、BB1[3..0]、BB0[3..0],C組分?jǐn)?shù)輸出端CC2[3..0]、CC1[3..0]、CC0[3..0],D組分?jǐn)?shù)輸出端DD2[3..0]、D
60、D1[3..0]、DD0[3..0]。</p><p> 計分模塊用VHDL語言進(jìn)行編程的流程圖如下:</p><p> 圖3-7計分模塊的設(shè)計狀態(tài)圖</p><p> 注:在設(shè)計中減法的實現(xiàn)是以加法運算來實現(xiàn)的。也以A為例,由于每次減分都是減去10分,即每次為POINTS_A1減一,所以可以用POINTS_A1+ "1111"來實現(xiàn)。如:
61、0111-0001=0110,用加法實現(xiàn):0111+1111=10110。由于POINTS_A1: STD_LOGIC_VECTOR(3 DOWNTO 0),所以POINTS_A1=0110。</p><p> 3.3.4 譯碼顯示模塊的設(shè)計與實現(xiàn)</p><p> 該模塊實際上是一個譯碼器,作用是用來顯示組別,時間和成績,其主要原理是四位二進(jìn)制BCD編碼轉(zhuǎn)換成七段二進(jìn)制數(shù)字,以阿拉伯
62、數(shù)字的形式輸出在數(shù)碼管上,使觀眾能夠更直觀的看到結(jié)果。譯碼器的譯碼對照表3-1如下所示:</p><p> 表3-1 譯碼器的譯碼對照表</p><p> 備注 :在程序中只考慮0000-1001(即0-9)的情況,將其轉(zhuǎn)化為相應(yīng)的七段顯示器的碼子,其他情況不予考慮。</p><p> 3.3.5 搶答器的系統(tǒng)實現(xiàn)</p><p>
63、單獨模塊只有彼此聯(lián)系起來構(gòu)成一個完整的系統(tǒng),才能實現(xiàn)其功能,這個過程有兩種實現(xiàn)方法:①元件例化。也是用編程的方式將它們各個程序、信號、輸入輸出之間的關(guān)系用VHDL語言來敘述清楚,還關(guān)系到程序的調(diào)用問題,需要設(shè)計者思路清晰,設(shè)計合理;②元器件圖示連線。這種連線方法思路清晰可見,而且用的時候很簡單方便,出現(xiàn)錯誤也很好檢查。在設(shè)計中選擇的是這種方法。通過總的頂層元件圖可以很清晰的看到模塊連接的原理。</p><p>
64、 圖3-8 頂層元件圖 </p><p> 附表:輸入/輸出引腳的作用:</p><p> 表3-2 輸入/輸出引腳的作用</p><p> 注:本設(shè)計中,搶答器組別信號A、B、C、D為高電平時,其功能為有效狀態(tài)。同樣,系統(tǒng)清零信號CLR、預(yù)置及倒計時控制信號LDN,亦為高電平有效。當(dāng)CLR有效時,搶答信號判別電路清零,為判別優(yōu)先搶答信號做出準(zhǔn)備。當(dāng)計時
65、使能端EN為低電平,預(yù)置時間設(shè)置信號LDN=1時,通過計時預(yù)置數(shù)據(jù)調(diào)整按鈕TA、TB進(jìn)行預(yù)置數(shù)。當(dāng)計時使能端EN為高電平,有系統(tǒng)時鐘信號CLK時,進(jìn)行一分鐘倒計時。輸入時鐘CLK一方面作為揚(yáng)聲器控制電路的輸入信號,另一方面作為搶答信號判別電路中鎖存器時鐘,為使揚(yáng)聲器音調(diào)較為悅耳,且是搶答判別電路有較高的準(zhǔn)確度(對信號判別的最大誤差是一個時鐘周期),CLK信號頻率高低應(yīng)適中,可取500Hz-1KHz;同時CLK信號經(jīng)過分頻后向倒計時電路提
66、供信號。</p><p> 4 智能搶答器子模塊的仿真驗證</p><p> 4.1鑒別模塊的仿真驗證</p><p> 利用QuartusII進(jìn)行編譯,綜合,仿真,時序圖如下:</p><p> 圖4-1鑒別模塊的仿真時序圖</p><p><b> 引腳作用:</b></p&g
67、t;<p> 系統(tǒng)輸入信號:各組的搶答按鈕A、B、C、D,系統(tǒng)清零信號CLR,CLK時鐘信號。</p><p> 系統(tǒng)的輸出信號: 各組的搶答按鈕顯示端A1、B1、C1、D1,組別顯示端控制信號G[3..0]。</p><p><b> 仿真分析:</b></p><p> 當(dāng)鑒別模塊的清零信號CLR為高電平時,無論A、B
68、、C、D四組參賽者誰按下?lián)尨鸢粹o,系統(tǒng)輸出均為零,同時組別顯示端G輸出信號也顯示為零;當(dāng)清零信號CLR為低電平時,A、B、C、D四組參賽者誰先按下?lián)尨鸢粹o,組別顯示端就顯示該組別的號碼。假如C組按下?lián)尨鸢粹o時,組別輸出為0010,同時C組的顯示燈被點亮。仿真圖上顯示的為A先搶答,因為在0-1.28微秒之間A、C雖然都按搶答鍵,但CLR為有效狀態(tài),所以在此時間段內(nèi)的搶答無效。</p><p> 4.2計時模塊的仿
69、真驗證</p><p> 利用QuartusII進(jìn)行編譯,綜合,仿真,時序圖如下:</p><p> 圖4-2 計時模塊的仿真時序圖</p><p><b> 引腳作用:</b></p><p> 系統(tǒng)輸入信號:系統(tǒng)清零信號CLR,計時預(yù)置控制端LDN,計時使能端EN,系統(tǒng)時鐘信號CLK,計時預(yù)置數(shù)據(jù)調(diào)整按鈕TA
70、、TB。</p><p> 系統(tǒng)輸出信號:倒計時輸出端QA[3..0]、QB[3..0]。</p><p> 仿真分析:當(dāng)系統(tǒng)清零信號CLR=1時,計時器的時鐘信號回到計時預(yù)置倒計時起始狀態(tài),此時倒計時輸出端QA=0000,QB=0000.當(dāng)計時使能端EN=0,計時預(yù)置控制端LDN=1時,通過計時預(yù)置數(shù)據(jù)調(diào)整按鈕TA、TB進(jìn)行預(yù)制數(shù),并且通過TA,TB來調(diào)整QA,QB即當(dāng)TA=1時,則
71、QA的數(shù)值加1,當(dāng)TB=1時,則QB的數(shù)值也加1。當(dāng)計時使能端EN=1,系統(tǒng)清零信號CLR=0,并且計時預(yù)置控制端LDN=0時,通過時鐘信號上升沿CLK來進(jìn)行60秒倒計時。</p><p> 4.3計分模塊的仿真驗證</p><p> 利用QuartusII進(jìn)行編譯,綜合,仿真,時序圖如下:</p><p> 圖4-3 計分模塊的仿真時序圖</p>
72、<p><b> 引腳作用:</b></p><p> 系統(tǒng)的輸入信號有:計分復(fù)位端RST,加分按鈕端ADD,減分按鈕端SUB,組別號輸入端CHOS[3..0]。</p><p> 系統(tǒng)的輸出信號有:A組分?jǐn)?shù)輸出端AA2[3..0]、AA1[3..0]、AA0[3..0],B組分?jǐn)?shù)輸出端BB2[3..0]、BB1[3..0]、BB0[3..0],C
73、組分?jǐn)?shù)輸出端CC2[3..0]、CC1[3..0]、CC0[3..0],D組分?jǐn)?shù)輸出端DD2[3..0]、DD1[3..0]、DD0[3..0]。</p><p> 仿真分析:首先應(yīng)該清楚,在計分器電路的設(shè)計中,按十進(jìn)制進(jìn)行加減分操作的,當(dāng)出現(xiàn)時鐘信號上升沿CLK就可以完成對參賽者加減分操作。智能搶答器記分模塊的仿真時以加分操作為例。由仿真圖3-10可知以下情況:</p><p> ?。?/p>
74、1)系統(tǒng)設(shè)計過程中,當(dāng)計分復(fù)位端RST=1時,并且組別輸入信號CHOS=0000,其中的組別輸入信號是搶答鑒別模塊的輸出信號,計分器復(fù)位,此時以上四組都不會產(chǎn)生加減分操作。</p><p> (2)然而當(dāng)計分復(fù)位端RST=0時,此時計分器可以計分。當(dāng)CHOS=0001時,組別顯示為A組,此時主持人利用計分器對A組進(jìn)行加減分操作;當(dāng)CHOS=0010時,組別顯示為B組,此時主持人則利用計分器對B組進(jìn)行加減分操作;
75、當(dāng)CHOS=0100時,組別顯示為C組,此時系統(tǒng)對C組進(jìn)行加減分操作;當(dāng)CHOS=1000時,組別顯示為D組,此時對D組進(jìn)行加減分操作。由仿真圖可知,當(dāng)主持人按下系統(tǒng)復(fù)位鍵RST鍵時,使分?jǐn)?shù)復(fù)位,每位設(shè)置的初始分?jǐn)?shù)為100分。當(dāng)CHOS=1000時,即D搶答成功時,加分鍵ADD輸入四個脈沖,DD1加到4,說明加分成功,成績變?yōu)?40分。其他搶答者搶答成功后的加分操作與此相同。減分的仿真與此類似,因為是以加法實現(xiàn),本質(zhì)與加分相同,當(dāng)計分復(fù)
76、位端RST=0時,可以計分。由仿真圖可知,初始成績均為100分。當(dāng)CHOS=1000時,即D搶答成功時,減分鍵SUB輸入四個脈沖,DD1加到4,說明減分成功,成績變?yōu)?0分。其他搶答者搶答成功后的減分操作與此相同。</p><p> 4.4數(shù)顯模塊的仿真驗證</p><p> 利用QuartusII進(jìn)行編譯,綜合,仿真,時序圖如下:</p><p> 圖4-4
77、數(shù)顯模塊的仿真時序圖</p><p><b> 引腳作用:</b></p><p> 輸入信號:AIN4;</p><p> 輸出信號:DOUT7。</p><p><b> 仿真分析:</b></p><p> 當(dāng)AIN4= "0000" ,
78、DOUT7輸出"1111110",此時數(shù)碼管顯示0; </p><p> 當(dāng)AIN4= "0001" , DOUT7輸出"0110000",此時數(shù)碼管顯示1;</p><p> 當(dāng)AIN4= "0010" , DOUT7輸出"1101101",此時數(shù)碼管顯示2; </p>
79、<p> 當(dāng)AIN4= "0011" , DOUT7輸出"1111001",此時數(shù)碼管顯示3; </p><p> 當(dāng)AIN4= "0100" , DOUT7輸出"0110011",此時數(shù)碼管顯示4; </p><p> 當(dāng)AIN4= "0101" , DOUT7輸出&quo
80、t;1011011",此時數(shù)碼管顯示5;</p><p> 當(dāng)AIN4= "0110" , DOUT7輸出"1011111",此時數(shù)碼管顯示6;</p><p> 當(dāng)AIN4= "0111" , DOUT7輸出"1110000",此時數(shù)碼管顯示7;</p><p> 當(dāng)A
81、IN4= "1000" , DOUT7輸出"1111111",此時數(shù)碼管顯示8;</p><p> 當(dāng)AIN4= "1001" , DOUT7輸出"1111011",此時數(shù)碼管顯示9;</p><p><b> 結(jié)束語</b></p><p> 本文主要介紹了
82、利用VHDL語言設(shè)計智能搶答器的詳細(xì)流程,并橫向介紹了一些關(guān)于此設(shè)計的背景知識,比如EDA的應(yīng)用、QutartusrⅡ設(shè)計流程等等。在設(shè)計的過程中,文章通過對比傳統(tǒng)的自底向上的設(shè)計方法和和現(xiàn)代EDA的自頂向下的設(shè)計方法,突出了EDA設(shè)計方法的優(yōu)越性。</p><p> 在這次設(shè)計中,我們也遇到了一些問題,比如設(shè)置輸入信號不合適時,時序圖也會出現(xiàn)一些毛刺現(xiàn)象。同時,我也發(fā)現(xiàn)了自己的許多不足。首先,最初開發(fā)時,對系
83、統(tǒng)沒有一個完整的思路,考慮不是很全面,所以系統(tǒng)功能設(shè)計時,碰到不少困難,也耽擱了不少時間。其次,我發(fā)現(xiàn)自己對于書本上的很多知識還不夠熟悉,對開發(fā)工具的掌握還不算很全面,有很多我們需要掌握的知識還沒掌握,所以在設(shè)計編程、編譯以及仿真過程中走了不少彎路。再次,在論文的整理過程中,我對word文檔的操作技能不是很嫻熟,所以在以后的學(xué)習(xí)生活中,我會努力并盡量彌補(bǔ)我所缺少的一些相關(guān)知識,不斷提高自己的操作能力。</p><p&
84、gt;<b> 致 謝</b></p><p> 本論文的工作是在我的導(dǎo)師陳楊教授的悉心指導(dǎo)下完成的。在整個畢業(yè)設(shè)計過程中,陳楊老師不斷引導(dǎo)我們,幫助我們梳理論文思路,耐心地給我解釋一些細(xì)節(jié)上的、我不理解的問題,并提出一些新的問題,使得我對畢業(yè)設(shè)計課題能夠有更深入的思考,幫助我順利完成畢業(yè)設(shè)計和論文。在此謹(jǐn)向陳老師致以誠摯的謝意和崇高的敬意。</p><p>
85、 在此,我還要感謝董碩、沈娟等同學(xué)對我的幫助,這段時間我們之間的相互協(xié)作,不僅促進(jìn)了畢設(shè)的順利完成,同時也增進(jìn)我們之間的友誼 。</p><p> 最后,感謝所有支持過我、幫助過我的老師、朋友和同學(xué)們,祝愿大家都會有一個美好而又光明的未來。</p><p><b> 參考文獻(xiàn)</b></p><p> [1] 漢澤西.EDA技術(shù)與應(yīng)用【M
86、】.北京:北京航空航天大學(xué)出版社,2004</p><p> [2] 侯伯亨,顧新. VHDL硬件描述語言與數(shù)字邏輯電路設(shè)計.西安:西安電子科技大學(xué)出版社,1997</p><p> [3] 黃任.編著VHDL入門、解惑、經(jīng)典實例、經(jīng)驗總結(jié).北京:北京航空航天大學(xué)出版社,2005</p><p> [4] 羅朝霞,高書莉.CPLD/FPGA設(shè)計及應(yīng)用.北京:人
87、民郵電出版社, 2007.7.</p><p> [5] 陳云恰,保延翔.CPLD應(yīng)用技術(shù)與數(shù)字系統(tǒng)統(tǒng)計.電子工業(yè)出版社, 2006.</p><p> [6] 李偉英,謝完成.基于EDA技術(shù)的搶答器的設(shè)計與實現(xiàn)【J】.科學(xué)技術(shù)與實現(xiàn), 2008.8(11).</p><p> [7]譚會生,瞿遂存.EDA技術(shù)綜合應(yīng)用實例與分析【M】.西安:西安電子科技大學(xué)出
88、版社, 2004.</p><p> [8]姜雪松,吳鈺淳.VHDL設(shè)計實例與仿真.機(jī)械工業(yè)出版社, 2007.</p><p> [9]Altera Corporation.Altera Digital Library.Altera,2002.</p><p> [10](美) Stephen Brown , Zvonko Vranesic 編著.Funda
89、mengtals of Digital Logic with VHDL Design.McGraw—Hill Education(Asia),2002.8.</p><p><b> 附 錄</b></p><p> 附錄1 搶答鑒別模塊VHDL程序(QDJB.VHD)</p><p> LIBRARY IEEE; </p>
90、<p> USE IEEE.STD_LOGIC_1164.ALL; </p><p> ENTITY QDJB IS</p><p> PORT (CLR: IN STD_LOGIC;</p><p> CLK: IN STD_LOGIC;</p><p> A, B, C, D: IN STD_LOGIC; &
91、lt;/p><p> A1, B1, C1, D1: OUT STD_LOGIC; </p><p> G: OUT STD_LOGIC_VECTOR (3 DOWNTO 0)); </p><p> END QDJB; </p><p> ARCHITECTURE ART OF QDJB IS</p><p>
92、 CONSTANT W1: STD_LOGIC_VECTOR:="0001"; </p><p> CONSTANT W2: STD_LOGIC_VECTOR:="0010"; </p><p> CONSTANT W3: STD_LOGIC_VECTOR:="0100"; </p><p> CO
93、NSTANT W4: STD_LOGIC_VECTOR:="1000"; </p><p><b> BEGIN</b></p><p> PROCESS (CLR, A, B, C, D)</p><p><b> BEGIN</b></p><p> IF CLR=&
94、#39;1' THEN G<="0000"; </p><p> ELSIF (A='1'AND B='0'AND C='0'AND D='0') THEN</p><p> A1<='1'; B1<='0'; C1<='0'
95、;; D1<='0'; G<=W1; </p><p> ELSIF (A='0'AND B='1'AND C='0'AND D='0') THEN</p><p> A1<='0'; B1<='1'; C1<='0'; D1&l
96、t;='0'; G<=W2; </p><p> ELSIF (A='0'AND B='0'AND C='1'AND D='0') THEN</p><p> A1<='0'; B1 <='0'; C1<='1'; D1<=
97、9;0'; G<=W3; </p><p> ELSIF (A='0'AND B='0'AND C='0'AND D='1') THEN</p><p> A1<='0'; B1 <='0'; C1<='0'; D1<='1
98、9;; G<=W4; </p><p><b> END IF; </b></p><p> END PROCESS; </p><p><b> END ART;</b></p><p> 附錄2 搶答計時模塊VHDL程序(JSQ.VHD)</p><p>
99、 LIBRARY IEEE; </p><p> USE IEEE.STD_LOGIC_1164.ALL; </p><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL; </p><p> ENTITY JSQ IS</p><p> PORT (CLR, LDN, EN, CLK: IN STD_LOGIC;
100、 </p><p> TA, TB: IN STD_LOGIC; </p><p> QA: OUT STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p> QB: OUT STD_LOGIC_VECTOR (3 DOWNTO 0)); </p><p><b> END JSQ; </b&g
101、t;</p><p> ARCHITECTURE ART OF JSQ IS</p><p> SIGNAL DA: STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p> SIGNAL DB: STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p><b> BEGIN
102、</b></p><p> PROCESS (TA,TB,CLR) </p><p><b> BEGIN</b></p><p> IF CLR='1' THEN</p><p> DA<="0000"; </p><p>
103、DB<="0000"; </p><p><b> ELSE</b></p><p> IF TA='1' THEN</p><p> DA<=DA+"0001" ; </p><p><b> END IF; </b>&
104、lt;/p><p> IF TB='1' THEN</p><p> DB<=DB+"0001"; </p><p><b> END IF; </b></p><p><b> END IF; </b></p><p> EN
105、D PROCESS; </p><p> PROCESS (CLK)</p><p> VARIABLE TMPA: STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p> VARIABLE TMPB: STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p><b> BEG
106、IN</b></p><p> IF CLR='1' THEN TMPA:="0000"; TMPB:="0110"; </p><p> ELSIF CLK'EVENT AND CLK='1' THEN</p><p> IF LDN='1' THEN
107、</p><p> TMPA:=DA;TMPB:=DB; </p><p> ELSIF EN='1' THEN</p><p> IF TMPA="0000" THEN</p><p> TMPA:="1001"; </p><p> IF TMPB=
108、"0000" THEN </p><p> TMPB:="0110"; </p><p> ELSE TMPB:=TMPB-"0001"; </p><p><b> END IF; </b></p><p> ELSE TMPA:=TMPA-"
109、;0001";</p><p><b> END IF; </b></p><p><b> END IF; </b></p><p><b> END IF; </b></p><p> QA<=TMPA; QB<=TMPB; </p>
110、;<p> END PROCESS; </p><p><b> END ART;</b></p><p> 附錄3 搶答計分模塊VHDL程序(JFQ.VHD)</p><p> LIBRARY IEEE; </p><p> USE IEEE.STD_LOGIC_1164.ALL; </p
111、><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL; </p><p> ENTITY JFQ IS</p><p> PORT (RST: IN STD_LOGIC; </p><p> ADD: IN STD_LOGIC;</p><p> SUB: IN STD_LOGIC;<
112、/p><p> CHOS: IN STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p> AA2, AA1, AA0, BB2, BB1, BB0: OUT STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p> CC2, CC1, CC0, DD2, DD1, DD0: OUT STD_LOGIC_VECTOR
113、 (3 DOWNTO 0)); </p><p><b> END JFQ; </b></p><p> ARCHITECTURE ART OF JFQ IS</p><p><b> BEGIN</b></p><p> PROCESS (RST, ADD, SUB,CHOS)</p
114、><p> VARIABLE POINTS_A2, POINTS_A1: STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p> VARIABLE POINTS_B2, POINTS_B1: STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p> VARIABLE POINTS_C2, POINTS_C1: ST
115、D_LOGIC_VECTOR (3 DOWNTO 0); </p><p> VARIABLE POINTS_D2, POINTS_D1: STD_LOGIC_VECTOR (3 DOWNTO 0); </p><p><b> BEGIN</b></p><p> IF ADD='1' THEN</p>&
116、lt;p> IF RST='1' THEN</p><p> POINTS_A2:="0001"; POINTS_A1:="0000"; </p><p> POINTS_B2:="0001"; POINTS_B1:="0000"; </p><p> PO
溫馨提示
- 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 八路搶答器eda課程設(shè)計vhdl
- 基于vhdl計時搶答器設(shè)計
- eda課程設(shè)計-搶答器
- eda課程設(shè)計---搶答器
- vhdl8路搶答器課程設(shè)計--基于vhdl語言的8路搶答器設(shè)計
- vhdl8路搶答器課程設(shè)計--基于vhdl語言的8路搶答器設(shè)計
- eda課程設(shè)計---競賽搶答器
- eda數(shù)字搶答器課程設(shè)計
- eda課程設(shè)計---競賽搶答器
- eda數(shù)字搶答器課程設(shè)計
- eda畢業(yè)課程設(shè)計--搶答器
- eda課程設(shè)計報告--eda數(shù)字搶答器
- 課程設(shè)計---基于vhdl語言的8路搶答器設(shè)計
- eda課程設(shè)計—四路搶答器
- 四路搶答器eda課程設(shè)計
- 智能搶答器課程設(shè)計
- 四路搶答器eda課程設(shè)計
- 智能搶答器課程設(shè)計
- 八路搶答器eda課程設(shè)計
- 八路搶答器-eda課程設(shè)計
評論
0/150
提交評論