AC_WPNav: stop track_desired from moving backwards

This commit is contained in:
Randy Mackay 2013-04-06 23:32:06 +09:00
parent c6b68c7843
commit 35001619f0
2 changed files with 22 additions and 6 deletions

View File

@ -126,6 +126,9 @@ void AC_WPNav::translate_loiter_target_movements(float nav_dt)
_target.x = curr_pos.x + MAX_LOITER_OVERSHOOT * distance_err.x/distance; _target.x = curr_pos.x + MAX_LOITER_OVERSHOOT * distance_err.x/distance;
_target.y = curr_pos.y + MAX_LOITER_OVERSHOOT * distance_err.y/distance; _target.y = curr_pos.y + MAX_LOITER_OVERSHOOT * distance_err.y/distance;
} }
// debug -- remove me!
//hal.console->printf_P(PSTR("\nLTarX:%4.2f Y:%4.2f Z:%4.2f\n"),_target.x, _target.y, _target.z);
} }
/// get_distance_to_target - get horizontal distance to loiter target in cm /// get_distance_to_target - get horizontal distance to loiter target in cm
@ -185,6 +188,11 @@ void AC_WPNav::set_origin_and_destination(const Vector3f& origin, const Vector3f
_pos_delta_unit = pos_delta/_track_length; _pos_delta_unit = pos_delta/_track_length;
_track_desired = 0; _track_desired = 0;
// debug -- remove me!
//hal.console->printf_P(PSTR("\nSOAD: Ox:%4.2f y:%4.2f z:%4.2f Dx:%4.2f y:%4.2f z:%4.2f\n"),_origin.x, _origin.y, _origin.z, _destination.x, _destination.y, _destination.z);
//hal.console->printf_P(PSTR("\nVTS:%4.2f TL:%4.2f\n"),_vert_track_scale, _track_length);
//hal.console->printf_P(PSTR("\nPDP: x:%4.2f y:%4.2f z:%4.2f\n"),_pos_delta_unit.x, _pos_delta_unit.y, _pos_delta_unit.z);
} }
/// advance_target_along_track - move target location along track from origin to destination /// advance_target_along_track - move target location along track from origin to destination
@ -194,6 +202,7 @@ void AC_WPNav::advance_target_along_track(float velocity_cms, float dt)
float track_covered; float track_covered;
float track_error; float track_error;
float track_desired_max; float track_desired_max;
float track_desired_temp = _track_desired;
float track_extra_max; float track_extra_max;
float curr_delta_length; float curr_delta_length;
//float alt_error; //float alt_error;
@ -211,6 +220,8 @@ void AC_WPNav::advance_target_along_track(float velocity_cms, float dt)
// alt_error = fabsf(_origin.z + _pos_delta_unit.z * track_covered - curr.z); // alt_error = fabsf(_origin.z + _pos_delta_unit.z * track_covered - curr.z);
track_extra_max = safe_sqrt(WPINAV_MAX_POS_ERROR*WPINAV_MAX_POS_ERROR - track_error*track_error); track_extra_max = safe_sqrt(WPINAV_MAX_POS_ERROR*WPINAV_MAX_POS_ERROR - track_error*track_error);
// debug -- remove me!
//hal.console->printf_P(PSTR("\nvel_cms:%4.2f Tcov:%4.2f\n"),velocity_cms, track_covered);
// we could save a sqrt by doing the following and not assigning track_error // we could save a sqrt by doing the following and not assigning track_error
// track_extra_max = safe_sqrt(WPINAV_MAX_POS_ERROR*WPINAV_MAX_POS_ERROR - (curr_delta_length*curr_delta_length - track_covered*track_covered)); // track_extra_max = safe_sqrt(WPINAV_MAX_POS_ERROR*WPINAV_MAX_POS_ERROR - (curr_delta_length*curr_delta_length - track_covered*track_covered));
@ -218,20 +229,25 @@ void AC_WPNav::advance_target_along_track(float velocity_cms, float dt)
track_desired_max = track_covered + track_extra_max; track_desired_max = track_covered + track_extra_max;
// advance the current target // advance the current target
_track_desired += velocity_cms * dt; track_desired_temp += velocity_cms * dt;
// debug -- remove me!
//hal.console->printf_P(PSTR("\nTdes:%4.2f TdesMx:%4.2f\n"),track_desired_temp, track_desired_max);
// constrain the target from moving too far // constrain the target from moving too far
if( _track_desired > track_desired_max ) { if( track_desired_temp > track_desired_max ) {
_track_desired = track_desired_max; track_desired_temp = track_desired_max;
} }
// do not let desired point go past the end of the segment // do not let desired point go past the end of the segment
_track_desired = constrain(_track_desired, 0, _track_length); track_desired_temp = constrain(track_desired_temp, 0, _track_length);
_track_desired = max(_track_desired, track_desired_temp);
// recalculate the desired position // recalculate the desired position
_target.x = _origin.x + _pos_delta_unit.x * _track_desired; _target.x = _origin.x + _pos_delta_unit.x * _track_desired;
_target.y = _origin.y + _pos_delta_unit.y * _track_desired; _target.y = _origin.y + _pos_delta_unit.y * _track_desired;
_target.z = _origin.z + (_pos_delta_unit.z * _track_desired)/_vert_track_scale; _target.z = _origin.z + (_pos_delta_unit.z * _track_desired)/_vert_track_scale;
// we could save a divide by having a variable for 1/_vert_track_scale // we could save a divide by having a variable for 1/_vert_track_scale
//hal.console->printf_P(PSTR("\nTarX:%4.2f Y:%4.2f Z:%4.2f\n"),_target.x, _target.y, _target.z);
} }
/// get_distance_to_destination - get horizontal distance to destination in cm /// get_distance_to_destination - get horizontal distance to destination in cm
@ -393,4 +409,4 @@ void AC_WPNav::reset_I()
// set last velocity to current velocity // set last velocity to current velocity
_vel_last = _inav->get_velocity(); _vel_last = _inav->get_velocity();
} }

View File

@ -40,7 +40,7 @@
// This should use the current waypoint max speed though rather than the default // This should use the current waypoint max speed though rather than the default
#define MAX_CLIMB_VELOCITY 125 // maximum climb velocity - ToDo: pull this in from main code #define MAX_CLIMB_VELOCITY 125 // maximum climb velocity - ToDo: pull this in from main code
#define WPINAV_MAX_ALT_ERROR 62.50f // maximum distance (in cm) that the desired track can stray from our current location. #define WPINAV_MAX_ALT_ERROR 100.0f // maximum distance (in cm) that the desired track can stray from our current location.
// D0 = ALT_HOLD_ACCEL_MAX/(2*Pid_P^2); // D0 = ALT_HOLD_ACCEL_MAX/(2*Pid_P^2);
// if g.pilot_velocity_z_max > 2*D0*Pid_P // if g.pilot_velocity_z_max > 2*D0*Pid_P
// WPINAV_MAX_ALT_ERROR = D0 + MAX_CLIMB_VELOCITY.^2 ./ (2*ALT_HOLD_ACCEL_MAX); // WPINAV_MAX_ALT_ERROR = D0 + MAX_CLIMB_VELOCITY.^2 ./ (2*ALT_HOLD_ACCEL_MAX);