Skip to content

Commit

Permalink
AC_PID: correct error caculation to use latest target
Browse files Browse the repository at this point in the history
  • Loading branch information
IamPete1 authored and tridge committed Jul 9, 2024
1 parent b191869 commit f3743b8
Showing 1 changed file with 21 additions and 7 deletions.
28 changes: 21 additions & 7 deletions libraries/AC_PID/AC_PID.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -201,34 +201,48 @@ float AC_PID::update_all(float target, float measurement, float dt, bool limit,
_pid_info.reset = _flags._reset_filter;
if (_flags._reset_filter) {
_flags._reset_filter = false;

// Reset target filter
_target = target;
_error = _target - measurement;
_derivative = 0.0f;
_target_derivative = 0.0f;
#if AP_FILTER_ENABLED
if (_target_notch != nullptr) {
_target_notch->reset();
_target = _target_notch->apply(_target);
}
#endif

// Calculate error and reset error filter
_error = _target - measurement;
#if AP_FILTER_ENABLED
if (_error_notch != nullptr) {
_error_notch->reset();
_error = _error_notch->apply(_error);
}
#endif
// Zero derivatives
_derivative = 0.0f;
_target_derivative = 0.0f;

} else {
float error_last = _error;
float target_last = _target;
float error = _target - measurement;

// Apply target filters
const float target_last = _target;
#if AP_FILTER_ENABLED
// apply notch filters before FTLD/FLTE to avoid shot noise
if (_target_notch != nullptr) {
target = _target_notch->apply(target);
}
#endif
_target += get_filt_T_alpha(dt) * (target - _target);

// Calculate error and apply error filter
const float error_last = _error;
float error = _target - measurement;
#if AP_FILTER_ENABLED
if (_error_notch != nullptr) {
error = _error_notch->apply(error);
}
#endif
_target += get_filt_T_alpha(dt) * (target - _target);
_error += get_filt_E_alpha(dt) * (error - _error);

// calculate and filter derivative
Expand Down

0 comments on commit f3743b8

Please sign in to comment.