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 +``` + +