allow stopwatch to return averages
fix AOCDay._submit()
This commit is contained in:
parent
082c61beca
commit
6b5d3de95b
@ -46,7 +46,7 @@ class AOCDay:
|
|||||||
for _ in range(timeit_number):
|
for _ in range(timeit_number):
|
||||||
answer = self.part_func[part]()
|
answer = self.part_func[part]()
|
||||||
stopwatch.stop()
|
stopwatch.stop()
|
||||||
exec_time = str(stopwatch)
|
exec_time = stopwatch.avg_string(timeit_number)
|
||||||
|
|
||||||
if solution is None:
|
if solution is None:
|
||||||
printSolution(self.day, part + 1, answer, solution, case_count, exec_time)
|
printSolution(self.day, part + 1, answer, solution, case_count, exec_time)
|
||||||
@ -92,7 +92,6 @@ class AOCDay:
|
|||||||
f.write(response.content)
|
f.write(response.content)
|
||||||
f.flush()
|
f.flush()
|
||||||
|
|
||||||
|
|
||||||
def _submit(self, part: int, answer: Any):
|
def _submit(self, part: int, answer: Any):
|
||||||
answer_cache = JSONFile("answer_cache.json", create=True)
|
answer_cache = JSONFile("answer_cache.json", create=True)
|
||||||
print(answer_cache)
|
print(answer_cache)
|
||||||
@ -121,7 +120,6 @@ class AOCDay:
|
|||||||
print("Your answer: %s" % answer)
|
print("Your answer: %s" % answer)
|
||||||
return
|
return
|
||||||
|
|
||||||
return
|
|
||||||
print("Submitting %s as answer for %d part %d" % (answer, self.day, part))
|
print("Submitting %s as answer for %d part %d" % (answer, self.day, part))
|
||||||
session_id = open(".session", "r").readlines()[0].strip()
|
session_id = open(".session", "r").readlines()[0].strip()
|
||||||
response = requests.post(
|
response = requests.post(
|
||||||
|
|||||||
@ -24,12 +24,18 @@ class StopWatch:
|
|||||||
else:
|
else:
|
||||||
return self.stopped - self.started
|
return self.stopped - self.started
|
||||||
|
|
||||||
def __str__(self):
|
def avg_elapsed(self, divider: int) -> float:
|
||||||
|
return self.elapsed() / divider
|
||||||
|
|
||||||
|
def avg_string(self, divider: int) -> str:
|
||||||
units = ['s', 'ms', 'µs', 'ns']
|
units = ['s', 'ms', 'µs', 'ns']
|
||||||
unit = 0
|
unit = 0
|
||||||
elapsed = self.elapsed()
|
elapsed = self.avg_elapsed(divider)
|
||||||
while elapsed < 1:
|
while elapsed < 1:
|
||||||
elapsed *= 1000
|
elapsed *= 1000
|
||||||
unit += 1
|
unit += 1
|
||||||
|
|
||||||
return "%1.2f%s" % (elapsed, units[unit])
|
return "%1.2f%s" % (elapsed, units[unit])
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return self.avg_string(1)
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user