форкнуто от main/python-labs
main
Родитель
f64dc46950
Сommit
981c93000b
@ -0,0 +1,79 @@
|
|||||||
|
# Общее контрольное задание по теме 8
|
||||||
|
|
||||||
|
Зеленкина Ксения, А-02-23
|
||||||
|
|
||||||
|
## Задание
|
||||||
|
Разработайте программу, состоящую из трех модулей:
|
||||||
|
- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Получен-ный список должен возвращаться в вызывающую программу.
|
||||||
|
- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
|
||||||
|
- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. За-тем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
|
||||||
|
Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы
|
||||||
|
|
||||||
|
## Решение
|
||||||
|
__Модуль1__
|
||||||
|
_Код:_
|
||||||
|
```py
|
||||||
|
def mod1(filename):
|
||||||
|
numbers = []
|
||||||
|
|
||||||
|
with open(filename, 'r') as f:
|
||||||
|
for i in f:
|
||||||
|
stroka = i.strip().split()
|
||||||
|
for el in stroka:
|
||||||
|
number = float(el)
|
||||||
|
numbers.append(number)
|
||||||
|
return numbers
|
||||||
|
```
|
||||||
|
__Модуль2__
|
||||||
|
_Код:_
|
||||||
|
```py
|
||||||
|
def mod2(list1, list2):
|
||||||
|
n = min(len(list1), len(list2))
|
||||||
|
if n == 0:
|
||||||
|
return 0.0
|
||||||
|
|
||||||
|
avg1 = sum(list1[:n]) / n
|
||||||
|
avg2 = sum(list2[:n]) / n
|
||||||
|
|
||||||
|
numerator = 0
|
||||||
|
denom1 = 0
|
||||||
|
denom2 = 0
|
||||||
|
|
||||||
|
for i in range(n):
|
||||||
|
diff1 = list1[i] - avg1
|
||||||
|
diff2 = list2[i] - avg2
|
||||||
|
numerator += diff1 * diff2
|
||||||
|
denom1 += diff1 * diff1
|
||||||
|
denom2 += diff2 * diff2
|
||||||
|
|
||||||
|
if denom1 == 0 or denom2 == 0:
|
||||||
|
return 0.0
|
||||||
|
|
||||||
|
correlation = numerator / ((denom1 * denom2) ** 0.5)
|
||||||
|
|
||||||
|
return correlation
|
||||||
|
```
|
||||||
|
|
||||||
|
__Модуль3__
|
||||||
|
_Код:_
|
||||||
|
```py
|
||||||
|
import TaskMod1
|
||||||
|
import TaskMod2
|
||||||
|
|
||||||
|
file1 = input("Первый файл: ")
|
||||||
|
file2 = input("Второй файл: ")
|
||||||
|
|
||||||
|
list1 = TaskMod1.mod1(file1)
|
||||||
|
list2 = TaskMod1.mod1(file2)
|
||||||
|
|
||||||
|
result = TaskMod2.mod2(list1, list2)
|
||||||
|
|
||||||
|
print(f"Коэффициент корреляции: {result:.3f}")
|
||||||
|
```
|
||||||
|
|
||||||
|
_Вывод:_
|
||||||
|
```py
|
||||||
|
Первый файл: task1.txt
|
||||||
|
Второй файл: task2.txt
|
||||||
|
Результат: 0.842
|
||||||
|
```
|
||||||
@ -0,0 +1,10 @@
|
|||||||
|
def mod1(filename):
|
||||||
|
numbers = []
|
||||||
|
|
||||||
|
with open(filename, 'r') as f:
|
||||||
|
for i in f:
|
||||||
|
stroka = i.strip().split()
|
||||||
|
for el in stroka:
|
||||||
|
number = float(el)
|
||||||
|
numbers.append(number)
|
||||||
|
return numbers
|
||||||
@ -0,0 +1,25 @@
|
|||||||
|
def mod2(list1, list2):
|
||||||
|
n = min(len(list1), len(list2))
|
||||||
|
if n == 0:
|
||||||
|
return 0.0
|
||||||
|
|
||||||
|
avg1 = sum(list1[:n]) / n
|
||||||
|
avg2 = sum(list2[:n]) / n
|
||||||
|
|
||||||
|
numerator = 0
|
||||||
|
denom1 = 0
|
||||||
|
denom2 = 0
|
||||||
|
|
||||||
|
for i in range(n):
|
||||||
|
diff1 = list1[i] - avg1
|
||||||
|
diff2 = list2[i] - avg2
|
||||||
|
numerator += diff1 * diff2
|
||||||
|
denom1 += diff1 * diff1
|
||||||
|
denom2 += diff2 * diff2
|
||||||
|
|
||||||
|
if denom1 == 0 or denom2 == 0:
|
||||||
|
return 0.0
|
||||||
|
|
||||||
|
correlation = numerator / ((denom1 * denom2) ** 0.5)
|
||||||
|
|
||||||
|
return correlation
|
||||||
@ -0,0 +1,12 @@
|
|||||||
|
import TaskMod1
|
||||||
|
import TaskMod2
|
||||||
|
|
||||||
|
file1 = input("Первый файл: ")
|
||||||
|
file2 = input("Второй файл: ")
|
||||||
|
|
||||||
|
list1 = TaskMod1.mod1(file1)
|
||||||
|
list2 = TaskMod1.mod1(file2)
|
||||||
|
|
||||||
|
result = TaskMod2.mod2(list1, list2)
|
||||||
|
|
||||||
|
print(f"Коэффициент корреляции: {result:.3f}")
|
||||||
@ -0,0 +1 @@
|
|||||||
|
1 2 3 4 5 6 7 8 9 10
|
||||||
@ -0,0 +1 @@
|
|||||||
|
12 45 23 67 34 89 56 102 78 145
|
||||||
Загрузка…
Ссылка в новой задаче