51单片机PID算法程序(一)PID算法
技术分类: 微处理器与DSP | 2009-03-16
作者:tengjingshu: EDN China
EDN博客精华文章 作者:
tengjingshu
比例,积分,微分的线性组合,构成控制量u(t),称为:比例(Proportional)、积分(Integrating)、微分(Differentiation)控制,简称PID控制
图1
控制器公式
在实际应用中,可以根据受控对象的特性和控制的性能要求,灵活地采用不同的控制组合,构成比例(P)控制器
比例+积分(PI)控制器
比例+积分+微分(PID)控制器
式中
或
式中
控制系统中的应用
在单回路控制系统中,由于扰动作用使被控参数偏离给定值,从而产生偏差。自动控制系统的调节单元将来自变送器的测量值与给定值相比较后产生的偏差进行比例、积分、微分(PID)运算,并输出统一标准信号,去控制执行机构的动作,以实现对温度、压力、流量、也为及其他工艺参数的自动控制。
比例作用P只与偏差成正比;积分作用I是偏差对时间的积累;微分作用D是偏差的变化率;
比例(P)控制
比例控制能迅速反应误差,从而减少稳态误差。除了系统控制输入为0和系统过程值等于期望值这两种情况,比例控制都能给出稳态误差。当期望值有一个变化时,系统过程值将产生一个稳态误差。但是,比例控制不能消除稳态误差。比例放大系数的加大,会引起系统的不稳定。
图2比例(P)控制阶跃响应
积分(I)控制
在积分控制中,控制器的输出与输入误差信号的积分成正比关系。
为了减小稳态误差,在控制器中加入积分项,积分项对误差取决于时间的积分,随着时间的增加,积分项会增大。这样,即使误差很小,积分项也会随着时间的增加而加大,它推动控制器的输出增大使稳态误差进一步减少,直到等于零。
积分(I)和比例(P)通常一起使用,称为比例+积分(PI)控制器,可以使系统在进入稳态后无稳态误差。如果单独用积分(I)的话,由于积分输出随时间积累而逐渐增大,故调节动作缓慢,这样会造成调节不及时,使系统稳定裕度下降。
图3积分(I)控制和比例积分(PI)控制阶跃相应
微分(D)控制
在微分控制中,控制器的输出与输入误差信号的微分(即误差的变化率)成正比关系。
由于自动控制系统有较大的惯性组件(环节)或有滞后(delay)组件,在调节过程中可能出现过冲甚至振荡。解决办法是引入微分 (D)控制,即在误差很大的时候,抑制误差的作用也很大;在误差接近零时,抑制误差的作用也应该是零。
图4微分 (D)控制和比例微分(PD)控制阶跃相应
总结:
PI比P少了稳态误差,PID比PI反应速度更快并且没有了过冲。PID比PI有更快的响应和没有了过冲。
点击看原图
图5
表1
点击看原图
注意,这里的
图6 典型的PID控制器对于阶跃跳变参考输入的响应
参数的调整
应用PID控制,必须适当地调整比例放大系数KP,积分时间TI和微分时间TD,使整个控制系统得到良好的性能。
最好的寻找PID参数的办法是从系统的数学模型出发,从想要的反应来计算参数。很多时候一个详细的数学描述是不存在的,这时候就需要实际地调节PID的参数.
Ziegler-Nichols方法
Ziegler-Nichols方法是基于系统稳定性分析的PID整定方法.在设计过程中无需考虑任何特性要求,整定方法非常简单,但控制效果却比较理想。
具体整定方法步骤如下:
1. 先置I和D的增益为0,逐渐增加KP直到在输出得到一个持续的稳定的振荡。
2. 记录下振荡时的P部分的临界增益Kc,和振荡周期Pc,代到下表中计算出KP,Ti, Td。
Ziegler-Nichols整定表
表2
点击看原图
Tyreus-Luyben 整定表:
表3
Tyreus-Luyben的整定值减少了振荡的作用和增强了稳定性。
自动测试方法:
为了确定过程的临界周期Pc和临界增益Kc,控制器会临时使它的
PID算法失效,取而代之的是一个ON/OFF的
继电器来让过程变为振荡的。这两个参数很好的将过程行为进行了量化以决定PID控制器应该如何整定来得到理想的闭环回路性能。
图7
参考资料
1)Mixed-Signal Control Circuits Use Microcontroller for Flexibility in Implementing PID Algorithms,By Eamon Neary
(图1,表1)
2)Atmel 8-bit AVR Microcontrollers Application Note:AVR221: Discrete PID controller
(图2,图3,图4,图5,表2)
3)使用Ziegler-Nichols方法的自整定控制
http://article.cechinamag.com/2007-03/200733042815.htm
(图6)
4)Ziegler-Nichols Method
http://www.chem.mtu.edu/~tbco/cm416/zn.html
(表3)
5)Ziegler-Nichols方法PID参数整定--随风的blog
http://blog.eccn.com/u/4/archives/2007/97.htm
6) PID控制原理教程,胡晓若编制
http://space.ednchina.com/upload/2009/3/16/4b598aaf-bb9e-47b3-ae3d-484c095026c9.rar
(原创文章,转载请注明出处blog.ednchina.com/tengjingshu )