实验二 LTI系统的响应
一、 实验目的
1. 熟悉连续时间系统的单位冲激响应、阶跃响应的意义及求解方法 2. 熟悉连续(离散)时间系统在任意信号激励下响应的求解方法 3. 熟悉应用MATLAB实现求解系统响应的方法
二、 实验原理
1.连续时间系统
在MATLAB中有专门用于求解连续系统冲激响应和阶跃响应, 并绘制其时域波形的函数impulse( ) 和step( )。如果系统输入为f(t),冲激响应为h(t),系统的零状态响应为y(t),则有:y(t)?h(t)?f(t)。
若已知系统的输入信号及初始状态,我们便可以用微分方程的经典时域求解方法,求出系统的响应。但是对于高阶系统,手工计算这一问题的过程非常困难和繁琐。
在MATLAB中,应用lsim( )函数很容易就能对上述微分方程所描述的系统的响应进行仿真,求出系统在任意激励信号作用下的响应。lsim( )函数不仅能够求出连续系统在指定的任意时间范围内系统响应的数值解,而且还能同时绘制出系统响应的时域波形图。 说明:
(1)当系统有初始状态时,若使用lsim( )函数求系统的全响应,就要使用系统的状态空间描述法,即首先要根据系统给定的方式,写出描述系统的状态方程和输出方程。假如系统原来给定的是微分方程或系统函数,则可用相变量法或对角线变量等方法写出系统的状态方程和输出方程。其转换原理如前面实验四所述。
(2)显然利用lsim( )函数不仅可以分析单输入单输出系统,还可以分析复杂的多输入多输出系统。
例题1: 若某连续系统的输入为e(t),输出为r(t),系统的微分方程为:
y''(t)?5y'(t)?6y(t)?3f'(t)?2f(t)
① 求该系统的单位冲激响应h(t)及其单位阶跃响应g(t)。 a=[1 5 6];b=[3 2];
subplot(2,1,1),impulse(b,a,0:0.01:5); subplot(2,1,2),step(b,a,0:0.01:5);
Impulse Response32Amplitude10-100.511.522.5Time (sec)Step Response33.544.550.80.6Amplitude0.40.2000.511.522.5Time (sec)33.544.55
② 若f(t)?e?2t?(t) 求出系统的零状态响应y(t)
a=[1 5 6];b=[3 2]; t=0:0.01:5; f=exp(-2*t); lsim(b,a,f,t);
Linear Simulation Results1.210.8Amplitude0.60.40.20-0.200.511.522.5Time (sec)33.544.55
例题2 已知一个过阻尼二阶系统的状态方程和输出方程分别为:
?01??0?x'(t)???X(t)??2?f(t) , r(t)=[0 1]X(t) 。
?2?3????若系统初始状态为X(0)=[4 -5]T , 求系统在f(t)?3eA=[0 1;-2 -3];
?4t?(t)作用下的全响应。
B=[0 2]';C=[0 1];D=[0]; x0=[4 -5]'; t=0:0.01:10; f=[3*exp(-4*t)]'; lsim(A,B,C,D,f,t,x0);
Linear Simulation Results3210Amplitude-1-2-3-4-5012345Time (sec)678910
2.离散时间系统
MATLAB中为用户提供了专门用于求解离散系统单位函数响应, 并绘制其时域波形的函数impz( )。同样也提供了求离散系统响应的专用函数filter( ),该函数能求出由差分方程所描述的离散系统在指定时间范围内的输入序列作用时,产生的响应序列的数值解。当系统初值不为零时,可以使用dlsim( )函数求出离散系统的全响应,其调用方法与前面连续系统的lsim( )函数相似。另外,求解离散系统阶跃响应可以通过如下两种方法实现:一种是直接调用专用函数dstep( ),其调用方法与求解连续系统阶跃响应的专用函数step( )的调用方法相似;另一种方法是利用求解离散系统零状态响应的专用函数filter( ),只要将其中的激励信号看成是单位阶跃信号ε(k)即可。 例题:已知描述离散系统的差分方程为:
y(k)?0.25y(k?1)?0.5y(k?2)?f(k)?f(k?1),且已知系统输入序列为
k, f(k)?(12)?(k)① 求出系统的单位函数响应h(k)在-3 ~10离散时间范围内响应波形。
a=[1 -0.25 0.5];b=[1 1 0]; impz(b,a,-3:10);