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

快速傅里叶变换  时间: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的指数上去,就是对这个函数的采样。

白丝云-美国圣何塞4837/德国4837大带宽/美西9929,26元/月起

官方网站:点击访问白丝云官网活动方案:一、KVM虚拟化套餐A1核心 512MB内存 10G SSD硬盘 800G流量 2560Mbps带宽159.99一年 26一月套餐B1核心 512MB内存 10G SSD硬盘 2000G流量 2560Mbps带宽299.99一年 52一月套餐...

virmach:AMD平台小鸡,赌一把,单车变摩托?$7.2/年-512M内存/1核/10gSSD/1T流量,多机房可选

virmach送来了夏季促销,价格低到爆炸,而且在低价的基础上还搞首年8折,也就是说VPS低至7.2美元/年。不过,这里有一点要说明:你所购买的当前的VPS将会在09/30/2021 ~ 04/30/2022进行服务器转移,而且IP还会改变,当前的Intel平台会换成AMD平台,机房也会变动(目前来看以后会从colocrossing切换到INAP和Psychz),采取的是就近原则,原来的水牛城可能...

零途云:香港站群云服务器16IP220元/月,云服务器低至39元/月

零途云(Lingtuyun.com)新上了香港站群云服务器 – CN2精品线路,香港多ip站群云服务器16IP/5M带宽,4H4G仅220元/月,还有美国200g高防云服务器低至39元/月起。零途云是一家香港公司,主要产品香港cn2 gia线路、美国Cera线路云主机,美国CERA高防服务器,日本CN2直连服务器;同时提供香港多ip站群云服务器。即日起,购买香港/美国/日本云服务器享受9折优惠,新...

快速傅里叶变换为你推荐
知识分享平台微信看到一些文章,可以分享到知识付费的平台吗?怎么操作呀?vga接口定义电脑显示屏VGA是什么意思asp大马问:ASP是什么?ASP根据什么制作木马的?ASP木马和大马有什么区别?币众筹众筹有哪几种 众筹如何实现回报文本框透明word文本框的背景图片怎样调透明度文本框透明html怎么把这个文本框变为透明?bt代理有人推荐我成为btbank代理人,这个没有什么风险?什么是网络地址请问电脑显示正在获取网络地址是什么意思怎么办embed函数datedif是什么函数哈?value又是什么函数哈yy号注册怎么申请yy号
域名服务器上存放着internet主机的 免费二级域名申请 已经备案域名 国外私服 域名优惠码 debian6 php免费空间 国内php空间 最好的免费空间 中国网通测速 paypal注册教程 超级服务器 空间登入 阿里云免费邮箱 主机管理系统 杭州电信宽带 xshell5注册码 web是什么意思 linux服务器系统 西部数码主机 更多