diff --git a/TEMA8/MM0.py b/TEMA8/MM0.py new file mode 100644 index 0000000..866432b --- /dev/null +++ b/TEMA8/MM0.py @@ -0,0 +1,2 @@ +import MM2 +print('y=',MM2.vyhod) diff --git a/TEMA8/MM1.py b/TEMA8/MM1.py new file mode 100644 index 0000000..1bb942a --- /dev/null +++ b/TEMA8/MM1.py @@ -0,0 +1,22 @@ +def realdvig(xtt,kk1,TT,yti1,ytin1): + #Модель реального двигателя + yp=kk1*xtt #усилитель + yti1=yp+yti1 #Интегратор + ytin1=(yti1+TT*ytin1)/(TT+1) + return [yti1,ytin1] + +def tahogen(xtt,kk2,yti2): + #Модель тахогенератора + yp=kk2*xtt #усилитель + yti2=yp+yti2 #интегратор + return yti2 + +def nechus(xtt,gran): + #зона нечувствит + if xtt(-gran): + ytt=0 + elif xtt>=gran: + ytt=xtt-gran + elif xtt<=(-gran): + ytt=xtt+gran + return ytt diff --git a/TEMA8/MM2.py b/TEMA8/MM2.py new file mode 100644 index 0000000..b88b110 --- /dev/null +++ b/TEMA8/MM2.py @@ -0,0 +1,23 @@ +znach=input('k1,T,k2,Xm,A,F,N=').split(',') +k1=float(znach[0]) +T=float(znach[1]) +k2=float(znach[2]) +Xm=float(znach[3]) +A=float(znach[4]) +F=float(znach[5]) +N=int(znach[6]) + +import math +vhod=[] +for i in range(N): + vhod.append(A*math.sin((2*i*math.pi)/F)) + +import MM1 as mod +yi1=0;yin1=0;yi2=0 +vyhod=[] +for xt in vhod: + xt1=xt-yi2 #отрицательная обратная связь + [yi1,yin1]=mod.realdvig(xt1,k1,T,yi1,yin1) + yi2=mod.tahogen(yin1,k2,yi2) + yt=mod.nechus(yin1,Xm) + vyhod.append(yt) diff --git a/TEMA8/Mod11.py b/TEMA8/Mod11.py new file mode 100644 index 0000000..cb98659 --- /dev/null +++ b/TEMA8/Mod11.py @@ -0,0 +1,8 @@ +def read_number_list(filename): + number_list = [] + with open(filename, 'r') as file: + for line in file: + numbers = line.strip().split() + for num in numbers: + number_list.append(float(num)) + return number_list diff --git a/TEMA8/Mod22.py b/TEMA8/Mod22.py new file mode 100644 index 0000000..9deabd3 --- /dev/null +++ b/TEMA8/Mod22.py @@ -0,0 +1,22 @@ +import math + +def calculate_correlation(list1, list2): + if not list1 or not list2: + print("Ошибка: Один или оба списка пусты.") + return None + + n = min(len(list1), len(list2)) # Используем меньшую длину + sum_x = sum(list1[:n]) + sum_y = sum(list2[:n]) + sum_x_squared = sum(x**2 for x in list1[:n]) + sum_y_squared = sum(y**2 for y in list2[:n]) + sum_xy = sum(list1[i] * list2[i] for i in range(n)) + + numerator = n * sum_xy - sum_x * sum_y + denominator = math.sqrt((n * sum_x_squared - sum_x**2) * (n * sum_y_squared - sum_y**2)) + + if denominator == 0: + print("Предупреждение: Деление на ноль при вычислении корреляции.") + return None + + return numerator / denominator diff --git a/TEMA8/Mod33.py b/TEMA8/Mod33.py new file mode 100644 index 0000000..2b40aad --- /dev/null +++ b/TEMA8/Mod33.py @@ -0,0 +1,14 @@ +import Mod11 +import Mod22 + +if __name__ == "__main__": + file1_name = input("Введите имя первого файла: ") + file2_name = input("Введите имя второго файла: ") + + list1 = Mod11.read_number_list(file1_name) + list2 = Mod11.read_number_list(file2_name) + + if list1 is not None and list2 is not None: + correlation = Mod22.calculate_correlation(list1, list2) + if correlation is not None: + print(f"Коэффициент корреляции: {correlation:.3f}") diff --git a/TEMA8/data1.txt b/TEMA8/data1.txt new file mode 100644 index 0000000..7bfdbff --- /dev/null +++ b/TEMA8/data1.txt @@ -0,0 +1,3 @@ +1.0 2.5 3.3 +4.1 5 +6.7 \ No newline at end of file diff --git a/TEMA8/data2.txt b/TEMA8/data2.txt new file mode 100644 index 0000000..1849953 --- /dev/null +++ b/TEMA8/data2.txt @@ -0,0 +1,3 @@ +2.1 3.0 +4.2 5.5 6.1 +7.8 diff --git a/TEMA8/report.md b/TEMA8/report.md new file mode 100644 index 0000000..5140c4a --- /dev/null +++ b/TEMA8/report.md @@ -0,0 +1,329 @@ +# Отчет по лабораторной работе 8 + +Анисенков Павел, А-01-23 + +## 1 Открытие и настройка интерактивной оболочки IDLE + +Была запущена интерактивная оболочка IDLE, указан рабочий каталог и импортированы необходимые модули. + +```py +>>>import os +>>>os.chdir('C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8') +>>>os.getcwd() #Контролируем корректность установки текущего каталога +'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8' +>>>import importlib +>>>import sys +``` +## 2 Создание и использование модулей в среде Python. + +## 2.1 Запуск модуля на выполнение + +Был запущен созданный модуль на выполнение, введенное на запрос число было сохранено в переменную perm1, созданную в модуле. Были просмотрены атрибуты и тип модуля. Была неудачно произведена попытка заново запустить модуль на выполнение..."Выполняется весь код в этом файле один раз. Сохраняется модуль в специальный кэш — словарь sys.modules. Любой последующий вызов import Mod1 не перезапускает код модуля — Python просто возвращает уже загруженный объект модуля из sys.modules." После этого модуль был запущен еще раз с помощью метода reload. Была просмотрена переменная perm1 и установлено, что данная переменная была переопределена. + +```py +>>>import Mod1 +Mod1:Введите значение = 5 +Mod1:Значение perm1= 5 +>>>type(Mod1) + +>>>dir(Mod1) +['__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'perm1'] +>>>Mod1.perm1 +'5' +>>>import Mod1 +>>>importlib.reload(Mod1) +Mod1:Введите значение = 3 +Mod1:Значение perm1= 3 + +>>>Mod1.perm1 +'3' +``` + +## 2.2 Изучение удаления модуля из словаря + +Был выведен словарь - значение атрибута sys.modules, среди которых был модуль Mod1. Далее этот модуль был удален, и снова изображен словарь, в котором Mod1 отсутствовал. Потом модуль был снова запущен и снова удален из словаря. + +```py +>>>print(sorted(sys.modules.keys())) +['Mod1', '__future__', '__main__', '_abc', '_ast', '_bisect', '_bz2', '_codecs', '_collections', '_collections_abc', '_colorize', '_compat_pickle', '_compression', '_datetime', '_distutils_hack', '_frozen_importlib', '_frozen_importlib_external', '_functools', '_heapq', '_imp', '_io', '_lzma', '_opcode', '_opcode_metadata', '_operator', '_pickle', '_pyrepl', '_pyrepl.pager', '_queue', '_random', '_signal', '_sitebuiltins', '_socket', '_sre', '_stat', '_string', '_struct', '_suggestions', '_sysconfig', '_thread', '_tkinter', '_tokenize', '_typing', '_warnings', '_weakref', '_weakrefset', '_winapi', '_wmi', 'abc', 'ast', 'bdb', 'binascii', 'bisect', 'builtins', 'bz2', 'codecs', 'collections', 'collections.abc', 'configparser', 'contextlib', 'copyreg', 'datetime', 'dis', 'encodings', 'encodings.aliases', 'encodings.cp1251', 'encodings.utf_8', 'encodings.utf_8_sig', 'enum', 'errno', 'fnmatch', 'functools', 'genericpath', 'heapq', 'idlelib', 'idlelib.autocomplete', 'idlelib.autocomplete_w', 'idlelib.calltip', 'idlelib.calltip_w', 'idlelib.config', 'idlelib.debugger', 'idlelib.debugger_r', 'idlelib.debugobj', 'idlelib.debugobj_r', 'idlelib.hyperparser', 'idlelib.iomenu', 'idlelib.macosx', 'idlelib.multicall', 'idlelib.pyparse', 'idlelib.rpc', 'idlelib.run', 'idlelib.scrolledlist', 'idlelib.stackviewer', 'idlelib.tooltip', 'idlelib.tree', 'idlelib.util', 'idlelib.window', 'idlelib.zoomheight', 'importlib', 'importlib._abc', 'importlib._bootstrap', 'importlib._bootstrap_external', 'importlib.machinery', 'importlib.util', 'inspect', 'io', 'ipaddress', 'itertools', 'keyword', 'linecache', 'lzma', 'marshal', 'math', 'nt', 'ntpath', 'opcode', 'operator', 'os', 'os.path', 'pickle', 'pkgutil', 'platform', 'plistlib', 'posixpath', 'pydoc', 'pyexpat', 'pyexpat.errors', 'pyexpat.model', 'queue', 'random', 're', 're._casefix', 're._compiler', 're._constants', 're._parser', 'reprlib', 'select', 'selectors', 'shlex', 'shutil', 'site', 'socket', 'socketserver', 'stat', 'string', 'struct', 'sys', 'sysconfig', 'tempfile', 'textwrap', 'threading', 'time', 'tkinter', 'tkinter.constants', 'token', 'tokenize', 'traceback', 'types', 'typing', 'urllib', 'urllib.parse', 'warnings', 'weakref', 'winreg', 'xml', 'xml.parsers', 'xml.parsers.expat', 'xml.parsers.expat.errors', 'xml.parsers.expat.model', 'zipimport', 'zlib'] +>>>sys.modules.pop('Mod1') + +>>>print(sorted(sys.modules.keys())) +['__future__', '__main__', '_abc', '_ast', '_bisect', '_bz2', '_codecs', '_collections', '_collections_abc', '_colorize', '_compat_pickle', '_compression', '_datetime', '_distutils_hack', '_frozen_importlib', '_frozen_importlib_external', '_functools', '_heapq', '_imp', '_io', '_lzma', '_opcode', '_opcode_metadata', '_operator', '_pickle', '_pyrepl', '_pyrepl.pager', '_queue', '_random', '_signal', '_sitebuiltins', '_socket', '_sre', '_stat', '_string', '_struct', '_suggestions', '_sysconfig', '_thread', '_tkinter', '_tokenize', '_typing', '_warnings', '_weakref', '_weakrefset', '_winapi', '_wmi', 'abc', 'ast', 'bdb', 'binascii', 'bisect', 'builtins', 'bz2', 'codecs', 'collections', 'collections.abc', 'configparser', 'contextlib', 'copyreg', 'datetime', 'dis', 'encodings', 'encodings.aliases', 'encodings.cp1251', 'encodings.utf_8', 'encodings.utf_8_sig', 'enum', 'errno', 'fnmatch', 'functools', 'genericpath', 'heapq', 'idlelib', 'idlelib.autocomplete', 'idlelib.autocomplete_w', 'idlelib.calltip', 'idlelib.calltip_w', 'idlelib.config', 'idlelib.debugger', 'idlelib.debugger_r', 'idlelib.debugobj', 'idlelib.debugobj_r', 'idlelib.hyperparser', 'idlelib.iomenu', 'idlelib.macosx', 'idlelib.multicall', 'idlelib.pyparse', 'idlelib.rpc', 'idlelib.run', 'idlelib.scrolledlist', 'idlelib.stackviewer', 'idlelib.tooltip', 'idlelib.tree', 'idlelib.util', 'idlelib.window', 'idlelib.zoomheight', 'importlib', 'importlib._abc', 'importlib._bootstrap', 'importlib._bootstrap_external', 'importlib.machinery', 'importlib.util', 'inspect', 'io', 'ipaddress', 'itertools', 'keyword', 'linecache', 'lzma', 'marshal', 'math', 'nt', 'ntpath', 'opcode', 'operator', 'os', 'os.path', 'pickle', 'pkgutil', 'platform', 'plistlib', 'posixpath', 'pydoc', 'pyexpat', 'pyexpat.errors', 'pyexpat.model', 'queue', 'random', 're', 're._casefix', 're._compiler', 're._constants', 're._parser', 'reprlib', 'select', 'selectors', 'shlex', 'shutil', 'site', 'socket', 'socketserver', 'stat', 'string', 'struct', 'sys', 'sysconfig', 'tempfile', 'textwrap', 'threading', 'time', 'tkinter', 'tkinter.constants', 'token', 'tokenize', 'traceback', 'types', 'typing', 'urllib', 'urllib.parse', 'warnings', 'weakref', 'winreg', 'xml', 'xml.parsers', 'xml.parsers.expat', 'xml.parsers.expat.errors', 'xml.parsers.expat.model', 'zipimport', 'zlib'] +>>>import Mod1 +Mod1:Введите значение = 2 +Mod1:Значение perm1= 2 +sys.modules.pop('Mod1') + +``` + +## 2.3 Изучение запуска модуля с помощью exec + +Модуль был запущен на выполнение с помощью функции exec, которая читает код. Далее трижды было введено значение perm1, и выведено на экран. + +```py +>>>exec(open('Mod1.py').read()) #не указана кодировка encoding='utf-8' +Mod1:Введите значение = 3 +Mod1:Значение perm1= 3 +>>>exec(open('Mod1.py').read()) +Mod1:Введите значение = 4 +Mod1:Значение perm1= 4 #объект-модуль при этом не создается +>>>exec(open('Mod1.py').read()) +Mod1:Введите значение = 5 +Mod1:Значение perm1= 5 +``` + +## 2.4 Изучение запуска модуля с помощью from … import … + +Была импортирована лишь часть обьектов модуля, просмотрены обьекты, а так же выведено значение переменной perm1. + +```py +>>>from Mod1 import perm1 +Mod1:Введите значение = 6 #выполняется потому что до этого мы его удалили из словаря +Mod1:Значение perm1= 6 +>>>dir() +['Mod1', '__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', '__warningregistry__', 'fg', 'imp', 'importlib', 'os', 'perm1', 'summa', 'sys'] +>>>perm1 +'6' +``` + +Пример: +```py +>>>from Mod2 import beta +>>>g=beta(2) +>>>****BETA**** +>>>g +535.4916555247646 +>>>dir() +['Mod1', '__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', '__warningregistry__', 'beta', 'g', 'importlib', 'os', 'perm1', 'sys']# была создана ссылка на функцию beta, не создаёт переменную с именем Mod2 в текущем пространстве имён из-за from.. +>>>alpha() +Traceback (most recent call last): + File "", line 1, in + alpha() +NameError: name 'alpha' is not defined +>>>from Mod2 import alpha as al +>>>al() +****ALPHA**** +Значение t=4 +'4' +>>>del al,beta #удаляет ссылку на обьект но не обьект +>>>from Mod2 import alpha as al, beta as bt +>>>del al #модуль остаётся загруженным, и его можно импортировать снова +>>>del bt +>>>from Mod2 import * #Звездочка означает, что импортируется весь модуль, а не конкретные функции. +tt=alpha() #На запрос введите значение 0.12 +****ALPHA**** +Значение t=0.12 +>>>uu=beta(float(tt)) +>>>uu +1.4578913609506803 #math.exp(q*math.pi) +``` + +## 3 Создание многомодульных программ. + +## 3.1 Пример: + +Был создан еще один модуль Mod0, в котором вызываются модуль 1 и функции из модуля 2. Также выведены значения обьектов, созданных во время выполнения программы. + +```py +>>>sys.modules.pop('Mod1') + +>>>sys.modules.pop('Mod2') + +>>>import Mod0 +Mod1:Введите значение = 1 +Mod1:Значение perm1= 1 +perm1= 1 +****ALPHA**** +Значение t=2 +tt= 2 +****BETA**** +qq= 535.4916555247646 #переменные (tt, qq) и модуль (Mod1) становятся атрибутами объекта модуля Mod0, потому что они были созданы внутри его кода +Mod0.tt;Mod0.qq;Mod0.Mod1.perm1 #Mod0 содержит ссылку на Mod1 в котором есть perm1(локальная переменная) +'2' +535.4916555247646 +'1' +``` + +## 3.2 Создание модулей для реализации программы моделирования системы управления + +Были созданы модули MM1 - с функциями реализующими реальный двигатель, тахогенератор и нелинейное звено; MM2 - с инструкциями, обеспечивающими ввод параметров задачи, формирование входного сигнала, импорт модуля ММ1 и реализацию модели при расчете выходного сигнала; MM0 - содержащую импорт модуля MM2 и печатающую получившийся выходной сигнал. Был вызван модуль MM0. + +```py +>>>import MM0 +k1,T,k2,Xm,A,F,N=0.5,35,0.6,5,1000,5,15 +y= [0, 8.209118281877132, 29.104924685415277, 40.86232427117668, 38.3075414151359, 34.68635884409398, 42.90679739719954, 57.19526562043458, 60.53754513466764, 47.64611630565597, 31.742316122264157, 25.812753880749888, 24.278160244795345, 10.44509996519298, -10.518946273258612] +``` + +## 3.3 Изучение области действия обьектов в модулях + +Была изучена область действия обьектов в модулях. Исходя из примеров, приведенных ниже, можно сказать, что обьекты входящие в один модуль будут локализованы в этом модуле и доступны в нем. К переменным из другого модуля, даже импортированного в главный (выполняемый) модуль, прямого доступа не будет. + +## 3.3.1 Изучение области действия обьектов в модулях (пример 1) + +Внутрь модуля Mod2 в функцию alpha был добавлен вызов функции beta. + +```py +def alpha(): + print('****ALPHA****') + t=input('Значение t=') + n = beta(6) + print(n) + return t + +def beta(q): + print('****BETA****') + import math + expi=q*math.pi + return math.exp(expi) +``` +Далее запущен модуль и вызвана функция alpha. Можно заметить, что инструкции успешно выполнились. + +```py +sys.modules.pop('Mod2') + +>>>import Mod2 +>>>alpha() +****ALPHA**** +Значение t=9 +153552935.39544657 +'9' +``` +Далее в модуле в функции beta был добавлен вызов функции alpha. + +```py +def alpha(): + print('****ALPHA****') + t=input('Значение t=') + return t + +def beta(q): + import math + expi=q*math.pi + alpha() + return math.exp(expi) +``` + +Функция beta была успешно вызвана + +```py +sys.modules.pop('Mod2') + +>>>import Mod2 +>>>beta(6) +****ALPHA**** +Значение t=9 +153552935.39544657 +``` + +## 3.3.2 Изучение области действия обьектов в модулях (пример 2) + +В модуль Mod0 была добавлена функция печати переменных t и expi, которые есть в Mod2. Мod2 переделан в исходный вариант + +```py +import Mod1 +print('perm1 =', Mod1.perm1) +from Mod2 import alpha, beta +t = alpha() +print('tt =', t) +t_num = float(t) +qq, expi = beta(t_num) +print(t) +print(expi) +print(qq) +``` +Итог: + +```py +sys.modules.pop('Mod1') + +sys.modules.pop('Mod2') + +sys.modules.pop('Mod0') + +import Mod0 +Mod1:Введите значение = 1 +Mod1:Значение perm1= 1 +perm1= 1 +****ALPHA**** +Значение t=0.12 +tt = 0.12 +****BETA**** +qq = 1.4578913609506803 +expi = 0.37699111843077515 +``` + +## 3.3.3 Изучение области действия обьектов в модулях (пример 3) + +В модуле Mod0 были добавлены инструкции, где переменная perm1 была увеличена в 3 раза и напечатана + +```py +#Модуль Mod0 +import Mod1 +print('perm1=',Mod1.perm1) +from Mod2 import alpha as al +tt=al() +print('tt=',tt) +from Mod2 import beta +qq=beta(float(tt)) +print('qq=',qq) +perm1 = Mod1.perm1*3 +print("perm1*3= ", perm1) +``` + +При запуске модуля напечаталась переменная perm1 умноженная на 3. Так как эта переменная класса строка, то строка была повторена трижды и сформирована новая строка. + +```py +sys.modules.pop('Mod0') + +sys.modules.pop('Mod1') + +sys.modules.pop('Mod2') + +import Mod0 +Mod1:Введите значение = 4 +Mod1:Значение perm1= 4 +perm1= 4 +****ALPHA**** +Значение t=3 +tt= 3 +****BETA**** +qq= (12391.647807916694, 9.42477796076938) +perm1*3= 444 +``` + +## 3.3.4 Изучение области действия обьектов в модулях (пример 4) + +В командной строке после выполнения главного модуля была произведена попытка изменить переменные perm1, tt, qq. + +```py +sys.modules.pop('Mod0') + +sys.modules.pop('Mod1') + +sys.modules.pop('Mod2') + +import Mod0 +Mod1:Введите значение = 3 +Mod1:Значение perm1= 3 +perm1= 3 +****ALPHA**** +Значение t=4 +tt= 4 +****BETA**** +qq= (286751.31313665316, 12.566370614359172) +perm1*3= 333 +Mod0.Mod1.perm1 = str(2 * float(Mod0.Mod1.perm1)) +Mod0.tt = str(2 * float(Mod0.tt)) +Mod0.qq = 2 * Mod0.qq +Mod0.Mod1.perm1 +'6.0' +Mod0.tt +'8.0' +Mod0.qq +(286751.31313665316, 12.566370614359172, 286751.31313665316, 12.566370614359172) +``` + +## 4 Завершение работы в IDLE + +Был завершен сеанс в среде IDLE. \ No newline at end of file diff --git a/TEMA8/task.md b/TEMA8/task.md new file mode 100644 index 0000000..f749182 --- /dev/null +++ b/TEMA8/task.md @@ -0,0 +1,77 @@ +# Общее контрольное задание по теме 8 + +Анисенков Павел, А-01-23 + +## Задание + +Разработайте программу, состоящую из трех модулей: +- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу. +- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу. +- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки. +Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы. + +## Решение +```py +Mod11 +def read_number_list(filename): + number_list = [] + with open(filename, 'r') as file: + for line in file: + numbers = line.strip().split() + for num in numbers: + number_list.append(float(num)) + return number_list +``` + +```py +Mod22 +import math +def calculate_correlation(list1, list2): + if not list1 or not list2: + print("Ошибка: Один или оба списка пусты.") + return None + + n = min(len(list1), len(list2)) # Используем меньшую длину + sum_x = sum(list1[:n]) + sum_y = sum(list2[:n]) + sum_x_squared = sum(x**2 for x in list1[:n]) + sum_y_squared = sum(y**2 for y in list2[:n]) + sum_xy = sum(list1[i] * list2[i] for i in range(n)) + + numerator = n * sum_xy - sum_x * sum_y + denominator = math.sqrt((n * sum_x_squared - sum_x**2) * (n * sum_y_squared - sum_y**2)) + + if denominator == 0: + print("Предупреждение: Деление на ноль при вычислении корреляции.") + return None + + return numerator / denominator +``` + +```py +Mod33 +import Mod11 +import Mod22 + +if __name__ == "__main__": + file1_name = input("Введите имя первого файла: ") + file2_name = input("Введите имя второго файла: ") + + list1 = Mod11.read_number_list(file1_name) + list2 = Mod11.read_number_list(file2_name) + + if list1 is not None and list2 is not None: + correlation = Mod22.calculate_correlation(list1, list2) + if correlation is not None: + print(f"Коэффициент корреляции: {correlation:.3f}") +``` + + + +```py += RESTART: C:\Users\Professional\Desktop\python-labs\TEMA8\Mod33.py +Введите имя первого файла: data1.txt +Введите имя второго файла: data2.txt +Коэффициент корреляции: 0.991 + +``` \ No newline at end of file