实验三:基于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控制,会是控制出现余差。

相关推荐
故事不长丨38 分钟前
C#正则表达式完全攻略:从基础到实战的全场景应用指南
开发语言·正则表达式·c#·regex
哈库纳玛塔塔1 小时前
放弃 MyBatis,拥抱新一代 Java 数据访问库
java·开发语言·数据库·mybatis·orm·dbvisitor
phltxy2 小时前
从零入门JavaScript:基础语法全解析
开发语言·javascript
天“码”行空2 小时前
java面向对象的三大特性之一多态
java·开发语言·jvm
odoo中国3 小时前
Odoo 19 模块结构概述
开发语言·python·module·odoo·核心组件·py文件按
代码N年归来仍是新手村成员4 小时前
【Java转Go】即时通信系统代码分析(一)基础Server 构建
java·开发语言·golang
Z1Jxxx4 小时前
01序列01序列
开发语言·c++·算法
沐知全栈开发5 小时前
C语言中的强制类型转换
开发语言
关于不上作者榜就原神启动那件事5 小时前
Java中大量数据Excel导入导出的实现方案
java·开发语言·excel
坚定学代码5 小时前
基于观察者模式的ISO C++信号槽实现
开发语言·c++·观察者模式·ai