张华伟-基于STM32F4ARM单片机精确温控的设计与实现(7)
if( Key1 == 0) { Dly_ms(5); if( Key1 == 0) { Set_Temp ++ ; if( Set_Temp>= 99)
Set_Temp = 99 ;
}
while( Key1 ==0 ) { Show_Flag2 = 1; }
}
if( Key2 == 0) { Dly_ms(5); if( Key2 == 0) { Set_Temp -- ; if( Set_Temp<20)
Set_Temp = 20;
}
while( Key2 ==0 ) { Show_Flag2 = 1; }
}
}
}
附录
26
附录
//增量PID算法 #include \#include \extern unsigned intSet_Temp; extern signed intRG_tem_real; extern unsigned char Sw_Flag ;
unsigned char RG_Ki_time1,RG_Ki_time2; double RG_fErr0,RG_fErr1,RG_fErr2; double RG_tem_Err1; struct RG_PP { double Ki_ek0; double Ki_ek1; signed intSetPoint; double SumError; double Proportion; double Integral; double Derivative; double LastError; double PrevError; double Error; double dError;
double FDUk;
}RG_PID;
void RG_PID_Init(void) { RG_PID.Ki_ek0 = 0; RG_PID.Ki_ek1 = 0; RG_PID.SetPoint = Set_Temp; RG_PID.SumError = 0;
RG_PID.Proportion = 5;
27
附录
}
RG_PID.Integral = 0.005; RG_PID.Derivative = 1; RG_PID.LastError = 0; RG_PID.PrevError = 0; RG_PID.Error = 0; RG_PID.dError = 0; RG_PID.FDUk = 0;
void RG_PID_fErr1(void) { }
void RG_PID_fErr2(void)
if(((RG_PID.Error>1)||(RG_PID.Error<-1))&&(RG_fErr0==RG_PID.Error)) { } else { }
RG_Ki_time1=0; RG_PID.Ki_ek0=1;
RG_Ki_time1++; if(RG_Ki_time1==3) { } else { }
RG_PID.Ki_ek0=20;
RG_Ki_time1=0; RG_PID.Ki_ek0=40;
RG_fErr0=RG_PID.Error;
28
附录
{
if((((RG_tem_real-RG_tem_Err1)<2)&&((RG_tem_real-RG_tem_Err1)>-2))&&((RG_
PID.Error>10)||(RG_PID.Error<-10))) { RG_Ki_time2++; if(RG_Ki_time2==3) { RG_Ki_time2=0; RG_PID.Ki_ek1=20;
} else { RG_PID.Ki_ek1=10; }
}
else { RG_Ki_time2=0; RG_PID.Ki_ek1=1; }
RG_tem_Err1=RG_tem_real;
}
void RG_PID_fErr3(void) { if(RG_PID.Ki_ek0>RG_PID.Ki_ek1) { RG_PID.Ki_ek1=1; } else {
RG_PID.Ki_ek0=1; 29
附录
}
}
void RG_PID_Calc(void) { RG_PID.Error = RG_PID.SetPoint - RG_tem_real; // 当前误差 if( RG_PID.Error< 0) { RG_PID.FDUk = 1 ;
}
else if( RG_PID.Error> 10) { RG_PID.FDUk = 999 ; }
else { RG_PID_fErr1(); RG_PID_fErr2(); RG_PID_fErr3();
RG_PID.SumError += RG_PID.Ki_ek0*RG_PID.Error; RG_PID.dError = RG_PID.LastError - RG_PID.PrevError; RG_PID.PrevError = RG_PID.LastError; RG_PID.LastError = RG_PID.Error;
RG_PID.FDUk = RG_PID.Proportion * RG_PID.Error + RG_PID.Integral * RG_PID.SumError
+ RG_PID.Derivative * RG_PID.dError; }
}
void RG_Pwm_Control(void) {
30
// 积分 // 当前微分 // 比例 // 积分项 // 微分项
…… 此处隐藏:108字,全部文档内容请下载后查看。喜欢就下载吧 ……
相关推荐:
- [实用模板]第八章:法国“新浪潮”与“左岸派”
- [实用模板]2021年北京上半年临床医学检验技师生物
- [实用模板]SAP GUI 7.10客户端安装配置文档
- [实用模板]2001年临床执业医师资格考试综合笔试试
- [实用模板]36机场工作实用英语词汇总结
- [实用模板](一)社会保险稽核通知书
- [实用模板]安全教育主题班会材料
- [实用模板]濉溪县春季呼吸道传染病防控应急演练方
- [实用模板]长沙房地产市场周报(1.30-2.3)
- [实用模板]六年级数学上册典中点 - 图文
- [实用模板]C程序设计(红皮书)习题官方参考答案
- [实用模板]中国证监会第一届创业板发行审核委员会
- [实用模板]桥梁工程复习题
- [实用模板]2011学而思数学及答案
- [实用模板]初中病句修改专项练习
- [实用模板]监理学习知识1 - 图文
- [实用模板]小机灵杯四年级试题
- [实用模板]国贸专业毕业论文模板
- [实用模板]教育学概论考试练习题-判断题4
- [实用模板]2015届高考英语一轮复习精品资料(译林
- 00Nkmhe_市场营销学工商管理_电子商务_
- 事业单位考试法律常识
- 诚信教育实施方案
- 吉大小天鹅食品安全检测箱方案(高中低
- 房地产销售培训资料
- 高一地理必修1复习提纲
- 新概念英语第二册lesson_1_练习题
- 证券公司内部培训资料
- 小学英语时间介词专项练习
- 新世纪英语专业综合教程(第二版)第1册U
- 【新课标】浙教版最新2018年八年级数学
- 工程建设管理纲要
- 外研版 必修一Module 4 A Social Surve
- Adobe认证考试 AE复习资料
- 基于H.264AVC与AVS标准的帧内预测技术
- 《食品检验机构资质认定管理办法》(质
- ABB变频器培训课件
- (完整版)小学说明文阅读练习题及答案
- 深思洛克(SenseLock) 深思IV,深思4,深
- 弟子规全文带拼音




