diff --git a/TEMA8/Modul1.py b/TEMA8/Modul1.py new file mode 100644 index 0000000..e86c5d1 --- /dev/null +++ b/TEMA8/Modul1.py @@ -0,0 +1,7 @@ +def read (file): + '''Чтение данных из файла''' + num = [] + with open(file,'r') as file: + for line in file: + num.extend(map(float,line.split())) + return num diff --git a/TEMA8/Modul2.py b/TEMA8/Modul2.py new file mode 100644 index 0000000..5eb86d2 --- /dev/null +++ b/TEMA8/Modul2.py @@ -0,0 +1,16 @@ +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 + diff --git a/TEMA8/Modul3.py b/TEMA8/Modul3.py new file mode 100644 index 0000000..7163131 --- /dev/null +++ b/TEMA8/Modul3.py @@ -0,0 +1,8 @@ +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}') diff --git a/TEMA8/data1.txt b/TEMA8/data1.txt new file mode 100644 index 0000000..f2194df --- /dev/null +++ b/TEMA8/data1.txt @@ -0,0 +1,4 @@ +1 2 3 +4 5 +6 7 8 +9 \ No newline at end of file diff --git a/TEMA8/data2.txt b/TEMA8/data2.txt new file mode 100644 index 0000000..1578931 --- /dev/null +++ b/TEMA8/data2.txt @@ -0,0 +1,3 @@ +2 4 6 +8 +10 11 \ No newline at end of file diff --git a/TEMA8/task.md b/TEMA8/task.md new file mode 100644 index 0000000..05ebd42 --- /dev/null +++ b/TEMA8/task.md @@ -0,0 +1,71 @@ +# Общее контрольное задание по теме 8 + +Лыкова Елизавета, А-01-23 + +# Задание: + +Разработайте программу, состоящую из трех модулей: + +- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу. + +- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу. + +- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки. + +Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы. + +# Решение + +## Модуль 1 + +```py +def read (file): + '''Чтение данных из файла''' + num = [] + with open(file,'r') as file: + for line in file: + num.extend(map(float,line.split())) + return num +``` + +## Модуль 2 + +```py +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 + +```py +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}') +``` + +## Выполнение + +```py +import Modul3 +Введите имя первого файла:data1.txt +Введите имя второго файла:data2.txt +Коэффициент корреляции: 0.847 +``` \ No newline at end of file