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

標題: 單片機PID算法控制直流電機轉速程序,可穩定調節到目標轉速 [打印本頁]

作者: 2983606955    時間: 2020-12-22 09:36
標題: 單片機PID算法控制直流電機轉速程序,可穩定調節到目標轉速
根據實際轉速來穩定調節到目標轉速


單片機源程序如下:
  1. #include<reg52.h>
  2. #include<stdio.h>
  3. #define uchar unsigned char
  4. #define uint unsigned int
  5. #define THC0 0xf9
  6. #define TLC0 0x0f   //2ms
  7. unsigned char  code Duan[]={0x3F, 0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};//共陰極數碼管,0-9段碼表
  8. unsigned char  Data_Buffer[8]={0,0,0,0,0,0,0,0};

  9. uchar i=0;
  10. sbit AddSpeed=P1^1;
  11. sbit SubSpeed=P1^2;
  12. sbit PWM_FC=P1^0;
  13. int e ,e1 ,e2 ;//pid 偏差
  14. float uk ,uk1 ,duk ;//pid輸出值
  15. float Kp=10,Ki=12,Kd=1.6;//pid控制系數        10,12,1.5
  16. int out=0;
  17. uint SpeedSet=380;
  18. uint cnt=0;
  19. uint Inpluse=0,num=0;//脈沖計數
  20. uint PWMTime=100;//脈沖寬度
  21. unsigned char  arry[];
  22. void SendString(uint ch);
  23. void PIDControl();
  24. void SystemInit();
  25. void delay(uchar x);
  26. void PWMOUT();
  27. void SetSpeed();
  28. void SegRefre();
  29. /**************主函數************/
  30. void main()
  31. {
  32.         SystemInit();
  33.         while(1)
  34.         {
  35.                 SetSpeed();
  36.                 SegRefre();
  37.                 PWMOUT();

  38.         }
  39. }

  40. void PIDControl()        //pid偏差計算
  41. {
  42.         e=SpeedSet-num;
  43.         duk=(Kp*(e-e1)+Ki*e+Kd*(e-2*e1+e2))/50;         //+Kd*(e-2e1+e2)
  44.         uk=uk1+duk;
  45.         out=(int)uk;
  46.         if(out>1000)
  47.         {
  48.                 out=1000;
  49.         }
  50.         else if(out<0)
  51.         {
  52.                 out=0;
  53.         }
  54.         uk1=uk;
  55.         e2=e1;
  56.         e1=e;
  57.         PWMTime=out;
  58. }

  59. void delay(uchar x)
  60. {
  61.         uint i,j;
  62.         for(i=x;i>0;i--)
  63.                 for(j=50;j>0;j--);
  64. }

  65. void PWMOUT()
  66. {
  67.         if(cnt<PWMTime)
  68.         {
  69.                 PWM_FC=1;
  70.         }
  71.         else
  72.         {
  73.                 PWM_FC=0;
  74.         }
  75.         if(cnt>1000) cnt=0;
  76. }
  77. void SystemInit()
  78. {
  79.         TMOD=0X21;   
  80.         TH0=THC0;
  81.         TL0=TLC0;
  82.         TH1=0xC0;
  83.         TL1=0XC0;
  84.         ET1=1;
  85.         ET0=1;
  86.         TR0=1;
  87.         TR1=1;
  88.         EX0=1;     //中斷0用來測量轉速
  89.         IT0=1;
  90.         EA=1;
  91.         e =0;
  92.         e1=0;
  93.         e2=0;
  94. }
  95. void SetSpeed()
  96. {
  97.         if(AddSpeed==0)
  98.         {
  99.                 delay(200);
  100.                 if(AddSpeed==0)
  101.                 {
  102.                         SpeedSet+=10;
  103.                         if(SpeedSet>1500)
  104.                         {
  105.                                 SpeedSet=1500;
  106.                         }
  107.                 }
  108.         }
  109.         if(SubSpeed==0)
  110.         {
  111.                 delay(200);
  112.                 if(SubSpeed==0)
  113.                 {
  114.                         SpeedSet-=10;
  115.                         if(SpeedSet<0) SpeedSet=0;
  116.                 }
  117.         }
  118. }
  119. void SegRefre()                  //顯示刷新
  120. {
  121.          Data_Buffer[0]=SpeedSet/1000;
  122.          Data_Buffer[1]=SpeedSet%1000/100;
  123.          Data_Buffer[2]=SpeedSet%100/10;
  124.          Data_Buffer[3]=SpeedSet%10;
  125.          Data_Buffer[4]=num/1000;
  126.          Data_Buffer[5]=num%1000/100;
  127.          Data_Buffer[6]=num%100/10;
  128.          Data_Buffer[7]=num%10;
  129. }

  130. void int0() interrupt 0
  131. {
  132.         Inpluse++;
  133. }
  134. void t0() interrupt 1
  135. {
  136.         static unsigned char Bit=0;//靜態變量,退出程序值保留
  137.         static unsigned int time=0;
  138. //        static unsigned int aa=0;
  139.         TH0=THC0;
  140.         TL0=TLC0;
  141. //        aa++;
  142. //        if(aa==50)
  143. //        {
  144. //                aa=0;
  145. ////                flag0=1;
  146. //        }

  147.         Bit++;
  148.         time++;  //轉速測量周期
  149.         if(Bit>8) Bit=0;
  150.         P0=0xff;
  151.         P2=Duan[Data_Buffer[Bit]];
  152.         switch(Bit)
  153.         {
  154. ……………………

  155. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼

所有資料51hei提供下載:
案列1 PID自動控制電機轉速.zip (75.46 KB, 下載次數: 187)

作者: 人人學會單片機    時間: 2021-1-19 16:10
做過實物測試嗎?

作者: 250416431    時間: 2021-1-25 17:23
帶負載時有處理嗎
作者: yrx0203    時間: 2021-3-7 20:49
調速的模型的傳遞函數怎么寫?
作者: aabbccmmy    時間: 2024-7-2 21:58
好資料,51黑有你更精彩!!!

作者: linlin1    時間: 2025-1-16 15:40
電機調速還自動收藏了




歡迎光臨 (http://www.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 91精品国产综合久久久久久漫画 | 国产精品亚洲一区 | 日韩欧美中文在线 | 国产精品久久久久久婷婷天堂 | 国产日韩精品一区 | 在线欧美小视频 | 瑟瑟免费视频 | 九色91视频| 男人午夜视频 | 伊人网99| 国产精品视频999 | 国产成人精品一区二区三区视频 | 国产美女在线免费观看 | 日韩精品一区二区三区 | 欧美精品网站 | 久久在看 | 中文字幕一区二区三区精彩视频 | 精品国产乱码久久久久久丨区2区 | 91免费版在线观看 | 亚洲成人精品在线观看 | 在线观看亚洲专区 | 国产精品入口久久 | 手机看片在线播放 | 国产99久久精品一区二区300 | 欧美日韩在线免费观看 | 久久激情视频 | 91视频免费视频 | 国产一级片一区二区三区 | 欧美性受| 伊人网伊人网 | 日本高清aⅴ毛片免费 | 日韩中文字幕在线视频观看 | 北条麻妃视频在线观看 | 精品麻豆剧传媒av国产九九九 | 欧美精品第一区 | 精品少妇一区二区三区在线播放 | av激情在线 | 日韩在线一区二区三区 | 国产精品久久久久久久久图文区 | 特黄毛片视频 | 久久久黑人 |