From d2320332dd2022c9f6dbed08e913e57520a51f7f Mon Sep 17 00:00:00 2001 From: YUKSELutku <149325205+YUKSELutku@users.noreply.github.com> Date: Tue, 23 Dec 2025 12:55:24 +0300 Subject: [PATCH] Add performance decorator for function metrics Implement a performance decorator to measure execution time and memory usage. --- Week04/decorators_utku_yuksel.py | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 Week04/decorators_utku_yuksel.py diff --git a/Week04/decorators_utku_yuksel.py b/Week04/decorators_utku_yuksel.py new file mode 100644 index 00000000..fcd6f9c4 --- /dev/null +++ b/Week04/decorators_utku_yuksel.py @@ -0,0 +1,25 @@ +def performance(func): + def wrapper(*args, **kwargs): + tm = __import__('tracemalloc') + t = __import__('time') + + tm.start() + start_time = t.perf_counter() + + result = func(*args, **kwargs) + + end_time = t.perf_counter() + current, peak = tm.get_traced_memory() + tm.stop() + + performance.counter += 1 + performance.total_time += (end_time - start_time) + performance.total_mem += peak + + return result + + return wrapper + +performance.counter = 0 +performance.total_time = 0 +performance.total_mem = 0