2016-02-17 21:25:38 -04:00
# pragma once
2015-07-21 07:07:54 -03:00
2015-08-15 13:42:46 -03:00
# include <AP_Common/AP_Common.h>
# include <AP_Math/AP_Math.h> // ArduPilot Mega Vector/Matrix math Library
2017-01-03 05:56:57 -04:00
# include <RC_Channel/RC_Channel.h>
# include <SRV_Channel/SRV_Channel.h>
2015-07-21 07:07:54 -03:00
2019-08-07 23:52:17 -03:00
// default main rotor speed (ch8 out) as a number from 0 ~ 100
# define AP_MOTORS_HELI_RSC_SETPOINT 70
// default main rotor critical speed
# define AP_MOTORS_HELI_RSC_CRITICAL 50
// RSC output defaults
# define AP_MOTORS_HELI_RSC_IDLE_DEFAULT 0
// default main rotor ramp up time in seconds
# define AP_MOTORS_HELI_RSC_RAMP_TIME 1 // 1 second to ramp output to main rotor ESC to setpoint
# define AP_MOTORS_HELI_RSC_RUNUP_TIME 10 // 10 seconds for rotor to reach full speed
2023-01-19 00:31:32 -04:00
# define AP_MOTORS_HELI_RSC_AROT_ENGAGE_TIME 1 // time in seconds to ramp motors when bailing out of autorotation
2023-02-02 00:18:58 -04:00
# define AP_MOTORS_HELI_RSC_AROT_IDLE 0
2019-08-07 23:52:17 -03:00
2019-02-14 20:28:48 -04:00
// Throttle Curve Defaults
2019-02-15 21:52:09 -04:00
# define AP_MOTORS_HELI_RSC_THRCRV_0_DEFAULT 25
# define AP_MOTORS_HELI_RSC_THRCRV_25_DEFAULT 32
# define AP_MOTORS_HELI_RSC_THRCRV_50_DEFAULT 38
# define AP_MOTORS_HELI_RSC_THRCRV_75_DEFAULT 50
# define AP_MOTORS_HELI_RSC_THRCRV_100_DEFAULT 100
2019-02-14 20:28:48 -04:00
2021-11-11 13:09:26 -04:00
// RSC governor defaults
# define AP_MOTORS_HELI_RSC_GOVERNOR_RANGE_DEFAULT 100
2015-08-07 20:52:22 -03:00
// rotor controller states
2015-08-28 03:20:42 -03:00
enum RotorControlState {
ROTOR_CONTROL_STOP = 0 ,
ROTOR_CONTROL_IDLE ,
ROTOR_CONTROL_ACTIVE
} ;
2015-08-07 20:52:22 -03:00
2015-08-11 15:31:20 -03:00
// rotor control modes
2015-08-28 03:22:23 -03:00
enum RotorControlMode {
ROTOR_CONTROL_MODE_DISABLED = 0 ,
2021-01-20 17:09:07 -04:00
ROTOR_CONTROL_MODE_PASSTHROUGH ,
ROTOR_CONTROL_MODE_SETPOINT ,
ROTOR_CONTROL_MODE_THROTTLECURVE ,
ROTOR_CONTROL_MODE_AUTOTHROTTLE
2015-08-28 03:22:23 -03:00
} ;
2015-08-11 15:31:20 -03:00
2015-07-21 07:07:54 -03:00
class AP_MotorsHeli_RSC {
public :
2016-06-04 05:03:16 -03:00
friend class AP_MotorsHeli_Single ;
2017-03-14 06:46:48 -03:00
friend class AP_MotorsHeli_Dual ;
2017-08-26 08:53:53 -03:00
friend class AP_MotorsHeli_Quad ;
2018-03-23 01:09:14 -03:00
2017-01-03 05:56:57 -04:00
AP_MotorsHeli_RSC ( SRV_Channel : : Aux_servo_function_t aux_fn ,
2016-06-04 22:20:58 -03:00
uint8_t default_channel ) :
2015-12-05 06:10:52 -04:00
_aux_fn ( aux_fn ) ,
2016-01-06 23:25:26 -04:00
_default_channel ( default_channel )
2019-08-07 23:52:17 -03:00
{
AP_Param : : setup_object_defaults ( this , var_info ) ;
} ;
2015-07-21 07:07:54 -03:00
2015-08-11 12:01:11 -03:00
// init_servo - servo initialization on start-up
void init_servo ( ) ;
2015-08-11 15:31:20 -03:00
// set_control_mode - sets control mode
2015-08-28 03:22:23 -03:00
void set_control_mode ( RotorControlMode mode ) { _control_mode = mode ; }
2015-08-11 15:31:20 -03:00
2019-08-07 23:52:17 -03:00
// reset_rsc_mode_param - resets rsc mode param to current control mode
void reset_rsc_mode_param ( ) { _rsc_mode . set ( ( uint8_t ) _control_mode ) ; }
// get_control_mode - gets control mode
uint8_t get_control_mode ( ) const { return _control_mode ; }
2015-07-21 07:07:54 -03:00
// set_critical_speed
2022-07-05 00:08:56 -03:00
void set_critical_speed ( float critical_speed ) { _critical_speed . set ( critical_speed ) ; }
2018-03-23 01:09:14 -03:00
2015-07-21 07:07:54 -03:00
// get_desired_speed
2016-02-03 04:53:34 -04:00
float get_desired_speed ( ) const { return _desired_speed ; }
2015-07-21 07:07:54 -03:00
2019-08-07 23:52:17 -03:00
// set_desired_speed - this requires input to be 0-1
2016-02-03 04:53:34 -04:00
void set_desired_speed ( float desired_speed ) { _desired_speed = desired_speed ; }
2015-07-21 07:07:54 -03:00
2019-02-03 19:19:13 -04:00
// get_rotor_speed - estimated rotor speed when no governor or rpm sensor is used
2016-02-03 04:53:34 -04:00
float get_rotor_speed ( ) const ;
2021-02-07 14:30:05 -04:00
2021-02-10 16:45:07 -04:00
// functions for autothrottle, throttle curve, governor, idle speed, output to servo
void set_governor_output ( float governor_output ) { _governor_output = governor_output ; }
2019-02-03 19:19:13 -04:00
float get_governor_output ( ) const { return _governor_output ; }
2021-02-10 16:45:07 -04:00
void governor_reset ( ) ;
float get_control_output ( ) const { return _control_output ; }
2022-07-05 00:08:56 -03:00
void set_idle_output ( float idle_output ) { _idle_output . set ( idle_output ) ; }
2021-02-10 16:45:07 -04:00
void autothrottle_run ( ) ;
void set_throttle_curve ( ) ;
2015-07-21 07:07:54 -03:00
2021-02-10 16:45:07 -04:00
// functions for ramp and runup timers, runup_complete flag
2022-07-05 00:08:56 -03:00
void set_ramp_time ( int8_t ramp_time ) { _ramp_time . set ( ramp_time ) ; }
void set_runup_time ( int8_t runup_time ) { _runup_time . set ( runup_time ) ; }
2015-07-21 07:07:54 -03:00
bool is_runup_complete ( ) const { return _runup_complete ; }
2021-12-05 19:57:05 -04:00
// is_spooldown_complete
bool is_spooldown_complete ( ) const { return _spooldown_complete ; }
2018-03-23 01:09:14 -03:00
// set_collective. collective for throttle curve calculation
void set_collective ( float collective ) { _collective_in = collective ; }
2021-02-07 14:30:05 -04:00
2019-11-28 16:23:47 -04:00
// use bailout ramp time
void use_bailout_ramp_time ( bool enable ) { _use_bailout_ramp = enable ; }
2020-04-01 11:40:53 -03:00
// use external governor autorotation window
2021-02-08 13:21:02 -04:00
void set_autorotation_flag ( bool flag ) { _in_autorotation = flag ; }
2020-04-01 11:40:53 -03:00
// set the throttle percentage to be sent to external governor to signal that autorotation bailout ramp should be used within this instance of Heli_RSC
void set_ext_gov_arot_bail ( int16_t pct ) { _rsc_arot_bailout_pct = pct ; }
2021-10-27 10:06:23 -03:00
2022-02-20 23:59:18 -04:00
// turbine start initialize sequence
void set_turbine_start ( bool turbine_start ) { _turbine_start = turbine_start ; }
2020-04-01 11:40:53 -03:00
2015-08-07 22:14:45 -03:00
// output - update value to send to ESC/Servo
2015-08-28 03:20:42 -03:00
void output ( RotorControlState state ) ;
2015-07-21 07:07:54 -03:00
2019-08-07 23:52:17 -03:00
// var_info for holding Parameter information
static const struct AP_Param : : GroupInfo var_info [ ] ;
// parameters
AP_Int16 _rsc_setpoint ; // rotor speed when RSC mode is set to is enabled
AP_Int8 _rsc_mode ; // Which main rotor ESC control mode is active
AP_Int8 _ramp_time ; // Time in seconds for the output to the main rotor's ESC to reach setpoint
AP_Int8 _runup_time ; // Time in seconds for the main rotor to reach full speed. Must be longer than _rsc_ramp_time
AP_Int16 _critical_speed ; // Rotor speed below which flight is not possible
AP_Int16 _idle_output ; // Rotor control output while at idle
2023-02-02 00:18:58 -04:00
AP_Int16 _arot_idle_output ; // Percent value used when in autorotation
2023-01-19 00:31:32 -04:00
AP_Int8 _rsc_arot_engage_time ; // time in seconds for in-flight power re-engagement
AP_Int8 _rsc_arot_man_enable ; // enables manual autorotation
2019-08-07 23:52:17 -03:00
2015-07-21 07:07:54 -03:00
private :
2016-06-04 22:20:58 -03:00
uint64_t _last_update_us ;
2018-03-23 01:09:14 -03:00
2015-12-05 06:10:52 -04:00
// channel setup for aux function
2017-01-03 05:56:57 -04:00
SRV_Channel : : Aux_servo_function_t _aux_fn ;
2015-12-05 06:10:52 -04:00
uint8_t _default_channel ;
2018-03-23 01:09:14 -03:00
2015-07-21 07:07:54 -03:00
// internal variables
2015-08-28 03:22:23 -03:00
RotorControlMode _control_mode = ROTOR_CONTROL_MODE_DISABLED ; // motor control mode, Passthrough or Setpoint
2019-02-28 21:43:03 -04:00
float _desired_speed ; // latest desired rotor speed from pilot
float _control_output ; // latest logic controlled output
float _rotor_ramp_output ; // scalar used to ramp rotor speed between _rsc_idle_output and full speed (0.0-1.0f)
float _rotor_runup_output ; // scalar used to store status of rotor run-up time (0.0-1.0f)
bool _runup_complete ; // flag for determining if runup is complete
float _thrcrv_poly [ 4 ] [ 4 ] ; // spline polynomials for throttle curve interpolation
float _collective_in ; // collective in for throttle curve calculation, range 0-1.0f
float _rotor_rpm ; // rotor rpm from speed sensor for governor
2022-02-20 23:59:18 -04:00
bool _turbine_start ; // initiates starting sequence
bool _starting ; // tracks if starting sequence has been used
2019-02-28 21:43:03 -04:00
float _governor_output ; // governor output for rotor speed control
2021-01-21 07:02:11 -04:00
bool _governor_engage ; // RSC governor status flag
bool _autothrottle ; // autothrottle status flag
bool _governor_fault ; // governor fault status flag
2019-11-28 16:23:47 -04:00
bool _use_bailout_ramp ; // true if allowing RSC to quickly ramp up engine
2021-11-11 13:09:26 -04:00
bool _in_autorotation ; // true if vehicle is currently in an autorotation
2020-04-01 11:40:53 -03:00
int16_t _rsc_arot_bailout_pct ; // the throttle percentage sent to the external governor to signal that autorotation bailout ramp should be used
2021-12-05 19:57:05 -04:00
bool _spooldown_complete ; // flag for determining if spooldown is complete
2021-11-11 13:09:26 -04:00
float _fast_idle_timer ; // cooldown timer variable
uint8_t _governor_fault_count ; // variable for tracking governor speed sensor faults
float _governor_torque_reference ; // governor reference for load calculations
2023-01-29 16:22:52 -04:00
bool _autorotating ; // flag that holds the status of autorotation
bool _bailing_out ; // flag that holds the status of bail out(power engagement)
float _idle_throttle ; // current idle throttle setting
2023-02-04 00:44:35 -04:00
bool _gov_bailing_out ; // flag that holds the status of governor bail out
2015-07-21 07:07:54 -03:00
2015-08-11 15:31:20 -03:00
// update_rotor_ramp - slews rotor output scalar between 0 and 1, outputs float scalar to _rotor_ramp_output
2016-06-04 22:20:58 -03:00
void update_rotor_ramp ( float rotor_ramp_input , float dt ) ;
2015-08-07 22:14:45 -03:00
2015-08-11 15:31:20 -03:00
// update_rotor_runup - function to slew rotor runup scalar, outputs float scalar to _rotor_runup_ouptut
2016-06-04 22:20:58 -03:00
void update_rotor_runup ( float dt ) ;
2015-08-10 18:24:57 -03:00
2016-02-03 04:53:34 -04:00
// write_rsc - outputs pwm onto output rsc channel. servo_out parameter is of the range 0 ~ 1
void write_rsc ( float servo_out ) ;
2018-03-23 01:09:14 -03:00
2021-01-21 07:02:11 -04:00
// calculate_throttlecurve - uses throttle curve and collective input to determine throttle setting
float calculate_throttlecurve ( float collective_in ) ;
2019-02-14 20:28:48 -04:00
2019-08-07 23:52:17 -03:00
// parameters
2021-01-21 07:02:11 -04:00
AP_Int16 _power_slewrate ; // throttle slew rate (percentage per second)
AP_Int16 _thrcrv [ 5 ] ; // throttle value sent to throttle servo at 0, 25, 50, 75 and 100 percent collective
2021-11-11 13:09:26 -04:00
AP_Int16 _governor_rpm ; // governor reference for speed calculations
2021-01-21 07:02:11 -04:00
AP_Float _governor_torque ; // governor torque rise setting
AP_Float _governor_compensator ; // governor torque compensator variable
AP_Float _governor_droop_response ; // governor response to droop under load
AP_Float _governor_ff ; // governor feedforward variable
2021-11-11 13:09:26 -04:00
AP_Float _governor_range ; // RPM range +/- governor rpm reference setting where governor is operational
AP_Int16 _cooldown_time ; // cooldown time to provide a fast idle
2019-08-07 23:52:17 -03:00
// parameter accessors to allow conversions
float get_critical_speed ( ) const { return _critical_speed * 0.01 ; }
2021-11-11 13:09:26 -04:00
float get_idle_output ( ) const { return _idle_output * 0.01 ; }
float get_governor_torque ( ) const { return _governor_torque * 0.01 ; }
float get_governor_compensator ( ) const { return _governor_compensator * 0.000001 ; }
2023-02-02 00:18:58 -04:00
float get_arot_idle_output ( ) const { return _arot_idle_output * 0.01 ; }
2019-02-14 20:28:48 -04:00
} ;