PID温度控制理解

PID控制算法

1,PID是一个闭环控制算法。因此要实现PID算法,必须在硬件上具有闭环控制,就是得有反馈。比如控制一个电机的转速,就得有一个测量转速的传感器,并将结果反馈到控制路线上,下面也将以转速控制为例。
2,PID是比例(P)、积分(I)、微分(D)控制算法。但并不是必须同时具备这三种算法,也可以是PD,PI,甚至只有P算法控制。我以前对于闭环控制的一个最朴素的想法就只有P控制,将当前结果反馈回来,再与目标相减,为正的话,就减速,为负的话就加速。现在知道这只是最简单的闭环控制算法。
3,比例(P)、积分(I)、微分(D)控制算法各有作用:
     比例,反应系统的基本(当前)偏差e(t),系数大,可以加快调节,减小误差,但过大的比例使系统稳定性下降,甚至造成系统不稳定;
     积分,反应系统的累计偏差

,使系统消除稳态误差,提高无差度,因为有误差,积分调节就进行,直至无误差;
     微分,反映系统偏差信号的变化率e(t)-e(t-1),具有预见性,能预见偏差变化的趋势,产生超前的控制作用,在偏差还没有形成之前,已被微分调节作用消除,因此可以改善系统的动态性能。但是微分对噪声干扰有放大作用,加强微分对系统抗干扰不利。
积分和微分都不能单独起作用,必须与比例控制配合。

4,控制器的P,I,D项选择。

下面将常用的各种控制规律的控制特点简单归纳一下:

    1、比例控制规律P:采用P控制规律能较快地克服扰动的影响,它的作用于输出值较快,但不能很好稳定在一个理想的数值,不良的结果是虽较能有效的克服扰动的影响,但有余差出现。它适用于控制通道滞后较小、负荷变化不大、控制要求不高、被控参数允许在一定范围内有余差的场合。如:金彪公用工程部下设的水泵房冷、热水池水位控制;油泵房中间油罐油位控制等。
    2、比例积分控制规律(PI):在工程中比例积分控制规律是应用最广泛的一种控制规律。积分能在比例的基础上消除余差,它适用于控制通道滞后较小、负荷变化不大、被控参数不允许有余差的场合。如:在主线窑头重油换向室中F1401到F1419号枪的重油流量控制系统;油泵房供油管流量控制系统;退火窑各区温度调节系统等。
    3、比例微分控制规律(PD):微分具有超前作用,对于具有容量滞后的控制通道,引入微分参与控制,在微分项设置得当的情况下,对于提高系统的动态性能指标,有着显著效果。因此,对于控制通道的时间常数或容量滞后较大的场合,为了提高系统的稳定性,减小动态偏差等可选用比例微分控制规律。如:加热型温度控制、成分控制。需要说明一点,对于那些纯滞后较大的区域里,微分项是无能为力,而在测量信号有噪声或周期性振动的系统,则也不宜采用微分控制。如:大窑玻璃液位的控制。
    4、例积分微分控制规律(PID):PID控制规律是一种较理想的控制规律,它在比例的基础上引入积分,可以消除余差,再加入微分作用,又能提高系统的稳定性。它适用于控制通道时间常数或容量滞后较大、控制要求较高的场合。如温度控制、成分控制等。

    鉴于D规律的作用,我们还必须了解时间滞后的概念,时间滞后包括容量滞后与纯滞后。其中容量滞后通常又包括:测量滞后和传送滞后。测量滞后是检测元件在检测时需要建立一种平衡,如热电偶、热电阻、压力等响应较慢产生的一种滞后。而传送滞后则是在传感器、变送器、执行机构等设备产生的一种控制滞后。纯滞后是相对与测量滞后的,在工业上,大多的纯滞后是由于物料传输所致,如:大窑玻璃液位,在投料机动作到核子液位仪检测需要很长的一段时间。

    总之,控制规律的选用要根据过程特性和工艺要求来选取,决不是说PID控制规律在任何情况下都具有较好的控制性能,不分场合都采用是不明智的。如果这样做,只会给其它工作增加复杂性,并给参数整定带来困难。当采用PID控制器还达不到工艺要求,则需要考虑其它的控制方案。如串级控制、前馈控制、大滞后控制等。
5,公式:


数值pid的计算:

6,问题。Kp,Ti,Td三个参数的设定是PID控制算法的关键问题。一般说来编程时只能设定他们的大概数值,并在系统运行时通过反复调试来确定最佳值。因此调试阶段程序须得能随时修改和记忆这三个参数。
7,参数的自整定。在某些应用场合,比如通用仪表行业,系统的工作对象是不确定的,不同的对象就得采用不同的参数值,没法为用户设定参数,就引入参数自整定的概念。实质就是在首次使用时,通过N次测量为新的工作对象寻找一套参数,并记忆下来作为以后工作的依据。
8,pid算法流程图:

/*PID温度控制公式--> u(t) = kp * e(t) + ki * [e(1) + e(2) + ....+ e(t)] + kd * [e(t) - e(t-1)]

Kc:只采用比例环节控制条件下,控制系统的稳态误差尽量达到最小时的Kp值。
Pc:只采用比例环节控制条件下,控制系统的震荡周期。
Ti:控制系统的积分时间。
Td:控制系统的微分时间。
T:PID控制采样计算周期。
Kp、Ki、Kd:被整定的参数。
Ki= Kp*T/Ti  Kd= Kp*Td/T

PID-->Kc==5    Pc=720*5/4= 900s  Ti=900*0.5=450s   Td=900*0.15=135s
Ti == 0.5Pc
Td == 0.15Pc
Kp == 0.65Kc  
Ki == Kp*T/Ti
Kd == Kp*Td/T*/

//程序
PID pid;
float error_thisandlast;/*这次误差和上次误差之差*/
float Ki;/*积分系数*/
float Kd;/*微分系数*/
/*PID初始化
参数1->设定温度
参数2->Kp值
参数3->pwm周期值
*/
void PID_Init(float SetTemp,float kp,int pwmcycle)
{
  pid.Set_Temp=SetTemp;/*用户设定温度*/
  pid.Kp=kp;/*30*/
  pid.T=400;/*PID计算周期500*/
  pid.Ti=5000000;/*积分时间*/
  pid.Td=1000;/*微分时间*/
  pid.pwmcycle=pwmcycle;/*pwm周期200*/
  pid.C1ms=0;
}
/*
pid计算
*/
void PID_Calc(void)
{
    if(pid.C1ms < (pid.T))/*计算周期还没到*/
    {
        return;
    }
    pid.error_this = pid.Set_Temp - pid.Read_Temp;/*计算本次偏差*/
    pid.Pout = pid.Kp * pid.error_this;/*计算比例输出*/
    
    pid.error_sum += pid.error_this;/*计算历史偏差之和*/
    error_thisandlast = pid.error_this - pid.error_last;/*计算这次误差和上次误差之差*/
    
    //Ki = pid.T*pid.Kp/pid.Ti;/*计算积分系数*/
    Ki=0;
    pid.Iout = Ki * pid.error_sum;/*计算积分输出*/
    
    //Kd = pid.T*pid.Kp/pid.Td;/*计算微分系数*/
    Kd=0;
    pid.Dout = Kd * error_thisandlast;/*计算微分输出*/
    
    pid.OUT = pid.Pout + pid.Iout + pid.Dout;/*总输出*/
    
    pid.error_last = pid.error_this;/*更新上次偏差*/
    pid.C1ms=0;/*计算周期置位*/
}

内容不完善后续更新。。。。。。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值