Improved profiler

This commit is contained in:
Mark Qvist 2025-01-12 17:51:02 +01:00
parent abc657806d
commit 53df2fa5e0
2 changed files with 32 additions and 15 deletions

View File

@ -172,8 +172,8 @@ class Reticulum:
RNS.Transport.exit_handler() RNS.Transport.exit_handler()
RNS.Identity.exit_handler() RNS.Identity.exit_handler()
# if RNS.Profiler.ran(): if RNS.Profiler.ran():
# RNS.Profiler.results() RNS.Profiler.results()
@staticmethod @staticmethod
def sigint_handler(signal, frame): def sigint_handler(signal, frame):

View File

@ -349,7 +349,7 @@ def exit():
sys.exit(0) sys.exit(0)
class Profiler: class Profiler:
ran = False _ran = False
profilers = {} profilers = {}
tags = {} tags = {}
@ -404,8 +404,8 @@ class Profiler:
begin = Profiler.tags[tag]["threads"][thread_ident]["current_start"] begin = Profiler.tags[tag]["threads"][thread_ident]["current_start"]
Profiler.tags[tag]["threads"][thread_ident]["current_start"] = None Profiler.tags[tag]["threads"][thread_ident]["current_start"] = None
Profiler.tags[tag]["threads"][thread_ident]["captures"].append(end-begin) Profiler.tags[tag]["threads"][thread_ident]["captures"].append(end-begin)
if not Profiler.ran: if not Profiler._ran:
Profiler.ran = True Profiler._ran = True
self.resume_super() self.resume_super()
def pause(self, pause_started=None): def pause(self, pause_started=None):
@ -422,7 +422,7 @@ class Profiler:
@staticmethod @staticmethod
def ran(): def ran():
return Profiler.ran return Profiler._ran
@staticmethod @staticmethod
def results(): def results():
@ -438,18 +438,25 @@ class Profiler:
thread_captures = thread_entry["captures"] thread_captures = thread_entry["captures"]
sample_count = len(thread_captures) sample_count = len(thread_captures)
if sample_count > 2: if sample_count > 1:
thread_results = { thread_results = {
"count": sample_count, "count": sample_count,
"mean": mean(thread_captures), "mean": mean(thread_captures),
"median": median(thread_captures), "median": median(thread_captures),
"stdev": stdev(thread_captures) "stdev": stdev(thread_captures)
} }
elif sample_count == 1:
thread_results = {
"count": sample_count,
"mean": mean(thread_captures),
"median": median(thread_captures),
"stdev": None
}
tag_captures.extend(thread_captures) tag_captures.extend(thread_captures)
sample_count = len(tag_captures) sample_count = len(tag_captures)
if sample_count > 2: if sample_count > 1:
tag_results = { tag_results = {
"name": tag, "name": tag,
"super": tag_entry["super"], "super": tag_entry["super"],
@ -458,6 +465,15 @@ class Profiler:
"median": median(tag_captures), "median": median(tag_captures),
"stdev": stdev(tag_captures) "stdev": stdev(tag_captures)
} }
elif sample_count == 1:
tag_results = {
"name": tag,
"super": tag_entry["super"],
"count": len(tag_captures),
"mean": mean(tag_captures),
"median": median(tag_captures),
"stdev": None
}
results[tag] = tag_results results[tag] = tag_results
@ -476,10 +492,11 @@ class Profiler:
mean = tag["mean"]; median = tag["median"]; stdev = tag["stdev"] mean = tag["mean"]; median = tag["median"]; stdev = tag["stdev"]
print( f"{ind}{name}") print( f"{ind}{name}")
print( f"{ind} Samples : {count}") print( f"{ind} Samples : {count}")
if stdev != None:
print(f"{ind} Mean : {prettyshorttime(mean)}") print(f"{ind} Mean : {prettyshorttime(mean)}")
print(f"{ind} Median : {prettyshorttime(median)}") print(f"{ind} Median : {prettyshorttime(median)}")
print(f"{ind} St.dev. : {prettyshorttime(stdev)}") print(f"{ind} St.dev. : {prettyshorttime(stdev)}")
print(f"{ind} Utilised : {prettyshorttime(mean*count)}") print( f"{ind} Total : {prettyshorttime(mean*count)}")
print("") print("")
print("\nProfiler results:\n") print("\nProfiler results:\n")