Skip to content

Commit

Permalink
[WIP] ekf2: setEkfGlobalOrigin respect current height reference and v…
Browse files Browse the repository at this point in the history
…ertical position aiding
  • Loading branch information
dagar committed Feb 15, 2024
1 parent 84a7d42 commit 1b64581
Showing 1 changed file with 24 additions and 26 deletions.
50 changes: 24 additions & 26 deletions src/modules/ekf2/EKF/ekf_helper.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -171,10 +171,11 @@ bool Ekf::isHeightResetRequired() const
return (continuous_bad_accel_hgt || hgt_fusion_timeout);
}

void Ekf::resetHorizontalPositionToExternal(const Vector2f &new_horiz_pos, float horiz_accuracy) {
_information_events.flags.reset_pos_to_ext_obs = true;
ECL_INFO("reset position to external observation");
resetHorizontalPositionTo(new_horiz_pos, sq(horiz_accuracy));
void Ekf::resetHorizontalPositionToExternal(const Vector2f &new_horiz_pos, float horiz_accuracy)
{
_information_events.flags.reset_pos_to_ext_obs = true;
ECL_INFO("reset position to external observation");
resetHorizontalPositionTo(new_horiz_pos, sq(horiz_accuracy));
}

void Ekf::resetVerticalPositionTo(const float new_vert_pos, float new_vert_pos_var)
Expand Down Expand Up @@ -290,9 +291,9 @@ bool Ekf::setEkfGlobalOrigin(const double latitude, const double longitude, cons
{
// sanity check valid latitude/longitude and altitude anywhere between the Mariana Trench and edge of Space
if (PX4_ISFINITE(latitude) && (abs(latitude) <= 90)
&& PX4_ISFINITE(longitude) && (abs(longitude) <= 180)
&& PX4_ISFINITE(altitude) && (altitude > -12'000.f) && (altitude < 100'000.f)
) {
&& PX4_ISFINITE(longitude) && (abs(longitude) <= 180)
&& PX4_ISFINITE(altitude) && (altitude > -12'000.f) && (altitude < 100'000.f)
) {
bool current_pos_available = false;
double current_lat = static_cast<double>(NAN);
double current_lon = static_cast<double>(NAN);
Expand All @@ -303,7 +304,7 @@ bool Ekf::setEkfGlobalOrigin(const double latitude, const double longitude, cons
current_pos_available = true;
}

const float gps_alt_ref_prev = getEkfGlobalOriginAltitude();
const float gps_alt_ref_prev = _gps_alt_ref;

// reinitialize map projection to latitude, longitude, altitude, and reset position
_pos_ref.initReference(latitude, longitude, _time_delayed_us);
Expand All @@ -321,39 +322,36 @@ bool Ekf::setEkfGlobalOrigin(const double latitude, const double longitude, cons

_wmm_gps_time_last_set = _time_delayed_us;
}

#endif // CONFIG_EKF2_MAGNETOMETER

_gpos_origin_eph = eph;
_gpos_origin_epv = epv;

_NED_origin_initialised = true;

// minimum change in position or height that triggers a reset
static constexpr float MIN_RESET_DIST_M = 0.01f;

if (current_pos_available) {
// reset horizontal position
// reset horizontal position if we already have a global origin
Vector2f position = _pos_ref.project(current_lat, current_lon);

if (Vector2f(position - Vector2f(_state.pos)).longerThan(MIN_RESET_DIST_M)) {
resetHorizontalPositionTo(position);
}
resetHorizontalPositionTo(position);
}

// reset vertical position (if there's any change)
if (fabsf(altitude - gps_alt_ref_prev) > MIN_RESET_DIST_M) {
// determine current z
float current_alt = -_state.pos(2) + gps_alt_ref_prev;
if (PX4_ISFINITE(gps_alt_ref_prev) && isVerticalPositionAidingActive()) {
// reset vertical position if we already had a GPS altitude reference

#if defined(CONFIG_EKF2_GNSS)
const float gps_hgt_bias = _gps_hgt_b_est.getBias();
#endif // CONFIG_EKF2_GNSS
resetVerticalPositionTo(_gps_alt_ref - current_alt);
if (_height_sensor_ref == HeightSensor::GNSS) {
// determine current z
float current_alt = -_state.pos(2) + gps_alt_ref_prev;
resetVerticalPositionTo(_gps_alt_ref - current_alt);

} else {
#if defined(CONFIG_EKF2_GNSS)
// preserve GPS height bias
_gps_hgt_b_est.setBias(gps_hgt_bias);
// adjust existing GPS height bias
const float gps_hgt_bias = _gps_hgt_b_est.getBias();
float delta_z = _gps_alt_ref - gps_alt_ref_prev;
_gps_hgt_b_est.setBias(gps_hgt_bias + delta_z);
#endif // CONFIG_EKF2_GNSS
}
}

return true;
Expand Down

0 comments on commit 1b64581

Please sign in to comment.