版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 課程設(shè)計(jì)說明書</b></p><p> 題目 帶有偶效驗(yàn)電位數(shù)據(jù)發(fā)生器 </p><p> 系(部) 電子與通信工程 </p><p> 專業(yè)(班級) 電氣二班 </p><p> 姓名
2、 </p><p> 學(xué)號 </p><p> 指導(dǎo)教師 </p><p> 起止日期 2012年12月16-28號 </p><p> 電子設(shè)計(jì)自動化設(shè)計(jì)任務(wù)書</p><p><b> 目錄</b
3、></p><p> 第1章 設(shè)計(jì)方案與論證5</p><p> 1.1 設(shè)計(jì)內(nèi)容及要求5</p><p> 第2章 模塊設(shè)計(jì)6</p><p> 2.1 分頻模塊6</p><p> 2.2 頂層文件7</p><p> 第3章 總體設(shè)計(jì)與仿真10&
4、lt;/p><p> 3.1 總體設(shè)計(jì)方案10</p><p> 3.2 引腳分配15</p><p> 實(shí)驗(yàn)總結(jié)與體會16</p><p><b> 參考文獻(xiàn):16</b></p><p><b> 設(shè)計(jì)內(nèi)容及要求</b></p><p
5、> 試設(shè)計(jì)一個(gè)帶有偶校驗(yàn)位的數(shù)據(jù)發(fā)生器。該數(shù)據(jù)發(fā)生器具有三個(gè)輸入端,輸入為一組并行3位二進(jìn)制數(shù)碼,輸岀是一組串行(低位先行)的四位二進(jìn)制數(shù)碼,其中串行輸岀的數(shù)碼的最后一位(即最高位)為偶校驗(yàn)位(由數(shù)據(jù)發(fā)送器輸出時(shí)加入),前3位依次為數(shù)據(jù)位,當(dāng)輸入的3位二進(jìn)制碼中有奇數(shù)個(gè)1時(shí),使其偶校驗(yàn)位為1,否則為0。同時(shí)數(shù)碼管也顯示輸岀的四位二進(jìn)制數(shù)碼。系統(tǒng)提供50MHZ頻率的時(shí)鐘源。完成該系統(tǒng)的硬件和軟件的設(shè)計(jì),并制作出實(shí)物裝置,調(diào)試好后并
6、能實(shí)際運(yùn)用(指導(dǎo)教師提供制作所需的器件),最后就課程設(shè)計(jì)本身提交一篇課程設(shè)計(jì)說明書。</p><p><b> 大體步驟</b></p><p><b> 課題介紹</b></p><p><b> 設(shè)計(jì)方案論證</b></p><p> 進(jìn)一步討論方案, 對設(shè)計(jì)方案進(jìn)
7、行必要的修正,方案確定后開始進(jìn)行VHDL語言程序設(shè)計(jì)</p><p> 設(shè)計(jì)VHDL語言程序</p><p> 在實(shí)驗(yàn)裝置上進(jìn)行硬件測試,對VHDL語言程序進(jìn)行必要的修正,并進(jìn)行演示</p><p> 根據(jù)要求,該數(shù)據(jù)發(fā)生器具有三個(gè)輸入端,輸入為一組并行3位二進(jìn)制數(shù)碼,輸岀是一組串行,輸岀是一組串行的四位二進(jìn)制數(shù)碼,其中串行輸岀的數(shù)碼的最后一位(即最高位)為偶
8、校驗(yàn)位,前3位依次為數(shù)據(jù)位,當(dāng)輸入的3位二進(jìn)制碼中有奇數(shù)個(gè)1時(shí),使其偶校驗(yàn)位為1,否則為0。同時(shí)數(shù)碼管也顯示輸岀的四位二進(jìn)制數(shù)碼。系統(tǒng)提供50MHZ頻率的時(shí)鐘源。</p><p><b> 2.1 分頻模塊</b></p><p> 2.1.1 vhdl語言程序:</p><p> library ieee;</p>&
9、lt;p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity fenpin is</p><p> port(clkk: in std_logic;</p><p> y: out std_logic);
10、</p><p> end fenpin;</p><p> architecture one of fenpin is</p><p> signal full:std_logic;</p><p><b> begin</b></p><p> p_reg:process(clkk)
11、 </p><p> variable cnt:integer range 1 to 10;</p><p><b> begin </b></p><p> if clkk'event and clkk='1' then</p><p> if cnt=5
12、then</p><p><b> cnt:=1;</b></p><p> full<='1';</p><p><b> else </b></p><p> cnt:=cnt+1;</p><p> full<='0'
13、;;</p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process p_reg;</p><p> p_div:process(full)</p><p> variable cnt2:
14、std_logic;</p><p><b> begin</b></p><p> if full'event and full='1' then</p><p> cnt2:=not cnt2;</p><p> if cnt2='1' then</p>
15、<p><b> y<='1';</b></p><p><b> else</b></p><p><b> y<='0';</b></p><p><b> end if;</b></p><p
16、><b> end if;</b></p><p> end process p_div;</p><p><b> end;</b></p><p> 2.1.2 程序仿真</p><p> 根據(jù)vhdl程序要求仿真結(jié)果如下:</p><p><b&
17、gt; 2.2 頂層文件</b></p><p> 2.2.1 vhdl語言程序</p><p> LIBRARY IEEE;</p><p> USE IEEE.STD_LOGIC_1164.ALL;</p><p> use ieee.std_logic_unsigned.all;</p><
18、p> ENTITY SHIFT IS</p><p> PORT (CLK,en: IN STD_LOGIC;</p><p> DIN: IN STD_LOGIC_VECTOR( 2 DOWNTO 0);</p><p> led_selout:out std_logic_vector( 3 downto 0);</p><p&g
19、t; LED7S: OUT STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p> QB : OUT STD_LOGIC); </p><p><b> END ;</b></p><p> ARCHITECTURE hav OF SHIFT IS</p><p> COMPONEN
20、T fenpin </p><p> PORT(clkk: in std_logic;</p><p> y: out std_logic);</p><p> END COMPONENT;</p><p> SIGNAL REG:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p>
21、SIGNAL CY,clkd :STD_LOGIC;</p><p> signal di:std_logic_vector(2 downto 0);</p><p> SIGNAL D:STD_LOGIC_vector(3 downto 0);</p><p> signal wei:std_logic_vector(1 downto 0);</p&g
22、t;<p><b> begin</b></p><p> u1:fenpin port map(clkk=>clk,y=>clkd);</p><p> process(clkd)</p><p><b> begin</b></p><p> if clkd
23、'event and clkd='1' then</p><p> if wei="11" then</p><p> wei<="00";</p><p><b> else</b></p><p> wei<=wei+1;</
24、p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process;</p><p> process(wei)</p><p><b> begin</b></p>
25、<p> case wei is</p><p> WHEN "00"=>LED_selout<="0001";</p><p> WHEN "01"=>LED_selout<="0010";</p><p> WHEN "10&q
26、uot;=>LED_selout<="0100";</p><p> WHEN "11"=>LED_selout<="1000";</p><p> when others=>null;</p><p><b> END CASE;</b></
27、p><p> END PROCESS;</p><p> PROCESS( en,clkd)</p><p><b> BEGIN</b></p><p> if clkd'event and clkd='1' then </p><p> IF EN='1&
28、#39; THEN</p><p> CY<=DIN(0 )XOR DIN(1) XOR DIN(2); </p><p> REG<=CY & DIN;</p><p><b> else</b></p><p> REG(2 DOWNTO 0)<=REG(3 DOWNTO 1);
29、 </p><p> END IF;END IF;</p><p> QB<=REG(0);D<=cy & diN;</p><p> END PROCESS; </p><p> PROCESS(d,wei)</p><p><b> BEGIN</b&
30、gt;</p><p> if wei="00" then</p><p> case D(0) is</p><p> when '0'=>led7s<="1000000";</p><p> when '1'=>led7s<="
31、;1111001";</p><p> when others=>null;</p><p><b> end case;</b></p><p><b> end if;</b></p><p> if wei="01" then</p>
32、<p> case D(1) is</p><p> when '0'=>led7s<="1000000";</p><p> when '1'=>led7s<="1111001";</p><p> when others=>null;</
33、p><p><b> end case;</b></p><p><b> end if;</b></p><p> if wei="10" then</p><p> case d(2) is</p><p> when '0'=&
34、gt;led7s<="1000000";</p><p> when '1'=>led7s<="1111001";</p><p> when others=>null;</p><p><b> end case;</b></p><p&
35、gt;<b> end if;</b></p><p> if wei="11" then</p><p> case d(3) is</p><p> when '0'=>led7s<="1000000";</p><p> when
36、9;1'=>led7s<="1111001";</p><p> when others=>null;</p><p><b> end case;</b></p><p><b> end if;</b></p><p> end proces
37、s ;</p><p><b> END HAV;</b></p><p> 2.2.2 程序仿真</p><p> 根據(jù)程序要求仿真結(jié)果如下:</p><p> 第3章 總體設(shè)計(jì)與仿真</p><p> 3.1 總體設(shè)計(jì)方案</p><p> 以上各個(gè)模
38、塊通過仿真測試后,將上述設(shè)計(jì)的各模塊通過一定的連接關(guān)系整合起來即得到總體設(shè)計(jì)方案。總體程序如下:</p><p> LIBRARY IEEE;</p><p> USE IEEE.STD_LOGIC_1164.ALL;</p><p> use ieee.std_logic_unsigned.all;</p><p> ENTITY
39、SHIFT IS</p><p> PORT (CLK,en: IN STD_LOGIC;</p><p> DIN: IN STD_LOGIC_VECTOR( 2 DOWNTO 0);</p><p> led_selout:out std_logic_vector( 3 downto 0);</p><p> LED7S: OUT
40、 STD_LOGIC_VECTOR(6 DOWNTO 0);</p><p> QB : OUT STD_LOGIC); </p><p><b> END ;</b></p><p> ARCHITECTURE hav OF SHIFT IS</p><p> COMPONENT fenpin </
41、p><p> PORT(clkk: in std_logic;</p><p> y: out std_logic);</p><p> END COMPONENT;</p><p> SIGNAL REG:STD_LOGIC_VECTOR(3 DOWNTO 0);</p><p> SIGNAL CY,clkd
42、 :STD_LOGIC;</p><p> signal di:std_logic_vector(2 downto 0);</p><p> SIGNAL D:STD_LOGIC_vector(3 downto 0);</p><p> signal wei:std_logic_vector(1 downto 0);</p><p>&
43、lt;b> begin</b></p><p> u1:fenpin port map(clkk=>clk,y=>clkd);</p><p> process(clkd)</p><p><b> begin</b></p><p> if clkd'event and
44、 clkd='1' then</p><p> if wei="11" then</p><p> wei<="00";</p><p><b> else</b></p><p> wei<=wei+1;</p><p&g
45、t;<b> end if;</b></p><p><b> end if;</b></p><p> end process;</p><p> process(wei)</p><p><b> begin</b></p><p> c
46、ase wei is</p><p> WHEN "00"=>LED_selout<="0001";</p><p> WHEN "01"=>LED_selout<="0010";</p><p> WHEN "10"=>LED_s
47、elout<="0100";</p><p> WHEN "11"=>LED_selout<="1000";</p><p> when others=>null;</p><p><b> END CASE;</b></p><p&g
48、t; END PROCESS;</p><p> PROCESS( en,clkd)</p><p><b> BEGIN</b></p><p> if clkd'event and clkd='1' then </p><p> IF EN='1' THEN</
49、p><p> CY<=DIN(0 )XOR DIN(1) XOR DIN(2); </p><p> REG<=CY & DIN;</p><p><b> else</b></p><p> REG(2 DOWNTO 0)<=REG(3 DOWNTO 1); </p>
50、<p> END IF;END IF;</p><p> QB<=REG(0);D<=cy & diN;</p><p> END PROCESS; </p><p> PROCESS(d,wei)</p><p><b> BEGIN</b></p>
51、<p> if wei="00" then</p><p> case D(0) is</p><p> when '0'=>led7s<="1000000";</p><p> when '1'=>led7s<="1111001"
52、;</p><p> when others=>null;</p><p><b> end case;</b></p><p><b> end if;</b></p><p> if wei="01" then</p><p> cas
53、e D(1) is</p><p> when '0'=>led7s<="1000000";</p><p> when '1'=>led7s<="1111001";</p><p> when others=>null;</p><p&g
54、t;<b> end case;</b></p><p><b> end if;</b></p><p> if wei="10" then</p><p> case d(2) is</p><p> when '0'=>led7s<=&
55、quot;1000000";</p><p> when '1'=>led7s<="1111001";</p><p> when others=>null;</p><p><b> end case;</b></p><p><b>
56、end if;</b></p><p> if wei="11" then</p><p> case d(3) is</p><p> when '0'=>led7s<="1000000";</p><p> when '1'=>l
57、ed7s<="1111001";</p><p> when others=>null;</p><p><b> end case;</b></p><p><b> end if;</b></p><p> end process ;</p>
58、<p><b> END HAV;</b></p><p> library ieee;</p><p> use ieee.std_logic_1164.all;</p><p> use ieee.std_logic_unsigned.all;</p><p> entity fenpin is
59、</p><p> port(clkk: in std_logic;</p><p> y: out std_logic);</p><p> end fenpin;</p><p> architecture one of fenpin is</p><p> signal full:std_logic;&
60、lt;/p><p><b> begin</b></p><p> p_reg:process(clkk) </p><p> variable cnt:integer range 1 to 10;</p><p><b> begin </b></p>
61、<p> if clkk'event and clkk='1' then</p><p> if cnt=5 then</p><p><b> cnt:=1;</b></p><p> full<='1';</p><p><b> els
62、e </b></p><p> cnt:=cnt+1;</p><p> full<='0';</p><p><b> end if;</b></p><p><b> end if;</b></p><p> end proce
63、ss p_reg;</p><p> p_div:process(full)</p><p> variable cnt2:std_logic;</p><p><b> begin</b></p><p> if full'event and full='1' then</p>
64、;<p> cnt2:=not cnt2;</p><p> if cnt2='1' then</p><p><b> y<='1';</b></p><p><b> else</b></p><p><b> y<=
65、'0';</b></p><p><b> end if;</b></p><p><b> end if;</b></p><p> end process p_div;</p><p><b> end;</b></p>&
66、lt;p> 對該程序仿真的波形如下:</p><p> 圖3.1 總體仿真波形</p><p><b> 3.2 引腳分配</b></p><p> 圖3.2 引腳分配圖</p><p><b> 實(shí)驗(yàn)總結(jié)與體會</b></p><p><b>
溫馨提示
- 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 函數(shù)發(fā)生器課程設(shè)計(jì)報(bào)告
- 函數(shù)發(fā)生器課程設(shè)計(jì)報(bào)告
- 波形發(fā)生器課程設(shè)計(jì)報(bào)告
- 波形發(fā)生器課程設(shè)計(jì)報(bào)告
- 函數(shù)發(fā)生器課程設(shè)計(jì)報(bào)告
- 波形發(fā)生器課程設(shè)計(jì)報(bào)告
- 信號發(fā)生器課程設(shè)計(jì)報(bào)告
- 課程設(shè)計(jì)報(bào)告---方波發(fā)生器設(shè)計(jì)
- 信號發(fā)生器課程設(shè)計(jì)報(bào)告--函數(shù)信號發(fā)生器的設(shè)計(jì)
- 微機(jī)課程設(shè)計(jì)報(bào)告-波形發(fā)生器
- 函數(shù)信號發(fā)生器課程設(shè)計(jì)報(bào)告
- 函數(shù)信號發(fā)生器課程設(shè)計(jì)報(bào)告
- 簡易波形發(fā)生器課程設(shè)計(jì)報(bào)告
- eda課程設(shè)計(jì)報(bào)告--樂曲發(fā)生器
- 信號發(fā)生器課程設(shè)計(jì)----函數(shù)信號發(fā)生器
- eda課程設(shè)計(jì)報(bào)告--音樂發(fā)生器設(shè)計(jì)
- 信號發(fā)生器課程設(shè)計(jì)---函數(shù)發(fā)生器的設(shè)計(jì)
- 課程設(shè)計(jì)---函數(shù)信號發(fā)生器設(shè)計(jì)報(bào)告
- 課程設(shè)計(jì)--函數(shù)發(fā)生器
- 函數(shù)發(fā)生器課程設(shè)計(jì)
評論
0/150
提交評論