<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的NCO設計方案

基于FPGA的NCO設計方案

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

 隨著(zhù)數字通信技術(shù)的飛速發(fā)展,軟件無(wú)線(xiàn)電的應用愈加的廣泛, 而影響軟件無(wú)線(xiàn)電性能的關(guān)鍵器件數控振蕩器(Numerical CONtrolled Oscillator) 的設計至關(guān)重要直接數字頻率合成(DDS)技術(shù)是一種從相位概念出發(fā)直接合成所需要的波形的新的全數字頻率合成技術(shù)。同傳統的頻率合成技術(shù)相比,DDS 技術(shù)具有頻率精度高、轉換時(shí)間短、頻譜純度高以及頻率相位易編程、輸出的頻率穩定度與系統的時(shí)鐘穩定度相同等一系列優(yōu)點(diǎn), 廣泛應用于現代各種通信系統中,包括數字上下變頻、中頻變換、頻率合成以及擴頻系統和各種頻率相位數字調制解調系統中。

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

  在軟件無(wú)線(xiàn)電及通信領(lǐng)域, 經(jīng)常使用正交的數字信號;針對此類(lèi)應用, 本文給出了一種基于 的正交 設計方法,可以實(shí)現正交的、連續相位、高性能、高精度、可重利用的數控振蕩器,適合于多種應用場(chǎng)景的片上系統的設計。

  1 實(shí)現原理

  直接數字頻率合成(DDS)技術(shù)是一種全數字技術(shù),同傳統的頻率合成技術(shù)相比,DDS 技術(shù)具有多項優(yōu)點(diǎn): 頻率切換時(shí)間短、頻率分辨率高、相位變化連續、容易實(shí)現對輸出信號的多種調制等。

  DDS 的原理框圖如圖1 所示, 其實(shí)質(zhì)是以基準頻率源(系統時(shí)鐘)對相位進(jìn)行等間隔的采樣。由圖1 可見(jiàn),DDS 由相位累加器和波形存儲器(ROM 查詢(xún)表)構成的數控振蕩器(NCO)、數模轉換器(DAC)以及低通濾波器(LPF)3 部分組成。而DDS 的核心是NCO 的設計與實(shí)現,NCO 一般是由相位累加器和正余弦查找表兩部分組成,其中相位累加器的設計較簡(jiǎn)單,故設計NCO 的關(guān)鍵是設計正、余弦函數發(fā)生器。

  實(shí)現函數發(fā)生器的方法為查表法(LUT),對于一個(gè)相位位數為L(cháng),輸出信號幅度位數為M 的NCO,所需查找表的大小為M×2L。

  

DDS 基本原理框圖

  圖1 DDS 基本原理框圖

  在每一個(gè)時(shí)鐘周期,L 位相位累加器與其反饋值進(jìn)行累加,其結果的高N 位作為ROM 查詢(xún)表的地址,然后從ROM中讀出相應的幅度值送到DAC。低通濾波器LPF 用于濾除DAC 輸出中的高次諧波。因此通過(guò)改變頻率控制字K 就可以改變輸出頻率fout。容易得到輸出頻率fout與頻率控制字K 的關(guān)系為:fout=Kfc /2L,其中fc為相位累加器的時(shí)鐘頻率,L 為相位累加器的位數。定義當K=1 為系統頻率分辨率,即f=fc /2L。

  2 NCO 幾種常見(jiàn)設計方法

  常見(jiàn)的NCO 實(shí)現的方法目前主要有計算法、CORDIC(Coordinated RotATIon Digital Computer)算法和查表法等。

  計算法是一種以軟件編程的方式通過(guò)實(shí)時(shí)計算產(chǎn)生正弦波樣本, 該方法耗時(shí)多且只能產(chǎn)生頻率相對較低的正弦波,而需要產(chǎn)生高速的正交信號時(shí),用此方法不能很好的滿(mǎn)足要求。

  CORDIC 算法即坐標旋轉數字計算方法, 其基本思想是用一系列固定角度的不斷偏擺逼近所需旋轉的角度,實(shí)現包括乘除、平方根、三角函數、向量旋轉(即復數乘法) 以及指數運算,該算法往往需要通過(guò)乘法器和查找表才能實(shí)現多種超越函數的計算,這會(huì )導致硬件電路實(shí)現復雜、運算速度降低,此外它能夠計算的角度范圍也有限,故CORDIC 算法在實(shí)際使用時(shí)有較大的限制條件。

  在實(shí)際應用中一般采用最有效、最簡(jiǎn)單的查表法,即事先根據各個(gè)NCO 正弦波相位計算好相位的正弦值, 并以相位角度作為地址把該相位的正弦值數據存儲在表中,然后通過(guò)相位累加產(chǎn)生地址信息讀取當前時(shí)刻的相位值在表中對應的正弦值,從而產(chǎn)生所需頻率的正弦波;同時(shí)由于正余弦波形的對稱(chēng)性,只需要存儲部分數據即可完成全相位的數值輸出。這種實(shí)現方法,設計簡(jiǎn)單、運算速度較高,可以很好的滿(mǎn)足在數字變頻、擴頻、調制解調等多種場(chǎng)合的要求。

  3 正交NCO 的查找表實(shí)現方法

  基于 的正交NCO 設計原理框圖如圖2 所示,主要由3 部分組成: 可變模計數器、正余弦查找表和輸出單元3個(gè)模塊組成。

  

  圖2 NCO 的設計原理框圖

  下面以輸入的頻率控制字為1 200 Hz 為例進(jìn)行設計。

  Fre_sample, 表示系統采用時(shí)鐘;Fre_cnt_word 表示頻率控制字。

  1)可變模計數器的設計

  可變模計數器是根據頻率控制字,計算出正余弦表的查表所需的地址;同時(shí)要保證產(chǎn)生的正余弦波的相位保持連續(有些應用場(chǎng)合常常要求輸出的相位連續),即置于相應的余數值。在第1 個(gè)工作時(shí)鐘周期讀入頻率控制字,第2 個(gè)工作時(shí)鐘周期內計算出mod(Fre_sample,Fre_cnt_word)作為相位控制字,第3 個(gè)工作時(shí)鐘周期內部計數器復位置入相位控制字,第4 個(gè)時(shí)鐘周期開(kāi)始以頻率控制字為步長(cháng),相位控制字為初始值進(jìn)行計數輸出。

  2)正余弦查找表的設計

  正余弦查找表是根據可變模計數器的輸出查表得到相應載頻波形的輸出。

  基于 的NCO 設計的一個(gè)關(guān)鍵就是波形存儲器ROM 相位累加器的輸出地址作為ROM 的地址輸入,經(jīng)查表和運算后,ROM 輸出正余弦波形的量化數據; 設計中主要是要節省存儲器資源的開(kāi)銷(xiāo),即減小ROM 存儲表的空間;由于存儲表的尺寸隨著(zhù)地址位數或數據位數的增加呈現指數級遞增關(guān)系,所以在滿(mǎn)足頻率分辨率、信號性能的前提下,主要考慮較小ROM 存儲表的開(kāi)銷(xiāo);在實(shí)際的應用中,可以充分利用正余弦信號在一個(gè)周期內的對稱(chēng)性來(lái)減少ROM 存儲表的開(kāi)銷(xiāo), 例如正弦信號, 在一個(gè)周期內對于X 軸是對稱(chēng)的,基于此可以將ROM 存儲表減少至原來(lái)的1 /2, 再利用半周期內的左右對稱(chēng)性,又可以將ROM 存儲表減少至原來(lái)的1 /2,因此通過(guò)一個(gè)正弦查找表的前1 /4 周期就可以變換得到整個(gè)正弦波周期查找表,這樣就節省了3 /4 的存儲器資源。

  正余弦表的具體設計思想如下: 取頻率分辨率為df=1 Hz ; 假設頻率控制字為1 200 Hz 的頻率左右, 現考慮對1 200 Hz 的正余弦波形每一個(gè)周期采8 個(gè)樣點(diǎn),則可得采樣率為fs =1 200×8=9 600 Hz.設對于每一個(gè)樣點(diǎn)值取8 bit 量化,則每個(gè)表格共需存儲9.6 kB;(如果考慮到正、余弦信號的對稱(chēng)性,設計時(shí)可優(yōu)化為上每個(gè)表格存儲1/4 個(gè)波形即可,即每個(gè)表格只需存儲2.4 kB;)使用時(shí)是用步長(cháng)STep 來(lái)調節輸出頻率, 同時(shí)保證輸出的正余弦波的相位連續。如果每隔0樣點(diǎn)取1,即step=1,輸出頻率為1 Hz;每隔1 點(diǎn)取1,即step=2,輸出頻率為2 Hz;……;每隔1 199 點(diǎn)取1,step=1 200, 輸出頻率為1 200 Hz.

3)正余弦表的裝載

  采用Quartus 軟件中的。mif 文件格式可以方便的完成存儲表的裝載; 同時(shí)對于裝載文件的生成可以使用matlab 輸出。mif 的文件格式很方便的生成; 如下文中給出了位寬為8 bit ,深度為9 600,地址為無(wú)符號數,數據為十進(jìn)制數的9 600 個(gè)單元的mif 文件,在初始化RAM 時(shí),按照Quartus 軟件的引導直接配置即可。

  WIDTH=8;

  DEPTH=9600;

  ADDRESS_RADIX=UNS;

  DATA_RADIX=DEC;

  CONTENT BEGIN

  0 : 0;

  1 : 2;

  2 : 10;

  3 : 30;

  4 : 50;

  5 : 50;

  6 : 10;

  7 : 100;

  ……

  9598 : 0;

  9599 : 0;

  END

fpga相關(guān)文章:fpga是什么


低通濾波器相關(guān)文章:低通濾波器原理



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

關(guān)鍵詞: FPGA NCO 設計方案

評論


相關(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>