位置式PID源代码,本程序来源于网络
- FUNCTION FC1 : VOID
- VAR_INPUT
- Run:BOOL; //True-运行,False-停止
- Auto:BOOL; //True-自动,False-手动
- ISW:BOOL; //True-积分有效,False-积分无效
- DSW:BOOL; //True-微分有效,False-微分无效
- SetMV:REAL; //手动时的开度设定值
- SVSW:REAL; //当设定值低于SVSW时,开度为零
- PV:REAL; //测量值
- SV:REAL; //设定值
- DeadBand:REAL; //死区大小
- PBW:REAL; //比例带大小
- IW:REAL; //积分带大小
- DW:REAL; //微分带大小
- dErr_IN:REAL; //误差累积
- LastPV_IN:REAL; //上一控制周期的测量值
- END_VAR
- VAR_OUTPUT
- MV:REAL; //输出开度
- dErr_OUT:REAL; //误差累积
- LastPV_OUT:REAL;//上一控制周期的测量值
- END_VAR
- VAR
- Err:REAL; //误差
- dErr:REAL; //误差累积
- PBH:REAL; //比例带上限
- PBL:REAL; //比例带下限
- PVC:REAL; //测量值在一个控制周期内的变化率,即测量值变化速率
- P:REAL; //比例项
- I:REAL; //积分项
- D:REAL; //微分项
- END_VAR
- IF Run THEN
- IF Auto THEN
- IF SV>=SVSW THEN
- Err:=SV-PV;
- PBH:=SV+PBW;
- PBL:=SV-PBW;
- IF PV<PBL THEN
- MV:=1;
- ELSIF PV>PBH THEN
- MV:=0;
- ELSE
- P:=(PBH-PV)/(PBH-PBL); //计算比例项
- /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- /////////////////////////////////////////////以下为积分项的计算//////////////////////////////////////////////////////////////
- IF ISW THEN
- dErr:=dErr_IN;
- IF (PV<(SV-DeadBand)) OR (PV>(SV+DeadBand)) THEN
- IF (dErr+Err)<(0-IW) THEN
- dErr:=0-IW;
- ELSIF (dErr+Err)>IW THEN
- dErr:=IW;
- ELSE
- dErr:=dErr+Err;
- END_IF;
- END_IF;
- I:=dErr/IW;
- dErr_OUT:=dErr;
- ELSE
- I:=0;
- END_IF;
- /////////////////////////////////////////////以上为积分项的计算//////////////////////////////////////////////////////////////
- /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- /////////////////////////////////////////////以下为微分项的计算//////////////////////////////////////////////////////////////
- IF DSW=1 THEN
- PVC:=LastPV_IN-PV;
- D:=PVC/DW;
- LastPV_OUT:=PV;
- ELSE
- D:=0;
- END_IF;
- /////////////////////////////////////////////以上为微分项的计算//////////////////////////////////////////////////////////////
- /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
- IF (P+I+D)>1 THEN
- MV:=1;
- ELSIF (P+I+D)<0 THEN
- MV:=0;
- ELSE
- MV:=P+I+D;
- END_IF;
- END_IF;
- ELSE
- MV:=0;
- END_IF;
- ELSE
- MV:=SetMV;
- END_IF;
- ELSE
- MV:=0;
- END_IF;
- END_FUNCTION
复制代码
【必读】版权免责声明
1、本主题所有言论和内容纯属会员个人意见,与本论坛立场无关。2、本站对所发内容真实性、客观性、可用性不做任何保证也不负任何责任,网友之间仅出于学习目的进行交流。3、对提供的数字内容不拥有任何权利,其版权归原著者拥有。请勿将该数字内容进行商业交易、转载等行为,该内容只为学习所提供,使用后发生的一切问题与本站无关。 4、本网站不保证本站提供的下载资源的准确性、安全性和完整性;同时本网站也不承担用户因使用这些下载资源对自己和他人造成任何形式的损失或伤害。 5、本网站所有软件和资料均为网友推荐收集整理而来,仅供学习用途使用,请务必下载后两小时内删除,禁止商用。6、如有侵犯你版权的,请及时联系我们(电子邮箱1370723259@qq.com)指出,本站将立即改正。
|