Paparazzi UAS
v5.15_devel-230-gc96ce27
Paparazzi is a free software Unmanned Aircraft System.
|
Vertical guidance for rotorcrafts. More...
#include "generated/airframe.h"
#include "firmwares/rotorcraft/guidance/guidance_v.h"
#include "firmwares/rotorcraft/guidance/guidance_module.h"
#include "firmwares/rotorcraft/guidance/guidance_hybrid.h"
#include "subsystems/radio_control.h"
#include "firmwares/rotorcraft/stabilization.h"
#include "firmwares/rotorcraft/navigation.h"
#include "state.h"
#include "math/pprz_algebra_int.h"
#include "subsystems/datalink/telemetry.h"
Go to the source code of this file.
Macros | |
#define | GUIDANCE_V_NOMINAL_HOVER_THROTTLE 0.4 |
#define | GUIDANCE_V_ADAPT_THROTTLE_ENABLED TRUE |
#define | GUIDANCE_V_CLIMB_RC_DEADBAND MAX_PPRZ/10 |
#define | GUIDANCE_V_MAX_RC_CLIMB_SPEED GUIDANCE_V_REF_MIN_ZD |
#define | GUIDANCE_V_MAX_RC_DESCENT_SPEED GUIDANCE_V_REF_MAX_ZD |
#define | GUIDANCE_V_MIN_ERR_Z POS_BFP_OF_REAL(-10.) |
#define | GUIDANCE_V_MAX_ERR_Z POS_BFP_OF_REAL(10.) |
#define | GUIDANCE_V_MIN_ERR_ZD SPEED_BFP_OF_REAL(-10.) |
#define | GUIDANCE_V_MAX_ERR_ZD SPEED_BFP_OF_REAL(10.) |
#define | GUIDANCE_V_MAX_SUM_ERR 2000000 |
#define | GUIDANCE_V_MAX_CMD 0.9*MAX_PPRZ |
#define | GUIDANCE_V_GUIDED_MODE_ZHOLD 0 |
#define | GUIDANCE_V_GUIDED_MODE_CLIMB 1 |
#define | GUIDANCE_V_GUIDED_MODE_THROTTLE 2 |
#define | FF_CMD_FRAC 18 |
Functions | |
static int32_t | get_vertical_thrust_coeff (void) |
get the cosine of the angle between thrust vector and gravity vector More... | |
static void | send_vert_loop (struct transport_tx *trans, struct link_device *dev) |
static void | send_tune_vert (struct transport_tx *trans, struct link_device *dev) |
void | guidance_v_init (void) |
void | guidance_v_read_rc (void) |
void | guidance_v_mode_changed (uint8_t new_mode) |
void | guidance_v_notify_in_flight (bool in_flight) |
void | guidance_v_thrust_adapt (bool in_flight) |
void | guidance_v_run (bool in_flight) |
void | guidance_v_z_enter (void) |
void | guidance_v_set_ref (int32_t pos, int32_t speed, int32_t accel) |
Set guidance ref parameters. More... | |
void | run_hover_loop (bool in_flight) |
void | guidance_v_from_nav (bool in_flight) |
Set guidance setpoint from NAV and run hover loop. More... | |
void | guidance_v_guided_enter (void) |
Enter GUIDED mode control. More... | |
void | guidance_v_guided_run (bool in_flight) |
Run GUIDED mode control. More... | |
bool | guidance_v_set_guided_z (float z) |
Set z setpoint in GUIDED mode. More... | |
bool | guidance_v_set_guided_vz (float vz) |
Set z velocity setpoint in GUIDED mode. More... | |
bool | guidance_v_set_guided_th (float th) |
Vertical guidance for rotorcrafts.
Definition in file guidance_v.c.
#define FF_CMD_FRAC 18 |
Definition at line 410 of file guidance_v.c.
Referenced by run_hover_loop().
#define GUIDANCE_V_ADAPT_THROTTLE_ENABLED TRUE |
Definition at line 60 of file guidance_v.c.
Referenced by guidance_v_init().
#define GUIDANCE_V_CLIMB_RC_DEADBAND MAX_PPRZ/10 |
Definition at line 68 of file guidance_v.c.
Referenced by guidance_v_read_rc().
#define GUIDANCE_V_GUIDED_MODE_CLIMB 1 |
Definition at line 113 of file guidance_v.c.
Referenced by guidance_v_guided_run(), and guidance_v_set_guided_vz().
#define GUIDANCE_V_GUIDED_MODE_THROTTLE 2 |
Definition at line 114 of file guidance_v.c.
Referenced by guidance_v_guided_run(), and guidance_v_set_guided_th().
#define GUIDANCE_V_GUIDED_MODE_ZHOLD 0 |
Definition at line 112 of file guidance_v.c.
Referenced by guidance_v_guided_enter(), guidance_v_guided_run(), guidance_v_init(), guidance_v_run(), and guidance_v_set_guided_z().
#define GUIDANCE_V_MAX_CMD 0.9*MAX_PPRZ |
Definition at line 100 of file guidance_v.c.
Referenced by run_hover_loop().
#define GUIDANCE_V_MAX_ERR_Z POS_BFP_OF_REAL(10.) |
Definition at line 84 of file guidance_v.c.
Referenced by run_hover_loop().
#define GUIDANCE_V_MAX_ERR_ZD SPEED_BFP_OF_REAL(10.) |
Definition at line 92 of file guidance_v.c.
Referenced by run_hover_loop().
#define GUIDANCE_V_MAX_RC_CLIMB_SPEED GUIDANCE_V_REF_MIN_ZD |
Definition at line 72 of file guidance_v.c.
Referenced by guidance_v_read_rc().
#define GUIDANCE_V_MAX_RC_DESCENT_SPEED GUIDANCE_V_REF_MAX_ZD |
Definition at line 76 of file guidance_v.c.
Referenced by guidance_v_read_rc().
#define GUIDANCE_V_MAX_SUM_ERR 2000000 |
Definition at line 96 of file guidance_v.c.
Referenced by run_hover_loop().
#define GUIDANCE_V_MIN_ERR_Z POS_BFP_OF_REAL(-10.) |
Definition at line 80 of file guidance_v.c.
Referenced by run_hover_loop().
#define GUIDANCE_V_MIN_ERR_ZD SPEED_BFP_OF_REAL(-10.) |
Definition at line 88 of file guidance_v.c.
Referenced by run_hover_loop().
#define GUIDANCE_V_NOMINAL_HOVER_THROTTLE 0.4 |
Definition at line 58 of file guidance_v.c.
Referenced by guidance_v_init().
|
static |
get the cosine of the angle between thrust vector and gravity vector
Definition at line 382 of file guidance_v.c.
References BFP_OF_REAL, INT32_TRIG_FRAC, Int32RMat::m, and stateGetNedToBodyRMat_i().
Referenced by guidance_v_thrust_adapt().
void guidance_v_from_nav | ( | bool | in_flight | ) |
Set guidance setpoint from NAV and run hover loop.
Definition at line 473 of file guidance_v.c.
References guidance_hybrid_vertical(), guidance_v_delta_t, GuidanceVSetRef, gv_update_ref_from_z_sp(), gv_update_ref_from_zd_sp(), Min, nav_climb, nav_flight_altitude, nav_throttle, radio_control, RC_OK, run_hover_loop(), stabilization_cmd, stateGetPositionNed_i(), stateGetSpeedNed_i(), RadioControl::status, vertical_mode, VERTICAL_MODE_ALT, VERTICAL_MODE_CLIMB, VERTICAL_MODE_MANUAL, and NedCoor_i::z.
Referenced by guidance_v_run().
void guidance_v_guided_enter | ( | void | ) |
Enter GUIDED mode control.
Definition at line 505 of file guidance_v.c.
References GUIDANCE_V_GUIDED_MODE_ZHOLD, GuidanceVSetRef, stateGetPositionNed_i(), stateGetSpeedNed_i(), and NedCoor_i::z.
Referenced by guidance_v_mode_changed().
void guidance_v_guided_run | ( | bool | in_flight | ) |
Run GUIDED mode control.
Definition at line 519 of file guidance_v.c.
References guidance_v_delta_t, GUIDANCE_V_GUIDED_MODE_CLIMB, GUIDANCE_V_GUIDED_MODE_THROTTLE, GUIDANCE_V_GUIDED_MODE_ZHOLD, guidance_v_th_sp, gv_update_ref_from_z_sp(), gv_update_ref_from_zd_sp(), Min, radio_control, RC_OK, run_hover_loop(), stabilization_cmd, stateGetPositionNed_i(), RadioControl::status, and NedCoor_i::z.
Referenced by guidance_v_run().
void guidance_v_init | ( | void | ) |
Definition at line 178 of file guidance_v.c.
References BFP_OF_REAL, DefaultPeriodic, GUIDANCE_V_ADAPT_THROTTLE_ENABLED, GUIDANCE_V_GUIDED_MODE_ZHOLD, GUIDANCE_V_MODE_KILL, guidance_v_module_init(), GUIDANCE_V_NOMINAL_HOVER_THROTTLE, gv_adapt_init(), INT32_TRIG_FRAC, register_periodic_telemetry(), send_tune_vert(), and send_vert_loop().
void guidance_v_mode_changed | ( | uint8_t | new_mode | ) |
Definition at line 231 of file guidance_v.c.
References guidance_v_guided_enter(), GUIDANCE_V_MODE_CLIMB, GUIDANCE_V_MODE_FLIP, GUIDANCE_V_MODE_GUIDED, GUIDANCE_V_MODE_HOVER, GUIDANCE_V_MODE_MODULE, GUIDANCE_V_MODE_NAV, GUIDANCE_V_MODE_RC_CLIMB, guidance_v_module_enter(), GuidanceVSetRef, stateGetPositionNed_i(), and stateGetSpeedNed_i().
Referenced by autopilot_static_set_mode().
void guidance_v_notify_in_flight | ( | bool | in_flight | ) |
Definition at line 271 of file guidance_v.c.
References gv_adapt_init().
void guidance_v_read_rc | ( | void | ) |
Definition at line 209 of file guidance_v.c.
References GUIDANCE_V_CLIMB_RC_DEADBAND, GUIDANCE_V_MAX_RC_CLIMB_SPEED, GUIDANCE_V_MAX_RC_DESCENT_SPEED, MAX_PPRZ, radio_control, RADIO_THROTTLE, SPEED_BFP_OF_REAL, and RadioControl::values.
Referenced by autopilot_static_on_rc_frame().
void guidance_v_run | ( | bool | in_flight | ) |
Definition at line 299 of file guidance_v.c.
References guidance_v_delta_t, guidance_v_from_nav(), GUIDANCE_V_GUIDED_MODE_ZHOLD, guidance_v_guided_run(), GUIDANCE_V_MODE_CLIMB, GUIDANCE_V_MODE_FLIP, GUIDANCE_V_MODE_GUIDED, GUIDANCE_V_MODE_HOVER, GUIDANCE_V_MODE_MODULE, GUIDANCE_V_MODE_NAV, GUIDANCE_V_MODE_RC_CLIMB, GUIDANCE_V_MODE_RC_DIRECT, guidance_v_module_run(), guidance_v_rc_delta_t, guidance_v_rc_zd_sp, guidance_v_thrust_adapt(), gv_update_ref_from_zd_sp(), Min, radio_control, RC_OK, run_hover_loop(), stabilization_cmd, stateGetPositionNed_i(), RadioControl::status, and NedCoor_i::z.
Referenced by autopilot_static_periodic().
bool guidance_v_set_guided_th | ( | float | th | ) |
Definition at line 582 of file guidance_v.c.
References GUIDANCE_V_GUIDED_MODE_THROTTLE, GUIDANCE_V_MODE_GUIDED, GuidanceVSetRef, MAX_PPRZ, stateGetPositionNed_i(), and stateGetSpeedNed_i().
bool guidance_v_set_guided_vz | ( | float | vz | ) |
Set z velocity setpoint in GUIDED mode.
vz | Setpoint (down is positive) in meters/second. |
Definition at line 568 of file guidance_v.c.
References GUIDANCE_V_GUIDED_MODE_CLIMB, GUIDANCE_V_MODE_GUIDED, and SPEED_BFP_OF_REAL.
Referenced by autopilot_guided_move_ned(), and autopilot_guided_update().
bool guidance_v_set_guided_z | ( | float | z | ) |
Set z setpoint in GUIDED mode.
z | Setpoint (down is positive) in meters. |
Definition at line 551 of file guidance_v.c.
References GUIDANCE_V_GUIDED_MODE_ZHOLD, GUIDANCE_V_MODE_GUIDED, and POS_BFP_OF_REAL.
Referenced by autopilot_guided_goto_ned(), and autopilot_guided_update().
Set guidance ref parameters.
Definition at line 372 of file guidance_v.c.
References gv_set_ref().
void guidance_v_thrust_adapt | ( | bool | in_flight | ) |
Definition at line 278 of file guidance_v.c.
References get_vertical_thrust_coeff(), guidance_v_thrust_coeff, gv_adapt_init(), gv_adapt_run(), INT32_TRIG_FRAC, stabilization_cmd, and stateGetAccelNed_i().
Referenced by guidance_v_run().
void guidance_v_z_enter | ( | void | ) |
Definition at line 359 of file guidance_v.c.
References GuidanceVSetRef, stateGetPositionNed_i(), and NedCoor_i::z.
void run_hover_loop | ( | bool | in_flight | ) |
Definition at line 412 of file guidance_v.c.
References BFP_OF_REAL, FF_CMD_FRAC, guidance_v_fb_cmd, GUIDANCE_V_MAX_CMD, GUIDANCE_V_MAX_ERR_Z, GUIDANCE_V_MAX_ERR_ZD, GUIDANCE_V_MAX_SUM_ERR, GUIDANCE_V_MIN_ERR_Z, GUIDANCE_V_MIN_ERR_ZD, guidance_v_z_sum_err, gv_adapt_X, GV_ADAPT_X_FRAC, gv_z_ref, GV_Z_REF_FRAC, gv_zd_ref, GV_ZD_REF_FRAC, gv_zdd_ref, GV_ZDD_REF_FRAC, INT32_ACCEL_FRAC, INT32_POS_FRAC, INT32_SPEED_FRAC, INT32_TRIG_FRAC, MAX_PPRZ, stateGetPositionNed_i(), stateGetSpeedNed_i(), and NedCoor_i::z.
Referenced by guidance_v_from_nav(), guidance_v_guided_run(), and guidance_v_run().
|
static |
Definition at line 168 of file guidance_v.c.
References stateGetPositionNed_i().
Referenced by guidance_v_init().
|
static |
Definition at line 150 of file guidance_v.c.
References gv_adapt_P, gv_adapt_X, gv_adapt_Xmeas, stateGetAccelNed_i(), stateGetPositionNed_i(), and stateGetSpeedNed_i().
Referenced by guidance_v_init().
|
static |
Definition at line 110 of file guidance_v.c.
bool guidance_v_adapt_throttle_enabled |
Use adaptive throttle command estimation.
Definition at line 109 of file guidance_v.c.
int32_t guidance_v_delta_t |
thrust command.
summation of feed-forward and feed-back commands, valid range 0 : MAX_PPRZ
Definition at line 106 of file guidance_v.c.
Referenced by guidance_hybrid_vertical(), guidance_v_from_nav(), guidance_v_guided_run(), and guidance_v_run().
int32_t guidance_v_fb_cmd |
int32_t guidance_v_ff_cmd |
feed-forward command
Definition at line 104 of file guidance_v.c.
int guidance_v_guided_mode |
Definition at line 116 of file guidance_v.c.
int32_t guidance_v_kd |
vertical control D-gain
Definition at line 137 of file guidance_v.c.
Referenced by guidance_hybrid_vertical().
int32_t guidance_v_ki |
vertical control I-gain
Definition at line 138 of file guidance_v.c.
Referenced by guidance_hybrid_vertical().
int32_t guidance_v_kp |
vertical control P-gain
Definition at line 136 of file guidance_v.c.
Referenced by guidance_hybrid_vertical().
uint8_t guidance_v_mode |
Definition at line 103 of file guidance_v.c.
Referenced by booz_fms_impl_periodic(), and send_status().
float guidance_v_nominal_throttle |
nominal throttle for hover.
This is only used if GUIDANCE_V_NOMINAL_HOVER_THROTTLE is defined! Unit: factor of MAX_PPRZ with range 0.1 : 0.9
Definition at line 108 of file guidance_v.c.
Referenced by guidance_hybrid_vertical(), and vertical_ctrl_module_init().
int32_t guidance_v_rc_delta_t |
Direct throttle from radio control.
range 0:MAX_PPRZ
Definition at line 121 of file guidance_v.c.
Referenced by guidance_v_run().
int32_t guidance_v_rc_zd_sp |
Vertical speed setpoint from radio control.
fixed point representation: Q12.19 accuracy 0.0000019, range +/-4096
Definition at line 127 of file guidance_v.c.
Referenced by guidance_v_run().
int32_t guidance_v_th_sp |
Definition at line 131 of file guidance_v.c.
Referenced by guidance_v_guided_run().
int32_t guidance_v_thrust_coeff |
Definition at line 142 of file guidance_v.c.
Referenced by guidance_h_traj_run(), and guidance_v_thrust_adapt().
int32_t guidance_v_z_ref |
altitude reference in meters.
fixed point representation: Q23.8 accuracy 0.0039, range 8388km
Definition at line 132 of file guidance_v.c.
Referenced by gps_sim_hitl_event(), and guidance_indi_run().
int32_t guidance_v_z_sp |
altitude setpoint in meters (input).
fixed point representation: Q23.8 accuracy 0.0039, range 8388km
Definition at line 129 of file guidance_v.c.
Referenced by send_fp().
int32_t guidance_v_z_sum_err |
int32_t guidance_v_zd_ref |
vertical speed reference in meter/s.
fixed point representation: Q12.19 accuracy 0.0000038, range 4096
Definition at line 133 of file guidance_v.c.
Referenced by gps_sim_hitl_event().
int32_t guidance_v_zd_sp |
vertical speed setpoint in meter/s (input).
fixed point representation: Q12.19 accuracy 0.0000019, range +/-4096
Definition at line 130 of file guidance_v.c.
Referenced by autopilot_static_set_mode().
int32_t guidance_v_zdd_ref |
vertical acceleration reference in meter/s^2.
fixed point representation: Q21.10 accuracy 0.0009766, range 2097152
Definition at line 134 of file guidance_v.c.
Referenced by gps_sim_hitl_event().