AR_PosControl: add singleton and get_srate

This commit is contained in:
Randy Mackay 2023-06-02 14:48:02 +09:00
parent 6c87dcd32d
commit 6540d12d66
2 changed files with 22 additions and 2 deletions

View File

@ -22,8 +22,6 @@
#include <GCS_MAVLink/GCS.h> #include <GCS_MAVLink/GCS.h>
#include <AC_Avoidance/AC_Avoid.h> #include <AC_Avoidance/AC_Avoid.h>
extern const AP_HAL::HAL& hal;
#define AR_POSCON_TIMEOUT_MS 100 // timeout after 0.1 sec #define AR_POSCON_TIMEOUT_MS 100 // timeout after 0.1 sec
#define AR_POSCON_POS_P 0.2f // default position P gain #define AR_POSCON_POS_P 0.2f // default position P gain
#define AR_POSCON_VEL_P 1.0f // default velocity P gain #define AR_POSCON_VEL_P 1.0f // default velocity P gain
@ -35,6 +33,10 @@ extern const AP_HAL::HAL& hal;
#define AR_POSCON_VEL_FILT_D 5.0f // default velocity D term filter #define AR_POSCON_VEL_FILT_D 5.0f // default velocity D term filter
#define AR_POSCON_DT 0.02f // default dt for PID controllers #define AR_POSCON_DT 0.02f // default dt for PID controllers
extern const AP_HAL::HAL& hal;
AR_PosControl *AR_PosControl::_singleton;
const AP_Param::GroupInfo AR_PosControl::var_info[] = { const AP_Param::GroupInfo AR_PosControl::var_info[] = {
// @Param: _POS_P // @Param: _POS_P
@ -103,6 +105,7 @@ AR_PosControl::AR_PosControl(AR_AttitudeControl& atc) :
_p_pos(AR_POSCON_POS_P), _p_pos(AR_POSCON_POS_P),
_pid_vel(AR_POSCON_VEL_P, AR_POSCON_VEL_I, AR_POSCON_VEL_D, AR_POSCON_VEL_FF, AR_POSCON_VEL_IMAX, AR_POSCON_VEL_FILT, AR_POSCON_VEL_FILT_D) _pid_vel(AR_POSCON_VEL_P, AR_POSCON_VEL_I, AR_POSCON_VEL_D, AR_POSCON_VEL_FF, AR_POSCON_VEL_IMAX, AR_POSCON_VEL_FILT, AR_POSCON_VEL_FILT_D)
{ {
_singleton = this;
AP_Param::setup_object_defaults(this, var_info); AP_Param::setup_object_defaults(this, var_info);
} }
@ -349,6 +352,13 @@ Vector2p AR_PosControl::get_pos_error() const
return (_pos_target - curr_pos_NE.topostype()); return (_pos_target - curr_pos_NE.topostype());
} }
// get the slew rate value for velocity. used for oscillation detection in lua scripts
void AR_PosControl::get_srate(float &velocity_srate)
{
// slew rate is the same for x and y axis
velocity_srate = _pid_vel.get_pid_info_x().slew_rate;
}
// write PSC logs // write PSC logs
void AR_PosControl::write_log() void AR_PosControl::write_log()
{ {

View File

@ -11,6 +11,11 @@ public:
// constructor // constructor
AR_PosControl(AR_AttitudeControl& atc); AR_PosControl(AR_AttitudeControl& atc);
// do not allow copying
CLASS_NO_COPY(AR_PosControl);
static AR_PosControl *get_singleton() { return _singleton; }
// update navigation // update navigation
void update(float dt); void update(float dt);
@ -73,6 +78,9 @@ public:
AC_P_2D& get_pos_p() { return _p_pos; } AC_P_2D& get_pos_p() { return _p_pos; }
AC_PID_2D& get_vel_pid() { return _pid_vel; } AC_PID_2D& get_vel_pid() { return _pid_vel; }
// get the slew rate value for velocity. used for oscillation detection in lua scripts
void get_srate(float &velocity_srate);
// write PSC logs // write PSC logs
void write_log(); void write_log();
@ -81,6 +89,8 @@ public:
private: private:
static AR_PosControl *_singleton;
// initialise and check for ekf position resets // initialise and check for ekf position resets
void init_ekf_xy_reset(); void init_ekf_xy_reset();
void handle_ekf_xy_reset(); void handle_ekf_xy_reset();