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

標題: STM32倒立擺程序源碼 [打印本頁]

作者: 17393161229    時間: 2019-9-9 18:51
標題: STM32倒立擺程序源碼
這個是已經調好的倒立擺的程序、有需要的趕緊下載哦!

單片機源程序如下:
  1. #include "MiniBalance.h"
  2. #include "math.h"
  3. #include "led.h"
  4. #include "mpu6050.h"
  5. #define PI 3.14159265

  6. /**************************************************************************
  7. 函數功能:5MS定時中斷函數 5MS控制周期
  8. 入口參數:無
  9. 返回  值:無
  10. 作    者:Mini Balance
  11. **************************************************************************/
  12. int zhongzhi=1750;
  13. int Balance_Pwm,Velocity_Pwm,Turn_Pwm;
  14. void TIM1_UP_TIM16_IRQHandler(void)  
  15. {   
  16.         if(TIM1->SR&0X0001)//5ms定時中斷
  17.         {   
  18.                   TIM1->SR&=~(1<<0);                                       //===清除定時器1中斷標志位                 
  19.                         readEncoder();                                           //===讀取編碼器的值
  20.                         adc=Get_Adc(0);
  21.                   Led_Flash(400);                                          //===LED閃爍;       
  22.                   Get_battery_volt();                                      //===獲取電池電壓                  
  23.                         key(100);                                                 //===掃描按鍵狀態
  24.                   Balance_Pwm=balance(adc,zhongzhi);
  25.                   Velocity_Pwm=velocity(Encoder_Left);
  26.                   Moto1=Balance_Pwm-Velocity_Pwm;                 //===計算左輪電機最終PWM
  27.                    Xianfu_Pwm();                                            //===PWM限幅
  28.      if(Turn_Off(adc,Voltage)==0)                   //===如果不存在異常
  29.                         Set_Pwm(Moto1);                                    //===賦值給PWM寄存器                   
  30.         }      
  31. }

  32. /**************************************************************************
  33. 函數功能:直立PID控制
  34. 入口參數:角度、角速度
  35. 返回  值:直立控制PWM
  36. 作    者:Mini Balance
  37. **************************************************************************/
  38. int balance(int adc, int target)
  39. {  
  40.          static int Last_Bias;
  41.          int balance,Bias;
  42.          Bias=adc-target;                                          //===求出平衡的角度中值 和機械相關
  43.          balance=15*Bias+50*(Bias-Last_Bias);                              //===計算平衡控制的電機PWM
  44.          Last_Bias=Bias;
  45.          return balance;
  46. }

  47. /**************************************************************************
  48. 函數功能:速度PI控制
  49. 入口參數:左輪編碼器、右輪編碼器
  50. 返回  值:速度控制PWM
  51. 作    者:Mini Balance
  52. **************************************************************************/
  53. int velocity(int encoder_left)
  54. {  
  55.           static int Velocity,Encoder_Least,Encoder,Movement;
  56.           static long Encoder_Integral;
  57.           //=============遙控前進后退部分=======================//
  58.                 if(1==Flag_Qian)        Movement=-900;                     //===如果前進標志位置1 位移為負
  59.                 else if(1==Flag_Hou)          Movement=900;        //===如果后退標志位置1 位移為正
  60.           else  Movement=0;       
  61.    //=============速度PI控制器=======================//       
  62.                 Encoder_Least =Encoder_Left; //===獲取最新速度偏差
  63.                 Encoder *= 0.4;                                         //===一階低通濾波器      
  64.                 Encoder += Encoder_Least*0.6;                     //===一階低通濾波器   
  65.                 Encoder_Integral +=Encoder;                                     //===積分出位移 積分時間:5ms
  66.                 Encoder_Integral=Encoder_Integral-Movement;                     //===接收遙控器數據,控制前進后退
  67.                 if(Encoder_Integral>500)          Encoder_Integral=500;          //===積分限幅
  68.                 if(Encoder_Integral<-500)        Encoder_Integral=-500;         //===積分限幅       
  69.                 Velocity=Encoder*300+Encoder_Integral*10; //===速度控制       
  70.                 if(Turn_Off(Angle_Balance,Voltage)==1)   Encoder_Integral=0;    //===電機關閉后清除積分
  71.           return Velocity;
  72. }


  73. /**************************************************************************
  74. 函數功能:賦值給PWM寄存器
  75. 入口參數:左輪PWM、右輪PWM
  76. 返回  值:無
  77. 作    者:Mini Balance
  78. **************************************************************************/
  79. void Set_Pwm(int moto1)
  80. {
  81.                         PBout(3)=1;//===電機使能打開
  82.                         if(moto1<0)                        PBout(5)=1,                        PBout(4)=0;
  83.                         else                   PBout(5)=0,                        PBout(4)=1;
  84.                         TIM4->CCR2=myabs(moto1);

  85.        
  86. }
  87. /**************************************************************************
  88. 函數功能:讀取編碼器的數據并進行數據類型轉換
  89. 入口參數:無
  90. 返回  值:無
  91. 作    者:Mini Balance
  92. **************************************************************************/
  93. void readEncoder(void)
  94. {
  95.           u16 Encoder_L;       //===左右編碼器的脈沖計數       
  96.           Encoder_L= TIM3 -> CNT;        //===獲取正交解碼2數據       
  97.           TIM3 -> CNT=0;                       //===計數器清零
  98.                 if(Encoder_L>32768)  Encoder_Left=Encoder_L-65000; else  Encoder_Left=Encoder_L;  //===數據類型轉換
  99. }

  100. /**************************************************************************
  101. 函數功能:限制PWM賦值
  102. 入口參數:無
  103. 返回  值:無
  104. 作    者:Mini Balance
  105. **************************************************************************/
  106. void Xianfu_Pwm(void)
  107. {       
  108.           int Amplitude=7100;    //===PWM滿幅是7200 限制在7100
  109.     if(Moto1<-Amplitude) Moto1=-Amplitude;       
  110.                 if(Moto1>Amplitude)  Moto1=Amplitude;       
  111.           if(Moto2<-Amplitude) Moto2=-Amplitude;       
  112.                 if(Moto2>Amplitude)  Moto2=Amplitude;               
  113. }

  114. /**************************************************************************
  115. 函數功能:異常關閉電機
  116. 入口參數:傾角和電壓
  117. 返回  值:1:異常  0:正常
  118. 作    者:Mini Balance
  119. **************************************************************************/
  120. u8 Turn_Off(int adc, int voltage)
  121. {
  122.             u8 temp;
  123.                         if(adc<(zhongzhi-500)||adc>(zhongzhi+500)||1==Flag_Stop||Voltage<1110)//===電壓低于11.1V 關閉電機
  124.                         {                                                    
  125.       temp=1;                                          
  126.                         PBout(3)=0;
  127.                         PBout(12)=0;
  128.                         PAout(15)=0;
  129.                         PBout(4)=0;       
  130.                         PBout(5)=0;
  131.       }
  132.                         else
  133.       temp=0;
  134.       return temp;                       
  135. }
  136.        
復制代碼

所有資料51hei提供下載:
倒立擺2.3.7z (354.95 KB, 下載次數: 35)




作者: jiangkeqin_sy    時間: 2019-9-10 10:23
有圖片嗎?
作者: 撲撲    時間: 2019-9-12 08:58
贊一個

作者: collapsar147    時間: 2019-9-12 15:44
有沒有接線圖?光有程序沒原理圖人家怎么看,簡單說明一下也好啊。




歡迎光臨 (http://www.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 久久99精品久久久久久琪琪 | 欧美日韩专区 | 91高清视频在线观看 | 在线色网| 91看片网 | 国产精品久久久久久久久久久久 | 国产欧美在线一区二区 | 国产在线视频在线观看 | 日本中文字幕视频 | 免费观看黄色片视频 | 国产成人精品网站 | 日本一道本视频 | 亚洲精品视频免费 | 国产一区二区在线视频 | 国产免费自拍 | 国产精品美女久久久久久免费 | 亚洲人人 | 久在线| 亚洲伊人精品酒店 | 高清黄色毛片 | 欧美日韩精品免费 | 欧美日韩在线视频一区二区 | 日韩精品激情 | 伊人爽| 精品一二三区在线观看 | 久久精品中文 | 亚洲一区二区三 | 国产亚洲精品久久久久动 | 久久精品国产久精国产 | 久久国产亚洲精品 | 久久久无码精品亚洲日韩按摩 | 天天干视频网 | 性视频网| 国产在线一区二区 | 国内在线视频 | 日韩视频91| 亚洲国产精品久久久久 | 日本欧美在线观看视频 | 国产成人精品网站 | 欧美一二精品 | 91短视频网址 |