форкнуто от main/python-labs
Родитель
b19c2abc22
Сommit
53aede1542
@ -1,79 +1,79 @@
|
|||||||
# Общее контрольное задание по Теме 8
|
# Общее контрольное задание по Теме 8
|
||||||
Ходюк Максим Романович
|
Ходюк Максим Романович
|
||||||
## Задание
|
## Задание
|
||||||
Разработайте программу, состоящую из трех модулей:
|
Разработайте программу, состоящую из трех модулей:
|
||||||
|
|
||||||
- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу.
|
- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу.
|
||||||
|
|
||||||
- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
|
- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
|
||||||
|
|
||||||
- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
|
- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
|
||||||
|
|
||||||
Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы.
|
Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы.
|
||||||
|
|
||||||
### Выполнение
|
### Выполнение
|
||||||
Содержание файла [ModOKZ1.py](ModOKZ1.py):
|
Содержание файла [ModOKZ1.py](ModOKZ1.py):
|
||||||
```
|
```
|
||||||
def ReadFile(file):
|
def ReadFile(file):
|
||||||
Spis = []
|
Spis = []
|
||||||
with open(file) as fl:
|
with open(file) as fl:
|
||||||
for line in fl:
|
for line in fl:
|
||||||
Spis.extend(map(float,line.split()))
|
Spis.extend(map(float,line.split()))
|
||||||
return Spis
|
return Spis
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
Содержание файла [ModOKZ2.py](ModOKZ2.py):
|
Содержание файла [ModOKZ2.py](ModOKZ2.py):
|
||||||
```
|
```
|
||||||
import statistics as st
|
import statistics as st
|
||||||
def CalcCorr(s1,s2):
|
def CalcCorr(s1,s2):
|
||||||
n = min(len(s1),len(s2))
|
n = min(len(s1),len(s2))
|
||||||
mean1 = st.mean(s1)
|
mean1 = st.mean(s1)
|
||||||
mean2 = st.mean(s2)
|
mean2 = st.mean(s2)
|
||||||
cov = sum((s1i - mean1) * (s2i - mean2) for s1i, s2i in zip(s1, s2)) / n
|
cov = sum((s1i - mean1) * (s2i - mean2) for s1i, s2i in zip(s1, s2)) / n
|
||||||
stdS1 = st.stdev(s1)
|
stdS1 = st.stdev(s1)
|
||||||
stdS2 = st.stdev(s2)
|
stdS2 = st.stdev(s2)
|
||||||
if stdS1 == 0 or stdS2 == 0:
|
if stdS1 == 0 or stdS2 == 0:
|
||||||
return 0
|
return 0
|
||||||
return cov/(stdS1*stdS2)
|
return cov/(stdS1*stdS2)
|
||||||
```
|
```
|
||||||
|
|
||||||
Содержание файла [ModOKZ3.py](ModOKZ3.py):
|
Содержание файла [ModOKZ3.py](ModOKZ3.py):
|
||||||
```
|
```
|
||||||
from ModOKZ1 import ReadFile
|
from ModOKZ1 import ReadFile
|
||||||
from ModOKZ2 import CalcCorr
|
from ModOKZ2 import CalcCorr
|
||||||
|
|
||||||
file1 = input('Введите имя первого файла: ')
|
file1 = input('Введите имя первого файла: ')
|
||||||
file2 = input('Введите имя второго файла: ')
|
file2 = input('Введите имя второго файла: ')
|
||||||
|
|
||||||
spis1 = ReadFile(file1)
|
spis1 = ReadFile(file1)
|
||||||
spis2 = ReadFile(file2)
|
spis2 = ReadFile(file2)
|
||||||
|
|
||||||
if not(spis1 == None) and not(spis2 == None):
|
if not(spis1 == []) and not(spis2 == []):
|
||||||
print(f'Коэффициент корреляции: {CalcCorr(spis1,spis2)}')
|
print(f'Коэффициент корреляции: {CalcCorr(spis1,spis2)}')
|
||||||
```
|
```
|
||||||
|
|
||||||
Содержание текстовых файлов с данными:
|
Содержание текстовых файлов с данными:
|
||||||
[testdata1.txt](testdata1.txt)
|
[testdata1.txt](testdata1.txt)
|
||||||
```
|
```
|
||||||
10.0 9.5 9.0 8.5 8.0
|
10.0 9.5 9.0 8.5 8.0
|
||||||
7.5 3.2 6.5
|
7.5 3.2 6.5
|
||||||
```
|
```
|
||||||
|
|
||||||
[testdata2.txt](testdata2.txt)
|
[testdata2.txt](testdata2.txt)
|
||||||
```
|
```
|
||||||
10.0 9.5 9.0 8.5 8.0
|
10.0 9.5 9.0 8.5 8.0
|
||||||
7.5 3.2 6.5
|
7.5 3.2 6.5
|
||||||
```
|
```
|
||||||
|
|
||||||
Вызов программы:
|
Вызов программы:
|
||||||
```
|
```
|
||||||
import os
|
import os
|
||||||
os.chdir('D:\\POAS\\Hodyuk\\Tema8\\')
|
os.chdir('D:\\POAS\\Hodyuk\\Tema8\\')
|
||||||
import ModOKZ3
|
import ModOKZ3
|
||||||
Введите имя первого файла: testdata1.txt
|
Введите имя первого файла: testdata1.txt
|
||||||
Введите имя второго файла: testdata2.txt
|
Введите имя второго файла: testdata2.txt
|
||||||
Коэффициент корреляции: -0.4838833004874475
|
Коэффициент корреляции: -0.4838833004874475
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Загрузка…
Ссылка в новой задаче