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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

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

驅(qū)動LSM6DS3TR-C實現(xiàn)高效運動檢測與數(shù)據(jù)采集(12)----加速度校準

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

概述

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

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

視頻教學

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

樣品申請

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

源碼下載

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

硬件準備

首先需要準備一個開發(fā)板,這里我準備的是自己繪制的開發(fā)板,需要的可以進行申請。

主控為STM32H503CB,陀螺儀為LSM6DS3TR-C,磁力計為LIS2MDL。

校準過程

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

開啟CRC

串口設置

設置串口速率為2000000。

開啟X-CUBE-MEMS1

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

速率選擇

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

AccelerometerCalibration

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

變量定義

float acceleration_mg[3];
static MAC_knobs_t Knobs;

MotionAC文件

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

MX_AccelerometerCalibration_Init

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

  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ù)決定啟用或禁用加速度計校準庫。此函數(shù)是 MotionAC 庫的核心初始化函數(shù),通過設置內(nèi)部狀態(tài)和參數(shù)來準備校準功能。

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

AC_Data_Handler

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

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

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

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

初始化定義

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


  /* Initialize mems driver interface */
  stmdev_ctx_t dev_ctx;
  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 */
  whoamI = 0;
  lsm6ds3tr_c_device_id_get(&dev_ctx, &whoamI);
    printf("LSM6DS3TR-C_ID=0x%x,whoamI=0x%x",LSM6DS3TR_C_ID,whoamI);
  if ( whoamI != LSM6DS3TR_C_ID )
    while (1); /*manage here device not found */

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

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



  /* Enable Block Data Update */
  lsm6ds3tr_c_block_data_update_set(&dev_ctx, PROPERTY_ENABLE);
  /* Set Output Data Rate */
  lsm6ds3tr_c_xl_data_rate_set(&dev_ctx, LSM6DS3TR_C_XL_ODR_52Hz);
  lsm6ds3tr_c_gy_data_rate_set(&dev_ctx, LSM6DS3TR_C_GY_ODR_52Hz);
  /* Set full scale */
  lsm6ds3tr_c_xl_full_scale_set(&dev_ctx, LSM6DS3TR_C_2g);
  lsm6ds3tr_c_gy_full_scale_set(&dev_ctx, LSM6DS3TR_C_2000dps);
  /* Configure filtering chain(No aux interface) */
  /* Accelerometer - analog filter */
//  lsm6ds3tr_c_xl_filter_analog_set(&dev_ctx,
//                                   LSM6DS3TR_C_XL_ANA_BW_400Hz);
  /* Accelerometer - LPF1 path ( LPF2 not used )*/
  //lsm6ds3tr_c_xl_lp1_bandwidth_set(&dev_ctx, LSM6DS3TR_C_XL_LP1_ODR_DIV_4);
  /* Accelerometer - LPF1 + LPF2 path */
//  lsm6ds3tr_c_xl_lp2_bandwidth_set(&dev_ctx,
//                                   LSM6DS3TR_C_XL_LOW_NOISE_LP_ODR_DIV_100);
  /* Accelerometer - High Pass / Slope path */
  //lsm6ds3tr_c_xl_reference_mode_set(&dev_ctx, PROPERTY_DISABLE);
  //lsm6ds3tr_c_xl_hp_bandwidth_set(&dev_ctx, LSM6DS3TR_C_XL_HP_ODR_DIV_100);
  /* Gyroscope - filtering chain */
//  lsm6ds3tr_c_gy_band_pass_set(&dev_ctx,
//                               LSM6DS3TR_C_HP_260mHz_LP1_STRONG);



    MX_AccelerometerCalibration_Init();
  /* USER CODE END 2 */

六位置法的標定方案

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

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

在沒有精密設備的情況下。這種方法基本上是在試圖找到每個軸的偏移(zero-g offset)和靈敏度(scale factor)。這種方法通常稱為靜態(tài)校準方法,因為它不需要動態(tài)輸入,只需將設備置于靜態(tài)的已知方向即可。

主函數(shù)

/* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
    /* Read output only if new value is available */
    lsm6ds3tr_c_reg_t reg;
    lsm6ds3tr_c_status_reg_get(&dev_ctx, ®.status_reg);

    if (reg.status_reg.xlda) {
      /* Read magnetic field data */
      memset(data_raw_acceleration, 0x00, 3 * sizeof(int16_t));
      lsm6ds3tr_c_acceleration_raw_get(&dev_ctx,
                                       data_raw_acceleration);
      acceleration_mg[0] = lsm6ds3tr_c_from_fs2g_to_mg(
                             data_raw_acceleration[0]);
      acceleration_mg[1] = lsm6ds3tr_c_from_fs2g_to_mg(
                             data_raw_acceleration[1]);
      acceleration_mg[2] = lsm6ds3tr_c_from_fs2g_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();
    }

//    if (reg.status_reg.gda) {
//      /* Read magnetic field data */
//      memset(data_raw_angular_rate, 0x00, 3 * sizeof(int16_t));
//      lsm6ds3tr_c_angular_rate_raw_get(&dev_ctx,
//                                       data_raw_angular_rate);
//      angular_rate_mdps[0] = lsm6ds3tr_c_from_fs2000dps_to_mdps(
//                               data_raw_angular_rate[0]);
//      angular_rate_mdps[1] = lsm6ds3tr_c_from_fs2000dps_to_mdps(
//                               data_raw_angular_rate[1]);
//      angular_rate_mdps[2] = lsm6ds3tr_c_from_fs2000dps_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]);
//    }

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

//    }


    /* USER CODE END WHILE */

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

演示

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

X軸向下。

X軸向上。

Y軸向下。

Y軸向上。

Z軸向下。

Z軸向上。

校準完畢Calibration=3

審核編輯 黃宇

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

    評論

    相關推薦

    驅(qū)動LSM6DS3TR-C實現(xiàn)高效運動檢測數(shù)據(jù)采集(1)----獲取ID

    本文將介紹如何驅(qū)動和利用LSM6DS3TR-C傳感器,實現(xiàn)精確的運動感應功能。LSM6DS3TR-C是一款先進的
    的頭像 發(fā)表于 11-13 15:45 ?1903次閱讀
    <b class='flag-5'>驅(qū)動</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>高效</b><b class='flag-5'>運動檢測</b>與<b class='flag-5'>數(shù)據(jù)采集</b>(1)----獲取ID

    驅(qū)動LSM6DS3TR-C實現(xiàn)高效運動檢測數(shù)據(jù)采集(6)----FIFO數(shù)據(jù)讀取與配置

    LSM6DS3TR-C是STMicroelectronics公司推出的iNEMO慣性模塊,集成了三軸加速度計和三軸陀螺儀,具備低功耗、強大的運動檢測功能。該傳感器支持多種操作模式,并內(nèi)置FIFO
    的頭像 發(fā)表于 07-18 10:58 ?976次閱讀
    <b class='flag-5'>驅(qū)動</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>高效</b><b class='flag-5'>運動檢測</b>與<b class='flag-5'>數(shù)據(jù)采集</b>(<b class='flag-5'>6</b>)----FIFO<b class='flag-5'>數(shù)據(jù)</b>讀取與配置

    lsm6ds3tr-c傳感器集合模式無法使用的原因?

    );/*讀取外掛磁力計代碼*///禁用I2C直通,禁用內(nèi)部上拉,禁用I2Cbsp_spi_write(LSM6DS3TR_MASTER_CONFIG, 0x00, 2);//關閉加速度
    發(fā)表于 03-07 06:26

    LSM6DS3TR-C使用時工作電流比datasheet上大很多是什么原因?

    使用場景是LSM6DS3TR-C通過SPI一拖四連接單片機,一共有四路這樣的一拖四。 測試時發(fā)現(xiàn)電流很大,感覺有點不對,編寫程序使LSM6DS3TR-C間隔5s一個一個使能,會發(fā)現(xiàn)穩(wěn)壓源的輸出電流從
    發(fā)表于 03-07 08:08

    請問LSM6DS3TRLSM6DS3TR-C兩個型號能否完全兼容?

    LSM6DS3TR停產(chǎn)買不到了,準備切換LSM6DS3TR-C型號使用。 請問兩者有什么差別?能否直接替換?有成功替換案例嗎?
    發(fā)表于 03-14 06:40

    LSM6DS3TR-C數(shù)據(jù)讀取異常是安利的問題?怎么處理?

    我在使用lsm6ds3tr-c 6軸傳感器時發(fā)現(xiàn),讀取的溫度以及角速度值異常,配置為官方lsm6ds3tr_c_read_data_polling.c文件中
    發(fā)表于 03-19 08:15

    LSM6DS3TR-C長時間讀取后角速度輸出為0是什么原因造成的?

    LSM6DS3TR-C 長時間讀取后角速度輸出為0
    發(fā)表于 03-20 06:28

    LSM6DS3TR-C速度輸出為0是什么原因?qū)е碌模?/a>

    LSM6DS3TR-C在長時間休眠后(6小時以上),角速度輸出為0,短時間休眠輸出正常,這是什么問題?
    發(fā)表于 03-21 06:27

    LSM6DS3TR-C的低功耗模式和高性能模式有什么區(qū)別

    如果我只在 12.5Hz 下操作加速度計,LSM6DS3TR-C 的低功耗模式和高性能模式有什么區(qū)別?
    發(fā)表于 12-09 06:47

    傳感器——LSM6DS3 加速度計 陀螺儀

    品牌:ST型號:LSM6DS3TR-C批號:2023+封裝:LGA-14數(shù)量:20000制造商:STmicroelectronics產(chǎn)品種類:IMU-慣性測量單元系列:LSM6DS3TR-C商標
    發(fā)表于 03-23 15:03

    LSM6DS3的應用筆記

    專門設計,可在硬件上實現(xiàn)大幅運動檢測、傾斜度檢測、硬件計步功能、時間戳,并支持對外部磁力計的數(shù)據(jù)采集,且支持鐵磁校準 (硬鐵修正,軟鐵修正)
    發(fā)表于 09-13 08:23

    驅(qū)動LSM6DS3TR-C實現(xiàn)高效運動檢測數(shù)據(jù)采集(2)----配置濾波器

    LSM6DS3TR-C中,加速度計和陀螺儀可以獨立地開啟/關閉,并且可以擁有不同的ODR和功耗模式。 LSM6DS3TR-C有三種可用的操作模式: ● 僅加速度計活動,陀螺儀處于
    的頭像 發(fā)表于 11-14 09:45 ?849次閱讀
    <b class='flag-5'>驅(qū)動</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>高效</b><b class='flag-5'>運動檢測</b>與<b class='flag-5'>數(shù)據(jù)采集</b>(2)----配置濾波器

    驅(qū)動LSM6DS3TR-C實現(xiàn)高效運動檢測數(shù)據(jù)采集(3)----獲取傳感器數(shù)據(jù)

    一旦傳感器被正確初始化,可以通過SPI或I2C接口向傳感器發(fā)送讀取命令,并接收傳感器返回的數(shù)據(jù)。這個讀取過程包括獲取LSM6DS3TR傳感器提供的加速度計和陀螺儀
    的頭像 發(fā)表于 11-14 09:59 ?696次閱讀
    <b class='flag-5'>驅(qū)動</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>高效</b><b class='flag-5'>運動檢測</b>與<b class='flag-5'>數(shù)據(jù)采集</b>(<b class='flag-5'>3</b>)----獲取傳感器<b class='flag-5'>數(shù)據(jù)</b>

    驅(qū)動LSM6DS3TR-C實現(xiàn)高效運動檢測數(shù)據(jù)采集(4)----上報匿名上位機實現(xiàn)可視化

    LSM6DS3TR-C是單芯片“3軸陀螺儀 + 3加速度計”的慣性 測量單元(IMU), 五種種可選滿量程的陀螺儀(125/250/500/1000/2000 dps)和
    的頭像 發(fā)表于 11-14 10:05 ?743次閱讀
    <b class='flag-5'>驅(qū)動</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>高效</b><b class='flag-5'>運動檢測</b>與<b class='flag-5'>數(shù)據(jù)采集</b>(4)----上報匿名上位機<b class='flag-5'>實現(xiàn)</b>可視化

    驅(qū)動LSM6DS3TR-C實現(xiàn)高效運動檢測數(shù)據(jù)采集(5)----姿態(tài)解算

    lsm6ds3trc包含三軸陀螺儀與三軸加速度計。 姿態(tài)有多種數(shù)學表示方式,常見的是四元數(shù),歐拉角,矩陣和軸角。他們各自有其自身的優(yōu)點,在不同的領域使用不同的表示方式。在四軸飛行器中使用到了四元數(shù)
    的頭像 發(fā)表于 11-14 10:11 ?699次閱讀
    <b class='flag-5'>驅(qū)動</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>高效</b><b class='flag-5'>運動檢測</b>與<b class='flag-5'>數(shù)據(jù)采集</b>(5)----姿態(tài)解算