ACM : Added larger WP radius for fast waypoints so we don't loose speed angling in on the WP at the last second.

This commit is contained in:
Jason Short 2012-08-10 10:02:32 -07:00
parent 31fdeab873
commit 0688eee9bc
4 changed files with 7 additions and 2 deletions

View File

@ -563,7 +563,7 @@ static int16_t waypoint_speed_gov;
static int32_t long_error, lat_error;
// Are we navigating while holding a positon? This is set to false once the speed drops below 1m/s
static boolean loiter_override;
static int16_t waypoint_radius;
////////////////////////////////////////////////////////////////////////////////
// Orientation

View File

@ -403,6 +403,9 @@ static void reset_nav_params(void)
// make sure we stick to Nav yaw on takeoff
auto_yaw = nav_yaw;
// revert to smaller radius set in params
waypoint_radius = g.waypoint_radius;
}
/*

View File

@ -452,7 +452,7 @@ static bool verify_nav_wp()
}
// Did we pass the WP? // Distance checking
if((wp_distance <= (g.waypoint_radius * 100)) || check_missed_wp()){
if((wp_distance <= (waypoint_radius * 100)) || check_missed_wp()){
// if we have a distance calc error, wp_distance may be less than 0
if(wp_distance > 0){

View File

@ -260,8 +260,10 @@ static int16_t get_desired_speed(int16_t max_speed, bool _slow)
*/
if(fast_corner){
waypoint_radius = g.waypoint_radius * 2;
//max_speed = max_speed;
}else{
waypoint_radius = g.waypoint_radius;
max_speed = min(max_speed, (wp_distance - g.waypoint_radius) / 3);
max_speed = max(max_speed, WAYPOINT_SPEED_MIN); // go at least 100cm/s
}