《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 通信與網(wǎng)絡(luò) > 設(shè)計(jì)應(yīng)用 > 基于Xilinx FPGA IP核的FFT算法的設(shè)計(jì)與實(shí)現(xiàn)
基于Xilinx FPGA IP核的FFT算法的設(shè)計(jì)與實(shí)現(xiàn)
摘要: 摘要本文介紹了一種基于XilinxIP核的FFT算法的設(shè)計(jì)與實(shí)現(xiàn)方法。在分析FFT算法模塊圖的基礎(chǔ)上,以XilinxSpartan-3ADSP系列FPGA為平臺(tái),通過(guò)調(diào)用FFTIP核,驗(yàn)證FFT算法在中低端FPGA中的可行性和可靠性。1FFT算
關(guān)鍵詞: Xilinx 算法 FFT IP核 DSP FPGA
Abstract:
Key words :

摘要
本文介紹了一種基于Xilinx IP核的FFT算法的設(shè)計(jì)與實(shí)現(xiàn)方法。在分析FFT算法模塊圖的基礎(chǔ)上,以Xilinx Spartan-3A
DSP系列FPGA為平臺(tái),通過(guò)調(diào)用FFT IP核,驗(yàn)證FFT算法在中低端FPGA中的可行性和可靠性。

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

2 Xilinx FFT IP核功能實(shí)現(xiàn)
Xilinx IP核功能是基于復(fù)雜系統(tǒng)功能的硬件描述語(yǔ)言(HDL)設(shè)計(jì)文件,這些驗(yàn)證的功能對(duì)于所有的Xilinx FPGA器件的結(jié)構(gòu)都能夠達(dá)到最優(yōu)化,且提供硬件描述語(yǔ)言(VHDL,Verilog)的功能仿真模型,可以在標(biāo)準(zhǔn)EDA仿真工具中進(jìn)行設(shè)計(jì)和調(diào)試。

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

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

對(duì)于Burst I/O結(jié)構(gòu),使用DIT抽取法;流水線,Streaming I/O結(jié)構(gòu)則使用DIF抽取法。

在實(shí)際硬件操作中,模塊的執(zhí)行速度是很重要的參數(shù),因此本文進(jìn)行的是基于流水線,Streaming I/O結(jié)構(gòu)的仿真驗(yàn)證,進(jìn)行連續(xù)的數(shù)據(jù)處理。流水線,Streaming I/O結(jié)構(gòu)對(duì)一系列基2蝶形處理引擎采用流水線技術(shù)設(shè)計(jì),且每個(gè)蝶形處理引擎都有自己獨(dú)立的存儲(chǔ)體對(duì)輸入數(shù)據(jù)和中間數(shù)據(jù)進(jìn)行存儲(chǔ)(如圖1)。這種結(jié)構(gòu)下,F(xiàn)FT IP核具有同時(shí)處理當(dāng)前幀N點(diǎn)數(shù)據(jù),載入下一幀N點(diǎn)數(shù)據(jù),輸出前一幀N點(diǎn)數(shù)據(jù)的能力。

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

對(duì)于全精度無(wú)壓縮結(jié)構(gòu),數(shù)據(jù)通道內(nèi)任意一位有意義的整數(shù)都將被保留,在運(yùn)算過(guò)程中產(chǎn)生的小數(shù)部分都被截?cái)嗷蛘呷≌4朔N結(jié)構(gòu),對(duì)于定點(diǎn)算法,經(jīng)過(guò)多級(jí)乘法操作以后,數(shù)據(jù)位寬將加倍遞增,其輸出位寬為(輸入位寬+log2(數(shù)據(jù)轉(zhuǎn)換長(zhǎng)度)+1)bits。

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

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

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

壓縮比例Scale_SCH的位寬,對(duì)于流水線,Streaming I/O結(jié)構(gòu)和基4,Burst I/O結(jié)構(gòu),為2*ceil(0.5*log2(N));對(duì)于基2,Burst I/O結(jié)構(gòu)和基2 Lite Burst I/O結(jié)構(gòu),為2* log2(N),其中N為轉(zhuǎn)換數(shù)據(jù)長(zhǎng)度。

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

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

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

4 結(jié)語(yǔ)
本文主要通過(guò)對(duì)FFT IP核的整體測(cè)試,驗(yàn)證FFT算法在中低端FPGA中的可行性和可靠性。在選用流水線結(jié)構(gòu)實(shí)現(xiàn)FFT的基礎(chǔ)上,采用定點(diǎn)壓縮結(jié)構(gòu),減少了數(shù)據(jù)的讀取和處理時(shí)間,更好的滿足了FFT處理數(shù)據(jù)的需要。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
激情久久中文字幕| 一二三四社区欧美黄| 欧美日韩成人| 蜜桃久久精品乱码一区二区| 欧美中文在线免费| 午夜久久99| 亚洲欧美日韩一区在线观看| 亚洲婷婷在线| 一区二区av| 在线亚洲精品| 亚洲香蕉在线观看| 亚洲综合国产| 午夜免费久久久久| 新片速递亚洲合集欧美合集| 亚洲在线不卡| 午夜精品www| 新67194成人永久网站| 欧美一区二区三区精品| 欧美一级免费视频| 久久av红桃一区二区小说| 欧美一区国产二区| 久久国产免费看| 久久夜色精品国产噜噜av| 久久看片网站| 欧美成人精品在线| 欧美日韩免费在线| 国产精品视频免费一区| 国产伦精品一区二区三区在线观看 | 欧美v日韩v国产v| 欧美精品高清视频| 欧美日韩视频专区在线播放| 欧美涩涩视频| 国产精品视频一区二区高潮| 国产欧美精品一区二区色综合| 国产日韩成人精品| 国内自拍一区| 亚洲日本欧美| 亚洲一区国产一区| 久久精品72免费观看| 最新亚洲电影| 亚洲愉拍自拍另类高清精品| 欧美一区午夜精品| 欧美xxx在线观看| 欧美日韩直播| 国产欧美一区二区在线观看| 在线免费日韩片| 日韩亚洲成人av在线| 午夜在线观看欧美| 亚洲另类自拍| 午夜精品一区二区三区在线播放| 久久久久一本一区二区青青蜜月| 欧美激情一区二区三区不卡| 国产精品久久99| 一区免费观看| 这里只有视频精品| 久久精品av麻豆的观看方式| 一区二区电影免费观看| 久久国产视频网| 欧美人交a欧美精品| 国产欧美欧洲在线观看| 亚洲高清一区二区三区| 亚洲伊人伊色伊影伊综合网| 亚洲国产成人精品久久久国产成人一区| 一区二区不卡在线视频 午夜欧美不卡'| 欧美专区中文字幕| 欧美二区在线播放| 国产欧美va欧美va香蕉在| 亚洲电影在线播放| 亚洲男人的天堂在线| 亚洲精品日韩激情在线电影| 午夜欧美大片免费观看| 欧美福利视频在线| 国产亚洲美州欧州综合国| 亚洲免费观看| 亚洲福利av| 亚洲自拍高清| 欧美激情一区二区三级高清视频| 国产精品制服诱惑| 日韩一级免费观看| 久久精品视频亚洲| 欧美亚洲一级| 欧美欧美天天天天操| 狠狠色综合网| 亚洲欧美在线播放| 亚洲午夜性刺激影院| 欧美1区视频| 国产自产在线视频一区| 亚洲一区欧美| 亚洲午夜久久久久久尤物| 欧美大片网址| 激情文学综合丁香| 亚洲欧美日韩国产另类专区| 亚洲视频精品| 欧美国产日韩二区| 精品福利免费观看| 欧美在线关看| 欧美影院成人| 国产精品欧美日韩一区二区| 亚洲免费观看高清在线观看 | 国内精品写真在线观看| 亚洲香蕉在线观看| 一区二区三区国产精华| 欧美黄色片免费观看| 黄色成人在线网站| 欧美一区亚洲二区| 欧美在线影院在线视频| 国产精品国产三级国产专播精品人| 亚洲精品国产日韩| 亚洲精品欧洲| 欧美高清hd18日本| 亚洲国产精品综合| 亚洲精品午夜| 欧美xxxx在线观看| 亚洲国产精品123| 亚洲精品一二三| 欧美承认网站| 亚洲日本一区二区| 一区二区三区黄色| 欧美日韩亚洲综合在线| 日韩视频免费| 亚洲一区二区三区精品在线观看| 欧美日韩中文字幕精品| 99精品国产热久久91蜜凸| 亚洲一区二区三区精品视频| 欧美视频一区在线| 在线视频精品| 午夜老司机精品| 国产日韩欧美| 欧美一区在线视频| 久久在线免费| 一区视频在线播放| 亚洲精品视频免费观看| 欧美日本国产| 亚洲一二三级电影| 欧美在线播放视频| 激情亚洲成人| 亚洲精品乱码久久久久久蜜桃91| 欧美久久电影| 一区二区欧美日韩视频| 午夜精品美女久久久久av福利| 国产欧美午夜| 亚洲第一成人在线| 欧美国产精品人人做人人爱| 亚洲理论在线观看| 亚洲在线一区二区| 国产日本欧美在线观看 | 久久欧美中文字幕| 亚洲福利国产精品| 亚洲天堂偷拍| 国产伦精品一区二区三区照片91 | 亚洲福利精品| 欧美理论电影在线播放| 一区二区免费在线播放| 欧美一区二区福利在线| 激情一区二区三区| 一本大道久久a久久精品综合 | 国产精品女人网站| 亚洲大片免费看| 欧美日韩精品一区二区天天拍小说| 亚洲丝袜av一区| 久久久国际精品| 亚洲精品欧美一区二区三区| 午夜一区在线| 在线日韩中文| 午夜免费在线观看精品视频| 黄色小说综合网站| 亚洲一二三区精品| 狠狠综合久久av一区二区小说| 夜夜嗨av一区二区三区中文字幕| 国产欧美日韩一区二区三区在线 | 午夜精品区一区二区三| 在线观看日韩av电影| 亚洲一级特黄| 伊人一区二区三区久久精品| 亚洲视频一区二区| 国产一区二区三区成人欧美日韩在线观看 | 久久精品九九| 欧美午夜在线一二页| 久久精品国产一区二区电影| 欧美日韩性生活视频| 久久精品99久久香蕉国产色戒| 欧美日韩一区二区三区在线看| 久久精品国产69国产精品亚洲| 欧美日韩一区二区三区免费| 欧美伊人久久| 欧美无乱码久久久免费午夜一区 | 亚洲欧洲在线一区| 欧美在线播放| 日韩一区二区免费看| 亚洲一区二区三区高清不卡| 国产精品vvv| 亚洲精品中文字幕女同| 国产亚洲精品aa午夜观看| 一区二区三区四区五区精品| 激情综合自拍| 欧美一区二区免费| 在线亚洲高清视频| 欧美人与性禽动交情品| 亚洲第一精品福利| 国产老肥熟一区二区三区|