0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

陀螺儀LSM6DSOW開發(fā)(9)----加速度校準(zhǔn)

嵌入式單片機(jī)MCU開發(fā) ? 來源:嵌入式單片機(jī)MCU開發(fā) ? 作者:嵌入式單片機(jī)MCU開 ? 2024-08-23 10:07 ? 次閱讀

概述

MotionAC 是 STMicroelectronics 提供的一款用于加速度計(jì)校準(zhǔn)的中間件庫。該庫可以實(shí)時(shí)計(jì)算加速度計(jì)的偏移和比例因子,并對傳感器數(shù)據(jù)進(jìn)行補(bǔ)償,從而提高測量精度。
MotionAC 庫通過獲取加速度計(jì)的數(shù)據(jù),計(jì)算出偏移和比例因子校準(zhǔn)參數(shù),并應(yīng)用這些參數(shù)對原始數(shù)據(jù)進(jìn)行校正。校準(zhǔn)可以在動(dòng)態(tài)和靜態(tài)兩種模式下進(jìn)行。

需要樣片的可以加群申請:615061293 。

視頻教學(xué)

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

樣品申請

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

源碼下載

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

硬件準(zhǔn)備

首先需要準(zhǔn)備一個(gè)開發(fā)板,這里我準(zhǔn)備的是自己繪制的開發(fā)板,需要的可以進(jìn)行申請。 主控為STM32H503CB,陀螺儀為LSM6DSOW,磁力計(jì)為LIS2MDL。

校準(zhǔn)過程

2.2.6 節(jié)詳細(xì)描述了如何使用 MotionAC 庫進(jìn)行加速度計(jì)的校準(zhǔn)過程。該過程通過正常運(yùn)動(dòng)或特定姿態(tài)的設(shè)備來確定偏移和比例因子補(bǔ)償,以提高加速度計(jì)的測量精度。
初始位置:
● 將設(shè)備穩(wěn)固地握在起始位置(位置1)。
旋轉(zhuǎn)設(shè)備:
● 輕輕地將設(shè)備沿 YZ 平面旋轉(zhuǎn) 180°,使設(shè)備翻轉(zhuǎn)到其背面(位置4)。
● 然后再沿 XZ 平面順時(shí)針旋轉(zhuǎn) 180°,使設(shè)備返回到起始位置(位置1)。
平滑路徑:
● 試圖沿平滑路徑和恒定速度旋轉(zhuǎn)設(shè)備。
六點(diǎn)校準(zhǔn):
● 也可以執(zhí)行標(biāo)準(zhǔn)的六點(diǎn)校準(zhǔn),將模塊靜止在六個(gè)不同方向(+X, -X, +Y, -Y, +Z, -Z)上。

開啟CRC

串口設(shè)置

設(shè)置串口速率為2000000。

開啟X-CUBE-MEMS1

通過使用 MotionAC 庫,可以有效地對加速度計(jì)進(jìn)行校準(zhǔn),確保測量數(shù)據(jù)的準(zhǔn)確性。

速率選擇

MotionAC 支持從20 Hz到100 Hz的更新頻率。

AccelerometerCalibration

該應(yīng)用程序展示了如何使用由 STMicroelectronics 開發(fā)的 MotionAC 中間件庫與 X-NUCLEO-IKS01A3 擴(kuò)展板和 STM32 Nucleo 板上的 LSM6DSO 組件進(jìn)行加速度計(jì)校準(zhǔn)。應(yīng)用程序啟動(dòng)后,用戶可以使用由 STMicroelectronics 開發(fā)的 Unicleo-GUI 應(yīng)用程序查看數(shù)據(jù)。

變量定義

float acceleration_mg[3];
static MAC_knobs_t Knobs;

MotionAC文件

主要包含app_mems_motionac.c和app_mems_motionac.h,這兩個(gè)文件是用于配置和實(shí)現(xiàn)加速度計(jì)校準(zhǔn)功能的頭文件和源文件。它們使用了 MotionAC 庫,提供了必要的函數(shù)接口和實(shí)現(xiàn)來初始化、更新、獲取校準(zhǔn)參數(shù)和應(yīng)用校準(zhǔn)補(bǔ)償。

MX_AccelerometerCalibration_Init

MX_AccelerometerCalibration_Init 該函數(shù)初始化了加速度計(jì)校準(zhǔn)功能。以下是其具體流程和每個(gè)步驟的詳細(xì)解釋:

  1. 調(diào)用 MotionAC_manager_init(MAC_DISABLE_LIB) 禁用 MotionAC 庫。
  2. 調(diào)用 MotionAC_manager_init(MAC_ENABLE_LIB) 啟用 MotionAC 庫。
    1和2主要使用MotionAC_Initialize 函數(shù)用于初始化 MotionAC 引擎,根據(jù)傳入的參數(shù)決定啟用或禁用加速度計(jì)校準(zhǔn)庫。此函數(shù)是 MotionAC 庫的核心初始化函數(shù),通過設(shè)置內(nèi)部狀態(tài)和參數(shù)來準(zhǔn)備校準(zhǔn)功能。

  1. 調(diào)用 MotionAC_GetKnobs(&Knobs) 獲取當(dāng)前的校準(zhǔn)設(shè)置。
  2. 調(diào)用 MotionAC_SetKnobs(&Knobs) 將這些新的設(shè)置應(yīng)用到庫中。
  3. 調(diào)用 MotionAC_manager_get_version(LibVersion, &LibVersionLen) 獲取 MotionAC 庫的版本信息

AC_Data_Handler

AC_Data_Handler 函數(shù)的主要功能是處理加速度計(jì)數(shù)據(jù),通過 MotionAC 庫進(jìn)行校準(zhǔn),獲取并應(yīng)用校準(zhǔn)參數(shù),最終輸出校準(zhǔn)后的加速度數(shù)據(jù)和校準(zhǔn)質(zhì)量信息。

  1. MotionAC_manager_update 函數(shù)用于更新加速度計(jì)數(shù)據(jù),并運(yùn)行加速度計(jì)的校準(zhǔn)算法。這一過程包括接收新的加速度計(jì)數(shù)據(jù),執(zhí)行校準(zhǔn)計(jì)算,確定是否需要更新校準(zhǔn)參數(shù),并返回校準(zhǔn)狀態(tài)。
    1中主要執(zhí)行MotionAC_Update 函數(shù)用于運(yùn)行加速度計(jì)校準(zhǔn)算法。它接收輸入的加速度計(jì)數(shù)據(jù)和時(shí)間戳,計(jì)算校準(zhǔn)參數(shù),并返回當(dāng)前樣本是否完成校準(zhǔn)。

MotionAC_manager_get_params 函數(shù)用于獲取加速度計(jì)的校準(zhǔn)參數(shù),包括偏移值(Offset)和比例因子(Scale Factor)矩陣。這些參數(shù)是由校準(zhǔn)算法計(jì)算得到的,用于對原始加速度計(jì)數(shù)據(jù)進(jìn)行校正。
2.中主要執(zhí)行MotionAC_GetCalParams 函數(shù)用于檢索加速度計(jì)的校準(zhǔn)系數(shù),包括偏移和比例因子補(bǔ)償參數(shù),以及校準(zhǔn)質(zhì)量因子。該函數(shù)將這些參數(shù)填充到傳入的輸出結(jié)構(gòu)體中,以便調(diào)用者使用這些參數(shù)進(jìn)行校準(zhǔn)數(shù)據(jù)處理。
● MAC_CALQSTATUSUNKNOWN = 0:校準(zhǔn)參數(shù)的準(zhǔn)確性未知。
● MAC_CALQSTATUSPOOR = 1:校準(zhǔn)參數(shù)的準(zhǔn)確性較差,不可信。
● MAC_CALQSTATUSOK = 2:校準(zhǔn)參數(shù)的準(zhǔn)確性尚可。
● MAC_CALQSTATUSGOOD = 3:校準(zhǔn)參數(shù)的準(zhǔn)確性良好。

  1. MotionAC_manager_compensate 函數(shù)用于對原始加速度計(jì)數(shù)據(jù)進(jìn)行補(bǔ)償,即應(yīng)用先前計(jì)算得到的校準(zhǔn)參數(shù)(偏移值和比例因子矩陣)來校正加速度計(jì)數(shù)據(jù)。這個(gè)過程是為了消除加速度計(jì)在測量中的系統(tǒng)誤差,提高數(shù)據(jù)的準(zhǔn)確性。

初始化定義

/* 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 */

六位置法的標(biāo)定方案

本文在校準(zhǔn)三軸加速度計(jì)時(shí)使用六位置校準(zhǔn)法,該方法使用地球的重力力加速度在靜態(tài)下校準(zhǔn)三軸加速度傳感器,具體的校準(zhǔn)過程如下圖所示。具體校準(zhǔn)過程如下:

  1. 將傳感器的Y軸垂直水平面向下;
  2. 以X軸為基準(zhǔn)軸,繞其逆旋轉(zhuǎn)90°,使乙軸垂直水平面向上
  3. 以Y軸為基準(zhǔn)軸,繞其逆旋轉(zhuǎn)90°,使X軸垂直水平面向下
  4. 以Y軸為基準(zhǔn)軸,繞其逆時(shí)針旋轉(zhuǎn)90°使2軸垂直水平面向下
  5. 繞Y軸逆時(shí)針旋轉(zhuǎn)909、使X軸垂直水平面向上
  6. 繞Z軸順時(shí)針旋轉(zhuǎn)90°、使Y軸垂直水平面向上

在沒有精密設(shè)備的情況下。這種方法基本上是在試圖找到每個(gè)軸的偏移(zero-g offset)和靈敏度(scale factor)。這種方法通常稱為靜態(tài)校準(zhǔn)方法,因?yàn)樗恍枰獎(jiǎng)討B(tài)輸入,只需將設(shè)備置于靜態(tài)的已知方向即可。

主函數(shù)

/* 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 */

演示

在未執(zhí)行六位置校準(zhǔn)法時(shí),Calibration不為3。

X軸向下。

X軸向上。

Y軸向下。

Y軸向上。

Z軸向下。

Z軸向上。

校準(zhǔn)完畢Calibration=3

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 傳感器
    +關(guān)注

    關(guān)注

    2551

    文章

    51084

    瀏覽量

    753403
  • 陀螺儀
    +關(guān)注

    關(guān)注

    44

    文章

    784

    瀏覽量

    98698
  • 加速度計(jì)
    +關(guān)注

    關(guān)注

    6

    文章

    702

    瀏覽量

    45897
收藏 人收藏

    評論

    相關(guān)推薦

    陀螺儀LSM6DSV16X與AI集成(2)----姿態(tài)解算

    LSM6DSV16X包含三軸陀螺儀與三軸加速度計(jì)。
    的頭像 發(fā)表于 12-18 10:51 ?2229次閱讀
    <b class='flag-5'>陀螺儀</b><b class='flag-5'>LSM6</b>DSV16X與AI集成(2)----姿態(tài)解算

    陀螺儀LSM6DSOW開發(fā)(1)----輪詢獲取陀螺儀數(shù)據(jù)

    本文將介紹如何使用 LSM6DSOW 傳感器來讀取數(shù)據(jù)。主要步驟包括初始化傳感器接口、驗(yàn)證設(shè)備ID、配置傳感器的數(shù)據(jù)輸出率和濾波器,以及通過輪詢方式持續(xù)讀取加速度、角速率和溫度數(shù)據(jù)。讀取到的數(shù)據(jù)會(huì)被
    的頭像 發(fā)表于 08-05 09:44 ?1574次閱讀
    <b class='flag-5'>陀螺儀</b><b class='flag-5'>LSM6DSOW</b><b class='flag-5'>開發(fā)</b>(1)----輪詢獲取<b class='flag-5'>陀螺儀</b>數(shù)據(jù)

    陀螺儀LSM6DSOW開發(fā)(2)----上報(bào)匿名上位機(jī)實(shí)現(xiàn)可視化

    本文檔詳細(xì)介紹了如何使用匿名助手的上位機(jī)實(shí)現(xiàn)加速度計(jì)和陀螺儀數(shù)據(jù)的可視化顯示。內(nèi)容涵蓋了加速度計(jì)和陀螺儀的工作原理、上位機(jī)通信協(xié)議、數(shù)據(jù)處理流程以及具體的代碼實(shí)現(xiàn)。通過本文檔,讀者可以
    的頭像 發(fā)表于 08-05 09:52 ?1468次閱讀
    <b class='flag-5'>陀螺儀</b><b class='flag-5'>LSM6DSOW</b><b class='flag-5'>開發(fā)</b>(2)----上報(bào)匿名上位機(jī)實(shí)現(xiàn)可視化

    陀螺儀LSM6DSOW開發(fā)(3)----FIFO數(shù)據(jù)讀取與配置

    本文檔旨在詳細(xì)介紹如何配置和讀取LSM6DSOW傳感器的FIFO數(shù)據(jù)。LSM6DSOW是一款高性能的6軸IMU(慣性測量單元),集成了三軸加速度計(jì)和三軸
    的頭像 發(fā)表于 08-05 10:03 ?1730次閱讀
    <b class='flag-5'>陀螺儀</b><b class='flag-5'>LSM6DSOW</b><b class='flag-5'>開發(fā)</b>(3)----FIFO數(shù)據(jù)讀取與配置

    關(guān)于陀螺儀加速度傳感器

    樓主新人,準(zhǔn)備看看三軸的加速度傳感器和陀螺儀,然后又看到了MPU-6050(整合了陀螺儀和三軸加速度傳感器),想向大家請教一下加速度傳感器和
    發(fā)表于 03-13 19:10

    請問為什么陀螺儀校準(zhǔn)加速度計(jì)不需?

    我看了原子四軸的代碼。發(fā)現(xiàn)上電后需要對陀螺儀數(shù)據(jù)進(jìn)行統(tǒng)計(jì),計(jì)算出樣本方差和均值。陀螺儀的均值作為零偏。為何加速度計(jì)不需求方差驗(yàn)證?為何加速度計(jì)不需要修正零偏?
    發(fā)表于 07-04 04:35

    初識加速度計(jì)與陀螺儀

    如何認(rèn)識這個(gè)加速度呢?加速度計(jì)的原理是什么?什么是陀螺儀?
    發(fā)表于 09-28 08:50

    CTRL9_XL (18h) 用于加速度計(jì)和陀螺儀操作行得通嗎?

    lsm6ds3tr寄存器的值中,CTRL9_XL (18h) 用于加速度計(jì)和陀螺儀操作行得通嗎?
    發(fā)表于 12-06 08:19

    加速度陀螺儀測試上位機(jī)軟件

    藍(lán)宙電子加速度陀螺儀測試上位機(jī)軟件藍(lán)宙電子加速度陀螺儀測試上位機(jī)軟件藍(lán)宙電子加速度陀螺儀測試上位
    發(fā)表于 01-21 14:45 ?41次下載

    基于機(jī)器學(xué)習(xí)方法校準(zhǔn)MPU6050陀螺儀加速度計(jì)(含完整源碼)

    基于機(jī)器學(xué)習(xí)方法校準(zhǔn)MCU6050陀螺儀加速度計(jì)(含源碼)最近組裝了一架無人機(jī),想要自己寫一個(gè)飛控,所以一直在研究陀螺儀,我使用的是目前最常用的MCU6050六軸運(yùn)動(dòng)傳感器,如下圖所示
    發(fā)表于 12-06 14:36 ?22次下載
    基于機(jī)器學(xué)習(xí)方法<b class='flag-5'>校準(zhǔn)</b>MPU6050<b class='flag-5'>陀螺儀</b><b class='flag-5'>加速度</b>計(jì)(含完整源碼)

    LSM6DSR 3D加速度計(jì)和3D陀螺儀應(yīng)用筆記

    電子發(fā)燒友網(wǎng)站提供《LSM6DSR 3D加速度計(jì)和3D陀螺儀應(yīng)用筆記.pdf》資料免費(fèi)下載
    發(fā)表于 07-31 10:05 ?5次下載
    <b class='flag-5'>LSM6</b>DSR 3D<b class='flag-5'>加速度</b>計(jì)和3D<b class='flag-5'>陀螺儀</b>應(yīng)用筆記

    LSM6DSO 3D數(shù)字加速度計(jì)和3D數(shù)字陀螺儀應(yīng)用筆記

    電子發(fā)燒友網(wǎng)站提供《LSM6DSO 3D數(shù)字加速度計(jì)和3D數(shù)字陀螺儀應(yīng)用筆記.pdf》資料免費(fèi)下載
    發(fā)表于 07-31 10:27 ?0次下載
    <b class='flag-5'>LSM6</b>DSO 3D數(shù)字<b class='flag-5'>加速度</b>計(jì)和3D數(shù)字<b class='flag-5'>陀螺儀</b>應(yīng)用筆記

    LSM6DSL 3D數(shù)字加速度計(jì)和3D數(shù)字陀螺儀應(yīng)用筆記

    電子發(fā)燒友網(wǎng)站提供《LSM6DSL 3D數(shù)字加速度計(jì)和3D數(shù)字陀螺儀應(yīng)用筆記.pdf》資料免費(fèi)下載
    發(fā)表于 07-31 10:43 ?2次下載
    <b class='flag-5'>LSM6</b>DSL 3D數(shù)字<b class='flag-5'>加速度</b>計(jì)和3D數(shù)字<b class='flag-5'>陀螺儀</b>應(yīng)用筆記

    LSM6DSM 3D加速度計(jì)和3D陀螺儀應(yīng)用筆記

    電子發(fā)燒友網(wǎng)站提供《LSM6DSM 3D加速度計(jì)和3D陀螺儀應(yīng)用筆記.pdf》資料免費(fèi)下載
    發(fā)表于 07-31 10:19 ?2次下載
    <b class='flag-5'>LSM6</b>DSM 3D<b class='flag-5'>加速度</b>計(jì)和3D<b class='flag-5'>陀螺儀</b>應(yīng)用筆記

    LSM6DS3:始終開啟的3D加速度計(jì)和3D陀螺儀

    電子發(fā)燒友網(wǎng)站提供《LSM6DS3:始終開啟的3D加速度計(jì)和3D陀螺儀.pdf》資料免費(fèi)下載
    發(fā)表于 07-31 10:20 ?4次下載
    <b class='flag-5'>LSM6</b>DS3:始終開啟的3D<b class='flag-5'>加速度</b>計(jì)和3D<b class='flag-5'>陀螺儀</b>