Chinaunix首页 | 论坛 | 博客
  • 博客访问: 624775
  • 博文数量: 194
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 884
  • 用 户 组: 普通用户
  • 注册时间: 2015-09-21 16:48
文章分类

全部博文(194)

文章存档

2023年(1)

2022年(3)

2021年(16)

2020年(4)

2019年(5)

2018年(10)

2017年(72)

2016年(36)

2015年(47)

我的朋友

分类: 嵌入式

2021-09-24 16:35:43

转:https://www.cnblogs.com/foxclever/p/9349213.html


对于一般的PID控制系统来说,当设定值发生较大的突变时,很容易产生超调而使系统不稳定。为了解决这种阶跃变化造成的不利影响,人们发明了步进式PID控制算法。

1、步进式PID的基本思想
  所谓步进式PID算法,实际就是在设定值发生阶跃变化时,不直接对阶跃信号进行响应,而是在一定的时间内逐步改变设定值,直至使设定值达到目标值。这种逐步改变设定值的办法使得对象运行平稳。适用于高精度伺服系统的位置跟踪。
  佷显然,这一方法并未改变PID控制器本身,而是对设定值做了前期处理。所以其结构框图与控制方程与其他的PID控制算法是一致的。
  为了对设定值做必要处理,以使其不知快速变化,有多种方法。比较常用的是建立线性变化函数的办法。我们可以规定设定值从0-100%的变化时间为T,则可以确定设定值变化的斜率绝对值,或者说是步长。知道补偿后,我们就可以根据补偿来不断修改设定值,直到目标值。可用公式描述为:

  其中SPt为设定值目标值,SPs为设定值的起始值,sl为步长,k为步长的变化系数:

  而控制器本身的位置型和增量型表达式都保持不变。

2、算法实现
  步进式PID的实质是将设定值的突变修改为平缓的变化,这一处理方式在控制中有大量应用。处理设定值变化过程的流程如下所示:


  根据这一流程我们可变写处理函数如下:

点击(此处)折叠或打开

  1. /*步进式PID控制设定值步进处理函数*/
  2. float StepInProcessing(CLASSICPID vPID,float sp)
  3. {
  4.   float stepIn=(vPID->maximum-vPID->minimum))*0.1;
  5.   float kFactor=0.0;

  6.   if(fabs(vPID->setpoint-sp)<=stepIn)
  7.   {
  8.     vPID->setpoint=sp;
  9.   }
  10.   else
  11.   {
  12.     if(vPID->setpoint-sp>0)
  13.     {
  14.       kFactor=-1.0;
  15.     }
  16.     else if(vPID->setpoint-sp<0)
  17.     {
  18.       kFactor=1.0;
  19.     }
  20.     else
  21.     {
  22.       kFactor=0.0;
  23.     }
  24.     vPID->setpoint=vPID->setpoint+kFactor*stepIn;
  25.   }

  26.   return vPID->setpoint;

  27. }
有了这一处理函数后,在调用PID控制器前,先对设定值进行判断,然后将该函数的结果作为设定值给PID控制器。至于PID控制器使用前面讲述的哪种形式,根据具体应用需求和使用方便而定。

3、总结
  所谓步进式实质是对设定值进行平缓变化处理,防止因为设定值的跳变而引起系统的波动。这一办法虽然能够减少阶跃跳变的干扰,但也会让系统的响应速度变慢,当然这要根据需要来处理,因为步长的选择决定了作用大小,补偿越小约平缓,相应的响应速度也越慢。

阅读(431) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~