Matlab仿真实验实验报告学院:电子工程学院专业:电子信息科学与技术班级:2012211201学号:2012210815姓名:李昊轩时间:2014年12月19日实验一:数字信号的FFT分析1.实验目的通过本次试验,应该掌握:(a)用傅里叶变换进行信号分析时基本参数的选择(b)经过离散时间傅里叶变换和有限长度离散傅里叶变换后信号频谱上的区别,前者DTFT时间域是离散信号,频率域还是连续的,而DFT在两个域中都是离散的。(c)离散傅里叶变化的基本原理、特性,以及经典的快速算法(基2时间抽选法),体会快速算法的效率。(d)获得一个高密度频谱和高分辨率频谱的概念和方法,建立频率分辨率和时间分辨率的概念,为将来进一步进行时频分析(例如小波)的学习和研究打下基础。(e)建立DFT从整体上可看成是由窄带相邻滤波器组成的滤波器组的概念,此概念的一个典型应用时数字音频压缩中的分析滤波器,例如DVDAC3和MPEGAudio。2.实验内容、要求及结果。(1)离散信号的频谱分析:设信号x(n)=0.001*cos(0.45nπ)+sin(0.3nπ)-cos(0.302nπ-π4)此信号的0.3π和0.302π两根谱线相距很近,谱线0.45π的幅度很小,请选择合适的序列长度N和窗函数,用DFT分析其频谱,要求得到清楚的三根谱线。【实验代码】:clear;closeall;N=5000;n=1:1:N;x=0.001*cos(0.45*n*pi)+sin(0.3*n*pi)-cos(0.302*n*pi-pi/4);y=fft(x,N);a=abs(y(1:1:N/2+1));k=0:1:N/2;w=2*pi/N*k;stem(w/pi,a);axis([0.29,0.46,0,10]);【实验结果图】:(2)DTMF信号频谱分析用计算机声卡采集一段通信系统中电话双音多频(DTMF)拨号数字0~9的数据,采用快速傅里叶变换(FFT)分析这10个号码DTMF拨号时的频谱。【实验代码】:num=[1,2,3,65;4,5,6,66;7,8,9,67;42,0,35,68];f1=[697,770,852,941];f2=[1209,1336,1477,1633];in=input('键入1位0-9的数字=');forp=1:4forq=1:4ifnum(p,q)==in,break,endendifnum(p,q)==in,break,endendn=0:1023;x=sin(2*pi*n*f1(p)/8000)+sin(2*pi*n*f2(q)/8000);X=fft(x',1024);X=abs(X);y=sort(X);fori=1:1024ifX(i)=y(1020)X(i)=0;end;endx=[1:512]./512*4000;X=X(1:512);f0=[];fori=1:512ifX(i)~=0f0=[f0,i];endendf0=round(f0*8000/1024);stem(x,X);text(2000,350,['所拨打的号码:',int2str(in)]);text(2000,300,['检测到的频率:',int2str(f0)]);text(2000,250,['查表所得频率:',int2str([f1(p),f2(q)])]);title('DTMF信号频谱分析');实验二:DTMF信号的编码1.实验目的:(a)复习和巩固IIR数字滤波器的基本概念;(b)掌握IIR数字滤波器的设计方法;(c)掌握IIR数字滤波器的实现结构;(d)能够由滤波器的实现结构分析滤波器的性能(字长效应);(e)了解通信系统电话DTMF拨号的基本原理和IIR数字滤波器的实现方法。2.实验内容、要求及结果:1)把你的联系电话号码通过DTMF编码生成一个.wav文件。技术指标:根据ITUQ.23建议,DTMF信号的技术指标是:传送/接收率为每秒10个号码,或每个号码100ms。每个号码传送过程中,信号存在时间至少45ms,且不多于55ms,100ms的其余时间是静音。在每个频率点上允许有不超过±1.5%的频率误差。任何超过给定频率±3.5%的信号,均被认为是无效的,拒绝接收。(其中关键是不同频率的正弦波的产生。可以使用查表方式模拟产生两个不同频率的正弦波。正弦表的制定要保证合成信号的频率误差在±1.5%以内,同时是取样点数尽量少)【实验代码】:tm=[1,2,3,65;4,5,6,66;7,8,9,67;42,0,35,68];N=205;K=[18,20,22,24,31,34,38,42];f1=[697,770,852,941];f2=[1209,1336,1477,1633];wav=[];TN=input('请您拨出11位手机号码=');TN2=TN;TNr=0;form=1:11d=fix(TN/10^(11-m));TN=TN-d*10^(11-m);forp=1:4;forq=1:4;iftm(p,q)==abs(d),break,endendiftm(p,q)==abs(d),break,endendn=1:400;x=sin(2*pi*n*f1(p)/8000)+sin(2*pi*n*f2(q)/8000);wav=[wav,x,zeros(1,400)];endx=[1:8800]./8800*11;plot(x,wav)title('DTMF信号的时域波形','color','b');text(2,4,['您拨打的手机号:',int2str(TN2)],'color','r');axis([0,12,-5,5])sound(wav,8000);wav=wav./2;wavwrite(wav,8000,'拨号音')2)对所生成的DTMF文件进行解码。DTMF信号解码可以采用FFT计算N点频率处的频谱值,然后估计出所拨号码。但FFT计算了许多不需要的值,计算量太大,而且为保证频率分辨率,FFT的点数较大,不利于实时实现。因此,FFT不适合于DTMF信号解码的应用。由于只需要知道8个特定点的频谱值,因此采用一种称为Goertzel算法的IIR滤波器可以有效的提高计算效率。其传递函数为:Hk(z)=1−e−j2πkNZ−11−2cos(2πkN)Z−1+Z−2【实验代码】:tm=[1,2,3,65;4,5,6,66;7,8,9,67;42,0,35,68];N=205;K=[18,20,22,24,31,34,38,42];f1=[697,770,852,941];f2=[1209,1336,1477,1633];TNr=0;wav=wavread('拨号音.wav');wav=wav.*2;figure(1)x=[1:8800]./8800*11;plot(x,wav)axis([0,12,-5,5])sound(wav,8000);figure(2)form=1:11xulie=wav((m-1)*800+1:(m-1)*800+205);X=goertzel(xulie,K+1);val=abs(X);subplot(4,3,m);stem(K,val,'.');grid;;ylabel('|X(k)|')axis([10500120])limit=80;fors=5:8;ifval(s)limit,break,endendforr=1:4;ifval(r)limit,break,endendTNr=TNr+tm(r,s-4)*10^(11-m);hao=int2str(tm(r,s-4));title(hao,'color','r');enddisp('接收端检测到的号码为:')disp(num2str(TNr))实验三:FIR数字滤波器的设计和实现1.实验目的:通过本次试验,掌握一下知识:FIR数字滤波器窗口设计法的原理和设计步骤;Gibbs效应发生的原因和影响;不同类型的窗函数对滤波效果的影响,以及窗函数和长度N的选择。(效果,耳机听前后声音,或者看前后的频谱图)2.实验内容、要求及结果:录制一段自己的声音,长度为十几秒,取样频率32khz,然后叠加一个高斯白噪声,(知道噪声分布,知道噪声功率,只要知道输入信号功率),使得信噪比为20db。请采用窗口法,设计一个FIR带通滤波器,滤除噪声提高质量。提示:滤波器指标参考:通带边缘频率为4khz,阻带边缘频率为4.5khz,阻带衰减大于50db;Matlab函数y=awgn(x,snr,’measured’),首先测量输入信号x的功率,然后对其叠加高斯白噪声。【实验代码】:clc,clearfs=32000;[x,fs,bits]=wavread('1.wav');snr=20;x2=awgn(x,snr,'measured','db');wavwrite(x2,fs,16,'2.wav');t=0:1/fs:(size(x2)-1)/fs;wp=8000*pi/32000;ws=9000*pi/32000;wdelta=ws-wp;N=ceil(11*pi/wdelta);%取整wn=(ws+wp)/2;b=fir1(N,wn/pi,blackman(N+1));%选择窗函数,并归一化截止频率figure(1)freqz(b,1,512)f2=filter(b,1,x2);title('滤波器幅频、相频特性');figure(2)subplot(2,1,1)plot(t,x2)title('滤波前时域波形');subplot(2,1,2)plot(t,f2)title('滤波后时域波形');F0=fft(f2,1024);f=fs*(0:511)/1024;figure(3)y2=fft(x2,1024);subplot(2,1,1)plot(f,abs(y2(1:512)));title('滤波前频谱')xlabel('Hz');ylabel('幅度');subplot(2,1,2)F2=plot(f,abs(F0(1:512)));title('滤波后频谱')xlabel('Hz');ylabel('幅度');wavwrite(f2,fs,16,'3.wav');【实验结果图】:实验问题及总结:在这次实验之前我就有接触过一些关于matlab的学习,那是大一下学期的专业选修课,不过当时并没有实践,大部分还是理论的学习,这次的matlab实验让我学到了许多,以前是学过matlab的,但是已经忘的差不多了,正好有这次机会让我重新复习相关的知识。把matlab与数字信号处理的相关知识很好的联系到一起。首先通过这次试验,使我更加深刻的理解DFT、FFT以及滤波器的原理和应用,并且能够用仿真软件设计滤波器达到滤除高斯白噪声的目的。在数字信号处理的理论课上,对于傅里叶变换、数字滤波器等知识的了解并不是很深刻,但是通过这次试验,我更好的理解了用傅里叶变换进行信号分析时基本参数的选择、离散时间傅里叶变换和有限长度离散傅里叶变换后信号频谱上的区别、离散傅里叶变化的基本原理、特性,以及经典的快速算法的效率,也更好的掌握了IIR数字滤波器的设计方法、实现结构及其性能,还有不同类型的窗函数对滤波效果的影响,以及窗函数和长度N的选择。在实验过程中还是不可避免的遇到了一些问题,一开始对于matlab软件的使用完全不熟悉,对于其中一些函数的运用也相当生疏,所以即使第一题比较简单,也花了相当一部分时间才完成。后来逐渐熟悉了,遇到的问题也通过自己上网查找资料得以解决。虽然课程时间非常短,不过让我有了对于MATLAB学习方向的掌握,相信以后对此的学习也不是是么问题,最后,谢谢老师的教导!