实验三:基于matlab的积分分离PID控制算法

实验内容

在普通PID控制中引入积分环节的目的,主要氏为了消除静差,提高控制精度。但在或称的启动、结束或者大幅度增减设定时,短时间内系统的输出有很大的偏差,就会造成PID运算的积分累计,只是控制量超过执行机构可能允许的最大动作范围对应的极限控制量,引起系统较大的超调,甚至引起系统较大的震荡。

积分分离的基本思路:当控制量与设定值偏差较大时,取消积分作用,以避免由于积分作用使系统稳定性降低,超调量变大;当控制量接近给定值时,引入积分控制,消除静差,提高控制精度。

控制对象


实验代码

%Integration Separation PID Controller

clear all;

close all;

ts=20;

%Delay plant

sys=tf([1],[60,1],'inputdelay',80);

dsys=c2d(sys,ts,'zoh');

num,den\]=tfdata(dsys,'v'); u_1=0;u_2=0;u_3=0;u_4=0;u_5=0; y_1=0;y_2=0;y_3=0; error_1=0;error_2=0; ei=0; for k=1:1:200 time(k)=k\*ts; %Delay plant y(k)=-den(2)\*y_1+num(2)\*u_5; %I separation yd(k)=40; error(k)=yd(k)-y(k); ei=ei+error(k)\*ts; M=2; if M1 %Using integration separation if abs(error(k))\>=30 beta=0.0; elseif abs(error(k))\>=20\&abs(error(k))\<=30 beta=0.6; elseif abs(error(k))\>=10\&abs(error(k))\<=20 beta=0.9; else beta=1.0; end elseif M2 beta=1.0; %Not using integration separation end kp=0.80; ki=0.005; kd=3.0; u(k)=kp*error(k)+kd* (error(k)-error_1)/ts+beta*ki*ei; if u(k)\>=110 % Restricting the output of controller u(k)=110; end if u(k)\<=-110 u(k)=-110; end u_5=u_4;u_4=u_3;u_3=u_2;u_2=u_1;u_1=u(k); y_3=y_2;y_2=y_1;y_1=y(k); error_2=error_1; error_1=error(k); end figure(1); plot(time,yd,'r',time,y,'k:','linewidth',2); xlabel('time(s)');ylabel('yd,y'); legend('Ideal position signal','Position tracking'); figure(2); plot(time,u,'r','linewidth',2); xlabel('time(s)');ylabel('Control input'); #### 实验结果分析 M =1 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/8004cf18f6464b239bcd9f189a535cad.png) M=2 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/d3fa0b08047a461288217a1355598be1.png) 由仿真结果可以看出,当采用积分分离方法控制效果有很大的改善。值得注意的是,为了保证积分作用后系统的稳定行不变,在输入积分作用是=时比例系数Kp可以做相应变化。此外, β值应该根据具体对象的要求而定,若β过大,则达不到积分分离的目的;若β过大小,则回导致无法进入积分区。如果只进行PD控制,会是控制出现余差。

相关推荐
野犬寒鸦4 分钟前
JVM垃圾回收机制面试常问问题及详解
java·服务器·开发语言·jvm·后端·算法·面试
本喵是FW15 分钟前
C语言手记3
c语言·开发语言
一杯美式 no sugar21 分钟前
类和对象(中)
开发语言·c++
qq_4160187224 分钟前
实时数据可视化库
开发语言·c++·算法
2401_8732046538 分钟前
C++中的策略模式进阶
开发语言·c++·算法
xushichao198942 分钟前
C++中的职责链模式实战
开发语言·c++·算法
清风徐来QCQ1 小时前
js中的模板字符串
开发语言·前端·javascript
2301_818419011 小时前
C++中的协程编程
开发语言·c++·算法
add45a1 小时前
C++中的工厂方法模式
开发语言·c++·算法
java1234_小锋1 小时前
Java高频面试题:Spring-AOP通知和执行顺序?
java·开发语言·spring