《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 設計應用 > 基于Xilinx FPGA IP核的FFT算法的設計與實現
基于Xilinx FPGA IP核的FFT算法的設計與實現
摘要: 摘要本文介紹了一種基于XilinxIP核的FFT算法的設計與實現方法。在分析FFT算法模塊圖的基礎上,以XilinxSpartan-3ADSP系列FPGA為平臺,通過調用FFTIP核,驗證FFT算法在中低端FPGA中的可行性和可靠性。1FFT算
關鍵詞: Xilinx 算法 FFT IP核 DSP FPGA
Abstract:
Key words :

摘要
本文介紹了一種基于Xilinx IP核的FFT算法的設計與實現方法。在分析FFT算法模塊圖的基礎上,以Xilinx Spartan-3A
DSP系列FPGA為平臺,通過調用FFT IP核,驗證FFT算法在中低端FPGA中的可行性和可靠性。

1 FFT算法簡介
FFT(Fast Fourier Transform)算法是計算DFT(Discrete Fourier Transform)的高效算法。算法最初由J.W.Cooley和J.W.Tukey于1965年提出,之后又有新的算法不斷涌現,總的來說發展方向有兩個:一是針對N等于2的整數次冪的算法,如基2算法、基4算法和分裂基算法等; 另一個是N不等于2 的整數次冪的算法, 如素因子算法、Winograd算法等。其中基2算法是目前所常用的FFT算法,其核心思想是將N點的序列逐次分解為(N-1)/2點,最后分解為2點DFT進行計算,從而消除DFT中大量的重復運算。FFT算法可從時域或頻域對序列進行分解:①時間抽取法(decimation in time,DIT),即直接將序列x(n)按奇、偶逐次分成奇數子序列和偶數子序列,然后通過計算子序列的DFT來實現整個序列的DFT; ② 頻率抽取法(decimation in frequency,DIF),即將頻域X(k)的序號k按照奇、偶逐次分解成偶數點子序列和奇數點子序列,然后計算子序列的DFT,得到整個頻域內的DFT。時間抽取法和頻率抽取法的計算復雜程度和所需要的計算量都是相同的,且由兩種方法不同的分解形式可知:時間抽取法需要對輸入數據序列x(n)進行重新排序,頻率抽取法需要對輸出數據序列X[k]進行進行排序。目前FFT算法已經廣泛應用于數字信號處理、圖像處理、石油勘探和地震預測等眾多領域。與此同時,為了便于FFT算法在工程實踐中的應用,各大FPGA生產商也都紛紛推出了具有相關功能的IP(Intellectual Property)模塊庫。其中由Xilinx公司研發的IP核Fast Fourier Transform V5.0提供了FFT算法多種可選的計算參數、結構、數據輸入輸出流的順序方式,可以根據用戶的需求方便地實現FFT算法。

2 Xilinx FFT IP核功能實現
Xilinx IP核功能是基于復雜系統功能的硬件描述語言(HDL)設計文件,這些驗證的功能對于所有的Xilinx FPGA器件的結構都能夠達到最優化,且提供硬件描述語言(VHDL,Verilog)的功能仿真模型,可以在標準EDA仿真工具中進行設計和調試。

Xilinx FFT IP核V5.0是Xilinx公司配套其FPGA開發工具ISE10.1推出的,其最大的系統時鐘頻率達到了550MHz,最大的數據吞吐量達到550MSPS,最高可進行65536點的FFT運算,最大輸入數據和相位因子位寬為24bit(位寬越大,動態范圍越大),支持所有的主流Xilinx FPGA芯片。同時,Xilinx FFT IP核V5.0可以實現變換長度為N點實數或復數形式的FFT變換及FFT逆變換(IFFT),N的取值范圍是(8~65536)。輸入數據實部和虛部都要以位寬為Mbits的二進制補碼(Two's-Complement)形式表示,M取值范圍是(8~24);同樣,相位因子位寬取值范圍也是(8~24)。數據、相位因子以及輸出數據重排序的緩存數據,在FFT實現的過程中,都可以用塊RAM(Block RAM)或者分布式RAM(Distributed RAM)進行存儲。對于Burst I/O結構, 塊RAM可以存儲任意點數的數據和相位因子,而分布式RAM則只能存儲點數不大于1024點的數據和相位因子;對于Streaming I/O結構,可采用混合存儲的方法,先選擇使用塊RAM存儲器的階數的數量,然后對剩余的采用分布式RAM。

Xilinx FFT IP核有四種結構可供選擇,用戶可以在邏輯資源使用的多少和轉換時間的長短之間進行取舍,具體情況分別如下。① 流水線,Streaming I/O結構:允許連續的數據處理,使用最多的邏輯資源。② 基4,Burst I/O結構:提供數據導入/導出階段和處理階段,導入數據和處理數據時單獨進行的。此結構擁有較小的結構,但是轉換時間較長。③ 基2,Burst I/O結構:使用較少的邏輯資源,同基4階段,提供兩階段的過程。④ 基2 Lite Burst I/O結構:這是一種基于基
2結構的變體,采用了時分復用的方法使用了最少的邏輯資源,但是轉換時間最長。

對于Burst I/O結構,使用DIT抽取法;流水線,Streaming I/O結構則使用DIF抽取法。

在實際硬件操作中,模塊的執行速度是很重要的參數,因此本文進行的是基于流水線,Streaming I/O結構的仿真驗證,進行連續的數據處理。流水線,Streaming I/O結構對一系列基2蝶形處理引擎采用流水線技術設計,且每個蝶形處理引擎都有自己獨立的存儲體對輸入數據和中間數據進行存儲(如圖1)。這種結構下,FFT IP核具有同時處理當前幀N點數據,載入下一幀N點數據,輸出前一幀N點數據的能力。

Xilinx FFT IP核V5.0支持三種算法類型:全精度無壓縮、塊浮點型和定點壓縮(壓縮比由用戶自定義)。

對于全精度無壓縮結構,數據通道內任意一位有意義的整數都將被保留,在運算過程中產生的小數部分都被截斷或者取整。此種結構,對于定點算法,經過多級乘法操作以后,數據位寬將加倍遞增,其輸出位寬為(輸入位寬+log2(數據轉換長度)+1)bits。

對于塊浮點型,對于一幀數據里面的任何一數據點有相同的壓縮比,這個壓縮比值由塊指數(Block Exponent)作為輸出值顯示,而且只有在FFT IP核檢測到將會產生數據溢出的時候,才會進行壓縮運算。

本文所采用的是定點壓縮結構。該結構相對于全精度無壓縮結構,能夠大大減少FPGA內部資源Xtreme DSP Slices和塊RAM的使用,而相對于塊浮點型,可靈活調節壓縮比。定點壓縮結構的壓縮比例表(Scale_SCH)完全由用戶自定義得到。壓縮比例是按照1、2、4或者8對每一階進行壓縮,即對應于分別向右移位0、1、2或者3。如果壓縮不充分,則蝶形輸出結果會超出其動態范圍,引起數據溢出。對于Burst I/O結構,Scale_SCH的表示方法:對于每一階的壓縮比都由指定的一個2bits的數表示,零階的2bits數為最低位,具體形式為[?N4,N3,N2,N1,N0],每一個2bits數分別對應著相應階數的壓縮比。例:對于基4結構,數據轉換長度N=1024,Scale_SCH=[01 10 00 1110]則表示對階0右移位2,對階1右移位3,對階2右移位0,對階3右移位2,對階4右移位1。經驗總結(可以防止產生數據溢出):對于1024點的基4,Burst I/O結構,Scale_SCH=[10 10 10 10 11];而對于1024點的基2結構,Scale_SCH=[01 01 01 01 01 01 01 01 01 10]。

對于流水線,Streaming I/O結構,把臨近的一對基2階組在一起,即階0和階1為組0,階2和階3為組1,等等。Scale_SCH的表示方法:對于每一組的壓縮比都由指定的一個2bits的數表示,零組的2bits數為最低位,具體形式為[?N4,N3,N2,N1,N0],每一個2bits數分別對應著相應組的壓縮比,表示同組內的兩個基2階有相同的壓縮比。例:數據長度N=1024,Scale_SCH=[10 10 00 01 11]表示對組0(階0和階1)右移位3,對組1(階2和階3)右移位1,對組2(階4和階5)沒有移位,對組3(階6和階7)右移位2,對組4(階8和階9)右移位2。若變換長度N不是4的冪次方的時候,最后一組只包含一個基2階,只能用00或者01表示。經驗總結(可以防止產生數據溢出):N=512時,Scale_SCH=[01 10 10 10 11];N=1024時,Scale_SCH=[10 10 10 10 11]。

壓縮比例Scale_SCH的位寬,對于流水線,Streaming I/O結構和基4,Burst I/O結構,為2*ceil(0.5*log2(N));對于基2,Burst I/O結構和基2 Lite Burst I/O結構,為2* log2(N),其中N為轉換數據長度。

3 FFT IP核的仿真驗證
通過例化調用Xilinx IP核來實現一個512點、數據位寬和相位因子位寬都為16bit的FFT算法模塊,時鐘頻率為50MHz(時鐘頻率越高,可以獲得更高的復用倍數,節省更多的資源面積),采用流水線,Streaming I/O和定點壓縮結構,完成在中低端FPGA上的調試,驗證其可靠性和可行性。為了方便驗證FFT IP核功能的正確性:以零開始計數,在每個時鐘上升沿到來時,進行加一運算得到的數據,分別作為其輸入信號的實部和輸入信號的虛部。Scale_SCH=[01 10 10 10 11],在ISE10.1中建工程,例化調用Xilinx FFT IP核,然后利用ModelSimSE6.5進行仿真,其仿真時序如圖2所示。

時序驗證方面:可以看出整個時序在實現中是完全正確的。從時序圖可以看出:busy信號高的的時候表明FFT IP核正在進行FFT運算,busy信號拉低后表明運算已經結束,要向外輸出FFT運算結果;edone信號在done信號之前一個周期到達;此時,done信號拉高一個周期,表明FFT運算完成;而且,由于進行的是512點的FFT運算,所以,每間隔512個時鐘周期,edone和done信號都會拉高一次;rfd信號一直拉高,表明輸入數據一直傳送到FFT IP核的輸入端口,跟采用流
水線,Streaming I/O結構,可以進行連續數據處理是一致的;dv信號一直為高,表明輸出的信號一直有效。

功能驗證方面:根據FFT IP核在流水線,Streaming I/O結構下,間隔每一幀數據需要三幀才能輸出計算結果的特點,可以推算出上面仿真圖形里面輸出結果時刻對應著[94:605]+ [94:605]*j的FFT輸出結果。把Matlab里面通過仿真得到的結果,按照Scale_SCH的比例進行壓縮,與上面得到的結果是一致的,表明了FFT IP核是正常工作的。

4 結語
本文主要通過對FFT IP核的整體測試,驗證FFT算法在中低端FPGA中的可行性和可靠性。在選用流水線結構實現FFT的基礎上,采用定點壓縮結構,減少了數據的讀取和處理時間,更好的滿足了FFT處理數據的需要。

此內容為AET網站原創,未經授權禁止轉載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
999亚洲国产精| 亚洲人成啪啪网站| 在线播放日韩专区| 国产亚洲午夜高清国产拍精品| 国产精品国产三级国产aⅴ入口| 欧美精选午夜久久久乱码6080| 牛夜精品久久久久久久99黑人 | 91久久久亚洲精品| 亚洲成色最大综合在线| 韩日成人av| 一区二区三区在线免费播放| 激情另类综合| 亚洲大胆人体视频| 亚洲国产精品久久久久婷婷884 | 亚洲欧美成人精品| 亚洲欧美日韩国产一区二区三区| 亚洲视频碰碰| 亚洲欧美久久| 欧美在线亚洲在线| 亚洲国产欧美一区二区三区同亚洲 | 亚洲精品欧美| 一本在线高清不卡dvd | 亚洲免费观看高清完整版在线观看| 亚洲精品婷婷| 亚洲一区二区三区精品在线| 亚洲综合国产精品| 久久xxxx精品视频| 久热精品视频在线观看| 欧美成人黄色小视频| 欧美日韩国产麻豆| 国产精品毛片| 黄色日韩网站| 亚洲全部视频| 亚洲免费视频一区二区| 久久精品视频一| 日韩一本二本av| 亚洲自啪免费| 久久亚洲春色中文字幕久久久| 欧美电影在线观看完整版| 欧美日韩亚洲一区二区三区在线观看 | 亚洲精品久久久久久久久久久久久 | 亚洲伊人色欲综合网| 久久er精品视频| 99精品热6080yy久久 | 久久久久国产精品一区三寸| 欧美成人四级电影| 欧美色图麻豆| 好吊日精品视频| 日韩一区二区精品葵司在线| 午夜伦理片一区| 亚洲精品一区二区三区av| 午夜一区二区三区在线观看| 老司机67194精品线观看| 欧美亚洲成人免费| 韩国av一区| 一区二区欧美日韩| 欧美一区二区三区另类| 一区二区三区免费观看| 久久久久免费视频| 欧美日韩国内| 国语自产精品视频在线看抢先版结局 | 亚洲国产婷婷香蕉久久久久久99| 亚洲午夜日本在线观看| 亚洲日本免费电影| 欧美在线高清视频| 欧美日韩人人澡狠狠躁视频| 国产一区二区剧情av在线| 亚洲美女性视频| 欧美资源在线| 亚洲综合国产| 欧美人交a欧美精品| 国模一区二区三区| 宅男66日本亚洲欧美视频| 亚洲国产成人久久综合| 亚洲一区二区三区四区在线观看| 久热精品在线视频| 国产精品夜色7777狼人| 亚洲精品一级| 亚洲欧洲在线一区| 久久精品国产综合精品| 欧美日韩一区二区国产| 在线日韩一区二区| 欧美在线|欧美| 午夜激情一区| 欧美日韩三级| 亚洲品质自拍| 亚洲国产成人在线视频| 久久精品盗摄| 国产欧美日韩一区| 国产精品99久久不卡二区| 亚洲精品午夜精品| 久久综合给合| 国产一区二区三区在线观看网站 | 欧美一区二区精品在线| 欧美视频在线不卡| 亚洲激情欧美激情| 亚洲激情一区二区三区| 久久精品一区二区三区不卡| 国产精品丝袜xxxxxxx| 夜夜嗨一区二区| 中文在线一区| 欧美日韩另类视频| 亚洲精品日韩欧美| 99精品热视频只有精品10| 欧美国产日韩免费| 亚洲精华国产欧美| 亚洲毛片视频| 欧美另类变人与禽xxxxx| 91久久国产综合久久| 亚洲日本无吗高清不卡| 欧美成人a视频| 亚洲国产精品v| 亚洲精品乱码久久久久久按摩观 | 亚洲精品一区二区三区av| 欧美1区3d| 亚洲国产欧美在线| av不卡在线看| 欧美日韩免费高清一区色橹橹| 亚洲国产欧美日韩另类综合| 亚洲精品韩国| 欧美激情亚洲一区| 亚洲乱码国产乱码精品精可以看 | 亚洲成人自拍视频| 久久亚洲色图| 亚洲成在人线av| 亚洲精品日韩综合观看成人91| 欧美va亚洲va香蕉在线| 亚洲经典三级| 中文国产成人精品久久一| 欧美三级在线播放| 亚洲视频在线观看三级| 香蕉亚洲视频| 黄色精品免费| 亚洲理论在线观看| 欧美日韩三级在线| 亚洲色图综合久久| 欧美在线观看一二区| 伊人成年综合电影网| 日韩亚洲欧美高清| 国产精品hd| 久久爱www久久做| 欧美电影在线免费观看网站| 日韩视频免费观看高清完整版| 亚洲无吗在线| 国产亚洲一本大道中文在线| 亚洲国产cao| 欧美日韩免费观看一区二区三区 | 在线视频精品一区| 国产老女人精品毛片久久| 亚洲第一搞黄网站| 欧美高清在线| 亚洲一区二区免费视频| 久久久久一本一区二区青青蜜月| 亚洲国产精品一区二区www| 亚洲一区二区在| 国产伦理一区| 亚洲国产一二三| 欧美午夜影院| 久久精品人人做人人爽| 欧美人成免费网站| 性18欧美另类| 欧美精品国产精品日韩精品| 亚洲一区二区精品在线观看| 久久夜色精品国产欧美乱| 亚洲乱码国产乱码精品精 | 免费日韩一区二区| 一区二区三区免费看| 久久久在线视频| 亚洲精选中文字幕| 久久aⅴ国产紧身牛仔裤| 亚洲日本中文字幕区| 欧美在线高清| 亚洲精品美女久久7777777| 欧美中日韩免费视频| 亚洲精品极品| 久久久91精品国产| 一区二区三区免费观看| 蜜臀91精品一区二区三区| 亚洲午夜精品视频| 欧美大片一区| 欧美一区亚洲| 欧美性天天影院| 亚洲人成人一区二区在线观看| 国产精品入口夜色视频大尺度| 亚洲日本成人| 国产一区二区在线免费观看| 亚洲一区二区三区欧美| 亚洲第一区在线| 欧美影院在线| 一区二区三区视频在线| 欧美大片在线影院| 久久国产主播精品| 国产精品资源在线观看| 一区二区三区 在线观看视| 好男人免费精品视频| 午夜免费久久久久| 一本一本久久| 欧美日韩成人综合在线一区二区| 亚洲国产高清高潮精品美女| 国产精品一区二区久久精品|