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

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

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

STM32倒立擺程序源碼

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:590365 發(fā)表于 2019-9-9 18:51 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
這個(gè)是已經(jīng)調(diào)好的倒立擺的程序、有需要的趕緊下載哦!

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

  6. /**************************************************************************
  7. 函數(shù)功能:5MS定時(shí)中斷函數(shù) 5MS控制周期
  8. 入口參數(shù):無(wú)
  9. 返回  值:無(wú)
  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定時(shí)中斷
  17.         {   
  18.                   TIM1->SR&=~(1<<0);                                       //===清除定時(shí)器1中斷標(biāo)志位                 
  19.                         readEncoder();                                           //===讀取編碼器的值
  20.                         adc=Get_Adc(0);
  21.                   Led_Flash(400);                                          //===LED閃爍;       
  22.                   Get_battery_volt();                                      //===獲取電池電壓                  
  23.                         key(100);                                                 //===掃描按鍵狀態(tài)
  24.                   Balance_Pwm=balance(adc,zhongzhi);
  25.                   Velocity_Pwm=velocity(Encoder_Left);
  26.                   Moto1=Balance_Pwm-Velocity_Pwm;                 //===計(jì)算左輪電機(jī)最終PWM
  27.                    Xianfu_Pwm();                                            //===PWM限幅
  28.      if(Turn_Off(adc,Voltage)==0)                   //===如果不存在異常
  29.                         Set_Pwm(Moto1);                                    //===賦值給PWM寄存器                   
  30.         }      
  31. }

  32. /**************************************************************************
  33. 函數(shù)功能:直立PID控制
  34. 入口參數(shù):角度、角速度
  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;                                          //===求出平衡的角度中值 和機(jī)械相關(guān)
  43.          balance=15*Bias+50*(Bias-Last_Bias);                              //===計(jì)算平衡控制的電機(jī)PWM
  44.          Last_Bias=Bias;
  45.          return balance;
  46. }

  47. /**************************************************************************
  48. 函數(shù)功能:速度PI控制
  49. 入口參數(shù):左輪編碼器、右輪編碼器
  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.           //=============遙控前進(jìn)后退部分=======================//
  58.                 if(1==Flag_Qian)        Movement=-900;                     //===如果前進(jìn)標(biāo)志位置1 位移為負(fù)
  59.                 else if(1==Flag_Hou)          Movement=900;        //===如果后退標(biāo)志位置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;                                     //===積分出位移 積分時(shí)間:5ms
  66.                 Encoder_Integral=Encoder_Integral-Movement;                     //===接收遙控器數(shù)據(jù),控制前進(jìn)后退
  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;    //===電機(jī)關(guān)閉后清除積分
  71.           return Velocity;
  72. }


  73. /**************************************************************************
  74. 函數(shù)功能:賦值給PWM寄存器
  75. 入口參數(shù):左輪PWM、右輪PWM
  76. 返回  值:無(wú)
  77. 作    者:Mini Balance
  78. **************************************************************************/
  79. void Set_Pwm(int moto1)
  80. {
  81.                         PBout(3)=1;//===電機(jī)使能打開(kāi)
  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. 函數(shù)功能:讀取編碼器的數(shù)據(jù)并進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換
  89. 入口參數(shù):無(wú)
  90. 返回  值:無(wú)
  91. 作    者:Mini Balance
  92. **************************************************************************/
  93. void readEncoder(void)
  94. {
  95.           u16 Encoder_L;       //===左右編碼器的脈沖計(jì)數(shù)       
  96.           Encoder_L= TIM3 -> CNT;        //===獲取正交解碼2數(shù)據(jù)       
  97.           TIM3 -> CNT=0;                       //===計(jì)數(shù)器清零
  98.                 if(Encoder_L>32768)  Encoder_Left=Encoder_L-65000; else  Encoder_Left=Encoder_L;  //===數(shù)據(jù)類型轉(zhuǎn)換
  99. }

  100. /**************************************************************************
  101. 函數(shù)功能:限制PWM賦值
  102. 入口參數(shù):無(wú)
  103. 返回  值:無(wú)
  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. 函數(shù)功能:異常關(guān)閉電機(jī)
  116. 入口參數(shù):傾角和電壓
  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 關(guān)閉電機(jī)
  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.        
復(fù)制代碼

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



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

使用道具 舉報(bào)

沙發(fā)
ID:267330 發(fā)表于 2019-9-10 10:23 | 只看該作者
有圖片嗎?
回復(fù)

使用道具 舉報(bào)

板凳
ID:238482 發(fā)表于 2019-9-12 08:58 | 只看該作者
贊一個(gè)
回復(fù)

使用道具 舉報(bào)

地板
ID:261330 發(fā)表于 2019-9-12 15:44 | 只看該作者
有沒(méi)有接線圖?光有程序沒(méi)原理圖人家怎么看,簡(jiǎn)單說(shuō)明一下也好啊。
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 欧美色人 | 亚洲精品区 | 成人三级视频 | 一区二区中文字幕 | 国内精品一区二区三区 | 日韩免费网站 | 亚洲精品国产成人 | 欧美无乱码久久久免费午夜一区 | 欧美在线一区二区三区 | 日韩www| 91青青草视频 | 秋霞电影一区二区 | 91xxx在线观看 | 国产999精品久久久久久 | 国产欧美在线播放 | 国产日韩精品一区二区 | 欧美日韩国产一区二区三区 | 免费视频一区二区三区在线观看 | 欧洲视频一区 | 国产三级一区二区 | 久久99这里只有精品 | 亚洲成人二区 | 中文字幕av高清 | 国产精品一区二区不卡 | 欧美精品一区在线发布 | 大香网伊人 | 国产精品亚洲一区 | 丁香综合 | 国产一区二区三区色淫影院 | 91国内外精品自在线播放 | 免费久久久久久 | www狠狠干| 性福视频在线观看 | 欧美一卡二卡在线观看 | 免费一区 | 国产精彩视频 | 欧美一区二区小视频 | 欧美二区在线 | 欧美在线观看一区二区 | 欧美一级做性受免费大片免费 | 在线免费观看成年人视频 |