more precise stopwatch
This commit is contained in:
parent
8e0b28159f
commit
199d6c1908
@ -1,43 +1,51 @@
|
|||||||
from time import time
|
from time import perf_counter_ns
|
||||||
from .types import FloatOrNone
|
from .types import IntOrNone
|
||||||
|
|
||||||
|
|
||||||
|
def ns_to_string(ns: int) -> str:
|
||||||
|
units = ['ns', 'µs', 'ms', 's']
|
||||||
|
unit = 0
|
||||||
|
while ns > 1_000:
|
||||||
|
ns /= 1_000
|
||||||
|
unit += 1
|
||||||
|
if unit == len(units) - 1:
|
||||||
|
break
|
||||||
|
|
||||||
|
return f"{ns:1.2f}{units[unit]}"
|
||||||
|
|
||||||
|
|
||||||
class StopWatch:
|
class StopWatch:
|
||||||
started: FloatOrNone = None
|
started: IntOrNone = None
|
||||||
stopped: FloatOrNone = None
|
stopped: IntOrNone = None
|
||||||
|
|
||||||
def __init__(self, auto_start=True):
|
def __init__(self, auto_start=True):
|
||||||
if auto_start:
|
if auto_start:
|
||||||
self.start()
|
self.start()
|
||||||
|
|
||||||
def start(self):
|
def start(self):
|
||||||
self.started = time()
|
self.started = perf_counter_ns()
|
||||||
self.stopped = None
|
self.stopped = None
|
||||||
|
|
||||||
def stop(self) -> float:
|
def stop(self) -> int:
|
||||||
self.stopped = time()
|
self.stopped = perf_counter_ns()
|
||||||
return self.elapsed()
|
return self.elapsed()
|
||||||
|
|
||||||
reset = start
|
reset = start
|
||||||
|
|
||||||
def elapsed(self) -> float:
|
def elapsed(self) -> int:
|
||||||
if self.stopped is None:
|
if self.stopped is None:
|
||||||
return time() - self.started
|
return perf_counter_ns() - self.started
|
||||||
else:
|
else:
|
||||||
return self.stopped - self.started
|
return self.stopped - self.started
|
||||||
|
|
||||||
def avg_elapsed(self, divider: int) -> float:
|
def avg_elapsed(self, divider: int) -> int:
|
||||||
return self.elapsed() / divider
|
return self.elapsed() // divider # in ns precision loosing some rounding error probably will not hurt
|
||||||
|
|
||||||
|
def elapsed_string(self):
|
||||||
|
return ns_to_string(self.elapsed())
|
||||||
|
|
||||||
def avg_string(self, divider: int) -> str:
|
def avg_string(self, divider: int) -> str:
|
||||||
units = ['s', 'ms', 'µs', 'ns']
|
return ns_to_string(self.avg_elapsed(divider))
|
||||||
unit = 0
|
|
||||||
elapsed = self.avg_elapsed(divider)
|
|
||||||
while 0 < elapsed < 1:
|
|
||||||
elapsed *= 1000
|
|
||||||
unit += 1
|
|
||||||
|
|
||||||
return "%1.2f%s" % (elapsed, units[unit])
|
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.avg_string(1)
|
return self.avg_string(1)
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user