1.3.5 积分分离PID控制算法
在普通PID控制中引入积分环节的目的,主要是为了消除静差,提高控制精度。但在过程的启动、结束或大幅度增减设定时,短时间内系统输出有很大的偏差,会造成PID运算的积分积累,致使控制量超过执行机构可能允许的最大动作范围对应的极限控制量,引起系统较大的超调,甚至引起系统较大的振荡。这在生产中是绝对不允许的。
积分分离控制基本思路:当被控量与设定值偏差较大时,取消积分作用,以免由于积分作用使系统稳定性降低,超调量增大;当被控量接近给定值时,引入积分控制,以便消除静差,提高控制精度。其具体实现步骤如下:
①根据实际情况,人为设定阈值ε>0;
②当|error(k)|>ε时,采用PD控制,可避免产生过大的超调,又使系统有较快的响应;
③当|error(k)|≤ε时,采用PID控制,以保证系统的控制精度。
积分分离控制算法可表示为
式中,T为采样时间;β为积分项的开关系数。
根据积分分离式PID控制算法得到其程序框图如图1-22所示。
图1-22 积分分离式PID控制算法程序框图
【仿真实例】
设被控对象为一延迟对象:
采样时间为20s,延迟时间为4个采样时间,即80s,被控对象离散化为
y(k)=-den(2)y(k-1)+num(2)u(k-5)
【仿真之一】 采用M语言进行仿真
取M=1,采用积分分离式PID控制器进行阶跃响应,对积分分离式PID控制算法进行改进,采用分段积分分离方式,即根据误差绝对值的不同,采用不同的积分强度。仿真中指令信号为yd(k)=40,控制器输出限制在[-110,110],其阶跃跟踪如图1-23所示。取M=2,采用普通PID控制,其阶跃跟踪如图1-24所示。
图1-23 积分分离式PID阶跃跟踪(M=1)
图1-24 采用普通PID阶跃跟踪(M=2)
〖仿真程序〗 chap1_13.m
由仿真结果可以看出,采用积分分离方法控制效果有很大的改善。值得注意的是,为保证引入积分作用后系统的稳定性不变,在输入积分作用时比例系数kp可作相应变化。此外,β值应根据具体对象及要求而定:若β过大,则达不到积分分离的目的;若β过小,则会导致无法进入积分区。如果只进行PD控制,会使控制出现余差。
【仿真之二】 采用Simulink仿真
通过Simulink模块实现积分分离PID控制算法阶跃响应,仿真结果如图1-25所示。
图1-25 采用Simulink仿真的阶跃响应
〖仿真程序〗
(1)初始化程序:chap1_14int.m
(2)Simulink主程序:chap1_14.mdl
(3)作图程序:chap1_14plot.m