AP_GPS: fixed yaw error when one GPS has zero position
the M_PI correction was only valid for one zero side. Much simpler to always calculate difference
This commit is contained in:
parent
0b8c8d744f
commit
ac51e2b02b
@ -1122,14 +1122,8 @@ AP_GPS_UBLOX::_parse_gps(void)
|
|||||||
offset_dist > min_separation &&
|
offset_dist > min_separation &&
|
||||||
fabsf(offset_dist - rel_dist) / MIN(offset_dist, rel_dist) < strict_length_error_allowed) {
|
fabsf(offset_dist - rel_dist) / MIN(offset_dist, rel_dist) < strict_length_error_allowed) {
|
||||||
float rotation_offset_rad;
|
float rotation_offset_rad;
|
||||||
if (offset0.is_zero()) {
|
|
||||||
rotation_offset_rad = Vector2f(offset1.x, offset1.y).angle();
|
|
||||||
} else if (offset1.is_zero()) {
|
|
||||||
rotation_offset_rad = Vector2f(offset0.x, offset0.y).angle();
|
|
||||||
} else {
|
|
||||||
const Vector3f diff = offset0 - offset1;
|
const Vector3f diff = offset0 - offset1;
|
||||||
rotation_offset_rad = Vector2f(diff.x, diff.y).angle();
|
rotation_offset_rad = Vector2f(diff.x, diff.y).angle();
|
||||||
}
|
|
||||||
if (state.instance != 0) {
|
if (state.instance != 0) {
|
||||||
rotation_offset_rad += M_PI;
|
rotation_offset_rad += M_PI;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user