<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 模擬技術 > 設計應用 > 實數(shù)FFT算法的設計及其C語言實現(xiàn)

          實數(shù)FFT算法的設計及其C語言實現(xiàn)

          作者: 時間:2013-09-22 來源:網(wǎng)絡 收藏

          目前國內(nèi)有關數(shù)字信號處理的教材在講解快速傅里葉變換(FFT)時,都是以復數(shù)FFT為重點,實數(shù)都是一筆帶過,書中給出的具體實現(xiàn)程序多為BASIC或FORTRAN程序并且多數(shù)不能真正運行。鑒于目前在許多嵌入式系統(tǒng)中要用到FFT運算,如以DSP為核心的交流采樣系統(tǒng)、頻譜分析、相關分析等。本人結合自己的實際開發(fā)經(jīng)驗,研究了實數(shù)的并給出具體的C語言函數(shù),讀者可以直接應用于自己的系統(tǒng)中。

            首先分析實數(shù)的推導過程,然后給出一種具體實現(xiàn)FFT算法的C語言程序,可以直接應用于需要FFT運算的單片機或DSP等嵌入式系統(tǒng)中。

            1 倒位序算法分析

            按時間抽取(DIT)的FFT算法通常將原始數(shù)據(jù)倒位序存儲,最后按正常順序輸出結果X(0),X(1),...,X(k),...。假設一開始,數(shù)據(jù)在數(shù)組 float dataR[128]中,我們將下標i表示為(b6b5b4b3b2b1b0)b,倒位序存放就是將原來第i個位置的元素存放到第(b0b1b2b3b4b5b6)b的位置上去.由于C語言的位操作能力很強,可以分別提取出b6、b5、b4、b3、b2、b1、b0,再重新組合成b0、b1、b2、b3、b4、b5、b6,即是倒位序的位置。程序段如下(假設128點FFT):

            /* i為原始存放位置,最后得invert_pos為倒位序存放位置 */

            int b0=b1=b2=b3=b4=b5=6=0;

            b0=i0x01; b1=(i/2)0x01; b2=(i/4)0x01;

            b3=(i/8)0x01; b4=(i/16)0x01; b5=(i/32)0x01;

            b6=(i/64)0x01; /*以上語句提取各比特的0、1值*/

            invert_pos=x0*64+x1*32+x2*16+x3*8+x4*4+x5*2+x6;

            大家可以對比教科書上的倒位序程序,會發(fā)現(xiàn)這種算法充分利用了C語言的位操作能力,非常容易理解而且位操作的速度很快。

            2 實數(shù)蝶形運算算法的推導

            我們首先看一下圖1所示的蝶形圖。

            

          實數(shù)FFT算法的設計及其C語言實現(xiàn)

            蝶形公式:

            X(K) = X’(K) + X’(K+B)W PN ,

            X(K+B) = X’(K) - X’(K+B) W PN

          c語言相關文章:c語言教程



          上一頁 1 2 3 4 5 下一頁

          關鍵詞: FFT算法 C語言實現(xiàn)

          評論


          相關推薦

          技術專區(qū)

          關閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();