You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
133 lines
4.0 KiB
133 lines
4.0 KiB
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: t -*- |
|
|
|
/// @file IMU.h |
|
/// @brief Abstract class defining the interface to a real or virtual |
|
/// Inertial Measurement Unit. |
|
|
|
#ifndef IMU_h |
|
#define IMU_h |
|
|
|
#include "../AP_Math/AP_Math.h" |
|
#include "../AP_PeriodicProcess/AP_PeriodicProcess.h" |
|
#include <inttypes.h> |
|
|
|
class IMU |
|
{ |
|
|
|
public: |
|
/// Constructor |
|
IMU(); |
|
|
|
enum Start_style { |
|
COLD_START = 0, |
|
WARM_START |
|
}; |
|
|
|
/// Perform startup initialisation. |
|
/// |
|
/// Called to initialise the state of the IMU. |
|
/// |
|
/// For COLD_START, implementations using real sensors can assume |
|
/// that the airframe is stationary and nominally oriented. |
|
/// |
|
/// For WARM_START, no assumptions should be made about the |
|
/// orientation or motion of the airframe. Calibration should be |
|
/// as for the previous COLD_START call. |
|
/// |
|
/// @param style The initialisation startup style. |
|
/// |
|
virtual void init( Start_style style, |
|
void (*delay_cb)(unsigned long t), |
|
void (*flash_leds_cb)(bool on), |
|
AP_PeriodicProcess * scheduler ); |
|
|
|
/// Perform cold startup initialisation for just the accelerometers. |
|
/// |
|
/// @note This should not be called unless ::init has previously |
|
/// been called, as ::init may perform other work. |
|
/// |
|
virtual void init_accel(void (*callback)(unsigned long t), void (*flash_leds_cb)(bool on)); |
|
|
|
/// Perform cold-start initialisation for just the gyros. |
|
/// |
|
/// @note This should not be called unless ::init has previously |
|
/// been called, as ::init may perform other work |
|
/// |
|
virtual void init_gyro(void (*callback)(unsigned long t), void (*flash_leds_cb)(bool on)); |
|
|
|
/// Give the IMU some cycles to perform/fetch an update from its |
|
/// sensors. |
|
/// |
|
/// @returns True if some state was updated. |
|
/// |
|
virtual bool update(void); |
|
|
|
// true if new data is available from the sensors |
|
virtual bool new_data_available(void); |
|
|
|
/// Fetch the current gyro values |
|
/// |
|
/// @returns vector of rotational rates in radians/sec |
|
/// |
|
Vector3f get_gyro(void) { |
|
return _gyro; |
|
} |
|
|
|
/// Fetch the current accelerometer values |
|
/// |
|
/// @returns vector of current accelerations in m/s/s |
|
/// |
|
Vector3f get_accel(void) { |
|
return _accel; |
|
} |
|
|
|
|
|
/// return the number of seconds that the last update represents |
|
/// |
|
/// @returns number of seconds |
|
/// |
|
float get_delta_time(void) { |
|
return _sample_time * 1.0e-6; |
|
} |
|
|
|
/// return the maximum gyro drift rate in radians/s/s. This |
|
/// depends on what gyro chips are being used |
|
virtual float get_gyro_drift_rate(void); |
|
|
|
/// A count of bad sensor readings |
|
/// |
|
/// @todo This should be renamed, as there's no guarantee that sensors |
|
/// are using ADCs, etc. |
|
/// |
|
uint8_t adc_constraints; |
|
|
|
virtual float gx(void); |
|
virtual float gy(void); |
|
virtual float gz(void); |
|
virtual float ax(void); |
|
virtual float ay(void); |
|
virtual float az(void); |
|
virtual void ax(const float v); |
|
virtual void ay(const float v); |
|
virtual void az(const float v); |
|
|
|
static const struct AP_Param::GroupInfo var_info[]; |
|
|
|
protected: |
|
|
|
AP_Vector6f _sensor_cal; ///< Calibrated sensor offsets |
|
|
|
/// Most recent accelerometer reading obtained by ::update |
|
Vector3f _accel; |
|
|
|
/// Most recent gyro reading obtained by ::update |
|
Vector3f _gyro; |
|
|
|
/// number of microseconds that the accel and gyro values |
|
/// were sampled over |
|
uint32_t _sample_time; |
|
|
|
AP_Int16 _product_id; // this is the product id returned from the INS init |
|
}; |
|
|
|
#endif
|
|
|