2014-01-01 21:15:58 -04:00
|
|
|
#ifndef __AP_AHRS_NAVEKF_H__
|
|
|
|
#define __AP_AHRS_NAVEKF_H__
|
|
|
|
/*
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* NavEKF based AHRS (Attitude Heading Reference System) interface for
|
|
|
|
* ArduPilot
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <AP_AHRS.h>
|
|
|
|
|
|
|
|
#if HAL_CPU_CLASS >= HAL_CPU_CLASS_150
|
|
|
|
#include <AP_NavEKF.h>
|
|
|
|
|
|
|
|
#define AP_AHRS_NAVEKF_AVAILABLE 1
|
|
|
|
|
|
|
|
class AP_AHRS_NavEKF : public AP_AHRS_DCM
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// Constructor
|
2014-01-02 02:06:30 -04:00
|
|
|
AP_AHRS_NavEKF(AP_InertialSensor &ins, AP_Baro &baro, GPS *&gps) :
|
|
|
|
AP_AHRS_DCM(ins, baro, gps),
|
2014-01-01 21:15:58 -04:00
|
|
|
EKF(this, baro),
|
2014-01-01 22:05:28 -04:00
|
|
|
_baro(baro),
|
|
|
|
ekf_started(false),
|
|
|
|
startup_delay_ms(5000)
|
2014-01-01 21:15:58 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
// return the smoothed gyro vector corrected for drift
|
|
|
|
const Vector3f get_gyro(void) const;
|
|
|
|
const Matrix3f &get_dcm_matrix(void) const;
|
|
|
|
|
|
|
|
// return the current drift correction integrator value
|
|
|
|
const Vector3f &get_gyro_drift(void) const;
|
|
|
|
|
|
|
|
void update(void);
|
|
|
|
void reset(bool recover_eulers = false);
|
|
|
|
|
2014-01-05 23:19:43 -04:00
|
|
|
void set_correct_centrifugal(bool setting);
|
|
|
|
|
2014-01-01 21:15:58 -04:00
|
|
|
// reset the current attitude, used on new IMU calibration
|
|
|
|
void reset_attitude(const float &roll, const float &pitch, const float &yaw);
|
|
|
|
|
|
|
|
// dead-reckoning support
|
|
|
|
bool get_position(struct Location &loc);
|
|
|
|
|
|
|
|
// status reporting of estimated error
|
|
|
|
float get_error_rp(void);
|
|
|
|
float get_error_yaw(void);
|
|
|
|
|
|
|
|
// return a wind estimation vector, in m/s
|
|
|
|
Vector3f wind_estimate(void);
|
|
|
|
|
|
|
|
// return an airspeed estimate if available. return true
|
|
|
|
// if we have an estimate
|
|
|
|
bool airspeed_estimate(float *airspeed_ret);
|
|
|
|
|
|
|
|
// true if compass is being used
|
|
|
|
bool use_compass(void);
|
|
|
|
|
|
|
|
const NavEKF &get_NavEKF(void) const { return EKF; }
|
2014-01-06 03:40:03 -04:00
|
|
|
NavEKF* get_EKF(void) { return &EKF; }
|
2014-01-01 21:15:58 -04:00
|
|
|
|
2014-01-01 22:47:40 -04:00
|
|
|
// return secondary attitude solution if available, as eulers in radians
|
|
|
|
bool get_secondary_attitude(Vector3f &eulers);
|
|
|
|
|
|
|
|
// return secondary position solution if available
|
|
|
|
bool get_secondary_position(struct Location &loc);
|
|
|
|
|
2014-01-01 23:25:41 -04:00
|
|
|
// EKF has a better ground speed vector estimate
|
|
|
|
Vector2f groundspeed_vector(void);
|
|
|
|
|
2014-01-02 07:06:10 -04:00
|
|
|
// set home location
|
|
|
|
void set_home(int32_t lat, int32_t lng, int32_t alt_cm);
|
|
|
|
|
2014-01-03 20:15:34 -04:00
|
|
|
bool have_inertial_nav(void) const;
|
|
|
|
|
|
|
|
Vector3f get_velocity_NED(void);
|
|
|
|
Vector3f get_relative_position_NED(void);
|
|
|
|
|
2014-01-03 21:39:20 -04:00
|
|
|
void set_ekf_use(bool setting) { _ekf_use.set(setting); }
|
|
|
|
|
2014-01-01 21:15:58 -04:00
|
|
|
private:
|
2014-01-03 20:15:34 -04:00
|
|
|
bool using_EKF(void) const { return ekf_started && _ekf_use && EKF.healthy(); }
|
2014-01-02 01:16:29 -04:00
|
|
|
|
2014-01-01 21:15:58 -04:00
|
|
|
NavEKF EKF;
|
|
|
|
AP_Baro &_baro;
|
2014-01-01 22:05:28 -04:00
|
|
|
bool ekf_started;
|
|
|
|
Matrix3f _dcm_matrix;
|
2014-01-01 22:47:40 -04:00
|
|
|
Vector3f _dcm_attitude;
|
2014-01-01 22:05:28 -04:00
|
|
|
const uint16_t startup_delay_ms;
|
|
|
|
uint32_t start_time_ms;
|
2014-01-01 21:15:58 -04:00
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // __AP_AHRS_NAVEKF_H__
|