博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
快速傅里叶变换(FFT)详解
阅读量:4302 次
发布时间:2019-05-27

本文共 1219 字,大约阅读时间需要 4 分钟。

快速傅里叶变换(FFT)详解

  (这是我第一次写博,不喜勿喷...)

  关于FFT已经听闻已久了,这次终于有机会在Function2的介绍下来了解一下FFT了。

  快速傅里叶变换(Fast Fourier Transformation)简称FFT。在各大OI竞赛中也常有用到,也是一个十分优秀的可以装逼的好算法

  在这篇blog中,有大量数学推导,因为我懒得写公式(好复杂,逃),所以用图片代替了╮(╯▽╰)╭,如有不适,望见谅(逃~~)。

 基础知识:

多项式的度数:

多项式的线性空间

系数表达

 

向量的卷积

 

分治乘法(如果你急着和MM约会或机房要关门了,那跳过也无妨)

点值表达

 

插值

 

 

点值计算分析

 单位复数根

 

单位复数根的性质

  1. 消去引理

    

  2.折半引理

    

  3.求和引理

    

 

铺垫都铺完了,让我们一起进入DFT,FFT,IDFT的美妙世界吧!

离散傅里叶变换(Discrete Fourier Transform 简称DFT)

 快速傅里叶变换(FFT)(终于等到你~~)

 

 

逆离散傅里叶变换(Inverse Discrete Fourier Transform 简称IDFT)

 FFT的迭代实现

我们类似于需要像这样实现FFT:

知识点终于讲完了,接下来我们就要开始写板子了

板子题:

代码附上~~

复制代码

1 #include
2 #include
3 #include
4 #include
5 #include
6 #include
7 using namespace std; 8 const int mod=1e9+7; 9 const double pi=acos(-1);10 struct cn11 {12 double x,y;13 cn (double x=0,double y=0):x(x),y(y) {}14 }a[300005],b[300005],c[300005];15 cn operator + (const cn &a,const cn &b) {return cn(a.x+b.x,a.y+b.y);}16 cn operator - (const cn &a,const cn &b) {return cn(a.x-b.x,a.y-b.y);}17 cn operator * (const cn &a,const cn &b) {return cn(a.x*b.x-a.y*b.y,a.x*b.y+a.y*b.x);}18 void fft(cn a[],int n,int l,int f) 19 { 20 int rev[n+5];21 rev[0]=0;22 for (int i=1; i
>1]>>1)|((i&1)<

复制代码

转载地址:http://mrows.baihongyu.com/

你可能感兴趣的文章
设计模式05_单例
查看>>
设计模式06_原型
查看>>
设计模式07_建造者
查看>>
设计模式08_适配器
查看>>
设计模式09_代理模式
查看>>
设计模式10_桥接
查看>>
设计模式11_装饰器
查看>>
设计模式12_外观模式
查看>>
设计模式13_享元模式
查看>>
设计模式14_组合结构
查看>>
设计模式15_模板
查看>>
海龟交易法则01_玩风险的交易者
查看>>
CTA策略02_boll
查看>>
vnpy通过jqdatasdk初始化实时数据及历史数据下载
查看>>
设计模式19_状态
查看>>
设计模式20_观察者
查看>>
vnpy学习10_常见坑
查看>>
vnpy学习10_常见坑02
查看>>
用时三个月,终于把所有的Python库全部整理了!拿去别客气!
查看>>
pd.stats.ols.MovingOLS以及替代
查看>>