PID算法C语言实例.doc_第1页
PID算法C语言实例.doc_第2页
PID算法C语言实例.doc_第3页
PID算法C语言实例.doc_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

#include typedef unsigned char uChar8; typedef unsigned int uInt16;typedef unsigned long int uInt32; sbit ConOut = P11; /加热丝接到P1.1口 typedef struct PID_Value uInt32 liEkVal3; /差值保存,给定和反馈的差值 uChar8 uEkFlag3; /符号,1为负数,0为正数 uChar8 uKP_Coe; /比例系数 uChar8 uKI_Coe; /积分常数 uChar8 uKD_Coe; /微分常数 uInt16 iPriVal; /上一时刻值 uInt16 iSetVal; /设定值 uInt16 iCurVal; /实际值PID_ValueStr; PID_ValueStr PID; /定义一个结构体,这个结构体用来存算法中要用到的各种数据bit g_bPIDRunFlag = 0; /PID运行标志位,PID算法不是一直在运算。而是每隔一定时间,算一次。/* */* 函数名称:PID_Operation() /* 函数功能:PID运算 /* 入口参数:无(隐形输入,系数、设定值等) /* 出口参数:无(隐形输出,U(k))/* 函数说明:U(k)+KP*E(k)-E(k-1)+KI*E(k)+KD*E(k)-2E(k-1)+E(k-2) * */void PID_Operation(void) uInt32 Temp3 = 0; /中间临时变量 存放差值 uInt32 PostSum = 0; /正数和 uInt32 NegSum = 0; /负数和 if(PID.iSetVal PID.iCurVal) /设定值大于实际值否? if(PID.iSetVal - PID.iCurVal 10) /偏差大于10否? PID.iPriVal = 100; /偏差大于10为上限幅值输出(全速加热) else /否则慢慢来 Temp0 = PID.iSetVal - PID.iCurVal; /偏差 PID.liEkVal1) /E(k)E(k-1)否? Temp0 = PID.liEkVal0 - PID.liEkVal1; /E(k)E(k-1) PID.uEkFlag0 = 0; /E(k)E(k-1) else Temp0 = PID.liEkVal1 - PID.liEkVal0; /E(k)E(k-1) PID.uEkFlag0 = 1; /E(k) Temp2) /E(k-2)+E(k)2E(k-1)? Temp2 = (PID.liEkVal0 + PID.liEkVal2) - Temp2; PID.uEkFlag2=0; /E(k-2)+E(k)2E(k-1) else /E(k-2)+E(k)2E(k-1)? Temp2 = Temp2 - (PID.liEkVal0 + PID.liEkVal2); PID.uEkFlag2 = 1; /E(k-2)+E(k) PID.iCurVal(即E(K)0)才进入if的, 那么就没可能为负,所以打个转回去就是了 */ /* = 计算KD*E(k-2)+E(k)-2E(k-1)的值 = */ if(PID.uEkFlag2=0) PostSum += Temp2; /正数和 else NegSum += Temp2; /负数和 /* = 计算U(k) = */ PostSum += (uInt32)PID.iPriVal; if(PostSum NegSum) /是否控制量为正数 Temp0 = PostSum - NegSum; if(Temp0 0,才有必要减“1” uCounter+; if(100 = uCounter) PID_Operation(); /每过0.1*100S调用一次PID运算。 uCounter = 0; /* */* 函数名称:PID_Output() /* 函数功能:PID输出控制 /* 入口参数:无(隐形输入,U(k)) /* 出口参数:无(控制端) * */void Timer0Init(void) TMOD |= 0x01; / 设置定时器0工作在模式1下 TH0 = 0xDC; TL0 = 0x00; / 赋初始值 TR0 = 1; / 开定时器0 EA = 1; / 开总中断 ET0 = 1; / 开定时器中断 void main(void) Timer0Init(); while(1) PID_Output(); void Timer0_ISR(void) interrupt 1 s

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论