Matlab求解阶跃响应性能指标 (上升时间、调整时间、峰值时间、超调量)

概述

工科的同学对阶跃响应应该不会陌生,简单来说,阶跃响应是指输入量发生阶跃变化时动态系统的输出阶跃响应,通过分析输出阶跃响应的性能指标,可以分析和比较动态系统的动态性能和稳态性能。

阶跃响应性能指标定义

阶跃响应性能指标主要包括稳态值、上升时间、峰值时间和超调量,定义如下:
稳态值ys:当时间趋近于无穷大时,阶跃响应的输出值,ys=y(∞)。
上升时间tr:输出阶跃响应达到90%稳态值时所对应的时刻。
峰值时间tm:输出阶跃响应峰值ym所对应的时刻。
超调量σ:输出阶跃响应峰值ym与稳态值ys之差所占稳态值ys的百分比, σ%= (ym-ys)/ys。
调整时间ts:输出阶跃响应进入稳态值ys±Δ误差带范围内所对应的时刻, 一般取Δ=0.02或Δ=0.05。
在这里插入图片描述

Matlab函数

按照阶跃响应性能指标的定义,作者使用Matlab开发了函数Fun_Step_Performance.m,使用数值算法求出各类阶跃响应的性能指标值,函数简单、易用、通用性好。

function [ys,tr,ts,tm,ov] = Fun_Step_Performance(t,y,drawflag)
% [ys,tr,ts,ov] = Fun_Step_Performance(t,y) 标准阶跃响应的性能指标求解
% 本程序适用于标准阶跃响应曲线,末尾时间必须已经接近稳态值
% t-y 为阶跃响应的时间-输出配对序列,可由[y,t] = step(sys)求得
% drawflag为时候作图标志,不输入或输入非0值时,默认作图,输入0时不做图
% ys 稳态值
% tr 上升时间,默认为0-90%的上升时间
% ts 调整时间,默认为2%的调整时间
% tm 为峰值时间
% ov 超调量 %
% e.g.
%  sys = tf(1,[1 2*0.5*1 1]);
%  [y,t] = step(sys,15);
%  [ys,tr,ts,tm,ov] = Fun_Step_Performance(t,y,1);

示例

求一阶系统阶跃响应性能指标

% Eg 1 一阶系统
sys = tf(1,[3 1]);
[y,t] = step(sys,25);
[ys,tr,ts,tm,ov] = Fun_Step_Performance(t,y);

在这里插入图片描述

%% 阶跃响应指标结果:
上升时间:7s
调整时间:11.5s
峰值时间:25s,超调量:0%
稳态值:1
%% 阶跃响应指标结果显示结束

求复杂系统阶跃响应性能指标

sys = tf(1,[1 2*0.20*1 1]) * tf(1,[2 1]) * tf([1.5 1],[1 2*0.25*3 9]);  % 5阶系统
[y,t] = step(sys,35);
[ys,tr,ts,tm,ov] = Fun_Step_Performance(t,y);

在这里插入图片描述

%% 阶跃响应指标结果:
上升时间:2.0877s
调整时间:17.3158s
峰值时间:3.5614s,超调量:40.1285%
稳态值:0.111
%% 阶跃响应指标结果显示结束

求解不同阻尼比时二阶系统的阶跃响应性能指标

% Eg 3 求解不同阻尼比时二阶系统的阶跃响应特性
wn = 1;    % 固有频率
kes_vet = [0.2 0.4 0.6 0.8 1 1.2];   % 阻尼比序列
figure
hold on
for ii = 1:length(kes_vet)
    kes = kes_vet(ii);
    sys = tf(1,[1 2*kes*wn wn^2]);   % 二阶系统传递函数
    [y,t] = step(sys,50);            % 阶跃响应
    [ys(ii),tr(ii),ts(ii),tm(ii),ov(ii)] = Fun_Step_Performance(t,y,0);  % 求解阶跃响应,不绘图
    plot(t,y)
    Str{ii} = [ '\xi = '  num2str(kes)];
end
legend(Str)
xlabel('时间t/s')
ylabel('输出响应y')
 
figure
subplot(221)
plot( kes_vet,tr,'-o' )
xlabel('阻尼比\xi')
ylabel('上升时间/s')
subplot(222)
plot( kes_vet,ts,'-o' )
xlabel('阻尼比\xi')
ylabel('调整时间/s')
subplot(223)
plot( kes_vet,tm,'-o' )
xlabel('阻尼比\xi')
ylabel('峰值时间/s')
subplot(224)
plot( kes_vet,ov,'-o' )
xlabel('阻尼比\xi')
ylabel('超调量/%')

在这里插入图片描述
在这里插入图片描述

tr =
    1.8349    2.0737    2.4540    2.9954    4.0000    4.9407

ts =
   19.2661    8.2949    5.8282    3.6866    5.5000    7.9051

tm =
    3.2110    3.4562    3.9877    5.1843   40.0000   50.0000

ov =
   52.6622   25.3725    9.4610    1.5144         0         0

对于二阶系统,阻尼比的变化不影响输出稳态值,随着阻尼比增加,上升时间逐步增大、调整时间先减小再增大、峰值时间逐步变大、超调量逐步变小;当阻尼比在0.707左右时,上升时间和调整时间较快,且超调量很小,系统综合性能较好,工程上通常设计阻尼比在0.707左右,称之为最佳阻尼比。

联系作者

有Matlab/Simulink方面的技术问题,欢迎发送邮件至944077462@qq.com讨论。
更多Matlab/Simulink原创资料,欢迎关注微信公众号:Matlab Fans

源程序下载:

  1. https://mp.weixin.qq.com/s?__biz=MzAwOTk1NDcyMw==&mid=2247483741&idx=1&sn=b37d10b7ae5f5feee6a967ec77682991&chksm=9b56f591ac217c87040918b60b053d3c95a93476509502c643f4151b96140c91aa346262c846&token=1240415358&lang=zh_CN#rd
  2. 扫码关注微信公众号Matlab Fans,回复BK06获取百度网盘下载链接。

在这里插入图片描述

  • 122
    点赞
  • 800
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 12
    评论
### 回答1: 相信大部分工程学生都学过控制工程,控制系统的性能指标有很多种,其中包括上升时间调整时间峰值时间以及超调量。一般来说,我们可以利用Matlab求解这些参数,具体步骤如下。 1. 对系统进行建模,并确定该系统的传递函数。 2. 利用matlab工具箱中的step()函数,绘制系统的阶跃响应曲线,并且可以得到系统的阶跃响应曲线。 3. 根据阶跃响应曲线,可以计算出系统的上升时间调整时间峰值时间超调量性能指标。 计算步骤如下: (1)上升时间上升时间指的是从阶跃响应曲线起始位置到信号达到其最终值的时间。可以通过阶跃响应曲线上升到信号95%的时间来计算,具体计算公式为:   t_r = t_(2%) - t_(98%) 其中,t_(2%)表示信号上升到2%的时间,t_(98%)表示信号上升到98%的时间。 (2)调整时间调整时间指的是信号从其最终值开始,首次进入指定的容差带的时间。在阶跃响应曲线上,以信号最终值为基准,向上和向下延伸,分别找到第一次与该信号连线交点的位置,将这两个交点的时间相减即为调整时间。   t_s = t_(r1) - t_0 其中,t_(r1)为第一次与信号连线相交的时间,t_0为信号起始的时间。 (3)峰值时间峰值时间指的是阶跃响应曲线峰值出现的时间。可以通过在阶跃响应曲线上找到最高点的时间来计算。 (4)超调量超调量指的是阶跃响应曲线的最高峰值与信号最终值之间的差值。可以通过计算阶跃响应曲线的最高峰值与信号最终值之间的差值,再除以信号最终值的绝对值,得到超调量的百分比。 综上所述,Matlab可以方便地求解控制系统的性能指标,是控制工程设计和分析的重要工具之一。 ### 回答2: 阶跃响应是描述系统响应特性的一种方法,它是指在理想阶跃信号作用下,系统输出的时间响应曲线。阶跃响应性能指标包括上升时间调整时间峰值时间超调量,这些指标能够直观地反映系统响应的快慢和稳定性。 在matlab中,我们可以利用step函数来求解系统的阶跃响应,具体步骤如下: 1. 定义系统传递函数 H(s) 或状态空间模型 A、B、C、D。 2. 使用step函数对系统进行阶跃响应分析,例如:step(H) 或 [y,t]=step(A,B,C,D)。 3. 根据阶跃响应曲线,利用matlab内置的函数计算阶跃响应性能指标。其中,上升时间指的是系统输出信号从10%到90%上升所需的时间,可以通过 find(y>=0.1*ymax,1) 和 find(y>=0.9*ymax,1)计算。调整时间指的是系统响应从超调量范围内首次进入稳定范围到达稳态所需的时间,通常取超调量达到最大值的时间点为调整时间。可以通过 max(y)-y(end) 和 find(y==ymax,1)计算。峰值时间指的是系统响应达到峰值时间,可以通过 find(y==ymax,1)计算。超调量指的是阶跃响应峰值与稳态值之间的差值,通常以百分比的形式表示,可以通过 (ymax-y(end))/y(end)*100计算。 综上所述,matlab提供了方便的工具和函数来求解系统的阶跃响应性能指标,可以帮助工程师和学生快速了解和分析系统的响应特性,为系统设计和优化提供重要参考。 ### 回答3: Matlab是一个非常强大的数学软件,我们可以利用它来求解系统的阶跃响应性能指标,例如上升时间调整时间峰值时间超调量。 1. 上升时间是指信号从0到达峰值时间,可以通过命令stepinfo获取。例如,我们定义一个传递函数为G(S)=1/(s+2),使用stepinfo命令计算它的上升时间,代码如下: G = tf([1],[1 2]); info = stepinfo(G); rise_time = info.RiseTime; 2. 调整时间是指信号从初始值到达稳定值所需的时间,也可以使用stepinfo命令获取。例如,在上面的例子中,我们可以计算出调整时间,代码如下: settling_time = info.SettlingTime; 3. 峰值时间是指信号达到峰值时间,可以使用findpeaks命令获取。例如,在上面的例子中,我们可以计算出峰值时间,代码如下: [y,t] = step(G); [pks,locs] = findpeaks(y); peak_time = t(locs(1)); 4. 超调量是指信号在达到稳定值之前所经历的最大偏差,也可以使用stepinfo命令获取。例如,在上面的例子中,我们可以计算出超调量,代码如下: overshoot = info.Overshoot; 通过以上几个步骤,我们就可以得到系统的阶跃响应性能指标。在实际应用中,我们可以利用这些指标来评估系统的响应速度和稳定性,以便进行系统设计和性能优化。
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MatlabFans_Mfun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值