<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

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

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

作者: 時(shí)間:2013-01-25 來(lái)源:網(wǎng)絡(luò ) 收藏

首先是將頻率分頻,產(chǎn)生1HZ頻率,程序如下:

本文引用地址:http://dyxdggzs.com/article/189696.htm

-------------------------------------------------------------------
-- 說(shuō)明: 分頻模塊,將標準輸入頻率分頻為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; --運算符重載的一個(gè)頭文件


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

其次是測頻控制模塊,主要用來(lái)產(chǎn)生1S的閘門(mén)信號,如下:

-------------------------------------------------------------------
-- 說(shuō)明: 測頻控制模塊
-- 文件: 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; --運算符重載的一個(gè)頭文件


--實(shí)體描述部分
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語(yǔ)句放在進(jìn)程中
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; --進(jìn)程結束
CNT_EN = Q ;
LOAD = NOT Q ;
END bhv; --結束結構體

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

-------------------------------------------------------------------
-- 說(shuō)明: 1位十進(jìn)制計數器模塊
-- 文件: 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; --運算符重載的一個(gè)頭文件


--實(shí)體描述部分
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 );--定義四位寬的矢量型信號節點(diǎn)

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


上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: FPGA 賽靈思 頻率計設

評論


相關(guān)推薦

技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>