FFT算法实现_DIT.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
FFT算法实现——DIT源代码1:function X = FFT_func1( x )%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%没有用bitrevorder命令%%%%%%%%%%%%%%%%%%%%%x_1=load(data.txt);N=length(x_1);M=ceil(log2(N));%如果N不等于2^M,zero-paddingx=zeros(2^M);N=2^M;for ii=1:length(x_1) x(ii)=x_1(ii);endif M==0 %if语句为考虑特殊情况M==0,即只有一个点做变换 y=0;elsea=zeros(N,M); for jj=1:M for kk=1:(N/(2^(jj-1))) if mod(kk,2)==0 a(((kk-1)*2^(jj-1)+1):kk*2^(jj-1),jj)=1; end endendfor i=1:M b(i)=2^(M-i);endy=a*b; end%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%XX=zeros(N,M+1);for nn=1:N %for循环得出倒序后的x[n],并令之为XX的第一列 XX(nn,1)=x(y(nn)+1);endif M==0 X=x;elsefor m=2:M+1 w=exp(-1i*2*pi/(2^(m-1)));%w为旋转因子 for p=0:2^(M-m+1)-1 for n=1:2^(m-2) XX(n+p*2^(m-1),m)=XX(n+p*2^(m-1),m-1)+XX(n+p*2^(m-1)+2^(m-2),m-1)*w^(n-1); XX(n+p*2^(m-1)+2^(m-2),m)=XX(n+p*2^(m-1),m-1)-XX(n+p*2^(m-1)+2^(m-2),m-1)*w^(n-1); end endendendX=XX(:,M+1); %X为XX的最后一列K=0:N-1; %作图stem(K,abs(X));grid onend源代码2:function X = FFT_recome( x )%%%%%%%%%%%%%%%%%%%%%%用了bitrevorder命令的%%%%%%%%%%%%%%%%%%%%%%%%%x_1=load(data.txt);N=length(x_1);M=ceil(log2(N)); %如果N不等于2^M,zero-paddingN=2^M;x=zeros(N);for ii=1:length(x_1) x(ii)=x_1(ii);endx1=0:N-1;y=bitrevorder(x1);XX=zeros(N,M+1);for nn=1:N%for循环得出倒序后的x[n],并令之为XX的第一列 XX(nn,1)=x(y(nn)+1);endif M==0 X=x;elsefor m=2:M+1 w=exp(-1i*2*pi/(2^(m-1))); %w为旋转因子 for p=0:2^(M-m+1)-1 for n=1:2^(m-2) XX(n+p*2^(m-1),m)=XX(n+p*2^(m-1),m-1)+XX(n+p*2^(m-1)+2^(m-2),m-1)*w^(n-1); XX(n+p*2^(m-1)+2^(m-2),m)=XX(n+p*2^(m-1),m-1)-XX(n+p*2^(m-1)+2^(m-2),m-1)*w^(n-1); end endendendX=XX(:,M+1); %X为XX的最后一列K=0:N-1; %作图stem(K,abs(X));grid onend实验结果:data.txt为与FFT_func1.m和FFT_recome.m同目录下的文件,即为x[n];两个程序的结果相同,都经过MATLAB中fft函数的验证,且结果正确。以下为两个例子结果:(1)取x[0]到x[N-1]依次为1 1 1 2 3 4 5 6 7 8,N=10,补零直到16个点X[k]: 38.0000 -21.6042 -12.4032i 11.3640 + 3.2929i -6.2987 + 1.9773i 5.0000 - 5.0000i -0.0444 + 4.4626i -1.3640 - 4.7071i 3.9474 + 2.0820i

文档评论(0)

gangshou + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档