PID的数学模型$ o1 O. d2 G/ Z7 M4 Y# M% _3 @
8 @0 F3 ]7 r9 \9 F/ s
在工业应用中PID及其衍生算法是应用最广泛的算法之一,是当之无愧的万能算法,如果能够熟练掌握PID算法的设计与实现过程,对于一般的研发人员来讲,应该是足够应对一般研发问题了,而难能可贵的是,在很多控制算法当中,PID控制算法又是最简单,最能体现反馈思想的控制算法,可谓经典中的经典。经典的未必是复杂的,经典的东西常常是简单的,而且是最简单的。PID算法的一般形式:
) ]9 p3 y5 G( ~$ x7 u3 s: E
' `- H' {8 [5 \PID算法通过误差信号控制被控量,而控制器本身就是比例、积分、微分三个环节的加和。这里我们规定(在t时刻):
# ]# v0 v1 z0 r/ v( M
. W8 m1 g4 J. f5 T- D6 P" t1.输入量为:O(t)* s4 y7 [# C o. g# B, |
( f8 B1 K8 M- I# B) I: V
2.输出量为:i(t)
! P- h! Z4 d5 f* C j5 L, u0 x" s4 S. O- T) D4 O% M7 r5 F2 I
3.偏差量为
! O" `1 f6 s" @- z: L, a7 S8 f$ e! |, l: |7 m- T. ^! A/ ^4 V
1 Y- }( F$ G- T* Z/ r6 Q( ~: f$ j) l& [1 t6 h
3 k+ |# r/ Z6 A1 {+ ]
8 N/ M- `0 x1 ~: r
" U, X) A0 @( h5 H3 _% X% j! b2 |3 W* \: t
◎ PID算法的数字离散化
; s$ F y( w* N. X! y2 v, K- \+ u5 \5 o+ O, e1 r0 a7 ?
假设采样间隔为T,则在第K个T时刻:' s* y5 K; \) r. W1 N
: L& _. n7 N" T" c1 ]$ i偏差=
4 U% ~8 C& T4 R9 k2 m
- u1 z" k+ ^* G) W1 ~& p G" G: y5 Q, u4 S& f' Z$ y
, T L( g& [+ K5 U% C: P* }3 h1 {7 E
积分环节用加和的形式表示,即5 a# R5 E0 a5 `) {$ k
- ]' Y( M# e, w: F) O
4 B% a5 }" F7 j5 S0 k* \: ]
' ^5 L! b7 G8 d! w) d* N# _4 U. Q
微分环节用斜率的形式表示,即8 e+ d) _1 _; s# t1 g$ Z6 A7 [5 w
f; o/ j" |% m0 S( C
) V, S5 W L8 I: g1 m/ [
5 I6 d: `( B/ E8 g4 B% p1 \7 M# pPID算法离散化后的式子:: c$ \ t; E" M, |; U- {
3 A M) {5 T! G5 v* k. `
- K$ V$ b+ ?/ R6 e, K
' F1 l1 c7 A$ P% h6 t$ m
则可表示成为:
$ h M0 P5 g, d. m* l# e6 |) t# j' O; J* l
! x$ }8 d2 `6 M; A) L) w$ p
# v% T8 [6 p" m( }4 |' d' [0 S: K4 D8 o% |0 F& B/ w
其中式中:
) H: k9 _* P W. G T8 p9 w3 N6 d+ g* A" n( ^* f, c" ?2 o
比例参数kp:控制器的输出与输入偏差值成比例关系。系统一旦出现偏差,比例调节立即产生调节作用以减少偏差。特点:过程简单快速、比例作用大,可以加快调节,减小误差;但是使系统稳定性下降,造成不稳定,有余差。
' V- m- n* l3 k) j2 P) x+ s7 a4 ]
" D3 U0 W4 N- J q5 d& G积分参数ki:积分环节主要是用来消除静差,所谓静差,就是系统稳定后输出值和设定值之间的差值,积分环节实际上就是偏差累计的过程,把累计的误差加到原有系统上以抵消系统造成的静差。8 l0 y4 W) g3 W0 E$ D7 x+ A
$ k& L p8 U) n# n- d3 y
微分参数kd:微分信号则反应了偏差信号的变化规律,或者说是变化趋势,根据偏差信号的变化趋势来进行超前调节,从而增加了系统的快速性。0 F4 z3 u* Y% D$ R
0 Y* R. F. K8 uPID的基本离散表示形式如上。目前的这种表述形式属于位置型PID,另外一种表述方式为增量式PID,由上述表达式可以轻易得到:
! }- A; \& f9 A6 G9 V" P8 }
& H! A! G, Z: x! ]+ H5 Y$ O
) T9 W( S+ v# o/ _/ k% N
5 I1 w/ v2 ^/ t% B7 n' L% O9 H6 a. U G6 F
那么:
! X# O# \1 m1 A. n6 G5 _* b, N- C+ |9 r/ O
L* @ w- d+ j, W4 w/ k
+ x9 s& A/ J. }# y* i) B
. p: d0 k3 A& w6 D$ J3 d
上式就是离散化PID的增量式表示方式,由公式可以看出,增量式的表达结果和最近三次的偏差有关,这样就大大提高了系统的稳定性。需要注意的是最终的输出结果应该为:
$ A; M6 S u6 l& p: z6 F5 K7 t
- C+ W! d, G! o* I1 ^! _输出量 = u(k)+ 增量调节值
# s3 z0 u/ [( y% @ b0 ]
9 u' R# X" `5 \3 L5 x( s+ b& G◎ 目的) W8 f/ R) p b. D' ^+ a4 V7 {
# D. T' Z7 i) Q/ c; W) v
PID 的重要性应该无需多说了,这个控制领域的应用最广泛的算法了。3 [2 e1 {* j# i" y1 b8 ~
& [' l% E6 K4 ]1 [/ G Y2 R
本篇文章的目的是希望通过一个例子展示算法过程,并解释以下概念:& M Q& N Q& o6 `" b3 E. t, U
4 A+ h8 F, U$ x(1)简单描述何为PID, 为何需要PID,PID 能达到什么作用。
$ m( b2 d; X% w" A
, a& S0 D0 _+ r, E# _% ](2)理解P(比例环节)作用:基础比例环节。2 ]8 q; `# I* y) \0 e) Q
9 a8 @' p( U: _6 j+ N缺点: 产生稳态误差.
% N* g( i" a2 X% }( Q3 a" y4 i. H% @9 T
疑问: 何为稳态误差 为什么会产生稳态误差.
7 u# ^' _! v5 [" _% o! I' R/ a* `' }
1 j0 @5 o7 Q D: G9 T(3)理解I(积分环节)作用:消除稳态误差., _ @! p, Y: {7 s
4 j4 T7 o+ b& v5 g J7 d3 b缺点: 增加超调. C4 J# Z6 F9 s; h" ]8 c" Y3 y
( u. F) C6 F! ]2 l' `疑问: 积分为何能消除稳态误差?
/ C, z& R" X, E- y- t" J, H2 ]2 R1 F* }; b* d- k
(4) 理解D(微分环节)作用:加大惯性响应速度,减弱超调趋势/ @# C% Y1 o1 X4 {' |* G
. T0 N3 ~ J6 j8 w疑问: 为何能减弱超调
' y( ~7 r h$ n4 w4 ]9 j9 R0 _# {! `4 r2 Q
(5)理解各个比例系数的作用
. }2 I% K/ \6 y% {* D1 l
5 {4 B& B' H6 ^- C C+ |( J
- q# }9 q) Q7 K! w8 D8 n1 `- }2 |' h, ^% |4 }' i+ g+ X% q7 F
: s6 U4 k5 S/ u何为PID以及为何需要PID?/ }+ B1 x% A9 R! D j" Y
, s- V: o1 Y2 h2 z1 [5 {9 T以下即PID 控制的整体框图,过程描述为:
! n2 J4 S4 I4 ?6 H$ V& ?) h9 K3 ?- b$ O1 G/ w3 C& p
设定一个输出目标,反馈系统传回输出值,如与目标不一致,则存在一个误差,PID 根据此误差调整输入值,直至输出达到设定值., H) W Z3 \, A% Z
' f0 P* [6 G$ i6 Y' R
' b" v: A5 N. ~8 h3 N5 I @9 y
( ?: J9 ^0 I$ z! r& {( v/ y
; [4 C4 d* s+ A- k
疑问:% F8 D5 S( Q6 |3 Q" |, K$ p
. |: S, y# [5 n0 P9 x" V! p
那么我们为什么需要PID 呢,比如我控制温度,我不能监控温度值,温度值一到就停止吗?9 h, d0 Q2 z1 G2 j( w6 o- w' Q% E1 P
( {: _' h1 j9 U) i2 B/ F
这里必须要先说下我们的目标,因为我们所有的控制无非就是想输出能够达到我们的设定,即如果我们设定了一个目标温度值,那么我们想要一个什么样的温度变化呢.
4 R2 _5 y$ X u5 s5 M3 }6 P1 \8 a# _0 z! h
比如设定目标温度为30度, 目标无非是希望达到图1 希望其能够快速而且没有抖动的达到30度.
) q1 P- S% I, {1 D& A$ Q: h7 U+ G1 l* f* f+ c
那这样大家应该就明白,如果使用温度一到就停止的办法,当然如果要求不高可能也行,当肯定达不到图1 这样的要求,因为温度到了后余温也会让温度继续升高.而且温度自身也会通过空气散热的.
+ I$ }. l$ z+ G7 a! V
0 v j2 p" u. n/ A7 R
+ @3 v! N+ J8 o/ S! P$ y
6 r: c% I# j* C2 O7 {" F图 系统输出的响应目标8 R1 S# h4 l- z" L( |( f7 N) Y
4 l3 q- I, h% v! E W1 h
综上所述,我们需要PID的原因无非就是普通控制手段没有办法使输出快速稳定的到达设定值。& l4 u8 e- l1 I& L8 `0 w% x9 K
3 X# F/ l8 }9 s5 w2 H◎ 控制器的P,I,D项选择
+ E/ B' ~+ n% C( D7 _% R8 K$ K0 z! B4 G2 P$ I; m( R
下面将常用的各种控制规律的控制特点简单归纳一下:
5 z" p i3 H2 P& T9 f
9 e& B( i# \. g. X4 {( p, \. u( C(1)、比例控制规律P:采用P控制规律能较快地克服扰动的影响,它的作用于输出值较快,但不能很好稳定在一个理想的数值,不良的结果是虽较能有效的克服扰动的影响,但有余差出现。它适用于控制通道滞后较小、负荷变化不大、控制要求不高、被控参数允许在一定范围内有余差的场合。如:金彪公用工程部下设的水泵房冷、热水池水位控制;油泵房中间油罐油位控制等。" J# f0 P9 S6 i; l, u3 C
) F7 |9 Z0 @; m(2)、比例积分控制规律(PI):在工程中比例积分控制规律是应用最广泛的一种控制规律。积分能在比例的基础上消除余差,它适用于控制通道滞后较小、负荷变化不大、被控参数不允许有余差的场合。如:在主线窑头重油换向室中F1401到F1419号枪的重油流量控制系统;油泵房供油管流量控制系统;退火窑各区温度调节系统等。
1 v4 G" v4 y" f) q0 t( q! h g
5 ^& i1 o- P+ {5 @# n3 n(3)、比例微分控制规律(PD):微分具有超前作用,对于具有容量滞后的控制通道,引入微分参与控制,在微分项设置得当的情况下,对于提高系统的动态性能指标,有着显著效果。因此,对于控制通道的时间常数或容量滞后较大的场合,为了提高系统的稳定性,减小动态偏差等可选用比例微分控制规律。如:加热型温度控制、成分控制。需要说明一点,对于那些纯滞后较大的区域里,微分项是无能为力,而在测量信号有噪声或周期性振动的系统,则也不宜采用微分控制。如:大窑玻璃液位的控制。$ Q1 e5 X! F! g& o8 _3 U3 y
+ K4 W" p0 b& T3 V4 z
(4)、例积分微分控制规律(PID):PID控制规律是一种较理想的控制规律,它在比例的基础上引入积分,可以消除余差,再加入微分作用,又能提高系统的稳定性。它适用于控制通道时间常数或容量滞后较大、控制要求较高的场合。如温度控制、成分控制等。
+ `# ]5 ~2 j1 ^/ N
8 A9 G% l7 V* N* R) `6 B鉴于D规律的作用,我们还必须了解时间滞后的概念,时间滞后包括容量滞后与纯滞后。其中容量滞后通常又包括:测量滞后和传送滞后。测量滞后是检测元件在检测时需要建立一种平衡,如热电偶、热电阻、压力等响应较慢产生的一种滞后。而传送滞后则是在传感器、变送器、执行机构等设备产生的一种控制滞后。纯滞后是相对与测量滞后的,在工业上,大多的纯滞后是由于物料传输所致,如:大窑玻璃液位,在投料机动作到核子液位仪检测需要很长的一段时间。
0 e( F ?8 u9 J( J
) h6 Z1 o3 K+ O+ O5 y+ B6 {4 K总之,控制规律的选用要根据过程特性和工艺要求来选取,决不是说PID控制规律在任何情况下都具有较好的控制性能,不分场合都采用是不明智的。如果这样做,只会给其它工作增加复杂性,并给参数整定带来困难。当采用PID控制器还达不到工艺要求,则需要考虑其它的控制方案。如串级控制、前馈控制、大滞后控制等。
: w$ Q' `4 ~$ b/ W s5 e A
- K, B# C' k0 r+ f3 MKp,Ti,Td三个参数的设定是PID控制算法的关键问题。一般说来编程时只能设定他们的大概数值,并在系统运行时通过反复调试来确定最佳值。因此调试阶段程序须得能随时修改和记忆这三个参数。* @# K$ S0 V( P1 N( I2 \. j7 J$ r' i
" x. s9 p& s L* A- k8 ^
数字PID控制器
Z9 W b) l! c0 N% L; e [( o# f$ t! c
(1)模拟PID控制规律的离散化1 q5 f8 g4 M% Y9 i' W( b
4 \) o2 b6 i; c
0 c L7 f9 j9 T1 x2 o$ K
7 E# _0 X8 {" y$ b ?
& i' k& o2 E0 F& p- T/ t(2)数字PID控制器的差分方程
( }, ~3 h' F1 _: d9 q3 H0 q0 K& E+ B9 a* J2 O
( x3 |+ `( M3 O# z/ N+ d! T
6 o* u; Y1 N% Y1 m$ u/ t3 |3 _9 S5 H7 _; s7 M& z8 C8 P
参数的自整定8 M0 `, j0 h& Q( c' g' L
( h1 i7 S' \, C+ }+ U( F) X& [! Z. C
在某些应用场合,比如通用仪表行业,系统的工作对象是不确定的,不同的对象就得采用不同的参数值,没法为用户设定参数,就引入参数自整定的概念。实质就是在首次使用时,通过N次测量为新的工作对象寻找一套参数,并记忆下来作为以后工作的依据。具体的整定方法有三种:临界比例度法、衰减曲线法、经验法。
7 a1 H) v/ J; `: I* f' G, F; q
' [! v1 k/ [& B8 I& f1、临界比例度法(Ziegler-Nichols)+ J3 t/ l. ~/ e/ F. ~9 [
9 r. H; E' ~" ]6 N9 \% K5 H1.1 在纯比例作用下,逐渐增加增益至产生等副震荡,根据临界增益和临界周期参数得出PID控制器参数,步骤如下:1 G* V5 U5 d9 i/ q- _9 |
! N4 D# q! E: e# R" D: f( l(1)将纯比例控制器接入到闭环控制系统中(设置控制器参数积分时间常数Ti =∞,实际微分时间常数Td =0)。
2 x4 z; y# E- P' W4 L; ?# t: Z6 {
$ n& \, P- }5 _! ]3 S(2)控制器比例增益K设置为最小,加入阶跃扰动(一般是改变控制器的给定值),观察被调量的阶跃响应曲线。3 y* A- R7 d% }: [
, r$ t! E. U1 B9 B2 T! q" H- R& W, s" h
(3)由小到大改变比例增益K,直到闭环系统出现振荡。
8 G0 k2 p- G( B ~3 W; v# r2 `
3 @+ k% x7 f! `8 {! O# O(4)系统出现持续等幅振荡时,此时的增益为临界增益(Ku),振荡周期(波峰间的时间)为临界周期(Tu)。1 R4 C3 O0 c- C/ t
" ?$ [. W5 t+ }/ C(5) 由表1得出PID控制器参数。
4 h9 `( M8 O- g! [
: k0 O( E- H; Z" h7 }表1( J" {( o q6 M! b
. I8 N/ F5 l/ b+ O3 G# z8 m
3 T0 }- y8 m4 x. a: \# [
) ?: Y& D3 |' B" y7 C+ J2 o1.2 采用临界比例度法整定时应注意以下几点:4 }' m5 A# p5 ]0 B" Z
+ _! Z, Z. Y* E, n+ n) S8 x5 T
(1)在采用这种方法获取等幅振荡曲线时,应使控制系统工作在线性区,不要使控制阀出现开、关的极端状态,否则得到的持续振荡曲线可能是“极限循环”,从线性系统概念上说系统早已处于发散振荡了。7 a/ `' z/ i5 }, G) n
0 _, Y8 D/ Z9 C1 h
(2)由于被控对象特性的不同,按上表求得的控制器参数不一定都能获得满意的结果。对于无自平衡特性的对象,用临界比例度法求得的控制器参数往住使系统响应的衰减率偏大(ψ>0.75 )。而对于有自平衡特性的高阶等容对象,用此法整定控制器参数时系统响应衰减率大多偏小(ψ<0.75 )。为此,上述求得的控制器参数,应针对具体系统在实际运行过程中进行在线校正。
$ N9 T5 Q. m% B, N& e7 |) `3 k* b( h- A" o
(3) 临界比例度法适用于临界振幅不大、振荡周期较长的过程控制系统,但有些系统从安全性考虑不允许进行稳定边界试验,如锅炉汽包水位控制系统。还有某些时间常数较大的单容对象,用纯比例控制时系统始终是稳定的,对于这些系统也是无法用临界比例度法来进行参数整定的。9 ^8 O1 k$ z/ k |5 R7 j" B
9 L. e; U# s: ]: ?(4)只适用于二阶以上的高阶对象,或一阶加纯滞后的对象,否则,在纯比例控制情况下,系统不会出现等幅振荡。
. m5 G+ y) p/ K7 P+ e1 t, U
7 h& [! i& P, ^5 @8 q. [1.3 若求出被控对象的静态放大倍数KP=△y/△u ,则增益乘积KpKu可视为系统的最大开环增益。通常认为Ziegler-Nichols闭环试验整定法的适用范围为:2<KpKu<201 t' A. v5 j9 }
+ t! u: v# _, B4 m6 D: b% D(1) 当KpKu > 20时,应采用更为复杂的控制算法,以求较好的调节效果。0 j/ }+ h3 u" C
" X% ]: p4 t9 y; {! w
(2)当KpKu < 2时,应使用一些能补偿传输迟延的控制策略。' N9 k/ C5 K2 D0 J1 V' A7 M
( Y4 k' N( v. X! W8 ~(3)当1.5<kpku< 2时,在对控制精度要求不高的场合仍可使用pid控制器,但需要对表1进行修正。在这种情况下,建议采用smith预估控制和imc控制策略。< span>' b- q- b: W! M) [
' F% M$ t6 A/ O8 q" V! _4 V# k
(4)当KpKu< 1.5时,在对控制精度要求不高的场合仍可使用PI控制器,在这种情况下,微分作用已意义不大。2 q. ]5 d% l; O4 x3 q- @5 R4 Y7 B
" m* f# P2 G E: F* w2 t
2、衰减曲线法
8 F6 T2 ^# m9 h Z1 c. n6 A. w0 ?( N6 ]0 Z
衰减曲线法与临界比例度法不同的是,闭环设定值扰动试验采用衰减振荡(通常为4:1或10:l),然后利用衰减振荡的试验数据,根据经验公式求取控制器的整定参数。整定步骤如下:
5 I: H* ]4 {2 j/ B) I2 Z) ^) m5 E! K7 a
(1)在纯比例控制器下,置比例增益K为较小值,并将系统投入运行。* O1 ]5 i0 B: o4 |7 x) w( F+ P+ z
" f" q2 w! i5 m. Y(2)系统稳定后,作设定值阶跃扰动,观察系统的响应,若系统响应衰减太快,则减小比例增益K;反之,应增大比例增益K。直到系统出现如下图(a)所示的4:1衰减振荡过程,记下此时的比例增益Ks及和振荡周期Ts数值。. {/ u" A1 [: j I. n
9 ]$ B' f$ i* ?( w R
) k7 D. Q. H: p5 x4 [9 h
# F' ~0 o2 `% J0 R
( Q' M4 r" a1 J3 x" R% c(3)利用Ks和Ts值,按下表给出的经验公式,计算出控制器的参数整定值。
6 |, _, }- [) C+ R% R2 }" k) h7 N. Y4 t( K( G- J' }" [$ y W
3 f* b9 ?/ {, e8 A
$ S' G7 W% I8 f) I4 C. I" u2 P' q& @$ S
(4)10:1衰减曲线法类似,只是用Tr带入计算。
) h$ `' g2 O/ P' ?: G+ @
r' a/ @! w. s( h0 y采用衰减曲线法必须注意几点:
/ R* v Z1 s! h, v& E8 b0 Q8 k7 |* _! _1 {) F# c' s. i: ^$ L( Y
(1)加给定干扰不能太大,要根据生产操作要求来定,一般在5%左右,也有例外的情况。
& z: F0 c/ _2 j# x% C( n( U x/ u U C7 x; B* f! ~
(2)必须在工艺参数稳定的情况下才能加给定干扰,否则得不到正确得 整定参数。2 m- Y% ]: ^9 Y3 S6 ^
. a4 U1 g( P' m9 j2 L
(3)对于反应快的系统,如流量、管道压力和小容量的液位调节等,要得到严格的4:1衰减曲线较困难,一般以被调参数来回波动两次达到稳定,就近似地认为达到4:1衰减过程了。) F# y! h! b1 f# s0 \
( H k. g7 e3 e% E# p+ Z(4)投运时,先将K放在较小的数值,把Ti减少到整定值,把Td逐步放大到整定值,然后把K拉到整定值(如果在K=整定值的条件下很快地把Td放到整定值,控制器的输出会剧烈变化)。
2 y, x/ ~% y5 n- W+ C5 n# h8 u/ ^( f; i, u& W2 w9 w
|
© 声明:本文仅表作者或发布者个人观点,与环保之家[2TECH.CN]无关。其原创性及陈述文字、内容、数据及图片均未经证实,对本文及其全部或部分内容、图片、文字的真实性、完整性、及时性本站不作任何保证或承诺,仅做参考并自行核实。如有侵权,请联系我们处理,在此深表歉意。
|