51單片機(jī)PID算法程序(三)增量式PID控制算法
當(dāng)執(zhí)行機(jī)構(gòu)需要的不是控制量的絕對(duì)值,而是控制量的增量(例如去驅(qū)動(dòng)步進(jìn)電動(dòng)機(jī))時(shí),需要用PID的“增量算法”。
本文引用地址:http://www.ex-cimer.com/article/201611/320783.htm(2-5)
將(2-4)與(2-5)相減并整理,就可以得到增量式PID控制算法公式為:
(2-6)
其中
增量式PID控制算法與位置式PID算法(2-4)相比,計(jì)算量小得多,因此在實(shí)際中得到廣泛的應(yīng)用。
位置式PID控制算法也可以通過增量式控制算法推出遞推計(jì)算公式:
(2-7)
(2-7)就是目前在計(jì)算機(jī)控制中廣泛應(yīng)用的數(shù)字遞推PID控制算法。
增量式PID控制算法C51程序
typedef struct PID
{
int SetPoint;
long SumError;
double Proportion;
double Integral;
double Derivative;
int LastError; //Error[-1]
int PrevError; //Error[-2]
} PID;
static PID sPID;
static PID *sptr = &sPID;
void IncPIDInit(void)
{
sptr->SumError = 0;
sptr->LastError = 0;
sptr->PrevError = 0;
sptr->Proportion = 0;
sptr->Integral = 0;
sptr->Derivative = 0;
sptr->SetPoint = 0;
}
int IncPIDCalc(int NextPoint)
{
register int iError, iIncpid;
iError = sptr->SetPoint - NextPoint;
iIncpid = sptr->Proportion * iError
- sptr->Integral * sptr->LastError
+ sptr->Derivative * sptr->PrevError;
//存儲(chǔ)誤差,用于下次計(jì)算
sptr->PrevError = sptr->LastError;
sptr->LastError = iError;
//返回增量值
return(iIncpid);
}
評(píng)論