新聞中心

EEPW首頁 > 測試測量 > 設(shè)計應用 > FFT實時譜分析系統(tǒng)的FPGA設(shè)計和實現(xiàn)

FFT實時譜分析系統(tǒng)的FPGA設(shè)計和實現(xiàn)

作者:劉桂華, 傅佑麟, 嚴 平 時間:2008-09-12 來源:電子技術(shù)應用 收藏
2.4 旋轉(zhuǎn)因子產(chǎn)生模塊

  在一個基-4蝶形運算單元中,包含WP、W2P和W3P三個旋轉(zhuǎn)因子,每組基-4蝶形運算的第一個輸出數(shù)據(jù)所乘的旋轉(zhuǎn)因子總為1。在同一個蝶形組內(nèi),p值是不變的,因而只需確定一個p值,三個旋轉(zhuǎn)因子便可確定下來。每當一個基-4蝶形組計算完畢而轉(zhuǎn)入下一個蝶形組時,p值改變一次,其變化的順序恰好是(L-1)位四進制數(shù)順序加1的倒序輸出。由此可以根據(jù)蝶形運算的級數(shù)和四點的節(jié)點位置計算出對應的旋轉(zhuǎn)因子的角度。

  由于=cos()-jsin(),在程序中將小數(shù)cos()和-sin()轉(zhuǎn)換成定點數(shù),變換為二進制數(shù)進行計算。

  本設(shè)計的復乘運算采用實現(xiàn),需要輸入角度值作為進行復乘運算的相應旋轉(zhuǎn)因子的角度,因此旋轉(zhuǎn)因子產(chǎn)生模塊輸出的數(shù)據(jù)即對應旋轉(zhuǎn)因子的角度值,模塊中包括10位計數(shù)器和一個計算輸出進程。程序的運算流程如圖5所示。

本文引用地址:http://www.butianyuan.cn/article/88001.htm

  本設(shè)計采用直接計算旋轉(zhuǎn)因子的方法,不需要產(chǎn)生旋轉(zhuǎn)因子的讀取地址和額外的ROM資源,簡化了設(shè)計,但需要一直進行角度值的計算,增加了系統(tǒng)的運算時間。

3 實時頻譜分析系統(tǒng)的實現(xiàn)

  本設(shè)計采用Synplicity公司的邏輯綜合軟件Synplify7.1 pro進行設(shè)計綜合,用Xilinx的ISE6.1布局布線。實現(xiàn)后的系統(tǒng)的時序分析結(jié)果表示,系統(tǒng)有9.139ns的延遲,系統(tǒng)時鐘周期可達10.817ns,系統(tǒng)頻率達到92.4MHz。當系統(tǒng)頻率為90MHz時,1024點運算需要的時間大約為68.3μs,完全可以滿足實時處理的要求。本文采用Xilinx公司的Virtex-Ⅱxc2v500 fg456-5 器件實現(xiàn)系統(tǒng),設(shè)計使用資源狀況如表1所示。

  本FFT實時譜分析系統(tǒng)采用定點運算方案,輸入為12位復數(shù)數(shù)據(jù),輸出為14位復數(shù)數(shù)據(jù)。采用方波信號進行測試,其參數(shù)為:脈沖幅度H=100,脈沖寬度M=10。本FFT實時譜分析系統(tǒng)輸出的幅值如圖6所示,輸出的幅值的相對誤差如圖7所示。相對誤差較大的一些點均出現(xiàn)在標準FFT輸出的幅值很小的點上,這是由于有限字長效應引起相對誤差造成的。同時由于采用的算術(shù)運算方案是定點運算,加劇了小信號的信噪比的惡化。但在實際應用中這些輸出幅值很小的點會被判別為頻譜上的噪聲點,對實際的頻譜分析影響不大,故對系統(tǒng)的誤差影響并不大。而在標準FFT輸出的幅值較大的點上,相對誤差則很小。

  本設(shè)計全部由VHDL語言實現(xiàn),采用自頂向下的設(shè)計方法,完成了一個1024點FFT實時譜分析系統(tǒng)。該FFT采用了基-4原位算法,既保證了運算速度,又節(jié)省了硬件資源。該FFT通過實現(xiàn)復乘,較傳統(tǒng)的復乘運算節(jié)省了大量的ROM資源,同時采用了流水線結(jié)構(gòu),加快了運算速度。

參考文獻

1 劉淩,胡永生. 數(shù)字信號處理的實現(xiàn). 北京:清華大學出版社,2002
2 李廣軍,孟憲元. 可編程ASIC 設(shè)計及應用[M].成都:電子科技大學出版社,2000
3 劉朝暉, 韓月秋.用 實現(xiàn)FFT 的研究[J].北京:北京理工大學學報,1999;19(2):234~238
4 Volder J E.The CORDIC Trigonometric Computing Technique IRE.Trans.on Electronic Computer,1959(9)


上一頁 1 2 下一頁

評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉