版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p><b> 數(shù)字式競賽搶答器</b></p><p> 摘要:搶答器是為智力競賽參賽者答題時進行搶答而設(shè)計的一種優(yōu)先判決器電路,競賽者可以分為若干組,搶答時各組對主持人提出的問題要在最短的時間內(nèi)做出判斷,并按下?lián)尨鸢存I回答問題。當(dāng)?shù)谝粋€人按下按鍵后,則在顯示器上顯示該組的號碼,對應(yīng)的燈亮,同時電路將其他各組按鍵封鎖,使其不起作用。若搶答時間內(nèi)無人搶答,則報警燈亮?;卮鹜陠?/p>
2、題后,由主持人將所有按鍵恢復(fù),重新開始下一輪搶答。</p><p> 此次課程設(shè)計的內(nèi)容是設(shè)計一個可容納四組參賽者同時搶答的數(shù)字搶答器,可判斷第一搶答者并報警指示搶答成功,其他組搶答均無效。若提前搶答則對相應(yīng)搶答組發(fā)出警報。給出系統(tǒng)總體組成框圖,設(shè)計思路,完成以上模塊的VHDL實現(xiàn)及功能仿真,頂層文件及整體仿真。</p><p> 關(guān)鍵詞: VHDL ;搶答器 ;設(shè)計仿真</p&
3、gt;<p><b> 目 錄</b></p><p> 1 搶答器的設(shè)計要求1</p><p> 2 搶答器的設(shè)計分析1</p><p> 3 搶答器的搶答鑒別模塊1</p><p> 3.1 搶答鑒別模塊的功能1</p><p> 3.2 搶答鑒別模塊的源
4、程序2</p><p> 3.3 搶答鑒別模塊的時序仿真圖4</p><p> 4 搶答器的搶答計時模塊4</p><p> 4.1 搶答計時模塊的功能4</p><p> 4.2 搶答計時模塊的源程序5</p><p> 4.3 搶答計時模塊的時序仿真圖7</p><p>
5、; 5 搶答器的譯碼顯示模塊7</p><p> 5.1 譯碼顯示模塊的功能7</p><p> 5.2 譯碼顯示模塊的源程序8</p><p> 5.3 譯碼顯示模塊的時序仿真圖9</p><p> 6 搶答器的其他功能模塊9</p><p> 6.1 犯規(guī)功能模塊9</p>&
6、lt;p> 6.2 犯規(guī)功能模塊的源程序10</p><p> 6.3 犯規(guī)功能模塊的時序仿真圖11</p><p> 7 搶答器的頂層原理圖設(shè)計12</p><p> 7.1 頂層原理圖的源文件12</p><p> 7.2 頂層原理圖的時序仿真圖13</p><p> 8 課程設(shè)計的總結(jié)
7、14</p><p><b> 參考文獻14</b></p><p> 1 搶答器的設(shè)計要求</p><p> 設(shè)計一個可容納四組參賽者同時搶答的數(shù)字搶答器,可判斷第一搶答者并報警指示搶答成功,其他組搶答均無效。若提前搶答則對相應(yīng)搶答組發(fā)出警報。</p><p> 給出系統(tǒng)總體組成框圖,設(shè)計思路,完成以上模
8、塊的VHDL實現(xiàn)及功能仿真,頂層文件及整體仿真。</p><p> 2 搶答器的設(shè)計分析</p><p> 系統(tǒng)設(shè)計方案:整個系統(tǒng)至少有兩個主要模塊——搶答鑒別模塊、搶答計時模塊;其他功能模塊(犯規(guī)警告模塊,輸出顯示模塊)。</p><p> 按照要求,我們可以將整個系統(tǒng)分為四個主要模塊:搶答鑒別模塊;搶答計時模塊;犯規(guī)功能模塊;譯碼顯示模塊。</p&g
9、t;<p> 3 搶答器的搶答鑒別模塊</p><p> 3.1 搶答鑒別模塊的功能 </p><p> 該模塊主要實現(xiàn)搶答過程中的搶答功能,并能對超前搶答進行警告,還能記錄無論是正常搶答還是朝前搶答者的臺號,并且能實現(xiàn)當(dāng)有一路搶答按鍵按下時,該路搶答信號將其余的搶答信號封鎖的功能,并有四個搶答信號s0、s1、s2、s3;搶答狀態(tài)顯示信號states;搶答與警報時鐘信號
10、clk2;系統(tǒng)復(fù)位信號rst;警報信號warm。</p><p> 圖3-1 搶答器鑒別元件圖</p><p> Figure 3-1 responder identification component diagram</p><p> 3.2 搶答鑒別模塊的源程序</p><p> library ieee;</p>
11、<p> use ieee.std_logic_1164.all;use ieee.std_logic_unsigned.all;</p><p> entity jianbei is </p><p> port(rst,clk2:in std_logic;</p><p> s0,s1,s2,s3:in std_logic;</p&g
12、t;<p> states:buffer std_logic_vector(3 downto 0);</p><p> light:buffer std_logic_vector(3 downto 0);</p><p> warm:out std_logic);</p><p> end jianbei ;</p><p&
13、gt; architecture one of jianbei is </p><p> signal st:std_logic_vector(3 downto 0);</p><p><b> begin</b></p><p> p1:process(s0,rst,s1,s2,s3,clk2)</p><p&
14、gt;<b> begin</b></p><p> if rst='0' then </p><p> warm<='0';st<="0000";</p><p> elsif clk2'event and clk2='1' then </
15、p><p> if (s0='1' or st(0)='1')and not( st(1)='1' or st(2)='1' or st(3)='1' ) </p><p> then st(0)<='1';</p><p><b> end if ;&
16、lt;/b></p><p> if (s1='1' or st(1)='1')and not( st(0)='1' or st(2)='1' or st(3)='1' ) </p><p> then st(1)<='1';</p><p><b&
17、gt; end if ;</b></p><p> if (s2='1' or st(2)='1')and not( st(0)='1' or st(1)='1' or st(3)='1' ) </p><p> then st(2)<='1';</p>&
18、lt;p><b> end if ;</b></p><p> if (s3='1' or st(3)='1')and not( st(0)='1' or st(1)='1' or st(2)='1' ) </p><p> then st(3)<='1'
19、;</p><p><b> end if ;</b></p><p> warm<=st(0) or st(1) or st(2) or st(3);</p><p><b> end if ;</b></p><p> end process p1;</p><
20、p> p2:process(states(0),states(1),states(2),states(3),light)</p><p><b> begin</b></p><p> if (st="0000") then states<="0000"; </p><p>
21、elsif (st<="0001") then states<="0001";</p><p> elsif (st<="0010") then states<="0010"; </p><p> elsif (st<="0100") then stat
22、es<="0011";</p><p> elsif (st<="1000") then states<="0100"; </p><p> end if; </p><p> light<=st;</p&
23、gt;<p> end process p2;</p><p><b> end one;</b></p><p> 3.3 搶答鑒別模塊的時序仿真圖</p><p> 圖 3-2搶答鑒別模塊的時序仿真圖</p><p> Figure 3-2 vies to answer first ident
24、ify module timing simulation diagram</p><p> 搶答時需要一個允許開始搶答信號,設(shè)為states,該信號輸入后,指示燈亮,信號為light,提示選手開始搶答,為了鑒別搶答者,設(shè)置s0,s1,s2,s3為了使系統(tǒng)重新進入搶答狀態(tài),還需要一個復(fù)位信號,設(shè)置為rst。</p><p> 在圖中可以看出,s0的速度最快,但明顯有一點搶先,緊隨其后的依
25、次是s1,s2,s3,這3人均沒有搶先,而且可以看出,搶答開始后,燈light[1]亮。</p><p> 4 搶答器的搶答計時模塊 </p><p> 4.1 搶答計時模塊的功能</p><p> 該模塊主要實現(xiàn)搶答過程中的計時功能,在有搶答開始后進行20秒的倒計時,并且在20秒倒計時后無人搶答顯示超時并報警,搶答時鐘信號clk1;系統(tǒng)復(fù)位信號rst;搶答
26、使能信號start;無人搶答警報信號warn;計時中止信號stop;計時十位和個位信號tb,ta。</p><p> 圖4-1 搶答計時元件圖</p><p> Figure 4-1 figure vies to answer first time components</p><p> 4.2 搶答計時模塊的源程序</p><p>
27、 library ieee; </p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity js is </p><p> port(clk1,rst,start,stop:in std_logic;
28、</p><p> ta,tb:buffer std_logic_vector(3 downto 0));</p><p><b> End js;</b></p><p> architecture one of js is </p><p> signal co:std_logic;</p>
29、<p><b> begin</b></p><p> p1:process(clk1,rst,start,stop,ta)</p><p><b> begin</b></p><p> if rst='0' or stop='1' then</p>&l
30、t;p> ta<="0000";</p><p> elsif clk1'event and clk1='1' then</p><p><b> co<='0';</b></p><p> if start='1' then</p>
31、;<p> if ta="0000" then</p><p> ta<="1001";co<='1';</p><p> else ta<=ta-1;</p><p><b> end if; </b></p><p>&l
32、t;b> end if;</b></p><p><b> end if;</b></p><p> end process p1;</p><p> p2:process(co,rst,start,stop,tb)</p><p><b> begin</b></
33、p><p> if rst='0' or stop='1' then</p><p> tb<="0010";</p><p> elsif co'event and co='1' then</p><p> if start='1' the
34、n</p><p> if tb="0000" then tb<="0011"; </p><p> else tb<=tb-1;</p><p><b> end if;</b></p><p><b> end if;</b></
35、p><p><b> end if;</b></p><p> end process p2;</p><p><b> end one ;</b></p><p> 4.3 搶答計時模塊的時序仿真圖 </p><p> 圖 4-2搶答計時模塊時序仿真
36、圖</p><p> Figure 4-2 vies to answer first timer module timing simulation diagram</p><p> 計時信號設(shè)為十位和個位信號tb,ta 以及搶答時鐘信號clk1;系統(tǒng)復(fù)位信號rst;搶答使能信號start;無人搶答警報信號warn;計時中止信號stop。</p><p> 從圖
37、中可以看出,每10個ta使tb改變1,stop時停止計時。</p><p> 5 搶答器的譯碼顯示模塊</p><p> 5.1 譯碼顯示模塊的功能</p><p> 該模塊中主要實現(xiàn)搶答過程中將BCD碼轉(zhuǎn)換成7段的功能。</p><p> 圖5-1 譯碼顯示元件圖</p><p> Figure 5 - 1
38、 decoding display component in figure </p><p> 5.2 譯碼顯示模塊的源程序</p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> entity ym is</p><p>
39、 port(bcd: in std_logic_vector(3 downto 0);</p><p> dout: out std_logic_vector(6 downto 0));</p><p><b> end ym ;</b></p><p> architecture rtl of ym is</p>
40、<p><b> begin</b></p><p> process(bcd)</p><p><b> begin</b></p><p> case bcd is</p><p> when "0000"=>dout<="100
41、0000";</p><p> when"0001"=>dout<="1111001";</p><p> when"0010"=>dout<="0100100";</p><p> when "0011"=>dout&l
42、t;="0110000";</p><p> when "0100"=>dout<="0011001";</p><p> when "0101"=>dout<="0010010";</p><p> when "0110&qu
43、ot;=>dout<="0000010";</p><p> when "0111"=>dout<="1111000";</p><p> when "1000"=>dout<="0000000";</p><p> when
44、 "1001"=>dout<="0010000";</p><p> when others=>dout<="1111111";</p><p> end case;</p><p> end process; </p><p><b&g
45、t; end rtl;</b></p><p> 5.3 譯碼顯示模塊的時序仿真圖</p><p> 圖 5-2譯碼顯示模塊時序仿真圖</p><p> Figure 5-2 decoding display module timing simulation diagram</p><p> 6 搶答器的其他功能模塊&
46、lt;/p><p> 6.1 犯規(guī)功能模塊</p><p> 該模塊主要實現(xiàn)搶答過程中的報警功能,當(dāng)主持人按下控制鍵,有限時間內(nèi),人搶答或是計數(shù)到時蜂鳴器開始報警,計數(shù)停止信號stop;狀態(tài)輸出信號alm;計數(shù)脈沖clk。</p><p> 圖6-1 犯規(guī)功能元件圖</p><p> Figure 5-1 foul function co
47、mponent diagram</p><p> 6.2 犯規(guī)功能模塊的源程序</p><p> library ieee; </p><p> use ieee.std_logic_1164.all; </p><p> entity shengyin is </p><p> port(rst:in s
48、td_logic;</p><p> warn:in std_logic;</p><p> clk:in std_logic;</p><p> ta,tb:in integer range 0 to 9;</p><p> stop:in std_logic;</p><p> alm:out std_l
49、ogic );</p><p><b> end;</b></p><p> architecture bhv of shengyin is</p><p><b> begin</b></p><p> process(warn,ta,tb,stop,clk)</p><
50、;p><b> begin</b></p><p> if rst='0'then</p><p><b> alm<='0';</b></p><p> elsif stop='1'then</p><p><b>
51、alm<='0';</b></p><p> elsif ta=0 and tb=0 then</p><p><b> alm<=clk;</b></p><p> elsif warn='1'then</p><p><b> alm<=
52、clk;</b></p><p> else alm<='0';</p><p><b> end if;</b></p><p> end process;</p><p><b> end; </b></p><p> 6.3
53、 犯規(guī)功能模塊的時序仿真圖</p><p> 圖 6-2犯規(guī)功能模塊時序仿真圖</p><p> Figure 6-2 fouls function module timing simulation diagram</p><p> 當(dāng)主持人按下控制鍵,有限時間內(nèi)無人搶答或是計數(shù)到時蜂鳴器開始報警,計數(shù)停止信號stop;狀態(tài)輸出信號alm;計數(shù)脈沖clk。&l
54、t;/p><p> 7 搶答器的頂層原理圖設(shè)計</p><p> 7.1 頂層原理圖的源文件</p><p> 圖 7-1頂層原理圖</p><p> Figure 7-1 the top principle diagram</p><p> 7.2 頂層原理圖的時序仿真圖</p><p>
55、; 圖 7-2頂層時序仿真圖</p><p> Figure 7-2 top timing simulation diagram</p><p> 頂層模塊是以上幾個模塊綜合起來,并且實現(xiàn)整個系統(tǒng)的功能。由圖可以看出,當(dāng)搶答開始后,如果限制時間,即20s內(nèi)無人搶答,則輸出超時報警信號。超前搶答時,也會報警。</p><p> 如圖,s0明顯有些搶先,雖然他的
56、速度最快,然后依次是s2,s1,s3,所以s2才是有效的最快搶答成功者,并且可以看到,燈在選手搶答時亮起,聲音信號也在搶答時響起。</p><p><b> 8 課程設(shè)計的總結(jié)</b></p><p> 本次的EDA課程設(shè)計雖然只有短暫的一周時間,但是通過實踐,使我對EDA技術(shù)有了更進一步的了解。同時,大致懂得了一個課題制作的具體流程和實施方法。另外,課程設(shè)計對Q
57、uartusⅡ軟件的使用要求較高,從而使我能較為熟練的運用此軟件。在設(shè)計時,采用模塊化的設(shè)計思路使得問題變的簡單明了,大大縮短了時間,降低了發(fā)生錯誤的機侓,也便于修改和更新。</p><p> 課程設(shè)計中,需要找很多資料,在當(dāng)今的信息化環(huán)境中,雖然資料很多,但需要仔細斟酌才能找到所要的。這次的課程設(shè)計很好的鍛煉了這種能力。此外,與同學(xué)和老師的交流必不可少,我從中也學(xué)到了不少東西。</p><
58、p> 課程設(shè)計是一次很好的鍛煉機會,我從中學(xué)的很多知識對將來的學(xué)習(xí)和工作都有很大的幫助。</p><p><b> 參考文獻</b></p><p> [1]潘松,黃繼業(yè).EDA技術(shù)與VHDL(第3版).清華大學(xué)出版社.2009.</p><p> [2]馬建國,孟憲元.FPGA現(xiàn)代數(shù)字系統(tǒng)設(shè)計.清華大學(xué)出版社.2010.<
溫馨提示
- 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)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- eda課程設(shè)計--數(shù)字式競賽搶答器設(shè)計
- 數(shù)字式搶答器課程設(shè)計--數(shù)字式競賽搶答器
- 數(shù)字式競賽搶答器課程設(shè)計
- 數(shù)電課程設(shè)計---數(shù)字式競賽搶答器
- 數(shù)字邏輯課程設(shè)計報告--數(shù)字式競賽搶答器
- eda課程設(shè)計---競賽搶答器
- 數(shù)字式競賽搶答器 數(shù)電課程設(shè)計報告
- eda課程設(shè)計---競賽搶答器
- eda數(shù)字搶答器課程設(shè)計
- 數(shù)字式搶答器課程設(shè)計報告
- 數(shù)字邏輯課程設(shè)計--數(shù)字式搶答器
- 微機原理課程設(shè)計報告--數(shù)字式競賽搶答器
- 數(shù)電課程設(shè)計報告---數(shù)字式競賽搶答器
- eda數(shù)字搶答器課程設(shè)計
- eda課程設(shè)計報告--eda數(shù)字搶答器
- 微機課程設(shè)計--數(shù)字式八位競賽搶答器
- eda課程設(shè)計-搶答器
- eda課程設(shè)計---搶答器
- eda課程設(shè)計報告--智力競賽搶答器
- 數(shù)字式競賽搶答器設(shè)計【帶ewb文件】
評論
0/150
提交評論