From 41f1983906a8f5bd74b9713bca7e930c6799118e Mon Sep 17 00:00:00 2001 From: KhodiukMR Date: Sun, 23 Nov 2025 19:59:38 +0000 Subject: [PATCH] =?UTF-8?q?=D0=97=D0=B0=D0=B3=D1=80=D1=83=D0=B7=D0=B8?= =?UTF-8?q?=D0=BB=20=D0=9E=D0=9A=D0=97=20=D0=BA=20=D0=A2=D0=B5=D0=BC=D0=B5?= =?UTF-8?q?=208=20=D0=B8=20=D1=84=D0=B0=D0=B9=D0=BB=D1=8B=20=D0=BA=20?= =?UTF-8?q?=D0=BD=D0=B5=D0=BC=D1=83?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- TEMA8/ModOKZ1.py | 7 +++++ TEMA8/ModOKZ2.py | 14 +++++++++ TEMA8/ModOKZ3.py | 12 ++++++++ TEMA8/task.md | 79 ++++++++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 112 insertions(+) create mode 100644 TEMA8/ModOKZ1.py create mode 100644 TEMA8/ModOKZ2.py create mode 100644 TEMA8/ModOKZ3.py create mode 100644 TEMA8/task.md diff --git a/TEMA8/ModOKZ1.py b/TEMA8/ModOKZ1.py new file mode 100644 index 0000000..915fd79 --- /dev/null +++ b/TEMA8/ModOKZ1.py @@ -0,0 +1,7 @@ +def ReadFile(file): + Spis = [] + with open(file) as fl: + for line in fl: + Spis.extend(map(float,line.split())) + return Spis + diff --git a/TEMA8/ModOKZ2.py b/TEMA8/ModOKZ2.py new file mode 100644 index 0000000..297471d --- /dev/null +++ b/TEMA8/ModOKZ2.py @@ -0,0 +1,14 @@ +import statistics as st +def CalcCorr(s1,s2): + n = min(len(s1),len(s2)) + mean1 = st.mean(s1) + mean2 = st.mean(s2) + cov = sum((s1i - mean1) * (s2i - mean2) for s1i, s2i in zip(s1, s2)) / n + stdS1 = st.stdev(s1) + stdS2 = st.stdev(s2) + if stdS1 == 0 or stdS2 == 0: + return 0 + return cov/(stdS1*stdS2) + + + diff --git a/TEMA8/ModOKZ3.py b/TEMA8/ModOKZ3.py new file mode 100644 index 0000000..5c62b9e --- /dev/null +++ b/TEMA8/ModOKZ3.py @@ -0,0 +1,12 @@ +from ModOKZ1 import ReadFile +from ModOKZ2 import CalcCorr + +file1 = input('Введите имя первого файла: ') +file2 = input('Введите имя второго файла: ') + +spis1 = ReadFile(file1) +spis2 = ReadFile(file2) + +if not(spis1 == None) and not(spis2 == None): + print(f'Коэффициент корреляции: {CalcCorr(spis1,spis2)}') + diff --git a/TEMA8/task.md b/TEMA8/task.md new file mode 100644 index 0000000..1a8eb18 --- /dev/null +++ b/TEMA8/task.md @@ -0,0 +1,79 @@ +# Общее контрольное задание по Теме 8 +Ходюк Максим Романович +## Задание +Разработайте программу, состоящую из трех модулей: + +- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу. + +- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу. + +- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки. + +Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы. + +### Выполнение +Содержание файла [ModOKZ1.py](ModOKZ1.py): +``` +def ReadFile(file): + Spis = [] + with open(file) as fl: + for line in fl: + Spis.extend(map(float,line.split())) + return Spis + +``` + +Содержание файла [ModOKZ2.py](ModOKZ2.py): +``` +import statistics as st +def CalcCorr(s1,s2): + n = min(len(s1),len(s2)) + mean1 = st.mean(s1) + mean2 = st.mean(s2) + cov = sum((s1i - mean1) * (s2i - mean2) for s1i, s2i in zip(s1, s2)) / n + stdS1 = st.stdev(s1) + stdS2 = st.stdev(s2) + if stdS1 == 0 or stdS2 == 0: + return 0 + return cov/(stdS1*stdS2) +``` + +Содержание файла [ModOKZ3.py](ModOKZ3.py): +``` +from ModOKZ1 import ReadFile +from ModOKZ2 import CalcCorr + +file1 = input('Введите имя первого файла: ') +file2 = input('Введите имя второго файла: ') + +spis1 = ReadFile(file1) +spis2 = ReadFile(file2) + +if not(spis1 == None) and not(spis2 == None): + print(f'Коэффициент корреляции: {CalcCorr(spis1,spis2)}') +``` + +Содержание текстовых файлов с данными: +[testdata1.txt](testdata1.txt) +``` +10.0 9.5 9.0 8.5 8.0 +7.5 3.2 6.5 +``` + +[testdata2.txt](testdata2.txt) +``` +10.0 9.5 9.0 8.5 8.0 +7.5 3.2 6.5 +``` + +Вызов программы: +``` +import os +os.chdir('D:\\POAS\\Hodyuk\\Tema8\\') +import ModOKZ3 +Введите имя первого файла: testdata1.txt +Введите имя второго файла: testdata2.txt +Коэффициент корреляции: -0.4838833004874475 +``` + +