快速傅里叶变换快速傅立叶变换的输入是什么,输出是什么,有什么物理意义?

快速傅里叶变换  时间:2021-06-02  阅读:()

什么是快速傅立叶计算机?

傅立叶变换分为: 连续傅立叶变换; 离散傅立叶变换; 这两种变换应用到计算机中都有一种近似的快速数值算法,叫做快速傅立叶变换。

具体的理论推导这里也说不清,我也有点忘了。

这个你可以在数学分析、信号与系统等学科的教材里找到。

你所谓的光学傅立叶变换应该就是一般的没有经过优化近似的傅立叶变换,而且应该是连续的,即“连续傅立叶变换”。

而计算机领域,尤其是信号处理领域,你因该知道计算机处理的数据都是离散的,如果你学过数值计算,就知道计算机都是用离散来逼近连续函数的。

所以计算机的信号处理领域多是用离散傅立叶变换,而且由于计算机要求实时处理,要快,所以又发明了一种快速算法。

所以就是“快速离散傅立叶变换”。

用C语言编写快速傅立叶变换源代码

// 函数名: 快速傅立叶变换(来源《C常用算法集》) // 本函数测试OK,可以在TC2.0,VC++6.0,Keil C51测试通过。

// 如果你的MCS51系统有足够的RAM时,可以验证一下用单片机处理FFT有多么的慢。

// // 入口参数: // l: l = 0, 傅立叶变换; l = 1, 逆傅立叶变换 // il: il = 0,不计算傅立叶变换或逆变换模和幅角;il = 1,计算模和幅角 // n: 输入的点数,为偶数,一般为32,64,128,...,1024等 // k: 满足n=2^k(k>0),实质上k是n个采样数据可以分解为偶次幂和奇次幂的次数 // pr[]: l="0时",存放N点采样数据的实部 // l="1时", 存放傅立叶变换的N个实部 // pi[]: l="0时",存放N点采样数据的虚部 // l="1时", 存放傅立叶变换的N个虚部 // // 出口参数: // fr[]: l="0", 返回傅立叶变换的实部 // l="1", 返回逆傅立叶变换的实部 // fi[]: l="0", 返回傅立叶变换的虚部 // l="1", 返回逆傅立叶变换的虚部 // pr[]: il = 1,i = 0 时,返回傅立叶变换的模 // il = 1,i = 1 时,返回逆傅立叶变换的模 // pi[]: il = 1,i = 0 时,返回傅立叶变换的辐角 // il = 1,i = 1 时,返回逆傅立叶变换的辐角 // data: 2005.8.15,Mend Xin Dong kkfft(double pr[], double pi[], int n, int k, double fr[], double fi[], int l, int il) { int it,m,is,i,j,nv,l0; double p,q,s,vr,vi,poddr,poddi; for (it=0; it<=n-1; it++) { m = it; is = 0; for(i=0; i<=k-1; i++) { j = m/2; is = 2*is+(m-2*j); m = j; } fr[it] = pr[is]; fi[it] = pi[is]; } //---------------------------- pr[0] = 1.0; pi[0] = 0.0; p = 6.283185306/(1.0*n); pr[1] = cos(p); pi[1] = -sin(p);

if (l!=0) pi[1]=-pi[1];

for (i=2; i<=n-1; i++) { p = pr[i-1]*pr[1]; q = pi[i-1]*pi[1]; s = (pr[i-1]+pi[i-1])*(pr[1]+pi[1]); pr[i] = p-q; pi[i] = s-p-q; }

for (it=0; it<=n-2; it="it"+2) { vr = fr[it]; vi = fi[it]; fr[it] = vr+fr[it+1]; fi[it] = vi+fi[it+1]; fr[it+1] = vr-fr[it+1]; fi[it+1] = vi-fi[it+1]; } m = n/2; nv = 2;

for (l0=k-2; l0>=0; l0--) { m = m/2; nv = 2*nv; for(it=0; it<=(m-1)*nv; it="it"+nv) for (j=0; j<=(nv/2)-1; j++) { p = pr[m*j]*fr[it+j+nv/2]; q = pi[m*j]*fi[it+j+nv/2]; s = pr[m*j]+pi[m*j]; s = s*(fr[it+j+nv/2]+fi[it+j+nv/2]); poddr = p-q; poddi = s-p-q; fr[it+j+nv/2] = fr[it+j]-poddr; fi[it+j+nv/2] = fi[it+j]-poddi; fr[it+j] = fr[it+j]+poddr; fi[it+j] = fi[it+j]+poddi; } }

if(l!=0) { for(i=0; i<=n-1; i++) { fr[i] = fr[i]/(1.0*n); fi[i] = fi[i]/(1.0*n); } } if(il!=0) { for(i=0; i<=n-1; i++) { pr[i] = sqrt(fr[i]*fr[i]+fi[i]*fi[i]); if(fabs(fr[i])<0.000001*fabs(fi[i])) { if ((fi[i]*fr[i])>0) pi[i] = 90.0; else pi[i] = -90.0; } else pi[i] = atan(fi[i]/fr[i])*360.0/6.283185306; } } return; }

快速傅立叶变换的输入是什么,输出是什么,有什么物理意义?

输入是一个非周期,长度为N点序列,输出同样是一个非周期,长度为N点序列,只是各点的值不一样。

它把时域信号转变到频域进行分析处理。

输入是在时间轴上的各个值,而输出则是输入序列各频率分量的值。

需要注意的是,输入是非周期的N点序列,但运算时我们却把它以N为周期做周期延拓,然后进行运算;而输出按理应该是周期的,但只需要取一个周期就可以表示出整个序列,所以我们只取一个周期的N点。

对快速傅立叶变换进行其他运算时,需要注意其隐含的周期性。

这个是数字信号处理领域里的一个具有划时代意义的发现,使得离散傅立叶变换的计算量减少了几个数量级,使计算机实现实时处理成为可能。

自从库利,图基两人的关于快速傅立叶变换计算方法的论文发表以来,数字信号处理从连续信号处理中独立出来,形成一个完整体系。

它是近代计算机技术飞速发展的基础。

关于复数序列,你可以把复数放到成自然常数e的指数上去,就是对这个函数的采样。

tmhhost:暑假快乐,全高端线路,VPS直接8折,200G高防,美国gia日本软银韩国cn2香港cn2大带宽

tmhhost为2021年暑假开启了全场大促销,全部都是高端线路的VPS,速度快有保障。美国洛杉矶CN2 GIA+200G高防、洛杉矶三网CN2 GIA、洛杉矶CERA机房CN2 GIA,日本软银(100M带宽)、香港BGP直连200M带宽、香港三网CN2 GIA、韩国双向CN2。本次活动结束于8月31日。官方网站:https://www.tmhhost.com8折优惠码:TMH-SUMMER日本...

陆零(¥25)云端专用的高性能、安全隔离的物理集群六折起

陆零网络是正规的IDC公司,我们采用优质硬件和网络,为客户提供高速、稳定的云计算服务。公司拥有一流的技术团队,提供7*24小时1对1售后服务,让您无后顾之忧。我们目前提供高防空间、云服务器、物理服务器,高防IP等众多产品,为您提供轻松上云、安全防护 为核心数据库、关键应用系统、高性能计算业务提供云端专用的高性能、安全隔离的物理集群。分钟级交付周期助你的企业获得实时的业务响应能力,助力核心业务飞速成...

legionbox:美国、德国和瑞士独立服务器,E5/16GB/1Gbps月流量10TB起/$69/月起

legionbox怎么样?legionbox是一家来自于澳大利亚的主机销售商,成立时间在2014年,属于比较老牌商家。主要提供VPS和独立服务器产品,数据中心包括美国洛杉矶、瑞士、德国和俄罗斯。其中VPS采用KVM和Xen架构虚拟技术,硬盘分机械硬盘和固态硬盘,系统支持Windows。当前商家有几款大硬盘的独立服务器,可选美国、德国和瑞士机房,有兴趣的可以看一下,付款方式有PAYPAL、BTC等。...

快速傅里叶变换为你推荐
chinapay贝宝和支付宝的区别iso20000认证ISO20000认证扫图问个非常白痴的问题撒,扫图是什么意思?12种颜色水粉颜料调色过程十二种颜色js后退javascript怎么禁用浏览器后退按钮部署工具win10 评估和部署工具包有什么用币众筹众筹平台开发哪家好文本框透明html怎么把这个文本框变为透明?数据库界面如何创建数据库网络电话免费版有没有免费的网络电话?纯免费的
花生壳域名贝锐 秒解服务器 wdcp 鲜果阅读 怎么测试下载速度 息壤代理 酷番云 最漂亮的qq空间 网页提速 路由跟踪 腾讯网盘 数据湾 脚本大全 美国代理服务器 美国西雅图独立 9929 什么是云主机 xendesktop 视频监控服务器 hp存储服务器 更多