From 0ea9882319b418830c4a4ff69a2356e0a877dc0d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C4=B0brahim=20As?= <148447898+zteplez@users.noreply.github.com> Date: Mon, 30 Mar 2026 21:59:08 +0300 Subject: [PATCH] Add performance decorator to measure execution time and memory --- Week04/decorators_ibrahim_as.py | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 Week04/decorators_ibrahim_as.py diff --git a/Week04/decorators_ibrahim_as.py b/Week04/decorators_ibrahim_as.py new file mode 100644 index 00000000..6f7e5431 --- /dev/null +++ b/Week04/decorators_ibrahim_as.py @@ -0,0 +1,28 @@ +import time +import tracemalloc +import functools +def performance(func): + @functools.wraps(func) + def wrapper(*args, **kwargs): + tracemalloc.start() + + start_time = time.perf_counter() + + result = func(*args, **kwargs) + + end_time = time.perf_counter() + + _, peak_mem = tracemalloc.get_traced_memory() + tracemalloc.stop() + + wrapper.counter += 1 + wrapper.total_time += (end_time - start_time) + wrapper.total_mem += peak_mem + + return result + + wrapper.counter = 0 + wrapper.total_time = 0.0 + wrapper.total_mem = 0 + + return wrapper