欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 9270|回復: 9
收起左側

STM32 PID精準控制電機轉到指定位置源程序

  [復制鏈接]
ID:519988 發表于 2019-4-23 21:43 | 顯示全部樓層 |閱讀模式
步進電機轉到指定位置

單片機源程序如下:
  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();                     //延時函數初始化          
  12.         uart_init(9600);                    //=====串口初始化
  13.   Encoder_Init_TIM2();            //=====編碼器接口
  14.         TIM6_Int_Init(99,7199);       //10MS進入一次中斷
  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翻轉
  28.                                         LED0=!LED0;
  29.                                         break;
  30.                                 case KEY1_PRES:        //控制LED1翻轉         
  31.                                         LED1=!LED1;
  32.                                         break;
  33.                                 case KEY0_PRES:        //同時控制LED0,LED1翻轉
  34.                                         LED0=!LED0;
  35.                                         LED1=!LED1;
  36.                                         break;
  37.                         }
  38.                 }else delay_ms(10);
  39.         }         
  40. }
復制代碼
  1. #include "control.h"       
  2. #define PI 3.141592653
  3. #include "sys.h"


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

  6. void TIM6_IRQHandler(void)   //TIM6中斷    函數實現了編碼器角速度線速度的計算  10MS進入一次中斷
  7. {
  8.         if (TIM_GetITStatus(TIM6, TIM_IT_Update) != RESET)  //檢查TIM3更新中斷發生與否
  9.                 {
  10.                 TIM_ClearITPendingBit(TIM6, TIM_IT_Update  );  //清除TIMx更新中斷標志
  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. 函數功能:賦值給PWM寄存器
  20. 入口參數: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. 函數功能:限制PWM賦值
  31. 入口參數:無
  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. 函數功能:絕對值函數
  42. 入口參數: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. 函數功能:增量PI控制器

  54. 入口參數:編碼器測量值,目標速度
  55. 返回  值:電機PWM
  56. 根據增量式離散]]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. 在我們的速度控制閉環系統里面,只使用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. }
復制代碼


所有資料51hei提供下載:
PID精準控制電機轉到指定位置.7z (191.75 KB, 下載次數: 311)


評分

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

查看全部評分

回復

使用道具 舉報

ID:86244 發表于 2019-4-24 21:22 | 顯示全部樓層
樓主很用心,很好的資料
回復

使用道具 舉報

ID:525089 發表于 2019-4-30 14:01 | 顯示全部樓層
才學習電機,還有很多不懂的地方啊。
回復

使用道具 舉報

ID:76606 發表于 2019-7-11 20:09 | 顯示全部樓層
下載學習學習
回復

使用道具 舉報

ID:267330 發表于 2019-9-12 20:36 | 顯示全部樓層
肯定要學習
回復

使用道具 舉報

ID:302850 發表于 2019-9-12 20:54 來自觸屏版 | 顯示全部樓層
收藏下,感覺一定會用到
回復

使用道具 舉報

ID:217614 發表于 2019-9-14 13:39 | 顯示全部樓層

非常好謝謝
回復

使用道具 舉報

ID:20672 發表于 2019-9-14 16:07 | 顯示全部樓層
正好用到~~
回復

使用道具 舉報

ID:752842 發表于 2020-5-26 16:51 | 顯示全部樓層
剛剛好,向大佬學習
回復

使用道具 舉報

ID:302325 發表于 2020-6-1 02:08 | 顯示全部樓層
好資料,51黑有你更精彩!!!
回復

使用道具 舉報

11#
無效樓層,該帖已經被刪除
12#
無效樓層,該帖已經被刪除
13#
無效樓層,該帖已經被刪除
您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表