新聞中心

        EEPW首頁 > EDA/PCB > 設計應用 > 基于賽靈思FPGA的頻率計設計

        基于賽靈思FPGA的頻率計設計

        作者: 時間:2013-01-25 來源:網絡 收藏

        首先是將頻率分頻,產生1HZ頻率,程序如下:

        本文引用地址:http://www.104case.com/article/189696.htm

        -------------------------------------------------------------------
        -- 說明: 分頻模塊,將標準輸入頻率分頻為1HZ
        -- 文件: fenpin.vhd
        -- 作者:
        -- 日期: 2012/04/09
        -- 修改:
        -- 軟件: Altera QuartusII 9.0
        -- 芯片: Altera Cyclone (EP1C3T144C8)
        -------------------------------------------------------------------


        LIBRARY IEEE;
        USE IEEE.STD_LOGIC_1164.ALL;
        USE IEEE.STD_LOGIC_UNSIGNED.ALL; --運算符重載的一個頭文件


        --實體描述部分
        ENTITY fenpin IS
        PORT( --端口聲明
        CLKIN : IN STD_LOGIC;
        CLK1HZ : OUT STD_LOGIC
        );
        END fenpin;


        --結構體描述部分
        ARCHITECTURE bhv OF fenpin IS

        SIGNAL Q : STD_LOGIC;

        BEGIN
        PROCESS(CLKIN)--IF語句放在進程中
        CONSTANT shuru_05CLK :integer := 50000; --shuru_05CLK是標準輸入頻率的一半,這里使shuru_05CLK=50000,
        --就是假設標準信號是100000HZ,要根據實際輸入頻率更改這個常量
        VARIABLE CNT :integer := 0 ;
        BEGIN
        IF (CLKIN'EVENT AND CLKIN='0') THEN --功能:當時鐘下降沿到來,判斷變量CNT=shuru_05CLK的值沒有
        IF CNT=shuru_05CLK THEN -- 不等于就繼續累加,直到CNT=shuru_05CLK,此時就將信
        CNT := 0; Q = NOT Q; -- 號Q取反,并把CNT清零,也就是每shuru_05CLK(這里是
        ELSE CNT := CNT + 1;-- 50000)次時鐘變化,才讓Q變一次,達到了分頻效果。
        END IF;
        END IF;
        END PROCESS; --進程結束
        CLK1HZ = Q ;
        END bhv; --結束結構體

        其次是測頻控制模塊,主要用來產生1S的閘門信號,如下:

        -------------------------------------------------------------------
        -- 說明: 測頻控制模塊
        -- 文件: kongzhi.vhd
        -- 作者:
        -- 日期: 2012/04/09
        -- 修改:
        -- 軟件: Altera QuartusII 9.0
        -- 芯片: Altera Cyclone (EP1C3T144C8)
        -------------------------------------------------------------------


        LIBRARY IEEE;
        USE IEEE.STD_LOGIC_1164.ALL;
        --USE IEEE.STD_LOGIC_UNSIGNED.ALL; --運算符重載的一個頭文件


        --實體描述部分
        ENTITY kongzhi IS
        PORT( --端口聲明
        CLKK : IN STD_LOGIC;
        RST_CNT,CNT_EN,LOAD : OUT STD_LOGIC
        );
        END kongzhi;


        --結構體描述部分
        ARCHITECTURE bhv OF kongzhi IS

        SIGNAL Q : STD_LOGIC;

        BEGIN
        PROCESS(CLKK)--IF語句放在進程中
        BEGIN
        IF (CLKK'EVENT AND CLKK='1') THEN
        Q = NOT Q;
        END IF;
        IF CLKK='0' AND Q = '0' THENRST_CNT = '1' ;
        ELSE RST_CNT = '0';
        END IF;
        END PROCESS; --進程結束
        CNT_EN = Q ;
        LOAD = NOT Q ;
        END bhv; --結束結構體

        第三步是計數器部分,對待測信號進行頻率計數:

        -------------------------------------------------------------------
        -- 說明: 1位十進制計數器模塊
        -- 文件: CNT10.vhd
        -- 作者:
        -- 日期: 2012/04/09
        -- 修改:
        -- 軟件: Altera QuartusII 9.0
        -- 芯片: Altera Cyclone (EP1C3T144C8)
        -------------------------------------------------------------------


        LIBRARY IEEE;
        USE IEEE.STD_LOGIC_1164.ALL;
        USE IEEE.STD_LOGIC_UNSIGNED.ALL; --運算符重載的一個頭文件


        --實體描述部分
        ENTITY CNT10 IS
        PORT( --端口聲明
        CLK, CLR, EN, RESET : IN STD_LOGIC;
        COUT : OUT STD_LOGIC;
        Q : OUT STD_LOGIC_VECTOR ( 3 DOWNTO 0 )
        );
        END CNT10;


        --結構體描述部分
        ARCHITECTURE bhv OF CNT10 IS

        SIGNAL Q1 : STD_LOGIC_VECTOR ( 3 DOWNTO 0 );--定義四位寬的矢量型信號節點

        BEGIN
        PROCESS(CLR,CLK)--IF語句放在進程中
        BEGIN
        IF RESET = '0' THEN Q1 = 0000;COUT = '0'; --復位信號,當RESET為0時復位,正常為低電平
        ELSIF CLR = '1' THEN Q1 = 0000;COUT = '0'; --清零信號,當CLR為1時清零,正常為低電平
        ELSIF CLK'EVENT AND CLK = '1' THEN
        IF EN='1' THEN
        IF Q19 THEN Q1 = Q1+1;COUT = '0'; --計數器未計滿9就繼續計數
        ELSE Q1 = 0000;COUT = '1'; --計數器計滿9就清零,產生進位信號
        END IF;
        END IF;
        END IF;
        END PROCESS; --進程結束
        Q = Q1; --端口賦值
        END bhv; --結束結構體


        上一頁 1 2 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 遂昌县| 赤壁市| 崇左市| 上思县| 成武县| 英超| 临沂市| 汉沽区| 怀宁县| 台湾省| 康平县| 南陵县| 泰和县| 遂平县| 合肥市| 靖宇县| 汝州市| 崇义县| 寿宁县| 东丰县| 右玉县| 台东市| 石首市| 呼玛县| 林周县| 雷州市| 安新县| 南川市| 隆化县| 鄢陵县| 晋宁县| 长岭县| 大悟县| 沙湾县| 建平县| 修水县| 永善县| 都兰县| 尼勒克县| 荣成市| 公安县|