日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

FFT算法程序设计c语言,实数FFT算法的设计及其C语言实现

發(fā)布時間:2023/12/9 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 FFT算法程序设计c语言,实数FFT算法的设计及其C语言实现 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

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

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

1 倒位序算法分析

按時間抽取(DIT)的FFT算法通常將原始數(shù)據(jù)倒位序存儲,最后按正常順序輸出結(jié)果X(0),X(1),...,X(k),...。假設(shè)一開始,數(shù)據(jù)在數(shù)組 float dataR[128]中,我們將下標(biāo)i表示為(b6b5b4b3b2b1b0)b,倒位序存放就是將原來第i個位置的元素存放到第(b0b1b2b3b4b5b6)b的位置上去.由于C語言的位操作能力很強(qiáng),可以分別提取出b6、b5、b4、b3、b2、b1、b0,再重新組合成b0、b1、b2、b3、b4、b5、b6,即是倒位序的位置。程序段如下(假設(shè)128點(diǎn)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ù)蝶形運(yùn)算算法的推導(dǎo)

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

蝶形公式:

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

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

總結(jié)

以上是生活随笔為你收集整理的FFT算法程序设计c语言,实数FFT算法的设计及其C语言实现的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。