VHDL八位數(shù)碼管頻率計(jì)課程設(shè)計(jì)_第1頁(yè)
VHDL八位數(shù)碼管頻率計(jì)課程設(shè)計(jì)_第2頁(yè)
VHDL八位數(shù)碼管頻率計(jì)課程設(shè)計(jì)_第3頁(yè)
VHDL八位數(shù)碼管頻率計(jì)課程設(shè)計(jì)_第4頁(yè)
VHDL八位數(shù)碼管頻率計(jì)課程設(shè)計(jì)_第5頁(yè)
已閱讀5頁(yè),還剩9頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、一、課程設(shè)計(jì)要求設(shè)計(jì)一個(gè)8位數(shù)碼管顯示的頻率計(jì)(頻率分辨率為1Hz)。二、總體結(jié)構(gòu)框圖圖1 總體結(jié)構(gòu)框圖三、課程設(shè)計(jì)原理在電子技術(shù)中,頻率是最基本的參數(shù)之一,并且與許多點(diǎn)參量的測(cè)量方案、測(cè)量結(jié)果都有十分密切的關(guān)系,因此,頻率的測(cè)量就顯得尤為重要。測(cè)量頻率的方法有很多種,其中電子計(jì)數(shù)器測(cè)量頻率具有精度高、使用方便、測(cè)量迅速,以及便于實(shí)現(xiàn)測(cè)量過(guò)程自動(dòng)化等優(yōu)點(diǎn),是頻率測(cè)量的重要手段之一。數(shù)字式頻率計(jì)的測(cè)量原理有兩類:一是直接測(cè)頻法,即在一定的閘門時(shí)間內(nèi)測(cè)量被測(cè)信號(hào)的脈沖個(gè)數(shù);二是間接測(cè)頻法即周期法,如周期測(cè)頻法。直接測(cè)頻法適用于高頻信號(hào)的頻率測(cè)量,通常采用計(jì)數(shù)器、數(shù)據(jù)鎖存器及控制電路實(shí)現(xiàn),并通過(guò)改變

2、計(jì)數(shù)閥門的時(shí)間長(zhǎng)短以達(dá)到不同的測(cè)量精度;間接測(cè)頻法適用于低頻信號(hào)的頻率測(cè)量。本次課程設(shè)計(jì)中使用的是直接測(cè)頻法,即用計(jì)數(shù)器在計(jì)算機(jī)1s內(nèi)輸入信號(hào)周期的個(gè)數(shù),其測(cè)頻范圍為0Hz-99999999Hz。四、器件的選擇1、裝有QuartusII軟件的計(jì)算機(jī)一臺(tái)。2、芯片:本實(shí)驗(yàn)板中為EP芯片。3、EDA實(shí)驗(yàn)箱一個(gè)。4、下載接口是數(shù)字芯片的下載接口(JTAG)主要用于FPGA芯片的數(shù)據(jù)下載。5、時(shí)鐘源。五、功能模塊和信號(hào)仿真圖以及源程序(1) 系統(tǒng)時(shí)鐘分頻及控制的功能模塊圖及其源程序 圖2 功能模塊圖作用:將試驗(yàn)箱上的50MHz的晶振分頻,輸出CLOCK為數(shù)碼管提供1kHz的動(dòng)態(tài)掃描頻率。CNT_EN輸

3、出為0.05s的信號(hào),對(duì)頻率計(jì)中的32位十進(jìn)制計(jì)數(shù)器CNT10的ENA使能端進(jìn)行同步控制,當(dāng)TSTEN高電平時(shí)允許計(jì)數(shù),低電平時(shí)停止計(jì)數(shù),并保持其所計(jì)的脈沖數(shù)。在停止計(jì)數(shù)期間,首先需要一個(gè)鎖存信號(hào)LOAD的上跳沿將計(jì)數(shù)器在前一秒的計(jì)數(shù)值鎖存進(jìn)鎖存器REG32B中,并由外部的十進(jìn)制7段數(shù)碼管顯示計(jì)數(shù)值。設(shè)置鎖存器的好處是數(shù)據(jù)顯示穩(wěn)定,不會(huì)由于周期性的清零信號(hào)而不斷閃爍。鎖存信號(hào)后,必須有一個(gè)清零信號(hào)RST_CNT對(duì)計(jì)數(shù)器進(jìn)行清零,為下一秒的計(jì)數(shù)操作做準(zhǔn)備。該模塊的信號(hào)仿真圖如下:圖3 仿真波形圖源程序如下:-分頻library ieee;use ieee.std_logic_1164.all;e

4、ntity fdivwangzheng isport(clk0:in std_logic; -輸入系統(tǒng)時(shí)鐘 clk1:out std_logic; -輸出1hz時(shí)鐘信號(hào) clk2:out std_logic); -輸出顯示掃描時(shí)鐘信號(hào) end fdivwangzheng;architecture a of fdivwangzheng isbegin p1:process(clk0)variable cnt:integer range 0 to 49999999; -分頻系數(shù)為24999999variable ff:std_logic;beginif clk0'event and clk

5、0='1' thenif cnt<49999999 thencnt:=cnt+1;elsecnt:=0;ff:=not ff; -反向end if;end if;clk1<=ff;end process p1;p2:process(clk0) variable cnn:integer range 0 to 999; -分頻系數(shù)為499variable dd:std_logic;beginif clk0'event and clk0='1' thenif cnn<999 thencnn:=cnn+1;elsecnn:=0;dd:=not

6、dd; -反向end if;end if;clk2<=dd;end process p2;end a;-測(cè)頻控制器(testctl.vhd)LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY TESTCTLwanzheng IS PORT ( CLKK : IN STD_LOGIC; - 1Hz CNT_EN,RST_CNT,LOAD : OUT STD_LOGIC); END TESTCTLwanzheng;ARCHITECTURE behav OF TESTCTLwanzhe

7、ng IS SIGNAL DIV2CLK : STD_LOGIC;BEGIN PROCESS( CLKK ) BEGIN IF CLKK'EVENT AND CLKK = '1' THEN DIV2CLK <= NOT DIV2CLK; END IF; END PROCESS; PROCESS (CLKK, DIV2CLK) BEGIN IF CLKK='0' AND Div2CLK='0' THEN RST_CNT <= '1' ELSE RST_CNT <= '0' END IF; E

8、ND PROCESS; LOAD <= NOT DIV2CLK ; CNT_EN <= DIV2CLK;END behav;(2) 十進(jìn)制計(jì)數(shù)器的功能模塊圖及其源程序圖4 功能模塊圖作用:當(dāng)使能端為高電平,清零端為低電平時(shí),實(shí)現(xiàn)十進(jìn)制計(jì)數(shù)功能。第一個(gè)CNT10計(jì)數(shù)輸出CQ=9時(shí),下一秒時(shí)鐘上升沿到來(lái)時(shí),將產(chǎn)生一個(gè)CARRY_OUT信號(hào)作為下一個(gè)CNT10的時(shí)鐘信號(hào),同時(shí)CQ清零,依次遞推到8個(gè)CNT10。當(dāng)清零端為低電平,使能端為低電平時(shí)停止計(jì)數(shù)。當(dāng)清零端為高電平時(shí),計(jì)數(shù)器清零。該模塊的信號(hào)仿真圖如下:圖5 仿真波形圖源程序如下:LIBRARY IEEE;USE IEEE.STD_

9、LOGIC_1164.ALL;ENTITY CNT10 ISPORT(CLK: IN STD_LOGIC; CLR: IN STD_LOGIC; ENA: IN STD_LOGIC; CQ : OUT INTEGER RANGE 0 TO 9; CARRY_OUT: OUT STD_LOGIC);END CNT10;ARCHITECTURE behav OF CNT10 ISSIGNAL CQI: INTEGER RANGE 0 TO 9;BEGINPROCESS(CLR,CLK,ENA)BEGINIF(CLR='1') THEN CQI<=0;ELSIF(CLK'

10、;EVENT AND CLK='1') THEN IF(ENA='1') THEN IF(CQI=9) THEN CQI<=0; CARRY_OUT<='1' ELSE CQI<=CQI+1; CARRY_OUT<='0' END IF; END IF;END IF;END PROCESS;CQ<=CQI;END behav;(3) 32位鎖存器的功能模塊圖及其源程序圖6 功能模塊圖實(shí)現(xiàn)方式:LOAD信號(hào)上升沿到來(lái)時(shí)將對(duì)輸入到內(nèi)部的CNT10計(jì)數(shù)信號(hào)進(jìn)行鎖存。作用:鎖存信號(hào),并將結(jié)果輸出給SELTIM

11、E。該模塊的信號(hào)仿真圖如下:圖7 仿真波形圖源程序如下:LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY REG32B IS PORT(LOAD: IN STD_LOGIC;DIN: IN STD_LOGIC_VECTOR(31 DOWNTO 0);DOUT: OUT STD_LOGIC_VECTOR(31 DOWNTO 0 );END ENTITY REG32B;ARCHITECTURE behav OF REG32B ISBEGIN PROCESS(LOAD,DIN) ISBEGIN IF LOAD'EVENT AND LOAD=

12、9;1' THEN DOUT<=DIN; END IF;END PROCESS;END ARCHITECTURE behav;(4) 數(shù)碼管掃描的功能模塊圖及其源程序圖8 功能模塊圖作用:鎖存信號(hào)輸出DIN31.0,然后由SELTIME進(jìn)行掃描輸出,當(dāng)SEL為”000”時(shí)選通第一個(gè)CNT10,輸出到LED7進(jìn)行譯碼輸出。依次類推。該模塊的信號(hào)仿真圖如下:圖9 仿真波形圖源程序如下:LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY SELTIME ISPORT( CLK :

13、 IN STD_LOGIC; DIN : IN STD_LOGIC_VECTOR(31 DOWNTO 0); DAOUT: OUT STD_LOGIC_VECTOR(3 DOWNTO 0); SEL : OUT STD_LOGIC_VECTOR(2 DOWNTO 0);END SELTIME;ARCHITECTURE behav OF SELTIME ISSIGNAL SEC : STD_LOGIC_VECTOR(2 DOWNTO 0);BEGINPROCESS(CLK)BEGIN IF(CLK'EVENT AND CLK='1') THEN IF(SEC="

14、111") THEN SEC<="000" ELSE SEC<=SEC+1; END IF; END IF;END PROCESS;PROCESS(SEC,DIN(31 DOWNTO 0)BEGINCASE SEC ISWHEN "000"=>DAOUT<=DIN(3 DOWNTO 0);WHEN "001"=>DAOUT<=DIN(7 DOWNTO 4);WHEN "010"=>DAOUT<=DIN(11 DOWNTO 8);WHEN "011&

15、quot;=>DAOUT<=DIN(15 DOWNTO 12);WHEN "100"=>DAOUT<=DIN(19 DOWNTO 16);WHEN "101"=>DAOUT<=DIN(23 DOWNTO 20);WHEN "110"=>DAOUT<=DIN(27 DOWNTO 24);WHEN "111"=>DAOUT<=DIN(31 DOWNTO 28);WHEN OTHERS=>NULL;END CASE;END PROCESS;SEL<=

16、SEC;END behav;(5) 七段數(shù)碼管譯碼顯示的功能模塊圖及其源程序圖10 功能模塊圖作用:將實(shí)驗(yàn)結(jié)果使用數(shù)碼管直觀的顯示出來(lái)。該模塊的信號(hào)仿真圖如下:圖11 仿真波形圖源程序如下:LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;ENTITY LED7 ISPORT(DIN:IN STD_LOGIC_VECTOR(3 DOWNTO 0);DOUT:OUT STD_LOGIC_VECTOR(6 DOWNTO 0);END LED7;ARCHITECTURE behav OF LED7 IS-

17、SIGNAL LED7:STD_LOGIC_VECTOR(6 DOWNTO 0);BEGINPROCESS(DIN)BEGINCASE DIN ISWHEN "0000"=>DOUT<="0111111"WHEN "0001"=>DOUT<="0000110"WHEN "0010"=>DOUT<="1011011"WHEN "0011"=>DOUT<="1001111"WHEN "

18、;0100"=>DOUT<="1100110"WHEN "0101"=>DOUT<="1101101"WHEN "0110"=>DOUT<="1111101"WHEN "0111"=>DOUT<="0000111"WHEN "1000"=>DOUT<="1111111"WHEN "1001"=>DOUT<="

19、;1101111"WHEN "1010"=>DOUT<="1110111"WHEN "1011"=>DOUT<="1111100"WHEN "1100"=>DOUT<="0111001"WHEN "1101"=>DOUT<="1011110"WHEN "1110"=>DOUT<="1111001"WHEN "1111&

20、quot;=>DOUT<="1110001"WHEN OTHERS=>NULL;END CASE;END PROCESS;END ARCHITECTURE behav;(6) 3-8譯碼器的功能模塊圖及其源程序圖12 功能模塊圖作用:利用3-8譯碼器將數(shù)碼管的位選信號(hào)選通。該模塊的信號(hào)仿真圖如下:圖13 仿真波形圖源程序如下:LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;ENTITY LS138 IS PORT(Q: IN STD_LOGIC_VECTOR(2 DOWNTO 0); D: OUT STD_LOGIC_VE

21、CTOR(7 DOWNTO 0); dp:OUT STD_LOGIC);END LS138;ARCHITECTURE behav OF LS138 ISBEGIN WITH Q SELECT D<="11111110" WHEN "000","11111101" WHEN "001","11111011" WHEN "010","11110111" WHEN "011","11101111" WHEN &quo

22、t;100","11011111" WHEN "101","10111111" WHEN "110","01111111" wHEN "111","11111111" WHEN OTHERS;WITH Q SELECT dp<='1' WHEN "001",'0' WHEN OTHERS;END behav;6、 頂層模塊圖圖14 總體設(shè)計(jì)頂層模塊圖其中8個(gè)十進(jìn)制計(jì)數(shù)器模塊JSQ的底層模塊

23、圖如圖15所示:圖15 計(jì)數(shù)器模塊原理圖 本次課程設(shè)計(jì)的時(shí)鐘信號(hào)由試驗(yàn)箱上面的5MHz的晶振提供,經(jīng)過(guò)系統(tǒng)時(shí)鐘和控制模塊后分別產(chǎn)生0.05Hz和10kHz的脈沖信號(hào)0.05Hz的脈沖信號(hào)十進(jìn)制計(jì)數(shù)器的使能信號(hào),使計(jì)數(shù)器統(tǒng)計(jì)出待測(cè)信號(hào)在1s脈寬之間的脈沖數(shù)目。再由計(jì)數(shù)模塊將測(cè)得的信號(hào)傳送給數(shù)碼管顯示部分,通過(guò)譯碼模塊產(chǎn)生可以在數(shù)碼管上顯示的BCD碼。而1kHz是作為數(shù)碼管動(dòng)態(tài)掃描的頻率,由于人的視覺(jué)暫留現(xiàn)象,頻率較高時(shí),數(shù)碼管看起來(lái)就是連續(xù)發(fā)光。本設(shè)計(jì)中使個(gè)位顯示為數(shù)碼管的小數(shù)點(diǎn)后面一位,由此實(shí)現(xiàn)了頻率分辨率為1Hz的頻率計(jì)設(shè)計(jì)。結(jié)論EDA技術(shù)是電子設(shè)計(jì)的發(fā)展趨勢(shì),利用EDA工具可以代替設(shè)計(jì)者完成電子系統(tǒng)設(shè)計(jì)中的大部分工作。EDA工具從數(shù)字系統(tǒng)設(shè)計(jì)的單一領(lǐng)域,發(fā)展到今天,應(yīng)用范圍己涉及

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論