- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一个实用的单片机PID方式控温实例
§1:基本情况本例中控制对象是一款小型专用工业烘箱要求恒温范围: 室温--300℃恒温精度: ±1℃(其它指标略)§2:控制器硬件 (参考原理图)①.单片机 采用(C51系列)TI公司的MCS1210Y4(内部有8通道24位AD转换器)串行口在线编程②.前向通道 温度信号(来自烘箱的Pt100电阻信号)经INA118放大送入AD通道CH0③.后向通道 I/O口驱动光耦MOC-3061,再驱动大功率双向可控硅输出④.键盘 up 递增按钮和down 递减按钮,设置目标温度⑤.LED(3位)显示温度值(软件切换显示目标温度或采样温度)⑥.电源 +5V单电源
§3:软件介绍(由C语言编写)①.流程
采样当前温度--PID运算--PWM(占空比式)输出 ②.温度采样采样周期是一个很重要的参数其确定取决于烘箱的固有响应特性参数(比如纯滞后时间θ以及响应时间常数τ)一般值在4--20秒之间(例中取16秒)③.PID运算每采样一次之后进行一次PID运算,得到一个输出量,供输出函数调用.为了下面叙述方便先定义几个变量定义:
T_target 表示目标温度T_real 表示当前温度T_diff 表示当前温差 并且T_diff=T_target-T_real PID运算表达式如下PWM_OUT=P_OUT+I_OUT+D_OUT+P_H;(求代数和)其中 P_OUT=KP*(T_diff) 称为比例项,KP是比例系数,比例项的作用是纠正偏差.比例项输出等于比例系数乘当前温差 (原理图)I_OUT=KI*Σ(diff) 称为积分项,KI是积分系数,积分项用于消除系统稳态误差Σ(diff)含义是由当前算起前面N次采样温差的和(例中N取20)D-_OUT=KD*Δdiff 称为微分项,KD是微分系数,微分项用于减小系统超调量,增加系统稳定性.(Δdiff=当前温差-上次温差)
P_H=KC*(T_target)
称为维持功率项,达温后(其它项均趋于0)此项起抵消散热维持温度的作用,可增加系统稳定性.KC是维持功率系数
如果约定满功率值为100,停止输出功率值为0 那末PWM_OUT的取值范围就确定为0--100主要是为了后面编制输出函数时方便简明,直接调用PWM_OUT作为输出占空比的百分数)后面整定系数时就要兼顾PWM_OUT的取值范围 §4.源程序(部分)#define KP 3.0 //比例系数 #define KI 0.3 //积分系数#define KD 200.0 //微分系数#define KC 0.1 //维持功率系数#define T_c 16 //采样周期(单位:秒)sbit pid_port=P3^5; //控制输出端口float T_target=0; //目标温度float T_real=0; //当前温度float PWM=0; //输出控制量 1-100
bit read_AD_enable=0; //PID运算允许标志位
//T0定时器初始化void Timer0_Init(){TMOD|=0x01; TF0 =0;TR0 =1;IE |=0x02; }//读取AD 转换值并刻度void read_AD(void){int delta_ad; unsigned char ad[3];ad[0]=ADRESH;ad[1]=ADRESM;ad[2]=ADRESL;delta_ad=ad[0]*0x100+ad[1]-0x23cb;//???if(delta_ad=0)delta_ad=0; T_real=(float)delta_ad/70; //当前温度}
//*--------PID运算函数void pid(void){static float diff[20]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0}; //静态变量 第n次温差static float sum_diff=0; //Σ(diff) 温差求和 积分static int curr_=0; //20次采样记数float p_out,i_out,d_out,temp;float pwm_0; //维持功率temp=diff[curr_]; //记录上一次温差 供微分用if(curr_+1=20)curr_=0; //20次采样else curr_+=1; sum_diff-=diff[curr_]; //减去最老的一次温差值diff[curr_]=T
您可能关注的文档
最近下载
- 型钢悬挑卸料平台监理实施细则.doc VIP
- 2025版最新建设工程强制性条文汇编.pdf VIP
- (高清版)DG∕TJ 08-2105-2022 行道树栽植与养护技术标准.pdf VIP
- 无人机组装与调试:多旋翼无人机飞控系统组装调试PPT教学课件.pptx VIP
- 检验检测机构资质认定质量手册和程序文件(质量记录表格汇编).doc VIP
- 建筑机电安装培训.pptx VIP
- 初三物理课件第十六章 3节 电阻课件初三物理课件第十六章 第3节 电阻课件.ppt VIP
- 低空经济产业园招商引资与项目管理.docx VIP
- 燃气经营安全重大隐患判定标准课件.pptx VIP
- 2025年学校基孔肯雅热防控工作预案(精选模板).docx
文档评论(0)