在計算機控制系統(tǒng)中,由于系統(tǒng)特性和計算精度等問題,致使系統(tǒng)偏差總是存在,系統(tǒng)總是頻繁動作不能穩(wěn)定。為了解決這種情況,我們可以引入帶死區(qū)的PID算法。
1、帶死區(qū)PID的基本思想
帶死區(qū)的PID控制算法就是檢測偏差值,若是偏差值達到一定程度,就進行調(diào)節(jié)。若是偏差值較小,就認為沒有偏差。用公式表示如下:
其中的死區(qū)值得選擇需要根據(jù)具體對象認真考慮,因為該值太小就起不到作用,該值選取過大則可能造成大滯后。
帶死區(qū)的PID算法,對無論位置型還是增量型的表達式?jīng)]有影響,不過它是一個非線性系統(tǒng)。
除以上描述之外還有一個問題,在零點附近時,若偏差很小,進入死去后,偏差置0會造成積分消失,如是系統(tǒng)存在靜差將不能消除,所以需要人為處理這一點。
2、算法實現(xiàn)
前面我們描述了帶死區(qū)的PID控制的基本思想。在接下來我們來實現(xiàn)這一思想,同樣是按位置型和增量型來分別實現(xiàn)。
(1)位置型PID算法實現(xiàn)
前面我們對微分項、積分項采用的不同的優(yōu)化算法,他們都可以與死區(qū)一起作用于PID控制。這一節(jié)我們就來實現(xiàn)一個采用抗積分飽和、梯形積分、變積分算法以及不完全微分算法和死區(qū)控制的PID算法。首先依然是定義一個PID結(jié)構(gòu)體
接下來我們實現(xiàn)帶死區(qū)、抗積分飽和、梯形積分、變積分算法以及不完全微分算法的增量型PID控制器。/*定義結(jié)構(gòu)體和公用體*/
typedef struct
{
float setpoint; /*設(shè)定值*/
float kp; /*比例系數(shù)*/
float ki; /*積分系數(shù)*/
float kd; /*微分系數(shù)*/
float lasterror; /*前一拍偏差*/
float preerror; /*前兩拍偏差*/
float deadband; /*死區(qū)*/
float result; /*PID控制器計算結(jié)果*/
float output; /*輸出值0-100%*/
float maximum; /*輸出值上限*/
float minimum; /*輸出值下限*/
float errorabsmax; /*偏差絕對值最大值*/
float errorabsmin; /*偏差絕對值最小值*/
float alpha; /*不完全微分系數(shù)*/
float derivative; /*微分項*/
float integralValue; /*積分累計量*/
}CLASSICPID;
接下來我們實現(xiàn)帶死區(qū)、抗積分飽和、梯形積分、變積分算法以及不完全微分算法的增量型PID控制器。
void PIDRegulator(CLASSICPID vPID,float pv)
{
float thisError;
float result;
float factor;
thisError=vPID->setpoint-pv; //得到偏差值
result=vPID->result;
if (fabs(thisError)>vPID->deadband)
{
vPID-> integralValue= vPID-> integralValue+ thisError;
//變積分系數(shù)獲取
factor=VariableIntegralCoefficient(thisError,vPID->errorabsmax,vPID->errorabsmin);
//計算微分項增量帶不完全微分
vPID-> derivative =kd*(1-vPID->alpha)* (thisError-vPID->lasterror +vPID->alpha*vPID-> derivative;
result=vPID->kp*thisError+vPID->ki*vPID-> integralValue +vPID-> derivative;
}
else
{
if((abs(vPID->setpoint-vPID->minimum)deadband)&&(abs(pv-vPID->minimum)deadband))
{
result=vPID->minimum;
}
}
/*對輸出限值,避免超調(diào)和積分飽和問題*/
if(result>=vPID->maximum)
{
result=vPID->maximum;
}
if(result<=vPID->minimum)
{
result=vPID->minimum;
}
vPID->preerror=vPID->lasterror; //存放偏差用于下次運算
vPID->lasterror=thisError;
vPID->result=result;
vPID->output=((result-vPID->minimum)/(vPID->maximum-vPID->minimum))*100.0;
}
3、總結(jié)
引入死區(qū)的主要目的是消除穩(wěn)定點附近的波動,由于測量值的測量精度和干擾的影響,實際系統(tǒng)中測量值不會真正穩(wěn)定在某一個具體的值,而與設(shè)定值之間總會存在偏差,而這一偏差并不是系統(tǒng)真實控制過程的反應,所以引入死區(qū)就能較好的消除這一點。
當然,死區(qū)的大小對系統(tǒng)的影響是不同的。太小可能達不到預期的效果,而太大則可能對系統(tǒng)的正常變化造成嚴重滯后,需要根據(jù)具體的系統(tǒng)對象來設(shè)定。
審核編輯:湯梓紅
-
控制器
+關(guān)注
關(guān)注
112文章
16444瀏覽量
179314 -
PID
+關(guān)注
關(guān)注
35文章
1473瀏覽量
85777 -
計算機控制
+關(guān)注
關(guān)注
0文章
36瀏覽量
10769 -
PID控制器
+關(guān)注
關(guān)注
2文章
173瀏覽量
18663
發(fā)布評論請先 登錄
相關(guān)推薦
評論