3.3 KiB
Общее контрольное задание по теме 8
Лыкова Елизавета, А-01-23
Задание:
Разработайте программу, состоящую из трех модулей:
-
Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу.
-
Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
-
Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы.
Решение
Модуль 1
def read (file):
'''Чтение данных из файла'''
num = []
with open(file,'r') as file:
for line in file:
num.extend(map(float,line.split()))
return num
Модуль 2
def correl (list1,list2):
'''Расчет коэффициента корреляции'''
n = min(len(list1),len(list2))
list1 = list1[:n]
list2 = list2[:n]
mean1 = sum(list1)/n
mean2 = sum(list2)/n
chis = sum((list1[i]-mean1)*(list2[i]-mean2)for i in range(n))
znam1 = sum((x-mean1)**2 for x in list1)
znam2 = sum((y-mean2)**2 for y in list1)
if znam1 == 0 or znam2 == 0:
return 0
return chis/(znam1*znam2)**0.5
Модуль 3
import Modul1
import Modul2
file1 = input('Введите имя первого файла:')
file2 = input('Введите имя второго файла:')
list1 = Modul1.read(file1)
list2 = Modul1.read(file2)
corr = Modul2.correl(list1,list2)
print(f'Коэффициент корреляции: {corr:.3f}')
Выполнение
import Modul3
Введите имя первого файла:data1.txt
Введите имя второго файла:data2.txt
Коэффициент корреляции: 0.847