找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5714|回复: 3
打印 上一主题 下一主题
收起左侧

卡尔曼滤波版STM32平衡小车源码

[复制链接]
跳转到指定楼层
楼主
这是以STM32的平衡小车代码

而且是卡尔曼滤波版的

STM32源程序:
  1. #include "sys.h"
  2.   /**************************************************************************
  3. 作者:平衡小车之家
  4. **************************************************************************/
  5. u8 Way_Angle=2;                             //获取角度的算法,1:四元数  2:卡尔曼  3:互补滤波 默认搭载卡尔曼滤波
  6. u8 Flag_Qian,Flag_Hou,Flag_Left,Flag_Right,Flag_sudu=2; //蓝牙遥控相关的变量
  7. u8 Flag_Stop=1,Flag_Show=1;                 //停止标志位和 显示标志位 默认停止 显示打开
  8. int Encoder_Left,Encoder_Right;             //左右编码器的脉冲计数
  9. int Moto1,Moto2;                            //电机PWM变量 应是Motor的 向Moto致敬       
  10. int Temperature;                            //显示温度
  11. int Voltage;                                //电池电压采样相关的变量
  12. float Angle_Balance,Gyro_Balance,Gyro_Turn; //平衡倾角 平衡陀螺仪 转向陀螺仪
  13. float Show_Data_Mb;                         //全局显示变量,用于显示需要查看的数据
  14. int main(void)
  15. {
  16.         Stm32_Clock_Init(9);            //系统时钟设置
  17.         delay_init(72);                 //延时初始化
  18.         JTAG_Set(JTAG_SWD_DISABLE);     //=====关闭JTAG接口
  19.         JTAG_Set(SWD_ENABLE);           //=====打开SWD接口 可以利用主板的SWD接口调试
  20.         LED_Init();                     //初始化与 LED 连接的硬件接口
  21.         KEY_Init();                     //按键初始化
  22.         OLED_Init();                    //OLED初始化
  23.         uart_init(72,115200);           //初始化串口1
  24.         uart3_init(36,9600);            //串口3初始化
  25.         Adc_Init();                     //ADC初始化
  26.         MiniBalance_PWM_Init(7199,0);   //=====初始化PWM 10KHZ 高频可以防止电机低频时的尖叫声
  27.         Encoder_Init_TIM2();            //初始化编码器1
  28.         Encoder_Init_TIM4();            //初始化编码器2
  29.         IIC_Init();                     //模拟IIC初始化
  30.   MPU6050_initialize();           //=====MPU6050初始化       
  31.         DMP_Init();                     //初始化DMP     
  32.   Timer1_Init(49,7199);           //=====5MS进一次中断服务函数,中断服务函数在control.c
  33.         while(1)
  34.                 {
  35.                         if(Way_Angle==1)                     //DMP没有涉及到严格的时序问题,在主函数读取
  36.                                 {
  37.                                         Read_DMP();                      //===读取角速度和倾角
  38.                                         Angle_Balance=Pitch;             //===更新平衡倾角
  39.                                         Gyro_Balance=gyro[1];            //===更新平衡角速度
  40.                                         Gyro_Turn=gyro[2];               //===更新转向角速度
  41.                                 }
  42.                                 if(Flag_Stop==1||Way_Angle>1)      //===电机关闭后或者没有使用DMP时,开启上位机监控
  43.                                 {
  44.                                         if(Flag_Show==1)  //使用MiniBalanceV3.5 APP
  45.                                         {
  46.                                         delay_ms(500);//延时减缓数据传输频率,确保通信的稳定
  47.                                   APP_Show();
  48.                                         }
  49.                                         else             //使用OLED显示屏和PC端串口调试助手
  50.                                         {
  51.                                         Temperature=Read_Temperature();  //===读取MPU6050内置温度传感器数


  52. …………限于本文篇幅 余下代码请从51黑电子论坛下载附件…………
复制代码

下载:
Biger Balance1.0 卡尔曼滤波版平衡小车源码(默认搭载).rar (2.58 MB, 下载次数: 80)

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏3 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:36299 发表于 2017-4-26 19:26 | 只看该作者
卡尔曼滤波出来值稳定吗?跳动厉害吗?
回复

使用道具 举报

板凳
ID:396383 发表于 2018-9-13 22:25 | 只看该作者
厉害了
回复

使用道具 举报

地板
ID:302850 发表于 2019-1-24 15:24 | 只看该作者
太感谢了,楼主真是雪中送炭的活雷锋啊
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表