0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

利用FFT算法实现快速傅里叶变换

凡亿PCB 来源:CSDN技术社区 作者:卓晴 2022-07-10 09:07 次阅读
d38c4b00-ff16-11ec-ba43-dac502259ad0.gif


简 介:利用FFT算法实现快速傅里叶变换, 在理论、工程中具有非常广泛的应用。除了能够在合适的计算平台完成FFT算法,同时还需要注意到它在频谱分析中可能带来的频率混叠以及频率泄露等问题。

01Python算法

天下午的信号与系统, 给同学们介绍了离散傅里叶变换的基本应用, 并且介绍了快速傅里叶变换(FFT)的主要思想与算法。FFT算法因其优异的性能和广泛的应用, 堪称信息处理领域的原子武器。实现FFT编程语言很多, 比较来比较去, 利用Python语音所描述的该算法最为简明和优雅。

1.1 FFT算法代码

下面的代码是在 The Fast Fourier Transform (FFT): Most Ingenious Algorithm Ever?视频中给出的 FFT 递归算法形式, 最大精度反映了FFT算法核心。

这个代码实现了DIF(时域抽取快速傅里叶变换), 利用递归定义,将FFT核心算法中的分而治之体现的淋漓尽致, 突出了递归核心中的核心思想。

defFFT(P):
n=len(P)
ifn*1:returnP

ye=FFT(P[0::2])
yo=FFT(P[1::2])

y=[0]*n
w=exp(-1j*2*pi/n)
forjinrange(n//2):
yow=w**j*array(yo)
y[j]=ye[j]+yow[j]
y[j+n//2]=ye[j]-yow[j]

returny

利用Python语音中对于数组切片操作语法, 还可以将上面FFT算法中的循环部分都替换成关于数组的操作, 使得实际运算速度得到提高。

defFFT1(P):
n=len(P)
ifn*1:returnP

ye=FFT(P[0::2])
yo=FFT(P[1::2])

w=exp(-1j*2*pi/n)**array(list(range(n//2)))
yow=w*yo

y=[0]*n
y[:n//2]=ye+yow
y[n//2:]=ye-yow

returny

1.2 FFT 算法测试

为了测试算法的有效性, 下面对于一个方波信号计算对应的FFT结果。

测试算法代码如下:

LEN=1024
oneLEN=10
p1=[1]*oneLEN+[0]*(LEN-oneLEN)

y=FFT(p1)
plt.plot(abs(array(y)),label='abs(FFT)')
plt.plot(p1,label='Data')

plt.xlabel("y")
plt.ylabel("abs(FFT(y))")
plt.grid(True)
plt.legend(loc='upperright')
plt.tight_layout()
plt.show()

下面是测试利用Python语言实现的FFT算法计算结果。

d3b21362-ff16-11ec-ba43-dac502259ad0.png▲ 图1.2.1 利用Python语音实现的FFT算法测试结果

02它语言FFT

FFT算法贵在计算效率,前面使用Python实现FFT,虽然形式上优雅,但实际执行效率不高。提高执行效率,还是需要使用编译语言。

2.1 Fortran FFT算法

在我上大学期间所学的编程语言为Fortran, 估计现在没有多少同学学习这个算法语言。下面给出了利用Fortran语言实现的FFT算法程序。

算法整体上包括有两个阶段:

  • 第一个阶段实现了对输入数据进行倒读顺序排列;
  • 第二阶段利用三重循环实现了分组蝶形运算。

当然了,时过三十年再看Fortran感觉十分酸爽, 但它简练语言和执行高效还是让我们回忆起当年编程时所感觉到的快乐。

d3c0ccd6-ff16-11ec-ba43-dac502259ad0.png▲ 图 Fortran 语言实现的FFT算法

2.2 C语言FFT算法

下面是在网络上博文C++ Program to Compute Discrete Fourier Transform using Fast Fourier Transform Approach[1]给出的FFT算法, 没有对其功能进行测试。相比于前面利用Python,Fortran来看, C语言实现FFT就显得非常啰嗦了。

#include
#include
#include
#include
usingnamespacestd;
unsignedintbitReverse(unsignedintx,intlog2n){
intn=0;
intmask=0x1;
for(inti=0;i< log2n; i++) {
        n <<= 1;
n|=(x&1);
x>>=1;
}
returnn;
}
constdoublePI=3.1415926536;
template<classIter_T>
voidfft(Iter_Ta,Iter_Tb,intlog2n){
typedeftypenameiterator_traits<iter_t>::value_typecomplex;
constcomplexJ(0,1);
intn=1<< log2n;
    for(unsignedinti=0;i< n; ++i) {
        b[bitReverse(i, log2n)] = a[i];
    }
 
    for(ints=1;s<= log2n; ++s)  {
        int m = 1<< s;
        int m2 = m >>1;
complexw(1,0);
complexwm=exp(-J*(PI/m2));
for(intj=0;j< m2; ++j) {
            for(intk=j;k< n; k += m) {
                complex t = w * b[k + m2];
                complex u = b[k];
                b[k] = u + t;
                b[k + m2] = u - t;
            }
            w *= wm;
        }
    }
}

 结 ※

用FFT算法实现快速傅里叶变换, 在理论、工程中具有非常广泛的应用。除了能够在合适的计算平台完成FFT算法,同时还需要注意到它在频谱分析中可能带来的频率混叠以及频率泄露等问题。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 算法
    +关注

    关注

    23

    文章

    4455

    浏览量

    90753
  • FFT
    FFT
    +关注

    关注

    15

    文章

    425

    浏览量

    58636
  • python
    +关注

    关注

    51

    文章

    4675

    浏览量

    83466
  • 傅里叶变换
    +关注

    关注

    5

    文章

    415

    浏览量

    42240

原文标题:优雅的FFT算法

文章出处:【微信号:FANYPCB,微信公众号:凡亿PCB】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Vivado中快速傅里叶变换FFT IP的配置及应用

    快速傅里叶变换 (Fast Fourier Transform,FFT), 即利用计算机计算离散傅里叶变换(DFT)的高效、
    的头像 发表于 07-20 16:46 2215次阅读
    Vivado中<b class='flag-5'>快速</b><b class='flag-5'>傅里叶变换</b><b class='flag-5'>FFT</b> IP的配置及应用

    C语言实现FFT(快速傅里叶变换)

    C语言实现FFT(快速傅里叶变换)
    发表于 10-25 21:33

    FFT快速傅里叶变换

    快速傅里叶变换FFT
    发表于 07-15 17:52

    第24章 快速傅里叶变换原理(FFT

    的核潜艇。所以在军事上,迫切需要一种快速的傅立叶变换算法,这也促进了FFT的正式提出。 FFT的这种方法充分利用了DFT运算中的对称性和周期
    发表于 09-27 08:09

    详解快速傅里叶变换FFT算法

    本帖最后由 richthoffen 于 2019-7-19 16:41 编辑 详解快速傅里叶变换FFT算法
    发表于 07-18 08:07

    详解快速傅里叶变换FFT算法

    详解快速傅里叶变换FFT算法
    发表于 03-28 11:48

    详解快速傅里叶变换FFT算法

    详解快速傅里叶变换FFT算法
    发表于 05-25 09:31

    快速傅里叶变换FFT算法及其应用

    快速傅里叶变换FFT算法及其应用
    发表于 05-28 09:13

    详解快速傅里叶变换FFT算法

    详解快速傅里叶变换FFT算法
    发表于 03-05 11:07

    快速傅里叶变换C语言实现

    快速傅里叶变换C语言实现 模拟采样进行频谱分析FFT是DFT的快速算法用于分析确定信号(时间连续可积信号、不一定是周期信号)的频率(或相位、
    发表于 07-20 06:01

    详解快速傅里叶变换FFT算法

    快速傅里叶变换 FFT 是离散傅里叶变换 DFT 的一种快速算法,只有 FFT 才能在现实中有实
    发表于 01-15 16:24 0次下载

    离散傅里叶变换(DFT)及其快速算法(FFT)

    第2章-离散傅里叶变换(DFT)及其快速算法(FFT)
    发表于 12-28 14:23 0次下载

    fft算法是什么_如何提高fft算法分辨率

    FFT算法(fast Fourier transform),即快速傅里叶变换,是指利用计算机计算离散傅里
    发表于 11-09 09:28 8074次阅读
    <b class='flag-5'>fft</b><b class='flag-5'>算法</b>是什么_如何提高<b class='flag-5'>fft</b><b class='flag-5'>算法</b>分辨率

    利用快速傅里叶变换计算相关面

      快速傅里叶变换 (fast Fourier transform),即利用计算机计算离散傅里叶变换(DFT)的高效、快速计算方法的统称,简
    发表于 11-27 16:23 1515次阅读

    傅里叶变换(FFT)的主要思想与算法

    利用FFT算法实现快速傅里叶变换, 在理论、工程中具有非常广泛的应用。除了能够在合适的计算平台完
    的头像 发表于 07-04 14:36 3362次阅读