mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-18 14:48:28 -04:00
AR_PosControl: limit and zero velocity I-term
zero in forward-back direction limit in lateral direction
This commit is contained in:
parent
6f52eaf9a7
commit
9c15dcb206
@ -157,12 +157,23 @@ void AR_PosControl::update(float dt)
|
|||||||
_vel_target.y = vel_3d_cms.y * 0.01;
|
_vel_target.y = vel_3d_cms.y * 0.01;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// calculate limit vector based on steering limits
|
||||||
|
Vector2f steering_limit_vec;
|
||||||
|
if (_atc.steering_limit_left()) {
|
||||||
|
steering_limit_vec = AP::ahrs().body_to_earth2D(Vector2f{0, _reversed ? 1.0f : -1.0f});
|
||||||
|
} else if (_atc.steering_limit_right()) {
|
||||||
|
steering_limit_vec = AP::ahrs().body_to_earth2D(Vector2f{0, _reversed ? -1.0f : 1.0f});
|
||||||
|
}
|
||||||
|
|
||||||
// calculate desired acceleration
|
// calculate desired acceleration
|
||||||
// To-Do: fixup _limit_vel used below
|
_accel_target = _pid_vel.update_all(_vel_target, curr_vel_NED.xy(), dt, steering_limit_vec);
|
||||||
_accel_target = _pid_vel.update_all(_vel_target, curr_vel_NED.xy(), dt, _limit_vel);
|
|
||||||
if (_accel_desired_valid) {
|
if (_accel_desired_valid) {
|
||||||
_accel_target += _accel_desired;
|
_accel_target += _accel_desired;
|
||||||
}
|
}
|
||||||
|
// velocity controller I-term zeroed in forward-back direction
|
||||||
|
const Vector2f lat_vec_ef = AP::ahrs().body_to_earth2D(Vector2f{0, 1});
|
||||||
|
const Vector2f vel_i = _pid_vel.get_i().projected(lat_vec_ef);
|
||||||
|
_pid_vel.set_integrator(vel_i);
|
||||||
|
|
||||||
// convert desired acceleration to desired forward-back speed, desired lateral speed and desired turn rate
|
// convert desired acceleration to desired forward-back speed, desired lateral speed and desired turn rate
|
||||||
|
|
||||||
|
@ -98,7 +98,6 @@ private:
|
|||||||
float _lat_accel_max; // lateral acceleration maximum in m/s/s
|
float _lat_accel_max; // lateral acceleration maximum in m/s/s
|
||||||
float _jerk_max; // maximum jerk in m/s/s/s (used for both forward and lateral input shaping)
|
float _jerk_max; // maximum jerk in m/s/s/s (used for both forward and lateral input shaping)
|
||||||
float _turn_radius; // vehicle turn radius in meters
|
float _turn_radius; // vehicle turn radius in meters
|
||||||
Vector2f _limit_vel; // To-Do: explain what this is
|
|
||||||
|
|
||||||
// position and velocity targets
|
// position and velocity targets
|
||||||
Vector2p _pos_target; // position target as an offset (in meters) from the EKF origin
|
Vector2p _pos_target; // position target as an offset (in meters) from the EKF origin
|
||||||
|
Loading…
Reference in New Issue
Block a user