《实验1 信号的时域描述与运算.docx》由会员分享,可在线阅读,更多相关《实验1 信号的时域描述与运算.docx(16页珍藏版)》请在课桌文档上搜索。
1、实验1信号的时域描述与运算一、实验目的1 .掌握信号的MATLAB表示及其可视化方法。2 .掌握信号基本时域运算的MATLAB实现方法。3 .利用MATLAB分析常用信号,加深对信号时域特性的理解二、实验原理与方法1 .连续时间信号的MATLAB表示连续时间信号指的是在连续时间范围内有定义的信号,即除了若干个不连续点外,在任何时刻信号都有定义。在MATLAB中连续时间信号可以用两种方法来表示,即向量表示法和符号对象表示法。从严格意义上来说,MATLAB并不能处理连续时间信号,在MATLAB中连续时间信号是用等时间间隔采样后的采样值来近似表示的,当采样间隔足够小时,这些采样值就可以很好地近似表示
2、出连续时间信号,这种表示方法称为向量表示法表示一个连续时间信号需要使用两个向量,其中一个向量用于表示信号的时间范围,另一个向量表示连续时间信号在该时间范围内的采样值。例如一个正弦信号可以表示如下:t=0:0.01:10;x=sin(t);利用plot(t,x)命令可以绘制上述信号的时域波形,如图1所示。如果连续时间信号可以用表达式来描述,则还可以采用符号表达式来表示信号。例如对于上述正弦信号,可以用符号对象表示如下:x=sin(t);ezplot(X);利用CZPlot(X)命令可以绘制上述信号的时域波形图1利用向量表示连续时间信号MATLAB提供了一些函数用于常用信号的产生,如阶跃信号,脉冲
3、信号,指数信号,正弦信号,表1中列出了一些常用的基本函数表1常用的信号产生函数函数名功能函数名功能Heaviside单位阶跃函数Rectpuls门函数Sin正弦函数Tripuls三角脉冲函数Cos余弦函数Square周期方波Sincsine函数Sawtooth周期锯齿波或三角波Exp指数函数图2利用符号对象表示连续时间信号2 .连续时间信号的时域运算对连续时间信号的运算包括两信号相加、相乘、微分、积分,以及位移、反转、尺度变换(尺度伸缩)等。1)相加和相乘信号相加和相乘指两信号对应时刻的值相加和相乘,对于两个采用向量表示的可以直接使用算术运算的运算符“+”和“*”来计算,此时要求表示两信号的向
4、量时间范围和采样间隔相同。采用符号对象表示的两个信号,可以直接根据符号对象的运算规则运算。2)微分和积分对于向量表示法表示的连续时间信号,可以通过数值计算的方法计算信号的微分和积分。这里微分使用差分来近似求取的,由时间向量K?,和采样值向量石,“2,,XN表示的连续时间信号,其微分可以通过下式求得x()F0z=l,2,”-14r其中加表示采样间隔。MATLAB中用diff函数来计算差分XN-Zo连续时间信号的定积分可以由MATLAB的qud函数实现,调用格式为quad(,functionnamc*,a,b)其中,function_namc为被积函数名,a、b为积分区间。对于符号对象表示的连续时
5、间信号,MATLAB提供了diff函数和quad函数分别用于求微分和积分。3 .离散时间信号的MATLAB表示离散时间信号仅在一些离散时刻有定义。在MATLAB中离散时间信号需要使用两个向量来表示,其中一个向量用于表示离散的时间点,另一个向量表示在这些时间点上的值。例如对于如下时间信号x()=-3,2,-1,2,1,1,2,3)采用MATLAB可以表示如下:n=-3:4;x=-32-121-123;stem(n,xt,filled*);xlabel(,n,);title(,x(n);Stem函数用于绘制离散时间信号波形,为了与我们表示离散时间信号的习惯相同,在绘图时一般需要添加filled,选
6、项,以绘制实心的杆状图形。上述命令绘制的信号时域波形如图3所示。()4 .离散时间信号的时域运算离散时间信号的相加相乘是将两个信号对应的时间点上的值相加或相乘,可以直接使用算术运算的运算符“+”和“*”来计算。离散时间信号的位移,则可看作是将表示时间的向量平移,而表示对应时间点上的值的向量不变。离散时间信号的反转,则可以看作是将表示时间的向量和表示对应时间点上的值的向量以零点为基准点,一纵轴为对称轴反折,向量的反折可以利用MATLAB的fliplr函数实现。三.实验内容1.利用MATLAB绘制下列连续时间信号波形。(1)x(0=(1-e-05W)代码及结果:t=-5:0.01:10;x=(l-
7、exp(-0.5*t).*heaviside(t);plot(t,x)jxlabel(ts,)jtitle(x(t);(t)0.9-/0.8-/0.7-/0.6*/0.5-/0.4-/-0.3/0.2-/-0.1-/-011-50510VSXa)=CoS(M-w(-2)代码及结果:t=-l:0.001:3;x=cos(pi*t).*(heaviside(t)-heaviside(t-2);plot(t,x)jxlabel(,ts)itle(x(t);x(r)=CoS(M+2)-u(t-2)代码及结果:t=-3:0.001:4;x=abs(t).*cos(pi*t).*(heaviside(t+
8、2)-heaviside(t-2)2;plot(t,x);xlabel(t/s);title(x(t);(t)(4)x(r)=etsin(2M)w(0-u(t-3)代码及结果:t=-l:0.001:5;=exp(-t).*sin(2*pi*t).*(heaviside(t)-heaviside(t-3);plot(t,x);xlabel(t/s);title(x(t);2.利用MATLAB绘制卜.歹IJ离散时间信号波形(1) x(n)=u(n-3)代码及结果:n=0:15;=heaviside(n-3);Stem(n,x,filled);XIabeI(n)itle(x(n);x(n)x(n)=
9、(-1/2)hw(三)(2)代码及结果:方法一:n=-3:12;x=(-l).An).*heaviside(n);Stem(n,x,filled);XlabeI(n);title(x(n);方法二:n=-3:12;x=power(-2zn).*heaviside(n);Stem(n,x,filled);XlabeI(n);title(x(n);x(n)=nu(n)-u(n-5)1代码及结果:n=-3:12;x=n.*(heaviside(n)-heaviside(n-5);Stem(n,x,filled);XlabeI(n);title(x(n);x(n)=sin(n/2)u(n)(4)代码及
10、结果:n=-3:12;x=sin(n*pi2).*heaviside(n);Stem(n,x,filled);XlabeI(n);title(x(n);3 .利用UATLAB生成并绘制连续周期矩形波信号,要求周期为2,峰值为3,显示三个周期的波形。代码及结果:t=0:0.001:6;a=3;%a是峰值p=3;%p是周期数y=a*square(p*t);plot(tzy)jxlabel(t,)jtitle(,y(t);axis(t(l)-lt(end)+l-(a+l)(a+l);y(t)4 .已知信号x),及信号X2Q)=sin(2加),用MATLAB绘出下列信号的波形。l(t)(1)(O=X(
11、Ox2(O代码及结果:t=-2:0.001:6;Width=4;SkeW=-1;yl=4*tripuls(t-2,width,skew);%yl表示三角波信号y2=sin(2*pi*t);%y2表示正弦波信号y3=yl+y2;plot(t,y3);xlabel(t);title(y3(t);%y3表示所求的函数的波形y3(t)(2)%=XIQ)Xw)代码及结果:t=-2:0.001:6;width=4;skew=l;yl=4*tripuls(t-2,width,skew);%yl表示三角波信号y2=sin(2*pi*t);%y2表示正弦波信号y4=yl.*y2;plot(tzy4)jxlabe
12、l(,t,)jtitle(,y4(t),);%y4表示所求的函数的波形f31x5=x1(-)x1()代码及结果:t=-6:0.001:6;y5=(4-t).*(heaviside(t)-heaviside(t-4)+(4+t).*(heaviside(t+4)-heaviside(t);plot(t,y5);xlabel(t);title(y5(t);(4)x6(0=x2(0X3G-1)代码及结果:t=-2:0.001:6;width=4;skew=l;yl=4*tripuls(t-3,width,skew)j%yl表示三角波信号y2=sin(2*pi*(t-l);%y2表示正弦波信号y3=y
13、l+y2;y6=y2.*y3plot(tzy6);xlabel(t);title(y6(t);%y6表示所求的函数的波形y(t)5.已知离散时间信号x(),用UATLAB绘出工5)/(-),%(+2)和工(一2)的波形。由教材上x()的波形可知M)=1,2,3,33)代码及结果:n=-3:4;=01233330;nl=-fliplr(n);xl=fliplr(x);stem(nl,xlfilled,)jabel(n,)jtitle(,x(-n);n=-3:4;=0123333O;n=-3:4;=O123333O;(6)6.用MATLAB编程绘制下列信号的时域波形,观察信号是否为周期信号?若是周
14、期信号,周期是多少?若不是周期信号,请说明原因。Mf)=1+cos(-1-)+2cos(-1-)+cos(2M(1)4324代码及结果:t=-4*pi:0.001:4*pi;x=l+cos(pi*t4-pi3)+2*cos(pi*t2-pi4)+cos(2*pi*t);plot(tzxxlabel(t,title(xl);该信号是在周期信号,周期为8x()=sin(r)+2Sin(M代码及结果:t=-4*pi:0.001:4*pi;x=sin(t)+2*sin(pi*t);plot(t,x)jxlabel(t,)ititle(x2);该信号不是周期信号。Sin(t)以2n为周期,而Sin(JT
15、t)以2为周期,没有一个实数是这两个信号叠加后信号的公周期。x()=2+3sin(-一)(3) 38代码及结果:n=-10:10;x=2+3*sin(羽*pi*n-pi8);stem(n,xfilled);Xlabelfn);title(,x3);该信号是周期信号,周期为3x(n)=cos()+sn()+cos()(4) 632代码及结果:n=-16:16;X=CoS(Pi由*n)+sin(pia*n)+cos(pi2*n);stem(n,xz,filledxabel(n,)itle(x4);x41.510.50-0.5-1.5-20-15-10-505101520n该信号是周期信号,周期为12四、心得体会本实验主要任务是研究如何用MATLAB做出连续信号和离散信号的时域波形。题目中所给的连续信号和时域信号都是一些简单的、基本的函数,关键是如何编程实现。在这个过程中我逐渐认识到MATLAB是做信号分析的强大工具,因为在编程时编程者可以直接调用多种函数,而不必自己编写,这无疑节省了很多时间且使用起来十分方便。由于是第一次使用MATLAB,对其编程语法不熟悉,所以做实验的过程中出现了用时长、纠结于语法错误的问题。接下来的实验任务可能会更难一些,但相信随着对这款编程软件的深入了解,我会用得更加得心应手。