mirror of https://github.com/commaai/openpilot.git
longcontrol: prevent integral windup when feedforward rises gradually (#33970)
* try
* messy
* simplify that
* clip instead
* clean up
* clean up
* update refs
* this is better for latcontrol
* Revert "update refs"
This reverts commit 1d2508237f
.
* ref commit
This commit is contained in:
parent
13d4b5f8bb
commit
44c889fa41
|
@ -59,15 +59,13 @@ class PIDController:
|
|||
if override:
|
||||
self.i -= self.i_unwind_rate * float(np.sign(self.i))
|
||||
else:
|
||||
i = self.i + error * self.k_i * self.i_rate
|
||||
control = self.p + i + self.d + self.f
|
||||
if not freeze_integrator:
|
||||
self.i = self.i + error * self.k_i * self.i_rate
|
||||
|
||||
# Update when changing i will move the control away from the limits
|
||||
# or when i will move towards the sign of the error
|
||||
if ((error >= 0 and (control <= self.pos_limit or i < 0.0)) or
|
||||
(error <= 0 and (control >= self.neg_limit or i > 0.0))) and \
|
||||
not freeze_integrator:
|
||||
self.i = i
|
||||
# Clip i to prevent exceeding control limits
|
||||
control_no_i = self.p + self.d + self.f
|
||||
control_no_i = clip(control_no_i, self.neg_limit, self.pos_limit)
|
||||
self.i = clip(self.i, self.neg_limit - control_no_i, self.pos_limit - control_no_i)
|
||||
|
||||
control = self.p + self.i + self.d + self.f
|
||||
|
||||
|
|
|
@ -1 +1 @@
|
|||
bde3a4e45bcb4c1c1952421a669b9dc3a705e31a
|
||||
48ac1ed94c5f1aa3bd21ac609fed8ce3eb0bab8f
|
Loading…
Reference in New Issue