標(biāo)題: STM32 PID精準(zhǔn)控制電機(jī)轉(zhuǎn)到指定位置源程序 [打印本頁]

作者: 吳浩    時間: 2019-4-23 21:43
標(biāo)題: STM32 PID精準(zhǔn)控制電機(jī)轉(zhuǎn)到指定位置源程序
步進(jìn)電機(jī)轉(zhuǎn)到指定位置

單片機(jī)源程序如下:
  1. #include "led.h"
  2. #include "delay.h"
  3. #include "key.h"
  4. #include "sys.h"
  5. #include "beep.h"
  6. #include "encoder.h"
  7. #include "timer.h"


  8. int main(void)
  9. {
  10.         vu8 key=0;       
  11.         delay_init();                     //延時函數(shù)初始化          
  12.         uart_init(9600);                    //=====串口初始化
  13.   Encoder_Init_TIM2();            //=====編碼器接口
  14.         TIM6_Int_Init(99,7199);       //10MS進(jìn)入一次中斷
  15.         TIM3_PWM_Init(7199,0);         //不分頻。PWM頻率=72000000/900=80Khz
  16. while(1)
  17.         {
  18.                
  19.                 key=KEY_Scan(0);        //得到鍵值
  20.                    if(key)
  21.                 {                                                  
  22.                         switch(key)
  23.                         {                                 
  24.                                 case WKUP_PRES:        //控制蜂鳴器
  25.                                 LED0=!LED0;
  26.                                         break;
  27.                                 case KEY2_PRES:        //控制LED0翻轉(zhuǎn)
  28.                                         LED0=!LED0;
  29.                                         break;
  30.                                 case KEY1_PRES:        //控制LED1翻轉(zhuǎn)         
  31.                                         LED1=!LED1;
  32.                                         break;
  33.                                 case KEY0_PRES:        //同時控制LED0,LED1翻轉(zhuǎn)
  34.                                         LED0=!LED0;
  35.                                         LED1=!LED1;
  36.                                         break;
  37.                         }
  38.                 }else delay_ms(10);
  39.         }         
  40. }
復(fù)制代碼
  1. #include "control.h"       
  2. #define PI 3.141592653
  3. #include "sys.h"


  4. int Encoder,Target_position=10280;             //Encoder編碼器的脈沖計數(shù),相當(dāng)于實際速度 Target_velocity目標(biāo)速度  一周1040脈沖 初始位置10000在encoder.c中設(shè)置
  5. int Moto;                 //電機(jī)PWM變量 應(yīng)是Motor的 向Moto致敬

  6. void TIM6_IRQHandler(void)   //TIM6中斷    函數(shù)實現(xiàn)了編碼器角速度線速度的計算  10MS進(jìn)入一次中斷
  7. {
  8.         if (TIM_GetITStatus(TIM6, TIM_IT_Update) != RESET)  //檢查TIM3更新中斷發(fā)生與否
  9.                 {
  10.                 TIM_ClearITPendingBit(TIM6, TIM_IT_Update  );  //清除TIMx更新中斷標(biāo)志
  11.                 Encoder=Read_Encoder(2);
  12.                 printf("位置%d\r\n",Encoder);
  13.                 Moto=Position_PID(Encoder,Target_position);              //===位置PID控制器
  14.                 Xianfu_Pwm();                                                            //===PWM限幅
  15.     Set_Pwm(Moto);                                                         //===賦值給PWM寄存器         
  16.                 }
  17. }


  18. /**************************************************************************
  19. 函數(shù)功能:賦值給PWM寄存器
  20. 入口參數(shù):PWM
  21. 返回  值:無
  22. **************************************************************************/
  23. void Set_Pwm(int moto1)
  24. {
  25.                         if(moto1<0)                        IN2=1,                        IN1=0;   //換向引腳
  26.                         else                                                                    IN2=0,                        IN1=1;
  27.                         TIM_SetCompare2(TIM3,myabs(moto1));
  28. }

  29. /**************************************************************************
  30. 函數(shù)功能:限制PWM賦值
  31. 入口參數(shù):無
  32. 返回  值:無
  33. **************************************************************************/
  34. void Xianfu_Pwm(void)
  35. {        
  36.           int Amplitude=5000;    //===PWM滿幅是7200 限制在7100
  37.     if(Moto<-Amplitude) Moto=-Amplitude;        
  38.                 if(Moto>Amplitude)  Moto=Amplitude;        
  39. }

  40. /**************************************************************************
  41. 函數(shù)功能:絕對值函數(shù)
  42. 入口參數(shù):int
  43. 返回  值:unsigned int
  44. **************************************************************************/
  45. int myabs(int a)
  46. {                    
  47.           int temp;
  48.                 if(a<0)  temp=-a;  
  49.           else temp=a;
  50.           return temp;
  51. }
  52. /**************************************************************************
  53. 函數(shù)功能:增量PI控制器

  54. 入口參數(shù):編碼器測量值,目標(biāo)速度
  55. 返回  值:電機(jī)PWM
  56. 根據(jù)增量式離散]]PID公式
  57. pwm+=Kp[e(k)-e(k-1)]+Ki*e(k)+Kd[e(k)-2e(k-1)+e(k-2)]
  58. e(k)代表本次偏差
  59. e(k-1)代表上一次的偏差  以此類推
  60. pwm代表增量輸出
  61. 在我們的速度控制閉環(huán)系統(tǒng)里面,只使用PI控制
  62. pwm+=Kp[e(k)-e(k-1)]+Ki*e(k)
  63. **************************************************************************/
  64. int Position_PID (int Encoder,int Target)
  65. {        
  66.          float Position_KP=10,Position_KI=0.1,Position_KD=40;
  67.          static float Bias,Pwm,Integral_bias,Last_Bias;
  68.          Bias=Encoder-Target;                                  //計算偏差
  69.          Integral_bias+=Bias;                                         //求出偏差的積分
  70.          Pwm=Position_KP*Bias+Position_KI*Integral_bias+Position_KD*(Bias-Last_Bias);       //位置式PID控制器
  71.          Last_Bias=Bias;                                       //保存上一次偏差
  72.          return Pwm;                                           //增量輸出
  73. }
復(fù)制代碼


所有資料51hei提供下載:
PID精準(zhǔn)控制電機(jī)轉(zhuǎn)到指定位置.7z (191.75 KB, 下載次數(shù): 311)



作者: djdltao    時間: 2019-4-24 21:22
樓主很用心,很好的資料
作者: ccczx    時間: 2019-4-30 14:01
才學(xué)習(xí)電機(jī),還有很多不懂的地方啊。
作者: 刺眼的光景    時間: 2019-7-11 20:09
下載學(xué)習(xí)學(xué)習(xí)
作者: jiangkeqin_sy    時間: 2019-9-12 20:36
肯定要學(xué)習(xí)
作者: prettytank    時間: 2019-9-12 20:54
收藏下,感覺一定會用到
作者: router123    時間: 2019-9-14 13:39

非常好謝謝
作者: wdliming    時間: 2019-9-14 16:07
正好用到~~
作者: 河鼓    時間: 2020-5-26 16:51
剛剛好,向大佬學(xué)習(xí)
作者: swustlx86    時間: 2020-6-1 02:08
好資料,51黑有你更精彩!!!




歡迎光臨 (http://www.torrancerestoration.com/bbs/) Powered by Discuz! X3.1