欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2264|回復: 0
打印 上一主題 下一主題
收起左側

增量式PID

[復制鏈接]
跳轉到指定樓層
樓主
ID:225844 發表于 2017-8-8 18:37 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
本帖最后由 @lins 于 2017-8-8 18:45 編輯

#include "pid.h"
#include "sys.h"

PIDtypedef PID1;         //PID結構體
PIDtypedef PID2;
PIDtypedef PID3;
PIDtypedef PID4;

/*------------------------------------------
函數功能:PID單元 參數初始化程序
函數說明:               
------------------------------------------*/
void incPIDinit(void)
{
//PID1參數初始化
PID1.sum_error=0;
PID1.last_error=0;
PID1.prev_error=0;
PID1.proportion=0;
PID1.integral=0;
PID1.derivative=0;
PID1.setpoint=0;

//PID2參數初始化
PID2.sum_error=0;
PID2.last_error=0;
PID2.prev_error=0;
PID2.proportion=0;
PID2.integral=0;
PID2.derivative=0;
PID2.setpoint=0;

//PID3參數初始化
PID3.sum_error=0;
PID3.last_error=0;
PID3.prev_error=0;
PID3.proportion=0;
PID3.integral=0;
PID3.derivative=0;
PID3.setpoint=0;

//PID4參數初始化
PID4.sum_error=0;      //增量疊加
PID4.last_error=0;     //當前誤差
PID4.prev_error=0;     //上一個誤差
PID4.proportion=0;     //比例
PID4.integral=0;       //積分
PID4.derivative=0;     //微分
PID4.setpoint=0;       //設定值
}


/*------------------------------------------
函數功能:預期值設定
函數說明:               
------------------------------------------*/
void PID_setpoint(PIDtypedef*PIDx,u16 setvalue)
{
  PIDx->setpoint=setvalue; //設定值
}


/*------------------------------------------
函數功能:PID增量式計算公式
函數說明:PID=Uk+KP*(E(k)-E(k-1))+KI*E(k)+KD*(E(k)-2E(k-1)+E(k-2))               
------------------------------------------*/
int incPIDcalc(PIDtypedef *PIDx,u16 nextpoint)
{
float iError,iincpid;
        
iincpid=                                                         
         PIDx->proportion*(iError-PIDx->last_error)
         +PIDx->integral*iError
         +PIDx->derivative*(iError-2*PIDx->last_error+PIDx->prev_error);

PIDx->prev_error=PIDx->last_error; //存儲誤差,便于下次計算
PIDx->last_error=iError;
PIDx->sum_error+=iincpid;
return(PIDx->sum_error) ;
}

/*------------------------------------------
函數功能:PID 參數設置
函數說明:        
------------------------------------------*/
void PIDset(PIDtypedef *PIDx,float P,float I,float D)
{
PIDx->proportion=P;
PIDx->integral=I;
PIDx->derivative=D;

}



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表