原创 51单片机PID算法程序(三)增量式PID控制算法

2009-8-28 13:05 5140 3 3 分类: MCU/ 嵌入式

51单片机PID算法程序()增量式PID控制算法<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


(转载自blog.ednchina.com/tengjingshu )


当执行机构需要的不是控制量的绝对值,而是控制量的增量(例如去驱动步进电动机)时,需要用PID增量算法


<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" />


f6250ba5-8055-466d-8cf4-5ecab5100e54.JPG


     增量式PID控制算法可以通过(2-4)式推导出。由(2-4)可以得到控制器的第k-1个采样时刻的输出值为:


4bbc4df1-a837-4000-aefc-c2e7b19f340d.JPG(2-5)


将(2-4)与(2-5)相减并整理,就可以得到增量式PID控制算法公式为:


点击看大图2-6


其中


 

c3290c6f-07af-4bf7-805c-34ab46f2297a.JPG


        由(2-6)可以看出,如果计算机控制系统采用恒定的采样周期T,一旦确定ABC,只要使用前后三次测量的偏差值,就可以由(2-6)求出控制量。


增量式PID控制算法与位置式PID算法(2-4)相比,计算量小得多,因此在实际中得到广泛的应用。


位置式PID控制算法也可以通过增量式控制算法推出递推计算公式:


1ae5871a-a76e-482f-a49c-293fb7c31e8a.JPG2-7


2-7)就是目前在计算机控制中广泛应用的数字递推PID控制算法。


 


增量式PID控制算法C51程序


/*====================================================================================================
PID Function
The PID (
比例、积分、微分) function is used in mainly
control applications. PIDCalc performs one iteration of the PID
algorithm.
While the PID function works, main is just a dummy program showing
a typical usage.
=====================================================================================================*/
 


typedef struct PID


{


int SetPoint; //设定目标 Desired Value


long SumError; //误差累计


double Proportion; //比例常数 Proportional Const


double Integral; //积分常数 Integral Const


double Derivative; //微分常数 Derivative Const


int LastError; //Error[-1]


int PrevError; //Error[-2]


} PID;


 


 


static PID sPID;


static PID *sptr = &sPID;


/*====================================================================================================
Initialize PID Structure  PID
参数初始化
=====================================================================================================*/


void IncPIDInit(void)


{


sptr->SumError = 0;


sptr->LastError = 0; //Error[-1]


sptr->PrevError = 0; //Error[-2]


sptr->Proportion = 0; //比例常数 Proportional Const


sptr->Integral = 0; //积分常数Integral Const


sptr->Derivative = 0; //微分常数 Derivative Const


sptr->SetPoint = 0;


}


 


/*====================================================================================================
增量式PID计算部分
=====================================================================================================*/


int IncPIDCalc(int NextPoint)


{


register int iError, iIncpid; //当前误差


iError = sptr->SetPoint - NextPoint; //增量计算


iIncpid = sptr->Proportion * iError //E[k]


- sptr->Integral * sptr->LastError //E[k1]


+ sptr->Derivative * sptr->PrevError; //E[k2]


//存储误差,用于下次计算


sptr->PrevError = sptr->LastError;


sptr->LastError = iError;


//返回增量值


return(iIncpid);


}


 


 


参考资料:


1PID 调节控制做电机速度控制,SUNPLUS凌阳科技


pdf


2)增量式PID控制模块程序设计


http://www.dzsc.com/data/html/2008-11-24/73560.html

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
3
关闭 站长推荐上一条 /3 下一条