- 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温控算法
PID温控算法#includereg51.h#includeintrins.h #define N0 40536#define nop() _nop_()#define uchar unsigned char#define uint unsigned int/*程序中变量数组定义*/uchar idata table[]={Real-time Temp:};//第一行显示Real-time Temp:uchar idata table1[5];uchar data1,kp,ki,kd;uint t,hightime,count; //占空比调节参数uint rltemp,settemp=350;int e1,e2,e3,duk,uk;/*引脚定义*/sbit EOC=P2^6;sbit OE=P2^5;sbit START=P2^7;sbit lcden=P3^2;sbit lcdrw=P3^1;sbit lcdrs=P3^0;sbit pwm=P3^3;/****************************** 延时子程序*******************************/void delay(uint 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)(P00x80);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);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);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;}/****************************** 温度比较 PID算法*******************************/void pid_ys(){if(rltempsettemp) //如果实际温度小于设定值{if(settemp-rltemp20) // 如果相差2度{hightime=100;//全速加热}else //否则运行PID算法进行平滑加热{e1 = settemp-rltemp;duk=(kp*(e1-e2)+
文档评论(0)