From d5a707cda09d6b858637023d117dcb3e178047c6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?RIDVAN=20=C5=9EEVK=C4=B0=20KARSLI?= <148614751+ridvanKarsli@users.noreply.github.com> Date: Tue, 3 Mar 2026 10:43:59 +0300 Subject: [PATCH 1/9] =?UTF-8?q?Add=20student=20information=20for=20R=C4=B1?= =?UTF-8?q?dvan=20=C5=9Eevki=20Karsl=C4=B1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- "Week01/info_ridvan_\305\237evki_karsli.py" | 2 ++ 1 file changed, 2 insertions(+) create mode 100644 "Week01/info_ridvan_\305\237evki_karsli.py" diff --git "a/Week01/info_ridvan_\305\237evki_karsli.py" "b/Week01/info_ridvan_\305\237evki_karsli.py" new file mode 100644 index 00000000..2657e323 --- /dev/null +++ "b/Week01/info_ridvan_\305\237evki_karsli.py" @@ -0,0 +1,2 @@ +student_id = "220315095" +full_name = "Rıdvan Şevki Karslı" From 1ccd2f4d91d73d457c75e27abc65d8465be18f2e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?RIDVAN=20=C5=9EEVK=C4=B0=20KARSLI?= <148614751+ridvanKarsli@users.noreply.github.com> Date: Wed, 1 Apr 2026 19:59:46 +0300 Subject: [PATCH 2/9] Add variables of different types in types_ridvan_sevki_karsli.py --- Week02/types_ridvan_sevki_karsli.py | 4 ++++ 1 file changed, 4 insertions(+) create mode 100644 Week02/types_ridvan_sevki_karsli.py diff --git a/Week02/types_ridvan_sevki_karsli.py b/Week02/types_ridvan_sevki_karsli.py new file mode 100644 index 00000000..c5c4c539 --- /dev/null +++ b/Week02/types_ridvan_sevki_karsli.py @@ -0,0 +1,4 @@ +my_int = 120 +my_float = 120.0 +my_bool = 36 == 36 +my_complex = 5j From f93b7d0715615a30b62fb47e87c8ed828247747c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?RIDVAN=20=C5=9EEVK=C4=B0=20KARSLI?= <148614751+ridvanKarsli@users.noreply.github.com> Date: Wed, 1 Apr 2026 20:04:24 +0300 Subject: [PATCH 3/9] Add function to calculate pyramid height from blocks --- Week03/pyramid_ridvan_sevki_karsli.py | 7 +++++++ 1 file changed, 7 insertions(+) create mode 100644 Week03/pyramid_ridvan_sevki_karsli.py diff --git a/Week03/pyramid_ridvan_sevki_karsli.py b/Week03/pyramid_ridvan_sevki_karsli.py new file mode 100644 index 00000000..69bae861 --- /dev/null +++ b/Week03/pyramid_ridvan_sevki_karsli.py @@ -0,0 +1,7 @@ +def calculate_pyramid_height(blocks): + total = 0 + for i in range(1, blocks + 1): + total += i + if total > blocks: + return i - 1 + return i From 0e564cb2681cbc21f93e8b8151e54c308750ed92 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?RIDVAN=20=C5=9EEVK=C4=B0=20KARSLI?= <148614751+ridvanKarsli@users.noreply.github.com> Date: Wed, 1 Apr 2026 20:08:05 +0300 Subject: [PATCH 4/9] Add PerformanceTracker decorator for function metrics Implement a PerformanceTracker decorator to measure function performance. --- Week04/decorators_ridvan_sevki_karsli.py | 26 ++++++++++++++++++++++++ 1 file changed, 26 insertions(+) create mode 100644 Week04/decorators_ridvan_sevki_karsli.py diff --git a/Week04/decorators_ridvan_sevki_karsli.py b/Week04/decorators_ridvan_sevki_karsli.py new file mode 100644 index 00000000..396ce23b --- /dev/null +++ b/Week04/decorators_ridvan_sevki_karsli.py @@ -0,0 +1,26 @@ +import tracemalloc +import time + + +class PerformanceTracker: + def __init__(self, func): + self.func = func + self.calls = 0 + self.total_time = 0 + self.total_memory = 0 + + def __call__(self, *args, **kwargs): + tracemalloc.start() + + start = time.time() + result = self.func(*args, **kwargs) + end = time.time() + + _, peak = tracemalloc.get_traced_memory() + tracemalloc.stop() + + self.calls += 1 + self.total_time += (end - start) + self.total_memory += peak + + return result From 78fc82201246e5f108f48f882c3d6c2028f77d8c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?RIDVAN=20=C5=9EEVK=C4=B0=20KARSLI?= <148614751+ridvanKarsli@users.noreply.github.com> Date: Wed, 1 Apr 2026 20:10:14 +0300 Subject: [PATCH 5/9] Add awaitme decorator for async function handling --- Week05/decorators_ridvan_sevki_karsli.py | 8 ++++++++ 1 file changed, 8 insertions(+) create mode 100644 Week05/decorators_ridvan_sevki_karsli.py diff --git a/Week05/decorators_ridvan_sevki_karsli.py b/Week05/decorators_ridvan_sevki_karsli.py new file mode 100644 index 00000000..111ad17f --- /dev/null +++ b/Week05/decorators_ridvan_sevki_karsli.py @@ -0,0 +1,8 @@ +import inspect + +def awaitme(func): + async def wrapper(*args, **kwargs): + if inspect.iscoroutinefunction(func): + return await func(*args, **kwargs) + return func(*args, **kwargs) + return wrapper From f962e3351879f8cae2c7c5f7fd67c0d9af4c8ebc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?RIDVAN=20=C5=9EEVK=C4=B0=20KARSLI?= <148614751+ridvanKarsli@users.noreply.github.com> Date: Tue, 7 Apr 2026 10:21:02 +0300 Subject: [PATCH 6/9] Add awaitme_ridvan_sevki_karsli.py file --- ...tors_ridvan_sevki_karsli.py => awaitme_ridvan_sevki_karsli.py} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename Week05/{decorators_ridvan_sevki_karsli.py => awaitme_ridvan_sevki_karsli.py} (100%) diff --git a/Week05/decorators_ridvan_sevki_karsli.py b/Week05/awaitme_ridvan_sevki_karsli.py similarity index 100% rename from Week05/decorators_ridvan_sevki_karsli.py rename to Week05/awaitme_ridvan_sevki_karsli.py From 2664f1701904347ec18d857ea75f9f9679f384bc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?RIDVAN=20=C5=9EEVK=C4=B0=20KARSLI?= <148614751+ridvanKarsli@users.noreply.github.com> Date: Tue, 7 Apr 2026 10:25:19 +0300 Subject: [PATCH 7/9] =?UTF-8?q?Create=20functions=5Fr=C4=B1dvan=5Fsevki=5F?= =?UTF-8?q?karsl=C4=B1.py?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...ions_r\304\261dvan_sevki_karsl\304\261.py" | 36 +++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 "Week05/functions_r\304\261dvan_sevki_karsl\304\261.py" diff --git "a/Week05/functions_r\304\261dvan_sevki_karsl\304\261.py" "b/Week05/functions_r\304\261dvan_sevki_karsl\304\261.py" new file mode 100644 index 00000000..63158c71 --- /dev/null +++ "b/Week05/functions_r\304\261dvan_sevki_karsl\304\261.py" @@ -0,0 +1,36 @@ +custom_power = lambda x=0, /, e=1: pow(x, e) + + +def custom_equation(x: int = 0, y: int = 0, /, a: int = 1, b: int = 1, *, c: int = 1) -> float: + """ + Computes a custom equation. + + :param x: First base (positional only) + :param y: Second base (positional only) + :param a: First exponent + :param b: Second exponent + :param c: Divisor (keyword only) + :return: The result of (x^a + y^b) / c + """ + + params = {'x': x, 'y': y, 'a': a, 'b': b, 'c': c} + + for param_name in params: + if type(params[param_name]) is not int: + raise TypeError(f"{param_name} must be an integer") + + if c == 0: + raise ZeroDivisionError("Division by zero is not allowed") + + result = (custom_power(x, a) + custom_power(y, b)) / c + + return float(result) + + +def fn_w_counter() -> (int, dict[str, int]): + if not hasattr(fn_w_counter, "count"): + setattr(fn_w_counter, "count", 0) + + setattr(fn_w_counter, "count", fn_w_counter.count + 1) + + return fn_w_counter.count, {fn_w_counter.__name__: fn_w_counter.count} From fd54848b9cce567db1306aa151ba61c205f20eab Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?RIDVAN=20=C5=9EEVK=C4=B0=20KARSLI?= <148614751+ridvanKarsli@users.noreply.github.com> Date: Tue, 7 Apr 2026 10:27:13 +0300 Subject: [PATCH 8/9] =?UTF-8?q?Delete=20Week05/functions=5Fr=C4=B1dvan=5Fs?= =?UTF-8?q?evki=5Fkarsl=C4=B1.py?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...ions_r\304\261dvan_sevki_karsl\304\261.py" | 36 ------------------- 1 file changed, 36 deletions(-) delete mode 100644 "Week05/functions_r\304\261dvan_sevki_karsl\304\261.py" diff --git "a/Week05/functions_r\304\261dvan_sevki_karsl\304\261.py" "b/Week05/functions_r\304\261dvan_sevki_karsl\304\261.py" deleted file mode 100644 index 63158c71..00000000 --- "a/Week05/functions_r\304\261dvan_sevki_karsl\304\261.py" +++ /dev/null @@ -1,36 +0,0 @@ -custom_power = lambda x=0, /, e=1: pow(x, e) - - -def custom_equation(x: int = 0, y: int = 0, /, a: int = 1, b: int = 1, *, c: int = 1) -> float: - """ - Computes a custom equation. - - :param x: First base (positional only) - :param y: Second base (positional only) - :param a: First exponent - :param b: Second exponent - :param c: Divisor (keyword only) - :return: The result of (x^a + y^b) / c - """ - - params = {'x': x, 'y': y, 'a': a, 'b': b, 'c': c} - - for param_name in params: - if type(params[param_name]) is not int: - raise TypeError(f"{param_name} must be an integer") - - if c == 0: - raise ZeroDivisionError("Division by zero is not allowed") - - result = (custom_power(x, a) + custom_power(y, b)) / c - - return float(result) - - -def fn_w_counter() -> (int, dict[str, int]): - if not hasattr(fn_w_counter, "count"): - setattr(fn_w_counter, "count", 0) - - setattr(fn_w_counter, "count", fn_w_counter.count + 1) - - return fn_w_counter.count, {fn_w_counter.__name__: fn_w_counter.count} From e1179b56073c86bea3c6e8228451ef353fffbbfd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?RIDVAN=20=C5=9EEVK=C4=B0=20KARSLI?= <148614751+ridvanKarsli@users.noreply.github.com> Date: Tue, 7 Apr 2026 10:28:09 +0300 Subject: [PATCH 9/9] Implement custom equation and function call counter Adds custom equation and counter functions with error handling. --- ...ions_r\304\261dvan_sevki_karsl\304\261.py" | 36 +++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 "Week04/functions_r\304\261dvan_sevki_karsl\304\261.py" diff --git "a/Week04/functions_r\304\261dvan_sevki_karsl\304\261.py" "b/Week04/functions_r\304\261dvan_sevki_karsl\304\261.py" new file mode 100644 index 00000000..63158c71 --- /dev/null +++ "b/Week04/functions_r\304\261dvan_sevki_karsl\304\261.py" @@ -0,0 +1,36 @@ +custom_power = lambda x=0, /, e=1: pow(x, e) + + +def custom_equation(x: int = 0, y: int = 0, /, a: int = 1, b: int = 1, *, c: int = 1) -> float: + """ + Computes a custom equation. + + :param x: First base (positional only) + :param y: Second base (positional only) + :param a: First exponent + :param b: Second exponent + :param c: Divisor (keyword only) + :return: The result of (x^a + y^b) / c + """ + + params = {'x': x, 'y': y, 'a': a, 'b': b, 'c': c} + + for param_name in params: + if type(params[param_name]) is not int: + raise TypeError(f"{param_name} must be an integer") + + if c == 0: + raise ZeroDivisionError("Division by zero is not allowed") + + result = (custom_power(x, a) + custom_power(y, b)) / c + + return float(result) + + +def fn_w_counter() -> (int, dict[str, int]): + if not hasattr(fn_w_counter, "count"): + setattr(fn_w_counter, "count", 0) + + setattr(fn_w_counter, "count", fn_w_counter.count + 1) + + return fn_w_counter.count, {fn_w_counter.__name__: fn_w_counter.count}