Auterion App SDK
Auterion SDK is a library that can be used by AuterionOS apps to communicate with the system.
Loading...
Searching...
No Matches
los_specific_force_controller.hpp
1/****************************************************************************
2 *
3 * Copyright 2026 Auterion. All rights reserved.
4 *
5 ****************************************************************************/
6
7#pragma once
8
9#include <Eigen/Eigen>
10#include <memory>
11
12namespace auterion {
13
19
29 public:
30 struct Parameters {
32 double sf_p{0.05};
34 double sf_i{5.0};
36 double att_lpf_tc{0.1};
38 double roll_limit_deg{180.0};
40 double pitch_limit_deg{90.0};
43 double cam_vfov{30.0};
45 double cam_pitch{0.0};
50 double thrust_min{0.0};
52 double thrust_max{1.0};
59 };
60
61 struct State {
63 Eigen::Matrix3d los_to_enu{Eigen::Matrix3d::Identity()};
65 Eigen::Vector3d sf_sp_enu{Eigen::Vector3d::Zero()};
68 Eigen::Vector3d sf_sp_los{Eigen::Vector3d::Zero()};
70 Eigen::Vector3d sf_los{Eigen::Vector3d::Zero()};
72 Eigen::Vector3d thrust_sp_enu{Eigen::Vector3d::Zero()};
74 Eigen::Vector3d thrust_sp_los{Eigen::Vector3d::Zero()};
78 Eigen::Quaterniond attitude_sp_enu{Eigen::Quaterniond::Identity()};
82 double thrust_command_abs{0.0};
84 Eigen::Vector3d sf_los_error_prev{Eigen::Vector3d::Zero()};
86 Eigen::Vector3d sf_los_prev{Eigen::Vector3d::Zero()};
88 bool initialized{false};
89 };
90
95 explicit LosSpecificForceController(const Parameters& parameters);
96
101 void setParameters(const Parameters& parameters);
102
116 void setInitialThrustNormalized(double thrust_normalized);
117
129 void update(float dt_s, bool hold, double max_thrust_rate_los_x, const Eigen::Vector3d& los,
130 const Eigen::Vector3d& acc_sp_enu, const Eigen::Quaterniond& attitude_enu,
131 const Eigen::Vector3d& specific_force_flu);
132
136 const State& state() const;
137
138 private:
139 std::shared_ptr<LosSpecificForceControllerImpl> _impl;
140};
141
142} // namespace auterion
Implementation details for the LosSpecificForceController class.
Line-of-Sight (LOS) attitude controller for multicopters.
Definition los_specific_force_controller.hpp:28
LosSpecificForceController(const Parameters &parameters)
Constructs a LosSpecificForceController with the given parameters.
const State & state() const
Returns a const reference to the current controller state.
void setParameters(const Parameters &parameters)
Updates the controller parameters.
void update(float dt_s, bool hold, double max_thrust_rate_los_x, const Eigen::Vector3d &los, const Eigen::Vector3d &acc_sp_enu, const Eigen::Quaterniond &attitude_enu, const Eigen::Vector3d &specific_force_flu)
Runs one update step of the LOS controller.
void setInitialThrustNormalized(double thrust_normalized)
Seed the initial normalized thrust for a glitch-free takeover.
Definition los_specific_force_controller.hpp:30
double thrust_min
Minimum normalized thrust command output [0, 1].
Definition los_specific_force_controller.hpp:50
double hover_thrust_normalized
Definition los_specific_force_controller.hpp:48
double cam_pitch
Camera pitch angle relative to the drone body, positive up [deg].
Definition los_specific_force_controller.hpp:45
double sf_i
Integral gain of the specific-force controller.
Definition los_specific_force_controller.hpp:34
double att_lpf_tc
Time constant of the attitude setpoint low-pass filter [s]. Set to 0 to disable.
Definition los_specific_force_controller.hpp:36
double thrust_max
Maximum normalized thrust command output [0, 1].
Definition los_specific_force_controller.hpp:52
double cam_vfov
Definition los_specific_force_controller.hpp:43
double sf_p
Proportional gain of the specific-force controller.
Definition los_specific_force_controller.hpp:32
double roll_limit_deg
Maximum roll angle [deg]. Set to 180 to disable.
Definition los_specific_force_controller.hpp:38
double roll_max_rate_deg_per_s
Maximum roll rate in body frame [deg/s]. Set to 0 to disable.
Definition los_specific_force_controller.hpp:56
double yaw_max_rate_deg_per_s
Maximum yaw rate in body frame [deg/s]. Set to infinity to disable.
Definition los_specific_force_controller.hpp:58
double pitch_limit_deg
Maximum pitch angle [deg]. Set to 90 to disable.
Definition los_specific_force_controller.hpp:40
double tilt_max_rate_deg_per_s
Maximum tilt rate [deg/s]. Limits how fast the thrust vector can tilt.
Definition los_specific_force_controller.hpp:54
Definition los_specific_force_controller.hpp:61
Eigen::Vector3d sf_los_prev
Previous measured specific force in LOS frame. Used internally by the velocity-form PID.
Definition los_specific_force_controller.hpp:86
double thrust_command_normalized
Normalized thrust command in [0, 1].
Definition los_specific_force_controller.hpp:80
Eigen::Vector3d sf_los_error_prev
Previous specific force error in LOS frame. Used internally by the velocity-form PID.
Definition los_specific_force_controller.hpp:84
double desired_thrust_rate_los_x
Thrust rate being applied along the LOS x-axis [normalized/s].
Definition los_specific_force_controller.hpp:76
Eigen::Vector3d thrust_sp_enu
Thrust setpoint in ENU frame [normalized].
Definition los_specific_force_controller.hpp:72
Eigen::Matrix3d los_to_enu
Rotation matrix from LOS frame to ENU frame.
Definition los_specific_force_controller.hpp:63
Eigen::Vector3d sf_sp_los
Definition los_specific_force_controller.hpp:68
double thrust_command_abs
Absolute thrust command [normalized, unbounded before hover thrust scaling].
Definition los_specific_force_controller.hpp:82
bool initialized
False until the first call to update(), after which the controller is fully initialized.
Definition los_specific_force_controller.hpp:88
Eigen::Vector3d sf_sp_enu
Specific force setpoint in ENU frame [m/s²].
Definition los_specific_force_controller.hpp:65
Eigen::Vector3d sf_los
Measured specific force in LOS frame [m/s²]. X component is always 0.
Definition los_specific_force_controller.hpp:70
Eigen::Vector3d thrust_sp_los
Thrust setpoint in LOS frame [normalized].
Definition los_specific_force_controller.hpp:74
Eigen::Quaterniond attitude_sp_enu
Attitude setpoint in ENU frame (after filtering and limiting).
Definition los_specific_force_controller.hpp:78