版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 數(shù)字電路課程設(shè)計(jì)</b></p><p><b> 設(shè)計(jì)任務(wù)</b></p><p> 在許多比賽活動(dòng)中,為了準(zhǔn)確、公正、直觀地判斷出第一搶答者,通常設(shè)置一臺(tái)搶答器。通過搶答器的數(shù)顯、燈光和音響等手段指示出第一搶答者。同時(shí),還可以設(shè)置定時(shí)、記分、犯規(guī)及獎(jiǎng)懲記錄等多種功能。</p><p>
2、<b> 基本要求:</b></p><p> 設(shè)計(jì)制作一個(gè)可容納8個(gè)組別參賽的搶答器,每組控制一個(gè)搶答開關(guān),分別為S0、S1、S2、S3、S4、S5、S6、S7。</p><p> 設(shè)置主持人控制鍵:reset是用于控制整個(gè)系統(tǒng)清零的按鈕;restart是開始新一輪搶答;begin是用于發(fā)布搶答開始命令的按鈕。同時(shí)設(shè)置搶答定時(shí)電路,且計(jì)時(shí)起點(diǎn)與搶答命令J1同步
3、,計(jì)時(shí)終點(diǎn)是第一個(gè)搶答者的搶答信號(hào)到來,超時(shí)面無人搶答則題目作廢。</p><p> 系統(tǒng)具有第一搶答信號(hào)鑒別和鎖在功能。在主持人發(fā)布搶答命令之后,第一搶答者按下?lián)尨鸢粹o后,電路應(yīng)記憶下第一搶答者的組別,并封鎖其他各組的按鈕,即其他任何一組按鍵都不會(huì)使電路響應(yīng)。</p><p> 系統(tǒng)以三種方式指示第一搶答者:其一是點(diǎn)亮發(fā)光二級(jí)管LED,表示各組的發(fā)光二級(jí)管分別為L0、L1、L2……L
4、7;其二是LCD顯示TEAM:隊(duì)伍編號(hào);其三是在第一搶答者產(chǎn)生時(shí),揚(yáng)聲器以“嘀—嘟”雙頻音響持續(xù)響1s。</p><p><b> 擴(kuò)展功能:</b></p><p> 系統(tǒng)具有提前搶答的犯規(guī)記錄功能,即在主持人搶答命令J1有效前按下?lián)尨疰I,這時(shí)揚(yáng)聲器發(fā)出特殊的高頻音響。同時(shí),組別顯示數(shù)碼管和LED指示燈都指示出該犯規(guī)組別。</p><p>
5、; 設(shè)計(jì)計(jì)分電路。計(jì)分電路可預(yù)置50分,然后以每次加1分和減1分進(jìn)行加/減計(jì)分。</p><p> 限時(shí)搶答。設(shè)置從發(fā)布搶答命令開始到最終時(shí)間的計(jì)時(shí),最終時(shí)間過后,如有組別斷續(xù)搶答視為犯規(guī)。</p><p><b> 設(shè)計(jì)要求</b></p><p> 分析設(shè)計(jì)任務(wù),擬訂多種設(shè)計(jì)方案,根據(jù)當(dāng)時(shí)的制作條件,選定其中的一種方案繪制設(shè)計(jì)系統(tǒng)
6、框圖和設(shè)計(jì)流程。</p><p> 設(shè)計(jì)各部分單元電路圖(或VHDL描述)。計(jì)算參數(shù),選定元器件型片ASIC。</p><p> 安裝、調(diào)試硬件電路,或制作以FPGA/CPLD為基礎(chǔ)的專用集成電路芯片ASIC。</p><p> 電路測(cè)試、分析所要求的各項(xiàng)功能和指標(biāo),或?qū)HDL描述的電路作功能仿真和時(shí)序仿真,對(duì)ASIC芯片作脫機(jī)運(yùn)行。</p>
7、<p> 運(yùn)行制作的硬件電路,操作各項(xiàng)設(shè)計(jì)功能是否正常、穩(wěn)定,交驗(yàn)并演示所設(shè)計(jì)制作的電路裝置。</p><p> 總結(jié)設(shè)計(jì)中各主要環(huán)節(jié)的資料,整理、打印出規(guī)范的設(shè)計(jì)報(bào)告。</p><p><b> 三 實(shí)驗(yàn)原理框圖</b></p><p> 當(dāng)主持人設(shè)置答題時(shí)間后,啟動(dòng)開始搶答按鍵時(shí),搶答鑒別模塊進(jìn)入工作狀態(tài),選手可以進(jìn)行搶答
8、,同時(shí)搶答定時(shí)器開始從10秒遞減;當(dāng)時(shí)間未減少到0秒時(shí),有選手搶答,報(bào)警電路發(fā)出警報(bào),則搶答鑒別模塊鎖存該選手的號(hào)碼,其他選手搶答無效,同時(shí),譯碼顯示選手編號(hào),定時(shí)器不再遞減;當(dāng)定時(shí)器時(shí)間減少到0秒時(shí),表示搶答時(shí)間到,發(fā)出警報(bào),選手搶答無效。搶答選手的號(hào)碼和搶答時(shí)間的倒計(jì)時(shí)分別顯示在LCD顯示屏上。</p><p> 四 鍵盤按鍵對(duì)應(yīng)功能:</p><p> 五 方案設(shè)計(jì)(系統(tǒng)的模塊結(jié)
9、構(gòu))</p><p><b> 搶答流程</b></p><p> 整個(gè)搶答過程分為幾個(gè)不同的狀態(tài),故用狀態(tài)機(jī)來實(shí)現(xiàn)。</p><p><b> 程序</b></p><p> library ieee;</p><p> use ieee.std_logic_11
10、64.all;</p><p> entity qiangda is</p><p> port ( reset, en, baojing, clk : in std_logic;</p><p> start1, start2, jishi : out std_logic</p><p><b> );</b>
11、</p><p> end qiangda;</p><p> architecture ztj of qiangda is</p><p> type states is ( st0, st1, st2 );</p><p> signal st : states;</p><p><b> be
12、gin</b></p><p> process( clk, reset, en, baojing )</p><p><b> begin</b></p><p> if reset = '1' then st <= st0; jishi <= '0'; start1 <=
13、'0'; start1 <= '0';</p><p> elsif clk'event and clk = '1' then</p><p> case st is</p><p> when st0 => if en = '1' then st <= st1; sta
14、rt1 <= '1'; start2 <= '0'; jishi <= '1'; </p><p> else st <= st0;</p><p><b> end if;</b></p><p> when st1 => if baojing = '
15、;1' then st <= st2; start1 <= '0'; start2 <= '1';</p><p> elsif baojing <= '0' then st <= st1;</p><p><b> end if;</b></p><p>
16、; when st2 => st <= st2;</p><p> when others => st <= st0;</p><p><b> end case;</b></p><p><b> end if;</b></p><p> end process;
17、</p><p><b> end;</b></p><p><b> 器件圖:</b></p><p><b> 波形圖</b></p><p><b> 搶答控制及鎖存</b></p><p><b> VH
18、DL程序:</b></p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> entity qa_sc is</p><p> port ( reset, start : in std_logic;</p><p>
19、 s1, s2, s3, s4, s5, s6, s7, s8 : in std_logic;</p><p> zubie : out std_logic_vector ( 3 downto 0);</p><p> led : out std_logic_vector ( 7 downto 0);</p><p> ring : out std_logic
20、</p><p><b> );</b></p><p> end qa_sc;</p><p> architecture bhv of qa_sc is</p><p> signal enabled: std_logic;</p><p> signal sc: std_logic
21、_vector(7 downto 0);</p><p><b> begin</b></p><p> process (s1, s2, s3, s4, s5, s6, s7, s8, reset)</p><p><b> begin</b></p><p> ring <=
22、39;0';</p><p> if (s1 or s2 or s3 or s4 or s5 or s6 or s7 or s8) = '1' and enabled = '1' then</p><p> ring <= '1';</p><p><b> end if;</b&g
23、t;</p><p> if reset = '1' then</p><p> sc(0) <= '0';</p><p> sc(1) <= '0';</p><p> sc(2) <= '0';</p><p> sc(3
24、) <= '0';</p><p> sc(4) <= '0';</p><p> sc(5) <= '0';</p><p> sc(6) <= '0';</p><p> sc(7) <= '0';</p>
25、<p> enabled <= '1';</p><p> elsif start = '1' then</p><p> if enabled = '1' and (s1 = '1' or s2 = '1' or s3 = '1' or s4 = '1'
26、or s5 = '1' or s6 = '1' or s7 = '1' or s8 = '1') then</p><p> sc(0) <= s1;</p><p> sc(1) <= s2;</p><p> sc(2) <= s3;</p><p>
27、 sc(3) <= s4;</p><p> sc(4) <= s5;</p><p> sc(5) <= s6;</p><p> sc(6) <= s7;</p><p> sc(7) <= s8;</p><p> enabled <= '0';&l
28、t;/p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process;</p><p> process (sc)</p><p><b> begin</b></p&
29、gt;<p> led <= sc;</p><p> case sc is</p><p> when "00000001" => zubie <= "0001";</p><p> when "00000010" => zubie <= "0
30、010";</p><p> when "00000100" => zubie <= "0011";</p><p> when "00001000" => zubie <= "0100";</p><p> when "00010000
31、" => zubie <= "0101";</p><p> when "00100000" => zubie <= "0110";</p><p> when "01000000" => zubie <= "0111";</p>
32、<p> when "10000000" => zubie <= "1000";</p><p> when others => zubie <= "0000";</p><p><b> end case;</b></p><p> en
33、d process;</p><p><b> end;</b></p><p><b> 器件圖:</b></p><p><b> 波形圖:</b></p><p><b> 2、10秒計(jì)時(shí)</b></p><p>&l
34、t;b> 用狀態(tài)機(jī)來實(shí)現(xiàn)</b></p><p><b> VHDL程序:</b></p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;<
35、;/p><p> entity jishiqi is</p><p> port ( clk, jishi, reset, stop : in std_logic;</p><p> baojing : out std_logic;</p><p> TM : out std_logic_vector ( 7 downto 0)</
36、p><p><b> );</b></p><p> end jishiqi;</p><p> architecture ztj_js of jishiqi is</p><p> type states is ( st0, st1, st2 );</p><p> signal st :
37、 states;</p><p> signal tl, th : std_logic_vector ( 3 downto 0 );</p><p><b> begin</b></p><p> process ( clk, jishi, reset, stop )</p><p><b> begi
38、n</b></p><p> if reset = '1' then st <= st0; th <= "0001"; tl <= "0000"; baojing <= '0'; --倒計(jì)時(shí) 10s</p><p> elsif clk'event and clk
39、 = '1' then</p><p> case st is</p><p> when st0 => if jishi = '1' then st <= st1; baojing <= '0';</p><p> else st <= st0;</p><p>
40、<b> end if;</b></p><p> when st1 => if stop = '1' then st <= st2;</p><p> elsif tl = "0000" then</p><p> if th = "0000" then</p&
41、gt;<p> th <= "0000"; tl <= "0000"; baojing <= '1';</p><p><b> else</b></p><p> tl <= "1001"; th <= th - 1;</p>
42、<p><b> end if;</b></p><p><b> else</b></p><p> tl <= tl - 1;</p><p><b> end if;</b></p><p> when st2 => baojing <
43、;= '0'; st <= st2;</p><p> when others => st <= st0;</p><p><b> end case;</b></p><p><b> end if;</b></p><p> end process;&l
44、t;/p><p> process ( tl, th )</p><p><b> begin</b></p><p> TM <= th & tl;</p><p> end process;</p><p><b> end;</b></p>
45、;<p><b> 器件圖:</b></p><p><b> 波形圖</b></p><p><b> 計(jì)分器</b></p><p><b> VHDL程序:</b></p><p> library ieee;</p&g
46、t;<p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity jifenqi is</p><p> port ( clk, clear : in std_logic;</p><p> ADD
47、, SUB : in std_logic;</p><p> team : in std_logic_vector ( 3 downto 0 );</p><p> F1, F2, F3, F4, F5, F6, F7, F8 : out std_logic_vector ( 7 downto 0 )</p><p><b> );</b>
48、;</p><p> end jifenqi;</p><p> architecture jfq_ztj of jifenqi is</p><p> type states is ( st0, st1, st2 );</p><p> signal st : states;</p><p> signal
49、 k1, k2, k3, k4, k5, k6, k7, k8 : std_logic_vector ( 7 downto 0 );</p><p><b> begin</b></p><p> process ( clk, ADD, SUB, clear, team )</p><p><b> begin</b>
50、;</p><p> if clear = '1' then</p><p> st <= st0;</p><p> k1 <= "01010000"; --初始賦值50分</p><p> k2 <= "01010000";</p>&
51、lt;p> k3 <= "01010000";</p><p> k4 <= "01010000";</p><p> k5 <= "01010000";</p><p> k6 <= "01010000";</p><p>
52、 k7 <= "01010000";</p><p> k8 <= "01010000";</p><p> elsif clk'event and clk = '1' then</p><p> case st is</p><p> when st0 =
53、> if ADD = '1' and SUB = '0' then st <= st1;</p><p> elsif ADD = '0' and SUB = '1' then st <= st2;</p><p> else st <= st0;</p><p><b
54、> end if;</b></p><p> when st1 => if team = "0001" then</p><p> if k1(3 downto 0) = "1001" then k1(3 downto 0) <= "0000";</p><p> if
55、 k1(7 downto 4) = "1001" then k1(7 downto 4) <= "0000";</p><p> else k1(7 downto 4) <= k1(7 downto 4) + 1;</p><p><b> end if;</b></p><p> el
56、se k1(3 downto 0) <= k1(3 downto 0) + 1;</p><p><b> end if;</b></p><p> elsif team = "0010" then</p><p> if k2(3 downto 0) = "1001" then k2(3 d
57、ownto 0) <= "0000";</p><p> if k2(7 downto 4) = "1001" then k2(7 downto 4) <= "0000";</p><p> else k2(7 downto 4) <= k2(7 downto 4) + 1;</p><p
58、><b> end if;</b></p><p> else k2(3 downto 0) <= k2(3 downto 0) + 1;</p><p><b> end if;</b></p><p> elsif team = "0011" then</p>&l
59、t;p> if k3(3 downto 0) = "1001" then k3(3 downto 0) <= "0000";</p><p> if k3(7 downto 4) = "1001" then k3(7 downto 4) <= "0000";</p><p> else
60、k3(7 downto 4) <= k3(7 downto 4) + 1;</p><p><b> end if;</b></p><p> else k3(3 downto 0) <= k3(3 downto 0) + 1;</p><p><b> end if;</b></p>&l
61、t;p> elsif team = "0100" then</p><p> if k4(3 downto 0) = "1001" then k4(3 downto 0) <= "0000";</p><p> if k4(7 downto 4) = "1001" then k4(7 down
62、to 4) <= "0000";</p><p> else k4(7 downto 4) <= k4(7 downto 4) + 1;</p><p><b> end if;</b></p><p> else k4(3 downto 0) <= k4(3 downto 0) + 1;</p
63、><p><b> end if;</b></p><p> elsif team = "0101" then</p><p> if k5(3 downto 0) = "1001" then k5(3 downto 0) <= "0000";</p><p
64、> if k5(7 downto 4) = "1001" then k5(7 downto 4) <= "0000";</p><p> else k5(7 downto 4) <= k5(7 downto 4) + 1;</p><p><b> end if;</b></p><p
65、> else k5(3 downto 0) <= k5(3 downto 0) + 1;</p><p><b> end if;</b></p><p> elsif team = "0110" then</p><p> if k6(3 downto 0) = "1001" the
66、n k6(3 downto 0) <= "0000";</p><p> if k6(7 downto 4) = "1001" then k6(7 downto 4) <= "0000";</p><p> else k6(7 downto 4) <= k6(7 downto 4) + 1;</p>
67、;<p><b> end if;</b></p><p> else k6(3 downto 0) <= k6(3 downto 0) + 1;</p><p><b> end if;</b></p><p> elsif team = "0111" then</p
68、><p> if k7(3 downto 0) = "1001" then k7(3 downto 0) <= "0000";</p><p> if k7(7 downto 4) = "1001" then k7(7 downto 4) <= "0000";</p><p>
69、; else k7(7 downto 4) <= k7(7 downto 4) + 1;</p><p><b> end if;</b></p><p> else k7(3 downto 0) <= k7(3 downto 0) + 1;</p><p><b> end if;</b></p
70、><p> elsif team = "1000" then</p><p> if k8(3 downto 0) = "1001" then k8(3 downto 0) <= "0000";</p><p> if k8(7 downto 4) = "1001" then k
71、8(7 downto 4) <= "0000";</p><p> else k8(7 downto 4) <= k8(7 downto 4) + 1;</p><p><b> end if;</b></p><p> else k8(3 downto 0) <= k8(3 downto 0) +
72、1;</p><p><b> end if;</b></p><p><b> end if;</b></p><p><b> --</b></p><p> -- if SUB = '1' then st
73、<= st2;</p><p> -- else st <= st1;</p><p> -- end if;</p><p> st <= st0;</p><p> when st2 => if team = "0
74、001" then</p><p> if k1(3 downto 0) = "0000" then k1(3 downto 0) <= "1001";</p><p> if k1(7 downto 4) = "0000" then k1(7 downto 4) <= "1001";
75、</p><p> else k1(7 downto 4) <= k1(7 downto 4) - 1;</p><p><b> end if;</b></p><p> else k1(3 downto 0) <= k1(3 downto 0) - 1;</p><p><b> end
76、 if;</b></p><p> elsif team = "0010" then</p><p> if k2(3 downto 0) = "0000" then k2(3 downto 0) <= "1001";</p><p> if k2(7 downto 4) = &qu
77、ot;0000" then k2(7 downto 4) <= "1001";</p><p> else k2(7 downto 4) <= k2(7 downto 4) - 1;</p><p><b> end if;</b></p><p> else k2(3 downto 0) <
78、;= k2(3 downto 0) - 1;</p><p><b> end if;</b></p><p> elsif team = "0011" then</p><p> if k3(3 downto 0) = "0000" then k3(3 downto 0) <= "
79、1001";</p><p> if k3(7 downto 4) = "0000" then k3(7 downto 4) <= "1001";</p><p> else k3(7 downto 4) <= k3(7 downto 4) - 1;</p><p><b> end if
80、;</b></p><p> else k3(3 downto 0) <= k3(3 downto 0) - 1;</p><p><b> end if;</b></p><p> elsif team = "0100" then</p><p> if k4(3 down
81、to 0) = "0000" then k4(3 downto 0) <= "1001";</p><p> if k4(7 downto 4) = "0000" then k4(7 downto 4) <= "1001";</p><p> else k4(7 downto 4) <=
82、k4(7 downto 4) - 1;</p><p><b> end if;</b></p><p> else k4(3 downto 0) <= k4(3 downto 0) - 1;</p><p><b> end if;</b></p><p> elsif team =
83、 "0101" then</p><p> if k5(3 downto 0) = "0000" then k5(3 downto 0) <= "1001";</p><p> if k5(7 downto 4) = "0000" then k5(7 downto 4) <= "100
84、1";</p><p> else k5(7 downto 4) <= k5(7 downto 4) - 1;</p><p><b> end if;</b></p><p> else k5(3 downto 0) <= k5(3 downto 0) - 1;</p><p><b&
85、gt; end if;</b></p><p> elsif team = "0110" then</p><p> if k6(3 downto 0) = "0000" then k6(3 downto 0) <= "1001";</p><p> if k6(7 downto
86、4) = "0000" then k6(7 downto 4) <= "1001";</p><p> else k6(7 downto 4) <= k6(7 downto 4) - 1;</p><p><b> end if;</b></p><p> else k6(3 downt
87、o 0) <= k6(3 downto 0) - 1;</p><p><b> end if;</b></p><p> elsif team = "0111" then</p><p> if k7(3 downto 0) = "0000" then k7(3 downto 0) <
88、= "1001";</p><p> if k7(7 downto 4) = "0000" then k7(7 downto 4) <= "1001";</p><p> else k7(7 downto 4) <= k7(7 downto 4) - 1;</p><p><b>
89、 end if;</b></p><p> else k7(3 downto 0) <= k7(3 downto 0) - 1;</p><p><b> end if;</b></p><p> elsif team = "1000" then</p><p> if k
90、8(3 downto 0) = "0000" then k8(3 downto 0) <= "1001";</p><p> if k8(7 downto 4) = "0000" then k8(7 downto 4) <= "1001";</p><p> else k8(7 downto 4
91、) <= k8(7 downto 4) - 1;</p><p><b> end if;</b></p><p> else k8(3 downto 0) <= k8(3 downto 0) - 1;</p><p><b> end if;</b></p><p><b&
92、gt; end if;</b></p><p> st <= st0;</p><p> --if ADD = '1' then st <= st1;</p><p> else st <= st2;</p><p><b> end if;</b></p&g
93、t;<p> when others => st <= st0;</p><p><b> end case;</b></p><p><b> end if;</b></p><p> end process;</p><p> process ( k1, k2
94、, k3, k4, k5, k6, k7, k8 )</p><p><b> begin</b></p><p><b> F1 <= k1;</b></p><p><b> F2 <= k2;</b></p><p><b> F3 <
95、= k3;</b></p><p><b> F4 <= k4;</b></p><p><b> F5 <= k5;</b></p><p><b> F6 <= k6;</b></p><p><b> F7 <= k7
96、;</b></p><p><b> F8 <= k8;</b></p><p> end process;</p><p><b> end;</b></p><p><b> 器件圖:</b></p><p><b&g
97、t; 波形圖</b></p><p><b> 4、報(bào)警電路</b></p><p><b> VHDL程序:</b></p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p&g
98、t; use ieee.std_logic_unsigned.all;</p><p> entity shengyin is</p><p> port ( ring, sy : in std_logic;</p><p> fengmingqi : out std_logic</p><p><b> );</b
99、></p><p> end shengyin;</p><p> architecture bhv of shengyin is</p><p><b> begin</b></p><p> process ( ring, sy )</p><p><b> begi
100、n</b></p><p> if ring = '1' then</p><p> fengmingqi <= sy;</p><p><b> else</b></p><p> fengmingqi <= '0';</p><p&g
101、t;<b> end if;</b></p><p> end process;</p><p><b> end;</b></p><p><b> 器件圖:</b></p><p><b> 波形圖</b></p><p&
102、gt;<b> 5、鍵盤掃描</b></p><p><b> VHDL程序</b></p><p> LIBRARY IEEE;</p><p> USE IEEE.STD_LOGIC_1164.ALL;</p><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL;
103、</p><p> entity PADTOKEY is</p><p> port (CPIN,R :IN STD_LOGIC;</p><p> Y: OUT STD_LOGIC_VECTOR(15 DOWNTO 0);</p><p> ICOL : IN STD_LOGIC_VECTOR(3 DOWNTO 0);</p&
104、gt;<p> OROW : OUT STD_LOGIC_VECTOR(3 DOWNTO 0)</p><p><b> );</b></p><p> END ENTITY;</p><p> architecture JGT of PADTOKEY is</p><p> TYPE STATE
105、S IS (S0,S1,S2,S3,S4);</p><p> SIGNAL S: STATES;</p><p> SIGNAL SROW : STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p> SIGNAL CPCT : INTEGER RANGE 0 TO 255;</p><p> SIGNAL C
106、TDELAY: INTEGER RANGE 0 TO 511;</p><p> SIGNAL CP:STD_LOGIC;</p><p><b> BEGIN</b></p><p> PROCESS(CPIN)</p><p><b> BEGIN</b></p><
107、p> IF CPIN='1' AND CPIN 'EVENT THEN</p><p> IF CPCT=255 THEN</p><p> CPCT<=0;CP<= NOT CP;</p><p><b> ELSE</b></p><p> CPCT<=CPC
108、T+1;</p><p><b> END IF;</b></p><p><b> END IF;</b></p><p> END PROCESS;</p><p> PROCESS(CP,R)</p><p> VARIABLE N:INTEGER RANGE
109、 0 TO 12;</p><p><b> BEGIN</b></p><p> IF R='1' THEN</p><p> S<=S0;Y<="0000000000000000";SROW<="1110";N:=0;</p><p>
110、 ELSIF CP='1' AND CP'EVENT THEN</p><p><b> CASE S IS</b></p><p> WHEN S0=>S<=S1;</p><p> WHEN S1=>OROW<=SROW;S<=S2;</p><p> W
111、HEN S2=>S<=S3;</p><p><b> CASE N IS</b></p><p> WHEN 0 =>Y(3 DOWNTO 0)<=NOT ICOL;</p><p> WHEN 4 =>Y(7 DOWNTO 4)<=NOT ICOL;</p><p> WH
112、EN 8 =>Y(11 DOWNTO 8)<=NOT ICOL;</p><p> WHEN 12 =>Y(15 DOWNTO 12)<=NOT ICOL;</p><p> WHEN OTHERS=>NULL;</p><p><b> END CASE;</b></p><p>
113、 WHEN S3=>IF N=12 THEN</p><p> N:=0;S<=S4;CTDELAY<=0;SROW<="1110";</p><p><b> ELSE</b></p><p> N:=N+4;S<=S1;SROW<=SROW(2 DOWNTO 0)&SRO
114、W(3);</p><p><b> END IF;</b></p><p> WHEN S4=>IF CTDELAY=511 THEN</p><p> S<=S1;CTDELAY<=0;</p><p><b> ELSE</b></p><p>
115、; CTDELAY<=CTDELAY+1;</p><p><b> END IF;</b></p><p><b> END CASE;</b></p><p><b> END IF;</b></p><p> END PROCESS;</p>
116、<p><b> END JGT;</b></p><p><b> 器件圖</b></p><p><b> 6、LCD顯示</b></p><p><b> VHDL程序</b></p><p> LIBRARY IEEE;<
117、;/p><p> USE IEEE.STD_LOGIC_1164.ALL;</p><p> USE IEEE.STD_LOGIC_UNSIGNED.ALL;</p><p> entity QDQLCD is</p><p><b> port (</b></p><p> CPIN,CL
118、EAR,BUSY :IN STD_LOGIC;</p><p> F0,F1,F2,F3,F4,F5,F6,F7:IN STD_LOGIC_VECTOR(7 DOWNTO 0); --得分</p><p> TM : IN STD_LOGIC_VECTOR(7 DOWNTO 0); --時(shí)間輸出</p><p> ZB : IN STD_LOGIC_
119、VECTOR(3 DOWNTO 0); --組別</p><p> CLK,RST,STROBE,OUTLINE : OUT STD_LOGIC;</p><p> DATA : OUT STD_LOGIC_VECTOR(7 DOWNTO 0);</p><p> ADDR : OUT STD_LOGIC_VECTOR(3 DOWNTO 0)</p
120、><p><b> );</b></p><p> end entity ;</p><p> architecture art of QDQLCD is</p><p> TYPE STATES IS (S0,S1,S2,S3,S4);</p><p> SIGNAL S: STATES;
121、</p><p> SIGNAL LCDPT : INTEGER RANGE 0 TO 25;</p><p> SIGNAL CPCT : INTEGER RANGE 0 TO 65535;</p><p> SIGNAL CP: STD_LOGIC;</p><p> --SIGNAL ASCEW,ASCSN : STD_LOGI
122、C_VECTOR(7 DOWNTO 0);</p><p><b> begin</b></p><p> PROCESS(CPIN,CLEAR)</p><p><b> BEGIN</b></p><p> CLK<=CPIN;</p><p> IF C
123、LEAR='1' THEN</p><p> CPCT<=65535;</p><p> ELSIF CPIN='1' AND CPIN 'EVENT THEN</p><p> IF CPCT=0 THEN</p><p> CPCT<=65535;CP<=NOT CP;&l
124、t;/p><p><b> ELSE</b></p><p> CPCT<=CPCT-1;</p><p><b> END IF;</b></p><p><b> END IF;</b></p><p> END PROCESS; --
125、分頻為500US周期</p><p> --主進(jìn)程:擬采用500us時(shí)鐘,即在500us后完成狀態(tài)轉(zhuǎn)換,修改LCDPT指針</p><p> --S0:初始狀態(tài),在R=1時(shí),處于S0狀態(tài),LCDPT=0</p><p> -- 流程: 輸出rst=1, 轉(zhuǎn)S1</p><p> --S1:輸出RST=0;判斷BUSY=0? :Y:
126、LCDPT+1;LCDPT到固定最后?::N: ->S2</p><p> -- ::Y: 轉(zhuǎn)S3</p><p> -- ;N; NULL</p><p> --S2:給出STROBE信號(hào)。轉(zhuǎn)S1</p>
127、<p> --S1,S2完成初始化固定顯示的功能</p><p> PROCESS(CP,CLEAR)</p><p><b> BEGIN</b></p><p> IF CLEAR='1' THEN</p><p> S<=S0;LCDPT<=0;RST<=
128、39;1';</p><p> ELSIF CP='1' AND CP 'EVENT THEN</p><p><b> CASE S IS</b></p><p> WHEN S0=> S<=S1;LCDPT<=0;RST<='1';</p><
129、p> WHEN S1=> RST<='0';STROBE<='0';</p><p> IF BUSY='0' THEN</p><p> LCDPT<=LCDPT+1;</p><p> IF LCDPT=11 THEN</p><p><b>
130、 S<=S3;</b></p><p><b> ELSE</b></p><p><b> S<=S2;</b></p><p><b> END IF;</b></p><p><b> END IF;</b><
131、/p><p> WHEN S2=> S<=S1;STROBE<='1';</p><p> --S3~S4完成掃描顯示功能</p><p> --S3:BUSY=0? :Y: LCDPT循環(huán)+1 ,轉(zhuǎn)S4</p><p> --S4:給出STROBE信號(hào),轉(zhuǎn)S3</p><p>
132、 WHEN S3=> STROBE<='0';</p><p> IF BUSY='0' THEN</p><p> IF LCDPT=29 THEN</p><p> LCDPT<=11;</p><p><b> ELSE</b></p><
133、;p> LCDPT<=LCDPT+1;</p><p><b> END IF;</b></p><p><b> S<=S4;</b></p><p><b> END IF;</b></p><p> WHEN S4=> STROBE<
134、;='1';S<=S3;</p><p> WHEN OTHERS=> NULL;</p><p><b> END CASE;</b></p><p><b> END IF;</b></p><p> END PROCESS;</p><p
135、> --選擇輸出進(jìn)程(LCDPT)</p><p> --LCDPT=0,NULL</p><p> -- =1~10 顯示 Team: Time:</p><p> PROCESS(LCDPT)</p><p><b> BEGIN</b></p><p> CASE
136、LCDPT IS</p><p> WHEN 0 => NULL;</p><p> WHEN 1=> DATA<="01010100";ADDR<="0000";OUTLINE<='0'; --T 54H</p><p> WHEN 2=> DATA<
137、="01100101";ADDR<="0001";OUTLINE<='0'; --e 65H</p><p> WHEN 3=> DATA<="01100001";ADDR<="0010";OUTLINE<='0'; --a 61H</p&
138、gt;<p> WHEN 4=> DATA<="01101101";ADDR<="0011";OUTLINE<='0'; --m 6DH</p><p> WHEN 5=> DATA<="00111010";ADDR<="0100";OUTLINE&
139、lt;='0'; --: 3AH</p><p> WHEN 6=> DATA<="01010100";ADDR<="0111";OUTLINE<='0'; --T 54H</p><p> WHEN 7=> DATA<="01101001"
140、;;ADDR<="1000";OUTLINE<='0'; --i 69H</p><p> WHEN 8=> DATA<="01101101";ADDR<="1001";OUTLINE<='0'; --m 6DH</p><p> WHEN
141、 9=> DATA<="01100101";ADDR<="1010";OUTLINE<='0'; --e 65H</p><p> WHEN 10=> DATA<="00111010";ADDR<="1011";OUTLINE<='0';
142、 --: 3AH</p><p> --LCDPT=11~26 顯示FS1~FS8</p><p> WHEN 11=>DATA<="0011"&F0(7 DOWNTO 4);ADDR<="0000";OUTLINE<='1';</p><p> WHEN 12=>
143、DATA<="0011"&F0(3 DOWNTO 0);ADDR<="0001";OUTLINE<='1';</p><p> WHEN 13=>DATA<="0011"&F1(7 DOWNTO 4);ADDR<="0010";OUTLINE<='1&
144、#39;;</p><p> WHEN 14=>DATA<="0011"&F1(3 DOWNTO 0);ADDR<="0011";OUTLINE<='1';</p><p> WHEN 15=>DATA<="0011"&F2(7 DOWNTO 4);ADDR&
145、lt;="0100";OUTLINE<='1';</p><p> WHEN 16=>DATA<="0011"&F2(3 DOWNTO 0);ADDR<="0101";OUTLINE<='1';</p><p> WHEN 17=>DATA<=&
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- eda數(shù)字搶答器課程設(shè)計(jì)
- eda課程設(shè)計(jì)報(bào)告--eda數(shù)字搶答器
- eda課程設(shè)計(jì)-搶答器
- eda課程設(shè)計(jì)---搶答器
- eda課程設(shè)計(jì)---競(jìng)賽搶答器
- eda課程設(shè)計(jì)---數(shù)字式競(jìng)賽搶答器
- eda課程設(shè)計(jì)--數(shù)字式競(jìng)賽搶答器設(shè)計(jì)
- eda課程設(shè)計(jì)---競(jìng)賽搶答器
- eda畢業(yè)課程設(shè)計(jì)--搶答器
- eda課程設(shè)計(jì)—四路搶答器
- 四路搶答器eda課程設(shè)計(jì)
- 課程設(shè)計(jì)--數(shù)字搶答器
- 數(shù)字搶答器課程設(shè)計(jì)
- 四路搶答器eda課程設(shè)計(jì)
- 數(shù)字搶答器課程設(shè)計(jì)
- 數(shù)字搶答器課程設(shè)計(jì)
- 課程設(shè)計(jì)--數(shù)字搶答器
- 八路搶答器eda課程設(shè)計(jì)
- 八路搶答器-eda課程設(shè)計(jì)
- 六人搶答器eda課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論