久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3929|回復: 2
打印 上一主題 下一主題
收起左側

51單片機PID抗飽和積分程序+Proteus仿真

[復制鏈接]
跳轉到指定樓層
樓主
這是一個C51的PID調節的源程序。

仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機源程序如下:
  1. #include <reg51.h>
  2. #include <intrins.h>
  3. #include <stdio.h>
  4. #include <math.h>

  5. #ifndef  uchar   
  6. #define  uchar         unsigned char
  7. #endif

  8. #ifndef  uint   
  9. #define  uint         unsigned int
  10. #endif

  11. #ifndef  ulong   
  12. #define  ulong         unsigned long
  13. #endif

  14. /*
  15. struct _pid{
  16. float         SetSpeed;                                //定義設定值
  17. float         ActualSpeed;                        //定義實際值
  18. float         err;                                        //定義偏差值
  19. float         err_last;                                //定義上一個偏差值
  20. float         Kp,Ki,Kd;                                //定義比例、積分、微分系數
  21. float         voltage;                                //定義電壓值(控制執行器的變量)
  22. float         integral;                                //定義積分值
  23. float         umax;
  24. float         umin;
  25. }pid;

  26. void PID_init(){
  27. printf("PID_init begin \n");
  28. pid.SetSpeed=0.0;
  29. pid.ActualSpeed=0.0;
  30. pid.err=0.0;
  31. pid.err_last=0.0;
  32. pid.voltage=0.0;
  33. pid.integral=0.0;
  34. pid.Kp=0.4;
  35. pid.Ki=0.2;                                //注意,和上幾次相比,這里加大了積分環節的值
  36. pid.Kd=0.2;
  37. pid.umax=400;
  38. pid.umin=-200;
  39. printf("PID_init end \n");
  40. }

  41. float PID_realize(float speed){
  42. int index;
  43. pid.SetSpeed=speed;
  44. pid.err=pid.SetSpeed-pid.ActualSpeed;

  45. if(pid.ActualSpeed>pid.umax)                //灰色底色表示抗積分飽和的實現
  46. {

  47.                 if(abs(pid.err)>200)                //藍色標注為積分分離過程
  48.                 {        index=0;  }
  49.                 else{
  50.                         if(abs(pid.err)>180)        {index=(200-abs(err))/20;}       
  51.                         else{index=1;}

  52.                                 if(pid.err<0)
  53.                                 {
  54.                                         pid.integral+=pid.err;
  55.                                 }
  56.                         }
  57. }
  58. else
  59.         if(pid.ActualSpeed<pid.umin)
  60.         {
  61.                 if(abs(pid.err)>200)                        //積分分離過程
  62.                 {        index=0;        }
  63.                 else{
  64.                         if(abs(pid.err)>180)        {index=(200-abs(err))/20;}       
  65.                         else{index=1;}
  66.                                 if(pid.err>0)
  67.                                 {
  68.                                         pid.integral+=pid.err;
  69.                                 }
  70.                         }
  71.         }
  72.         else
  73.         {
  74.                 if(abs(pid.err)>200)                        //積分分離過程
  75.                 {        index=0;        }
  76.                 else{
  77.                         if(abs(pid.err)>180)        {index=(200-abs(err))/20;}       
  78.                         else{index=1;}

  79.                                 pid.integral+=pid.err;
  80.                         }
  81.         }

  82. //pid.voltage=pid.Kp*pid.err+index*pid.Ki*pid.integral+pid.Kd*(pid.err-pid.err_last);

  83. //pid.voltage=pid.Kp*pid.err+index*pid.Ki*pid.integral/2+pid.Kd*(pid.err-pid.err_last);        //梯形積分

  84.   pid.voltage=pid.Kp*pid.err+index*pid.Ki*pid.integral+pid.Kd*(pid.err-pid.err_last);           //
  85. pid.err_last=pid.err;
  86. pid.ActualSpeed=pid.voltage*1.0;
  87. return pid.ActualSpeed;
  88. }

  89. */





  90. void main()
  91. {
  92. uint idata        count=0;
  93. int idata        speed1,speed3=0;
  94. // uchar         speed2;
  95. SCON=0x50;
  96. TMOD=0x20;
  97. TCON=0x40;
  98. TH1=0xe8;
  99. TL1=0xe8;
  100. TI=1;
  101. TR1=1;

  102. printf("System begin \n");

  103. PID_init();
  104. while(1)
  105. {
  106.         if(count<100)
  107.         {       
  108.         speed1 = PID_contral(250, speed3 );

  109.         // printf("%f\n",speed);         
  110.          printf("%d\n",speed1);       
  111.          printf("%5d\n",speed3);
  112. //         if(speed3<151){speed3 +=20;}
  113. //         if((speed3>150)&&(speed3<181)){speed3 += 10;}
  114. //         if((speed3>180)&&(speed3<191)){speed3 += 2;}
  115.          if(speed3<250){speed3 += 10;}

  116.           }


  117.          if((count>99)&&(count<150))
  118.          {
  119.                   speed1=PID_contral(200,speed3);
  120.                  printf("%d\n",speed1);         
  121.                 printf("%5d\n",speed3);
  122.                 if(count<110) {speed3 -= 2;}
  123.                 if((count>119)&&(count<130)) {speed3 -= 1;}
  124. //                else speed3 =202;
  125.         }
  126.         count++;
  127.        
  128.          if(count>150){break;}       
  129.           
  130. }


  131. }
復制代碼

所有資料51hei提供下載:
pid抗飽和變積分.rar (103.99 KB, 下載次數: 37)


評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏3 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:136947 發表于 2019-9-27 16:02 | 只看該作者
keil編譯不通過,提供的仿真一直發送“覽”,你告訴我你干啥呢?
回復

使用道具 舉報

板凳
ID:606251 發表于 2019-9-28 07:38 | 只看該作者
這里高手真多,學習了,謝謝樓主!
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产视频1 | 一本综合久久 | 中文字幕 国产精品 | 亚洲视频免费在线观看 | 色综合久久久久 | 金莲网| 视频二区| 亚洲精品一区二区三区在线 | 国产精品无 | 一区二区精品视频 | 国产精品国产三级国产aⅴ无密码 | 欧美一区二区视频 | 欧美日韩在线观看视频网站 | 5060网一级毛片 | 阿v视频在线观看 | 狠狠av | 欧美日韩激情 | 成人在线视频免费观看 | 亚洲成人久久久 | 日韩精品二区 | 日韩字幕 | 精品三级在线观看 | 美国一级片在线观看 | 国产精品亚洲一区二区三区在线 | 国产乱码精品一区二区三区中文 | 中文字幕在线剧情 | 亚洲欧美综合精品另类天天更新 | 国产精品久久久久久婷婷天堂 | 99久久国产 | 国产传媒在线观看 | 一区二区久久精品 | 久久最新| 麻豆91av| 午夜精品一区二区三区在线播放 | 超碰av在线 | 欧美激情精品久久久久久变态 | 国产亚洲成av人在线观看导航 | 久久一视频 | 精品国产精品 | 国产欧美在线观看 | 一级黄色片免费在线观看 |