關于pid的算法51實現(xiàn)_第1頁
已閱讀1頁,還剩3頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、PID的算法51實現(xiàn)關于PID的算法實現(xiàn),很多書上都講了。但是,最近真正要用PID算法的時候,發(fā)現(xiàn)書上的代碼在我們51上來實現(xiàn)還不是那么容易的事情。簡單的說來,就是不能直接調用。仔細分析你可以發(fā)現(xiàn),教材上的、網(wǎng)上現(xiàn)行的PID實現(xiàn)的C語言代碼幾乎都是用浮點型的數(shù)據(jù)來做的,可以想象,如果我們的計算使用浮點數(shù)據(jù),那我們的51單片機來運行的話會有多痛苦。所以,本人自己琢磨著弄了一個整型變量來實現(xiàn)了PID算法,由于是用整型數(shù)來做的,所以也不是很精

2、確,但是對于很多的使用場合,這個精度也夠了。關于系數(shù)和采樣電壓全部是放大10倍處理的。所以精度不是很高,但是也不是那么低,大部分的場合都夠用了。實在覺得精度不夠,可以再放大10倍或者100倍處理,但是要注意不超出整個數(shù)據(jù)類型的范圍就可以了。本人做的是帶死區(qū)控制的PID算法。具體的參考代碼參見下面:typedefstructPIDValueuint32Ek_Uint32[3]差值保存,給定和反饋的差值uint8EkFlag_Uint8[3

3、]符號,1則對應的Ek[i]為負數(shù),0為對應的Temp[2]=(uint32)PID.KD_Uint8PID.Ek_Uint32[2]KDEK2else反饋大于給定Temp[0]=ADPool.Value_Uint16[UFADCH]ADPool.Value_Uint16[UINADCH]計算Ek[0]if(Temp[0]PID.B_Uint8)數(shù)值移位PID.Ek_Uint32[2]=PID.Ek_Uint32[1]PID.Ek_Ui

4、nt32[1]=PID.Ek_Uint32[0]PID.Ek_Uint32[0]=Temp[0]符號移位PID.EkFlag_Uint8[2]=PID.EkFlag_Uint8[1]PID.EkFlag_Uint8[1]=PID.EkFlag_Uint8[0]PID.EkFlag_Uint8[0]=1當前EK為負數(shù)Temp[0]=(uint32)PID.KP_Uint8PID.Ek_Uint32[0]KPEK0Temp[1]=(uint

5、32)PID.KI_Uint8PID.Ek_Uint32[1]KIEK1Temp[2]=(uint32)PID.KD_Uint8PID.Ek_Uint32[2]KDEK2以下部分代碼是講所有的正數(shù)項疊加,負數(shù)項疊加if(PID.EkFlag_Uint8[0]==0)PostSum=Temp[0]正數(shù)和elseNegSum=Temp[0]負數(shù)和KPEK0if(PID.EkFlag_Uint8[1]!=0)PostSum=Temp[1]正數(shù)

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論