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

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

3天内不再提示

驱动LSM6DS3TR-C实现高效运动检测与数据采集(4)----上报匿名上位机实现可视化

嵌入式单片机MCU开发 来源: 嵌入式单片机MCU开发 作者: 嵌入式单片机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 的四个可编程满量程范围内测量角度旋转。

加速度计工作方式

假设立方体在外太空,那里的一切都是失重的,球会简单地漂浮在立方体的中心

现在,假设每面墙代表一个特定的轴。 如果我们突然以 1g 的加速度向左移动盒子(单个 G 力 1g 相当于重力加速度 9.8 m/s 2),球无疑会撞到墙壁 X。如果我们测量球对墙壁施加的力X,我们可以得到沿X轴的输出值为1g。

让我们看看当我们把那个立方体放在地球上时会发生什么。球将简单地落在墙 Z 上,施加 1g 的力,如下图所示:

在这种情况下,盒子没有移动,但我们仍然在 Z 轴上得到 1g 的读数。这是因为重力(实际上是加速度的一种形式)以 1g 的力向下拉球。

虽然此模型并不完全代表真实世界的加速度计传感器是如何构建的,但它通常有助于理解为什么加速度计的输出信号通常以 ±g 为单位指定,或者为什么加速度计在静止时在 z 轴上读数为 1g,或者您可以在不同方向上获得什么样的加速度计读数。

上位机通讯

这里使用的是匿名助手的上位机

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

有专门的通讯协议

串口通讯协议格式如下所示,需要注意传输为小端模式传输。

对应的源地址和目标地址分别为0xFD和0xFE。

我们只需要上报加速度和陀螺仪数据,所以功能码为0x01,数据长度为0x0D,需要主要为小端模式传输。

加速度演示

实测移动模块分别为X、Y、Z轴向下,可以看见数值基本上为1000mg。

陀螺仪工作方式

加速度计测量线性加速度,而陀螺仪测量角旋转。为此,他们测量了科里奥利效应产生的力。

陀螺仪是一种运动传感器,能够感测物体在一轴或多轴上的旋转角速度。它能够精确地感测自由空间中复杂的移动动作,因此成为追踪物体移动方位和旋转动作的必要设备。与加速计电子罗盘不同,陀螺仪不需要依赖外部力量(如重力或磁场),可以自主地发挥其功能。

因此,从理论上讲,只使用陀螺仪就可以完成姿态导航的任务。

陀螺仪的每个通道检测一个轴的旋转。也就是说陀螺仪通过测量自身的旋转状态,判断出设备当前运动状态,是向前、向后、向上、向下、向左还是向右呢,是加速(角速度)还是减速(角速度)呢,都可以实现,但是要判断出设备的方位(东西南北),陀螺仪就没有办法。

MEMS陀螺仪主要利用科里奥利力(旋转物体在有径向运动时所受到的切向力)原理,公开的微机械陀螺仪均采用振动物体传感角速度的概念,利用振动来诱导和探测科里奥利力。

MEMS陀螺仪的核心是一个微加工机械单元,在设计上按照一个音叉机制共振运动,通过科里奥利力原理把角速率转换成一个特定感测结构的位移。

两个相同的质量块以方向相反的做水平震荡。当外部施加一个角速率,就会出现一个科氏力,力的方向垂直于质量运动方向,如垂直方向箭头所示。产生的科氏力使感测质量发生位移,位移大小与所施加的角速率大小成正比,科氏力引起的电容变化即可计算出角速率大小。 科里奥利效应指出,当质量 (m) 以速度 (v) 沿特定方向移动并施加外部角速率 (Ω)(红色箭头)时,科里奥利效应会产生一个力(黄色箭头),导致质量垂直移动。该位移的值与应用的角速率直接相关。

上报源码

/**
  * @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;//数据长度LEN
        data[5]=0x00;//数据长度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]; //从帧头开始,对每一字节进行求和,直到 DATA 区结束
addcheck += sumcheck; //每一字节的求和操作,进行一次 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 */
}

审核编辑 黄宇

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

    关注

    129

    文章

    3885

    浏览量

    190211
  • 陀螺仪
    +关注

    关注

    44

    文章

    776

    浏览量

    98474
  • 数据采集
    +关注

    关注

    38

    文章

    5806

    浏览量

    113417
  • 上位机
    +关注

    关注

    27

    文章

    930

    浏览量

    54692
  • 运动检测
    +关注

    关注

    0

    文章

    34

    浏览量

    12603
收藏 人收藏

    评论

    相关推荐

    驱动LSM6DS3TR-C实现高效运动检测数据采集(1)----获取ID

    本文将介绍如何驱动和利用LSM6DS3TR-C传感器,实现精确的运动感应功能。LSM6DS3TR-C是一款先进的
    的头像 发表于 11-13 15:45 2033次阅读
    <b class='flag-5'>驱动</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>实现</b><b class='flag-5'>高效</b><b class='flag-5'>运动检测</b>与<b class='flag-5'>数据采集</b>(1)----获取ID

    驱动LSM6DS3TR-C实现高效运动检测数据采集(6)----FIFO数据读取与配置

    LSM6DS3TR-C是STMicroelectronics公司推出的iNEMO惯性模块,集成了三轴加速度计和三轴陀螺仪,具备低功耗、强大的运动检测功能。该传感器支持多种操作模式,并内置FIFO
    的头像 发表于 07-18 10:58 1153次阅读
    <b class='flag-5'>驱动</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>实现</b><b class='flag-5'>高效</b><b class='flag-5'>运动检测</b>与<b class='flag-5'>数据采集</b>(<b class='flag-5'>6</b>)----FIFO<b class='flag-5'>数据</b>读取与配置

    驱动LSM6驱动LSM6DS3TR-C实现高效运动检测数据采集(7)----MotionFX库解析空间坐标DS3TR-C实现高效运动检测数据

    本文将探讨如何使用MotionFX库解析空间坐标。MotionFX库是一种用于传感器融合的强大工具,可以将加速度计、陀螺仪和磁力计的数据融合在一起,实现精确的姿态和位置估计。本文将介绍如何初始
    的头像 发表于 07-18 11:02 1003次阅读
    <b class='flag-5'>驱动</b><b class='flag-5'>LSM6</b><b class='flag-5'>驱动</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>实现</b><b class='flag-5'>高效</b><b class='flag-5'>运动检测</b>与<b class='flag-5'>数据采集</b>(7)----MotionFX库解析空间坐标<b class='flag-5'>DS3TR-C</b><b class='flag-5'>实现</b><b class='flag-5'>高效</b><b class='flag-5'>运动检测</b>与<b class='flag-5'>数据</b>采

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

    本文档详细介绍了如何使用匿名助手的上位实现加速度计和陀螺仪数据可视化显示。内容涵盖了加速度计
    的头像 发表于 08-05 09:52 1343次阅读
    陀螺仪<b class='flag-5'>LSM6</b>DSOW开发(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'>实现</b><b class='flag-5'>可视化</b>

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

    使用场景是LSM6DS3TR-C通过SPI一拖四连接单片,一共有四路这样的一拖四。 测试时发现电流很大,感觉有点不对,编写程序使LSM6DS3TR-C间隔5s一个一个使能,会发现稳压源的输出电流从
    发表于 03-07 08:08

    请问LSM6DS3TRLSM6DS3TR-C两个型号能否完全兼容?

    LSM6DS3TR停产买不到了,准备切换LSM6DS3TR-C型号使用。 请问两者有什么差别?能否直接替换?有成功替换案例吗?
    发表于 03-14 06:40

    LSM6DS3TR-C数据读取异常是安利的问题?怎么处理?

    我在使用lsm6ds3tr-c 6轴传感器时发现,读取的温度以及角速度值异常,配置为官方lsm6ds3tr_c_read_data_polling.c文件中
    发表于 03-19 08:15

    LSM6DS3TR-C长时间读取后角速度输出为0是什么原因造成的?

    LSM6DS3TR-C 长时间读取后角速度输出为0
    发表于 03-20 06:28

    LSM6DS3TR-C角速度输出为0是什么原因导致的?

    LSM6DS3TR-C在长时间休眠后(6小时以上),角速度输出为0,短时间休眠输出正常,这是什么问题?
    发表于 03-21 06:27

    LSM6DS3TR-C的FIFO读取数据出错是什么原因造成的?怎么解决?

    使用LSM6DS3TR-C的FIFO,先获取了FIFO的WaterM标志,该标志置位之后再去获取当前存在FIFO缓存的数据长度,再去读取FIFO中对应长度的数据,会出现读取数据出错的现
    发表于 03-27 06:05

    请问LSM6DS3TR-C有没有windows下的测试工具?

    LSM6DS3TR-C有没有windows下的测试工具
    发表于 05-20 06:22

    LSM6DS3TR-C的低功耗模式和高性能模式有什么区别

    如果我只在 12.5Hz 下操作加速度计,LSM6DS3TR-C 的低功耗模式和高性能模式有什么区别?
    发表于 12-09 06:47

    驱动LSM6DS3TR-C实现高效运动检测数据采集(2)----配置滤波器

    LSM6DS3TR-C中,加速度计和陀螺仪可以独立地开启/关闭,并且可以拥有不同的ODR和功耗模式。 LSM6DS3TR-C有三种可用的操作模式: ● 仅加速度计活动,陀螺仪处于断电状态 ● 仅陀螺仪活动,加速度计处于断电状态 ● 加速度计和陀螺仪传感器同时活动
    的头像 发表于 11-14 09:45 905次阅读
    <b class='flag-5'>驱动</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>实现</b><b class='flag-5'>高效</b><b class='flag-5'>运动检测</b>与<b class='flag-5'>数据采集</b>(2)----配置滤波器

    驱动LSM6DS3TR-C实现高效运动检测数据采集(3)----获取传感器数据

    一旦传感器被正确初始,可以通过SPI或I2C接口向传感器发送读取命令,并接收传感器返回的数据。这个读取过程包括获取LSM6DS3TR传感器提供的加速度计和陀螺仪
    的头像 发表于 11-14 09:59 759次阅读
    <b class='flag-5'>驱动</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>实现</b><b class='flag-5'>高效</b><b class='flag-5'>运动检测</b>与<b class='flag-5'>数据采集</b>(<b class='flag-5'>3</b>)----获取传感器<b class='flag-5'>数据</b>

    驱动LSM6DS3TR-C实现高效运动检测数据采集(5)----姿态解算

    lsm6ds3trc包含三轴陀螺仪与三轴加速度计。 姿态有多种数学表示方式,常见的是四元数,欧拉角,矩阵和轴角。他们各自有其自身的优点,在不同的领域使用不同的表示方式。在四轴飞行器中使用到了四元数
    的头像 发表于 11-14 10:11 736次阅读
    <b class='flag-5'>驱动</b><b class='flag-5'>LSM6DS3TR-C</b><b class='flag-5'>实现</b><b class='flag-5'>高效</b><b class='flag-5'>运动检测</b>与<b class='flag-5'>数据采集</b>(5)----姿态解算