From ce1b07004bbbf8fefa409a2d1c994e6e65eb9393 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Turhan=20G=C3=BCnd=C3=BCzo=C4=9Flu?= <220315031@ogr.cbu.edu.tr> Date: Tue, 7 Apr 2026 18:31:02 +0300 Subject: [PATCH] Implement performance decorator for function metrics --- Week04/decorators_turhan_gunduzoglu.py | 40 ++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 Week04/decorators_turhan_gunduzoglu.py diff --git a/Week04/decorators_turhan_gunduzoglu.py b/Week04/decorators_turhan_gunduzoglu.py new file mode 100644 index 00000000..425c5803 --- /dev/null +++ b/Week04/decorators_turhan_gunduzoglu.py @@ -0,0 +1,40 @@ +import time +import tracemalloc +from functools import wraps + +def performance(func): + counter = 0 + total_time = 0 + total_mem = 0 + + @wraps(func) + def wrapper(*args, **kwargs): + nonlocal counter, total_time, total_mem + + counter += 1 + + tracemalloc.start() + start_time = time.perf_counter() + + result = func(*args, **kwargs) + + end_time = time.perf_counter() + elapsed_time = end_time - start_time + + current, peak = tracemalloc.get_traced_memory() + tracemalloc.stop() + + total_time += elapsed_time + total_mem += peak + + wrapper.counter = counter + wrapper.total_time = total_time + wrapper.total_mem = total_mem + + return result + + wrapper.counter = 0 + wrapper.total_time = 0 + wrapper.total_mem = 0 + + return wrapper