FFT 专题讲解
FFT是什么?
FFT是快速傅里叶变换(fast Fourier transform)的简称。在ACM领域主要是用来快速求解多项式乘法的算法,
在信号领域也有很大用途
基础知识
卷积
举个例子,给你两个向量 \(a (a_0, a_1, a_2), b(b_0, b_1, b_2)\)
a和b的卷积就是$ ( a_0b_0, a_1b_0+a_0b_1, a_2b_0+a_1b_1+a_0b_2, a_1b_2+a_2b_1, a_2b_2 ) \(
即可以看作两个多项式\)A(x)=a_0+a_1x1+a_2x2和B(x)=b_0+b_1x+b_2x^2\(相乘。
所以卷积就可看做多项式乘法。那些形如\)c_k = \Sigma_{i=0}^{k}a_ib_{k-i}$卷积的就可以类比成多项式乘法 ,就可通过fft快速求解。多项式
- 多项式有两种表达形式
- 一种是系数表达形如\(A(x) = \Sigma_{i=0}^{n-1} a_ix^i\)
- 另一种是点值表达, 形如\((x_1, y_1), (x_2, y_2), (x_3, y_3)...(x_m, y_m)\), 且m>=n
- 多项式的点值表示和插值表示可以互推
\(w_n=e^{2\pi i/n}\)
- \(w_n^{n/2+k}=-w_n^k\)
- \(w_n^{2k}=w_{n/2}^k\)
- $ \Sigma_{j=0}{n-1}w_n{jk}= (k%n==0)?n:0$
傅里叶变换的原理
在傅里叶变换里面系数表达和点值表达如何互推?
一个暴力点的方法
系数表达->点值表达 \(y_k = \Sigma_{i=0}^{n-1}a_iw_n^{ki}\)
点值表达->系数表达 \(a_k = 1/n*\Sigma_{i=0}^{n-1}y_iw_n^{-ki}\)
证明看黑板
所以不论是系数表达推点值表达还是点值表达推系数表达方法都一样
如何快速的求出上面的式子呢
假设 $A(x)=a_0+a_1x+a_2x2+...+a_{n-1}x{n-1} \(
那\)A(x)=(a_0+a_2x2+a_4x4+...+a_{n-2}x{n-2})+(a_1x+a_3x3+..+a_{n-1}x^{n-1})\(
令\)A_0(x)=a_0+a_2x+a_4x2+...+a_{n-2}x{n/2-1}, A_1(x)=a_1+a_3x+a_5x+...+a_{n-1}x^{n/2-1}\(
则\)A(x) = A_0(x2)+xA_1(x2)\(
那么就可以用\)A_0(w_{n/2}^0), A_0(w_{n/2}^1) ... A_0(w_{n/2}^{n/2-1})$ 和 \(A_1(w_{n/2}^0), A_1(w_{n/2}^1) ... A_1(w_{n/2}^{n/2-1}\)
得出\(A(w_{n}^0), A(w_{n}^1) ... A(w_{n}^{n-1})\)
\(所以可以采用递归分治的办法求解FFT\)
分治图
void ntt(ll* a, int n, int t) {
rep(i, 0, n) {
int rv = rev(i,n);
if(i<rv) swap(a[i], a[rv]);
}
ll g=1;
if(t==1) g=3;
else g=inv[3];
for(int m=2; m<n+1; m<<=1) {
ll wm= mypow(g, (MOD-1)/m);
int mid=m>>1;
for(ll *p=a; p<a+n; p+=m) {
ll w=1;
rep(i, 0, mid) {
ll t=w*(p[mid+i]);
p[mid+i] = p[i]-t;
p[i] = p[i]+t;
w = w*wm%MOD;
p[i]=%MOD, p[mid+i]%=MOD;
}
}
}
if(t==-1) {
rep(i, 0, tn)
a[i]=a[i]*inv[n]%MOD;
}
}
void fft(ll *a, ll* b, int n) {
int tn=MAXN;
while(tn/4>=n) tn>>=1;
ntt(a, tn, 1);
ntt(b, tn, 1);
rep(i, 0, tn)
a[i] = a[i]*b[i]%MOD;
ntt(a, tn, -1);
}
NTT \(w_n=g^{(P-1)/n}\%P\)
- 一些更高级的操作或例题
https://wenku.baidu.com/view/20c234cf581b6bd97f19eaea.html
http://blog.csdn.net/samjia2000/article/details/65661468
https://www.cnblogs.com/candy99/p/6738010.html
FFT 专题讲解的更多相关文章
- Activity Process Task Application 专题讲解
Activity Process Task Application 专题讲解 Activity.和进程 为了阅读方便,将文档转成pdf http://files.cnblogs.com/franksu ...
- 13Mybatis_SqlMapConfig.xml专题讲解
Mybatis的SqlMapConfig.xml中以下的标签: properties(属性) settings(全局配置参数) typeAliases(类型别名) typeHandlers(类型处理器 ...
- Android中View的绘制流程(专题讲解)
Android中的UI视图有两种方式实现:.xml文件(实现代码和UI的分离)和代码实现. Android的UI框架基本概念: 1. Activity:基本的页面单元,Activity包含一个Wind ...
- LeetCode递归 -2(Recursion) 培训专题 讲解文章翻译 (附链接) (2019-04-09 15:50)
递归 - 空间复杂度 在本文中, 我们将讨论如何分析递归算法的空间复杂度. 在计算递归算法的空间复杂度时,最需要考虑的两个部分就是: 递归相关空间 (recursion related space) ...
- LeetCode 递归(Recursion) 培训专题 讲解文章翻译 (附链接)
递归 - 时间复杂度 在本文中, 我们主要介绍如何分析递归算法程序中的时间复杂度.. 在一个递归程序中, 它的时间复杂度 O(T) 一般来说就是他总共递归调用的次数 (定义为 R) 以及每次调用时所 ...
- 火柴排队(NOIP2013)(附树状数组专题讲解(其实只是粗略。。。))
原题传送门 首先,这道题目是一道神奇的题. 看到这道题,第一眼就觉得2个数组排个序,然后一一对应的时候一定差值最小. 由于我们可以将这2个数列同时进行调换. 所以我们先把2个数列排个序. 第二个序列中 ...
- H3C路由器登录策略专题讲解
password-control login-attempt login-times [ exceed { lock | lock-time time | unlock } ] undo passwo ...
- javascript进阶系列专题:作用域与作用域链
字面意思,作用域是指变量和函数的作用范围,换言之,作用域决定了变量和函数的可见性和有效时间.javascript作用域是用函数来区分,与其他语言的大括号不同. for (var i=0; i<5 ...
- 在 Visual Studio 2013 中创建 ASP.NET Web 项目(0):专题导航 [持续更新中]
写在前面的话 随着 Visual Studio 2013 的正式推出,ASP.NET 和 Visual Studio Web 开发工具 也发布了各自的最新版本. 新版本在构建 One ASP.NET ...
随机推荐
- oracle批量数据导入工具 sqlldr
sqlldr工具参数: [oracle@server ~]$ sqlldr SQL*Loader: Release - Production on Wed Nov :: Copyright (c) , ...
- Vsftpd3.0--FTP服务器搭建之本地用户篇
Vsftpd3.0--FTP服务器搭建之本地用户篇 年4月10日 19:23 FTP服务在工作中是经用到的一种工具,可以实现上传下载等功能.那么今天我们来聊一聊FTP服务器使用本地用户登录的实现模式. ...
- 将ArrayList<HashMap<String, String>>转为ArrayList<Bundle>类型的解决方案
Bundle是一种利用键值对存储的数据格式,而我们在程序中通常利用HashMap存储数据.在开发中,通过Http请求得到JSONArray类型的返回值,我选择利用ArrayList<HashMa ...
- cobbler简介+安装
(介绍部分的内容部分是借鉴网上的非原创) 回顾pxe+kickstart PXE PXE(preboot execute environment,预启动执行环境) PXE启动原理: 当计 ...
- 基于pytorch实现word2vec
一.介绍 word2vec是Google于2013年推出的开源的获取词向量word2vec的工具包.它包括了一组用于word embedding的模型,这些模型通常都是用浅层(两层)神经网络训练词向量 ...
- 全网首创ISE入门级教程
转眼间我已经大三了,现在成为了实验室的负责人,对于下一届学生的纳新重任就交到了我的手上,想采取不同的方法暑假尽可能对他们进行一些培训,所以制作了此教程,说实话,在网上还没有找到关于ISE的入门级使用教 ...
- 解决无线网络连接出现黄色感叹号---win10
今天使用公司的电脑,这个电脑是另一位同事用过的,然后到我这里就连不上网了.然后把自己解决的方法记录一下: 开始运行输入以下命令来重置IP. 打开运行输入:cmd 在命令窗口中输入:ipconfig / ...
- servlet前台中文参数处理
@Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletExcep ...
- (转)CentOS 7.0关闭默认防火墙启用iptables防火墙
场景:在本地虚拟机上使用ftp软件需要进行相应的端口设置,不可避免要访问Cnetos的防火墙,默认firewall操作不方便,所以需要进行相应的替换. 1 配置防火墙,开启80端口.3306端口 1. ...
- C语言基础 - 实现动态数组并增加内存管理
用C语言实现一个动态数组,并对外暴露出对数组的增.删.改.查函数 (可以存储任意类型的元素并实现内存管理) 这里我的编译器就是xcode 分析: 模拟存放 一个 People类 有2个属性 字符串类型 ...