



全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 土地转让协议(15篇)
- 2025年防护安全行业智能安防系统市场前景分析报告
- 2025年智能物流行业物流网络优化与智能仓储技术研究报告
- 2025年安防行业智能安防技术与物联网应用研究报告
- 2025会计面试题目及最佳答案
- 2025中铁四局北方区域指挥部公开招聘1人笔试题库历年考点版附带答案详解
- 2025年家政服务行业家政服务平台消费者需求分析研究报告
- 2025年餐饮行业互联网订餐服务用户体验研究报告
- 2025年智慧城市行业智慧城市管理平台研究报告
- 2025年食品饮料行业健康食品市场调查报告
- 金太阳九年级数学月考试卷及答案
- 企业食品安全培训课件
- HPV科普讲堂课件
- 港口设施保安培训知识课件
- 电梯维护保养标准作业指导书
- 煤矿安全生产责任制考核制度和考核标准
- PGL喷雾干燥机性能验证报告
- 医师变更注册管理办法
- 2024年甘肃省临夏县人民医院公开招聘护理工作人员试题带答案详解
- 网络安全防护策略与加固方案报告模板
- 新产品开发流程及管理制度
评论
0/150
提交评论