




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
一个实用的单片机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=P35; /控制输出端口float T_target=0; /目标温度float T_real=0; /当前温度float PWM=0; /输出控制量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 ad3;ad0=ADRESH;ad1=ADRESM;ad2=ADRESL;delta_ad=ad0*0x100+ad1-0x23cb;if(delta_ad=20)curr_=0;else curr_+=1;sum_diff-=diffcurr_;diffcurr_=T_target-T_real;sum_diff+=diffcurr_;p_out=KP*diffcurr_; /比例项输出i_out=KI*sum_diff; /积分项输出d_out=KD*(diffcurr_-temp); /微分项输出pwm_0=KC*T_target; /维持功率项if(i_out100)i_out=100; /积分分离if(i_out-100)i_out=-100;PWM=p_out+i_out+d_out+pwm_0; /总输出量if(PWM=100)PWM=100;/ 输出函数void PWM_OUT(float PWM)static unsigned char t=1; /t=(1-100)周期为4秒unsigned char limit; /pid_value输出百分比limit=(unsigned char)PWM;if(t100)t=1;/*/T0中断服务程序void Timer0_ISR() interrupt 1 using 1static unsigned int x=0;TH0=(28672)8; / 11.0592MHz,interval 40mSTL0=(28672+20)&0xff; / +20 compensate TF0=0;if(x+)(T_c*25)x=0;read_AD_enable=1;PWM_OUT(PWM); /可控硅输出/*主程序-*/void main (void)/-程序初始化(略)while (1)if(read_AD_enable=1)read_AD_enable=0;read_AD();pid();5.参数的整定(这大概是最困难而且费时的事)T_c(采样周期)单从控制精度上考虑,T_c当然是越小越好,但过小占用处理器的运算时间会加长,从而导致系统成本增加,例中主要考虑被控对象的时间常数和纯滞后时间,下面用扩充响应曲线法求取及.a. 使系统处于开环,手动直接在被控对象输入端加一个阶跃信号描绘出响应曲线(如图)b. 在响应曲线的最大斜率处作切线即可得到和c. 选择T_c,当占主导地位时,应尽量使为T_c的整倍数如 =2T_c 或=T_c ,当比T_c小得多时,可取T_c= /10KP( 比例系数)先定为1,做一个简单的只有比例调节的函数,使系统工作于闭环,T_target 定在150(恒温范围的中间值)纪录响应曲线,如果曲线没有出现振铃则可能是KP偏小,调整KP,使曲线出现轻微振铃.反之振铃幅度过大,则可能是KP偏大. KC(维持功率系数)借用5.中的曲线(如下图)根据图中所示 由KC*150=PWM_H 导出KCKI(积分系数)KI 的选取与T_c和积分时长有关,回过头看源程序PID运算函数中有一个静态数组,记录过去t时刻到当前的各个温度采样值.每一次采样之后都要更新(淘汰掉最早的采样值,加入当前采样值).积分时长=T_c*采样个数(即数组大小SIZE)积分时长的选择一般使它大于纯滞后时间即可,反过来通过T_c和可以确定数组的大小SIZE,接着套用下式就可以大致确定KI了.KI*SIZE=10%*满功率值KD(微分系数)KD取值大致为纯滞后时间(比如=200秒,KD先取200,后根据实验在调整)以上的步骤可能要反复进行多次,各个系数也要作相应的调整.这里我介绍一个站长编写的并已成功应用的调试软件HUANENG.EXE专用于串行口数据分析绘图,可同时描绘8条曲线,(VC编写) 使用非常简单,只需在上面源程序中pid()函数末尾加上几行数据打印输出的语
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 租赁店铺的残疾人士服务考核试卷
- 铸造过程中的质量管理方法创新与实践案例分析考核试卷
- 银矿市场动态监测与投资决策分析考核试卷
- 过敏性休克病人急救护理
- 呼吸道疾病预防及措施
- 院前急救的常见护理技术
- 机场应急救援浅析课件
- 影像学呼吸系统概述
- 外科手部护理标准流程
- 感染控制管理规范实施框架
- 2023年黄冈市团风县社区工作者招聘考试真题
- 被迫离职通知书
- 中学化学实验员培训材料
- 30题投资管理类岗位常见面试问题含HR问题考察点及参考回答
- 校园网络运维服务需求
- 2023调度自动化系统主站信息自动联调技术规范
- 物流公司运输安全管理制度
- 三个合伙人分配合同范本
- PLC课程设计-四人抢答器
- 资产管理+数据资产确权登记导则(2022年)
- SL637-2023年《水力机械辅助设备系统安装工程施工质量验收评定标准》
评论
0/150
提交评论