风筝
发表于: 2019-11-27 21:55:25 | 显示全部楼层

BMI085是系统级封装惯性测量单元,可提供精确的加速度和角速率测量。由于采用了系统级封装方法(两个传感器位于单个封装中),因此陀螺仪和加速度数据是以非同步方式获取的。但是,加速度计和陀螺仪之间的同步很容易实现。本文档介绍了如何在典型应用(例如增强现实或虚拟现实)中实现加速度计和陀螺仪之间的同步。


为了在BMI085上实现数据同步,需要将来自BMI085陀螺仪的数据就绪中断信号连接到BMI085加速度计的中断引脚之一(可以将其配置为输入引脚)。考虑到传感器的群时延,加速度计的内部信号处理单元使用来自陀螺仪的数据就绪信号来同步(synchronize)和内插(Interpolate)加速度计的数据。然后,加速度计部分可以将可用数据通知主机。使用此技术,可以实现同步数据并以2 kHz的ODR提供加速度计数据。


注意:数据同步是为需要高带宽的应用程序而设计的,而BMI085旨在用于此应用程序,但它也可与BMI088一起使用。然而,对于某些应用,具有非常低的带宽,并且对于加速度计和陀螺仪具有不同的带宽设置。这时,同步功能没有意义。


概念

同步数据意味着陀螺仪和加速度计数据的采集是同时发生的,并且信号具有相同的传播时间(propagation time)。从运动到寄存器读出之间的时间取决于主要由信号滤波路径引起的物理传播时间。加速度计和陀螺仪数据之间到公共时间点和公共组延迟之间的同步可以使用以下各节中描述的方法来实现。


BMI085的硬件中断引脚(INT1 / INT3)用于数据同步,必须将其连接。中断引脚INT2可用于BMI085将数据就绪通知给主机。


技术实现

数据同步功能需要PCB上的传感器的物理中断引脚连接以及BMI085的特殊配置。要求和步骤如下所述。


连接图

Connection diagram.png

对于对延迟至关重要的多传感器应用,建议使用SPI接口以最快的速度读取传感器数据(建议SPI时钟频率> 2MHz)。


配置BMI085进行数据同步

包含bmi08x头文件

  1. #include "bmi08x.h"
复制代码

包含bmi085变量的头文件

  1. #include "bmi085.h"
复制代码

在bmi08x_defs.h中启用以下宏以使用BMI085传感器功能

  1. /** \name enable bmi085 sensor */
  2. #ifndef BMI08X_ENABLE_BMI085
  3. #define BMI08X_ENABLE_BMI085       1
  4. #endif
复制代码

要初始化BMI085进行数据同步,应创建bmi08x结构体的实例。用户需要在结构体中更新以下参数:

参数
描述
accel_id I2C接口的设备地址(如果intf是BMI08X_I2C_INTF)
gyro_id I2C接口的设备地址(如果intf为BMI08X_I2C_INTF)
intf I2C或SPI
read 通过I2C / SPI接口进行读取的函数指针
write 通过I2C / SPI接口进行写入的函数指针
delay_ms 延时函数指针

通过SPI接口初始化

以下示例代码是简化代码,未添加返回值检查,以使其更易于阅读。

  1. struct bmi08x_dev bmi08xdev = {
  2.         .accel_id = 0,
  3.         .gyro_id = 0,
  4.         .intf = BMI08X_SPI_INTF,  
  5.         .read = user_spi_read,  
  6.         .write = user_spi_write,  
  7.         .delay_ms = user_delay_milli_sec
  8. };

  9. int16_t rslt;

  10. /* Initialize bmi085 sensors (accel & gyro)*/
  11. rslt = bmi085_init(&bmi08xdev);
  12. /* Reset the accelerometer and wait for 1 ms - delay taken care inside the function */
  13. rslt = bmi08a_soft_reset(&bmi08xdev);


  14. /*! Max read/write length (maximum supported length is 32).
  15. To be set by the user */
  16. bmi08xdev.read_write_len = 32;
  17. /*set accel power mode */
  18. bmi08xdev.accel_cfg.power = BMI08X_ACCEL_PM_ACTIVE;
  19. rslt = bmi08a_set_power_mode(&bmi08xdev);

  20. bmi08xdev.gyro_cfg.power = BMI08X_GYRO_PM_NORMAL;
  21. bmi08g_set_power_mode(&bmi08xdev);

  22. /* API uploads the bmi08x config file onto the device and wait for 150ms
  23.    to enable the data synchronization - delay taken care inside the function */
  24. rslt = bmi085_apply_config_file(&bmi08xdev);

  25. /*assign accel range setting*/
  26. bmi08xdev.accel_cfg.range = BMI085_ACCEL_RANGE_4G;
  27. /*assign gyro range setting*/
  28. bmi08xdev.gyro_cfg.range = BMI08X_GYRO_RANGE_2000_DPS;
  29. /*! Mode (0 = off, 1 = 400Hz, 2 = 1kHz, 3 = 2kHz) */
  30. sync_cfg.mode = BMI08X_ACCEL_DATA_SYNC_MODE_2000HZ;
  31. rslt = bmi085_configure_data_synchronization(sync_cfg, &bmi08xdev);


  32. /*set accel interrupt pin configuration*/
  33. /*configure host data ready interrupt */
  34. int_config.accel_int_config_1.int_channel = BMI08X_INT_CHANNEL_1;
  35. int_config.accel_int_config_1.int_type = BMI08X_ACCEL_SYNC_INPUT;
  36. int_config.accel_int_config_1.int_pin_cfg.output_mode = BMI08X_INT_MODE_PUSH_PULL;
  37. int_config.accel_int_config_1.int_pin_cfg.lvl = BMI08X_INT_ACTIVE_HIGH;
  38. int_config.accel_int_config_1.int_pin_cfg.enable_int_pin = BMI08X_ENABLE;

  39. /*configure Accel syncronization input interrupt pin */
  40. int_config.accel_int_config_2.int_channel = BMI08X_INT_CHANNEL_2;
  41. int_config.accel_int_config_2.int_type = BMI08X_ACCEL_SYNC_DATA_RDY_INT;
  42. int_config.accel_int_config_2.int_pin_cfg.output_mode = BMI08X_INT_MODE_PUSH_PULL;
  43. int_config.accel_int_config_2.int_pin_cfg.lvl = BMI08X_INT_ACTIVE_HIGH;
  44. int_config.accel_int_config_2.int_pin_cfg.enable_int_pin = BMI08X_ENABLE;

  45. /*set gyro interrupt pin configuration*/
  46. int_config.gyro_int_config_1.int_channel = BMI08X_INT_CHANNEL_3;
  47. int_config.gyro_int_config_1.int_type = BMI08X_GYRO_DATA_RDY_INT;
  48. int_config.gyro_int_config_1.int_pin_cfg.enable_int_pin = BMI08X_ENABLE;
  49. int_config.gyro_int_config_1.int_pin_cfg.lvl = BMI08X_INT_ACTIVE_HIGH;
  50. int_config.gyro_int_config_1.int_pin_cfg.output_mode = BMI08X_INT_MODE_PUSH_PULL;

  51. int_config.gyro_int_config_2.int_channel = BMI08X_INT_CHANNEL_4;
  52. int_config.gyro_int_config_2.int_type = BMI08X_GYRO_DATA_RDY_INT;
  53. int_config.gyro_int_config_2.int_pin_cfg.enable_int_pin = BMI08X_DISABLE;
  54. int_config.gyro_int_config_2.int_pin_cfg.lvl = BMI08X_INT_ACTIVE_HIGH;
  55. int_config.gyro_int_config_2.int_pin_cfg.output_mode = BMI08X_INT_MODE_PUSH_PULL;

  56. /* Enable synchronization interrupt pin */
  57. rslt = bmi085_set_data_sync_int_config(&int_config, &bmi08xdev);
复制代码

读取原始加速度数据

  1. /* Declare an instance of the sensor data structure for accel */
  2. static struct bmi08x_sensor_data accel_bmi085;

  3. rslt = bmi08a_get_data(&accel_bmi085, &bmi08xdev);
复制代码

读取同步数据

  1. /* Declare an instance of the sensor data structure for accel */
  2. static struct bmi08x_sensor_data accel_bmi085;
  3. /* Declare an instance of the sensor data structure for gyro */
  4. static struct bmi08x_sensor_data gyro_bmi085;

  5. rslt = bmi085_get_synchronized_data(&accel_bmi085,&gyro_bmi085, &bmi08xdev);
复制代码

跳转到指定楼层
风筝
发表于: 2020-5-10 20:03:19 | 显示全部楼层

以下是两款BMI088传感器模块的淘宝链接:

●    YBX-BMI088(I2C接口)加速度传感器模块:https://item.taobao.com/item.htm?id=589447558027

●    YBX-BMI088(SPI接口)加速度传感器模块:https://item.taobao.com/item.htm?id=591903885679

YBX-BMI088(SPI)商品主图.jpg

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

主题 705 | 回复: 1492



手机版|

GMT+8, 2024-11-7 21:13 , Processed in 0.052260 second(s), 6 queries , Gzip On, MemCache On. Powered by Discuz! X3.5

YiBoard一板网 © 2015-2022 地址:河北省石家庄市长安区高营大街 ( 冀ICP备18020117号 )

快速回复 返回顶部 返回列表