mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
AC_Circle: integrate pos vel accel offsets
Co-authored-by: Leonard Hall <leonardthall@gmail.com>
This commit is contained in:
parent
9185b82b7a
commit
9ca47cf465
@ -86,7 +86,7 @@ void AC_Circle::init()
|
|||||||
_pos_control.init_z_controller_stopping_point();
|
_pos_control.init_z_controller_stopping_point();
|
||||||
|
|
||||||
// get stopping point
|
// get stopping point
|
||||||
const Vector3p& stopping_point = _pos_control.get_pos_target_cm();
|
const Vector3p& stopping_point = _pos_control.get_pos_desired_cm();
|
||||||
|
|
||||||
// set circle center to circle_radius ahead of stopping point
|
// set circle center to circle_radius ahead of stopping point
|
||||||
_center = stopping_point;
|
_center = stopping_point;
|
||||||
@ -185,7 +185,7 @@ bool AC_Circle::update(float climb_rate_cms)
|
|||||||
if (_terrain_alt) {
|
if (_terrain_alt) {
|
||||||
target_z_cm = _center.z + terr_offset;
|
target_z_cm = _center.z + terr_offset;
|
||||||
} else {
|
} else {
|
||||||
target_z_cm = _pos_control.get_pos_target_z_cm();
|
target_z_cm = _pos_control.get_pos_desired_z_cm();
|
||||||
}
|
}
|
||||||
|
|
||||||
// if the circle_radius is zero we are doing panorama so no need to update loiter target
|
// if the circle_radius is zero we are doing panorama so no need to update loiter target
|
||||||
@ -200,7 +200,7 @@ bool AC_Circle::update(float climb_rate_cms)
|
|||||||
target.y += - _radius * sinf(-_angle);
|
target.y += - _radius * sinf(-_angle);
|
||||||
|
|
||||||
// heading is from vehicle to center of circle
|
// heading is from vehicle to center of circle
|
||||||
_yaw = get_bearing_cd(_inav.get_position_xy_cm(), _center.tofloat().xy());
|
_yaw = get_bearing_cd(_pos_control.get_pos_desired_cm().xy().tofloat(), _center.tofloat().xy());
|
||||||
|
|
||||||
if ((_options.get() & CircleOptions::FACE_DIRECTION_OF_TRAVEL) != 0) {
|
if ((_options.get() & CircleOptions::FACE_DIRECTION_OF_TRAVEL) != 0) {
|
||||||
_yaw += is_positive(_rate)?-9000.0f:9000.0f;
|
_yaw += is_positive(_rate)?-9000.0f:9000.0f;
|
||||||
@ -313,12 +313,13 @@ void AC_Circle::init_start_angle(bool use_heading)
|
|||||||
_angle = wrap_PI(_ahrs.yaw-M_PI);
|
_angle = wrap_PI(_ahrs.yaw-M_PI);
|
||||||
} else {
|
} else {
|
||||||
// if we are exactly at the center of the circle, init angle to directly behind vehicle (so vehicle will backup but not change heading)
|
// if we are exactly at the center of the circle, init angle to directly behind vehicle (so vehicle will backup but not change heading)
|
||||||
const Vector3f &curr_pos = _inav.get_position_neu_cm();
|
// curr_pos_desired is the position before we add offsets and terrain
|
||||||
if (is_equal(curr_pos.x,float(_center.x)) && is_equal(curr_pos.y,float(_center.y))) {
|
const Vector3f &curr_pos_desired= _pos_control.get_pos_desired_cm().tofloat();
|
||||||
|
if (is_equal(curr_pos_desired.x,float(_center.x)) && is_equal(curr_pos_desired.y,float(_center.y))) {
|
||||||
_angle = wrap_PI(_ahrs.yaw-M_PI);
|
_angle = wrap_PI(_ahrs.yaw-M_PI);
|
||||||
} else {
|
} else {
|
||||||
// get bearing from circle center to vehicle in radians
|
// get bearing from circle center to vehicle in radians
|
||||||
float bearing_rad = atan2f(curr_pos.y-_center.y,curr_pos.x-_center.x);
|
float bearing_rad = atan2f(curr_pos_desired.y-_center.y, curr_pos_desired.x-_center.x);
|
||||||
_angle = wrap_PI(bearing_rad);
|
_angle = wrap_PI(bearing_rad);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user