位置式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)指出,本站將立即改正。
|