欢迎来到天天文库
浏览记录
ID:37718866
大小:37.50 KB
页数:4页
时间:2019-05-29
《按时间抽取基2-快速傅里叶逆变换算法_MATLAB代码》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、functionx=MyIFFT_TB(y)%MyIFFT_TB:MyInverseFastFourierTransformTimeBased%按时间抽取基2-傅里叶逆变换算法%input:%y--傅里叶正变换结果,1*N的向量%output:%x--逆变换结果,1*N的向量%参考文献:%http://wenku.baidu.com/view/fea1e985b9d528ea81c779ee.htmlN=length(y);x=conj(y);%求共轭x=MyFFT_TB(x);%求FFTx=conj(x);%求共轭x=x./N;%除以Nend%%内嵌函数=
2、=====================================================functiony=MyFFT_TB(x,n)%MYFFT_TB:MyFastFourierTransformTimeBased%按时间抽取基2-fft算法%input:%x--输入的一维样本%n--变换长度,缺省时n=length(x)当n小于x数据长度时,x数据被截断到第n个数据%当n大于时,x数据在尾部补0直到x含n个数据%output:%y--1*n的向量,快速傅里叶变换结果%variabledefine:%N--一维数据x的长度%xtem--临
3、时储存x数据用%m,M--对N进行分解N=2^m*M,M为不能被2整除的整数%two_m--2^m%adr--变址,1*N的向量%l--当前蝶形运算的级数%W--长为N/2的向量,记录W(0,N),W(1,N),...W(N/2-1,N)%d--蝶形运算两点间距离%t--第l级蝶形运算含有的奇偶数组的个数%mul--标量,乘数%ind1,ind2--标量,下标%tem--标量,用于临时储存%%输入参数个数检查msg=nargchk(1,2,nargin);error(msg);%%输入数据截断或加0N=length(x);ifnargin==2ifN4、0xtem=x;x=zeros(1,n);x(1:N)=xtem;N=n;else%截断xtem=x;x=xtem(1:n);N=n;endend%%对N进行分解N=2^m*M[m,M]=factorize(N);two_m=N/M;%%变换ifm~=0%%如果N可以被2整除adr=address(m,M,two_m);y=x(adr+1);%蝶形运算级数l=m时ifM~=1%N分解含有非2因数M时,对y中每M个数据做直接傅里叶变换forii=1:two_my((ii-1)*M+1:ii*M)=DDFT(y((ii-1)*M+1:ii*M));endend%5、%计算W向量W=exp(-2*pi*i*(0:N/2-1)/N);%%蝶形运算d=M;t=N/2/d;forl=m:-1:1%乘forr=0:d-1mul=W(r*t+1);forii=0:t-1y(ii*2*d+d+1+r)=y(ii*2*d+d+1+r)*mul;endend%加forii=0:t-1ind1=ii*2*d+1;ind2=ind1+d;forr=0:d-1tem=y(ind1)+y(ind2);y(ind2)=y(ind1)-y(ind2);y(ind1)=tem;ind1=ind1+1;ind2=ind2+1;endendd=2*d;t6、=t/2;endelse%%如果N不能被2整除y=DDFT(x);endendfunctiony=DDFT(x)%%直接离散傅里叶变换%input:%x--样本数据,N维向量%output:%y--N维向量%参考文献:%结构动力学,克拉夫,P82%variabledefine%s--sum,用于求和N=length(x);y=zeros(size(x));forn=1:Ns=0;form=1:Ns=s+x(m)*exp(-i*2*pi*(m-1)*(n-1)/N);endy(n)=s;endendfunction[m,M]=factorize(N)%%对N分7、解m=0;whiletrueifmod(N,2)==0m=m+1;N=N/2;elseM=N;break;endendendfunctionadr=address(m,M,two_m)%%变址%b--2^m*m的矩阵,用来存储二进制数据%ds--数,公差adr=zeros(two_m,M);b=de2bi(0:two_m-1,m);%转换为2进制注:matlab中二进制[011]=6b=b(:,end:-1:1);%逆序adr(:,1)=bi2de(b);%2进制转换为10进制ifM~=1ds=two_m;adr=adr(:,1)*ones(1,M);adr8、=adr+ds*ones(size(adr,1),1
4、0xtem=x;x=zeros(1,n);x(1:N)=xtem;N=n;else%截断xtem=x;x=xtem(1:n);N=n;endend%%对N进行分解N=2^m*M[m,M]=factorize(N);two_m=N/M;%%变换ifm~=0%%如果N可以被2整除adr=address(m,M,two_m);y=x(adr+1);%蝶形运算级数l=m时ifM~=1%N分解含有非2因数M时,对y中每M个数据做直接傅里叶变换forii=1:two_my((ii-1)*M+1:ii*M)=DDFT(y((ii-1)*M+1:ii*M));endend%
5、%计算W向量W=exp(-2*pi*i*(0:N/2-1)/N);%%蝶形运算d=M;t=N/2/d;forl=m:-1:1%乘forr=0:d-1mul=W(r*t+1);forii=0:t-1y(ii*2*d+d+1+r)=y(ii*2*d+d+1+r)*mul;endend%加forii=0:t-1ind1=ii*2*d+1;ind2=ind1+d;forr=0:d-1tem=y(ind1)+y(ind2);y(ind2)=y(ind1)-y(ind2);y(ind1)=tem;ind1=ind1+1;ind2=ind2+1;endendd=2*d;t
6、=t/2;endelse%%如果N不能被2整除y=DDFT(x);endendfunctiony=DDFT(x)%%直接离散傅里叶变换%input:%x--样本数据,N维向量%output:%y--N维向量%参考文献:%结构动力学,克拉夫,P82%variabledefine%s--sum,用于求和N=length(x);y=zeros(size(x));forn=1:Ns=0;form=1:Ns=s+x(m)*exp(-i*2*pi*(m-1)*(n-1)/N);endy(n)=s;endendfunction[m,M]=factorize(N)%%对N分
7、解m=0;whiletrueifmod(N,2)==0m=m+1;N=N/2;elseM=N;break;endendendfunctionadr=address(m,M,two_m)%%变址%b--2^m*m的矩阵,用来存储二进制数据%ds--数,公差adr=zeros(two_m,M);b=de2bi(0:two_m-1,m);%转换为2进制注:matlab中二进制[011]=6b=b(:,end:-1:1);%逆序adr(:,1)=bi2de(b);%2进制转换为10进制ifM~=1ds=two_m;adr=adr(:,1)*ones(1,M);adr
8、=adr+ds*ones(size(adr,1),1
此文档下载收益归作者所有