mirror of https://github.com/ArduPilot/ardupilot
AP_GPS: Ignore Z-axis difference while dual GPS difference check
This commit is contained in:
parent
88957235d2
commit
be808343fa
|
@ -1484,13 +1484,18 @@ bool AP_GPS::all_consistent(float &distance) const
|
||||||
{
|
{
|
||||||
// return true immediately if only one valid receiver
|
// return true immediately if only one valid receiver
|
||||||
if (num_instances <= 1 ||
|
if (num_instances <= 1 ||
|
||||||
drivers[0] == nullptr || params[0].type == GPS_TYPE_NONE) {
|
drivers[0] == nullptr || params[0].type == GPS_TYPE_NONE || GPS_MAX_INSTANCES <= 1) {
|
||||||
distance = 0;
|
distance = 0;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// calculate distance
|
// calculate distance
|
||||||
distance = state[0].location.get_distance_NED(state[1].location).length();
|
if (state[0].have_altitude && state[1].have_altitude) {
|
||||||
|
distance = state[0].location.get_distance_NED(state[1].location).length();
|
||||||
|
} else {
|
||||||
|
distance = state[0].location.get_distance_NE(state[1].location).length();
|
||||||
|
}
|
||||||
|
|
||||||
// success if distance is within 50m
|
// success if distance is within 50m
|
||||||
return (distance < 50);
|
return (distance < 50);
|
||||||
}
|
}
|
||||||
|
|
|
@ -216,6 +216,7 @@ public:
|
||||||
bool have_vertical_accuracy; ///< does GPS give vertical position accuracy? Set to true only once available.
|
bool have_vertical_accuracy; ///< does GPS give vertical position accuracy? Set to true only once available.
|
||||||
bool have_gps_yaw; ///< does GPS give yaw? Set to true only once available.
|
bool have_gps_yaw; ///< does GPS give yaw? Set to true only once available.
|
||||||
bool have_gps_yaw_accuracy; ///< does the GPS give a heading accuracy estimate? Set to true only once available
|
bool have_gps_yaw_accuracy; ///< does the GPS give a heading accuracy estimate? Set to true only once available
|
||||||
|
bool have_altitude; ///< does GPS give altitude? Set to false only if GPS instance does not provide altitude.
|
||||||
float undulation; //<height that WGS84 is above AMSL at the current location
|
float undulation; //<height that WGS84 is above AMSL at the current location
|
||||||
bool have_undulation; ///<do we have a value for the undulation
|
bool have_undulation; ///<do we have a value for the undulation
|
||||||
uint32_t last_gps_time_ms; ///< the system time we got the last GPS timestamp, milliseconds
|
uint32_t last_gps_time_ms; ///< the system time we got the last GPS timestamp, milliseconds
|
||||||
|
|
|
@ -72,6 +72,7 @@ void AP_GPS_MAV::handle_msg(const mavlink_message_t &msg)
|
||||||
if (have_alt) {
|
if (have_alt) {
|
||||||
loc.alt = packet.alt * 100; // convert to centimeters
|
loc.alt = packet.alt * 100; // convert to centimeters
|
||||||
}
|
}
|
||||||
|
state.have_altitude = have_alt;
|
||||||
state.location = loc;
|
state.location = loc;
|
||||||
|
|
||||||
if (have_hdop) {
|
if (have_hdop) {
|
||||||
|
|
|
@ -50,6 +50,7 @@ AP_GPS_Backend::AP_GPS_Backend(AP_GPS &_gps, AP_GPS::Params &_params, AP_GPS::GP
|
||||||
state.have_speed_accuracy = false;
|
state.have_speed_accuracy = false;
|
||||||
state.have_horizontal_accuracy = false;
|
state.have_horizontal_accuracy = false;
|
||||||
state.have_vertical_accuracy = false;
|
state.have_vertical_accuracy = false;
|
||||||
|
state.have_altitude = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue