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

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

SugarHosts新增Windows云服务器sugarhosts六折无限流量云服务器六折优惠

SugarHosts糖果主机商我们较早的站长们肯定是熟悉的,早年是提供虚拟主机起家的,如今一直还在提供虚拟主机,后来也有增加云服务器、独立服务器等。数据中心涵盖美国、德国、香港等。我们要知道大部分的海外主机商都只提供Linux系统云服务器。今天,糖果主机有新增SugarHosts夏季六折的优惠,以及新品Windows云服务器/云VPS上线。SugarHosts Windows系统云服务器有区分限制...

Gigsgigscloud($9.8)联通用户优选日本软银VPS

gigsgigsCloud日本东京软银VPS的大带宽配置有100Mbps、150Mbps和200Mbps三种,三网都走软银直连,售价最低9.8美元/月、年付98美元。gigsgigscloud带宽较大延迟低,联通用户的好选择!Gigsgigscloud 日本软银(BBTEC, SoftBank)线路,在速度/延迟/价格方面,是目前联通用户海外VPS的最佳选择,与美国VPS想比,日本软银VPS延迟更...

青果云(59元/月)香港多线BGP云服务器 1核 1G

青果云香港CN2_GIA主机测评青果云香港多线BGP网络,接入电信CN2 GIA等优质链路,测试IP:45.251.136.1青果网络QG.NET是一家高效多云管理服务商,拥有工信部颁发的全网云计算/CDN/IDC/ISP/IP-VPN等多项资质,是CNNIC/APNIC联盟的成员之一。青果云香港CN2_GIA主机性能分享下面和大家分享下。官方网站:点击进入CPU内存系统盘数据盘宽带ip价格购买地...

快速傅里叶变换为你推荐
excel计算公式excel表格如何用公式计算加减乘除混合运算数据监测什么是媒体监测?自定义表情QQ自定义表情star413匡威jack star 的后标是不是真的?如图jstz举手望,草上马跑,打什么数字?jstz谁有101网校的账号?天翼校园宽带天翼校园宽带怎么样用手机打开这个页面登陆微软操作系统下载微软的系统到哪下载kjava谁能告诉我KJAVA是什么意思和普通的JAVA程序有什么区别?bt代理有人推荐我成为btbank代理人,这个没有什么风险?
香港虚拟主机 未注册域名查询 出租服务器 免费试用vps 免费com域名申请 万网免费域名 fdcservers Vultr php主机 softbank官网 好看的桌面背景图 腾讯云分析 网站cdn加速 秒杀汇 免费美国空间 hkt 流媒体加速 安徽双线服务器 登陆qq空间 万网注册 更多