форкнуто от main/python-labs
Вы не можете выбрать более 25 тем
Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.
70 строки
3.4 KiB
Markdown
70 строки
3.4 KiB
Markdown
# Общее контрольное задание по теме 8
|
|
Бережков Дмитрий А-01-23
|
|
|
|
## Задание:
|
|
Разработайте программу, состоящую из трех модулей:
|
|
- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу.
|
|
- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
|
|
- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. За-тем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
|
|
Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы.
|
|
|
|
## Решение:
|
|
Модуль 1
|
|
```py
|
|
def read(file):
|
|
"""Чтение данных из файла"""
|
|
numbers=[]
|
|
with open(file,'r') as file:
|
|
for line in file:
|
|
numbers.extend(map(float,line.split()))
|
|
return numbers
|
|
```
|
|
Модуль 2
|
|
```py
|
|
def correlations(list1,list2):
|
|
""" Расчет коэффициента корреляции"""
|
|
n= min(len(list1), len(list2))
|
|
list1 = list1[:n]
|
|
list2 = list2[:n]
|
|
mean1 = sum(list1)/n
|
|
mean2 = sum(list2)/n
|
|
chisl = 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 list2)
|
|
if znam1 == 0 or zname2 == 0:
|
|
return 0
|
|
return chisl/(znam1 * znam2) ** 0.5
|
|
|
|
```
|
|
Модуль 3
|
|
```py
|
|
import modul1
|
|
import modul2
|
|
file1 = input("Введите имя первого файла: ")
|
|
file2 = input("Введите имя второго файла: ")
|
|
list1 = modul1.read(file1)
|
|
list2 = modul1.read(file2)
|
|
corr = modul2.correlations(list1, list2)
|
|
print(f"Коэффициент корреляции: {corr:.3f}")
|
|
```
|
|
Тест:
|
|
```py
|
|
>>> import modul3
|
|
Введите имя первого файла: data1.txt
|
|
Введите имя второго файла: data2.txt
|
|
Коэффициент корреляции: -0.166
|
|
```
|
|
Данные файла data1.txt
|
|
```py
|
|
10 25 5.5
|
|
-3
|
|
100 0.1 999
|
|
42
|
|
```
|
|
Данные файла data2.txt
|
|
```py
|
|
2.718 3.14159
|
|
5000
|
|
-1.0 -2.0 -3.0 -4.0 -5.0
|
|
77
|
|
``` |