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

QQ登錄

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

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

平衡小車(chē)源碼(卡爾曼濾波版)附STM32源碼

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:243746 發(fā)表于 2017-10-28 19:15 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
這個(gè)是用STM32103C8 寫(xiě)的

所有資料51hei提供下載:
平衡小車(chē)源碼(卡爾曼濾波版).rar (448.52 KB, 下載次數(shù): 15)

單片機(jī)源程序如下:
  1. #include "stm32f10x.h"
  2. #include "sys.h"
  3.   /**************************************************************************
  4. 作者:平衡小車(chē)之家
  5. **************************************************************************/
  6. u8 Way_Angle=2;                             //獲取角度的算法,1:四元數(shù)  2:卡爾曼  3:互補(bǔ)濾波
  7. u8 Flag_Qian,Flag_Hou,Flag_Left,Flag_Right,Flag_sudu=1; //藍(lán)牙遙控相關(guān)的變量
  8. u8 Flag_Stop=1,Flag_Show=0;                 //停止標(biāo)志位和 顯示標(biāo)志位 默認(rèn)停止 顯示打開(kāi)
  9. int Encoder_Left,Encoder_Right;             //左右編碼器的脈沖計(jì)數(shù)
  10. int Moto1,Moto2;                            //電機(jī)PWM變量 應(yīng)是Motor的 向Moto致敬       
  11. int Temperature;                            //顯示溫度
  12. int Voltage;                                //電池電壓采樣相關(guān)的變量
  13. float Angle_Balance,Gyro_Balance,Gyro_Turn; //平衡傾角 平衡陀螺儀 轉(zhuǎn)向陀螺儀
  14. float Show_Data_Mb;                         //全局顯示變量,用于顯示需要查看的數(shù)據(jù)
  15. u32 Distance;                               //超聲波測(cè)距
  16. u8 delay_50,delay_flag,Bi_zhang=0,PID_Send,Flash_Send;//延時(shí)和調(diào)參等變量
  17. float Acceleration_Z;                       //Z軸加速度計(jì)  
  18. float Balance_Kp=223,Balance_Kd=0.82,Velocity_Kp=83,Velocity_Ki=0.41;//PID參數(shù)
  19. u16 PID_Parameter[10],Flash_Parameter[10];  //Flash相關(guān)數(shù)組
  20. int main(void)
  21.   {
  22.                 delay_init();                                //=====延時(shí)函數(shù)初始化       
  23.                 uart_init(128000);                    //=====串口初始化為
  24.                 JTAG_Set(JTAG_SWD_DISABLE);     //=====關(guān)閉JTAG接口
  25.                 JTAG_Set(SWD_ENABLE);           //=====打開(kāi)SWD接口 可以利用主板的SWD接口調(diào)試
  26.                 LED_Init();                     //=====初始化與 LED 連接的硬件接口
  27.           KEY_Init();                     //=====按鍵初始化
  28.                 MY_NVIC_PriorityGroupConfig(2);        //=====中斷分組
  29.     MiniBalance_PWM_Init(7199,0);   //=====初始化PWM 10KHZ,用于驅(qū)動(dòng)電機(jī) 如需初始化電調(diào)接口
  30.                 uart3_init(9600);               //=====串口3初始化
  31.     Encoder_Init_TIM2();            //=====編碼器接口
  32.     Encoder_Init_TIM4();            //=====初始化編碼器2
  33.                 Adc_Init();                     //=====adc初始化
  34.     IIC_Init();                     //=====IIC初始化
  35.                 delay_ms(1000);
  36.     MPU6050_initialize();           //=====MPU6050初始化       
  37.     DMP_Init();                     //=====初始化DMP
  38.     OLED_Init();                    //=====OLED初始化            
  39.                 TIM3_Cap_Init(0XFFFF,72-1);            //=====超聲波初始化
  40.           MiniBalance_EXTI_Init();        //=====MPU6050 5ms定時(shí)中斷初始化
  41.     while(1)
  42.            {
  43.                                          if(Flash_Send==1)        //寫(xiě)入PID參數(shù)到Flash,由app控制該指令
  44.                                         {
  45.                   Flash_Write();       
  46.                                                 Flash_Send=0;       
  47.                                         }       
  48.                     if(Flag_Show==0)          //使用MiniBalance APP和OLED顯示屏
  49.                                         {
  50.                                                         APP_Show();       
  51.                                                         oled_show();          //===顯示屏打開(kāi)
  52.                                         }
  53.                                         else                      //使用MiniBalance上位機(jī) 上位機(jī)使用的時(shí)候需要嚴(yán)格的時(shí)序,故此時(shí)關(guān)閉app監(jiān)控部分和OLED顯示屏
  54.                                         {
  55.                                       DataScope();          //開(kāi)啟MiniBalance上位機(jī)
  56.                                         }       
  57.                                   delay_flag=1;       
  58.                                         delay_50=0;
  59.                                         while(delay_flag);             //通過(guò)MPU6050的INT中斷實(shí)現(xiàn)的50ms精準(zhǔn)延時(shí)       
  60.            }
  61. }

復(fù)制代碼



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

使用道具 舉報(bào)

沙發(fā)
ID:243668 發(fā)表于 2017-10-31 16:44 | 只看該作者
有沒(méi)有原理圖一起發(fā)上來(lái)學(xué)習(xí)一下?
回復(fù)

使用道具 舉報(bào)

板凳
ID:519499 發(fā)表于 2019-4-23 13:25 | 只看該作者
沒(méi)有原圖嗎
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表