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

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

3天內不再提示

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

嵌入式單片機MCU開發(fā) ? 來源: 嵌入式單片機MCU開發(fā) ? 作者: 嵌入式單片機MC ? 2023-11-14 10:05 ? 次閱讀

概述

LSM6DS3TR-C是單芯片“3軸陀螺儀 + 3軸加速度計”的慣性 測量單元(IMU), 五種種可選滿量程的陀螺儀(125/250/500/1000/2000 dps)和加速度計(2/4/8/16 g)。

上述工程中選擇的加速度和陀螺儀對應的量程為2g和2000dps,對應的靈敏度如下所示,分別為0.061mg/LSB和70mdps/LSB。

最近在弄ST和瑞薩RA的課程,需要樣片的可以加群申請:615061293 。

視頻教學

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

樣品申請

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

完整代碼下載

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

參考坐標系

測量加速度

LSM6DS3TR-C有一個片上加速度計,可以在 ±2g、±4g、±8g 和 ±16g 四個可編程滿量程范圍內測量加速度。

測量角速度

MPU6050 有一個片上陀螺儀,可以在 ±125°/s ±250°/s、±500°/s、±1000°/s 和 ±2000°/s 的四個可編程滿量程范圍內測量角度旋轉。

加速度計工作方式

假設立方體在外太空,那里的一切都是失重的,球會簡單地漂浮在立方體的中心。

現(xiàn)在,假設每面墻代表一個特定的軸。 如果我們突然以 1g 的加速度向左移動盒子(單個 G 力 1g 相當于重力加速度 9.8 m/s 2),球無疑會撞到墻壁 X。如果我們測量球對墻壁施加的力X,我們可以得到沿X軸的輸出值為1g。

讓我們看看當我們把那個立方體放在地球上時會發(fā)生什么。球將簡單地落在墻 Z 上,施加 1g 的力,如下圖所示:

在這種情況下,盒子沒有移動,但我們仍然在 Z 軸上得到 1g 的讀數(shù)。這是因為重力(實際上是加速度的一種形式)以 1g 的力向下拉球。

雖然此模型并不完全代表真實世界的加速度計傳感器是如何構建的,但它通常有助于理解為什么加速度計的輸出信號通常以 ±g 為單位指定,或者為什么加速度計在靜止時在 z 軸上讀數(shù)為 1g,或者您可以在不同方向上獲得什么樣的加速度計讀數(shù)。

上位機通訊

這里使用的是匿名助手的上位機

[https://gitee.com/anotc/AnoAssistant]

有專門的通訊協(xié)議

串口通訊協(xié)議格式如下所示,需要注意傳輸為小端模式傳輸。

對應的源地址和目標地址分別為0xFD和0xFE。

我們只需要上報加速度和陀螺儀數(shù)據(jù),所以功能碼為0x01,數(shù)據(jù)長度為0x0D,需要主要為小端模式傳輸。

加速度演示

實測移動模塊分別為X、Y、Z軸向下,可以看見數(shù)值基本上為1000mg。

陀螺儀工作方式

加速度計測量線性加速度,而陀螺儀測量角旋轉。為此,他們測量了科里奧利效應產(chǎn)生的力。

陀螺儀是一種運動傳感器,能夠感測物體在一軸或多軸上的旋轉角速度。它能夠精確地感測自由空間中復雜的移動動作,因此成為追蹤物體移動方位和旋轉動作的必要設備。與加速計電子羅盤不同,陀螺儀不需要依賴外部力量(如重力或磁場),可以自主地發(fā)揮其功能。

因此,從理論上講,只使用陀螺儀就可以完成姿態(tài)導航的任務。

陀螺儀的每個通道檢測一個軸的旋轉。也就是說陀螺儀通過測量自身的旋轉狀態(tài),判斷出設備當前運動狀態(tài),是向前、向后、向上、向下、向左還是向右呢,是加速(角速度)還是減速(角速度)呢,都可以實現(xiàn),但是要判斷出設備的方位(東西南北),陀螺儀就沒有辦法。

MEMS陀螺儀主要利用科里奧利力(旋轉物體在有徑向運動時所受到的切向力)原理,公開的微機械陀螺儀均采用振動物體傳感角速度的概念,利用振動來誘導和探測科里奧利力。

MEMS陀螺儀的核心是一個微加工機械單元,在設計上按照一個音叉機制共振運動,通過科里奧利力原理把角速率轉換成一個特定感測結構的位移。

兩個相同的質量塊以方向相反的做水平震蕩。當外部施加一個角速率,就會出現(xiàn)一個科氏力,力的方向垂直于質量運動方向,如垂直方向箭頭所示。產(chǎn)生的科氏力使感測質量發(fā)生位移,位移大小與所施加的角速率大小成正比,科氏力引起的電容變化即可計算出角速率大小。 科里奧利效應指出,當質量 (m) 以速度 (v) 沿特定方向移動并施加外部角速率 (Ω)(紅色箭頭)時,科里奧利效應會產(chǎn)生一個力(黃色箭頭),導致質量垂直移動。該位移的值與應用的角速率直接相關。

上報源碼

/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
  /* USER CODE BEGIN 1 */

  /* USER CODE END 1 */

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();

  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();

  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
  MX_I2C1_Init();
  MX_USART1_UART_Init();
  /* USER CODE BEGIN 2 */
    printf("hello");


      if (LSM6DS3TRC_Init(LSM6DS3TRC_MODE_I2C) == false)
    printf("LSM6DS3TRC initialize error.rn");
  else
    printf("LSM6DS3TRC initialize register finished.rn");
        int16_t    acc_int16[3]    ={0,0,0};
        int16_t    gyr_int16[3]        ={0,0,0};    
        float acc[3] = {0};
        float gyr[3] = {0};
        uint8_t data[21]={0};
        data[0]=0xAB;//幀頭
        data[1]=0xFD;//源地址
        data[2]=0xFE;//目標地址        
        data[3]=0x01;//功能碼ID    
        data[4]=0x0D;//數(shù)據(jù)長度LEN
        data[5]=0x00;//數(shù)據(jù)長度LEN 13

uint8_t sumcheck = 0;
uint8_t addcheck = 0;

  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {    
    uint8_t status;
    status = LSM6DS3TRC_Get_Status();

    if (status & LSM6DS3TRC_STATUS_ACCELEROMETER)
    {

      LSM6DS3TRC_Get_Acceleration(LSM6DS3TRC_ACC_FSXL_2G, acc);
//      printf("rnacc:X:%2f,tY:%2f,tZ:%2fr", acc[0], acc[1], acc[2]);
    }
    if (status & LSM6DS3TRC_STATUS_GYROSCOPE)
    {

      LSM6DS3TRC_Get_Gyroscope(LSM6DS3TRC_GYR_FSG_2000, gyr);
//      printf("rgyr:X:%4.2f,tY:%4.2f,tZ:%4.2fr", gyr[0], gyr[1], gyr[2]);
    }
    if (status & LSM6DS3TRC_STATUS_TEMPERATURE)
    {
//      printf("rtemp:%2frn", LSM6DS3TRC_Get_Temperature());
    }

        //匿名上位機
        acc_int16[0]=(int16_t)(acc[0]);
        acc_int16[1]=(int16_t)(acc[1]);        
        acc_int16[2]=(int16_t)(acc[2]);    

        gyr_int16[0]=(int16_t)(gyr[0])/1000;        
        gyr_int16[1]=(int16_t)(gyr[1])/1000;    
        gyr_int16[2]=(int16_t)(gyr[2])/1000;    

        data[7]=acc_int16[0] >>8;//ACC_X
        data[6]=acc_int16[0];
        data[9]=acc_int16[1] >>8;//ACC_Y
        data[8]=acc_int16[1];
        data[11]=acc_int16[2] >>8;//ACC_Z
        data[10]=acc_int16[2];

        data[13]=gyr_int16[0] >>8;//GYR_X 
        data[12]=gyr_int16[0];        
        data[15]=gyr_int16[1] >>8;//GYR_Y 
        data[14]=gyr_int16[1];            
        data[17]=gyr_int16[2] >>8;//GYR_Z 
        data[16]=gyr_int16[2];    

        data[18]=0;    

sumcheck = 0;
addcheck = 0;
for(uint16_t i=0; i < 19; i++)
{
sumcheck += data[i]; //從幀頭開始,對每一字節(jié)進行求和,直到 DATA 區(qū)結束
addcheck += sumcheck; //每一字節(jié)的求和操作,進行一次 sumcheck 的累加
}
data[19]=sumcheck;
data[20]=addcheck;

    HAL_UART_Transmit(&huart1 , (uint8_t *)&data, 21, 0xFFFF);
//        printf("naccx=%d    accy=%d    accz=%d    gyrx=%d    gyry=%d    gyrx=%d    ",acc_int16[0],acc_int16[1],acc_int16[2],gyr_int16[0],gyr_int16[1],gyr_int16[2]);        
    HAL_Delay(100);        
    /* USER CODE END WHILE */

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

審核編輯 黃宇

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

    關注

    129

    文章

    3949

    瀏覽量

    190838
  • 陀螺儀
    +關注

    關注

    44

    文章

    787

    瀏覽量

    98814
  • 數(shù)據(jù)采集

    關注

    39

    文章

    6192

    瀏覽量

    113820
  • 上位機
    +關注

    關注

    27

    文章

    944

    瀏覽量

    54903
  • 運動檢測
    +關注

    關注

    0

    文章

    34

    瀏覽量

    12627
收藏 人收藏

    評論

    相關推薦

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

    本文將介紹如何驅動和利用LSM6DS3TR-C傳感器,實現(xiàn)精確的運動感應功能。LSM6DS3TR-C是一款先進的
    的頭像 發(fā)表于 11-13 15:45 ?2327次閱讀
    <b class='flag-5'>驅動</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

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

    LSM6DS3TR-C是STMicroelectronics公司推出的iNEMO慣性模塊,集成了三軸加速度計和三軸陀螺儀,具備低功耗、強大的運動檢測功能。該傳感器支持多種操作模式,并內置FIFO
    的頭像 發(fā)表于 07-18 10:58 ?1678次閱讀
    <b class='flag-5'>驅動</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>讀取與配置

    陀螺儀LSM6DSOW開發(fā)(2)----上報匿名上位實現(xiàn)可視化

    本文檔詳細介紹了如何使用匿名助手的上位實現(xiàn)加速度計和陀螺儀數(shù)據(jù)可視化顯示。內容涵蓋了加速度計
    的頭像 發(fā)表于 08-05 09:52 ?1523次閱讀
    陀螺儀<b class='flag-5'>LSM6</b>DSOW開發(fā)(2)----<b class='flag-5'>上報</b><b class='flag-5'>匿名</b><b class='flag-5'>上位</b><b class='flag-5'>機</b><b class='flag-5'>實現(xiàn)</b><b class='flag-5'>可視化</b>

    陀螺儀LSM6DSV16X與AI集成(14)----上報匿名上位

    本文介紹了如何將 LSM6DSV16X 傳感器的姿態(tài)數(shù)據(jù)通過匿名通信協(xié)議上報到上位。通過獲取傳感器的四元數(shù)
    的頭像 發(fā)表于 11-25 11:53 ?741次閱讀
    陀螺儀<b class='flag-5'>LSM6</b>DSV16X與AI集成(14)----<b class='flag-5'>上報</b><b class='flag-5'>匿名</b><b class='flag-5'>上位</b><b class='flag-5'>機</b>

    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是什么原因導致的?

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

    LSM6DS3TR-C的FIFO讀取數(shù)據(jù)出錯是什么原因造成的?怎么解決?

    使用LSM6DS3TR-C的FIFO,先獲取了FIFO的WaterM標志,該標志置位之后再去獲取當前存在FIFO緩存的數(shù)據(jù)長度,再去讀取FIFO中對應長度的數(shù)據(jù),會出現(xiàn)讀取數(shù)據(jù)出錯的現(xiàn)
    發(fā)表于 03-27 06:05

    請問LSM6DS3TR-C有沒有windows下的測試工具?

    LSM6DS3TR-C有沒有windows下的測試工具
    發(fā)表于 05-20 06:22

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

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

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

    LSM6DS3TR-C中,加速度計和陀螺儀可以獨立地開啟/關閉,并且可以擁有不同的ODR和功耗模式。 LSM6DS3TR-C有三種可用的操作模式: ● 僅加速度計活動,陀螺儀處于斷電狀態(tài) ● 僅陀螺儀活動,加速度計處于斷電狀態(tài) ● 加速度計和陀螺儀傳感器同時活動
    的頭像 發(fā)表于 11-14 09:45 ?1130次閱讀
    <b class='flag-5'>驅動</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)----配置濾波器

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

    一旦傳感器被正確初始,可以通過SPI或I2C接口向傳感器發(fā)送讀取命令,并接收傳感器返回的數(shù)據(jù)。這個讀取過程包括獲取LSM6DS3TR傳感器提供的加速度計和陀螺儀
    的頭像 發(fā)表于 11-14 09:59 ?916次閱讀
    <b class='flag-5'>驅動</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>

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

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