2019-10-10 16:28:42 +00:00
|
|
|
// Copyright 2019, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief C interface to basic IMU fusion.
|
|
|
|
* @author Ryan Pavlik <ryan.pavlik@collabora.com>
|
|
|
|
* @ingroup aux_tracking
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "math/m_api.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2019-11-21 13:00:52 +00:00
|
|
|
|
2019-11-11 16:23:49 +00:00
|
|
|
/*!
|
|
|
|
* Opaque type for fusing IMU reports.
|
|
|
|
*/
|
2019-10-10 16:28:42 +00:00
|
|
|
struct imu_fusion;
|
2019-11-11 16:23:49 +00:00
|
|
|
|
2019-10-10 16:28:42 +00:00
|
|
|
/*!
|
|
|
|
* Create a struct imu_fusion.
|
|
|
|
*
|
|
|
|
* @public @memberof imu_fusion
|
|
|
|
* @ingroup aux_tracking
|
|
|
|
*/
|
|
|
|
struct imu_fusion *
|
|
|
|
imu_fusion_create();
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Destroy a struct imu_fusion.
|
|
|
|
*
|
|
|
|
* Should not be called simultaneously with any other imu_fusion function.
|
|
|
|
*
|
2019-11-12 17:37:59 +00:00
|
|
|
* @param fusion The IMU Fusion object
|
|
|
|
*
|
2019-10-10 16:28:42 +00:00
|
|
|
* @public @memberof imu_fusion
|
|
|
|
* @ingroup aux_tracking
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
imu_fusion_destroy(struct imu_fusion *fusion);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Predict and correct fusion with a gyroscope reading.
|
|
|
|
*
|
|
|
|
* dt should not be zero: If you're receiving accel and gyro data at the same
|
|
|
|
* time, call imu_fusion_incorporate_gyros_and_accelerometer() instead.
|
|
|
|
*
|
|
|
|
* Should not be called simultaneously with any other imu_fusion function.
|
|
|
|
*
|
|
|
|
* Non-zero return means error.
|
|
|
|
*
|
2019-11-12 17:37:59 +00:00
|
|
|
* @param fusion The IMU Fusion object
|
|
|
|
* @param timestamp_ns The timestamp corresponding to the information being
|
|
|
|
* processed with this call.
|
|
|
|
* @param ang_vel Angular velocity vector from gyroscope
|
|
|
|
* @param ang_vel_variance The variance of the angular velocity measurements:
|
|
|
|
* part of the characteristics of the IMU being used.
|
|
|
|
*
|
2019-10-10 16:28:42 +00:00
|
|
|
* @public @memberof imu_fusion
|
|
|
|
* @ingroup aux_tracking
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
imu_fusion_incorporate_gyros(struct imu_fusion *fusion,
|
2019-11-11 17:55:39 +00:00
|
|
|
uint64_t timestamp_ns,
|
2019-10-10 16:28:42 +00:00
|
|
|
struct xrt_vec3 const *ang_vel,
|
2019-11-12 17:37:59 +00:00
|
|
|
struct xrt_vec3 const *ang_vel_variance);
|
2019-10-10 16:28:42 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Predict and correct fusion with an accelerometer reading.
|
|
|
|
*
|
2019-11-11 17:55:39 +00:00
|
|
|
* If you're receiving accel and gyro data at the same time, call
|
|
|
|
* imu_fusion_incorporate_gyros_and_accelerometer() instead.
|
2019-10-10 16:28:42 +00:00
|
|
|
*
|
|
|
|
* Should not be called simultaneously with any other imu_fusion function.
|
|
|
|
*
|
|
|
|
* Non-zero return means error.
|
|
|
|
*
|
2019-11-12 17:37:59 +00:00
|
|
|
* @param fusion The IMU Fusion object
|
|
|
|
* @param timestamp_ns The timestamp corresponding to the information being
|
|
|
|
* processed with this call.
|
|
|
|
* @param accel Accelerometer data (in m/s/s) including the effect of gravity -
|
|
|
|
* assumed to be +y when aligned with the world.
|
|
|
|
* @param accel_variance The variance of the accelerometer measurements: part of
|
|
|
|
* the characteristics of the IMU being used.
|
2019-11-12 17:43:17 +00:00
|
|
|
* @param out_world_accel Optional output parameter: will contain the
|
|
|
|
* non-gravity acceleration in the world frame.
|
2019-11-12 17:37:59 +00:00
|
|
|
*
|
2019-10-10 16:28:42 +00:00
|
|
|
* @public @memberof imu_fusion
|
|
|
|
* @ingroup aux_tracking
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
imu_fusion_incorporate_accelerometer(struct imu_fusion *fusion,
|
2019-11-11 17:55:39 +00:00
|
|
|
uint64_t timestamp_ns,
|
2019-10-10 16:28:42 +00:00
|
|
|
struct xrt_vec3 const *accel,
|
2019-11-12 17:43:17 +00:00
|
|
|
struct xrt_vec3 const *accel_variance,
|
|
|
|
struct xrt_vec3 *out_world_accel);
|
2019-10-10 16:28:42 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Predict and correct fusion with a simultaneous accelerometer and gyroscope
|
|
|
|
* reading.
|
|
|
|
*
|
|
|
|
* Should not be called simultaneously with any other imu_fusion function.
|
|
|
|
*
|
|
|
|
* Non-zero return means error.
|
|
|
|
*
|
2019-11-12 17:37:59 +00:00
|
|
|
* @param fusion The IMU Fusion object
|
|
|
|
* @param timestamp_ns The timestamp corresponding to the information being
|
|
|
|
* processed with this call.
|
|
|
|
* @param ang_vel Angular velocity vector from gyroscope
|
|
|
|
* @param ang_vel_variance The variance of the angular velocity measurements:
|
|
|
|
* part of the characteristics of the IMU being used.
|
|
|
|
* @param accel Accelerometer data (in m/s/s) including the effect of gravity -
|
|
|
|
* assumed to be +y when aligned with the world.
|
|
|
|
* @param accel_variance The variance of the accelerometer measurements: part of
|
|
|
|
* the characteristics of the IMU being used.
|
2019-11-12 17:43:17 +00:00
|
|
|
* @param out_world_accel Optional output parameter: will contain the
|
|
|
|
* non-gravity acceleration in the world frame.
|
2019-11-12 17:37:59 +00:00
|
|
|
*
|
2019-10-10 16:28:42 +00:00
|
|
|
* @public @memberof imu_fusion
|
|
|
|
* @ingroup aux_tracking
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
imu_fusion_incorporate_gyros_and_accelerometer(
|
|
|
|
struct imu_fusion *fusion,
|
2019-11-11 17:55:39 +00:00
|
|
|
uint64_t timestamp_ns,
|
2019-10-10 16:28:42 +00:00
|
|
|
struct xrt_vec3 const *ang_vel,
|
|
|
|
struct xrt_vec3 const *ang_vel_variance,
|
|
|
|
struct xrt_vec3 const *accel,
|
2019-11-12 17:43:17 +00:00
|
|
|
struct xrt_vec3 const *accel_variance,
|
|
|
|
struct xrt_vec3 *out_world_accel);
|
2019-10-10 16:28:42 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Get the predicted state. Does not advance the internal state clock.
|
|
|
|
*
|
|
|
|
* Non-zero return means error.
|
|
|
|
*
|
2019-11-12 17:37:59 +00:00
|
|
|
* @param fusion The IMU Fusion object
|
|
|
|
* @param timestamp_ns The timestamp corresponding to the predicted state you
|
|
|
|
* want.
|
|
|
|
* @param out_quat The quaternion to populate with the predicted orientation.
|
|
|
|
* @param out_ang_vel The vector to poluate with the predicted angular velocity.
|
|
|
|
*
|
2019-10-10 16:28:42 +00:00
|
|
|
* @public @memberof imu_fusion
|
|
|
|
* @ingroup aux_tracking
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
imu_fusion_get_prediction(struct imu_fusion const *fusion,
|
2019-11-11 17:55:39 +00:00
|
|
|
uint64_t timestamp_ns,
|
2019-10-10 16:28:42 +00:00
|
|
|
struct xrt_quat *out_quat,
|
|
|
|
struct xrt_vec3 *out_ang_vel);
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Get the predicted state as a rotation vector. Does not advance the internal
|
|
|
|
* state clock.
|
|
|
|
*
|
2019-11-12 17:37:59 +00:00
|
|
|
* This is mostly for debugging: a rotation vector can be easier to visualize or
|
|
|
|
* understand intuitively.
|
|
|
|
*
|
2019-10-10 16:28:42 +00:00
|
|
|
* Non-zero return means error.
|
|
|
|
*
|
2019-11-12 17:37:59 +00:00
|
|
|
* @param fusion The IMU Fusion object
|
|
|
|
* @param timestamp_ns The timestamp corresponding to the predicted state you
|
|
|
|
* want.
|
|
|
|
* @param out_rotation_vec The vector to poluate with the predicted orientation
|
|
|
|
* rotation vector.
|
|
|
|
*
|
2019-10-10 16:28:42 +00:00
|
|
|
* @public @memberof imu_fusion
|
|
|
|
* @ingroup aux_tracking
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
imu_fusion_get_prediction_rotation_vec(struct imu_fusion const *fusion,
|
2019-11-11 17:55:39 +00:00
|
|
|
uint64_t timestamp_ns,
|
2019-10-10 16:28:42 +00:00
|
|
|
struct xrt_vec3 *out_rotation_vec);
|
2019-11-21 13:00:52 +00:00
|
|
|
|
|
|
|
|
2019-10-10 16:28:42 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|