在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

采用FPGA芯片實(shí)現(xiàn)FFT處理器的設(shè)計(jì)

電子設(shè)計(jì) ? 來源:郭婷 ? 作者:電子設(shè)計(jì) ? 2019-01-15 10:20 ? 次閱讀

引 言

數(shù)字信號(hào)處理主要研究采用數(shù)字序列或符號(hào)序列表示信號(hào),并用數(shù)字計(jì)算方法對(duì)這些序列進(jìn)行處理,以便把信號(hào)變換成符合某種需要的形式。在現(xiàn)代數(shù)字信號(hào)處理中,最常用的變換方法就是離散傅里葉變換(DFT),然而,它的計(jì)算量較大。運(yùn)算時(shí)間長(zhǎng),在某種程度上限制了它的使用范圍。快速傅里葉變換(FFT)的提出使DFT的實(shí)現(xiàn)變得接近實(shí)時(shí),DFT的應(yīng)用領(lǐng)域也得以迅速拓展。它在圖像處理、語音分析、雷達(dá)、聲納、地震、通信系統(tǒng)、遙感遙測(cè)、地質(zhì)勘探、航空航天、生物醫(yī)學(xué)等眾多領(lǐng)域都獲得極其廣泛的應(yīng)用。隨著FPGA技術(shù)的高速發(fā)展以及EDA技術(shù)的成熟,采用FPGA芯片實(shí)現(xiàn)FFT已經(jīng)顯示出巨大的潛力。

目前用FPGA實(shí)現(xiàn)的FFT處理器結(jié)構(gòu)大致分為四種:遞歸結(jié)構(gòu)、級(jí)聯(lián)結(jié)構(gòu)、并行結(jié)構(gòu)和陣列結(jié)構(gòu)。遞歸結(jié)構(gòu)只利用一個(gè)碟形運(yùn)算單元對(duì)數(shù)據(jù)進(jìn)行規(guī)律的循環(huán)計(jì)算,使用硬件資源較少,但運(yùn)算時(shí)間較長(zhǎng)。級(jí)聯(lián)結(jié)構(gòu)每一級(jí)均采用一個(gè)獨(dú)立的碟形運(yùn)算單元來處理,相對(duì)遞歸結(jié)構(gòu)速度上有所提高,不足之處是增加了延時(shí)用的緩沖存儲(chǔ)器使用量。并行結(jié)構(gòu)對(duì)一級(jí)中的蝶形單元并行實(shí)現(xiàn),陣列結(jié)構(gòu)是將每一級(jí)的蝶形運(yùn)算單元全部并行實(shí)現(xiàn),這兩種結(jié)構(gòu)有很高的運(yùn)算速度,但消耗的資源過大,一般不采用。為了提高運(yùn)算速度,特別是為了適應(yīng)多批數(shù)據(jù)處理,一般采用級(jí)聯(lián)結(jié)構(gòu)實(shí)現(xiàn)FFT處理器。

1 FFT整體結(jié)構(gòu)設(shè)計(jì)

在FFT算法中,目前大多使用基-2和基-4算法實(shí)現(xiàn)級(jí)聯(lián)結(jié)構(gòu)的FFT處理器,除此之外,也可采用基-8和基-16算法來實(shí)現(xiàn)。隨著基數(shù)的增大,對(duì)于相同點(diǎn)數(shù)的離散數(shù)列,處理器所分的級(jí)數(shù)越少,對(duì)緩沖存儲(chǔ)器的需求也越小,因此考慮采用基-16算法來實(shí)現(xiàn)FFT處理器,但基-16算法只能實(shí)現(xiàn)離散數(shù)列點(diǎn)數(shù)是16的p次冪的FFT。從而,引入混合基思想來改進(jìn)基-16算法。

采用FPGA芯片實(shí)現(xiàn)FFT處理器的設(shè)計(jì)

設(shè)r1=16P,r2=N/16P=2,4,8,式(2)先將原非16的p次冪的N點(diǎn)FFT分解為16P點(diǎn)的FFT;再分解為N/16P點(diǎn)的FFT。首先對(duì)輸入信號(hào)進(jìn)行16P點(diǎn)的FFT運(yùn)算,然后將結(jié)果乘以一個(gè)旋轉(zhuǎn)因子最后將計(jì)算出的數(shù)據(jù)進(jìn)行一次N/16P點(diǎn)FFT運(yùn)算,得到的結(jié)果即為所需要的N點(diǎn)FFT運(yùn)算結(jié)果。這樣處理,既能減少分解的級(jí)數(shù),又能使計(jì)算離散數(shù)列點(diǎn)數(shù)只需是2的整數(shù)次冪即可。以1 024點(diǎn)為例,只需分解成兩級(jí)基-16運(yùn)算模塊和一級(jí)基-4運(yùn)算模塊即可實(shí)現(xiàn),其FFT處理器結(jié)構(gòu)圖如圖1所示。在此結(jié)構(gòu)圖的前端增加/減少基-16運(yùn)算模塊或?qū)⒆詈笠患?jí)基-4運(yùn)算模塊改為基-2或基-8運(yùn)算模塊,就可以實(shí)現(xiàn)其他離散數(shù)列的點(diǎn)數(shù)只需是2的整數(shù)次冪的FFT運(yùn)算。

2 蝶形運(yùn)算核的實(shí)現(xiàn)

2.1 基-16蝶形運(yùn)算核

如果直接將基-16蝶形運(yùn)算公式轉(zhuǎn)換到硬件中實(shí)現(xiàn)基-16運(yùn)算核,其結(jié)構(gòu)將十分復(fù)雜的。因此,采用易實(shí)現(xiàn)的頻域抽選基-4算法來實(shí)現(xiàn)頻域抽選基-16蝶形運(yùn)算核。由基-4蝶行運(yùn)算單元實(shí)現(xiàn)的基-16蝶行運(yùn)算單元如圖2所示。

采用FPGA芯片實(shí)現(xiàn)FFT處理器的設(shè)計(jì)

采用并行流水結(jié)構(gòu)實(shí)現(xiàn)的基-16運(yùn)算核,一個(gè)數(shù)據(jù)時(shí)鐘可處理16個(gè)數(shù)據(jù)。而每次蝶形運(yùn)算在一個(gè)數(shù)據(jù)時(shí)鐘內(nèi)只需要計(jì)算出一個(gè)結(jié)果,這將造成資源浪費(fèi)。因此,采用級(jí)聯(lián)結(jié)構(gòu)實(shí)現(xiàn)的基-16蝶形運(yùn)算核,用兩個(gè)基-4蝶形運(yùn)算核分別復(fù)用4次來實(shí)現(xiàn)每一級(jí)中的四個(gè)蝶行運(yùn)算,中間用一個(gè)串行出入/輸出的寄存器進(jìn)行連接,其結(jié)構(gòu)框圖如圖3所示。

采用FPGA芯片實(shí)現(xiàn)FFT處理器的設(shè)計(jì)

2.2 基-4蝶形運(yùn)算核

基-4蝶形運(yùn)算核的結(jié)構(gòu)如圖4所示,其中加減模塊為兩級(jí)流水結(jié)構(gòu),一次可以計(jì)算4個(gè)數(shù)據(jù)。蝶形運(yùn)算的四個(gè)串行輸入數(shù)據(jù)經(jīng)串/并轉(zhuǎn)換器轉(zhuǎn)換為四路并行數(shù)據(jù),進(jìn)入加減運(yùn)算單元。計(jì)算出的4個(gè)并行結(jié)果進(jìn)入并/串轉(zhuǎn)換器后,串行輸入復(fù)數(shù)乘法器和旋轉(zhuǎn)因子相乘然后輸出結(jié)果。因?yàn)閳D1中最后一級(jí)的數(shù)據(jù)只需要進(jìn)行加減運(yùn)算不需要再乘以旋轉(zhuǎn)因子,所以圖1中的基-4蝶形運(yùn)算核是沒有復(fù)數(shù)乘法器的,數(shù)據(jù)從并/串轉(zhuǎn)換器中直接輸出給緩沖存儲(chǔ)器。

2.3 復(fù)數(shù)乘法器

雖然現(xiàn)在的高端產(chǎn)中已經(jīng)集成了可以完成乘法的DSP資源,但也是有限的。因此高效復(fù)數(shù)乘法器的設(shè)計(jì)對(duì)該設(shè)計(jì)來講仍然非常的重要。復(fù)數(shù)乘法的標(biāo)準(zhǔn)式如下:

R+jI=(A+jB)×(C+jD)=(AC-BD)+j(AD+BC)

式中:A,B分別為輸人數(shù)據(jù)的實(shí)部和虛部,C和D分別為旋轉(zhuǎn)因子的實(shí)部和虛部。按照這種標(biāo)準(zhǔn)表達(dá)式,執(zhí)行一次復(fù)數(shù)乘法需要進(jìn)行4次實(shí)數(shù)乘法,2次實(shí)數(shù)加法和2次實(shí)數(shù)減法。將上述公式重新整理為:R=(C-D)·B+C(A-B),I=(C-D)A-C(A-B)優(yōu)化后的復(fù)數(shù)乘法器需要進(jìn)行3次實(shí)數(shù)乘法,2次實(shí)數(shù)加法和3次實(shí)數(shù)減法,相比傳統(tǒng)結(jié)構(gòu)多了一個(gè)減法器,少了一個(gè)乘法器。在FPGA中,加減法模塊所占用的相對(duì)裸片面積要小于相同位數(shù)的乘法器模塊。這樣的優(yōu)化還是很有價(jià)值的,在FFT吞吐量不變的情況下,可減少25%的乘法器使用量,在乘法器數(shù)量一定的情況下可高FFT吞吐量。

3 存儲(chǔ)器單元

傳統(tǒng)的級(jí)聯(lián)結(jié)構(gòu)的FFT處理器的緩沖存儲(chǔ)器都是采用乒乓結(jié)構(gòu),基本思想就是用兩塊相同的RAM交替讀出或?qū)懭霐?shù)據(jù)。即其中一塊RAM在寫入數(shù)據(jù)時(shí),另一塊RAM用于讀出數(shù)據(jù)。當(dāng)用于寫入數(shù)據(jù)的RAM寫滿時(shí)交換讀寫功能。將乒乓結(jié)構(gòu)中RAM的內(nèi)部存儲(chǔ)單元地址用二進(jìn)制數(shù)a9a8a7a6a5a4a3a2a1a0表示。以寫滿其中以塊RAM為一個(gè)周期,用一個(gè)二進(jìn)制計(jì)數(shù)器m9m8m7m6m5m4m3m2m1m0生成的順序?qū)懭耄煨蜃x取的乒乓結(jié)構(gòu)RAM的操作地址如表1所示。

采用FPGA芯片實(shí)現(xiàn)FFT處理器的設(shè)計(jì)

表1中第一,二,四塊存儲(chǔ)器的寫操作地址和讀操作地址是可以互換的,也就是將數(shù)據(jù)混序?qū)懭耄樞蜃x取。因此,根據(jù)這個(gè)規(guī)律采用一塊可同時(shí)讀寫的雙端口RAM來實(shí)現(xiàn)第一,二,四塊存儲(chǔ)器。其基本思想就是對(duì)同一個(gè)地址進(jìn)行讀和寫。以用一塊雙端口RAM實(shí)現(xiàn)第一塊存儲(chǔ)器的為例,在第一個(gè)周期內(nèi)雙端口RAM按照地址m9msm7m6m5mdm3m2m1m0進(jìn)行寫操作,即數(shù)據(jù)是按照自然順序儲(chǔ)存的。在第二個(gè)周期按照地址m0m1m2m3m4m5m6m7msm9同時(shí)進(jìn)行讀寫操作,讀出的數(shù)據(jù)按照倒位序排列,寫入的數(shù)據(jù)按照倒位序儲(chǔ)存的。 在第三個(gè)周期按照地址m9msm7m6m5m4m3m2m1m0同時(shí)進(jìn)行讀寫操作,讀出的數(shù)據(jù)按照倒位序排列,寫入的數(shù)據(jù)是按照自然順序儲(chǔ)存的。依次類推下去,讀出的數(shù)據(jù)都是按照倒位序排列。同樣第二塊和第四塊存儲(chǔ)器的存儲(chǔ)地址也具有這樣類似的循環(huán)規(guī)律。因此只有第三塊存儲(chǔ)器需要用乒乓結(jié)構(gòu)的RAM實(shí)現(xiàn),與傳統(tǒng)所有存儲(chǔ)器都用乒乓結(jié)構(gòu)RAM實(shí)現(xiàn)相比,節(jié)省了3/8的存儲(chǔ)單元。設(shè)計(jì)中用Matlab軟件直接生成旋轉(zhuǎn)因子,并將其轉(zhuǎn)化為16位有符號(hào)定點(diǎn)數(shù)寫入MIF文件。然后用ROM直接調(diào)用MIF文件,將旋轉(zhuǎn)因子預(yù)置在ROM中。

4 仿真結(jié)果

選用Altera公司生產(chǎn)的Cyclone Ⅱ的EP2C35F484C7芯片上進(jìn)行驗(yàn)證,在QuartyusⅡ7.2軟件中進(jìn)行編譯和仿真。通過對(duì)高基核的優(yōu)化處理,該設(shè)計(jì)對(duì)邏輯單元消耗量和傳統(tǒng)用基-4算法實(shí)現(xiàn)相近,僅為4 399,但由于本文采用了高基低基組合的混合基算法,在處理1 024點(diǎn)的離散數(shù)列時(shí),處理器所分的級(jí)數(shù)僅為3級(jí),相對(duì)傳統(tǒng)的低基數(shù)算法,其實(shí)現(xiàn)減少了對(duì)緩沖存儲(chǔ)器塊數(shù)的需求;并通過對(duì)緩沖存儲(chǔ)器的優(yōu)化設(shè)計(jì),又比全部用乒乓結(jié)構(gòu)RAM實(shí)現(xiàn)的傳統(tǒng)方法節(jié)省了3/8的存儲(chǔ)單元,因此占用的存儲(chǔ)資源僅為154 048 b。仿真波形如圖5所示,該仿真結(jié)果和Matlab計(jì)算結(jié)果基本一致,存在一定的誤差是由于有限字長(zhǎng)效應(yīng)引起的。

采用FPGA芯片實(shí)現(xiàn)FFT處理器的設(shè)計(jì)

5 結(jié) 語

在100 MHz的時(shí)鐘下工作,完成一次1 024點(diǎn)的FFT從輸入初始數(shù)據(jù)到運(yùn)算結(jié)果完全輸出僅需要54.48μs,且連續(xù)運(yùn)算時(shí),處理一組1 024點(diǎn)FFT的時(shí)間僅為10.24 μs,達(dá)到了高速信號(hào)處理的要求。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    19336

    瀏覽量

    230195
  • FPGA
    +關(guān)注

    關(guān)注

    1629

    文章

    21753

    瀏覽量

    604195
  • 數(shù)字信號(hào)處理

    關(guān)注

    15

    文章

    562

    瀏覽量

    45900
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    FPGA實(shí)現(xiàn)高速FFT處理器的設(shè)計(jì)

    FPGA實(shí)現(xiàn)高速FFT處理器的設(shè)計(jì)介紹了采用Xilinx公司的Virtex - II系列FPGA
    發(fā)表于 08-12 11:49

    一種基于FPGA的可配置FFT IP核實(shí)現(xiàn)設(shè)計(jì)

    多個(gè)蝶形處理器并行運(yùn)算,能對(duì)較高的數(shù)據(jù)采樣率進(jìn)行運(yùn)算,但其硬件規(guī)模較大,當(dāng)在FPGA上要實(shí)現(xiàn)較大點(diǎn)數(shù)的FFT時(shí)較為困難。(2)串行方法,采用
    發(fā)表于 07-03 07:56

    如何設(shè)計(jì)一個(gè)基于FPGA移位寄存流水線結(jié)構(gòu)的FFT處理器

    本文設(shè)計(jì)的FFT處理器,基于FPGA技術(shù),由于采用移位寄存流水線結(jié)構(gòu),實(shí)現(xiàn)了兩路數(shù)據(jù)的同時(shí)輸入
    發(fā)表于 04-28 06:32

    求一種基于FPGA的64點(diǎn)FFT處理器的設(shè)計(jì)方案

    討論了一種基于FPGA的64點(diǎn)FFT處理器的設(shè)計(jì)方案,輸入數(shù)據(jù)的實(shí)部和虛部均以16位二進(jìn)制數(shù)表示,采用基2DIT-FFT算法,以Altera
    發(fā)表于 04-29 06:25

    一種基于FPGA實(shí)現(xiàn)FFT結(jié)構(gòu)

    本文討論了一種可在FPGA實(shí)現(xiàn)FFT 結(jié)構(gòu)。該結(jié)構(gòu)采用基于流水線結(jié)構(gòu)和快速并行乘法器的蝶形處理器。乘法器
    發(fā)表于 09-11 15:46 ?16次下載

    基于FPGAFFT處理器的設(shè)計(jì)

    本文主要研究基于FPGA 的數(shù)據(jù)處理系統(tǒng),內(nèi)部包含一個(gè)1024 點(diǎn)的FFT 處理單元。FFT 部分采用
    發(fā)表于 12-19 16:18 ?59次下載

    基于FPGAFFT處理器的研究與設(shè)計(jì)

    本文利用頻域抽取基四算法,運(yùn)用靈活的硬件描述語言-Verilog HDL 作為設(shè)計(jì)主體,設(shè)計(jì)并實(shí)現(xiàn)一套集成于FPGA 內(nèi)部的FFT 處理器FFT
    發(fā)表于 01-20 14:33 ?40次下載

    基于FPGA的級(jí)聯(lián)結(jié)構(gòu)FFT處理器的優(yōu)化設(shè)計(jì)

    基于FPGA的級(jí)聯(lián)結(jié)構(gòu)FFT處理器的優(yōu)化設(shè)計(jì)   0 引 言   數(shù)字信號(hào)處理主要研究采用數(shù)字序列或符號(hào)序列表示信號(hào),并用數(shù)字計(jì)算方法對(duì)
    發(fā)表于 12-28 11:07 ?2141次閱讀
    基于<b class='flag-5'>FPGA</b>的級(jí)聯(lián)結(jié)構(gòu)<b class='flag-5'>FFT</b><b class='flag-5'>處理器</b>的優(yōu)化設(shè)計(jì)

    OFDM系統(tǒng)中IFFT與FFT處理器實(shí)現(xiàn)

    提出了Radix-4 FFT的優(yōu)化算法,采用該優(yōu)化算法設(shè)計(jì)了64 點(diǎn)流水線IFFT/FFT 處理器,該處理器可以在64 個(gè)時(shí)鐘周期內(nèi)僅
    發(fā)表于 12-14 16:03 ?47次下載
    OFDM系統(tǒng)中IFFT與<b class='flag-5'>FFT</b><b class='flag-5'>處理器</b>的<b class='flag-5'>實(shí)現(xiàn)</b>

    基于FPGAFFT信號(hào)處理器的設(shè)計(jì)與實(shí)現(xiàn)

    本文主要研究如何利用FPGA實(shí)現(xiàn)FFl’算法,研制具有自主知識(shí)產(chǎn)權(quán)的FFT 信號(hào)處理器
    發(fā)表于 03-21 16:22 ?44次下載

    基于FPGA的1024點(diǎn)高性能FFT處理器的設(shè)計(jì)鐘冠文

    基于FPGA的1024點(diǎn)高性能FFT處理器的設(shè)計(jì)_鐘冠文
    發(fā)表于 03-19 11:36 ?10次下載

    基于FPGAFFT實(shí)現(xiàn)方案

    兩種:軟件(軟件編程)和硬件(專用ASIC芯片)。DSP軟件編程實(shí)現(xiàn)速度較慢,不能滿足FFT算法高速、實(shí)時(shí)的場(chǎng)合;專用芯片在速度上能滿足要求,但外圍電路復(fù)雜,可擴(kuò)展性差,
    發(fā)表于 11-09 10:58 ?11次下載
    基于<b class='flag-5'>FPGA</b>的<b class='flag-5'>FFT</b><b class='flag-5'>實(shí)現(xiàn)</b>方案

    基于FPGA器件實(shí)現(xiàn)微波接力機(jī)中的FFT模塊設(shè)計(jì)

    對(duì)實(shí)現(xiàn)FFT的工程,目前通用的方法是采用DSP、FFT處理電路及FPGA。用DSP
    發(fā)表于 07-27 17:52 ?1468次閱讀
    基于<b class='flag-5'>FPGA</b>器件<b class='flag-5'>實(shí)現(xiàn)</b>微波接力機(jī)中的<b class='flag-5'>FFT</b>模塊設(shè)計(jì)

    使用FPGA實(shí)現(xiàn)流水線結(jié)構(gòu)的FFT處理器論文講解

    針對(duì)高速實(shí)時(shí)信號(hào)處理的要求,介紹了用現(xiàn)場(chǎng)可編程邏輯陣列(FPGA實(shí)現(xiàn)的一種流水線結(jié)構(gòu)的FFT處理器方案。該
    發(fā)表于 01-25 14:51 ?12次下載
    使用<b class='flag-5'>FPGA</b><b class='flag-5'>實(shí)現(xiàn)</b>流水線結(jié)構(gòu)的<b class='flag-5'>FFT</b><b class='flag-5'>處理器</b>論文講解

    采用FPGA實(shí)現(xiàn)FFT算法示例

     目前,硬件實(shí)現(xiàn)FFT算法的方案主要有:通用數(shù)字信號(hào)處理器(DSP)、FFT專用器件和現(xiàn)場(chǎng)可編程門陣列(FPGA)。DSP具有純軟件
    的頭像 發(fā)表于 05-11 15:31 ?2721次閱讀
    <b class='flag-5'>采用</b><b class='flag-5'>FPGA</b><b class='flag-5'>實(shí)現(xiàn)</b><b class='flag-5'>FFT</b>算法示例
    主站蜘蛛池模板: 天天摸天天干天天操| 大学生一级特黄的免费大片视频| 国产成人精品高清免费| 日本不卡视频一区二区| 欧美日本一区二区三区生| 狠狠干网站| 亚洲精品美女视频| 天天久久影视色香综合网| 日本免费网站| 久久精品亚洲一级毛片| 福利社藏经阁| 午夜黄大色黄大片美女图片| 日韩伊人网| 202z国产高清日本在线播放| 色综合久久88色综合天天| 免费视频一级片| 97夜夜操| 婷婷久月| 亚洲 欧洲 日韩| 欧美日韩性猛交xxxxx免费看| 精品国产一二三区在线影院| www.五月婷婷.com| 色资源网| 黄色的视频网站在线观看| 国产精品久久久久免费| 天堂在线免费视频| 性视频久久| 日本经典在线三级视频| 黄色超污网站| 午夜精品福利影院| 99xxxx开心| 国产精品第一页在线观看| 天天色影| 九色国产在视频线精品视频| 又粗又爽又色男女乱淫播放男女| 奇米久久久| 全免费一级毛片在线播放| 中文字幕在线观看亚洲| www.亚洲一区| 日韩美毛片| 成人特黄午夜性a一级毛片|