ImageVerifierCode 换一换
格式:DOC , 页数:9 ,大小:74KB ,
资源ID:2602127      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/2602127.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(温度的PID控制及程序示例.doc)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

温度的PID控制及程序示例.doc

1、 温度的PID控制一温度检测部分首先要OK.二、PID调节作用PID控制时域的公式分解开来:(1) 比例调节器 y(t) = Kp * e(t) e(k) 为当前的温差(设定值与检测值的插值) y(k) 为当前输出的控制信号(需要转化为PWM形式) # 输出与输入偏差成正比。只要偏差出现,就能及时地产生与之成比例的调节作用,使被控量朝着减小偏差的方向变化,具有调节及时的特点。但是, Kp过大会导致动态品质变坏,甚至使系统不稳定。比例调节器的特性曲线.(2) 积分调节器 y(t) = Ki * (e(t)dt Ki = Kp/Ti Ti为积分时间#TI是积分时间常数,它表示积分速度的大小,Ti越

2、大,积分速度越慢,积分作用越弱。只要偏差不为零就会产生对应的控制量并依此影响被控量。增大Ti会减小积分作用,即减慢消除静差的过程,减小超调,提高稳定性。(3) 微分调节器 y(t) = Kd*d(e(t)/dt Kd = Kp*Td Td为微分时间#微分分量对偏差的任何变化都会产生控制作用,以调整系统输出,阻止偏差变化。偏差变化越快,则产生的阻止作用越大。从分析看出,微分作用的特点是:加入微分调节将有助于减小超调量,克服震荡,使系统趋于稳定。他加快了系统的动作速度,减小调整的时间,从而改善了系统的动态性能。三 PID算法:由时域的公式离散化后可得如下公式:y(k) = y(k-1)+(Kp+K

3、i+Kd)*e(k)-(Kp +2*Kd)*e(k-1) + Kd*e(k-2)y(k) 为当前输出的控制信号(需要转化为PWM形式)y(k-1)为前一次输出的控制信号e(k) 为当前的温差(设定值与检测值的插值)e(k-1) 为一次前的温差e(k-2) 为二次前的温差Kp 为比例系数Ki = Kp*T/Ti T为采样周期Kd = Kp*Td/T四PID参数整定(确定Kp,Ts,Ti,Td):温度控制适合衰减曲线法,需要根据多次采样的数据画出响应曲线。所以需要通过串口将采样时间t, 输出y(t)记录下来,方便分析。 1)、不加入算法,系统全速加热,从常温加热到较高的温度的时间为Tk, 则采样时

4、间一般设为 T = Tk/10。 2)、置调节器积分时间TI=,微分时间TD=0,即只加比例算法: y(k) = y(k-1)+Kp*e(k) 比例带置于较大的值。将系统投入运行。 ( = 1/Kp)3)、待系统工作稳定后,对设定值作阶跃扰动,然后观察系统的响应。若响应振荡衰减太快,就减小比例带;反之,则增大比例带。如此反复,直到出现如图所示的衰减比为4:1的振荡过程时,记录此时的值(设为S),以及TS的值(如图中所示)。当采用衰减比为10:1振荡过程时,应用上升时间Tr替代振荡周期TS计算。 系统衰减振荡曲线图中,TS为衰减振荡周期,Tr为响应上升时间。据表中所给的经验公式计算、TI及TD的

5、参数。表衰减曲线法整定计算公式衰减率 整定参数调节规律(1/Kp)T IT D0.75P S PI1.2 S0.5T S PID0.8 S0.3T S0.1T S0.9P S PI1.2 S2T r PID0.8 S1.2T r0.4T r 大致计算出Kp,Ti,Td后代入公式,然后完善算法。让系统运作多测试几次。直到满意为止。以下是网上找的一个示例程序#include #include #define N0 40536#define nop() _nop_()#define uchar unsigned char#define uint unsigned int/*程序中变量 数组定义*/u

6、char idata table=Real-time Temp:;/第一行显示Real-time Temp:uchar idata table15;uchar data1,kp,ki,kd;uint t,hightime,count; /占空比调节参数uint rltemp,settemp=350;int e1,e2,e3,duk,uk;/*引脚定义*/sbit EOC=P26;sbit OE=P25;sbit START=P27;sbit lcden=P32;sbit lcdrw=P31;sbit lcdrs=P30;sbit pwm=P33;/* 延时子程序*/void delay(uin

7、t z) uint x,y;for(x=z;x0;x-)for(y=29;y0;y-);/* LCD忙检测*/bit lcd_busy()bit result;lcdrw = 1;lcdrs = 0;lcden = 1;nop();nop();nop();nop();result = (bit)(P0&0x80);lcden = 0;return(result);/* LCD写命令子程序*/void write_com(uchar com) while(lcd_busy();/忙等待lcdrs = 0;lcdrw = 0;P1 = com;delay(5);lcden = 1;delay(5)

8、;lcden = 0;/* LCD写数据子程序*/void write_data(uchar date) while(lcd_busy(); /忙等待lcdrs = 1;lcdrw = 0;P1=date;delay(5);lcden = 1;delay(5);lcden = 0;/* LCD初始化*/void lcd_init()lcden = 0;write_com(0x38);delay(5);write_com(0x0f);delay(5);write_com(0x06);delay(5);write_com(0x01);delay(5);write_com(0x80);delay(5

9、);write_com(0x01); /* 定时器初始化*/void time_init()EA = 1;ET0 = 1;ET1 = 1;TR0 = 1;TR1 = 1;TMOD = 0x11; TH0 = N0/256; TL0 = N0%256;TH1 = 0X3C;TL1 = 0XB0;/* PID算法系数装载*/void Pid_init()hightime= 0; /输出的占空比e1 = 0; /本次的温度差e2 = 0; /前一次的温度差e3 = 0; /两次前的温度差kp = 10; /需要根据试验确定参数ki = 5; /需要根据试验确定参数kd = 5; /需要根据试验确定参

10、数/* 温度比较 PID算法*/void pid_ys()if(rltemp20) / 如果相差20度(根据实际情况确定是多少)hightime=100;/全速加热else /否则运行PID算法进行平滑加热 e1 = settemp-rltemp;duk=(kp*(e1-e2)+ki*e1+kd*(e1-e2*2+e3)/10; / 式(1) 因为Kp是10,输入放大了10倍,所以duk的输出结果需要除以10uk = uk+duk;/*式(1)与上面提到的公式类似y(k) = y(k-1)+(Kp+Ki+Kd)*e(k)-(Kp +2*Kd)*e(k-1) + Kd*e(k-2) 可以写成 y

11、(k)-y(k-1)=(kp*(e(k)-e(k)+ki*e(k)+kd*(e(k)-e(k-1)*2+e(k-2) 式(1)中 duk 相当于y(k)-(k-1) */if(uk100)uk = 100; /设置饱和控制,else if(uk-100)uk = -100;if(uk=settemp)/如果实际温度大于设定值if(rltemp-settemp 0) /只要实际温度与设定值不相等hightime=0; /停止加热else /e1 = rltemp-settemp;duk=(kp*(e1-e2)+ki*e1+kd*(e1-e2*2+e3);uk = uk+duk;if(uk100)uk = 10

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1