C语言实现基2DIF-FFT算法(桑德·图基快速傅立叶变换)

傅立叶变换能将时域信号转换为由sin函数为基底的频域信号,从而我们可以从信号中提取出频率信息或截断频谱简化信号压缩信息。计算机难以处理连续信号。DFT是一种适用于计算机处理的有限信号时频转换方法。DFT用一句话概括,就是将连续信号(频域也是连续函数)经过时域采样(这样会使信号的频域发生周期延拓,得到周期连续的函数,计算机无法处理),再经过频域采样(这样会使时域信号发生周期延拓,时域周期延拓这一步可以直接在采样后实现,即 直接将采样后的DTFT过程转化为DFS),得到周期离散的频谱结果,取主值(一个周期),即得DFT结果X(k)。若要对DFT有个更直观的理解,推荐这篇博客

 

实现DFT的过程,可以总结为计算以下公式的过程

                                                                         (1)

式中,。计算(1)式的朴素算法时间复杂度为O(N^2),而目前的快速傅立叶算法能使(1)式的时间复杂度降为O( Nlog2(N) )。快速傅立叶算法的思路,就是利用复指数函数的性质减小计算量。一种快速傅立叶算法的思路是将N点DFT转化为N/2点DFT,即 将N点序列进行分割。若按n域(时域)划分,就是所谓DIT-FFT算法(decimation-in-time FFT,库利·图基算法);按k域(频域)划分,则是DIF-FFT算法(decimation-in-frequency FFT,桑德·图基算法)。本文介绍DIF-FFT算法。将(1)式按k分割成k为奇数和k为偶数两个部分,如下所示:

  • 8
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值