实验2matlab中基2DITFFT的实现_第1页
实验2matlab中基2DITFFT的实现_第2页
实验2matlab中基2DITFFT的实现_第3页
实验2matlab中基2DITFFT的实现_第4页
实验2matlab中基2DITFFT的实现_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、电 子 科 技 大 学实 验 报 告学生姓名: 学 号:2010013080 指导教师一、实验室名称:数字信号处理实验室二、实验项目名称:FFT的实现三、实验原理:一 FFT算法思想:1 DFT的定义:对于有限长离散数字信号xn,0 £ n £ N-1,其离散谱xk可以由离散付氏变换(DFT)求得。DFT的定义为:,k=0,1,N-1通常令,称为旋转因子。2 直接计算DFT的问题及FFT的基本思想:由DFT的定义可以看出,在xn为复数序列的情况下,完全直接运算N点DFT需要(N-1)2次复数乘法和N(N-1)次加法。因此,对于一些相当大的N值(如1024)来说,直接计算它的

2、DFT所作的计算量是很大的。FFT的基本思想在于,将原有的N点序列分成两个较短的序列,这些序列的DFT可以很简单的组合起来得到原序列的DFT。例如,若N为偶数,将原有的N点序列分成两个(N/2)点序列,那么计算N点DFT将只需要约(N/2)2 ·2=N2/2次复数乘法。即比直接计算少作一半乘法。因子(N/2)2表示直接计算(N/2)点DFT所需要的乘法次数,而乘数2代表必须完成两个DFT。上述处理方法可以反复使用,即(N/2)点的DFT计算也可以化成两个(N/4)点的DFT(假定N/2为偶数),从而又少作一半的乘法。这样一级一级的划分下去一直到最后就划分成两点的FFT运算的情况。3

3、基2按时间抽取(DIT)的FFT算法思想:设序列长度为,L为整数(如果序列长度不满足此条件,通过在后面补零让其满足)。将长度为的序列,先按n的奇偶分成两组:,r=0,1,N/2-1DFT化为:上式中利用了旋转因子的可约性,即:。又令,则上式可以写成:(k=0,1,N/2-1)可以看出,分别为从中取出的N/2点偶数点和奇数点序列的N/2点DFT值,所以,一个N点序列的DFT可以用两个N/2点序列的DFT组合而成。但是,从上式可以看出,这样的组合仅表示出了前N/2点的DFT值,还需要继续利用表示的后半段本算法推导才完整。利用旋转因子的周期性,有:,则后半段的DFT值表达式:,同样, (k=0,1,

4、N/2-1),所以后半段(k=N/2,N-1)的DFT值可以用前半段k值表达式获得,中间还利用到,得到后半段的值表达式为:(k=0,1,N/2-1)。这样,通过计算两个N/2点序列的N/2点DFT,可以组合得到N点序列的DFT值,其组合过程如下图所示: -1 比如,一个N = 8点的FFT运算按照这种方法来计算FFT可以用下面的流程图来表示:4 基2按频率抽取(DIF)的FFT算法思想:设序列长度为,L为整数(如果序列长度不满足此条件,通过在后面补零让其满足)。在把按k的奇偶分组之前,把输入按n的顺序分成前后两半:因为,则有,所以:按k的奇偶来讨论,k为偶数时:k为奇数时:前面已经推导过,所以

5、上面的两个等式可以写为:通过上面的推导,的偶数点值和奇数点值分别可以由组合而成的N/2点的序列来求得,其中偶数点值为输入xn的前半段和后半段之和序列的N/2点DFT值,奇数点值为输入xn的前半段和后半段之差再与相乘序列的N/2点DFT值。令,则有:这样,也可以用两个N/2点DFT来组合成一个N点DFT,组合过程如下图所示: -1 二 在FFT计算中使用到的MATLAB命令:函数fft(x)可以计算R点序列的R点DFT值;而fft(x,N)则计算R点序列的N点DFT,若R>N,则直接截取R点DFT的前N点,若R<N,则x先进行补零扩展为N点序列再求N点DFT。函数ifft(X)可以计

6、算R点的谱序列的R点IDFT值;而ifft(X,N)同fft(x,N)的情况。四、实验目的:离散傅氏变换(DFT)的目的是把信号由时域变换到频域,从而可以在频域分析处理信息,得到的结果再由逆DFT变换到时域。FFT是DFT的一种快速算法。在数字信号处理系统中,FFT作为一个非常重要的工具经常使用,甚至成为DSP运算能力的一个考核因素。本实验通过直接计算DFT,利用FFT算法思想计算DFT,以及使用MATLAB函数中的FFT命令计算离散时间信号的频谱,以加深对离散信号的DFT变换及FFT算法的理解。五、实验内容:a) 计算实数序列的256点DFT。b) 计算周期为1kHz的方波序列(占空比为50

7、,幅度取为/-512,采样频率为25kHz,取256点长度) 256点DFT。六、实验器材(设备、元器件):安装MATLAB软件的PC机一台,DSP实验演示系统一套。七、实验步骤:(1) 先利用DFT定义式,编程直接计算2个要求序列的DFT值。(2) 利用MATLAB中提供的FFT函数,计算2个要求序列的DFT值。(3) (拓展要求)不改变序列的点数,仅改变DFT计算点数(如变为计算1024点DFT值),观察画出来的频谱与前面频谱的差别,并解释这种差别。通过这一步骤的分析,理解频谱分辨力的概念,解释如何提高频谱分辨力。(4) 利用FFT的基本思想(基2DIT或基2DIF),自己编写FFT计算函

8、数,并用该函数计算要求序列的DFT值。并对前面3个结果进行对比。(5) (拓展要求)尝试对其他快速傅立叶变换算法(如Goertzel算法)进行MATLAB编程实现,并用它来计算要求的序列的DFT值。并与前面的结果进行对比。(6) (拓展要求)在提供的DSP实验板上演示要求的2种序列的FFT算法(基2DIT),用示波器观察实际计算出来的频谱结果,并与理论结果对比。八、实验数据及结果分析:程序:(1) 对要求的2种序列直接进行DFT计算的程序%第一种序列的计算N=0:255;X=cos(5*pi*N/16);for a=1:256 Y(a)=0; for b=1:256 Y(a)=Y(a)+X(b

9、)*exp(-j*2*pi*(b-1)*(a-1)/256); endendsubplot(2,1,1)stem(N,abs(Y)title('DFTµÄ½á¹û')subplot(2,1,2)Y2=fft(X);stem(N,Y2)title('FFTµÄ½á¹û')%第二种序列的计算N=0:1/(1000*25):255/(1000*25);X=512*square(2*pi*N*1000);for a=1:256 Y(a)=0; for

10、b=1:256 Y(a)=Y(a)+X(b)*exp(-j*2*pi*(b-1)*(a-1)/256); endendY%»­fftºÍÉÏÃæµÄ½á¹ûµÄ¶Ô±Èf=0:255;Y1=fft(X);subplot(2,1,1)stem(f,Y)title('DFTµÄ½á¹û')subplot(2,1,2)stem(

11、f,Y1)title('FFTµÄ½á¹û')(2) 对要求的2种序列进行基2DIT和基2DIF FFT算法程序%基-2DIT-FFT的算法%»ù-2-DIT-FFTclearclctic%½«¶ÔÊäÈëÐòÁÐx²¹ÁãÖÁ2M¸öN=input('ÇëÊ

12、28;ÈëµãÊýN=');x=input('ÇëÊäÈëÐòÁÐx(ÆäÖÐÒѾ­¶¨ÒåÁËn=0:N-1)=');M=nextpow2(length(x);N=2M;n=0:N-1;x=x,zeros(1,N-length(x);%¶ÔÊ

13、äÈëµÄÐòÁÐx½øÐÐÖØÐÂÅÅÐòLH=N/2;j1=LH;N1=N-2;for i=1:N1 if(i<j1) T=x(i+1); x(i+1)=x(j1+1); x(j1+1)=T; end k=LH; while(j1>=k) j1=j1-k; k=k/2; end j1=j1+k; end%½øÐе

14、1;ÐÎÔËËãfor L=1:M %¼¶ÊýµÄÑ­»· B=2(L-1); for i=0:B-1 %ͬһ¼¶ÐýתÒò×ÓµÄÑ­»· p=i*2(M-L); for k=i:2L:(2(M-L)-1)*(2L)+i %

15、5;¬Ò»¼¶Í¬Ò»¸öÐýתÒò×ÓµÄÑ­»·.£¨ÔÚL¼¶ÖÐͬһ¸öÐýתÒò×Ó³ö&#

16、207;Ö2(M-L)´Î£© temp=x(k+1); x(k+1)=temp+x(k+1+B)*exp(-j*2*pi*p/N); x(k+1+B)=temp-x(k+1+B)*exp(-j*2*pi*p/N); end endendstem(n,x)title('»ù-2-DIT-FFTµÄ½á¹û')time=toc %基-2-DIF-FFT的算法%»ù-2-DIT-FFTclearclctic%½«&

17、#182;ÔÊäÈëÐòÁÐx²¹ÁãÖÁ2M¸öN=input('ÇëÊäÈëµãÊýN=');x=input('ÇëÊäÈëÐòÁÐx(ÆäÖÐÒ

18、09;¾­¶¨ÒåÁËn=0:N-1)=');M=nextpow2(length(x);N=2M;n=0:N-1;x=x,zeros(1,N-length(x);%¶ÔÊäÈëµÄÐòÁÐx½øÐÐÖØÐÂÅÅÐòLH=N/2;j1=LH;N1=N-2;for i=1:N

19、1 if(i<j1) T=x(i+1); x(i+1)=x(j1+1); x(j1+1)=T; end k=LH; while(j1>=k) j1=j1-k; k=k/2; end j1=j1+k; end%½øÐеûÐÎÔËËãfor L=1:M %¼¶ÊýµÄÑ­»· B=2(L-1); for i=0:B-1 %ͬһ

20、;¼¶ÐýתÒò×ÓµÄÑ­»· p=i*2(M-L); for k=i:2L:(2(M-L)-1)*(2L)+i %ͬһ¼¶Í¬Ò»¸öÐýתÒò×ÓµÄÑ­»·.

21、63;¨ÔÚL¼¶ÖÐͬһ¸öÐýתÒò×Ó³öÏÖ2(M-L)´Î£© temp=x(k+1); x(k+1)=temp+x(k+1+B)*exp(-j*2*pi*p/N); x(k+1+B)=temp-x(k+1+B)*exp(-j*2*pi*p/N); end endendstem(n,x)title('»ù-2-DIT-FFTµÄ½á¹û')time=toc (3) 对要求的2种序列用MATLAB中提供的FFT函数进行计算的程序N=0:255;w=0:4095;X=512*square(2*pi*1000*N/25000);y1=fft(X)

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论