2012-11-05 00:31:02 -04:00
|
|
|
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
|
2012-11-07 09:24:00 -04:00
|
|
|
#ifndef __AP_INERTIALNAV_H__
|
|
|
|
#define __AP_INERTIALNAV_H__
|
2012-11-05 00:31:02 -04:00
|
|
|
|
|
|
|
#include <AP_AHRS.h>
|
|
|
|
#include <AP_InertialSensor.h> // ArduPilot Mega IMU Library
|
|
|
|
#include <AP_Baro.h> // ArduPilot Mega Barometer Library
|
2012-12-09 11:43:11 -04:00
|
|
|
#include <AP_Buffer.h> // FIFO buffer library
|
2013-09-19 03:56:23 -03:00
|
|
|
#include <AP_GPS_Glitch.h> // GPS Glitch detection library
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2013-04-30 00:52:28 -03:00
|
|
|
#define AP_INTERTIALNAV_TC_XY 2.5f // default time constant for complementary filter's X & Y axis
|
2013-03-31 23:51:12 -03:00
|
|
|
#define AP_INTERTIALNAV_TC_Z 5.0f // default time constant for complementary filter's Z axis
|
2013-01-10 03:56:21 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// #defines to control how often historical accel based positions are saved
|
|
|
|
// so they can later be compared to laggy gps readings
|
|
|
|
#define AP_INTERTIALNAV_SAVE_POS_AFTER_ITERATIONS 10
|
|
|
|
#define AP_INTERTIALNAV_GPS_LAG_IN_10HZ_INCREMENTS 4 // must not be larger than size of _hist_position_estimate_x and _hist_position_estimate_y
|
2013-01-22 05:16:18 -04:00
|
|
|
#define AP_INTERTIALNAV_GPS_TIMEOUT_MS 300 // timeout after which position error from GPS will fall to zero
|
2012-12-09 11:43:11 -04:00
|
|
|
|
2012-11-05 00:31:02 -04:00
|
|
|
/*
|
2012-11-07 09:24:00 -04:00
|
|
|
* AP_InertialNav is an attempt to use accelerometers to augment other sensors to improve altitud e position hold
|
2012-11-05 00:31:02 -04:00
|
|
|
*/
|
2012-11-07 09:24:00 -04:00
|
|
|
class AP_InertialNav
|
2012-11-05 00:31:02 -04:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
// Constructor
|
2013-09-19 03:56:23 -03:00
|
|
|
AP_InertialNav( AP_AHRS* ahrs, AP_InertialSensor* ins, AP_Baro* baro, GPS*& gps, GPS_Glitch& gps_glitch ) :
|
2012-11-05 00:31:02 -04:00
|
|
|
_ahrs(ahrs),
|
|
|
|
_baro(baro),
|
2013-09-19 03:56:23 -03:00
|
|
|
_gps(gps),
|
2012-11-05 00:31:02 -04:00
|
|
|
_xy_enabled(false),
|
2012-12-09 11:43:11 -04:00
|
|
|
_gps_last_update(0),
|
2013-04-17 10:00:52 -03:00
|
|
|
_gps_last_time(0),
|
2013-08-07 11:00:09 -03:00
|
|
|
_historic_xy_counter(0),
|
2013-09-19 03:56:23 -03:00
|
|
|
_baro_last_update(0),
|
|
|
|
_glitch_detector(gps_glitch)
|
2012-12-12 17:46:06 -04:00
|
|
|
{
|
|
|
|
AP_Param::setup_object_defaults(this, var_info);
|
|
|
|
}
|
2012-11-05 00:31:02 -04:00
|
|
|
|
|
|
|
// Initialisation
|
2013-03-19 05:51:16 -03:00
|
|
|
void init();
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// update - updates velocities and positions using latest info from accelerometers;
|
2013-03-19 05:51:16 -03:00
|
|
|
void update(float dt);
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
//
|
|
|
|
// XY Axis specific methods
|
|
|
|
//
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// set time constant - set timeconstant used by complementary filter
|
2013-03-19 05:51:16 -03:00
|
|
|
void set_time_constant_xy( float time_constant_in_seconds );
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// altitude_ok, position_ok - true if inertial based altitude and position can be trusted
|
2013-04-21 08:04:47 -03:00
|
|
|
bool position_ok() const;
|
2012-11-05 00:31:02 -04:00
|
|
|
|
|
|
|
// check_gps - check if new gps readings have arrived and use them to correct position estimates
|
2013-03-19 05:51:16 -03:00
|
|
|
void check_gps();
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2013-09-19 03:56:23 -03:00
|
|
|
// correct_with_gps - modifies accelerometer offsets using gps.
|
|
|
|
void correct_with_gps(uint32_t now, int32_t lon, int32_t lat);
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2013-04-11 06:24:20 -03:00
|
|
|
// get_position - returns current position from home in cm
|
2013-04-21 08:04:47 -03:00
|
|
|
Vector3f get_position() const { return _position_base + _position_correction; }
|
2013-04-11 06:24:20 -03:00
|
|
|
|
2013-08-07 11:00:09 -03:00
|
|
|
// get latitude & longitude positions in degrees * 10,000,000
|
2013-04-21 08:04:47 -03:00
|
|
|
int32_t get_latitude() const;
|
|
|
|
int32_t get_longitude() const;
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2013-09-19 03:57:22 -03:00
|
|
|
// set_home_position - all internal calculations are recorded as the distances from this point
|
|
|
|
void set_home_position(int32_t lon, int32_t lat);
|
2012-12-09 11:43:11 -04:00
|
|
|
|
|
|
|
// get latitude & longitude positions from base location (in cm)
|
2013-04-21 08:04:47 -03:00
|
|
|
float get_latitude_diff() const;
|
|
|
|
float get_longitude_diff() const;
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// get velocity in latitude & longitude directions (in cm/s)
|
2013-04-21 08:04:47 -03:00
|
|
|
float get_latitude_velocity() const;
|
|
|
|
float get_longitude_velocity() const;
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2013-03-27 02:09:04 -03:00
|
|
|
// get_velocity - returns current velocity in cm/s
|
2013-04-21 08:04:47 -03:00
|
|
|
Vector3f get_velocity() const { return _velocity; }
|
2013-03-27 02:09:04 -03:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// set velocity in latitude & longitude directions (in cm/s)
|
2013-03-19 05:51:16 -03:00
|
|
|
void set_velocity_xy(float x, float y);
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
//
|
|
|
|
// Z Axis methods
|
|
|
|
//
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// set time constant - set timeconstant used by complementary filter
|
2013-03-19 05:51:16 -03:00
|
|
|
void set_time_constant_z( float time_constant_in_seconds );
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// altitude_ok, position_ok - true if inertial based altitude and position can be trusted
|
2013-04-21 08:04:47 -03:00
|
|
|
bool altitude_ok() const { return true; }
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// check_baro - check if new baro readings have arrived and use them to correct vertical accelerometer offsets
|
2013-03-19 05:51:16 -03:00
|
|
|
void check_baro();
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// correct_with_baro - modifies accelerometer offsets using barometer. dt is time since last baro reading
|
2013-03-19 05:51:16 -03:00
|
|
|
void correct_with_baro(float baro_alt, float dt);
|
2012-11-05 00:31:02 -04:00
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
// get_altitude - get latest altitude estimate in cm
|
2013-04-21 08:04:47 -03:00
|
|
|
float get_altitude() const { return _position_base.z + _position_correction.z; }
|
2013-03-19 05:51:16 -03:00
|
|
|
void set_altitude( float new_altitude);
|
2012-12-09 11:43:11 -04:00
|
|
|
|
|
|
|
// get_velocity_z - get latest climb rate (in cm/s)
|
2013-04-21 08:04:47 -03:00
|
|
|
float get_velocity_z() const { return _velocity.z; }
|
2013-03-19 05:51:16 -03:00
|
|
|
void set_velocity_z( float new_velocity );
|
2012-12-09 11:43:11 -04:00
|
|
|
|
|
|
|
// class level parameters
|
|
|
|
static const struct AP_Param::GroupInfo var_info[];
|
|
|
|
|
|
|
|
// public variables
|
|
|
|
Vector3f accel_correction_ef; // earth frame accelerometer corrections. here for logging purposes only
|
|
|
|
|
2013-09-19 03:56:23 -03:00
|
|
|
// set_position_xy - sets inertial navigation position to given xy coordinates from home
|
|
|
|
void set_position_xy(float pos_x, float pos_y);
|
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
protected:
|
|
|
|
|
2013-03-19 05:51:16 -03:00
|
|
|
void update_gains(); // update_gains - update gains from time constant (given in seconds)
|
2012-12-09 11:43:11 -04:00
|
|
|
|
2013-09-19 03:56:23 -03:00
|
|
|
// structure for holding flags
|
|
|
|
struct InertialNav_flags {
|
|
|
|
uint8_t gps_glitching : 1; // 1 if glitch detector was previously indicating a gps glitch
|
|
|
|
} _flags;
|
|
|
|
|
2012-12-09 11:43:11 -04:00
|
|
|
AP_AHRS* _ahrs; // pointer to ahrs object
|
|
|
|
AP_Baro* _baro; // pointer to barometer
|
2013-09-19 03:56:23 -03:00
|
|
|
GPS*& _gps; // pointer to gps
|
2012-12-09 11:43:11 -04:00
|
|
|
|
|
|
|
// XY Axis specific variables
|
|
|
|
bool _xy_enabled; // xy position estimates enabled
|
|
|
|
AP_Float _time_constant_xy; // time constant for horizontal corrections
|
|
|
|
float _k1_xy; // gain for horizontal position correction
|
|
|
|
float _k2_xy; // gain for horizontal velocity correction
|
|
|
|
float _k3_xy; // gain for horizontal accelerometer offset correction
|
|
|
|
uint32_t _gps_last_update; // system time of last gps update
|
|
|
|
uint32_t _gps_last_time; // time of last gps update according to the gps itself
|
|
|
|
uint8_t _historic_xy_counter; // counter used to slow saving of position estimates for later comparison to gps
|
|
|
|
AP_BufferFloat_Size5 _hist_position_estimate_x; // buffer of historic accel based position to account for lag
|
|
|
|
AP_BufferFloat_Size5 _hist_position_estimate_y; // buffer of historic accel based position to account for lag
|
|
|
|
int32_t _base_lat; // base latitude
|
|
|
|
int32_t _base_lon; // base longitude
|
2013-08-07 11:00:09 -03:00
|
|
|
float _lon_to_cm_scaling; // conversion of longitude to centimeters
|
2012-12-09 11:43:11 -04:00
|
|
|
|
|
|
|
// Z Axis specific variables
|
|
|
|
AP_Float _time_constant_z; // time constant for vertical corrections
|
|
|
|
float _k1_z; // gain for vertical position correction
|
|
|
|
float _k2_z; // gain for vertical velocity correction
|
|
|
|
float _k3_z; // gain for vertical accelerometer offset correction
|
2013-08-07 11:00:09 -03:00
|
|
|
uint32_t _baro_last_update; // time of last barometer update
|
2012-12-09 11:43:11 -04:00
|
|
|
AP_BufferFloat_Size15 _hist_position_estimate_z; // buffer of historic accel based altitudes to account for lag
|
|
|
|
|
|
|
|
// general variables
|
|
|
|
Vector3f _position_base; // position estimate
|
|
|
|
Vector3f _position_correction; // sum of correction to _comp_h from delayed 1st order samples
|
|
|
|
Vector3f _velocity; // latest velocity estimate (integrated from accelerometer values)
|
2013-01-05 22:59:09 -04:00
|
|
|
Vector3f _position_error;
|
2013-09-19 03:56:23 -03:00
|
|
|
|
|
|
|
// GPS Glitch detector
|
|
|
|
GPS_Glitch& _glitch_detector;
|
2012-11-05 00:31:02 -04:00
|
|
|
};
|
|
|
|
|
2012-11-07 09:24:00 -04:00
|
|
|
#endif // __AP_INERTIALNAV_H__
|