diff --git a/Week01/info_umut_sahin.py b/Week01/info_umut_sahin.py new file mode 100644 index 00000000..ea6274a0 --- /dev/null +++ b/Week01/info_umut_sahin.py @@ -0,0 +1,2 @@ +student_id = "220316051" +full_name = "Umut Şahin" diff --git a/Week02/types_umut_sahin.py b/Week02/types_umut_sahin.py new file mode 100644 index 00000000..cb513e5b --- /dev/null +++ b/Week02/types_umut_sahin.py @@ -0,0 +1,4 @@ +my_int = 47 +my_float = 2 / 1 +my_bool = True +my_complex = 3j diff --git a/Week03/pyramid_umut_sahin.py b/Week03/pyramid_umut_sahin.py new file mode 100644 index 00000000..832a02a8 --- /dev/null +++ b/Week03/pyramid_umut_sahin.py @@ -0,0 +1,10 @@ +def calculate_pyramid_height(number_of_blocks): + height = 0 + n = 0 + while True: + blocks_needed = (n * (n + 1)) // 2 + if blocks_needed > number_of_blocks: + break + height = n + n += 1 + return height diff --git a/Week04/decorators_umut_sahin.py b/Week04/decorators_umut_sahin.py new file mode 100644 index 00000000..f598313e --- /dev/null +++ b/Week04/decorators_umut_sahin.py @@ -0,0 +1,32 @@ +import tracemalloc, time + +def performance(func): + """ + Decorator to track function performance and record statistics. + + :param func: Function to decorate. + :type func: callable + :return: Wrapped function. + :rtype: callable + + :cvar counter: Number of calls. + :cvar total_time: Total execution time in seconds. + :cvar total_mem: Total peak memory in bytes. + """ + performance.counter = 0 + performance.total_time = 0.0 + performance.total_mem = 0.0 + + def wrapper(*args, **kwargs): + tracemalloc.start() + start_time = time.time() + result = func(*args, **kwargs) + end_time = time.time() + current, peak = tracemalloc.get_traced_memory() + tracemalloc.stop() + performance.counter += 1 + performance.total_time += (end_time - start_time) + performance.total_mem += peak + return result + + return wrapper diff --git a/Week04/functions_umut_sahin.py b/Week04/functions_umut_sahin.py new file mode 100644 index 00000000..37e9d111 --- /dev/null +++ b/Week04/functions_umut_sahin.py @@ -0,0 +1,29 @@ +custom_power = lambda x = 0, /, e = 1: x ** e + + +def custom_equation(x: int = 0, y: int = 0, /, a: int = 1, b: int = 1, *, c: int = 1) -> float: + """ + This function raises x to the power of a, y to the power of b, sums them, and then divides the result by c. + + :param x: The positional-only integer base parameter for the equation , default is 0 + :param y: The positional-only integer base parameter for the equation , default is 0 + :param a: The positional-or-keyword integer exponent parameter for the equation , default is 1 + :param b: The positional-or-keyword integer exponent parameter for the equation , default is 1 + :param c: The keyword-only integer divisor parameter for the equation , default is 1 + :return: The result of the calculation as a float and the equation is (x**a + y**b) / c + :rtype: float + """ + return (x**a + y**b) / c + + +def fn_w_counter() -> (int, dict[str, int]): + if not hasattr(fn_w_counter,'_call_counter'): + fn_w_counter._call_counter = 0 + fn_w_counter._caller_dict = {} + caller = __name__ + fn_w_counter._call_counter += 1 + if caller in fn_w_counter._caller_dict: + fn_w_counter._caller_dict[caller] += 1 + else: + fn_w_counter._caller_dict[caller] = 1 + return fn_w_counter._call_counter,fn_w_counter._caller_dict diff --git a/Week05/awaitme_umut_sahin.py b/Week05/awaitme_umut_sahin.py new file mode 100644 index 00000000..7f7f7c53 --- /dev/null +++ b/Week05/awaitme_umut_sahin.py @@ -0,0 +1,9 @@ +import asyncio + +def awaitme(function): + async def wrapper(*args, **kwargs): + result = function(*args, **kwargs) + if asyncio.iscoroutine(result): + return await result + return result + return wrapper