|
|
|
@ -6,10 +6,14 @@
@@ -6,10 +6,14 @@
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* update_auto - runs the auto controller |
|
|
|
|
* called at 50hz while control_mode is 'AUTO' |
|
|
|
|
* called at 50hz while control mode is 'AUTO' |
|
|
|
|
*/ |
|
|
|
|
void Tracker::update_auto(void) |
|
|
|
|
void Mode::update_auto(void) |
|
|
|
|
{ |
|
|
|
|
struct Tracker::NavStatus &nav_status = tracker.nav_status; |
|
|
|
|
|
|
|
|
|
Parameters &g = tracker.g; |
|
|
|
|
|
|
|
|
|
float yaw = wrap_180_cd((nav_status.bearing+g.yaw_trim)*100); // target yaw in centidegrees
|
|
|
|
|
float pitch = constrain_float(nav_status.pitch+g.pitch_trim, g.pitch_min, g.pitch_max) * 100; // target pitch in centidegrees
|
|
|
|
|
|
|
|
|
@ -22,17 +26,18 @@ void Tracker::update_auto(void)
@@ -22,17 +26,18 @@ void Tracker::update_auto(void)
|
|
|
|
|
convert_ef_to_bf(pitch, yaw, bf_pitch, bf_yaw); |
|
|
|
|
|
|
|
|
|
// only move servos if target is at least distance_min away if we have a target
|
|
|
|
|
if ((g.distance_min <= 0) || (nav_status.distance >= g.distance_min) || !vehicle.location_valid) { |
|
|
|
|
update_pitch_servo(bf_pitch); |
|
|
|
|
update_yaw_servo(bf_yaw); |
|
|
|
|
if ((g.distance_min <= 0) || (nav_status.distance >= g.distance_min) || !tracker.vehicle.location_valid) { |
|
|
|
|
tracker.update_pitch_servo(bf_pitch); |
|
|
|
|
tracker.update_yaw_servo(bf_yaw); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void Tracker::calc_angle_error(float pitch, float yaw, bool direction_reversed) |
|
|
|
|
void Mode::calc_angle_error(float pitch, float yaw, bool direction_reversed) |
|
|
|
|
{ |
|
|
|
|
// Pitch angle error in centidegrees
|
|
|
|
|
// Positive error means the target is above current pitch
|
|
|
|
|
// Negative error means the target is below current pitch
|
|
|
|
|
const AP_AHRS &ahrs = AP::ahrs(); |
|
|
|
|
float ahrs_pitch = ahrs.pitch_sensor; |
|
|
|
|
int32_t ef_pitch_angle_error = pitch - ahrs_pitch; |
|
|
|
|
|
|
|
|
@ -53,25 +58,29 @@ void Tracker::calc_angle_error(float pitch, float yaw, bool direction_reversed)
@@ -53,25 +58,29 @@ void Tracker::calc_angle_error(float pitch, float yaw, bool direction_reversed)
|
|
|
|
|
float bf_pitch_err; |
|
|
|
|
float bf_yaw_err; |
|
|
|
|
convert_ef_to_bf(ef_pitch_angle_error, ef_yaw_angle_error, bf_pitch_err, bf_yaw_err); |
|
|
|
|
struct Tracker::NavStatus &nav_status = tracker.nav_status; |
|
|
|
|
nav_status.angle_error_pitch = bf_pitch_err; |
|
|
|
|
nav_status.angle_error_yaw = bf_yaw_err; |
|
|
|
|
|
|
|
|
|
// set actual and desired for logging, note we are using angles not rates
|
|
|
|
|
Parameters &g = tracker.g; |
|
|
|
|
g.pidPitch2Srv.set_target_rate(pitch * 0.01); |
|
|
|
|
g.pidPitch2Srv.set_actual_rate(ahrs_pitch * 0.01); |
|
|
|
|
g.pidYaw2Srv.set_target_rate(yaw * 0.01); |
|
|
|
|
g.pidYaw2Srv.set_actual_rate(ahrs_yaw_cd * 0.01); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
void Tracker::convert_ef_to_bf(float pitch, float yaw, float& bf_pitch, float& bf_yaw) |
|
|
|
|
void Mode::convert_ef_to_bf(float pitch, float yaw, float& bf_pitch, float& bf_yaw) |
|
|
|
|
{ |
|
|
|
|
// earth frame to body frame pitch and yaw conversion
|
|
|
|
|
const AP_AHRS &ahrs = AP::ahrs(); |
|
|
|
|
bf_pitch = ahrs.cos_roll() * pitch + ahrs.sin_roll() * ahrs.cos_pitch() * yaw; |
|
|
|
|
bf_yaw = -ahrs.sin_roll() * pitch + ahrs.cos_pitch() * ahrs.cos_roll() * yaw; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
bool Tracker::convert_bf_to_ef(float pitch, float yaw, float& ef_pitch, float& ef_yaw) |
|
|
|
|
bool Mode::convert_bf_to_ef(float pitch, float yaw, float& ef_pitch, float& ef_yaw) |
|
|
|
|
{ |
|
|
|
|
const AP_AHRS &ahrs = AP::ahrs(); |
|
|
|
|
// avoid divide by zero
|
|
|
|
|
if (is_zero(ahrs.cos_pitch())) { |
|
|
|
|
return false; |
|
|
|
@ -83,13 +92,14 @@ bool Tracker::convert_bf_to_ef(float pitch, float yaw, float& ef_pitch, float& e
@@ -83,13 +92,14 @@ bool Tracker::convert_bf_to_ef(float pitch, float yaw, float& ef_pitch, float& e
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// return value is true if taking the long road to the target, false if normal, shortest direction should be used
|
|
|
|
|
bool Tracker::get_ef_yaw_direction() |
|
|
|
|
bool Mode::get_ef_yaw_direction() |
|
|
|
|
{ |
|
|
|
|
// calculating distances from current pitch/yaw to lower and upper limits in centi-degrees
|
|
|
|
|
float yaw_angle_limit_lower = (-g.yaw_range * 100.0f / 2.0f) - yaw_servo_out_filt.get(); |
|
|
|
|
float yaw_angle_limit_upper = (g.yaw_range * 100.0f / 2.0f) - yaw_servo_out_filt.get(); |
|
|
|
|
float pitch_angle_limit_lower = (g.pitch_min * 100.0f) - pitch_servo_out_filt.get(); |
|
|
|
|
float pitch_angle_limit_upper = (g.pitch_max * 100.0f) - pitch_servo_out_filt.get(); |
|
|
|
|
Parameters &g = tracker.g; |
|
|
|
|
float yaw_angle_limit_lower = (-g.yaw_range * 100.0f / 2.0f) - tracker.yaw_servo_out_filt.get(); |
|
|
|
|
float yaw_angle_limit_upper = (g.yaw_range * 100.0f / 2.0f) - tracker.yaw_servo_out_filt.get(); |
|
|
|
|
float pitch_angle_limit_lower = (g.pitch_min * 100.0f) - tracker.pitch_servo_out_filt.get(); |
|
|
|
|
float pitch_angle_limit_upper = (g.pitch_max * 100.0f) - tracker.pitch_servo_out_filt.get(); |
|
|
|
|
|
|
|
|
|
// distances to earthframe angle limits in centi-degrees
|
|
|
|
|
float ef_yaw_limit_lower = yaw_angle_limit_lower; |
|
|
|
@ -99,7 +109,9 @@ bool Tracker::get_ef_yaw_direction()
@@ -99,7 +109,9 @@ bool Tracker::get_ef_yaw_direction()
|
|
|
|
|
convert_bf_to_ef(pitch_angle_limit_lower, yaw_angle_limit_lower, ef_pitch_limit_lower, ef_yaw_limit_lower); |
|
|
|
|
convert_bf_to_ef(pitch_angle_limit_upper, yaw_angle_limit_upper, ef_pitch_limit_upper, ef_yaw_limit_upper); |
|
|
|
|
|
|
|
|
|
const AP_AHRS &ahrs = AP::ahrs(); |
|
|
|
|
float ef_yaw_current = wrap_180_cd(ahrs.yaw_sensor); |
|
|
|
|
struct Tracker::NavStatus &nav_status = tracker.nav_status; |
|
|
|
|
float ef_yaw_target = wrap_180_cd((nav_status.bearing+g.yaw_trim)*100); |
|
|
|
|
float ef_yaw_angle_error = wrap_180_cd(ef_yaw_target - ef_yaw_current); |
|
|
|
|
|
|
|
|
|