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

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

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

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

3、]符號,1則對應(yīng)的Ek[i]為負(fù)數(shù),0為對應(yīng)的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當(dāng)前EK為負(fù)數(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ù)項疊加,負(fù)數(shù)項疊加if(PID.EkFlag_Uint8[0]==0)PostSum=Temp[0]正數(shù)和elseNegSum=Temp[0]負(fù)數(shù)和KPEK0if(PID.EkFlag_Uint8[1]!=0)PostSum=Temp[1]正數(shù)

溫馨提示

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

評論

0/150

提交評論