傅里叶:有关FFT,DFT与蝴蝶操作(转 重要!!!!重要!!!!真的很重要!!!!)
转载地址:http://blog.renren.com/share/408963653/15068964503(作者 : 徐可扬)
有没有!!!
其实我感觉这个学期算法最难最搞不懂的绝对不是动态规划啊!绝对是快速傅里叶变换啊!最近才弄懂有木有。
有不少人问我,于是干脆就写成日志吧。
首先明确一下基本概念吧,就三点,DFT,FFT,蝴蝶操作。
DFT(离散傅里叶变换):书上写的最清楚的一句话叫做,向量y=(y0,y1,……yn-1)是系数向量a=(a0,a1,,……,an-1)的离散傅里叶变换,也写作y=DFTn(a)。说白了,就是求n个y值,但是n个自变量x的取值很特殊

FFT(快速傅里叶变换):这个名词好理解,就是很快地算出这n个y值。一般我们计算n个n次的多项式值需要O(n^2)的时间。现在用FFT可以减少到O(n*logn)。具体原理一两句话说不完……要考的话也太理论性了…
蝴蝶操作:这个应该是让大家最费解的…他就是一个FFT得实际应用…因为这是实践的东西所以要掌握。书上有一个图,虽然感觉看书不一定看的怎么懂,但是这个图还是要记住。不过我觉得从下往上写看起来更舒服。
转过来以后,向左边是加,向右边是减。谨记啊!
突然发现好难解释,先把宋老师课件里面上次坑爹的没有答案的课后练习拿来看看。
我这里a0,a1,a2……就不调换顺序了,其实是一样的,格式不同罢了。
a=(0,1)

经过FFT,Y=(1,-1),这个就是书上最简单的应用了。
再来一个简单的 a=(1,0).

y=(1,1).
我觉得要考试一般就是考四个的吧,两个太简单了,8个的太复杂了(我后面有写)
例子
a=(1,1,0,1)

y=(3,1,-1,1) 注意算出来是 y0,y2,y1,y3的顺序。
a=(0,1,2,3)

y=(6,-2-2i, -2 , -2+2i).
注意右上角的蝶形运算中的旋转因子变成了(恩!?怎么不能插公式啊!)w(1/4)=i。。。那是因为在a0,a2的蝶形运算中我们多乘了(n/2),这里n=2.(这个我解释不来…不过这个数是固定的,背就行了)。
那我上个八个的,有点复杂,估计可能不会考
a=(0,1,2,3,4,5,6,7).

y的顺序如图
告诉大家一个比较好的办法判断是否算对了,直接人肉使用O(n^2)算法就好了,举四个的例子。就是把x得值带入多项式y=a3*x^3+a2*x^2+a1*x+a0算出y值什么的。x0=1,x1=i,x2=-1,x3=-i带入。这样的话,其实考察算没算对完全是个伪命题吗……
再提醒一次,左加右减哦!
最后再说一下这玩意有什么用,什么信号学的废话就不说了。无非是FFT用N*LogN时间算出点值方便用点值法算出多项式乘法的系数结果,这个大家看书上510的图我觉得就能理解了。插值神马的,背公式吧……虽然我也不记得了。
时间有点紧迫,感觉写的巨烂无比,大神们如果发现写错了留言给我立马改,关键不要误人子弟……
这有帮助的请让我知道。感谢大家!
If it helps you , let me know. Thank you !
傅里叶:有关FFT,DFT与蝴蝶操作(转 重要!!!!重要!!!!真的很重要!!!!)的更多相关文章
- 初探 FFT/DFT
		
有用的学习链接&书籍 傅立叶变化-维基百科 离散傅立叶变化-维基百科·长整数与多项式乘法 维基百科看英文的更多内容&有趣的图 快速傅立叶变化-百度百科,注意其中的图! 组合数学(第4版 ...
 - 信号基础知识--FFT DFT
		
clc;close all;clear all; f0=10; fs=100; %采样率 t=1/fs:1/fs:2; %共两秒钟,共200个采样点.采样间隔T=1/100 y ...
 - ubuntu16.04——WingIDE安装 操作服务器是一件很好玩的事情
		
1.在服务器上部署环境时,区分linux 系统和winddos系统 2.下载安装包: 3.输入命令操作 4.进入相对应的目录下: 5.命令 6.发生错误,更新环境 7.安装成功
 - 【分享】 封装js操作textarea 方法集合(兼容很好)。
		
请使用下面的btn操作. 虽然你现在看来没什么用,当要用的时候又到处找资料,还不如现在收集一下. 在DOM里面操作textarea里面的字符,是比较麻烦的. 于是我有这个封装分享给大家 ...
 - canvas调用scale或者drawImage图片操作后,锯齿感很明显的解决
		
<script type="text/javascript"> //解决canvas画画图片 var mengvalue = -1; var phoneWidth = ...
 - 【转】ini载入保存类,操作INI配置文件方便的很
		
/****************************************************************** * * ^_^ 恶猫 独门商标 挖哈哈 * * QQ:\> ...
 - [Reprinted] 使用Spring Data Redis操作Redis(一) 很全面
		
Original Address: http://blog.csdn.net/albertfly/article/details/51494080
 - 面试题: 数据库操作面试 已看1 很典型的sql面试题
		
摘要:今天参加了大展公司的一个电话面试,那位先生首先问我查询一个表的问题,条件是:1.一个数据表,有username字段.2.查询数据表中姓名姓张的.姓李的.姓刘的总数,并展现在一张表中.我当时就糊涂 ...
 - python专题文件操作
		
一 前言 本篇文章主要对文件操作进行说明,知识追寻者创作必属精品,读完本篇你将获得基础的文件操作能力,深入理解文件操作API,基础真的很重要,不管学什么知识,故看知识追寻者的专题系列真的很不错. 二 ...
 
随机推荐
- boi剖析 - 基于webpack的css sprites实现方案
			
本文是58到家前端工程化集成解决方案boi的博文系列之一.boi是基于webpack打造的一站式前端工程化解决方案,现已开源Github. 作为前端构建工具不可或缺的一个环节,自动生成css spri ...
 - [转载]逐步建设企业DevOps能力
			
当软件行业进入互联网时代,市场对软件产品和服务的交付提出了更高的要求:不仅要快速实现需求,而且要快速发布上线,并且必须保证业务可靠.高效运行.为了满足这些要求,IT组织需要强有力的流程.技术和人员作为 ...
 - 充实你的素材库!10款免费的 PSD 素材下载
			
由于网页设计师没有时间来自己从零开始设计,所以在设计项目中使用网络上已有的设计素材是常见的方式.这就是为什么我们经常会到网上搜索可以免费下载的素材. 今天,我们这里有几套不同的免费的 PSD 素材分享 ...
 - Weblogic魔法堂:AdminServer.lok被锁导致启动、关闭域失败
			
一.判断AdminServer.lok被其进程锁死 >weblogic.management.ManagementException: Unable to obtain lock on **** ...
 - EFcodeFirst+T4=操纵任意数据库
			
之前有写过两篇,EF选择Mysql数据源 跟 EF添加ADO.NET实体模型处直接选择Oracle数据源,其方便之处就不多说了,使用DBfirst直接点点点就能与数据库双向更新,而且关键是方便我们使用 ...
 - 怎么快速了解自己的MySQL服务器
			
1.查看数据库服务器状态:status Linux 下的MySQL服务器状态 该列表中主要包括MySQL的版本(为version 5.1.61).运行平台(debian-linux-gnu(i68 ...
 - 详细介绍ASP.NET页面间数据传递的使用方法
			
源码:http://www.jinhusns.com/Products/Download/?type=xcj 在ASP.NET中,页面间数据传递的方法有很多.下面为大家总结一下,页面间数据传递的方法. ...
 - 基于吉日嘎底层架构的Web端权限管理操作演示-角色管理
			
上一篇介绍了用户管理,这篇来介绍角色管理,这是权限管理的核心部分,因为我们的权限管理系统是基于角色的,有个高大上的英文名叫RBAC(Role Based Acccess Control). 下面的这段 ...
 - JPHP试用笔记
			
JPHP试用指南 编译 环境准备 有JDK 1.6 的环境 Gradle 1.4 以上 具体配置略过,git签出https://github.com/dim-s/jphp/代码后,看readme.md ...
 - inotify--内核中文件系统的通知机制
			
转载:http://www.ibm.com/developerworks/cn/linux/l-inotifynew/index.html 一. 引言 众所周知,Linux 桌面系统与 MAC 或 W ...