From 37fb028532c28eac4266d1d5510a2e143456f0a1 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Mon, 7 Oct 2019 17:00:11 +1100 Subject: [PATCH] AP_GPS: improved checking for valid yaw for moving baseline and fixed check for carrSolnFixed --- libraries/AP_GPS/AP_GPS_UBLOX.cpp | 22 ++++++++++++++-------- libraries/AP_GPS/AP_GPS_UBLOX.h | 3 ++- 2 files changed, 16 insertions(+), 9 deletions(-) diff --git a/libraries/AP_GPS/AP_GPS_UBLOX.cpp b/libraries/AP_GPS/AP_GPS_UBLOX.cpp index 48f6db7a4d..ef49499deb 100644 --- a/libraries/AP_GPS/AP_GPS_UBLOX.cpp +++ b/libraries/AP_GPS/AP_GPS_UBLOX.cpp @@ -1036,21 +1036,27 @@ AP_GPS_UBLOX::_parse_gps(void) { const Vector3f &offset0 = gps._antenna_offset[0].get(); const Vector3f &offset1 = gps._antenna_offset[1].get(); + // note that we require the yaw to come from a fixed solution, not a float solution + // yaw from a float solution would only be acceptable with a very large separation between + // GPS modules const uint32_t valid_mask = static_cast(RELPOSNED::relPosHeadingValid) | static_cast(RELPOSNED::relPosValid) | static_cast(RELPOSNED::gnssFixOK) | static_cast(RELPOSNED::isMoving) | - (2 << static_cast(RELPOSNED::carrSoln)); // require fixed ambiguity + static_cast(RELPOSNED::carrSolnFixed); const uint32_t invalid_mask = static_cast(RELPOSNED::refPosMiss) | - static_cast(RELPOSNED::refObsMiss); + static_cast(RELPOSNED::refObsMiss) | + static_cast(RELPOSNED::carrSolnFloat); + const float offset_dist = (offset0 - offset1).length(); + const float rel_dist = _buffer.relposned.relPosLength * 1.0e-2; + const float strict_length_error_allowed = 0.2; // allow for up to 20% error + const float min_separation = 0.05; if (((_buffer.relposned.flags & valid_mask) == valid_mask) && - ((_buffer.relposned.flags & invalid_mask) == 0) -#if defined(STRICT_LENGTH_CHECK) - // force the estimated position to be within - && (fabsf(offset0.distance(offset1) - (_buffer.relposned.relPosLength * 1e-2)) < STRICT_LENGTH_CHECK) -#endif // defined(STRICT_LENGTH_CHECK) - ) { + ((_buffer.relposned.flags & invalid_mask) == 0) && + rel_dist > min_separation && + offset_dist > min_separation && + fabsf(offset_dist - rel_dist) / MIN(offset_dist, rel_dist) < strict_length_error_allowed) { float rotation_offset_rad; if (offset0.is_zero()) { rotation_offset_rad = Vector2f(offset1.x, offset1.y).angle(); diff --git a/libraries/AP_GPS/AP_GPS_UBLOX.h b/libraries/AP_GPS/AP_GPS_UBLOX.h index 4cb4b99a12..90b35785ed 100644 --- a/libraries/AP_GPS/AP_GPS_UBLOX.h +++ b/libraries/AP_GPS/AP_GPS_UBLOX.h @@ -480,7 +480,8 @@ private: gnssFixOK = 1U << 0, diffSoln = 1U << 1, relPosValid = 1U << 2, - carrSoln = 1U << 3, + carrSolnFloat = 1U << 3, + carrSolnFixed = 1U << 4, isMoving = 1U << 5, refPosMiss = 1U << 6, refObsMiss = 1U << 7,