From efd6d6dc70ca707f123adedb35ec0872ffd2c6fd Mon Sep 17 00:00:00 2001 From: Randy Mackay Date: Thu, 5 Jun 2014 16:36:30 +0900 Subject: [PATCH] AC_WPNav: spline div by zero fix Also add check for straight line navigation to ensure speed is not reduced below zero when it hits the leash limit Also minor formatting changes --- libraries/AC_WPNav/AC_WPNav.cpp | 13 ++++++++++--- libraries/AC_WPNav/AC_WPNav.h | 4 ++-- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/libraries/AC_WPNav/AC_WPNav.cpp b/libraries/AC_WPNav/AC_WPNav.cpp index e119ff105a..fdbb7a726e 100644 --- a/libraries/AC_WPNav/AC_WPNav.cpp +++ b/libraries/AC_WPNav/AC_WPNav.cpp @@ -104,6 +104,7 @@ AC_WPNav::AC_WPNav(const AP_InertialNav& inav, const AP_AHRS& ahrs, AC_PosContro _track_leash_length(0.0), _slow_down_dist(0.0), _spline_time(0.0), + _spline_time_scale(0.0), _spline_vel_scaler(0.0), _yaw(0.0) { @@ -407,7 +408,6 @@ void AC_WPNav::advance_wp_target_along_track(float dt) float track_covered; // distance (in cm) along the track that the vehicle has traveled. Measured by drawing a perpendicular line from the track to the vehicle. Vector3f track_error; // distance error (in cm) from the track_covered position (i.e. closest point on the line to the vehicle) and the vehicle float track_desired_max; // the farthest distance (in cm) along the track that the leash will allow - float track_desired_temp = _track_desired; float track_leash_slack; // additional distance (in cm) along the track from our track_covered position that our leash will allow bool reached_leash_limit = false; // true when track has reached leash limit and we need to slow down the target point @@ -494,9 +494,13 @@ void AC_WPNav::advance_wp_target_along_track(float dt) if (!reached_leash_limit) { _track_desired += _limited_speed_xy_cms * dt; - if (_track_desired > track_desired_max){ + // reduce speed if we reach end of leash + if (_track_desired > track_desired_max) { _track_desired = track_desired_max; _limited_speed_xy_cms -= 2.0f * _track_accel * dt; + if (_limited_speed_xy_cms < 0.0f) { + _limited_speed_xy_cms = 0.0f; + } } } @@ -809,7 +813,10 @@ void AC_WPNav::advance_spline_target_along_track(float dt) } // scale the spline_time by the velocity we've calculated vs the velocity that came out of the spline calculator - float _spline_time_scale = _spline_vel_scaler/target_vel.length(); + float target_vel_length = target_vel.length(); + if (target_vel_length != 0.0f) { + _spline_time_scale = _spline_vel_scaler/target_vel_length; + } // update target position _pos_control.set_pos_target(target_pos); diff --git a/libraries/AC_WPNav/AC_WPNav.h b/libraries/AC_WPNav/AC_WPNav.h index 2bf61200a4..c95666134b 100644 --- a/libraries/AC_WPNav/AC_WPNav.h +++ b/libraries/AC_WPNav/AC_WPNav.h @@ -289,8 +289,8 @@ protected: float _slow_down_dist; // vehicle should begin to slow down once it is within this distance from the destination // spline variables - float _spline_time; // current spline time between origin and destination - float _spline_time_scale; // current spline time between origin and destination + float _spline_time; // current spline time between origin and destination + float _spline_time_scale; // current spline time between origin and destination Vector3f _spline_origin_vel; // the target velocity vector at the origin of the spline segment Vector3f _spline_destination_vel;// the target velocity vector at the destination point of the spline segment Vector3f _hermite_spline_solution[4]; // array describing spline path between origin and destination