форкнуто от 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
|
||||||
|
```
|
||||||
Загрузка…
Ссылка в новой задаче