快速傅里叶算法(FFT)快在哪里?
创始人
2024-05-27 19:55:55
0

目录

前言

1、DFT算法 

2、FFT算法

2.1 分类

 2.2 以基2 DIT(时间抽取) FFT 算法为例

2.2.1 一次分解 

2.2.2 多次分解

 参考


前言

  对信号分析的过程中,为了能换一个角度观察问题,很多时候需要把时域信号波形变换到频域进行分析,这涉及到对信号求傅里叶变换,在计算机中便于处理的是离散信号,因此需要求信号的离散傅里叶变换,但是离散傅里叶变换(DFT--Discrete Fourier transform)的算法时间复杂度O(n2),为了能提高计算的速度,很多时候我们进行的变换为快速傅里叶变换(FFT--Fast Fourier Transform),其算法时间复杂度O(nlogn),大大提高了计算的速度,那么该快速傅里叶变换算法的快在哪里?中间进行了什么操作,我们下面具体分析。

在之前的一篇文章中我们提到了DFT和FFT的关系

频谱、功率谱、倒频谱_heda3的博客-CSDN博客_倒频谱

1、DFT算法 

DFT的数学计算表达式为:

长度为N的离散时间信号x(n),做N点离散傅里叶变换如下:

  X(k)=\sum_{n=0}^{N-1}x(n)e^{-j\frac{2\pi}{N}kn}=\sum_{n=0}^{N-1}x(n)W_{N}^{kn}

其中k=0,1,2,...N-1

其中W_{N}=e^{-j2\frac{ \pi }{N}}

运算量表述为:

依据上述公式可知,做1点DFT,需要N次复数乘法、N-1次复数加法

做N点DFT,则需要N*N次复数乘法、N*(N-1)次复数加法

当N为256点时,所需运算量65536次复数乘法、65280次复数加法

N=512点时,所需运算量262144次复数乘法、261632次复数加法

N=1024点时,所需运算量1048576次复数乘法、1047552次复数加法

可见当N点从256到1024点变化时,DFT算法的计算量从万级到百万级。

2、FFT算法

2.1 分类

分为按照时间抽取(在时间上将信号长度逐步减少)和按照频率抽取

依据抽取长度分为基2、基4

基2 DIT(时间抽取) FFT  也称为Cooley-Tukey algorithm 库利图基算法

基2 DIF(频率抽取) FFT

基4 FFT

分裂基FFT(包含两种不同基的混合计算)

 2.2 以基2 DIT(时间抽取) FFT 算法为例

基于基2时间抽取将信号划分为两部分分别计算FFT(信号长度N要求为N=2的整数倍):

X(k)=\sum_{n=0}^{N-1}x(n)W_{N}^{kn}=\sum_{n=0}^{N/2-1}x(2n)W_{N}^{k2n}+\sum_{n=0}^{N/2-1}x(2n+1)W_{N}^{k(2n+1)}                          1)

其中k=0,1,2,...N-1

复数运算的特性

W_{N}^{kn}=e^{-j2\frac{ \pi }{N}kn}

对称性: 

 W_{N}^{nk}=W_{N}^{-nk}=W_{N}^{(N-n)k}

周期性:

 W_{N}^{nk}=W_{N}^{(n+N)k}

可约性:

 W_{N}^{nk}=W_{mN}^{mnk} =W_{N/m}^{nk/m}

常见的计算 

W_{N}^{0}=1

W_{N}^{N/2}=-1

W_{N}^{N/4}=-j

2.2.1 一次分解 

依据上述复数运算的特性的可约性,则1)化简为:

X(k)=\sum_{n=0}^{N-1}x(n)W_{N}^{kn}=\sum_{n=0}^{N/2-1}x(2n)W_{N/2}^{kn}+W_{N}^{k}\sum_{n=0}^{N/2-1}x(2n+1)W_{N/2}^{kn}     2)

             X(k)=\sum_{n=0}^{N-1}x(n)W_{N}^{kn}=X_{0}(k)+W_{N}^{k}X_{1}(k)                                                  3)

              其中k=0,1,2,...N-1

利用特性:

W_{N}^{k+N/2}=W_{N}^{N/2}W_{N}^{k}=-W_{N}^{k}

则3)可表述为:

                            X(k)=X_{0}(k)+W_{N}^{k}X_{1}(k)                                                 4)

X(k+N/2)=X_{0}(k)-W_{N}^{k}X_{1}(k)                    

                               其中k=0,1,2,...N/2-1 

用如下的蝶形方式表述为3式和4式:

 两次复数运算:

 一次复数运算:

也即是N点DFT包含:2个 N/2点DFT和N/2个蝶形运算,一个蝶形运算包含一次复数乘法和两次复数加法

上述:做N点DFT,则需要N*N次复数乘法、N*(N-1)次复数加法

则2个N/2点DFT,则需要2*(N/2*N/2)=N^{^{2}}/2次复数乘法,2*(N/2)*(N/2-1)=N(N/2-1)次复数加法运算;蝶形运算次数:N/2次复数乘法,N次复数加法。

因此总的复数乘法计算:N(N+1)/2    总的复数加法次数:N^{^{2}}/2

通过上述的一次分解前后的运算量分析,可见经过一次分解后(信号按照奇偶数将N点DFT划分为N/2点DFT,并将两个N/2点DFT组合的方式),其运算量降低了一半,计算效率得到了提升。

2.2.2 多次分解

当N一直分解下去直到DFT的点数为2时,最小的计算单元为一个基本的蝶形运算,因此由于信号长度最初定义为N=2的整数倍,也即是N=2^{^{M}},因此N点DFT运算可以分解为M级蝶形运算,每一级为N/2个蝶形运算。

通过上述的FFT计算方法,则N点FFT运算需要M*N/2个蝶形运算,复数乘法次数:

N/2*M=N/2*log_{2}^{N}

复数加法次数:

   N/2*2*M=N*log_{2}^{N}

 

当N点从256到1024点变化时,FFT算法的计算量从千级到万级。可见FFT运算速度较DFT得到较大的提升。

    现在我们可以明显知道FFT到底快在哪里,因为经过对信号的逐级分解,将大点DFT划分为小点DFT计算,也即是N点FFT若基于基2抽取方法,则需要log_{2}^{N}级分解,N点DFT最终划分为2点DFT计算,并结合指数运算的特性,减少冗余计算,使得运算量大为减小。

 参考

【1】《数字信号处理》

【2】如何利用FFT(基2时间以及基2频率)信号流图求序列的DFT

 

相关内容

热门资讯

常用商务英语口语   商务英语是以适应职场生活的语言要求为目的,内容涉及到商务活动的方方面面。下面是小编收集的常用商务...
六年级上册英语第一单元练习题   一、根据要求写单词。  1.dry(反义词)__________________  2.writ...
复活节英文怎么说 复活节英文怎么说?复活节的英语翻译是什么?复活节:Easter;"Easter,anniversar...
2008年北京奥运会主题曲 2008年北京奥运会(第29届夏季奥林匹克运动会),2008年8月8日到2008年8月24日在中华人...
英语道歉信 英语道歉信15篇  在日常生活中,道歉信的使用频率越来越高,通过道歉信,我们可以更好地解释事情发生的...
六年级英语专题训练(连词成句... 六年级英语专题训练(连词成句30题)  1. have,playhouse,many,I,toy,i...
上班迟到情况说明英语   每个人都或多或少的迟到过那么几次,因为各种原因,可能生病,可能因为交通堵车,可能是因为天气冷,有...
小学英语教学论文 小学英语教学论文范文  引导语:英语教育一直都是每个家长所器重的,那么有关小学英语教学论文要怎么写呢...
英语口语学习必看的方法技巧 英语口语学习必看的方法技巧如何才能说流利的英语? 说外语时,我们主要应做到四件事:理解、回答、提问、...
四级英语作文选:Birth ... 四级英语作文范文选:Birth controlSince the Chinese Governmen...
金融专业英语面试自我介绍 金融专业英语面试自我介绍3篇  金融专业的学生面试时,面试官要求用英语做自我介绍该怎么说。下面是小编...
我的李老师走了四年级英语日记... 我的李老师走了四年级英语日记带翻译  我上了五个学期的小学却换了六任老师,李老师是带我们班最长的语文...
小学三年级英语日记带翻译捡玉... 小学三年级英语日记带翻译捡玉米  今天,我和妈妈去外婆家,外婆家有刚剥的`玉米棒上带有玉米籽,好大的...
七年级英语优秀教学设计 七年级英语优秀教学设计  作为一位兢兢业业的人民教师,常常要写一份优秀的教学设计,教学设计是把教学原...
我的英语老师作文 我的英语老师作文(通用21篇)  在日常生活或是工作学习中,大家都有写作文的经历,对作文很是熟悉吧,...
英语老师教学经验总结 英语老师教学经验总结(通用19篇)  总结是指社会团体、企业单位和个人对某一阶段的学习、工作或其完成...
初一英语暑假作业答案 初一英语暑假作业答案  英语练习一(基础训练)第一题1.D2.H3.E4.F5.I6.A7.J8.C...
大学生的英语演讲稿 大学生的英语演讲稿范文(精选10篇)  使用正确的写作思路书写演讲稿会更加事半功倍。在现实社会中,越...
VOA美国之音英语学习网址 VOA美国之音英语学习推荐网址 美国之音网站已经成为语言学习最重要的资源站点,在互联网上还有若干网站...
商务英语期末试卷 Part I Term Translation (20%)Section A: Translate ...