2013-05-29 20:51:34 -03:00
// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
2012-10-26 20:59:07 -03:00
# ifndef __AP_MOTORS_CLASS_H__
# define __AP_MOTORS_CLASS_H__
# include <AP_Common.h>
2012-12-16 20:55:33 -04:00
# include <AP_Progmem.h>
2012-10-26 20:59:07 -03:00
# include <AP_Math.h> // ArduPilot Mega Vector/Matrix math Library
2013-08-08 10:15:04 -03:00
# include <AP_Notify.h> // Notify library
2012-10-26 20:59:07 -03:00
# include <AP_Curve.h> // Curve used to linearlise throttle pwm to thrust
# include <RC_Channel.h> // RC Channel Library
// offsets for motors in motor_out, _motor_filtered and _motor_to_channel_map arrays
# define AP_MOTORS_MOT_1 0
# define AP_MOTORS_MOT_2 1
# define AP_MOTORS_MOT_3 2
# define AP_MOTORS_MOT_4 3
# define AP_MOTORS_MOT_5 4
# define AP_MOTORS_MOT_6 5
# define AP_MOTORS_MOT_7 6
# define AP_MOTORS_MOT_8 7
# define APM1_MOTOR_TO_CHANNEL_MAP CH_1,CH_2,CH_3,CH_4,CH_7,CH_8,CH_10,CH_11
# define APM2_MOTOR_TO_CHANNEL_MAP CH_1,CH_2,CH_3,CH_4,CH_5,CH_6,CH_7,CH_8
# define AP_MOTORS_MAX_NUM_MOTORS 8
# define AP_MOTORS_DEFAULT_MIN_THROTTLE 130
2013-05-26 23:21:31 -03:00
# define AP_MOTORS_DEFAULT_MID_THROTTLE 500
2013-05-14 04:05:22 -03:00
# define AP_MOTORS_DEFAULT_MAX_THROTTLE 1000
2012-10-26 20:59:07 -03:00
// APM board definitions
# define AP_MOTORS_APM1 1
# define AP_MOTORS_APM2 2
// frame definitions
2013-03-31 00:41:02 -03:00
# define AP_MOTORS_PLUS_FRAME 0
# define AP_MOTORS_X_FRAME 1
# define AP_MOTORS_V_FRAME 2
2013-05-03 11:13:40 -03:00
# define AP_MOTORS_H_FRAME 3 // same as X frame but motors spin in opposite direction
2012-10-26 20:59:07 -03:00
// motor update rate
2013-05-14 04:56:55 -03:00
# define AP_MOTORS_SPEED_DEFAULT 490 // default output rate to the motors
2012-10-26 20:59:07 -03:00
# define THROTTLE_CURVE_ENABLED 1 // throttle curve disabled by default
# define THROTTLE_CURVE_MID_THRUST 52 // throttle which produces 1/2 the maximum thrust. expressed as a percentage of the full throttle range (i.e 0 ~ 100)
# define THROTTLE_CURVE_MAX_THRUST 93 // throttle which produces the maximum thrust. expressed as a percentage of the full throttle range (i.e 0 ~ 100)
2013-09-12 10:36:04 -03:00
# define AP_MOTORS_SPIN_WHEN_ARMED 70 // spin motors at this PWM value when armed
2013-06-22 22:07:35 -03:00
2012-10-26 20:59:07 -03:00
// bit mask for recording which limits we have reached when outputting to motors
# define AP_MOTOR_NO_LIMITS_REACHED 0x00
# define AP_MOTOR_ROLLPITCH_LIMIT 0x01
# define AP_MOTOR_YAW_LIMIT 0x02
# define AP_MOTOR_THROTTLE_LIMIT 0x04
# define AP_MOTOR_ANY_LIMIT 0xFF
2013-09-12 10:27:44 -03:00
// slow start increment - max throttle increase per (100hz) iteration. i.e. 10 = full speed in 1 second
# define AP_MOTOR_SLOW_START_INCREMENT 10
2012-10-26 20:59:07 -03:00
/// @class AP_Motors
class AP_Motors {
public :
// Constructor
2013-01-02 00:27:58 -04:00
AP_Motors ( RC_Channel * rc_roll , RC_Channel * rc_pitch , RC_Channel * rc_throttle , RC_Channel * rc_yaw , uint16_t speed_hz = AP_MOTORS_SPEED_DEFAULT ) ;
2012-10-26 20:59:07 -03:00
// init
virtual void Init ( ) ;
// set mapping from motor number to RC channel
2013-05-14 06:23:36 -03:00
void set_motor_to_channel_map ( uint8_t mot_1 , uint8_t mot_2 , uint8_t mot_3 , uint8_t mot_4 , uint8_t mot_5 , uint8_t mot_6 , uint8_t mot_7 , uint8_t mot_8 ) {
2012-10-26 20:59:07 -03:00
_motor_to_channel_map [ AP_MOTORS_MOT_1 ] = mot_1 ;
_motor_to_channel_map [ AP_MOTORS_MOT_2 ] = mot_2 ;
_motor_to_channel_map [ AP_MOTORS_MOT_3 ] = mot_3 ;
_motor_to_channel_map [ AP_MOTORS_MOT_4 ] = mot_4 ;
_motor_to_channel_map [ AP_MOTORS_MOT_5 ] = mot_5 ;
_motor_to_channel_map [ AP_MOTORS_MOT_6 ] = mot_6 ;
_motor_to_channel_map [ AP_MOTORS_MOT_7 ] = mot_7 ;
_motor_to_channel_map [ AP_MOTORS_MOT_8 ] = mot_8 ;
}
// set update rate to motors - a value in hertz
2013-05-14 06:23:36 -03:00
virtual void set_update_rate ( uint16_t speed_hz ) { _speed_hz = speed_hz ; } ;
2012-10-26 20:59:07 -03:00
// set frame orientation (normally + or X)
2013-09-12 10:27:44 -03:00
virtual void set_frame_orientation ( uint8_t new_orientation ) { _flags . frame_orientation = new_orientation ; } ;
2012-10-26 20:59:07 -03:00
// enable - starts allowing signals to be sent to motors
2013-05-31 02:17:08 -03:00
virtual void enable ( ) = 0 ;
2012-10-26 20:59:07 -03:00
// arm, disarm or check status status of motors
2013-09-12 10:27:44 -03:00
bool armed ( ) { return _flags . armed ; } ;
2013-08-08 10:15:04 -03:00
void armed ( bool arm ) ;
2012-10-26 20:59:07 -03:00
// set_min_throttle - sets the minimum throttle that will be sent to the engines when they're not off (i.e. to prevents issues with some motors spinning and some not at very low throttle)
2013-05-26 23:21:31 -03:00
void set_min_throttle ( uint16_t min_throttle ) ;
// set_mid_throttle - sets the mid throttle which is close to the hover throttle of the copter
// this is used to limit the amount that the stability patch will increase the throttle to give more room for roll, pitch and yaw control
void set_mid_throttle ( uint16_t mid_throttle ) ;
2012-10-26 20:59:07 -03:00
// output - sends commands to the motors
2013-09-12 10:27:44 -03:00
void output ( ) ;
2012-10-26 20:59:07 -03:00
// output_min - sends minimum values out to the motors
2013-05-31 02:17:08 -03:00
virtual void output_min ( ) = 0 ;
2012-10-26 20:59:07 -03:00
// motor test
2013-05-31 02:17:08 -03:00
virtual void output_test ( ) = 0 ;
2012-10-26 20:59:07 -03:00
2013-05-14 05:07:36 -03:00
// throttle_pass_through - passes pilot's throttle input directly to all motors - dangerous but used for initialising ESCs
2012-10-26 20:59:07 -03:00
virtual void throttle_pass_through ( ) ;
// setup_throttle_curve - used to linearlise thrust output by motors
// returns true if curve is created successfully
2013-05-14 06:23:36 -03:00
bool setup_throttle_curve ( ) ;
2012-10-26 20:59:07 -03:00
// 1 if motor is enabled, 0 otherwise
2013-05-14 04:05:22 -03:00
bool motor_enabled [ AP_MOTORS_MAX_NUM_MOTORS ] ;
2012-10-26 20:59:07 -03:00
2013-09-12 10:27:44 -03:00
// slow_start - set to true to slew motors from current speed to maximum
// Note: this must be set immediately before a step up in throttle
void slow_start ( bool true_false ) ;
2012-10-26 20:59:07 -03:00
// final output values sent to the motors. public (for now) so that they can be access for logging
int16_t motor_out [ AP_MOTORS_MAX_NUM_MOTORS ] ;
2013-07-21 01:58:24 -03:00
// structure for holding motor limit flags
struct AP_Motors_limit {
uint8_t roll_pitch : 1 ; // we have reached roll or pitch limit
uint8_t yaw : 1 ; // we have reached yaw limit
2013-07-25 12:45:59 -03:00
uint8_t throttle_lower : 1 ; // we have reached throttle's lower limit
uint8_t throttle_upper : 1 ; // we have reached throttle's upper limit
2013-07-21 01:58:24 -03:00
} limit ;
2012-10-26 20:59:07 -03:00
// var_info for holding Parameter information
static const struct AP_Param : : GroupInfo var_info [ ] ;
protected :
// output functions that should be overloaded by child classes
2013-09-12 10:27:44 -03:00
virtual void output_armed ( ) { } ;
virtual void output_disarmed ( ) { } ;
2012-10-26 20:59:07 -03:00
2013-09-12 10:27:44 -03:00
// update_max_throttle - updates the limits on _max_throttle if necessary taking into account slow_start_throttle flag
void update_max_throttle ( ) ;
2013-05-26 23:21:31 -03:00
2013-09-12 10:27:44 -03:00
// flag bitmask
struct AP_Motors_flags {
uint8_t armed : 1 ; // 1 if the motors are armed, 0 if disarmed
uint8_t frame_orientation : 2 ; // PLUS_FRAME 0, X_FRAME 1, V_FRAME 2, H_FRAME 3
uint8_t slow_start : 1 ; // 1 if slow start is active
} _flags ;
2013-07-16 00:45:40 -03:00
2013-09-12 10:27:44 -03:00
// parameters
AP_CurveInt16_Size4 _throttle_curve ; // curve used to linearize the pwm->thrust
AP_Int8 _throttle_curve_enabled ; // enable throttle curve
AP_Int8 _throttle_curve_mid ; // throttle which produces 1/2 the maximum thrust. expressed as a percentage (i.e. 0 ~ 100 ) of the full throttle range
AP_Int8 _throttle_curve_max ; // throttle which produces the maximum thrust. expressed as a percentage (i.e. 0 ~ 100 ) of the full throttle range
2013-07-16 00:45:40 -03:00
AP_Int8 _spin_when_armed ; // used to control whether the motors always spin when armed. pwm value above radio_min
2013-09-12 10:27:44 -03:00
// internal variables
RC_Channel * _rc_roll , * _rc_pitch , * _rc_throttle , * _rc_yaw ; // input in from users
uint8_t _motor_to_channel_map [ AP_MOTORS_MAX_NUM_MOTORS ] ; // mapping of motor number (as received from upper APM code) to RC channel output - used to account for differences between APM1 and APM2
uint16_t _speed_hz ; // speed in hz to send updates to motors
int16_t _min_throttle ; // the minimum throttle to be sent to the motors when they're on (prevents motors stalling while flying)
int16_t _max_throttle ; // the maximum throttle to be sent to the motors (sometimes limited by slow start)
int16_t _hover_out ; // the estimated hover throttle in pwm (i.e. 1000 ~ 2000). calculated from the THR_MID parameter
2012-10-26 20:59:07 -03:00
} ;
# endif // __AP_MOTORS_CLASS_H__