2021-08-03 04:47:46 -07:00
|
|
|
class FirstOrderFilter:
|
2021-09-01 15:00:52 -07:00
|
|
|
def __init__(self, x0, rc, dt, initialized=True):
|
2020-01-17 10:28:44 -08:00
|
|
|
self.x = x0
|
2025-09-30 16:34:45 -07:00
|
|
|
self.dt = dt
|
2021-08-03 04:47:46 -07:00
|
|
|
self.update_alpha(rc)
|
2021-09-01 15:00:52 -07:00
|
|
|
self.initialized = initialized
|
2021-08-03 04:47:46 -07:00
|
|
|
|
|
|
|
|
def update_alpha(self, rc):
|
2025-09-30 16:34:45 -07:00
|
|
|
self.alpha = self.dt / (rc + self.dt)
|
2020-01-17 10:28:44 -08:00
|
|
|
|
|
|
|
|
def update(self, x):
|
2021-09-01 15:00:52 -07:00
|
|
|
if self.initialized:
|
2025-09-30 16:34:45 -07:00
|
|
|
self.x = (1. - self.alpha) * self.x + self.alpha * x
|
2021-09-01 15:00:52 -07:00
|
|
|
else:
|
|
|
|
|
self.initialized = True
|
|
|
|
|
self.x = x
|
2020-04-01 15:58:40 -07:00
|
|
|
return self.x
|
2025-11-18 10:42:06 -08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class BounceFilter(FirstOrderFilter):
|
|
|
|
|
def __init__(self, x0, rc, dt, initialized=True, bounce=2):
|
|
|
|
|
self.velocity = FirstOrderFilter(0.0, 0.15, dt)
|
|
|
|
|
self.bounce = bounce
|
|
|
|
|
super().__init__(x0, rc, dt, initialized)
|
|
|
|
|
|
|
|
|
|
def update(self, x):
|
|
|
|
|
super().update(x)
|
|
|
|
|
scale = self.dt / (1.0 / 60.0) # tuned at 60 fps
|
|
|
|
|
self.velocity.x += (x - self.x) * self.bounce * scale * self.dt
|
|
|
|
|
self.velocity.update(0.0)
|
|
|
|
|
if abs(self.velocity.x) < 1e-5:
|
|
|
|
|
self.velocity.x = 0.0
|
|
|
|
|
self.x += self.velocity.x
|
|
|
|
|
return self.x
|