标题: 平衡小車源碼(卡爾曼濾波版)附STM32源碼 [打印本页]

作者: frank.chan    时间: 2017-10-28 19:15
标题: 平衡小車源碼(卡爾曼濾波版)附STM32源碼
這個是用STM32103C8 寫的

所有资料51hei提供下载:
平衡小車源碼(卡爾曼濾波版).rar (448.52 KB, 下载次数: 15)

单片机源程序如下:
  1. #include "stm32f10x.h"
  2. #include "sys.h"
  3.   /**************************************************************************
  4. 作者:平衡小车之家
  5. **************************************************************************/
  6. u8 Way_Angle=2;                             //获取角度的算法,1:四元数  2:卡尔曼  3:互补滤波
  7. u8 Flag_Qian,Flag_Hou,Flag_Left,Flag_Right,Flag_sudu=1; //蓝牙遥控相关的变量
  8. u8 Flag_Stop=1,Flag_Show=0;                 //停止标志位和 显示标志位 默认停止 显示打开
  9. int Encoder_Left,Encoder_Right;             //左右编码器的脉冲计数
  10. int Moto1,Moto2;                            //电机PWM变量 应是Motor的 向Moto致敬       
  11. int Temperature;                            //显示温度
  12. int Voltage;                                //电池电压采样相关的变量
  13. float Angle_Balance,Gyro_Balance,Gyro_Turn; //平衡倾角 平衡陀螺仪 转向陀螺仪
  14. float Show_Data_Mb;                         //全局显示变量,用于显示需要查看的数据
  15. u32 Distance;                               //超声波测距
  16. u8 delay_50,delay_flag,Bi_zhang=0,PID_Send,Flash_Send;//延时和调参等变量
  17. float Acceleration_Z;                       //Z轴加速度计  
  18. float Balance_Kp=223,Balance_Kd=0.82,Velocity_Kp=83,Velocity_Ki=0.41;//PID参数
  19. u16 PID_Parameter[10],Flash_Parameter[10];  //Flash相关数组
  20. int main(void)
  21.   {
  22.                 delay_init();                                //=====延时函数初始化       
  23.                 uart_init(128000);                    //=====串口初始化为
  24.                 JTAG_Set(JTAG_SWD_DISABLE);     //=====关闭JTAG接口
  25.                 JTAG_Set(SWD_ENABLE);           //=====打开SWD接口 可以利用主板的SWD接口调试
  26.                 LED_Init();                     //=====初始化与 LED 连接的硬件接口
  27.           KEY_Init();                     //=====按键初始化
  28.                 MY_NVIC_PriorityGroupConfig(2);        //=====中断分组
  29.     MiniBalance_PWM_Init(7199,0);   //=====初始化PWM 10KHZ,用于驱动电机 如需初始化电调接口
  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定时中断初始化
  41.     while(1)
  42.            {
  43.                                          if(Flash_Send==1)        //写入PID参数到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();          //===显示屏打开
  52.                                         }
  53.                                         else                      //使用MiniBalance上位机 上位机使用的时候需要严格的时序,故此时关闭app监控部分和OLED显示屏
  54.                                         {
  55.                                       DataScope();          //开启MiniBalance上位机
  56.                                         }       
  57.                                   delay_flag=1;       
  58.                                         delay_50=0;
  59.                                         while(delay_flag);             //通过MPU6050的INT中断实现的50ms精准延时       
  60.            }
  61. }

复制代码




作者: sopc12    时间: 2017-10-31 16:44
有没有原理图一起发上来学习一下?
作者: davidjai12345    时间: 2019-4-23 13:25
沒有原圖嗎




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1