2

我正在从单个 stm32 板上查询多个 imu 传感器。但是,读取这些多个传感器会导致每个添加的传感器的数据频率下降 100 毫秒。我想知道是否有办法在我的代码中使用线程,以便可以同时进行查询,或者想知道是否有另一种方法。

while (1)
  {

  /* USER CODE END WHILE */

 MX_X_CUBE_BLE1_Process();
 /* USER CODE BEGIN 3 */
 for(i = 0; i < NUM_MPU_DEVICES; ++i) {
     update_MPU_data(&mpu_devices[i]);
 }
 uint32_t timestamp = HAL_GetTick();
 for(i = 0; i < NUM_MPU_DEVICES; ++i) {
     print_MPU_data(i+1, &mpu_devices[i], timestamp);
 }
}

以下是它更新传感器数据的地方

void update_MPU_data(MPU_DEVICE *mpu_dev)
{
MPU_Read_Accel_Data(mpu_dev);
MPU_Read_Gyro_Data(mpu_dev);
MPU_Read_Mag_Data(mpu_dev);
}

此外,此功能是读取传感器数据的示例。

void MPU_Read_Accel_Data(MPU_DEVICE * pMPU9250)
{

  uint8_t rawData[6];  // x/y/z accel register data stored here
  int16_t tempData[3];
  // Read the six raw data registers into data array
  MPU_SPI_Read(pMPU9250, MPUREG_ACCEL_XOUT_H, 6, rawData);

  // Turn the MSB and LSB into a signed 16-bit value
  tempData[0] = ((int16_t)rawData[0] << 8) | rawData[1] ;
  tempData[1] = ((int16_t)rawData[2] << 8) | rawData[3] ;
  tempData[2] = ((int16_t)rawData[4] << 8) | rawData[5] ;

// Now we'll calculate the accleration value into actual g's
  // This depends on scale being set
pMPU9250->accelX = (float)tempData[0] * pMPU9250->accelRes;
pMPU9250->accelY = (float)tempData[1] * pMPU9250->accelRes;
pMPU9250->accelZ = (float)tempData[2] * pMPU9250->accelRes;
}

以下代码为 MPU_SPI_Read

int MPU_SPI_Read(MPU_DEVICE *pMPU9250, unsigned char reg_addr, unsigned char 
length, unsigned char *pData)
{
MPU_Chip_Select(pMPU9250);

// specifying reister address
uint8_t address;
address = reg_addr | 0x80;
uint8_t *pRegAddr = &address;
HAL_SPI_Transmit(pMPU9250->pSPIHandle, pRegAddr, 1, 10);

// reading data from register
HAL_SPI_Receive(pMPU9250->pSPIHandle, pData, length, 10);
MPU_Chip_Deselect(pMPU9250);
HAL_Delay(1);

return 0;
}

我在函数调用 MPU_Chip_Select 中发现了 10ms HAL_Delay,在 Deselect 中发现了另外 10ms。虽然,我认为这种延迟对于 spi 信号完整性是必要的,即不干扰信号。

总的来说,我希望电路板每 100 毫秒输出 8 个传感器的数据,其中 NUM_MPU_DEVICES == 8。但是,输出所有 8 个传感器的数据大约需要 800 毫秒。

先感谢您。

4

0 回答 0