电子产业
数字化服务平台

扫码下载
手机洽洽

  • 微信小程序

    让找料更便捷

  • 扫码下载手机洽洽

    随时找料

    即刻洽谈

    点击下载PC版
  • 华强电子网公众号

    电子元器件

    采购信息平台

  • 华强电子网移动端

    生意随身带

    随时随地找货

  • 华强商城公众号

    一站式电子元器件

    采购平台

  • 芯八哥公众号

    半导体行业观察第一站

C语言实现51单片机中的PID算法

来源:华强电子网 作者:华仔 浏览:769

标签:

摘要: //pid.h#ifndef __PID__#define __PID__/*PID = Uk + KP*[E(k)-E(k-1)]+KI*E(k)+KD*[E(k)-2E(k-1)+E(k-2)];(增量型PID算式)函数入口: RK(设定值),CK(实际值),KP,KI,KD函数出口: U(K)*/typedef struct PIDValue{int8 KP;int8 KI;int8 KD;

//pid.h
#ifndef __PID__#define __PID__/*PID = Uk + KP*[E(k)-E(k-1)]+KI*E(k)+KD*[E(k)-2E(k-1)+E(k-2)];(增量型PID算式)函数入口: RK(设定值),CK(实际值),KP,KI,KD函数出口: U(K)*/typedef struct PIDValue{int8 KP;int8 KI;int8 KD;int8 F;int8 BITMOV;int EK[3];int UK;int RK;int CK;int UK_REAL;}pid_str;//PIDValueStr  PID;void    pid_exe(pid_str *PID)  ;#endif//pid.c/*PID = PID->UK_REAL + PID->KP*[E(k)-E(k-1)]+PID->KI*E(k)+PID->KD*[E(k)-2E(k-1)+E(k-2)];(增量型PID算式)函数入口: PID->RK(设定值),PID->CK(实际值),PID->KP,PID->KI,PID->KD函数出口: U(K)*/#include"defines.h"#include"pid.h"#define MAXOUT 0xff//#define MAXGAP 100void pid_exe(pid_str*PID){PID->EK[2]=PID->EK[1];PID->EK[1]=PID->EK[0];PID->EK[0]=PID->RK-PID->CK;PID->UK_REAL=PID->UK_REAL+PID->KP*(PID->EK[0]-PID->EK[1])//微分一次后积分即原数+(float)PID->KI*PID->EK[0]/PID->F//直接积分+(float)PID->KD*(PID->EK[0]-2*PID->EK[1]+PID->EK[2])*PID->F;//二阶微分后积分即一阶微分if((PID->UK_REAL>>PID->BITMOV)>=MAXOUT){PID->UK=MAXOUT;}else if(PID->UK_REAL>>PID->BITMOV<=-MAXOUT){PID->UK=-MAXOUT;}else{PID->UK=PID->UK_REAL>>PID->BITMOV;}}
型号 厂商 价格
EPCOS 爱普科斯 /
STM32F103RCT6 ST ¥461.23
STM32F103C8T6 ST ¥84
STM32F103VET6 ST ¥426.57
STM32F103RET6 ST ¥780.82
STM8S003F3P6 ST ¥10.62
STM32F103VCT6 ST ¥275.84
STM32F103CBT6 ST ¥130.66
STM32F030C8T6 ST ¥18.11
N76E003AT20 NUVOTON ¥9.67