int SetPoint// 设定目标 Desired value
int Proportion// 比例常数 Proportional Const
int Integral// 积分常数 Integral Const
int Derivative// 微分常数 Derivative Const
unsigned int LastError// Error[-1]
unsigned int PrevError// Error[-2]
unsigned int SumError// Sums of Errors
// double Lastout //上次输出
unsigned int E1 // e1>e2
unsigned int E2 //
int Pmax//上限
int Pmin/段棚简和老/下限
} PID
/*====================================================================================================
PID计算部分,遇限消弱积分PID防饱和,积分分离算法实现
=====================================================================================================*/
int PIDCalc( PID *pp, unsigned int NextPoint )
{
int dError,
Error
Error = pp->SetPoint - NextPoint //偏差
if (Error<=-pp->E1) return (pp->Pmin) //饱和
else if (Error>=pp->E1)
return (pp->Pmax)
else
{
dError = pp->LastError - pp->PrevError// 当前微分
pp->PrevError = pp->LastError
pp->LastError = Error
if (Error>=pp->E2||Error<=-pp->E2) //分离握裤
return (pp->Proportion * Error // 比例项
+ pp->Derivative * dError )//PD,考虑限幅
else //位置式
{
pp->SumError += Error // 积分
return (pp->Proportion * Error // 比例项
+ pp->Integral * pp->SumError // 积分项
+ pp->Derivative * dError // 微分项 //PID
)
}
}
}
非法芦举字符,或橡颤者缺少生声明。建议删除这行,重新输入下。
把陪如碧void PIDfunc_calc(...)放到结构体PID_FUNC_DEFAULTS{..} 前面。
模拟PID就是在现没散场安装的利用DDZII或者DDZIII型表再加上其他气动仪表的模块,对坦银现场控制变量的模拟信号利用旋钮或拨盘对PID的三个值进行设定对或者手动控制输出的系统,其信号均为模拟信号。数字PID就是把现场的控制变量的模拟信号和对现场受控变量的输出信号均转换成了数字信号,PID的枯信氏实现也是通过数字信号的设定来完成的。现在大多在DCS、PLC系统内完成的。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)