2017-07-18 23:17:45 -03:00
# pragma once
# include <stdint.h>
# include <GCS_MAVLink/GCS_MAVLink.h> // for MAV_SEVERITY
# include "defines.h"
class Mode
{
public :
// Constructor
Mode ( ) ;
// enter this mode, returns false if we failed to enter
bool enter ( ) ;
// perform any cleanups required:
void exit ( ) ;
// returns a unique number specific to this mode
virtual uint32_t mode_number ( ) const = 0 ;
//
// methods that sub classes should override to affect movement of the vehicle in this mode
//
// convert user input to targets, implement high level control for this mode
virtual void update ( ) = 0 ;
//
// attributes of the mode
//
// return if in non-manual mode : AUTO, GUIDED, RTL
virtual bool is_autopilot_mode ( ) const { return false ; }
// returns true if steering is directly controlled by RC
virtual bool manual_steering ( ) const { return false ; }
// returns true if the throttle is controlled automatically
virtual bool auto_throttle ( ) { return is_autopilot_mode ( ) ; }
// return true if throttle should be supressed in event of a
// FAILSAFE_EVENT_THROTTLE
virtual bool failsafe_throttle_suppress ( ) const { return true ; }
//
// attributes for mavlink system status reporting
//
// returns true if any RC input is used
virtual bool has_manual_input ( ) const { return false ; }
// true if heading is controlled
virtual bool attitude_stabilized ( ) const { return true ; }
2017-08-03 05:08:09 -03:00
//
// navigation methods
//
// return distance (in meters) to destination
virtual float get_distance_to_destination ( ) const { return 0.0f ; }
// set desired location and speed
virtual void set_desired_location ( const struct Location & destination ) ;
// true if vehicle has reached desired location. defaults to true because this is normally used by missions and we do not want the mission to become stuck
virtual bool reached_destination ( ) { return true ; }
virtual void set_desired_heading_and_speed ( float yaw_angle_cd , float target_speed ) ;
// get speed error in m/s, returns zero for modes that do not control speed
float speed_error ( ) { return _speed_error ; }
2017-07-18 23:17:45 -03:00
// Navigation control variables
// The instantaneous desired lateral acceleration in m/s/s
float lateral_acceleration ;
protected :
// subclasses override this to perform checks before entering the mode
virtual bool _enter ( ) { return true ; }
// subclasses override this to perform any required cleanup when exiting the mode
virtual void _exit ( ) { return ; }
// calculate steering angle given a desired lateral acceleration
virtual void calc_nav_steer ( ) ;
// calculate desired lateral acceleration
2017-08-03 05:08:09 -03:00
void calc_lateral_acceleration ( const struct Location & origin , const struct Location & destination ) ;
// calculates the amount of throttle that should be output based
// on things like proximity to corners and current speed
virtual void calc_throttle ( float target_speed ) ;
2017-07-18 23:17:45 -03:00
2017-07-18 04:27:05 -03:00
// calculate pilot input to nudge throttle up or down
int16_t calc_throttle_nudge ( ) ;
2017-08-03 05:08:09 -03:00
// calculated a reduced speed(in m/s) based on yaw error and lateral acceleration and/or distance to a waypoint
// should be called after calc_lateral_acceleration and before calc_throttle
// relies on these internal members being updated: lateral_acceleration, _yaw_error_cd, _distance_to_destination
float calc_reduced_speed_for_turn_or_distance ( float desired_speed ) ;
2017-07-18 23:17:45 -03:00
// references to avoid code churn:
2017-08-03 05:08:09 -03:00
class AP_AHRS & ahrs ;
2017-07-18 23:17:45 -03:00
class Parameters & g ;
class ParametersG2 & g2 ;
class RC_Channel * & channel_steer ; // TODO : Pointer reference ?
class RC_Channel * & channel_throttle ;
class AP_Mission & mission ;
2017-08-03 05:08:09 -03:00
// private members for waypoint navigation
Location _origin ; // origin Location (vehicle will travel from the origin to the destination)
Location _destination ; // destination Location when in Guided_WP
float _distance_to_destination ; // distance from vehicle to final destination in meters
bool _reached_destination ; // true once the vehicle has reached the destination
float _desired_yaw_cd ; // desired yaw in centi-degrees
float _yaw_error_cd ; // error between desired yaw and actual yaw in centi-degrees
float _desired_speed ; // desired speed in m/s
float _speed_error ; // ground speed error in m/s
2017-07-18 23:17:45 -03:00
} ;
class ModeAuto : public Mode
{
public :
uint32_t mode_number ( ) const override { return AUTO ; }
// methods that affect movement of the vehicle in this mode
void update ( ) override ;
void calc_throttle ( float target_speed ) override ;
// attributes of the mode
bool is_autopilot_mode ( ) const override { return true ; }
bool failsafe_throttle_suppress ( ) const override { return false ; }
2017-08-03 05:11:45 -03:00
// return distance (in meters) to destination
float get_distance_to_destination ( ) const override { return _distance_to_destination ; }
// set desired location, heading and speed
// set stay_active_at_dest if the vehicle should attempt to maintain it's position at the destination (mostly for boats)
void set_desired_location ( const struct Location & destination , bool stay_active_at_dest ) ;
bool reached_destination ( ) override ;
// heading and speed control
void set_desired_heading_and_speed ( float yaw_angle_cd , float target_speed ) override ;
bool reached_heading ( ) ;
2017-07-18 23:17:45 -03:00
protected :
bool _enter ( ) override ;
void _exit ( ) override ;
2017-08-03 05:11:45 -03:00
enum AutoSubMode {
Auto_WP , // drive to a given location
Auto_HeadingAndSpeed // turn to a given heading
} _submode ;
2017-07-18 23:17:45 -03:00
private :
bool check_trigger ( void ) ;
// this is set to true when auto has been triggered to start
bool auto_triggered ;
2017-08-03 05:11:45 -03:00
bool _reached_heading ; // true when vehicle has reached desired heading in TurnToHeading sub mode
bool _stay_active_at_dest ; // true when we should actively maintain position even after reaching the destination
2017-07-18 23:17:45 -03:00
} ;
class ModeGuided : public Mode
{
public :
uint32_t mode_number ( ) const override { return GUIDED ; }
// methods that affect movement of the vehicle in this mode
void update ( ) override ;
// attributes of the mode
bool is_autopilot_mode ( ) const override { return true ; }
bool failsafe_throttle_suppress ( ) const override { return false ; }
2017-08-03 05:14:16 -03:00
// return distance (in meters) to destination
float get_distance_to_destination ( ) const override ;
// set desired location, heading and speed
void set_desired_location ( const struct Location & destination ) override ;
void set_desired_heading_and_speed ( float yaw_angle_cd , float target_speed ) override ;
// set desired heading-delta, turn-rate and speed
void set_desired_heading_delta_and_speed ( float yaw_delta_cd , float target_speed ) ;
void set_desired_turn_rate_and_speed ( float turn_rate_cds , float target_speed ) ;
protected :
2017-07-18 23:17:45 -03:00
enum GuidedMode {
Guided_WP ,
2017-08-03 05:14:16 -03:00
Guided_HeadingAndSpeed ,
Guided_TurnRateAndSpeed
2017-07-18 23:17:45 -03:00
} ;
2017-08-03 05:14:16 -03:00
bool _enter ( ) override ;
2017-07-18 23:17:45 -03:00
2017-08-03 05:14:16 -03:00
GuidedMode _guided_mode ; // stores which GUIDED mode the vehicle is in
2017-07-18 23:17:45 -03:00
2017-08-03 05:14:16 -03:00
// attitude control
bool have_attitude_target ; // true if we have a valid attitude target
uint32_t _des_att_time_ms ; // system time last call to set_desired_attitude was made (used for timeout)
float _desired_yaw_rate_cds ; // target turn rate centi-degrees per second
2017-07-18 23:17:45 -03:00
} ;
class ModeHold : public Mode
{
public :
uint32_t mode_number ( ) const override { return HOLD ; }
// methods that affect movement of the vehicle in this mode
void update ( ) override ;
// attributes for mavlink system status reporting
bool attitude_stabilized ( ) const override { return false ; }
} ;
class ModeManual : public Mode
{
public :
uint32_t mode_number ( ) const override { return MANUAL ; }
// methods that affect movement of the vehicle in this mode
void update ( ) override ;
// attributes of the mode
bool manual_steering ( ) const override { return true ; }
// attributes for mavlink system status reporting
bool has_manual_input ( ) const override { return true ; }
bool attitude_stabilized ( ) const override { return false ; }
} ;
class ModeLearning : public ModeManual
{
public :
uint32_t mode_number ( ) const override { return LEARNING ; }
// attributes for mavlink system status reporting
bool has_manual_input ( ) const override { return true ; }
} ;
class ModeRTL : public Mode
{
public :
uint32_t mode_number ( ) const override { return RTL ; }
// methods that affect movement of the vehicle in this mode
void update ( ) override ;
void update_navigation ( ) override ;
// attributes of the mode
bool is_autopilot_mode ( ) const override { return true ; }
bool failsafe_throttle_suppress ( ) const override { return false ; }
protected :
bool _enter ( ) override ;
} ;
class ModeSteering : public Mode
{
public :
uint32_t mode_number ( ) const override { return STEERING ; }
// methods that affect movement of the vehicle in this mode
void update ( ) override ;
// attributes for mavlink system status reporting
bool has_manual_input ( ) const override { return true ; }
} ;
class ModeInitializing : public Mode
{
public :
uint32_t mode_number ( ) const override { return INITIALISING ; }
// methods that affect movement of the vehicle in this mode
void update ( ) override { }
// attributes for mavlink system status reporting
bool has_manual_input ( ) const override { return true ; }
bool attitude_stabilized ( ) const override { return false ; }
} ;