Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

3.3 KiB

Общее контрольное задание по теме 8

Зеленкина Ксения, А-02-23

Задание

Разработайте программу, состоящую из трех модулей:

  • Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Получен-ный список должен возвращаться в вызывающую программу.
  • Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
  • Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. За-тем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки. Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы

Решение

Модуль1 Код:

def mod1(filename):
    numbers = []
    
    with open(filename, 'r') as f:
        for i in f:
            stroka = i.strip().split()
            for el in stroka:
                number = float(el)
                numbers.append(number)
    return numbers

Модуль2 Код:

def mod2(list1, list2):
    n = min(len(list1), len(list2))
    if n == 0:
        return 0.0
    
    avg1 = sum(list1[:n]) / n
    avg2 = sum(list2[:n]) / n
    
    numerator = 0
    denom1 = 0
    denom2 = 0
    
    for i in range(n):
        diff1 = list1[i] - avg1
        diff2 = list2[i] - avg2
        numerator += diff1 * diff2
        denom1 += diff1 * diff1
        denom2 += diff2 * diff2

    if denom1 == 0 or denom2 == 0:
        return 0.0

    correlation = numerator / ((denom1 * denom2) ** 0.5)

    return correlation

Модуль3 Код:

import TaskMod1
import TaskMod2

file1 = input("Первый файл: ")
file2 = input("Второй файл: ")

list1 = TaskMod1.mod1(file1)
list2 = TaskMod1.mod1(file2)

result = TaskMod2.mod2(list1, list2)

print(f"Коэффициент корреляции: {result:.3f}")

Вывод:

Первый файл: task1.txt
Второй файл: task2.txt
Результат: 0.842