Paparazzi UAS
v7.0_unstable
Paparazzi is a free software Unmanned Aircraft System.
|
Horizontal guidance for rotorcrafts. More...
#include "math/pprz_algebra_int.h"
#include "math/pprz_algebra_float.h"
#include "firmwares/rotorcraft/guidance/guidance_h_ref.h"
#include "firmwares/rotorcraft/stabilization.h"
#include "generated/airframe.h"
#include "std.h"
Go to the source code of this file.
Data Structures | |
struct | HorizontalGuidanceSetpoint |
struct | HorizontalGuidanceReference |
struct | HorizontalGuidanceRCInput |
struct | HorizontalGuidance |
Macros | |
#define | GUIDANCE_H_USE_REF TRUE |
Use horizontal guidance reference trajectory. More... | |
#define | GUIDANCE_H_USE_SPEED_REF TRUE |
Use horizontal guidance speed reference. More... | |
#define | GUIDANCE_H_MODE_NONE 0 |
#define | GUIDANCE_H_MODE_HOVER 1 |
#define | GUIDANCE_H_MODE_NAV 2 |
#define | GUIDANCE_H_MODE_GUIDED 3 |
#define | GUIDANCE_H_MAX_BANK RadOfDeg(20) |
Max bank controlled by guidance. More... | |
#define | guidance_h_SetUseRef(_val) |
Functions | |
void | guidance_h_init (void) |
void | guidance_h_mode_changed (uint8_t new_mode) |
void | guidance_h_run_enter (void) |
struct StabilizationSetpoint | guidance_h_run (bool in_flight) |
struct StabilizationSetpoint | guidance_h_run_pos (bool in_flight, struct HorizontalGuidance *gh) |
struct StabilizationSetpoint | guidance_h_run_speed (bool in_flight, struct HorizontalGuidance *gh) |
struct StabilizationSetpoint | guidance_h_run_accel (bool in_flight, struct HorizontalGuidance *gh) |
void | guidance_h_hover_enter (void) |
void | guidance_h_nav_enter (void) |
struct StabilizationSetpoint | guidance_h_from_nav (bool in_flight) |
Set horizontal guidance from NAV and run control loop. More... | |
struct StabilizationSetpoint | guidance_h_guided_run (bool in_flight) |
Run GUIDED mode control. More... | |
void | guidance_h_set_pos (float x, float y) |
Set horizontal position setpoint. More... | |
void | guidance_h_set_heading (float heading) |
Set heading setpoint. More... | |
void | guidance_h_set_body_vel (float vx, float vy) |
Set body relative horizontal velocity setpoint. More... | |
void | guidance_h_set_acc (float ax, float ay) |
Set horizontal velocity setpoint. More... | |
void | guidance_h_set_body_acc (float ax, float ay) |
Set body relative horizontal acceleration setpoint. More... | |
void | guidance_h_set_vel (float vx, float vy) |
Set horizontal acceleration setpoint. More... | |
void | guidance_h_set_heading_rate (float rate) |
Set heading rate setpoint. More... | |
static void | guidance_h_SetMaxSpeed (float speed) |
static void | guidance_h_SetOmega (float omega) |
static void | guidance_h_SetZeta (float zeta) |
static void | guidance_h_SetTau (float tau) |
Variables | |
struct HorizontalGuidance | guidance_h |
Horizontal guidance for rotorcrafts.
Definition in file guidance_h.h.
struct HorizontalGuidanceReference |
Definition at line 91 of file guidance_h.h.
Data Fields | ||
---|---|---|
struct Int32Vect2 | accel | with INT32_ACCEL_FRAC |
struct Int32Vect2 | pos | with INT32_POS_FRAC |
struct Int32Vect2 | speed | with INT32_SPEED_FRAC |
struct HorizontalGuidanceRCInput |
Definition at line 97 of file guidance_h.h.
Data Fields | ||
---|---|---|
float | heading | |
float | last_ts | |
struct Int32Vect2 | vect |
struct HorizontalGuidance |
Definition at line 103 of file guidance_h.h.
Data Fields | ||
---|---|---|
uint8_t | mode | |
struct HorizontalGuidanceRCInput | rc_sp | remote control setpoint |
struct HorizontalGuidanceReference | ref | reference calculated from setpoints |
struct HorizontalGuidanceSetpoint | sp | setpoints |
bool | use_ref |
#define GUIDANCE_H_MAX_BANK RadOfDeg(20) |
Max bank controlled by guidance.
Definition at line 64 of file guidance_h.h.
#define GUIDANCE_H_MODE_GUIDED 3 |
Definition at line 59 of file guidance_h.h.
#define GUIDANCE_H_MODE_HOVER 1 |
Definition at line 57 of file guidance_h.h.
#define GUIDANCE_H_MODE_NAV 2 |
Definition at line 58 of file guidance_h.h.
#define GUIDANCE_H_MODE_NONE 0 |
Definition at line 56 of file guidance_h.h.
#define guidance_h_SetUseRef | ( | _val | ) |
Definition at line 177 of file guidance_h.h.
#define GUIDANCE_H_USE_REF TRUE |
Use horizontal guidance reference trajectory.
Default is TRUE, define to FALSE to always disable it.
Definition at line 45 of file guidance_h.h.
#define GUIDANCE_H_USE_SPEED_REF TRUE |
Use horizontal guidance speed reference.
This also allows to give velocity commands via RC in GUIDANCE_H_MODE_HOVER. Default is TRUE, define to FALSE to always disable it.
Definition at line 53 of file guidance_h.h.
struct StabilizationSetpoint guidance_h_from_nav | ( | bool | in_flight | ) |
Set horizontal guidance from NAV and run control loop.
Definition at line 364 of file guidance_h.c.
References RotorcraftNavigation::carrot, guidance_h_run_enter(), guidance_h_set_heading(), guidance_h_set_pos(), RotorcraftNavigation::heading, nav, reset_guidance_reference_from_current_position(), EnuCoor_f::x, and EnuCoor_f::y.
struct StabilizationSetpoint guidance_h_guided_run | ( | bool | in_flight | ) |
Run GUIDED mode control.
Definition at line 364 of file guidance_h.c.
void guidance_h_hover_enter | ( | void | ) |
Definition at line 343 of file guidance_h.c.
References guidance_h, guidance_h_run_enter(), guidance_h_set_heading(), guidance_h_set_pos(), HorizontalGuidanceRCInput::heading, FloatEulers::psi, HorizontalGuidance::rc_sp, reset_guidance_reference_from_current_position(), HorizontalGuidance::sp, HorizontalGuidanceSetpoint::speed, stateGetNedToBodyEulers_f(), stateGetPositionNed_f(), FloatVect2::x, Int32Vect2::x, FloatVect2::y, and Int32Vect2::y.
Referenced by guidance_h_mode_changed().
void guidance_h_init | ( | void | ) |
Definition at line 86 of file guidance_h.c.
References DefaultPeriodic, gh_ref_init(), guidance_h, GUIDANCE_H_MODE_NONE, GUIDANCE_H_RC_ID, GUIDANCE_H_USE_REF, HorizontalGuidanceSetpoint::h_mask, HorizontalGuidanceSetpoint::heading, HorizontalGuidanceRCInput::heading, HorizontalGuidanceSetpoint::heading_rate, INT_VECT2_ZERO, HorizontalGuidanceRCInput::last_ts, HorizontalGuidance::mode, HorizontalGuidanceSetpoint::pos, rc_cb(), rc_ev, HorizontalGuidance::rc_sp, register_periodic_telemetry(), send_gh(), send_href(), HorizontalGuidance::sp, HorizontalGuidance::use_ref, HorizontalGuidanceRCInput::vect, and HorizontalGuidanceSetpoint::yaw_mask.
void guidance_h_mode_changed | ( | uint8_t | new_mode | ) |
Definition at line 128 of file guidance_h.c.
References guidance_h, guidance_h_hover_enter(), GUIDANCE_H_MODE_GUIDED, GUIDANCE_H_MODE_HOVER, GUIDANCE_H_MODE_NAV, guidance_h_nav_enter(), and HorizontalGuidance::mode.
Referenced by autopilot_static_set_mode(), and guidance_module_enter().
void guidance_h_nav_enter | ( | void | ) |
Definition at line 364 of file guidance_h.c.
Referenced by guidance_h_mode_changed().
struct StabilizationSetpoint guidance_h_run | ( | bool | in_flight | ) |
Definition at line 219 of file guidance_h.c.
References autopilot_in_flight(), guidance_h, GUIDANCE_H_MODE_HOVER, GUIDANCE_H_MODE_NAV, HorizontalGuidanceSetpoint::h_mask, INT_VECT2_ZERO, HorizontalGuidance::mode, radio_control, RC_OK, HorizontalGuidance::rc_sp, read_rc_setpoint_heading(), read_rc_setpoint_speed_i(), HorizontalGuidance::sp, HorizontalGuidanceSetpoint::speed, RadioControl::status, and HorizontalGuidanceRCInput::vect.
Referenced by autopilot_static_periodic(), and guidance_module_run().
struct StabilizationSetpoint guidance_h_run_accel | ( | bool | in_flight, |
struct HorizontalGuidance * | gh | ||
) |
Definition at line 45 of file guidance_oneloop.c.
void guidance_h_run_enter | ( | void | ) |
Definition at line 35 of file guidance_oneloop.c.
References CTRL_ANDI, and oneloop_andi_enter().
Referenced by guidance_h_from_nav(), and guidance_h_hover_enter().
struct StabilizationSetpoint guidance_h_run_pos | ( | bool | in_flight, |
struct HorizontalGuidance * | gh | ||
) |
Definition at line 45 of file guidance_oneloop.c.
struct StabilizationSetpoint guidance_h_run_speed | ( | bool | in_flight, |
struct HorizontalGuidance * | gh | ||
) |
Definition at line 45 of file guidance_oneloop.c.
void guidance_h_set_acc | ( | float | ax, |
float | ay | ||
) |
Set horizontal velocity setpoint.
vx | North velocity (local NED frame) in meters/sec. |
vy | East velocity (local NED frame) in meters/sec. |
Definition at line 495 of file guidance_h.c.
References HorizontalGuidanceSetpoint::accel, ACCEL_BFP_OF_REAL, guidance_h, HorizontalGuidanceSetpoint::h_mask, reset_guidance_reference_from_current_position(), HorizontalGuidance::sp, Int32Vect2::x, and Int32Vect2::y.
Referenced by guidance_h_set_body_acc().
void guidance_h_set_body_acc | ( | float | ax, |
float | ay | ||
) |
Set body relative horizontal acceleration setpoint.
vx | forward acceleration (body frame) in meters/sec². |
vy | right acceleration (body frame) in meters/sec². |
Definition at line 487 of file guidance_h.c.
References guidance_h_set_acc(), FloatEulers::psi, and stateGetNedToBodyEulers_f().
void guidance_h_set_body_vel | ( | float | vx, |
float | vy | ||
) |
Set body relative horizontal velocity setpoint.
vx | forward velocity (body frame) in meters/sec. |
vy | right velocity (body frame) in meters/sec. |
Definition at line 469 of file guidance_h.c.
References guidance_h_set_vel(), FloatEulers::psi, and stateGetNedToBodyEulers_f().
Referenced by orange_avoider_guided_periodic().
void guidance_h_set_heading | ( | float | heading | ) |
Set heading setpoint.
heading | Setpoint in radians. |
Definition at line 462 of file guidance_h.c.
References FLOAT_ANGLE_NORMALIZE, guidance_h, HorizontalGuidanceSetpoint::heading, heading, HorizontalGuidance::sp, and HorizontalGuidanceSetpoint::yaw_mask.
Referenced by guidance_h_from_nav(), guidance_h_hover_enter(), and orange_avoider_guided_periodic().
void guidance_h_set_heading_rate | ( | float | rate | ) |
Set heading rate setpoint.
rate | Heading rate in radians. |
Definition at line 505 of file guidance_h.c.
References guidance_h, HorizontalGuidanceSetpoint::heading_rate, HorizontalGuidance::sp, and HorizontalGuidanceSetpoint::yaw_mask.
Referenced by orange_avoider_guided_periodic().
void guidance_h_set_pos | ( | float | x, |
float | y | ||
) |
Set horizontal position setpoint.
x | North position (local NED frame) in meters. |
y | East position (local NED frame) in meters. |
Definition at line 452 of file guidance_h.c.
References guidance_h, HorizontalGuidanceSetpoint::h_mask, HorizontalGuidanceSetpoint::pos, POS_BFP_OF_REAL, reset_guidance_reference_from_current_position(), HorizontalGuidance::sp, Int32Vect2::x, and Int32Vect2::y.
Referenced by guidance_h_from_nav(), and guidance_h_hover_enter().
void guidance_h_set_vel | ( | float | vx, |
float | vy | ||
) |
Set horizontal acceleration setpoint.
vx | North acceleration (local NED frame) in meters/sec². |
vy | East acceleration (local NED frame) in meters/sec². |
Definition at line 477 of file guidance_h.c.
References guidance_h, HorizontalGuidanceSetpoint::h_mask, reset_guidance_reference_from_current_position(), HorizontalGuidance::sp, HorizontalGuidanceSetpoint::speed, SPEED_BFP_OF_REAL, Int32Vect2::x, and Int32Vect2::y.
Referenced by guidance_h_set_body_vel().
|
inlinestatic |
Definition at line 181 of file guidance_h.h.
References gh_set_max_speed().
|
inlinestatic |
Definition at line 186 of file guidance_h.h.
References gh_set_omega().
|
inlinestatic |
Definition at line 196 of file guidance_h.h.
|
inlinestatic |
Definition at line 191 of file guidance_h.h.
References gh_set_zeta().
|
extern |
Definition at line 1 of file guidance_h.c.
Referenced by autopilot_static_periodic(), guidance_h_hover_enter(), guidance_h_init(), guidance_h_mode_changed(), guidance_h_run(), guidance_h_set_acc(), guidance_h_set_heading(), guidance_h_set_heading_rate(), guidance_h_set_pos(), guidance_h_set_vel(), guidance_h_update_reference(), ins_ekf2_publish_attitude(), orange_avoider_guided_periodic(), periodic_rotwing_state(), reset_guidance_reference_from_current_position(), send_fp(), send_gh(), send_hover_loop(), send_href(), send_status(), and stabilization_indi_set_wls_settings().