форкнуто от main/python-labs
Сравнить коммиты
Ничего общего в коммитах. 'a20fa6826bdcb9a48f9620c6b6b3699014b2e191' и '4f3124a80e89128a59b3a6b617535a9019ea016e' имеют совершенно разные истории.
a20fa6826b
...
4f3124a80e
@ -1,2 +0,0 @@
|
|||||||
import MM2
|
|
||||||
print('y=',MM2.vyhod)
|
|
||||||
@ -1,22 +0,0 @@
|
|||||||
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 and xtt>(-gran):
|
|
||||||
ytt=0
|
|
||||||
elif xtt>=gran:
|
|
||||||
ytt=xtt-gran
|
|
||||||
elif xtt<=(-gran):
|
|
||||||
ytt=xtt+gran
|
|
||||||
return ytt
|
|
||||||
@ -1,23 +0,0 @@
|
|||||||
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)
|
|
||||||
@ -1,8 +0,0 @@
|
|||||||
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
|
|
||||||
@ -1,13 +1,11 @@
|
|||||||
|
|
||||||
def alpha():
|
def alpha():
|
||||||
print('****ALPHA****')
|
print('****ALPHA****')
|
||||||
t = input('Значение t=')
|
t=input('Значение t=')
|
||||||
return t # возвращает строку
|
return t
|
||||||
|
|
||||||
def beta(q):
|
def beta(q):
|
||||||
print('****BETA****')
|
print('****BETA****')
|
||||||
import math
|
import math
|
||||||
expi = q * math.pi
|
expi=q*math.pi
|
||||||
result = math.exp(expi)
|
return math.exp(expi)
|
||||||
# Возвращаем не только результат, но и expi (если нужно)
|
|
||||||
return result, expi # возвращаем кортеж
|
|
||||||
|
|||||||
@ -1,22 +0,0 @@
|
|||||||
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
|
|
||||||
@ -1,14 +0,0 @@
|
|||||||
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}")
|
|
||||||
@ -1,3 +0,0 @@
|
|||||||
1.0 2.5 3.3
|
|
||||||
4.1 5
|
|
||||||
6.7
|
|
||||||
@ -1,3 +0,0 @@
|
|||||||
2.1 3.0
|
|
||||||
4.2 5.5 6.1
|
|
||||||
7.8
|
|
||||||
@ -1,329 +0,0 @@
|
|||||||
# Отчет по лабораторной работе 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)
|
|
||||||
<class 'module'>
|
|
||||||
>>>dir(Mod1)
|
|
||||||
['__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'perm1']
|
|
||||||
>>>Mod1.perm1
|
|
||||||
'5'
|
|
||||||
>>>import Mod1
|
|
||||||
>>>importlib.reload(Mod1)
|
|
||||||
Mod1:Введите значение = 3
|
|
||||||
Mod1:Значение perm1= 3
|
|
||||||
<module 'Mod1' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod1.py'>
|
|
||||||
>>>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')
|
|
||||||
<module 'Mod1' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod1.py'>
|
|
||||||
>>>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')
|
|
||||||
<module 'Mod1' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod1.py'>
|
|
||||||
```
|
|
||||||
|
|
||||||
## 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 "<pyshell#29>", line 1, in <module>
|
|
||||||
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')
|
|
||||||
<module 'Mod1' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod1.py'>
|
|
||||||
>>>sys.modules.pop('Mod2')
|
|
||||||
<module 'Mod2' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod2.py'>
|
|
||||||
>>>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')
|
|
||||||
<module 'Mod2' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod2.py'>
|
|
||||||
>>>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')
|
|
||||||
<module 'Mod2' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod2.py'>
|
|
||||||
>>>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')
|
|
||||||
<module 'Mod1' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod1.py'>
|
|
||||||
sys.modules.pop('Mod2')
|
|
||||||
<module 'Mod2' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod2.py'>
|
|
||||||
sys.modules.pop('Mod0')
|
|
||||||
<module 'Mod0' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod0.py'>
|
|
||||||
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')
|
|
||||||
<module 'Mod0' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod0.py'>
|
|
||||||
sys.modules.pop('Mod1')
|
|
||||||
<module 'Mod1' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod1.py'>
|
|
||||||
sys.modules.pop('Mod2')
|
|
||||||
<module 'Mod2' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod2.py'>
|
|
||||||
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')
|
|
||||||
<module 'Mod0' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod0.py'>
|
|
||||||
sys.modules.pop('Mod1')
|
|
||||||
<module 'Mod1' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod1.py'>
|
|
||||||
sys.modules.pop('Mod2')
|
|
||||||
<module 'Mod2' from 'C:\\Users\\Professional\\Desktop\\python-labs\\TEMA8\\Mod2.py'>
|
|
||||||
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.
|
|
||||||
@ -1,77 +0,0 @@
|
|||||||
# Общее контрольное задание по теме 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
|
|
||||||
|
|
||||||
```
|
|
||||||
Загрузка…
Ссылка в новой задаче