mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-10 18:08:30 -04:00
AC_PosControl: Move hover throttle calculation to AP_Motors
This commit is contained in:
parent
b27da7699e
commit
dcbb071c07
@ -41,7 +41,6 @@ AC_PosControl::AC_PosControl(const AP_AHRS& ahrs, const AP_InertialNav& inav,
|
|||||||
_dt_xy(POSCONTROL_DT_50HZ),
|
_dt_xy(POSCONTROL_DT_50HZ),
|
||||||
_last_update_xy_ms(0),
|
_last_update_xy_ms(0),
|
||||||
_last_update_z_ms(0),
|
_last_update_z_ms(0),
|
||||||
_throttle_hover(POSCONTROL_THROTTLE_HOVER),
|
|
||||||
_speed_down_cms(POSCONTROL_SPEED_DOWN),
|
_speed_down_cms(POSCONTROL_SPEED_DOWN),
|
||||||
_speed_up_cms(POSCONTROL_SPEED_UP),
|
_speed_up_cms(POSCONTROL_SPEED_UP),
|
||||||
_speed_cms(POSCONTROL_SPEED),
|
_speed_cms(POSCONTROL_SPEED),
|
||||||
@ -307,7 +306,7 @@ void AC_PosControl::init_takeoff()
|
|||||||
freeze_ff_z();
|
freeze_ff_z();
|
||||||
|
|
||||||
// shift difference between last motor out and hover throttle into accelerometer I
|
// shift difference between last motor out and hover throttle into accelerometer I
|
||||||
_pid_accel_z.set_integrator(_motors.get_throttle()-_throttle_hover);
|
_pid_accel_z.set_integrator(_motors.get_throttle()-_motors.get_throttle_hover());
|
||||||
}
|
}
|
||||||
|
|
||||||
// is_active_z - returns true if the z-axis position controller has been run very recently
|
// is_active_z - returns true if the z-axis position controller has been run very recently
|
||||||
@ -483,7 +482,7 @@ void AC_PosControl::accel_to_throttle(float accel_target_z)
|
|||||||
// get d term
|
// get d term
|
||||||
d = _pid_accel_z.get_d();
|
d = _pid_accel_z.get_d();
|
||||||
|
|
||||||
float thr_out = (p+i+d)/1000.0f +_throttle_hover;
|
float thr_out = (p+i+d)/1000.0f +_motors.get_throttle_hover();
|
||||||
|
|
||||||
// send throttle to attitude controller with angle boost
|
// send throttle to attitude controller with angle boost
|
||||||
_attitude_control.set_throttle_out(thr_out, true, POSCONTROL_THROTTLE_CUTOFF_FREQ);
|
_attitude_control.set_throttle_out(thr_out, true, POSCONTROL_THROTTLE_CUTOFF_FREQ);
|
||||||
|
@ -14,7 +14,6 @@
|
|||||||
|
|
||||||
|
|
||||||
// position controller default definitions
|
// position controller default definitions
|
||||||
#define POSCONTROL_THROTTLE_HOVER 0.5f // default throttle required to maintain hover
|
|
||||||
#define POSCONTROL_ACCELERATION_MIN 50.0f // minimum horizontal acceleration in cm/s/s - used for sanity checking acceleration in leash length calculation
|
#define POSCONTROL_ACCELERATION_MIN 50.0f // minimum horizontal acceleration in cm/s/s - used for sanity checking acceleration in leash length calculation
|
||||||
#define POSCONTROL_ACCEL_XY 100.0f // default horizontal acceleration in cm/s/s. This is overwritten by waypoint and loiter controllers
|
#define POSCONTROL_ACCEL_XY 100.0f // default horizontal acceleration in cm/s/s. This is overwritten by waypoint and loiter controllers
|
||||||
#define POSCONTROL_ACCEL_XY_MAX 980.0f // max horizontal acceleration in cm/s/s that the position velocity controller will ask from the lower accel controller
|
#define POSCONTROL_ACCEL_XY_MAX 980.0f // max horizontal acceleration in cm/s/s that the position velocity controller will ask from the lower accel controller
|
||||||
@ -108,9 +107,6 @@ public:
|
|||||||
/// called by pos_to_rate_z if z-axis speed or accelerations are changed
|
/// called by pos_to_rate_z if z-axis speed or accelerations are changed
|
||||||
void calc_leash_length_z();
|
void calc_leash_length_z();
|
||||||
|
|
||||||
/// set_throttle_hover - update estimated throttle required to maintain hover
|
|
||||||
void set_throttle_hover(float throttle) { _throttle_hover = throttle; }
|
|
||||||
|
|
||||||
/// set_alt_target - set altitude target in cm above home
|
/// set_alt_target - set altitude target in cm above home
|
||||||
void set_alt_target(float alt_cm) { _pos_target.z = alt_cm; }
|
void set_alt_target(float alt_cm) { _pos_target.z = alt_cm; }
|
||||||
|
|
||||||
@ -248,7 +244,7 @@ public:
|
|||||||
|
|
||||||
/// get_stopping_point_xy - calculates stopping point based on current position, velocity, vehicle acceleration
|
/// get_stopping_point_xy - calculates stopping point based on current position, velocity, vehicle acceleration
|
||||||
/// distance_max allows limiting distance to stopping point
|
/// distance_max allows limiting distance to stopping point
|
||||||
/// results placed in stopping_position vector
|
/// results placed in stopping_position vector
|
||||||
/// set_accel_xy() should be called before this method to set vehicle acceleration
|
/// set_accel_xy() should be called before this method to set vehicle acceleration
|
||||||
/// set_leash_length() should have been called before this method
|
/// set_leash_length() should have been called before this method
|
||||||
void get_stopping_point_xy(Vector3f &stopping_point) const;
|
void get_stopping_point_xy(Vector3f &stopping_point) const;
|
||||||
@ -366,7 +362,7 @@ private:
|
|||||||
AC_P& _p_pos_z;
|
AC_P& _p_pos_z;
|
||||||
AC_P& _p_vel_z;
|
AC_P& _p_vel_z;
|
||||||
AC_PID& _pid_accel_z;
|
AC_PID& _pid_accel_z;
|
||||||
AC_P& _p_pos_xy;
|
AC_P& _p_pos_xy;
|
||||||
AC_PI_2D& _pi_vel_xy;
|
AC_PI_2D& _pi_vel_xy;
|
||||||
|
|
||||||
// parameters
|
// parameters
|
||||||
@ -377,7 +373,6 @@ private:
|
|||||||
float _dt_xy; // time difference (in seconds) between update_xy_controller and update_vel_controller_xyz calls
|
float _dt_xy; // time difference (in seconds) between update_xy_controller and update_vel_controller_xyz calls
|
||||||
uint32_t _last_update_xy_ms; // system time of last update_xy_controller call
|
uint32_t _last_update_xy_ms; // system time of last update_xy_controller call
|
||||||
uint32_t _last_update_z_ms; // system time of last update_z_controller call
|
uint32_t _last_update_z_ms; // system time of last update_z_controller call
|
||||||
float _throttle_hover; // estimated throttle required to maintain a level hover
|
|
||||||
float _speed_down_cms; // max descent rate in cm/s
|
float _speed_down_cms; // max descent rate in cm/s
|
||||||
float _speed_up_cms; // max climb rate in cm/s
|
float _speed_up_cms; // max climb rate in cm/s
|
||||||
float _speed_cms; // max horizontal speed in cm/s
|
float _speed_cms; // max horizontal speed in cm/s
|
||||||
|
Loading…
Reference in New Issue
Block a user