PID控制设计但向阳.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PID控制设计但向阳.doc

二,PID控制程序及流程图部分 图一;占空比坐标图 增量式PID控制算法部分程序: 程序如下: #includereg51.h #includeintrins.h #define uchar unsigned char uchar timecount, PWMH,SpeedSet,SpeedDet; uchar KP,KI,KD; int c1,c2,c3,uk,duk; sbit Dir =P1^0; sbit PWM=P1^1; void PWMout(uchar q) { PWM=1; delay (q); // q即为所求的占空比 PWM=0; delay(100-q); } void timer1( ) interrupt 3 { TH1=0x3c; TL1=0xb0; If(-- timecount = =0); { timecount =4; TR0=0 SpeefDet=TL0; TL0=0; TR0=1; e1=SpeedSet –SpeedDet; duk=(KP*(e1-e2) +KI*e1+KD*(e1-2*e2+e3) )/10; uk=uk+duk; if(uk100)uk=100; else if(uk -100)uk=-100; } PEMH=uk; } void main( ) { TH0= 0; TL0=0; TH1=0x3c; TL0=0xb0; Timecount=4; PEMH=0; SpeedSet=50; .//设定的水温温度为50℃ SpeedDet=0; e1=0; //对应为PID控制中的 e(k),e(k-1),e(k-2) e2=0; e3=0; KP=10; //对应为PID控制中的 KP,KI,KD KI=1; //KI,KP,KD为实验室经实验后所得的数据 KD=2; TR0=1; TR1=1; ET1=1; EA=1; While(1) { PWMout(PWMH); } 图二 ;利用PID增量式控制算法控制水温温度流程图 开始 参数初始化 初始化 采入水温检测值和设定值 计算出偏差值的大小 偏差值的大小是否在允许范围内 求比例分量 求积分分量 求微分分量 利用公式求出占空比q PID控制算法算出控制量 控制器输出量不变 控制量驱动执行机构输出 检测值=设定值 检测值=设定值 继电器断开 电热器停止加热 打开报警允许标志 返回 继电器闭合 电热器开始加热 Y N N Y Y N 高电平1 低电平0 Uk 100

文档评论(0)

wuyouwulu + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档