diff --git a/TEMA8/task.md b/TEMA8/task.md new file mode 100644 index 0000000..30c9ff5 --- /dev/null +++ b/TEMA8/task.md @@ -0,0 +1,75 @@ +# ОБЩЕЕ КОНТРОЛЬНОЕ ЗАДАНИЕ по Теме 8 +Выполнил: Тимошенко А.А. Проверил: Козлюк Д.А. + +## Задание +Разработайте программу, состоящую из трех модулей: +- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколь-ко на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полу-ченный список должен возвращаться в вызывающую программу. +- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу. +- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. За-тем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки. +Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы. + +## Решение +okz1.py +``` +def reading (file): + nums = [] + with open(file, 'r') as file: + for line in file: + nums.extend(map(float, line.split())) + return nums +``` +okz2.py +``` +import math +def correlation(l1, l2): + n = min(len(l1), len(l2)) + sum1 = sum(l1) + sum2 = sum(l2) + sum1sq = sum(now ** 2 for now in l1) + sum2sq = sum(now ** 2 for now in l2) + sum12 = sum(x * y for x, y in zip(l1, l2)) + + part1 = n * sum12 - sum1 * sum2 + part2 = math.sqrt((n * sum1sq - sum1 ** 2) * (n * sum2sq - sum2 ** 2)) + + try: + corr = part1 / part2 + return corr + except ZeroDivisionError: + print("Ошибка деления на ноль!") + return +``` +okz3.py +``` +from okz1 import reading +from okz2 import correlation + +file1 = input("Введите имя первого файла: ") +file2 = input("Введите имя второго файла: ") + +arr1 = reading(file1) +arr2 = reading(file2) + +if arr1 is None or arr2 is None: + print("Не удалось считать данные из файлов.") +else: + corr = correlation(arr1, arr2) + if corr is not None: + print(f"Коэффициент корреляции: {corr:.2f}") +``` +Содержимое файлов: +``` +data1.txt +1.0 2.0 3.0 4.0 5.0 +6.0 7.0 8.0 9.0 10.0 + +data2.txt +10.0 9.5 9.0 8.5 8.0 +7.5 7.0 6.5 6.0 1.0 +``` +``` +================ RESTART: C:/Users/mapon/OneDrive/Рабочий стол/ПО АС/ТЕМА8/okz3.py ================ +Введите имя первого файла: data1.txt +Введите имя второго файла: data2.txt +Коэффициент корреляции: -0.88 +``` \ No newline at end of file