AC_PID: correct error caculation to use latest target

This commit is contained in:
Iampete1 2024-07-06 02:23:14 +01:00 committed by Andrew Tridgell
parent 0e45d89491
commit 04e69d738d

View File

@ -201,34 +201,48 @@ float AC_PID::update_all(float target, float measurement, float dt, bool limit,
_pid_info.reset = _flags._reset_filter; _pid_info.reset = _flags._reset_filter;
if (_flags._reset_filter) { if (_flags._reset_filter) {
_flags._reset_filter = false; _flags._reset_filter = false;
// Reset target filter
_target = target; _target = target;
_error = _target - measurement;
_derivative = 0.0f;
_target_derivative = 0.0f;
#if AP_FILTER_ENABLED #if AP_FILTER_ENABLED
if (_target_notch != nullptr) { if (_target_notch != nullptr) {
_target_notch->reset(); _target_notch->reset();
_target = _target_notch->apply(_target); _target = _target_notch->apply(_target);
} }
#endif
// Calculate error and reset error filter
_error = _target - measurement;
#if AP_FILTER_ENABLED
if (_error_notch != nullptr) { if (_error_notch != nullptr) {
_error_notch->reset(); _error_notch->reset();
_error = _error_notch->apply(_error); _error = _error_notch->apply(_error);
} }
#endif #endif
// Zero derivatives
_derivative = 0.0f;
_target_derivative = 0.0f;
} else { } else {
float error_last = _error;
float target_last = _target; // Apply target filters
float error = _target - measurement; const float target_last = _target;
#if AP_FILTER_ENABLED #if AP_FILTER_ENABLED
// apply notch filters before FTLD/FLTE to avoid shot noise // apply notch filters before FTLD/FLTE to avoid shot noise
if (_target_notch != nullptr) { if (_target_notch != nullptr) {
target = _target_notch->apply(target); 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) { if (_error_notch != nullptr) {
error = _error_notch->apply(error); error = _error_notch->apply(error);
} }
#endif #endif
_target += get_filt_T_alpha(dt) * (target - _target);
_error += get_filt_E_alpha(dt) * (error - _error); _error += get_filt_E_alpha(dt) * (error - _error);
// calculate and filter derivative // calculate and filter derivative