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

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

3天内不再提示

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

GReq_mcu168 来源:TsinghuaJoking 作者:TsinghuaJoking 2022-07-04 14:36 次阅读

64ee5150-f9d2-11ec-ba43-dac502259ad0.gif

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

01 Python算法

  今天下午的信号与系统, 给同学们介绍了离散傅里叶变换的基本应用, 并且介绍了快速傅里叶变换(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算法计算结果。

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

02 其它语言FFT

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

2.1 Fortran FFT算法

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

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

第一个阶段实现了对输入数据进行倒读顺序排列;

第二阶段利用三重循环实现了分组蝶形运算。

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

658a2e86-f9d2-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
voidfft(Iter_Ta,Iter_Tb,intlog2n){
typedeftypenameiterator_traits::value_typecomplex;
constcomplexJ(0,1);
intn=1<< log2n;
    for (unsigned int i = 0; i < n; ++i) {
        b[bitReverse(i, log2n)] = a[i];
    }
 
    for (int s = 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 (int k = 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算法,同时还需要注意到它在频谱分析中可能带来的频率混叠以及频率泄露等问题。

原文标题:优雅的FFT算法

文章出处:【微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

审核编辑:彭静

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

    关注

    15

    文章

    434

    浏览量

    59328
  • 频谱
    +关注

    关注

    7

    文章

    879

    浏览量

    45596
  • 代码
    +关注

    关注

    30

    文章

    4762

    浏览量

    68408
  • 傅里叶变换
    +关注

    关注

    6

    文章

    438

    浏览量

    42573

原文标题:优雅的FFT算法

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    为什么使用傅里叶变换 FFT变换的基本原理

    1.FFT变换的基本原理 傅立叶变换是数字信号处理领域一种很重要的算法,可以将一个信号从时域变换到频域。傅立叶原理表明:任何连续测量的时序或
    的头像 发表于 11-09 16:52 1.4w次阅读
    为什么使用<b class='flag-5'>傅里叶变换</b> <b class='flag-5'>FFT</b><b class='flag-5'>变换</b>的基本原理

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

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

    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

    DSP变换运算-傅里叶变换

    第24章 DSP变换运算-傅里叶变换本章节开始进入此教程最重要的知识点之一傅里叶变换。关于傅里叶变换,本章主要是把傅里叶相关的基础知识进行必
    发表于 08-03 06:14

    FFT(快速傅里叶变换)运算器电路图

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

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

    快速傅里叶变换 FFT 是离散傅里叶变换 DFT 的一种快速算法,只有 FFT 才能在现实中有实际应 用的意义。虽然许多学过数字信号处理这
    发表于 01-15 16:24 0次下载

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

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

    经验证的FFT变换傅里叶变换程序(C语言)

    项目中验证可用的FFT变换傅里叶变换,C语言,带头文件。
    发表于 09-08 20:21 16次下载

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

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

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

    简 介: 利用FFT算法实现快速傅里叶变换, 在理论、工程中具有非常广泛的应用。除了能够在合适的计算平台完成FFT算法,同时还需要注意到它在
    的头像 发表于 07-10 09:07 3245次阅读