PID 算法 (温控为例子)_pid算法控温-CSDN博客

一:位式控制:

位式控制算法输出信号一般只有高低两种状态。

算法输出信号out的依据 PV < SP => H; PV >= SP => L

对于系统惯性,会导致系统震荡

  1. PID算法 (基于位式控制,做了很多优化)

SP: Set Point

PV: Process Value

  1. PID算法分析:

采样的温度系列: X_{1}, X_{2}, X_{3}, ......, X_{k-2}, X!1(assets/d347fd8617a4cb885c7efa973a39c475.png), X_{k}

1). 当前偏差: E_{k} = SP - X_{k} 

      >0: 当前未达标; =0; 正好达标; <0: 当前超标

P_{Out}= K_{p} * E_{k} + Out_{0}  ---比例控制 (只考虑现在偏差,偏差越大,输出PWM越大)

因为如果 E_{k} 为0表述没有PWM输出了,为了维持系统温度, 需要有一个维持的默认常数输出值Out_{0}这样可以保证系统能温度在目标温度SP (根据不同系统,调试得到具体值。) 

 2). 历史的偏差系列: E_{1}, E_{2}, E_{3}, ......, E_{k-2}, E!1(assets/d347fd8617a4cb885c7efa973a39c475.png), E_{k}

S_{k} =  E_{1}+ E_{2} + E_{3}+ ...... + E_{k-2} + E!1(assets/d347fd8617a4cb885c7efa973a39c475.png) + E_{k}

    >0: 表示过去这段时间,大多数情况下未达标; =0: 总体可以; <0: 表示过去这段时间,大多数情况下超标;

I_{Out} =  K_{p} * S_{k} + Out_{0}  ---积分算法控制(只考虑历史偏差,缺点很大)

因为如果 E_{k} 为0表述没有PWM输出了,为了维持系统温度, 需要有一个维持的默认常数输出值Out_{0}这样可以保证系统能温度在目标温度SP (根据不同系统,调试得到具体值。)

 3). 最近两次的偏差相减: 

 D_{k} = E_{k} -  E!1(assets/d347fd8617a4cb885c7efa973a39c475.png) ---偏差变化率,变化趋势

D_{Out} = K_{p} * D_{k} + Out_{0}  ---微分算法控制(只考最近两次的变化率,预测下一次的走势(可以适当通过系数增大变化率,这样可以提前控制未来的变化))

 >0: 表示偏差有增大趋势; =0: 表示偏差趋势没有改变; <0: 表示偏差有减小趋势;

因为如果 E_{k} 为0表述没有PWM输出了,为了维持系统温度, 需要有一个维持的默认常数输出值Out_{0}这样可以保证系统能温度在目标温度SP (根据不同系统,调试得到具体值。)

二:PID算法的数学模型: 

PID_{}!2(assets/7d93db30721eaba71c41612fc3a6a577.png) =  P_{Out} + I_{Out} + D_{Out} 

            =  (K_{p} * E_{k} + Out_{0}) + (K_{p} * S_{k} + Out_{0}) + (K_{p} * D_{k} + Out_{0})

            =  K_{p} * ( E_{k} +  S_{k} +  D_{k}) + Out_{0} 

 S_{k} 的处理:

 S_{k}  =  frac{1 }{T i}* sum_{k=0}^{n}E_{k} * T

T: 采样周期(PID计算周期)

T_{i} : 积分常数(积分时间)越大影响越弱 (不能太大也不能太小)

 第一次达到目标温度SP之前,会产生错误,导致超调,过冲。为了避免超调, 可以做积分分离处理,可以在第一次达到目标温度SP之前,可以设置T_{i}为一个很大的值,把  S_{k} 忽略掉。

 积分项一般是在积分项在比例项失效时再起作用,用历史经验继续来控制。

两个关键因素的选择:T 和 T_{i} 

 D_{k} 的处理: 

  D_{k} = T_{d} * (( E_{k} -  E!1(assets/d347fd8617a4cb885c7efa973a39c475.png) ) / T)

T_{d}: 微分常数 

三:位置式PID 算法表达式:

OUT = (K_{p} * E_{k}) + (K_{p} * T/T_{i} * sum_{k=0}^{n}E_{k})  + ( K_{p} * T_{d}/T *  ( E_{k} -  E!1(assets/d347fd8617a4cb885c7efa973a39c475.png) )) + OUT_{0} 

四: K_{p} K_{i} 和 K_{d}的关系:

 K_{p} 

 K_{i} = K_{p} * T/T_{i} 

 K_{d} = K_{p} * T_{d}/T

五:增量式PID (输出是一个增量,计算出控制量的增加值):

Delta!2(assets/7d93db30721eaba71c41612fc3a6a577.png) = OUT!3(assets/7a4eb2a1b44844f14c37cf4da1f28efe.png) - OUT!1(assets/d347fd8617a4cb885c7efa973a39c475.png)

 OUT!3(assets/7a4eb2a1b44844f14c37cf4da1f28efe.png) = (K_{p} * E_{k}) + (K_{p} * T/T_{i} * sum_{k=0}^{n}E_{k})  + ( K_{p} * T_{d}/T *  ( E_{k} -  E!1(assets/d347fd8617a4cb885c7efa973a39c475.png) )) + Out_{0} 

  OUT!1(assets/d347fd8617a4cb885c7efa973a39c475.png) = (K_{p} * E!1(assets/d347fd8617a4cb885c7efa973a39c475.png)) + (K_{p} * T/T_{i} * sum_{k=0}^{n-1}E_{k})  + ( K_{p} * T_{d}/T *  ( E!1(assets/d347fd8617a4cb885c7efa973a39c475.png) -  E!4(assets/32c87a0078e0726cdb1658669cfcccf4.png) )) + Out_{0} 

 Delta!2(assets/7d93db30721eaba71c41612fc3a6a577.png) =  (K_{p} * ( E_{k} - E!1(assets/d347fd8617a4cb885c7efa973a39c475.png)))  +  K_{p}   T/T_{i}   E_{k} + K_{p} * T_{d}/T  (  E_{k} -  2 E!1(assets/d347fd8617a4cb885c7efa973a39c475.png) + E!4(assets/32c87a0078e0726cdb1658669cfcccf4.png))

  E_{k} : 当前本次偏差值

  E!1(assets/d347fd8617a4cb885c7efa973a39c475.png) :上次偏差值

  E!4(assets/32c87a0078e0726cdb1658669cfcccf4.png) :上上次偏差值


原网址: 访问
创建于: 2023-12-08 16:42:44
目录: default
标签: 无


  1. {_{k-1}}
  2. {_{Out}}
  3. {_{k}}
  4. {_{k-2}}

请先后发表评论
  • 最新评论
  • 总共0条评论