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

    文章

    4629

    浏览量

    93229
  • FFT
    FFT
    +关注

    关注

    15

    文章

    437

    浏览量

    59507
  • python
    +关注

    关注

    56

    文章

    4807

    浏览量

    84972
  • 傅里叶变换
    +关注

    关注

    6

    文章

    442

    浏览量

    42674

原文标题:优雅的FFT算法

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

收藏 人收藏

    评论

    相关推荐

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

    快速傅里叶变换 (Fast Fourier Transform,FFT), 即利用计算机计算离散傅里叶变换(DFT)的高效、
    的头像 发表于 07-20 16:46 4214次阅读
    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

    详解快速傅里叶变换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快速傅里叶变换)运算器电路图
    发表于 07-16 11:49 4657次阅读
    <b class='flag-5'>FFT</b>(<b class='flag-5'>快速</b><b class='flag-5'>傅里叶变换</b>)运算器电路图

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

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

    快速傅里叶变换FFT的C程序代码实现

    本文为您讲解快速傅里叶变换FFT的C语言程序代码实现的具体方法,C编程需要解决的问题及FFT计算结果验证。
    发表于 10-08 16:38 6.1w次阅读
    <b class='flag-5'>快速</b><b class='flag-5'>傅里叶变换</b><b class='flag-5'>FFT</b>的C程序代码<b class='flag-5'>实现</b>

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

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

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

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

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

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