位置式PID与增量式PID区别浅析(百度百科增量式PID讲解思路概念更明确清晰)

位置式PID与增量式PID区别浅析

Z小旋 2019-04-26 08:55:12  59882  收藏 713
分类专栏: NXP智能车学习 文章标签: 位置式PID PID 增量式PID
版权
1PID控制算法
什么是PID
PID 控制器以各种形式使用超过了 1 世纪,广泛应用在机械设备、气动设备 和电子设备.在工业应用中PID及其衍生算法是应用最广泛的算法之一,是当之无愧的万能算法

PID 实指“比例 proportional”、“积分 integral”、“微分 derivative”,这三项构 成 PID 基本要素。每一项完成不同任务,对系统功能产生不同的影响。它的结构简单,参数易 于调整,是控制系统中经常采用的控制算法。

PID:比例单元(P)、积分单元(I)和微分单元(D)组成

PID控制公式

其中:u(t)为控制器输出的控制量;(输出)

e(t)为偏差信号,它等于给定量与输出量之差;(输入)

KP 为比例系数;(对应参数 P)

TI 为积分时间常数;(对应参数I)

TD 为微分时间常数。(对应参数 D) 

 

数字 PID 控制算法通常分为位置式 PID 控制算法和增量式 PID 控制算法。  

位置式 PID 算法 :


 e(k): 用户设定的值(目标值) -  控制对象的当前的状态值 

比例P :    e(k)

积分I :   ∑e(i)     误差的累加

微分D :  e(k) - e(k-1)  这次误差-上次误差

也就是位置式PID是当前系统的实际位置,与你想要达到的预期位置的偏差,进行PID控制

因为有误差积分 ∑e(i),一直累加,也就是当前的输出u(k)与过去的所有状态都有关系,用到了误差的累加值;(误差e会有误差累加),输出的u(k)对应的是执行机构的实际位置,,一旦控制输出出错(控制对象的当前的状态值出现问题 ),u(k)的大幅变化会引起系统的大幅变化

并且位置式PID在积分项达到饱和时,误差仍然会在积分作用下继续累积,一旦误差开始反向变化,系统需要一定时间从饱和区退出,所以在u(k)达到最大和最小时,要停止积分作用,并且要有积分限幅和输出限幅

所以在使用位置式PID时,一般我们直接使用PD控制

而位置式 PID 适用于执行机构不带积分部件的对象,如舵机和平衡小车的直立和温控系统的控制

 

结合代码可以很好理解

typedef struct PID

  float P,I,D,limit;
}PID;
 
typedef struct Error
{
  float Current_Error;//当前误差
  float Last_Error;//上一次误差
  float Previous_Error;//上上次误差
}Error;
 
/*! 
 *  @brief      位置式PID
 *  @since      v1.0
 *  *sptr :误差参数
 *  *pid:  PID参数
 *  NowPlace:当前位置
 *  Point:   预期位置  
 */
 
// 位置式PID控制
float PID_Realize(Error *sptr,PID *pid, int32 NowPlace, float Point)
{
 
    int32 iError,    // 当前误差
         Realize;   //实际输出    
 
    iError = Point - NowPlace;    // 计算当前误差
    sptr->Current_Error += pid->I * iError;    // 误差积分
      sptr->Current_Error = sptr->Current_Error > pid->limit?pid->limit:sptr->Current_Error;//积分限幅
      sptr->Current_Error = sptr->Current_Error <-pid->limit?-pid->limit:sptr->Current_Error;
    Realize = pid->P * iError       //比例P
            + sptr->Current_Error   //积分I
            + pid->D * (iError - sptr->Last_Error);  //微分D
    sptr->Last_Error = iError;              // 更新上次误差
    return Realize;    // 返回实际值
}
增量式PID
 

比例P :    e(k)-e(k-1)   这次误差-上次误差

积分I :   e(i)     误差   

微分D :  e(k) - 2e(k-1)+e(k-2)   这次误差-2*上次误差+上上次误差

 增量式PID根据公式可以很好地看出,一旦确定了 KP、TI  、TD,只要使用前后三次测量值的偏差, 即可由公式求出控制增量

而得出的控制量▲u(k)对应的是近几次位置误差的增量,而不是对应与实际位置的偏差     没有误差累加

也就是说,增量式PID中不需要累加。控制增量Δu(k)的确定仅与最近3次的采样值有关,容易通过加权处理获得比较好的控制效果,并且在系统发生问题时,增量式不会严重影响系统的工作

总结:增量型 PID,是对位置型 PID 取增量,这时控制器输出的是相邻两次采样时刻所计算的位置值
之差,得到的结果是增量,即在上一次的控制量的基础上需要增加(负值意味减少)控制量。

 

typedef struct PID

  float P,I,D,limit;
}PID;
typedef struct Error
{
  float Current_Error;//当前误差
  float Last_Error;//上一次误差
  float Previous_Error;//上上次误差
}Error;
 
/*! 
 *  @brief      增量式PID
 *  @since      v1.0
 *  *sptr :误差参数
 *  *pid:  PID参数
 *  NowPlace:实际值
 *  Point:   期望值
 */
// 增量式PID电机控制
int32 PID_Increase(Error *sptr, PID *pid, int32 NowPlace, int32 Point)
{
 
    int32 iError,    //当前误差
        Increase;    //最后得出的实际增量
 
    iError = Point - NowPlace;    // 计算当前误差
 
    Increase =  pid->P * (iError - sptr->Last_Error)   //比例P
              + pid->I * iError      //积分I
              + pid->D * (iError - 2 * sptr->Last_Error + sptr->Previous_Error);  //微分D
    
    sptr->Previous_Error = sptr->Last_Error;    // 更新前次误差
    sptr->Last_Error = iError;              // 更新上次误差
    
    return Increase;    // 返回增量
}
增量式与位置式区别:
1增量式算法不需要做累加,控制量增量的确定仅与最近几次偏差采样值有关,计算误差对控制 量计算的影响较小。而位置式算法要用到过去偏差的累加值,容易产生较大的累加误差。 

2增量式算法得出的是控制量的增量,例如在阀门控制中,只输出阀门开度的变化部分,误动作 影响小,必要时还可通过逻辑判断限制或禁止本次输出,不会严重影响系统的工作。 而位置式的输出直接对应对象的输出,因此对系统影响较大。

3增量式PID控制输出的是控制量增量,并无积分作用,因此该方法适用于执行机构带积分部件的对象,如步进电机等,而位置式PID适用于执行机构不带积分部件的对象,如电液伺服阀。

4在进行PID控制时,位置式PID需要有积分限幅和输出限幅,而增量式PID只需输出限幅

位置式PID优缺点:
优点:
①位置式PID是一种非递推式算法,可直接控制执行机构(如平衡小车),u(k)的值和执行机构的实际位置(如小车当前角度)是一一对应的,因此在执行机构不带积分部件的对象中可以很好应用

缺点:
①每次输出均与过去的状态有关,计算时要对e(k)进行累加,运算工作量大。

增量式PID优缺点:
优点:
①误动作时影响小,必要时可用逻辑判断的方法去掉出错数据。
②手动/自动切换时冲击小,便于实现无扰动切换。当计算机故障时,仍能保持原值。
③算式中不需要累加。控制增量Δu(k)的确定仅与最近3次的采样值有关。


缺点:
①积分截断效应大,有稳态误差;

②溢出的影响大。有的被控对象用增量式则不太好;
————————————————
版权声明:本文为CSDN博主「Z小旋」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/as480133937/article/details/89508034

增量式PID控制(百度百科)

 编辑 讨论 上传视频

本词条由“科普中国”科学百科词条编写与应用工作项目 审核 。

增量式PID控制,数字PID控制算法的一种基本形式,是通过对控制量的增量(本次控制量和上次控制量的差值)进行PID控制的一种控制算法

中文名

增量式PID控制

外文名

Increment PID Control

基本概念

对控制量的增量进行PID控制

相关概念

位置式PID控制

相关领域

控制理论、自动化、计算机控制

主要优点

占用内存少、容错能力高

目录

  1. 基本概念
  2. ▪ PID控制
  3. ▪ 模拟PID控制
  4. ▪ 数字PID控制
  5. ▪ 位置式PID控制
  6. ▪ 增量式PID控制
  1. 公式表示
  2. ▪ 连续PID控制
  3. ▪ 离散PID控制
  4. ▪ 增量式PID控制
  5. PID控制的特点
  1. ▪ P控制
  2. ▪ I控制
  3. ▪ D控制
  4. 增量式PID控制

基本概念

编辑

PID控制

PID控制,即比例-积分-微分控制,是自动控制原理中定义的一种控制方法,也可以称为是校正方法 [1]  

PID控制主要是对系统偏差进行比例、积分、微分三种操作并线性组合成控制量,以减小系统误差,提高系统响应速度和响应效果。

模拟PID控制

传统的PID控制是模拟PID控制,即通过现场检测仪表、控制仪表、执行器等直接对模拟信号如液位、流速、温度、位置等物理量进行PID控制 [2]  

数字PID控制

数字PID控制是把现场的控制变量的模拟信号和对现场受控变量的输出信号均转换成了数字信号,PID的实现也是通过数字信号的设定来完成的。数字PID控制大多在DCSPLC等计算机系统内完成的 [3]  。

数字PID控制的两种基本形式是位置式PID控制和增量式PID控制。

位置式PID控制

位置式PID控制是指在积分环节,对从0时刻到当前时刻的所有偏差进行积分,是非递推式的全局积分。

增量式PID控制

和位置式PID控制不同,增量式PID控制将当前时刻的控制量和上一时刻的控制量做差,以差值为新的控制量,是一种递推式的算法。

公式表示

编辑

连续PID控制

对模拟信号进行的模拟PID控制,也可以称作连续PID控制,微分表示为:

 

式中,Kp为比例系数,Ti为积分时间常数,Td为微分时间常数。对上式进行拉氏变换:

 

PID控制器的传递函数为:

 

离散PID控制

对连续PID控制以一定离散化方法离散后就可以得到数字PID控制,离散的本质是采样,假设采样为周期采样,采样周期为T,离散自变量为n,则离散PID控制可以表示为:

 

上式也表示出了位置式PID控制算法。

增量式PID控制

根据位置式PID控制公式,写出n-1时刻的控制量:

 

 

得到

 

 

为积分系数;

为微分系数,可以将上式简化为

 

PID控制的特点

编辑

比例、积分、微分控制各有所长,根据实际需求对几种控制律加以结合,一般采用PI、PD或者PID控制 [1]  。

P控制

P(比例)控制实质上是一个可调增益放大器,只改变被调信号的幅值而不改变相位。加大增益可以提高系统开环增益,减小系统稳态误差,提高控制精度,但P控制不能消除稳态误差,且大增益会降低系统相对稳定性,甚至造成系统不稳定。

I控制

I(积分)控制可以消除稳态误差,但控制作用慢,有可能降低系统稳定性。

D控制

D(微分)控制可以超前控制,动作十分迅速,可以改善滞后的情况,但不能消除稳态误差,且当出现脉冲时容易有过激动作,而在恒差时不动作。

增量式PID控制

编辑

增量式PID控制主要是通过求出增量,将原先的积分环节的累积作用进行了替换,避免积分环节占用大量计算性能和存储空间。

增量式PID控制的主要优点为:

①算式中不需要累加。控制增量Δu(k)的确定仅与最近3次的采样值有关,容易通过加权处理获得比较好的控制效果;

②计算机每次只输出控制增量,即对应执行机构位置的变化量,故机器发生故障时影响范围小、不会严重影响生产过程;

③手动—自动切换时冲击小。当控制从手动向自动切换时,可以作到无扰动切换 [2]  。

由于增量式需要对控制量进行记忆,所以对于不带记忆装置的系统,只能使用位置式PID控制方式进行控制。

https://baike.baidu.com/item/%E5%A2%9E%E9%87%8F%E5%BC%8FPID%E6%8E%A7%E5%88%B6/20861314?fr=aladdin

  • 3
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值