форкнуто от main/python-labs
main
Родитель
fe05f31e0b
Сommit
9a0f5143bd
@ -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
|
||||
@ -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
|
||||
|
||||
@ -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}')
|
||||
@ -0,0 +1,4 @@
|
||||
1 2 3
|
||||
4 5
|
||||
6 7 8
|
||||
9
|
||||
@ -0,0 +1,3 @@
|
||||
2 4 6
|
||||
8
|
||||
10 11
|
||||
@ -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
|
||||
```
|
||||
Загрузка…
Ссылка в новой задаче