diff --git a/TEMA8/Mo.py b/TEMA8/Mo.py new file mode 100644 index 0000000..bea8fda --- /dev/null +++ b/TEMA8/Mo.py @@ -0,0 +1,16 @@ +def calculate_correlation(list1, list2): + n = min(len(list1), len(list2)) # Используем меньшую длину + sum_x = sum(list1[:n]) + sum_y = sum(list2[:n]) + sum_x_squared = sum(x**2 for x in list1[:n]) + sum_y_squared = sum(y**2 for y in list2[:n]) + sum_xy = sum(list1[i] * list2[i] for i in range(n)) + + numerator = n * sum_xy - sum_x * sum_y + denominator = math.sqrt((n * sum_x_squared - sum_x**2) * (n * sum_y_squared - sum_y**2)) + + if denominator == 0: + print("Предупреждение: Деление на ноль при вычислении корреляции.") + return None + + return numerator / denominator diff --git a/TEMA8/Module1.py b/TEMA8/Module1.py new file mode 100644 index 0000000..ea0a434 --- /dev/null +++ b/TEMA8/Module1.py @@ -0,0 +1,8 @@ +def read_number_list(filename): + number_list = [] + with open(filename, 'r') as file: + for line in file: + numbers = line.strip().split() + for num in numbers: + number_list.append(float(num)) + return number_list diff --git a/TEMA8/Module2.py b/TEMA8/Module2.py new file mode 100644 index 0000000..9deabd3 --- /dev/null +++ b/TEMA8/Module2.py @@ -0,0 +1,22 @@ +import math + +def calculate_correlation(list1, list2): + if not list1 or not list2: + print("Ошибка: Один или оба списка пусты.") + return None + + n = min(len(list1), len(list2)) # Используем меньшую длину + sum_x = sum(list1[:n]) + sum_y = sum(list2[:n]) + sum_x_squared = sum(x**2 for x in list1[:n]) + sum_y_squared = sum(y**2 for y in list2[:n]) + sum_xy = sum(list1[i] * list2[i] for i in range(n)) + + numerator = n * sum_xy - sum_x * sum_y + denominator = math.sqrt((n * sum_x_squared - sum_x**2) * (n * sum_y_squared - sum_y**2)) + + if denominator == 0: + print("Предупреждение: Деление на ноль при вычислении корреляции.") + return None + + return numerator / denominator diff --git a/TEMA8/Module3.py b/TEMA8/Module3.py new file mode 100644 index 0000000..81a719a --- /dev/null +++ b/TEMA8/Module3.py @@ -0,0 +1,14 @@ +import Module1 +import Module2 + +if __name__ == "__main__": + file1_name = input("Введите имя первого файла: ") + file2_name = input("Введите имя второго файла: ") + + list1 = Module1.read_number_list(file1_name) + list2 = Module1.read_number_list(file2_name) + + if list1 is not None and list2 is not None: + correlation = Module2.calculate_correlation(list1, list2) + if correlation is not None: + print(f"Коэффициент корреляции: {correlation:.3f}") diff --git a/TEMA8/task.md b/TEMA8/task.md new file mode 100644 index 0000000..aa28adb --- /dev/null +++ b/TEMA8/task.md @@ -0,0 +1,22 @@ +# Общее контрольное задание по теме 8 + +Добровольска Елизавета, А-02-23 + +## Задание + +Разработайте программу, состоящую из трех модулей: +- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу. +- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу. +- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки. +Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы. + +## Решение + +Были созданы три модуля, реализующие инструкции задания. Запущен модуль 3 на выполнение. + +```py +=============== RESTART: C:\Users\Лиза\OneDrive\Desktop\python-labs\TEMA8\Module3.py =============== +Введите имя первого файла: text1.txt +Введите имя второго файла: text2.txt +Коэффициент корреляции: 0.962 +``` \ No newline at end of file diff --git a/TEMA8/text1.txt b/TEMA8/text1.txt new file mode 100644 index 0000000..23415c5 --- /dev/null +++ b/TEMA8/text1.txt @@ -0,0 +1 @@ +1 2 3 4 7 \ No newline at end of file diff --git a/TEMA8/text2.txt b/TEMA8/text2.txt new file mode 100644 index 0000000..92e475a --- /dev/null +++ b/TEMA8/text2.txt @@ -0,0 +1 @@ +6 7 8 9 10 \ No newline at end of file