window_stat.py 827 B

12345678910111213141516171819202122232425262728
  1. import numpy as np
  2. class WindowStat:
  3. def __init__(self, name, n):
  4. self.name = name
  5. self.items = [None] * n
  6. self.idx = 0
  7. self.count = 0
  8. def push(self, obj):
  9. self.items[self.idx] = obj
  10. self.idx += 1
  11. self.count += 1
  12. self.idx %= len(self.items)
  13. def stats(self):
  14. if not self.count:
  15. _quantiles = []
  16. else:
  17. _quantiles = np.nanpercentile(self.items[:self.count],
  18. [0, 10, 50, 90, 100]).tolist()
  19. return {
  20. self.name + "_count": int(self.count),
  21. self.name + "_mean": float(np.nanmean(self.items[:self.count])),
  22. self.name + "_std": float(np.nanstd(self.items[:self.count])),
  23. self.name + "_quantiles": _quantiles,
  24. }