ardupilot/ArduPlane/tailsitter.h
2021-07-27 09:08:34 +10:00

117 lines
3.4 KiB
C++

/*
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include <AP_Param/AP_Param.h>
class QuadPlane;
class AP_MotorsMulticopter;
class Tailsitter
{
friend class QuadPlane;
friend class Plane;
public:
Tailsitter(QuadPlane& _quadplane, AP_MotorsMulticopter*& _motors);
bool enabled() const { return enable > 0;}
// return true when flying a control surface only tailsitter
bool is_control_surface_tailsitter(void) const;
// return true when flying a tailsitter in VTOL
bool active(void);
// create outputs for tailsitters
void output(void);
// handle different tailsitter input types
void check_input(void);
// check if we have completed transition to fixed wing
bool transition_fw_complete(void);
// return true if we are a tailsitter in FW flight
bool is_in_fw_flight(void) const;
// check if we have completed transition to vtol
bool transition_vtol_complete(void) const;
// return true if transistion to VTOL flight
bool in_vtol_transition(uint32_t now = 0) const;
// account for control surface speed scaling in VTOL modes
void speed_scaling(void);
// return the transition_angle_vtol value
int8_t get_transition_angle_vtol() const;
// true when flying a tilt-vectored tailsitter
bool _is_vectored;
// tailsitter speed scaler
float last_spd_scaler = 1.0f; // used to slew rate limiting with TAILSITTER_GSCL_ATT_THR option
float log_spd_scaler; // for QTUN log
static const struct AP_Param::GroupInfo var_info[];
// bit 0 enables plane mode and bit 1 enables body-frame roll mode
enum input {
TAILSITTER_INPUT_PLANE = (1U<<0),
TAILSITTER_INPUT_BF_ROLL = (1U<<1)
};
enum mask {
TAILSITTER_MASK_AILERON = (1U<<0),
TAILSITTER_MASK_ELEVATOR = (1U<<1),
TAILSITTER_MASK_THROTTLE = (1U<<2),
TAILSITTER_MASK_RUDDER = (1U<<3),
};
enum gscl_mask {
TAILSITTER_GSCL_THROTTLE = (1U<<0),
TAILSITTER_GSCL_ATT_THR = (1U<<1),
TAILSITTER_GSCL_DISK_THEORY = (1U<<2),
TAILSITTER_GSCL_ALTITUDE = (1U<<3),
};
AP_Int8 enable;
AP_Int8 transition_angle_fw;
AP_Float transition_rate_fw;
AP_Int8 transition_angle_vtol;
AP_Float transition_rate_vtol;
AP_Int8 input_type;
AP_Int8 input_mask;
AP_Int8 input_mask_chan;
AP_Float vectored_forward_gain;
AP_Float vectored_hover_gain;
AP_Float vectored_hover_power;
AP_Float throttle_scale_max;
AP_Float gain_scaling_min;
AP_Float max_roll_angle;
AP_Int16 motor_mask;
AP_Float scaling_speed_min;
AP_Float scaling_speed_max;
AP_Int16 gain_scaling_mask;
AP_Float disk_loading;
private:
// refences for convenience
QuadPlane& quadplane;
AP_MotorsMulticopter*& motors;
};