0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

陀螺仪LSM6DSOW开发(9)----加速度校准

嵌入式单片机MCU开发 来源:嵌入式单片机MCU开发 作者:嵌入式单片机MCU开 2024-08-23 10:07 次阅读

概述

MotionAC 是 STMicroelectronics 提供的一款用于加速度计校准的中间件库。该库可以实时计算加速度计的偏移和比例因子,并对传感器数据进行补偿,从而提高测量精度。
MotionAC 库通过获取加速度计的数据,计算出偏移和比例因子校准参数,并应用这些参数对原始数据进行校正。校准可以在动态和静态两种模式下进行。

需要样片的可以加群申请:615061293 。

视频教学

[https://www.bilibili.com/video/BV1Yw4m1k7tR/]

样品申请

[https://www.wjx.top/vm/OhcKxJk.aspx#]

源码下载

[https://download.csdn.net/download/qq_24312945/89628523]

硬件准备

首先需要准备一个开发板,这里我准备的是自己绘制的开发板,需要的可以进行申请。 主控为STM32H503CB,陀螺仪为LSM6DSOW,磁力计为LIS2MDL。

校准过程

2.2.6 节详细描述了如何使用 MotionAC 库进行加速度计的校准过程。该过程通过正常运动或特定姿态的设备来确定偏移和比例因子补偿,以提高加速度计的测量精度。
初始位置:
● 将设备稳固地握在起始位置(位置1)。
旋转设备:
● 轻轻地将设备沿 YZ 平面旋转 180°,使设备翻转到其背面(位置4)。
● 然后再沿 XZ 平面顺时针旋转 180°,使设备返回到起始位置(位置1)。
平滑路径:
● 试图沿平滑路径和恒定速度旋转设备。
六点校准:
● 也可以执行标准的六点校准,将模块静止在六个不同方向(+X, -X, +Y, -Y, +Z, -Z)上。

开启CRC

串口设置

设置串口速率为2000000。

开启X-CUBE-MEMS1

通过使用 MotionAC 库,可以有效地对加速度计进行校准,确保测量数据的准确性。

速率选择

MotionAC 支持从20 Hz到100 Hz的更新频率。

AccelerometerCalibration

该应用程序展示了如何使用由 STMicroelectronics 开发的 MotionAC 中间件库与 X-NUCLEO-IKS01A3 扩展板和 STM32 Nucleo 板上的 LSM6DSO 组件进行加速度计校准。应用程序启动后,用户可以使用由 STMicroelectronics 开发的 Unicleo-GUI 应用程序查看数据。

变量定义

float acceleration_mg[3];
static MAC_knobs_t Knobs;

MotionAC文件

主要包含app_mems_motionac.c和app_mems_motionac.h,这两个文件是用于配置和实现加速度计校准功能的头文件和源文件。它们使用了 MotionAC 库,提供了必要的函数接口和实现来初始化、更新、获取校准参数和应用校准补偿。

MX_AccelerometerCalibration_Init

MX_AccelerometerCalibration_Init 该函数初始化了加速度计校准功能。以下是其具体流程和每个步骤的详细解释:

  1. 调用 MotionAC_manager_init(MAC_DISABLE_LIB) 禁用 MotionAC 库。
  2. 调用 MotionAC_manager_init(MAC_ENABLE_LIB) 启用 MotionAC 库。
    1和2主要使用MotionAC_Initialize 函数用于初始化 MotionAC 引擎,根据传入的参数决定启用或禁用加速度计校准库。此函数是 MotionAC 库的核心初始化函数,通过设置内部状态和参数来准备校准功能。

  1. 调用 MotionAC_GetKnobs(&Knobs) 获取当前的校准设置。
  2. 调用 MotionAC_SetKnobs(&Knobs) 将这些新的设置应用到库中。
  3. 调用 MotionAC_manager_get_version(LibVersion, &LibVersionLen) 获取 MotionAC 库的版本信息

AC_Data_Handler

AC_Data_Handler 函数的主要功能是处理加速度计数据,通过 MotionAC 库进行校准,获取并应用校准参数,最终输出校准后的加速度数据和校准质量信息。

  1. MotionAC_manager_update 函数用于更新加速度计数据,并运行加速度计的校准算法。这一过程包括接收新的加速度计数据,执行校准计算,确定是否需要更新校准参数,并返回校准状态。
    1中主要执行MotionAC_Update 函数用于运行加速度计校准算法。它接收输入的加速度计数据和时间戳,计算校准参数,并返回当前样本是否完成校准。

MotionAC_manager_get_params 函数用于获取加速度计的校准参数,包括偏移值(Offset)和比例因子(Scale Factor)矩阵。这些参数是由校准算法计算得到的,用于对原始加速度计数据进行校正。
2.中主要执行MotionAC_GetCalParams 函数用于检索加速度计的校准系数,包括偏移和比例因子补偿参数,以及校准质量因子。该函数将这些参数填充到传入的输出结构体中,以便调用者使用这些参数进行校准数据处理。
● MAC_CALQSTATUSUNKNOWN = 0:校准参数的准确性未知。
● MAC_CALQSTATUSPOOR = 1:校准参数的准确性较差,不可信。
● MAC_CALQSTATUSOK = 2:校准参数的准确性尚可。
● MAC_CALQSTATUSGOOD = 3:校准参数的准确性良好。

  1. MotionAC_manager_compensate 函数用于对原始加速度计数据进行补偿,即应用先前计算得到的校准参数(偏移值和比例因子矩阵)来校正加速度计数据。这个过程是为了消除加速度计在测量中的系统误差,提高数据的准确性。

初始化定义

/* USER CODE BEGIN 2 */
    printf("HELLO!n");
  HAL_GPIO_WritePin(CS1_GPIO_Port, CS1_Pin, GPIO_PIN_SET);
  HAL_GPIO_WritePin(SA0_GPIO_Port, SA0_Pin, GPIO_PIN_RESET);
  HAL_GPIO_WritePin(CS2_GPIO_Port, CS2_Pin, GPIO_PIN_SET);
    HAL_Delay(100);    



  stmdev_ctx_t dev_ctx;
  /* Initialize mems driver interface */
  dev_ctx.write_reg = platform_write;
  dev_ctx.read_reg = platform_read;
  dev_ctx.mdelay = platform_delay;
  dev_ctx.handle = &SENSOR_BUS;
  /* Init test platform */
//  platform_init();
  /* Wait sensor boot time */
  platform_delay(BOOT_TIME);
  /* Check device ID */
  lsm6dso_device_id_get(&dev_ctx, &whoamI);
    printf("LSM6DSO_ID=0x%x,whoamI=0x%x",LSM6DSO_ID,whoamI);
  if (whoamI != LSM6DSO_ID)
    while (1);

  /* Restore default configuration */
  lsm6dso_reset_set(&dev_ctx, PROPERTY_ENABLE);

  do {
    lsm6dso_reset_get(&dev_ctx, &rst);
  } while (rst);

  /* Disable I3C interface */
  lsm6dso_i3c_disable_set(&dev_ctx, LSM6DSO_I3C_DISABLE);
  /* Enable Block Data Update */
  lsm6dso_block_data_update_set(&dev_ctx, PROPERTY_ENABLE);
  /* Set Output Data Rate */
  lsm6dso_xl_data_rate_set(&dev_ctx, LSM6DSO_XL_ODR_52Hz);
  lsm6dso_gy_data_rate_set(&dev_ctx, LSM6DSO_GY_ODR_52Hz);
  /* Set full scale */
  lsm6dso_xl_full_scale_set(&dev_ctx, LSM6DSO_2g);
  lsm6dso_gy_full_scale_set(&dev_ctx, LSM6DSO_2000dps);
  /* Configure filtering chain(No aux interface)
   * Accelerometer - LPF1 + LPF2 path
   */
  lsm6dso_xl_hp_path_on_out_set(&dev_ctx, LSM6DSO_LP_ODR_DIV_100);
  lsm6dso_xl_filter_lp2_set(&dev_ctx, PROPERTY_ENABLE);

  /* Initialize the peripherals and the MEMS components */    
    MX_AccelerometerCalibration_Init();
  /* USER CODE END 2 */

六位置法的标定方案

本文在校准三轴加速度计时使用六位置校准法,该方法使用地球的重力力加速度在静态下校准三轴加速度传感器,具体的校准过程如下图所示。具体校准过程如下:

  1. 将传感器的Y轴垂直水平面向下;
  2. 以X轴为基准轴,绕其逆旋转90°,使乙轴垂直水平面向上
  3. 以Y轴为基准轴,绕其逆旋转90°,使X轴垂直水平面向下
  4. 以Y轴为基准轴,绕其逆时针旋转90°使2轴垂直水平面向下
  5. 绕Y轴逆时针旋转909、使X轴垂直水平面向上
  6. 绕Z轴顺时针旋转90°、使Y轴垂直水平面向上

在没有精密设备的情况下。这种方法基本上是在试图找到每个轴的偏移(zero-g offset)和灵敏度(scale factor)。这种方法通常称为静态校准方法,因为它不需要动态输入,只需将设备置于静态的已知方向即可。

主函数

/* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
    uint8_t reg;
    /* Read output only if new xl value is available */
    lsm6dso_xl_flag_data_ready_get(&dev_ctx, ®);

    if (reg) {
      /* Read acceleration field data */
      memset(data_raw_acceleration, 0x00, 3 * sizeof(int16_t));
      lsm6dso_acceleration_raw_get(&dev_ctx, data_raw_acceleration);
      acceleration_mg[0] =
        lsm6dso_from_fs2_to_mg(data_raw_acceleration[0]);
      acceleration_mg[1] =
        lsm6dso_from_fs2_to_mg(data_raw_acceleration[1]);
      acceleration_mg[2] =
        lsm6dso_from_fs2_to_mg(data_raw_acceleration[2]);




      printf("Acceleration [mg]:%4.2ft%4.2ft%4.2frn",
              acceleration_mg[0], acceleration_mg[1], acceleration_mg[2]);
AC_Data_Handler();
    }

//    lsm6dso_gy_flag_data_ready_get(&dev_ctx, ®);

//    if (reg) {
//      /* Read angular rate field data */
//      memset(data_raw_angular_rate, 0x00, 3 * sizeof(int16_t));
//      lsm6dso_angular_rate_raw_get(&dev_ctx, data_raw_angular_rate);
//      angular_rate_mdps[0] =
//        lsm6dso_from_fs2000_to_mdps(data_raw_angular_rate[0]);
//      angular_rate_mdps[1] =
//        lsm6dso_from_fs2000_to_mdps(data_raw_angular_rate[1]);
//      angular_rate_mdps[2] =
//        lsm6dso_from_fs2000_to_mdps(data_raw_angular_rate[2]);
//      printf("Angular rate [mdps]:%4.2ft%4.2ft%4.2frn",
//              angular_rate_mdps[0], angular_rate_mdps[1], angular_rate_mdps[2]);


//    }

//    lsm6dso_temp_flag_data_ready_get(&dev_ctx, ®);

//    if (reg) {
//      /* Read temperature data */
//      memset(&data_raw_temperature, 0x00, sizeof(int16_t));
//      lsm6dso_temperature_raw_get(&dev_ctx, &data_raw_temperature);
//      temperature_degC =
//        lsm6dso_from_lsb_to_celsius(data_raw_temperature);
//      printf( "Temperature [degC]:%6.2frn", temperature_degC);

//    }    

HAL_Delay(1);


    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
  }
  /* USER CODE END 3 */

演示

在未执行六位置校准法时,Calibration不为3。

X轴向下。

X轴向上。

Y轴向下。

Y轴向上。

Z轴向下。

Z轴向上。

校准完毕Calibration=3

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 传感器
    +关注

    关注

    2541

    文章

    49852

    浏览量

    747008
  • 陀螺仪
    +关注

    关注

    44

    文章

    768

    浏览量

    98130
  • 加速度计
    +关注

    关注

    6

    文章

    691

    浏览量

    45716
收藏 人收藏

    评论

    相关推荐

    陀螺仪LSM6DSV16X与AI集成(2)----姿态解算

    LSM6DSV16X包含三轴陀螺仪与三轴加速度计。
    的头像 发表于 12-18 10:51 1627次阅读
    <b class='flag-5'>陀螺仪</b><b class='flag-5'>LSM6</b>DSV16X与AI集成(2)----姿态解算

    陀螺仪LSM6DSOW开发(1)----轮询获取陀螺仪数据

    本文将介绍如何使用 LSM6DSOW 传感器来读取数据。主要步骤包括初始化传感器接口、验证设备ID、配置传感器的数据输出率和滤波器,以及通过轮询方式持续读取加速度、角速率和温度数据。读取到的数据会被
    的头像 发表于 08-05 09:44 1014次阅读
    <b class='flag-5'>陀螺仪</b><b class='flag-5'>LSM6DSOW</b><b class='flag-5'>开发</b>(1)----轮询获取<b class='flag-5'>陀螺仪</b>数据

    陀螺仪LSM6DSOW开发(2)----上报匿名上位机实现可视化

    本文档详细介绍了如何使用匿名助手的上位机实现加速度计和陀螺仪数据的可视化显示。内容涵盖了加速度计和陀螺仪的工作原理、上位机通信协议、数据处理流程以及具体的代码实现。通过本文档,读者可以
    的头像 发表于 08-05 09:52 1024次阅读
    <b class='flag-5'>陀螺仪</b><b class='flag-5'>LSM6DSOW</b><b class='flag-5'>开发</b>(2)----上报匿名上位机实现可视化

    陀螺仪LSM6DSOW开发(3)----FIFO数据读取与配置

    本文档旨在详细介绍如何配置和读取LSM6DSOW传感器的FIFO数据。LSM6DSOW是一款高性能的6轴IMU(惯性测量单元),集成了三轴加速度计和三轴
    的头像 发表于 08-05 10:03 1080次阅读
    <b class='flag-5'>陀螺仪</b><b class='flag-5'>LSM6DSOW</b><b class='flag-5'>开发</b>(3)----FIFO数据读取与配置

    关于陀螺仪加速度传感器

    楼主新人,准备看看三轴的加速度传感器和陀螺仪,然后又看到了MPU-6050(整合了陀螺仪和三轴加速度传感器),想向大家请教一下加速度传感器和
    发表于 03-13 19:10

    请问为什么陀螺仪校准加速度计不需?

    我看了原子四轴的代码。发现上电后需要对陀螺仪数据进行统计,计算出样本方差和均值。陀螺仪的均值作为零偏。为何加速度计不需求方差验证?为何加速度计不需要修正零偏?
    发表于 07-04 04:35

    初识加速度计与陀螺仪

    如何认识这个加速度呢?加速度计的原理是什么?什么是陀螺仪
    发表于 09-28 08:50

    CTRL9_XL (18h) 用于加速度计和陀螺仪操作行得通吗?

    lsm6ds3tr寄存器的值中,CTRL9_XL (18h) 用于加速度计和陀螺仪操作行得通吗?
    发表于 12-06 08:19

    加速度陀螺仪测试上位机软件

    蓝宙电子加速度陀螺仪测试上位机软件蓝宙电子加速度陀螺仪测试上位机软件蓝宙电子加速度陀螺仪测试上位
    发表于 01-21 14:45 41次下载

    基于机器学习方法校准MPU6050陀螺仪加速度计(含完整源码)

    基于机器学习方法校准MCU6050陀螺仪加速度计(含源码)最近组装了一架无人机,想要自己写一个飞控,所以一直在研究陀螺仪,我使用的是目前最常用的MCU6050六轴运动传感器,如下图所示
    发表于 12-06 14:36 22次下载
    基于机器学习方法<b class='flag-5'>校准</b>MPU6050<b class='flag-5'>陀螺仪</b><b class='flag-5'>加速度</b>计(含完整源码)

    LSM6DSR 3D加速度计和3D陀螺仪应用笔记

    电子发烧友网站提供《LSM6DSR 3D加速度计和3D陀螺仪应用笔记.pdf》资料免费下载
    发表于 07-31 10:05 4次下载
    <b class='flag-5'>LSM6</b>DSR 3D<b class='flag-5'>加速度</b>计和3D<b class='flag-5'>陀螺仪</b>应用笔记

    LSM6DSO 3D数字加速度计和3D数字陀螺仪应用笔记

    电子发烧友网站提供《LSM6DSO 3D数字加速度计和3D数字陀螺仪应用笔记.pdf》资料免费下载
    发表于 07-31 10:27 0次下载
    <b class='flag-5'>LSM6</b>DSO 3D数字<b class='flag-5'>加速度</b>计和3D数字<b class='flag-5'>陀螺仪</b>应用笔记

    LSM6DSL 3D数字加速度计和3D数字陀螺仪应用笔记

    电子发烧友网站提供《LSM6DSL 3D数字加速度计和3D数字陀螺仪应用笔记.pdf》资料免费下载
    发表于 07-31 10:43 2次下载
    <b class='flag-5'>LSM6</b>DSL 3D数字<b class='flag-5'>加速度</b>计和3D数字<b class='flag-5'>陀螺仪</b>应用笔记

    LSM6DSM 3D加速度计和3D陀螺仪应用笔记

    电子发烧友网站提供《LSM6DSM 3D加速度计和3D陀螺仪应用笔记.pdf》资料免费下载
    发表于 07-31 10:19 2次下载
    <b class='flag-5'>LSM6</b>DSM 3D<b class='flag-5'>加速度</b>计和3D<b class='flag-5'>陀螺仪</b>应用笔记

    LSM6DS3:始终开启的3D加速度计和3D陀螺仪

    电子发烧友网站提供《LSM6DS3:始终开启的3D加速度计和3D陀螺仪.pdf》资料免费下载
    发表于 07-31 10:20 4次下载
    <b class='flag-5'>LSM6</b>DS3:始终开启的3D<b class='flag-5'>加速度</b>计和3D<b class='flag-5'>陀螺仪</b>