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-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
|
|
|
|
2023-12-12 22:52:56 -04:00
|
|
|
// rotor controller states
|
|
|
|
enum class RotorControlState {
|
|
|
|
STOP = 0,
|
|
|
|
IDLE,
|
|
|
|
ACTIVE
|
|
|
|
};
|
|
|
|
|
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
|
|
|
|
2023-02-18 00:49:06 -04:00
|
|
|
// set the throttle percentage to be used during autorotation for this instance of Heli_RSC
|
|
|
|
void set_arot_idle_output(int16_t idle) { _arot_idle_output.set(idle); }
|
|
|
|
|
|
|
|
// set the manual autorotation option for this instance of Heli_RSC
|
|
|
|
void set_rsc_arot_man_enable(int8_t enable) { _rsc_arot_man_enable.set(enable); }
|
|
|
|
|
|
|
|
// set the autorotation power recovery time for this instance of Heli_RSC
|
|
|
|
void set_rsc_arot_engage_time(int8_t eng_time) { _rsc_arot_engage_time.set(eng_time); }
|
|
|
|
|
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
|
|
|
|
2023-05-05 16:06:42 -03:00
|
|
|
// Return mask of output channels which the RSC is outputting on
|
|
|
|
uint32_t get_output_mask() const;
|
|
|
|
|
2023-04-29 18:23:25 -03:00
|
|
|
// rotor_speed_above_critical - return true if rotor speed is above that critical for flight
|
2024-04-17 12:57:49 -03:00
|
|
|
bool rotor_speed_above_critical(void) const { return get_rotor_speed() >= get_critical_speed(); }
|
2023-04-29 18:23:25 -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
|
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
|
|
|
};
|