Copter: pre-arm check of EKF pos and vel variances

This commit is contained in:
Randy Mackay 2021-03-10 14:26:16 +09:00
parent 49486b7cea
commit e0a8baccfd

View File

@ -554,13 +554,23 @@ bool AP_Arming_Copter::mandatory_gps_checks(bool display_failure)
} }
} }
// check EKF compass variance is below failsafe threshold // check EKF's compass, position and velocity variances are below failsafe threshold
float vel_variance, pos_variance, hgt_variance, tas_variance; if (copter.g.fs_ekf_thresh > 0.0f) {
Vector3f mag_variance; float vel_variance, pos_variance, hgt_variance, tas_variance;
ahrs.get_variances(vel_variance, pos_variance, hgt_variance, mag_variance, tas_variance); Vector3f mag_variance;
if (copter.g.fs_ekf_thresh > 0 && mag_variance.length() >= copter.g.fs_ekf_thresh) { ahrs.get_variances(vel_variance, pos_variance, hgt_variance, mag_variance, tas_variance);
check_failed(display_failure, "EKF compass variance"); if (mag_variance.length() >= copter.g.fs_ekf_thresh) {
return false; check_failed(display_failure, "EKF compass variance");
return false;
}
if (pos_variance >= copter.g.fs_ekf_thresh) {
check_failed(display_failure, "EKF position variance");
return false;
}
if (vel_variance >= copter.g.fs_ekf_thresh) {
check_failed(display_failure, "EKF velocity variance");
return false;
}
} }
// check home and EKF origin are not too far // check home and EKF origin are not too far