2013-03-20 03:27:26 -03:00
/// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
# ifndef AC_WPNAV_H
# define AC_WPNAV_H
# include <AP_Common.h>
# include <AP_Param.h>
# include <AP_Math.h>
# include <AC_PID.h> // PID library
# include <APM_PI.h> // PID library
# include <AP_InertialNav.h> // Inertial Navigation library
2014-01-17 22:52:33 -04:00
# include <AC_PosControl.h> // Position control library
2013-03-20 03:27:26 -03:00
// loiter maximum velocities and accelerations
2013-07-07 22:58:33 -03:00
# define WPNAV_ACCELERATION 100.0f // defines the default velocity vs distant curve. maximum acceleration in cm/s/s that position controller asks for from acceleration controller
2013-06-15 23:39:54 -03:00
# define WPNAV_ACCELERATION_MIN 50.0f // minimum acceleration in cm/s/s - used for sanity checking _wp_accel parameter
2013-05-31 09:03:27 -03:00
# define WPNAV_ACCEL_MAX 980.0f // max acceleration in cm/s/s that the loiter velocity controller will ask from the lower accel controller.
2013-05-24 11:45:03 -03:00
// should be 1.5 times larger than WPNAV_ACCELERATION.
2013-04-02 11:22:09 -03:00
// max acceleration = max lean angle * 980 * pi / 180. i.e. 23deg * 980 * 3.141 / 180 = 393 cm/s/s
2013-04-06 10:25:58 -03:00
2013-07-07 22:58:33 -03:00
# define WPNAV_LOITER_SPEED 500.0f // maximum default loiter speed in cm/s
# define WPNAV_LOITER_ACCEL_MAX 250.0f // maximum acceleration in loiter mode
2013-05-24 11:45:03 -03:00
# define WPNAV_LOITER_ACCEL_MIN 25.0f // minimum acceleration in loiter mode
2013-07-10 03:34:15 -03:00
# define WPNAV_LOITER_SPEED_MAX_TO_CORRECT_ERROR 200.0f // maximum speed used to correct position error (i.e. not including feed forward)
2013-05-24 11:45:03 -03:00
2013-04-01 03:45:23 -03:00
# define MAX_LEAN_ANGLE 4500 // default maximum lean angle
2013-03-20 03:27:26 -03:00
2013-04-18 02:51:01 -03:00
# define WPNAV_WP_SPEED 500.0f // default horizontal speed betwen waypoints in cm/s
# define WPNAV_WP_RADIUS 200.0f // default waypoint radius in cm
# define WPNAV_WP_SPEED_UP 250.0f // default maximum climb velocity
2013-04-18 10:32:00 -03:00
# define WPNAV_WP_SPEED_DOWN 150.0f // default maximum descent velocity
2013-04-18 02:51:01 -03:00
2013-07-07 22:58:33 -03:00
# define WPNAV_ALT_HOLD_P 1.0f // default throttle controller's altitude hold's P gain.
2013-05-31 09:03:27 -03:00
# define WPNAV_ALT_HOLD_ACCEL_MAX 250.0f // hard coded copy of throttle controller's maximum acceleration in cm/s. To-Do: remove duplication with throttle controller definition
2013-04-06 10:25:58 -03:00
2013-05-14 23:51:26 -03:00
# define WPNAV_MIN_LEASH_LENGTH 100.0f // minimum leash lengths in cm
2013-03-20 03:27:26 -03:00
class AC_WPNav
{
public :
/// Constructor
2014-01-17 22:52:33 -04:00
AC_WPNav ( const AP_InertialNav * inav , const AP_AHRS * ahrs , AC_PosControl & pos_control , APM_PI * pid_pos_lat , APM_PI * pid_pos_lon , AC_PID * pid_rate_lat , AC_PID * pid_rate_lon ) ;
2013-03-20 03:27:26 -03:00
///
2014-01-19 06:26:29 -04:00
/// loiter controller
2013-03-20 03:27:26 -03:00
///
/// set_loiter_target in cm from home
2013-05-25 02:07:04 -03:00
void set_loiter_target ( const Vector3f & position ) ;
2013-03-20 03:27:26 -03:00
2014-01-19 06:26:29 -04:00
/// init_loiter_target - initialize's loiter position and feed-forward velocity from current pos and velocity
void init_loiter_target ( ) ;
2013-03-20 03:27:26 -03:00
2014-01-19 06:26:29 -04:00
/// set_loiter_velocity - allows main code to pass the maximum velocity for loiter
void set_loiter_velocity ( float velocity_cms ) { _loiter_speed_cms = velocity_cms ; } ;
2013-03-20 10:28:05 -03:00
2014-01-19 06:26:29 -04:00
/// calculate_loiter_leash_length - calculates the maximum distance in cm that the target position may be from the current location
void calculate_loiter_leash_length ( ) ;
2013-03-20 10:28:05 -03:00
2014-01-19 06:26:29 -04:00
/// set_pilot_desired_acceleration - sets pilot desired acceleration from roll and pitch stick input
void set_pilot_desired_acceleration ( float control_roll , float control_pitch ) ;
2013-03-20 10:28:05 -03:00
2013-05-11 04:05:42 -03:00
/// get_stopping_point - returns vector to stopping point based on a horizontal position and velocity
2014-01-19 06:26:29 -04:00
void get_loiter_stopping_point_xy ( Vector3f & stopping_point ) const ;
2013-05-11 04:05:42 -03:00
2014-01-19 06:26:29 -04:00
/// get_loiter_distance_to_target - get horizontal distance to loiter target in cm
float get_loiter_distance_to_target ( ) const { return _pos_control . get_distance_to_target ( ) ; }
/// get_loiter_bearing_to_target - get bearing to loiter target in centi-degrees
int32_t get_loiter_bearing_to_target ( ) const ;
/// update_loiter - run the loiter controller - should be called at 10hz
void update_loiter ( ) ;
2014-01-15 02:22:30 -04:00
2013-03-20 03:27:26 -03:00
///
2013-04-08 23:50:12 -03:00
/// waypoint controller
2013-03-20 03:27:26 -03:00
///
2014-01-19 06:26:29 -04:00
/// get_wp_destination waypoint using position vector (distance from home in cm)
const Vector3f & get_wp_destination ( ) const { return _destination ; }
2013-03-27 11:07:33 -03:00
2014-01-19 06:26:29 -04:00
/// set_wp_destination waypoint using position vector (distance from home in cm)
void set_wp_destination ( const Vector3f & destination ) ;
2013-03-20 03:27:26 -03:00
2014-01-19 06:26:29 -04:00
/// set_wp_origin_and_destination - set origin and destination waypoints using position vectors (distance from home in cm)
void set_wp_origin_and_destination ( const Vector3f & origin , const Vector3f & destination ) ;
2013-03-20 03:27:26 -03:00
2014-01-19 06:26:29 -04:00
/// get_wp_stopping_point_xy - calculates stopping point based on current position, velocity, waypoint acceleration
/// results placed in stopping_position vector
void get_wp_stopping_point_xy ( Vector3f & stopping_point ) const ;
2013-03-20 03:27:26 -03:00
2014-01-19 06:26:29 -04:00
/// get_wp_distance_to_destination - get horizontal distance to destination in cm
float get_wp_distance_to_destination ( ) ;
2013-03-20 10:28:05 -03:00
/// get_bearing_to_destination - get bearing to next waypoint in centi-degrees
2014-01-19 06:26:29 -04:00
int32_t get_wp_bearing_to_destination ( ) ;
2013-03-20 10:28:05 -03:00
2013-04-08 23:50:12 -03:00
/// reached_destination - true when we have come within RADIUS cm of the waypoint
2014-01-19 06:26:29 -04:00
bool reached_wp_destination ( ) const { return _flags . reached_destination ; }
2013-05-08 12:18:02 -03:00
/// set_fast_waypoint - set to true to ignore the waypoint radius and consider the waypoint 'reached' the moment the intermediate point reaches it
void set_fast_waypoint ( bool fast ) { _flags . fast_waypoint = fast ; }
2013-04-08 23:50:12 -03:00
2013-03-20 10:28:05 -03:00
/// update_wp - update waypoint controller
void update_wpnav ( ) ;
2013-03-20 03:27:26 -03:00
///
/// shared methods
///
2013-04-08 23:50:12 -03:00
/// get desired roll, pitch which should be fed into stabilize controllers
2014-01-19 06:26:29 -04:00
int32_t get_roll ( ) const { return _pos_control . get_roll ( ) ; } ;
int32_t get_pitch ( ) const { return _pos_control . get_pitch ( ) ; } ;
2013-03-20 03:27:26 -03:00
2013-04-08 23:50:12 -03:00
/// get_desired_alt - get desired altitude (in cm above home) from loiter or wp controller which should be fed into throttle controller
2014-01-19 06:26:29 -04:00
float get_desired_alt ( ) const { return _pos_control . get_alt_target ( ) ; }
2013-04-08 23:50:12 -03:00
/// set_desired_alt - set desired altitude (in cm above home)
2014-01-19 06:26:29 -04:00
void set_desired_alt ( float desired_alt ) { _pos_control . set_alt_target ( desired_alt ) ; }
2013-05-31 09:03:27 -03:00
2013-04-14 01:24:14 -03:00
/// set_horizontal_velocity - allows main code to pass target horizontal velocity for wp navigation
2013-05-07 05:11:24 -03:00
void set_horizontal_velocity ( float velocity_cms ) { _wp_speed_cms = velocity_cms ; } ;
2013-04-18 02:51:01 -03:00
2013-06-01 05:19:05 -03:00
/// get_horizontal_velocity - allows main code to retrieve target horizontal velocity for wp navigation
float get_horizontal_velocity ( ) { return _wp_speed_cms ; } ;
2013-04-18 02:51:01 -03:00
/// get_climb_velocity - returns target climb speed in cm/s during missions
2013-05-07 05:11:24 -03:00
float get_climb_velocity ( ) const { return _wp_speed_up_cms ; } ;
2013-04-14 01:24:14 -03:00
2013-04-18 02:51:01 -03:00
/// get_descent_velocity - returns target descent speed in cm/s during missions. Note: always positive
2013-05-07 05:11:24 -03:00
float get_descent_velocity ( ) const { return _wp_speed_down_cms ; } ;
2013-04-02 06:23:46 -03:00
2014-01-19 06:26:29 -04:00
/// get_wp_radius - access for waypoint radius in cm
float get_wp_radius ( ) const { return _wp_radius_cm ; }
2013-04-14 01:24:14 -03:00
2014-01-19 06:26:29 -04:00
/// get_wp_acceleration - returns acceleration in cm/s/s during missions
float get_wp_acceleration ( ) const { return _wp_accel_cms . get ( ) ; }
2013-08-11 00:51:08 -03:00
2014-01-23 01:12:07 -04:00
/// advance_wp_target_along_track - move target location along track from origin to destination
void advance_wp_target_along_track ( float dt ) ;
2013-03-20 03:27:26 -03:00
static const struct AP_Param : : GroupInfo var_info [ ] ;
protected :
2013-05-08 12:18:02 -03:00
// flags structure
struct wpnav_flags {
uint8_t reached_destination : 1 ; // true if we have reached the destination
uint8_t fast_waypoint : 1 ; // true if we should ignore the waypoint radius and consider the waypoint complete once the intermediate target has reached the waypoint
} _flags ;
2013-03-20 03:27:26 -03:00
2014-01-19 06:26:29 -04:00
/// calc_loiter_desired_velocity - updates desired velocity (i.e. feed forward) with pilot requested acceleration and fake wind resistance
/// updated velocity sent directly to position controller
void calc_loiter_desired_velocity ( float nav_dt ) ;
2013-03-20 03:27:26 -03:00
2013-03-20 10:28:05 -03:00
/// get_bearing_cd - return bearing in centi-degrees between two positions
2013-04-21 07:54:31 -03:00
float get_bearing_cd ( const Vector3f & origin , const Vector3f & destination ) const ;
2013-03-20 10:28:05 -03:00
2013-05-07 05:11:24 -03:00
/// calculate_wp_leash_length - calculates horizontal and vertical leash lengths for waypoint controller
2013-04-18 02:51:01 -03:00
/// set climb param to true if track climbs vertically, false if descending
2013-05-07 05:11:24 -03:00
void calculate_wp_leash_length ( bool climb ) ;
2013-04-18 02:51:01 -03:00
2013-07-24 11:26:30 -03:00
// references to inertial nav and ahrs libraries
const AP_InertialNav * const _inav ;
2013-07-24 11:52:39 -03:00
const AP_AHRS * const _ahrs ;
2014-01-17 22:52:33 -04:00
AC_PosControl & _pos_control ;
2013-03-20 03:27:26 -03:00
// pointers to pid controllers
2013-07-24 11:52:39 -03:00
APM_PI * const _pid_pos_lat ;
APM_PI * const _pid_pos_lon ;
AC_PID * const _pid_rate_lat ;
AC_PID * const _pid_rate_lon ;
2013-03-20 03:27:26 -03:00
// parameters
2013-05-07 05:11:24 -03:00
AP_Float _loiter_speed_cms ; // maximum horizontal speed in cm/s while in loiter
AP_Float _wp_speed_cms ; // maximum horizontal speed in cm/s during missions
AP_Float _wp_speed_up_cms ; // climb speed target in cm/s
AP_Float _wp_speed_down_cms ; // descent speed target in cm/s
2013-04-18 02:51:01 -03:00
AP_Float _wp_radius_cm ; // distance from a waypoint in cm that, when crossed, indicates the wp has been reached
2013-06-15 23:39:54 -03:00
AP_Float _wp_accel_cms ; // acceleration in cm/s/s during missions
2013-03-20 03:27:26 -03:00
2013-04-17 23:17:41 -03:00
// loiter controller internal variables
2014-01-19 06:26:29 -04:00
uint32_t _loiter_last_update ; // time of last update_loiter call
uint8_t _loiter_step ; // used to decide which portion of loiter controller to run during this iteration
int16_t _pilot_accel_fwd_cms ; // pilot's desired acceleration forward (body-frame)
int16_t _pilot_accel_rgt_cms ; // pilot's desired acceleration right (body-frame)
2013-05-07 05:11:24 -03:00
float _loiter_leash ; // loiter's horizontal leash length in cm. used to stop the pilot from pushing the target location too far from the current location
2013-06-15 23:39:54 -03:00
float _loiter_accel_cms ; // loiter's acceleration in cm/s/s
2013-04-17 23:17:41 -03:00
// waypoint controller internal variables
2014-01-19 06:26:29 -04:00
uint32_t _wp_last_update ; // time of last update_wpnav call
uint8_t _wp_step ; // used to decide which portion of wpnav controller to run during this iteration
2013-03-20 03:27:26 -03:00
Vector3f _origin ; // starting point of trip to next waypoint in cm from home (equivalent to next_WP)
Vector3f _destination ; // target destination in cm from home (equivalent to next_WP)
2013-04-06 10:25:58 -03:00
Vector3f _pos_delta_unit ; // each axis's percentage of the total track from origin to destination
2013-03-20 03:27:26 -03:00
float _track_length ; // distance in cm between origin and destination
float _track_desired ; // our desired distance along the track in cm
2013-05-07 05:11:24 -03:00
float _wp_leash_xy ; // horizontal leash length in cm
2013-05-31 09:03:27 -03:00
float _wp_leash_z ; // horizontal leash length in cm
2013-04-29 22:20:23 -03:00
float _limited_speed_xy_cms ; // horizontal speed in cm/s used to advance the intermediate target towards the destination. used to limit extreme acceleration after passing a waypoint
2013-05-31 09:03:27 -03:00
float _track_accel ; // acceleration along track
float _track_speed ; // speed in cm/s along track
float _track_leash_length ; // leash length along track
2013-03-20 03:27:26 -03:00
} ;
# endif // AC_WPNAV_H