1.内容
(一)、Lorenz模型的状态方程表示为:
data:image/s3,"s3://crabby-images/bb5ee/bb5eefdbb3e54d65b3c133795893d2f8a640a28b" alt=""
初值为
要求:
1.建立脚本,采用四阶五级的(Runge-Kutta-Felhberg, RKF)方法,调用ode45()方法求解该方程;
2.在Simulink下完成下列要求:
(1) 在Simulink下为上述方程组建立仿真模型,保存在st1.mdl中;
(2)仿真时间tout初值为0,终值根据实际情况而定,在图形窗口中设置4个子窗口,将x 1 (t), x 2 (t), x 3 *(t)*和相三维图分别绘在其中:
(a) 给该图形窗口增加标题"Lorenz模型的状态方程仿真图形";
(b)给每个子窗口加坐标轴名称。
(3)将tout, x 1 (t), x 2 (t), x 3 *(t)*中的数据分别保存到变量t,x1,x2及x3中,将这四个变量保存到st1_data.mat数据文件中。
(二)、下面给出的微分代数方程表示为:
data:image/s3,"s3://crabby-images/321f3/321f3a0056b8366b3b85ab7af4d63612e0cbdd92" alt=""
初始条件为x 10=0.8, x 20=x30=0.1
要求:
1.建立脚本,采用刚性方程求解算法ode15()函数求解该方程;
2.在Simulink下完成下列要求
(1)在Simulink下为上述一阶微分方程组建立仿真模型,保存在st1.mdl中;
(2)利用(1)中的仿真模型,在Simulink下调用ode15( )方法进行仿真求解x1(t), x2(t)和x3(t),仿真时间tout初值为0,终值为20,在图形窗口中设置2×2四个子窗口,将x1(t),x2(t),x3(t)和x(t)(包含x1(t), x2(t)和x3(t)三个变量),分别绘在四个子窗口中,并包括:
(a)给该图形窗口增加标题"微分代数方程仿真图形";(b)给每个子窗口加坐标轴名称。
(3) 将tout,x1(t),,x2(t)和x3(t)中的数据分别保存到变量t,y1,y2和y3中,将这四个变量保存到st1_data.mat数据文件中。
(三)、子系统封装及仿真
(1)将图1中的PID Controller模型图在Simulink下封装成子系统;其中:
data:image/s3,"s3://crabby-images/f9860/f98605fd55ef63ae929aaefcae2cbc2f7752bd96" alt=""
data:image/s3,"s3://crabby-images/050aa/050aa1969aa527e2828d4911f9bf29df68e19b56" alt=""
图1 PID Controller模型图
(2)将(1)中的子系统用在图2所示的仿真模型(保存到st2.mdl)中,在Simulink下调用ode45( )方法进行仿真求解单位阶跃响应y(t)(包括y(t)响应曲线和tout在0-20秒内的y(t)的值)。
data:image/s3,"s3://crabby-images/d2d5a/d2d5a41f15799769daee012b71c51c108ba1b261" alt=""
图2 PID控制系统仿真图
data:image/s3,"s3://crabby-images/e4457/e445768071119a377a2e9e46cd33fb107447494f" alt=""
Kp=11.520,Ti=0.658,Td=0.164,Step为单位阶跃函数。如果仿真输出超调量过大,希望调整以上参数以获取更好的动态性能。
2. 过程
(一)、Lorenz模型
- 建立脚本,采用四阶五级的(Runge-Kutta-Felhberg, RKF)方法,调用ode45()方法求解该方程;
脚本:
clear;
f=@(t,x)[-8*x(1)/3+x(2)*x(3);-10*x(2)+10*x(3);-x(1)*x(2)+28*x(2)-x(3)];
t=50;
x0=[0;0;1e-10];
[t,x]=ode45(f,[0,t],x0);
x1=x(:,1);
x2=x(:,2);
x3=x(:,3);
plot3(x1,x2,x3);%绘制相三维图
xlabel('x1(t)'),ylabel('x2(t)'),zlabel('x3(t)');
title('Lorenz模型的状态方程仿真图形');
运行图形:
data:image/s3,"s3://crabby-images/8d70a/8d70aa72819f7aac2802a685d82f399ea9c9cbac" alt=""
图3 Lorenz模型三维仿真图
- Simulink仿真
Lorenz仿真模型:
data:image/s3,"s3://crabby-images/e9b29/e9b2956cb786098abe7c1576f35d2d8643dd6d2b" alt=""
图4 Lorenz仿真模型
设置相关属性:
形式改为数组形式
data:image/s3,"s3://crabby-images/6c13e/6c13eeb4eede0f5c9d0f2841b554080a0821c5bf" alt=""
图5 修改为数组形式
调用ode45( )方法进行仿真求解x1(t), x2(t)和x3(t),仿真时间tout初值为0,终值为50
data:image/s3,"s3://crabby-images/84543/84543dd9185caa6d31ec999952203e0655c1352b" alt=""
图6 修改方法以及时间
设置初值为
data:image/s3,"s3://crabby-images/50185/501854f8a95d4eb44026fd7faac40198446e927f" alt=""
data:image/s3,"s3://crabby-images/1915f/1915f42743fdb4cf3386837d0989075aeb8dea0e" alt=""
data:image/s3,"s3://crabby-images/0ff02/0ff025df1023ce591dc272bbeb3b5298a5a570f1" alt=""
图7 修改x1,x2,x3初始值
脚本实现绘图保存数据等功能:
t=tout;
x1=yout(:,1);
x2=yout(:,2);
x3=yout(:,3);
subplot(2,2,1);%设置2*2四个子窗口
plot(t,x1);%绘制x1(t)曲线
xlabel('时间t'),ylabel('x1(t)');%设置坐标轴
subplot(2,2,2);
plot(t,x2);%绘制x2(t)曲线
xlabel('时间t'),ylabel('x2(t)');
subplot(2,2,3);
plot(t,x3);%绘制x3(t)曲线
xlabel('时间t'),ylabel('x3(t)');
subplot(2,2,4);
plot3(x1,x2,x3);%绘制相三维图
xlabel('x1(t)'),ylabel('x2(t)'),zlabel('x3(t)');
suptitle('Lorenz模型的状态方程仿真图形');
save st1_data t x1 x2 x3;%保存
仿真图形
data:image/s3,"s3://crabby-images/65391/653918ef47fd209efcf1e44bba1ebde8a5198a4c" alt=""
图8 Lorenz模型仿真图形
比较脚本和仿真的运行图形可以发现它们是有区别的
在脚本和仿真模型都运行过后,查看工作区:
data:image/s3,"s3://crabby-images/f7711/f77117f3ed49a76c776a3495741f55087f405445" alt=""
图9 工作区
可以发现,脚本中运行后时间和结果长度都是2597,而仿真中tout和yout长度都是530,这导致所绘制的图形有所不同,经过查阅得知可能与ode45为变步长算法有关,自动根据连续状态变化速度,来改变步长,但是具体原因还未弄清。但是可以验证它们的趋势一致,由此可见,ode45脚本解方程与仿真解方程两种方式都是没有问题的。
保存的数据文件st1_data.mat
data:image/s3,"s3://crabby-images/ce98d/ce98dd16dc8b655de89637acc8c5027534c93341" alt=""
图10 保存的st1_data.mat文件
(二)微分方程
- 建立脚本,采用刚性方程求解算法ode15()函数求解该方程;
脚本:
clear;
f=@(t,x)[-0.2*x(1)+x(2)*x(3)+0.3*x(1)*x(2);2*x(1)*x(2)-5*x(2)*x(3)-2*x(2)*x(2);x(1)+x(2)+x(3)-1];
A=[1 0 0;0 1 0;0 0 0];
options=odeset;
options.Mass=A;
x0=[0.8;0.1;0.1];
[t,x]=ode15s(f,[0 20],x0,options);
ph=plot(t,x);
xlabel('时间t'),ylabel('x(t)');
legend([ph(1),ph(2),ph(3)],'x1(t)','x2(t)','x3(t)');
suptitle('微分代数方程仿真图形');
仿真图形:
data:image/s3,"s3://crabby-images/c7d97/c7d97ca4d4112b51318a712d951c6b7ce299ac44" alt=""
图11 微分代数方程仿真图形
- Simulink仿真
微分代数方程仿真模型:
data:image/s3,"s3://crabby-images/fb743/fb743167eaf5c9dbcd547c39bdf77d996c8d9e93" alt=""
图12 微分代数方程仿真模型
设置相关属性:
形式改为数组形式
data:image/s3,"s3://crabby-images/6c13e/6c13eeb4eede0f5c9d0f2841b554080a0821c5bf" alt=""
图13 修改输出形式
调用ode15( )方法进行仿真求解x1(t), x2(t)和x3(t),仿真时间tout初值为0,终值为20
data:image/s3,"s3://crabby-images/981ee/981ee6951cede986ee54e6ba72926b03bd6a343c" alt=""
图14 修改调用方法以及时间
设置初值为。
data:image/s3,"s3://crabby-images/94599/9459982dbdbd298f2ae9916c63011ba6d3d29b6d" alt=""
data:image/s3,"s3://crabby-images/9e08c/9e08c0945351222ef7d1f190454a996ac485f460" alt=""
data:image/s3,"s3://crabby-images/c55af/c55af70ab5ee9f3d3af584d197ff5b7d39d24872" alt=""
图15 修改初始值
脚本实现绘图保存数据等功能:
脚本:
t=tout;
x1=yout(:,1);
x2=yout(:,2);
x3=yout(:,3);
subplot(2,2,1);%设置2*2四个子窗口
plot(t,x1);%绘制x1(t)曲线
xlabel('时间t'),ylabel('x1(t)');%设置坐标轴
subplot(2,2,2);
plot(t,x2);%绘制x2(t)曲线
xlabel('时间t'),ylabel('x2(t)');
subplot(2,2,3);
plot(t,x3);%绘制x3(t)曲线
xlabel('时间t'),ylabel('x3(t)');
subplot(2,2,4);
ph=plot(t,yout);%绘制x(t)曲线
xlabel('时间t'),ylabel('x(t)');
legend([ph(1),ph(2),ph(3)],'x1(t)','x2(t)','x3(t)');
suptitle('微分代数方程仿真图形');
y1=x1;y2=x2;y3=x3;
save st1_data t y1 y2 y3;%保存
仿真图形
data:image/s3,"s3://crabby-images/d12f8/d12f831c032309b29a5708c67a4213227a2e18f7" alt=""
图16 微分代数方程仿真图形
可以看出与ode15脚本所绘制图形一致,表明两种解代数方程的方法均有效实现
保存的数据文件st1_data.mat
data:image/s3,"s3://crabby-images/6f014/6f014ea2fbf7a76122c8eb894100185992fe740c" alt=""
图17 保存的文件
(三)、子系统封装及仿真
(1)将图1中的PID Controller模型图在Simulink下封装成子系统
data:image/s3,"s3://crabby-images/7e97d/7e97d9ba0eff0b967c57cd0840c125b61b14fb28" alt=""
图18 子系统封装内部结构
data:image/s3,"s3://crabby-images/d7020/d7020066b0e82a780e8042a05681bc00520ea226" alt=""
图19 封装后
(2)将(1)中的子系统用在图2所示的仿真模型(保存到st2.mdl)中,在Simulink下调用ode45( )方法进行仿真求解单位阶跃响应y(t)(包括y(t)响应曲线和tout在0-20秒内的y(t)的值)。
G(s)值设置:
data:image/s3,"s3://crabby-images/588c8/588c856c9d89b3eb30cb415e7917174165a19066" alt=""
图20 设置G(s)值
仿真模型:
data:image/s3,"s3://crabby-images/2b5d7/2b5d77bd455391814da3341ddf74eaaeb0c4e158" alt=""
图21 仿真模型
鼠标右击simulink子系统mask如下图所示
data:image/s3,"s3://crabby-images/c5a61/c5a61155482e0087d23daaaf86cd3f0b96c50ff9" alt=""
图22 创建mask
设置相关参数的值:
data:image/s3,"s3://crabby-images/7d311/7d311603717fc34ea63e48e6bb3b7c74949f6a3a" alt=""
图23 修改参数初始值
设置起始到终止时间0-20,调用ode45
data:image/s3,"s3://crabby-images/adcde/adcde0d50f527b028535ae875ed70276c6ae164b" alt=""
图24 修改方法以及时间
此时示波器中仿真图形:
data:image/s3,"s3://crabby-images/8a9e8/8a9e8ce6d10ccf2e7f290a3aabdc7dd4f3dcc843" alt=""
图25 Kp=11.52,Ti=0.658,Td=0.164
将Kp值减小为8,所的仿真图形:
data:image/s3,"s3://crabby-images/94d37/94d3780d1462fc2e381b94f2dcd770da40a8dab1" alt=""
图26 Kp=8,Ti=0.658,Td=0.164
超调量减小
继续将Kp值减小为4,所的仿真图型如下:
data:image/s3,"s3://crabby-images/fa5e2/fa5e2f54ba25bdb0342fe08b03b7d04d9a20c493" alt=""
图27 Kp=4,Ti=0.658,Td=0.164
可以看出此时超调量几乎没有了,且曲线变得更加平缓
而若将Kp值升高为15:
data:image/s3,"s3://crabby-images/1b904/1b9046e745e57b4fb49e1a64328b59affe08062a" alt=""
图28 Kp=15,Ti=0.658,Td=0.164
超调量将会增大,且曲线上升的趋势更加陡峭
保持Kp值为15不变,此时如果我们将Ti值增加到1:
data:image/s3,"s3://crabby-images/f576e/f576e8252546684f7b5073a812a198b561564efd" alt=""
图29 Kp=11.52,Ti=1,Td=0.164
超调量明显减小,系统响应趋于稳态值的速度加快
此时继续升高Ti至1.5:
data:image/s3,"s3://crabby-images/27db5/27db5ae3716564a205481d6761d6b8f6230e3e86" alt=""
图30 Kp=11.52,Ti=1.5,Td=0.164
曲线无超调,初期曲线陡峭,然后快速平缓趋于稳态
将Ti减小至0.5:
data:image/s3,"s3://crabby-images/ee1e4/ee1e4944bbe5cc9c8a6b7d943f3e5b56a51c377d" alt=""
图31 Kp=11.52,Ti=0.5,Td=0.164
曲线振荡,稳定性降低
此时,再将Td值增加至1:
data:image/s3,"s3://crabby-images/89a55/89a5563728060eac6c8a5b6025558088e965e8b7" alt=""
图32 Kp=11.52,Ti=0.658,Td=1
曲线振荡减弱
而若将Td减少至0.5:
data:image/s3,"s3://crabby-images/1c578/1c5780c2e6eaf599c74650ab9b474c4d3b1532f6" alt=""
图33 Kp=11.52,Ti=0.658,Td=0.5
振荡幅度增加
3. 结果分析
通过上述过程分析可以发现,随着Kp的增大系统的响应速度越快,系统的调节精度越高,但是系统易产生超调,系统的稳定性变差,甚至会导致系统不稳定。Kp取值过小,调节精度降低,响应速度变慢,调节时间加长,使系统的动静态性能变坏。Ti可以消除系统的稳态误差。Ti越大系统的稳态误差消除的越快,但Ti如果过大,在响应过程的初期会产生积分饱和现象。若Ti过小,系统的稳态误差将难以消除,影响系统的调节精度,系统可能会更加不稳定,此时可以增加Td的值改善系统的动态性能,抑制响应过程中出现的振荡偏差,系统的抗干扰性能增强。