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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3855|回復(fù): 2
打印 上一主題 下一主題
收起左側(cè)

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

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:412641 發(fā)表于 2019-9-25 15:51 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
這是一個C51的PID調(diào)節(jié)的源程序。

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


單片機(jī)源程序如下:
  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;                                //定義設(shè)定值
  17. float         ActualSpeed;                        //定義實(shí)際值
  18. float         err;                                        //定義偏差值
  19. float         err_last;                                //定義上一個偏差值
  20. float         Kp,Ki,Kd;                                //定義比例、積分、微分系數(shù)
  21. float         voltage;                                //定義電壓值(控制執(zhí)行器的變量)
  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;                                //注意,和上幾次相比,這里加大了積分環(huán)節(jié)的值
  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)                //灰色底色表示抗積分飽和的實(shí)現(xiàn)
  46. {

  47.                 if(abs(pid.err)>200)                //藍(lán)色標(biāo)注為積分分離過程
  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. }
復(fù)制代碼

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


評分

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

查看全部評分

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

使用道具 舉報

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

使用道具 舉報

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

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 毛片99| 一区二区三区免费 | 午夜精品一区 | 激情五月婷婷在线 | 草久在线 | 欧美色图综合网 | 中文字幕视频在线观看 | 日韩免费一区二区 | 97国产在线观看 | 欧美 中文字幕 | 无码日韩精品一区二区免费 | 国产91视频一区二区 | 日操操 | 国产女人与拘做视频免费 | 亚洲一二三区精品 | 欧美精品中文字幕久久二区 | 国产欧美日韩一区 | 国产美女一区二区 | 国产欧美精品区一区二区三区 | 欧美日韩1区2区 | 色资源在线观看 | 国产欧美一区二区三区久久手机版 | 国产精品一区二区在线播放 | 五月天婷婷丁香 | 97视频人人澡人人爽 | 亚洲午夜电影 | 狠狠色综合久久丁香婷婷 | 91高清视频在线观看 | 日韩中文字幕在线观看 | 色综合av| 精品久久久久久久久久久久 | 日韩国产一区二区 | 精品国产乱码久久久久久老虎 | 免费视频一区二区三区在线观看 | 亚洲狠狠爱 | 伊人精品久久久久77777 | 欧美在线观看一区 | 黄色在线免费观看视频 | 欧美精品一区二区三区在线 | 亚洲国产精品成人无久久精品 | 99久久免费精品视频 |