Mercurial > code > home > repos > light9
view light8/updatefreq.py @ 59:001646cd5349
all mousewheel events everywhere will now pass up the tree to be caught by
all mousewheel events everywhere will now pass up the tree to be caught by
higher widgets. if things get slow, this might be the problem
author | drewp |
---|---|
date | Tue, 09 Jul 2002 07:36:29 +0000 |
parents | 45b12307c695 |
children | b75bfbcf5979 |
line wrap: on
line source
"""calculates your updates-per-second""" import time class Updatefreq: """make one of these, call update() on it as much as you want, and then float() or str() the object to learn the updates per second. the samples param to __init__ specifies how many past updates will be stored. """ def __init__(self,samples=20): self.times=[0] self.samples=samples def update(self): """call this every time you do an update""" self.times=self.times[-self.samples:] self.times.append(time.time()) def __float__(self): """a cheap algorithm, for now, which looks at the first and last times only""" try: hz=len(self.times)/(self.times[-1]-self.times[0]) except ZeroDivisionError: return 0 return hz def __str__(self): return "%.2fHz"%float(self)