2013-09-19 03:52:13 -03:00
|
|
|
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
|
|
|
|
|
|
|
|
/// @file GPS_Glitch.h
|
|
|
|
/// @brief GPS Glitch protection
|
|
|
|
|
|
|
|
#ifndef __GPS_GLITCH_H__
|
|
|
|
#define __GPS_GLITCH_H__
|
|
|
|
|
|
|
|
#include <AP_HAL.h>
|
|
|
|
|
|
|
|
#include <inttypes.h>
|
|
|
|
#include <AP_Progmem.h>
|
|
|
|
#include <AP_Math.h>
|
|
|
|
#include <AP_GPS.h>
|
|
|
|
|
2013-11-13 08:33:34 -04:00
|
|
|
#define GPS_GLITCH_ACCEL_MAX_CMSS 1000.0f // vehicle can accelerate at up to 5m/s/s in any direction
|
2013-12-08 22:42:03 -04:00
|
|
|
#define GPS_GLITCH_RADIUS_CM 200.0f // gps movement within 2m of current position are always ok
|
2013-09-19 03:52:13 -03:00
|
|
|
|
|
|
|
/// @class GPS_Glitch
|
|
|
|
/// @brief GPS Glitch protection class
|
|
|
|
class GPS_Glitch
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// constructor
|
|
|
|
GPS_Glitch(GPS*& gps);
|
|
|
|
|
2013-09-22 23:48:27 -03:00
|
|
|
// check_position - checks latest gps position against last know position, velocity and maximum acceleration and updates glitching flag
|
2013-09-19 03:52:13 -03:00
|
|
|
void check_position();
|
|
|
|
|
|
|
|
// enable - enable or disable gps sanity checking
|
2013-09-23 00:04:09 -03:00
|
|
|
void enable(bool true_or_false) { _enabled = true_or_false; }
|
2013-09-19 03:52:13 -03:00
|
|
|
|
|
|
|
// enabled - returns true if glitch detection is enabled
|
2013-09-23 05:08:40 -03:00
|
|
|
bool enabled() const { return _enabled; }
|
2013-09-19 03:52:13 -03:00
|
|
|
|
|
|
|
// glitching - returns true if we are experiencing a glitch
|
2013-09-23 05:08:40 -03:00
|
|
|
bool glitching() const { return _flags.glitching; }
|
2013-09-19 03:52:13 -03:00
|
|
|
|
|
|
|
// last_good_update - returns system time of the last good update
|
2013-09-23 05:08:40 -03:00
|
|
|
uint32_t last_good_update() const { return _last_good_update; }
|
2013-09-19 03:52:13 -03:00
|
|
|
|
2013-09-23 00:04:09 -03:00
|
|
|
// class level parameters
|
|
|
|
static const struct AP_Param::GroupInfo var_info[];
|
|
|
|
|
2013-09-19 03:52:13 -03:00
|
|
|
private:
|
|
|
|
|
|
|
|
/// external dependencies
|
|
|
|
GPS*& _gps; // pointer to gps
|
|
|
|
|
|
|
|
/// structure for holding flags
|
|
|
|
struct GPS_Glitch_flags {
|
|
|
|
uint8_t initialised : 1; // 1 if we have received at least one good gps lock
|
|
|
|
uint8_t glitching : 1; // 1 if we are experiencing a gps glitch
|
|
|
|
} _flags;
|
|
|
|
|
2013-09-23 00:04:09 -03:00
|
|
|
// parameters
|
|
|
|
AP_Int8 _enabled; // top level enable/disable control
|
2013-10-09 01:02:14 -03:00
|
|
|
AP_Float _radius_cm; // radius in cm within which all new positions from GPS are accepted
|
|
|
|
AP_Float _accel_max_cmss; // vehicles maximum acceleration in cm/s/s
|
2013-09-23 00:04:09 -03:00
|
|
|
|
2013-09-19 03:52:13 -03:00
|
|
|
// gps sanity check variables
|
|
|
|
uint32_t _last_good_update; // system time of last gps update that passed checks
|
|
|
|
int32_t _last_good_lat; // last good latitude reported by the gps
|
|
|
|
int32_t _last_good_lon; // last good longitude reported by the gps
|
|
|
|
Vector2f _last_good_vel; // last good velocity reported by the gps in cm/s in lat and lon directions
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // __GPS_H__
|