Program Listing for File imu_data_provider.cpp

Return to documentation for file (src/imu_data_provider.cpp)

/*******************************************************************************
 *   @file   imu_ros_publisher.cpp
 *   @brief  Implementation for providing IMU ros standard data.
 *   @author Vasile Holonec (Vasile.Holonec@analog.com)
*******************************************************************************/
// Copyright 2023 Analog Devices, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#include "adi_imu/imu_data_provider.h"

#include <sensor_msgs/msg/imu.hpp>

namespace adi_imu
{

ImuDataProvider::ImuDataProvider() : m_frame_id("imu") {}

ImuDataProvider::~ImuDataProvider() {}

void ImuDataProvider::setFrameId(const std::string & frame_id) { m_frame_id = frame_id; }

bool ImuDataProvider::getData(sensor_msgs::msg::Imu & message)
{
  if (!m_iio_wrapper.updateBuffer(ACCEL_GYRO_BUFFERED_DATA)) return false;

  message.linear_acceleration.x = m_iio_wrapper.getBuffLinearAccelerationX();
  message.linear_acceleration.y = m_iio_wrapper.getBuffLinearAccelerationY();
  message.linear_acceleration.z = m_iio_wrapper.getBuffLinearAccelerationZ();

  message.angular_velocity.x = m_iio_wrapper.getBuffAngularVelocityX();
  message.angular_velocity.y = m_iio_wrapper.getBuffAngularVelocityY();
  message.angular_velocity.z = m_iio_wrapper.getBuffAngularVelocityZ();

  message.header.frame_id = m_frame_id;
  m_iio_wrapper.getBuffSampleTimestamp(message.header.stamp.sec, message.header.stamp.nanosec);

  // No orientation provided direclty by the IMU
  message.orientation_covariance[0] = -1;

  // Handle covariance if provider is set
  if (m_covariance_provider) {
    //Feed sample for calibration/adaptation
    adi_imu::Vec3 accel = message.linear_acceleration;
    adi_imu::Vec3 gyro = message.angular_velocity;

    m_covariance_provider->addSample(accel, gyro);
    if (m_covariance_provider->isReady()) {
      // Copy covariance to message
      auto accel_cov = m_covariance_provider->getAccelCovariance();
      auto gyro_cov = m_covariance_provider->getGyroCovariance();

      std::copy(accel_cov.begin(), accel_cov.end(), message.linear_acceleration_covariance.begin());
      std::copy(gyro_cov.begin(), gyro_cov.end(), message.angular_velocity_covariance.begin());
    } else {
      // Set to -1 to indicate unknown during calibration
      message.linear_acceleration_covariance[0] = -1;
      message.angular_velocity_covariance[0] = -1;
    }
  } else {
    // No covariance provider - set to unknown
    message.linear_acceleration_covariance[0] = -1;
    message.angular_velocity_covariance[0] = -1;
  }

  return true;
}

// Method for setting the covariance provider
void ImuDataProvider::setCovarianceProvider(ImuCovarianceInterface * provider)
{
  m_covariance_provider = provider;
}

}  // namespace adi_imu