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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

單片機(jī)PID轉(zhuǎn)速測量控制程序 包括Proteus仿真

  [復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:634507 發(fā)表于 2019-11-30 15:01 | 只看該作者 |只看大圖 回帖獎勵 |倒序?yàn)g覽 |閱讀模式
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機(jī)源程序如下:
  1. #include <REGX51.H>
  2. #include<stdio.h>
  3. #define uchar unsigned char
  4. #define uint unsigned int
  5. #define THC0 0xf8
  6. #define TLC0 0x50   //2ms,0x30,含中斷處理時間時,0x50
  7. #include "LCD.H"
  8. #include "delay.h"

  9. unsigned char aa[]={'T','a','r','g','e','t',' ',' ',' ',' ',' ','r','/','m','i','n'};  //目標(biāo)轉(zhuǎn)速。Target            r/min
  10. unsigned char cc[]={'A','c','t','u','a','l',' ',' ',' ',' ',' ','r','/','m','i','n'};           //實(shí)測轉(zhuǎn)速: Actual      r/min
  11.                                                                                                                                                                                                                                  
  12. uchar i=0;
  13. sbit k1=P1^3;
  14. sbit k2=P1^4;
  15. sbit k3=P1^5;
  16. sbit k4=P1^6;
  17. sbit k5=P1^7;
  18. sbit PWM_FC=P3^5;
  19. sbit IN1=P3^4;
  20. sbit IN2=P3^3;

  21. int e ,e1 ,e2 ;//pid 偏差
  22. float uk ,uk1 ,duk ;//pid輸出值
  23. float Kp=0.25,Ki=0.05,Kd=0.015;//pid控制系數(shù)        0.1 0.05 0.016

  24. /*
  25. PID的參數(shù)設(shè)置可以參照以下來進(jìn)行:  
  26.      參數(shù)整定找最佳,從小到大順序查;  
  27.          先是比例后積分,最后再把微分加;  
  28.          曲線振蕩很頻繁,比例度盤要放大;  
  29.          曲線漂浮繞大灣,比例度盤往小扳;  
  30.          曲線偏離回復(fù)慢,積分時間往下降;  
  31.          曲線波動周期長,積分時間再加長;  
  32.          曲線振蕩頻率快,先把微分降下來;  
  33.          動差大來波動慢。微分時間應(yīng)加長;  
  34.          理想曲線兩個波,前高后低4比1 ; 
  35.          一看二調(diào)多分析,調(diào)節(jié)質(zhì)量不會低;
  36. */

  37. int out=0;
  38. uint SpeedSet=3000;
  39. uint cnt=0;
  40. uint Inpluse=0,num=0,zs;//脈沖計(jì)數(shù)
  41. uint PWMTime=100;//脈沖寬度
  42. void PIDControl();
  43. void SystemInit();
  44. void delay(uchar x);
  45. void PWMOUT();
  46. void SetSpeed();

  47. /**************主函數(shù)************/
  48. void main()
  49. {
  50.         SystemInit();
  51.          init();
  52.          LCD_Write_String(0,0,aa);
  53.         zs=1;
  54.         while(1)
  55.         {
  56.                 SetSpeed();
  57.                 if(zs==1)
  58.                 {
  59.                     zs=0;
  60.                         cc[7]=num/1000+'0';
  61.                         cc[8]=num/100%10+'0';
  62.                         cc[9]=num/10%10+'0';
  63.                         cc[10]=num%10+'0';
  64.                         LCD_Write_String(0,1,cc);
  65.                 }
  66.         }
  67. }

  68. void PIDControl()        //pid偏差計(jì)算
  69. {
  70.         e=SpeedSet-num;
  71.         duk=(Kp*(e-e1)+Ki*e+Kd*(e-2*e1+e2));  
  72.         uk=uk1+duk;
  73.         out=(int)uk;
  74.         if(out>1000)
  75.         {
  76.                 out=1000;
  77.         }
  78.         else if(out<0)
  79.         {
  80.                 out=0;
  81.         }
  82.         uk1=uk;
  83.         e2=e1;
  84.         e1=e;
  85.         PWMTime=out;
  86. }

  87. void delay(uchar x)
  88. {
  89.         uint i,j;
  90.         for(i=x;i>0;i--)
  91.                 for(j=50;j>0;j--);
  92. }

  93. void PWMOUT()
  94. {
  95.         if(cnt<PWMTime)
  96.         {
  97.                 PWM_FC=1;
  98.         }
  99.         else
  100.         {
  101.                 PWM_FC=0;
  102.         }
  103.         if(cnt>1000) cnt=0;
  104. }
  105. void SystemInit()
  106. {
  107.         TMOD=0X21;    //t1用來串口t2定時
  108.         TH0=THC0;
  109.         TL0=TLC0;
  110.         TH1=0xC0;
  111.         TL1=0XC0;
  112.         ET1=1;
  113.         ET0=1;
  114.         TR0=1;
  115.         TR1=1;
  116.         EX0=1;     //中斷0用來測量轉(zhuǎn)速
  117.         IT0=1;
  118.         EA=1;
  119.         e =0;
  120.         e1=0;
  121.         e2=0;
  122.         IN1=1;
  123.         IN2=1;
  124. }
  125. void SetSpeed()
  126. {
  127.         if(k1==0)
  128.         {
  129.                 delay(100);
  130.                 if(k1==0)
  131.                 {
  132.                    IN1=0;
  133.                    IN2=1;
  134.                 }
  135.         }
  136.         if(k2==0)
  137.         {
  138.                 delay(100);
  139.                 if(k2==0)
  140.                 {
  141.                    IN1=1;
  142.                    IN2=1;
  143.                 }
  144.         }
  145.         if(k3==0)
  146.         {
  147.                 delay(100);
  148.                 if(k3==0)
  149.                 {
  150.                    IN1=~IN1;
  151.                    IN2=~IN2;
  152.                 }
  153.                 while(k3==0);
  154.         }
  155.         if(k4==0)
  156.         {
  157.                 delay(100);
  158.                 if(k4==0)
  159.                 {
  160.                         SpeedSet+=10;
  161.                         if(SpeedSet>3500)
  162.                         {
  163.                                 SpeedSet=3500;
  164.                         }
  165.                 }
  166.         }
  167.         if(k5==0)
  168.         {
  169.                 delay(100);
  170.                 if(k5==0)
  171.                 {
  172.                         SpeedSet-=10;
  173.                         if(SpeedSet<0) SpeedSet=0;
  174.                 }
  175.         }        
  176.         aa[7]=SpeedSet/1000+'0';
  177.         aa[8]=SpeedSet/100%10+'0';
  178.         aa[9]=SpeedSet/10%10+'0';
  179.         aa[10]=SpeedSet%10+'0';
  180.         LCD_Write_String(0,0,aa);
  181. }


  182. void int0() interrupt 0
  183. {
  184.         Inpluse++;
  185. }
  186. void t0() interrupt 1
  187. {
  188.         static unsigned int time=0;

  189.         TH0=THC0;
  190.         TL0=TLC0;
  191.         time++;  //轉(zhuǎn)速測量周期
  192.         if(time>500)
  193.         {
  194.                 zs=1;
  195.                 time=0;
  196.                 num=Inpluse;         //計(jì)算式中是仿真時,碼盤數(shù)60時的情況,如果碼盤數(shù)n=10時,num=Inpluse*60/n=Inpluse*6;
  197.                 Inpluse=0;
  198.                 PIDControl();
  199.         }
  200.         PWMOUT();
  201. }
  202. void timer_1()  interrupt 3
  203. {
  204.            cnt++;        //cnt越大占空比越高2.5Khz
  205. }


復(fù)制代碼


全部資料51hei下載地址:
2-PID轉(zhuǎn)速測量控制_LCD.zip (296.09 KB, 下載次數(shù): 122)

評分

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

查看全部評分

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

使用道具 舉報(bào)

沙發(fā)
ID:693716 發(fā)表于 2020-3-9 11:39 | 只看該作者
這個仿真有點(diǎn)意思,學(xué)習(xí)了下,主要學(xué)習(xí)pid控制
回復(fù)

使用道具 舉報(bào)

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

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: h在线观看 | 久久久精品久久 | 久久精品国产一区二区电影 | 久久精品手机视频 | 国产欧美一级二级三级在线视频 | 久久视频精品 | 亚洲小视频| 欧美a免费 | 黄色精品 | 中文字幕一区二区三区不卡 | 精品国产免费一区二区三区演员表 | 中文在线视频 | 精品免费在线 | 国产精品美女久久久免费 | 美女久久久久久久久 | 日日干日日操 | 欧美精品网 | 国产精品一区二区在线免费观看 | 在线亚洲免费视频 | www.国产精 | 久久一本 | 91高清在线观看 | 免费看黄色国产 | 久久久久久久久蜜桃 | 欧美男人天堂 | 亚洲男人的天堂网站 | 精品日韩欧美一区二区 | 欧美成人免费在线视频 | 久久精品久久久久久 | 天天色天天色 | 黄色网址免费在线观看 | 欧美性一区二区三区 | 最新午夜综合福利视频 | 色爱综合网 | 亚洲天堂精品久久 | 国产视频久久久久 | 亚洲区在线 | 中文字幕视频在线 | 亚洲成人免费在线观看 | 久久精品女人天堂av | 国产成人jvid在线播放 |