From 2d9f1a0b9b552394c27f9f9cb9d091a22582c382 Mon Sep 17 00:00:00 2001 From: KHalid102205 Date: Mon, 30 Mar 2026 21:47:07 +0300 Subject: [PATCH] Add performance decorator for function metrics Implement a performance decorator to measure execution time and memory usage. --- Week04/decorators_khaled_alismail.py | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 Week04/decorators_khaled_alismail.py diff --git a/Week04/decorators_khaled_alismail.py b/Week04/decorators_khaled_alismail.py new file mode 100644 index 00000000..a2c0c91e --- /dev/null +++ b/Week04/decorators_khaled_alismail.py @@ -0,0 +1,26 @@ +import time +import tracemalloc +from functools import update_wrapper + + +class performance: + def __init__(self, func): + self.func = func + self.counter = 0 + self.total_time = 0.0 + self.total_mem = 0 + update_wrapper(self, func) + + def __call__(self, *args, **kwargs): + tracemalloc.start() + start_time = time.perf_counter() + + try: + return self.func(*args, **kwargs) + finally: + _, peak_memory = tracemalloc.get_traced_memory() + tracemalloc.stop() + + self.counter += 1 + self.total_time += time.perf_counter() - start_time + self.total_mem += peak_memory