• MATLAB连续LTI系统的时域分析(十)


    目录

    1、实验目的:

    2、实验内容:


    1、实验目的:

    1)掌握利用MATLAB对系统进行时域分析的方法

    2)掌握连续时间系统零输入响应的求解方法

    3)掌握连续时间系统零状态响应、冲激响应和阶跃响应的求解方法

    4)掌握利用计算机进行卷积积分和卷积和计算的方法

    2、实验内容

    2-1)、已知某系统可以由如下微分方程描述y′′(t)+ y′(t)+6y(t)=x(t)利用MATLAB绘出该系统冲激响应和阶跃响应的时域波形。(注:题中时域范围可取[0 10],参考函数tfimpulsestep

    1. a = [1 1 6]; b = [1]; %微分方程左右两端多项式的系数矩阵
    2. time = 0:0.01:10; %时域范围[0 10]
    3. sys = tf(b,a);
    4. y1 = impulse(sys,time); %系统的冲激响应
    5. y2 = step(sys,time); %系统的阶跃响应
    6. subplot(1,2,1), plot(time,y1), xlabel('时间t'), title('冲激响应');
    7. subplot(1,2,2), plot(time,y2), xlabel('时间t'), title('阶跃响应');

    2-2)、编程实现如下图所示的两个波形的卷积,并绘制出卷积后的波形。(要求:先构建两信号卷积函数,而后通过调用该函数实现做题) 

    编写的卷积函数

    1. function [t,x] = sss_conv(x1,x2,t1,t2,dt)
    2. %文件名与函数名对应
    3. %自写的卷积函数
    4. x = conv(x1,x2)*dt;
    5. t0 = t1(1) + t2(1);
    6. L = length(x1) + length(x2)-2;
    7. t = t0:dt:(t0+L*dt);
    8. end

    功能实现

    1. dt = 0.01;
    2. x1 = -1 : dt : 1;
    3. f1t = 2*(heaviside(x1+1) - heaviside(x1-1));
    4. % plot(x1,f1t);
    5. x2 = -2 : dt : 2;
    6. f2t = heaviside(x2+2) - heaviside(x2-2);
    7. % plot(x2,f2t);
    8. [t, f] = My_conv(f1t, f2t, x1, x2, dt); %调用卷积函数
    9. plot(t, f);
    10. axis([-4 4 -1 5]);

    2-3)、已知系统的微分方程为:,x(t)为e-tu(t),用数值法求零状态响应y(t)并绘图。(注:题中时域范围可取[0 10]

    1. a = [1 4 4]; b = [1 3]; dt = 0.1; t = 0:dt:10; % 微分方程左侧系数向量a,微分方程右侧系数向量b
    2. [r,p] = residue(b,a); % 用residue函数(参见12.1.2节)求出其特征根p1、p2和相应的留数r1、r2
    3. h = r(1)*exp(p(1)*t)+r(2)*exp(p(2)*t); %叠加各根分量
    4. subplot(1,2,1), plot(t,h), title('冲激响应');
    5. x = exp(-t); % t已经大于0了
    6. y = conv(x,h)*dt; % 求x和h的卷积,长度为2*length(t)-1
    7. subplot(1,2,2), plot(t,y(1:length(t))), title('零状态响应');

    2-4)、分别用数值法和符号法求齐次微分方程在给定初始条件下的零输入响应波形,y′′(t)+2y(t)=0,y(0_)=3,y′(0_)=4。(注:题中时域范围可取[0 10],以实现方法作为图形标题名称)

    1. % (1)数值法
    2. a = [1 0 2]; % 方程左端系数向量
    3. n=length(a)-1; % 微分方程的阶数(即根的数量)
    4. Y0 = [3 4]; % 初始条件向量
    5. p=roots(a); % 求特征方程的根
    6. V=rot90(vander(p)); % 生成范德蒙特矩阵
    7. C= V\Y0'; % 求对应于各特征根的系数 左除
    8. dt = 0.1; tf = 10; % 时域取值范围[0 10]
    9. t = 0:dt:tf; % 时域取值范围[0 10]
    10. y = zeros(1,length(t));
    11. for k=1:n y = y + C(k)*exp(p(k)*t); end % 将各分量叠加,得到零输入响应的通式
    12. subplot(121);
    13. plot(t, y), xlabel('t'), ylabel('real(y)'); %零输入响应的实部随时间变化的趋势
    14. title('数值法');
    15. % 符号法
    16. eq='D2y+2*y=0'; con='y(0)=3, Dy(0)=4';
    17. y = dsolve(eq, con); y=simplify(y);
    18. subplot(122);
    19. ezplot(y, t); %一定要加参数t,限制时间的范围,保证波形正确
    20. axis([0 10 -5 5]); % 限制xy轴范围
    21. title('符号法');

    2-5)、求系统,y′(0+)=-1;y(0+)=0的全响应。(注:题中时域范围可取[0 10],参考函数tf2sslsim

    1. clear
    2. b = [1]; a = [1 0 1];
    3. t = 0:0.1:10; x = cos(t);
    4. sys1 = tf(b,a); %系统函数模型
    5. y1 = lsim(sys1,x,t); %零状态响应
    6. % subplot(1,2,1),plot(t,y1);
    7. xlabel('时间');title('零状态响应');
    8. [A B C D] = tf2ss(b,a); %系统函数模型转化成状态空间模型参数
    9. sys2 = ss(A,B,C,D) ;zi = [-1 0]; %产生状态空间模型和初始状态矩阵
    10. y2 = lsim(sys2,x,t,zi); %全响应
    11. % subplot(1,2,2);
    12. plot(t,y2);
    13. xlabel('时间t');title('全响应');

  • 相关阅读:
    【鸿蒙开发】第十七章 Web组件(一)
    SpringMVC
    一个普通人怎样做自媒体赚钱呢?
    【附源码】计算机毕业设计SSM图书商城
    .Net DI(Dependency Injection)依赖注入机制
    vue 高德api Map事件方法封装
    散列(哈希)查找的定义,常见的散列函数设计以及处理哈希冲突方法
    ADG无法切换:报错 ORA-16467
    经典双栈实现队列,注意遍历栈的判定条件修改。
    如何写好提示词?《Midjourney常用关键词大全》-附关键词文件
  • 原文地址:https://blog.csdn.net/weixin_63135906/article/details/130415342