форкнуто от main/python-labs
Сравнить коммиты
Ничего общего в коммитах. 'be1a33a4110d981eca252de198ae5b7bae6fdc65' и '0f5120ea57a61a4772dd336518314578206028ac' имеют совершенно разные истории.
be1a33a411
...
0f5120ea57
@ -1,2 +0,0 @@
|
|||||||
import MM2
|
|
||||||
print('y=',MM2.vyhod)
|
|
||||||
@ -1,20 +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):
|
|
||||||
ytt = 0
|
|
||||||
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,300 +0,0 @@
|
|||||||
# Отчёт по теме 7
|
|
||||||
|
|
||||||
Гордиевских Данил А-03-23
|
|
||||||
|
|
||||||
## Настройка окружения
|
|
||||||
|
|
||||||
```py
|
|
||||||
>>> import os,sys,importlib
|
|
||||||
>>> os.chdir(r"/Users/technetium/Yandex.Disk.localized/5 семестр/ПОАС/python-labs/TEMA8")
|
|
||||||
>>> os.getcwd()
|
|
||||||
'/Users/technetium/Yandex.Disk.localized/5 семестр/ПОАС/python-labs/TEMA8'
|
|
||||||
```
|
|
||||||
|
|
||||||
## Пункт 2
|
|
||||||
|
|
||||||
### Пункт 2.1. Запуск модуля на исполнение путём его импорта
|
|
||||||
|
|
||||||
Создан файл mod1.py со следующим содержимым
|
|
||||||
|
|
||||||
```py
|
|
||||||
perm1=input('Mod1:Введите значение = ')
|
|
||||||
print('Mod1:Значение perm1=',perm1)
|
|
||||||
```
|
|
||||||
|
|
||||||
Результат вызова функции
|
|
||||||
|
|
||||||
```py
|
|
||||||
>>> import Mod1
|
|
||||||
Mod1:Введите значение = 5
|
|
||||||
Mod1:Значение perm1= 5
|
|
||||||
>>> Mod1.perm1
|
|
||||||
'5'
|
|
||||||
```
|
|
||||||
|
|
||||||
Попытка повторного вызова функции
|
|
||||||
|
|
||||||
```py
|
|
||||||
>>> import Mod1
|
|
||||||
>>> importlib.reload(Mod1)
|
|
||||||
Mod1:Введите значение = 3
|
|
||||||
Mod1:Значение perm1= 3
|
|
||||||
<module 'Mod1' from '/Users/technetium/Yandex.Disk.localized/5 семестр/ПОАС/python-labs/TEMA8/Mod1.py'>
|
|
||||||
>>> Mod1.perm1
|
|
||||||
'3'
|
|
||||||
```
|
|
||||||
|
|
||||||
### Пункт 2.2. Импортированные модули заносятся в словарь – значение атрибута sys.modules
|
|
||||||
|
|
||||||
```>>> print(sorted(sys.modules.keys()))
|
|
||||||
['Mod1', '__future__', '__main__', '_abc', '_ast', '_codecs', '_collections', '_collections_abc', '_colorize', '_curses', '_frozen_importlib', '_frozen_importlib_external', '_functools', '_imp', '_io', '_opcode', '_opcode_metadata', '_operator', '_pyrepl', '_pyrepl.base_eventqueue', '_pyrepl.commands', '_pyrepl.completing_reader', '_pyrepl.console', '_pyrepl.curses', '_pyrepl.fancy_termios', '_pyrepl.historical_reader', '_pyrepl.input', '_pyrepl.keymap', '_pyrepl.main', '_pyrepl.reader', '_pyrepl.readline', '_pyrepl.simple_interact', '_pyrepl.trace', '_pyrepl.types', '_pyrepl.unix_console', '_pyrepl.unix_eventqueue', '_pyrepl.utils', '_signal', '_sitebuiltins', '_sre', '_stat', '_struct', '_suggestions', '_thread', '_tokenize', '_warnings', '_weakref', '_weakrefset', 'abc', 'ast', 'atexit', 'builtins', 'code', 'codecs', 'codeop', 'collections', 'collections.abc', 'contextlib', 'copy', 'copyreg', 'dataclasses', 'dis', 'encodings', 'encodings.aliases', 'encodings.utf_8', 'enum', 'errno', 'fcntl', 'functools', 'genericpath', 'importlib', 'importlib._abc', 'importlib._bootstrap', 'importlib._bootstrap_external', 'importlib.machinery', 'importlib.util', 'inspect', 'io', 'itertools', 'keyword', 'linecache', 'marshal', 'opcode', 'operator', 'os', 'os.path', 'platform', 'posix', 'posixpath', 're', 're._casefix', 're._compiler', 're._constants', 're._parser', 'readline', 'reprlib', 'rlcompleter', 'runpy', 'select', 'signal', 'site', 'stat', 'struct', 'sys', 'termios', 'textwrap', 'time', 'token', 'tokenize', 'traceback', 'types', 'unicodedata', 'warnings', 'weakref', 'zipimport']
|
|
||||||
|
|
||||||
>>> sys.modules.pop('Mod1')
|
|
||||||
<module 'Mod1' from '/Users/technetium/Yandex.Disk.localized/5 семестр/ПОАС/python-labs/TEMA8/Mod1.py'>
|
|
||||||
>>> import Mod1
|
|
||||||
Mod1:Введите значение = 9
|
|
||||||
Mod1:Значение perm1= 9
|
|
||||||
>>> Mod1.perm1
|
|
||||||
'9'
|
|
||||||
```
|
|
||||||
|
|
||||||
### Пункт 2.3. Запуск модуля с помощью exec()
|
|
||||||
|
|
||||||
```py
|
|
||||||
>>> exec(open('Mod1.py').read())
|
|
||||||
Mod1:Введите значение = 8
|
|
||||||
Mod1:Значение perm1= 8
|
|
||||||
>>> perm1
|
|
||||||
'8'
|
|
||||||
>>> exec(open('Mod1.py').read())
|
|
||||||
Mod1:Введите значение = 888
|
|
||||||
Mod1:Значение perm1= 888
|
|
||||||
>>> perm1
|
|
||||||
'888'
|
|
||||||
>>> exec(open('Mod1.py').read())
|
|
||||||
Mod1:Введите значение = 7777
|
|
||||||
Mod1:Значение perm1= 7777
|
|
||||||
>>> perm1
|
|
||||||
'7777'
|
|
||||||
```
|
|
||||||
|
|
||||||
### Пункт 2.4. Использование инструкции from … import …
|
|
||||||
|
|
||||||
Пример 1
|
|
||||||
|
|
||||||
```py
|
|
||||||
>>> from Mod1 import perm1
|
|
||||||
>>> perm1
|
|
||||||
'9'
|
|
||||||
```
|
|
||||||
|
|
||||||
Пример 2
|
|
||||||
|
|
||||||
```py
|
|
||||||
>>> from Mod2 import beta
|
|
||||||
>>> g = beta(2);g
|
|
||||||
****BETA****
|
|
||||||
535.4916555247646
|
|
||||||
>>> print(sorted(sys.modules.keys()))
|
|
||||||
['Mod1', 'Mod2', '__future__', '__main__', '_abc', '_ast', '_codecs', '_collections', '_collections_abc', '_colorize', '_curses', '_frozen_importlib', '_frozen_importlib_external', '_functools', '_imp', '_io', '_opcode', '_opcode_metadata', '_operator', '_pyrepl', '_pyrepl.base_eventqueue', '_pyrepl.commands', '_pyrepl.completing_reader', '_pyrepl.console', '_pyrepl.curses', '_pyrepl.fancy_termios', '_pyrepl.historical_reader', '_pyrepl.input', '_pyrepl.keymap', '_pyrepl.main', '_pyrepl.reader', '_pyrepl.readline', '_pyrepl.simple_interact', '_pyrepl.trace', '_pyrepl.types', '_pyrepl.unix_console', '_pyrepl.unix_eventqueue', '_pyrepl.utils', '_signal', '_sitebuiltins', '_sre', '_stat', '_struct', '_suggestions', '_thread', '_tokenize', '_warnings', '_weakref', '_weakrefset', 'abc', 'ast', 'atexit', 'builtins', 'code', 'codecs', 'codeop', 'collections', 'collections.abc', 'contextlib', 'copy', 'copyreg', 'dataclasses', 'dis', 'encodings', 'encodings.aliases', 'encodings.utf_8', 'enum', 'errno', 'fcntl', 'functools', 'genericpath', 'importlib', 'importlib._abc', 'importlib._bootstrap', 'importlib._bootstrap_external', 'importlib.machinery', 'importlib.util', 'inspect', 'io', 'itertools', 'keyword', 'linecache', 'marshal', 'math', 'opcode', 'operator', 'os', 'os.path', 'platform', 'posix', 'posixpath', 're', 're._casefix', 're._compiler', 're._constants', 're._parser', 'readline', 'reprlib', 'rlcompleter', 'runpy', 'select', 'signal', 'site', 'stat', 'struct', 'sys', 'termios', 'textwrap', 'time', 'token', 'tokenize', 'traceback', 'types', 'unicodedata', 'warnings', 'weakref', 'zipimport']
|
|
||||||
>>> alpha()
|
|
||||||
Traceback (most recent call last):
|
|
||||||
File "<python-input-25>", line 1, in <module>
|
|
||||||
alpha()
|
|
||||||
^^^^^
|
|
||||||
NameError: name 'alpha' is not defined
|
|
||||||
>>> from Mod2 import alpha as al
|
|
||||||
>>> al()
|
|
||||||
****ALPHA****
|
|
||||||
Значение t=5
|
|
||||||
'5'
|
|
||||||
>>> del al,beta
|
|
||||||
>>> from Mod2 import alpha as al, beta as bt
|
|
||||||
>>> del al,bt
|
|
||||||
>>> from Mod2 import *
|
|
||||||
>>> tt=alpha()
|
|
||||||
****ALPHA****
|
|
||||||
Значение t=0.12
|
|
||||||
>>> uu = beta(float(tt))
|
|
||||||
****BETA****
|
|
||||||
```
|
|
||||||
|
|
||||||
## Пункт 3. Многомодульные программы
|
|
||||||
|
|
||||||
### Пункт 3.1. Простая многомодульная программа
|
|
||||||
|
|
||||||
```py
|
|
||||||
>>> import Mod0
|
|
||||||
Mod1:Введите значение = 13
|
|
||||||
Mod1:Значение perm1= 13
|
|
||||||
perm1= 13
|
|
||||||
****ALPHA****
|
|
||||||
Значение t=22
|
|
||||||
tt= 22
|
|
||||||
****BETA****
|
|
||||||
qq= 1.038197035676497e+30
|
|
||||||
>>> Mod0.tt;Mod0.qq;Mod0.Mod1.perm1
|
|
||||||
'13'
|
|
||||||
```
|
|
||||||
|
|
||||||
### Пункт 3.2. Сложная многомодульная программа
|
|
||||||
|
|
||||||
[Содержимое файла mm0](MM0.py)
|
|
||||||
|
|
||||||
[Содержимое файла mm1](MM1.py)
|
|
||||||
|
|
||||||
[Содержимое файла mm3](MM2.py)
|
|
||||||
|
|
||||||
Проверка программы
|
|
||||||
|
|
||||||
```py
|
|
||||||
k1,T,k2,Xm,A,F,N=9,6,4,11,3,0.5,150
|
|
||||||
y= [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, ... , 9.174885290878997e+22, -2.3735104205090632e+23, 2.945671256147081e+23, 4.958412951209005e+22, -1.1163182444540476e+24]
|
|
||||||
```
|
|
||||||
|
|
||||||
### Пункт 3.3. Действие объектов в модулях
|
|
||||||
|
|
||||||
Обращение в функции alpha к функции beta:
|
|
||||||
|
|
||||||
```py
|
|
||||||
def alpha():
|
|
||||||
print('****ALPHA****')
|
|
||||||
t=input('Значение t=')
|
|
||||||
beta(int(t))
|
|
||||||
return t
|
|
||||||
|
|
||||||
def beta(q):
|
|
||||||
import math
|
|
||||||
expi=q*math.pi
|
|
||||||
return math.exp(expi)
|
|
||||||
```
|
|
||||||
|
|
||||||
```py
|
|
||||||
Mod1: Введите значение = 8
|
|
||||||
Mod1: Значение perm1 = 8
|
|
||||||
perm1 = 8
|
|
||||||
****ALPHA****
|
|
||||||
Значение t=4
|
|
||||||
tt = 4
|
|
||||||
qq = 286751.31313665316
|
|
||||||
```
|
|
||||||
|
|
||||||
Обращение в функции beta к функции alpha:
|
|
||||||
|
|
||||||
```py
|
|
||||||
def alpha():
|
|
||||||
print('****ALPHA****')
|
|
||||||
t=input('Значение t=')
|
|
||||||
return t
|
|
||||||
|
|
||||||
def beta(q):
|
|
||||||
import math
|
|
||||||
expi = int(alpha())*math.pi
|
|
||||||
return math.exp(expi)
|
|
||||||
```
|
|
||||||
|
|
||||||
```py
|
|
||||||
Mod1: Введите значение = 8
|
|
||||||
Mod1: Значение perm1 = 8
|
|
||||||
perm1 = 8
|
|
||||||
****ALPHA****
|
|
||||||
Значение t=4
|
|
||||||
tt = 4
|
|
||||||
****ALPHA****
|
|
||||||
Значение t=4
|
|
||||||
qq = 286751.31313665316
|
|
||||||
```
|
|
||||||
|
|
||||||
Попробуйте отобразить на экране в модуле Mod0 значения объектов t и expi
|
|
||||||
|
|
||||||
Модифицированный mod0.py
|
|
||||||
|
|
||||||
```py
|
|
||||||
#Модуль Mod0
|
|
||||||
import math
|
|
||||||
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)
|
|
||||||
|
|
||||||
print("t = ", tt)
|
|
||||||
print("expi = ", math.log(qq))
|
|
||||||
```
|
|
||||||
|
|
||||||
Вывод
|
|
||||||
|
|
||||||
```py
|
|
||||||
Mod1:Введите значение = 5
|
|
||||||
Mod1:Значение perm1= 5
|
|
||||||
perm1= 5
|
|
||||||
****ALPHA****
|
|
||||||
Значение t=3
|
|
||||||
tt= 3
|
|
||||||
****BETA****
|
|
||||||
qq= 12391.647807916694
|
|
||||||
t = 3
|
|
||||||
expi = 9.42477796076938
|
|
||||||
```
|
|
||||||
|
|
||||||
Попробуйте в модуле Mod0 увеличить в 3 раза значение объекта perm1 и отобразить его после это-го на экране
|
|
||||||
|
|
||||||
Модифицированный Mod0.py
|
|
||||||
|
|
||||||
```py
|
|
||||||
import math
|
|
||||||
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)
|
|
||||||
|
|
||||||
print("t = ", tt)
|
|
||||||
print("expi = ", math.log(qq))
|
|
||||||
print('3 * perm1=',3*int(Mod1.perm1))
|
|
||||||
```
|
|
||||||
|
|
||||||
Вывод
|
|
||||||
|
|
||||||
```py
|
|
||||||
Mod1:Введите значение = 2
|
|
||||||
Mod1:Значение perm1= 2
|
|
||||||
perm1= 2
|
|
||||||
****ALPHA****
|
|
||||||
Значение t=2
|
|
||||||
tt= 2
|
|
||||||
****BETA****
|
|
||||||
qq= 535.4916555247646
|
|
||||||
t = 2
|
|
||||||
expi = 6.283185307179586
|
|
||||||
3 * perm1= 6
|
|
||||||
```
|
|
||||||
|
|
||||||
Попробуйте в командной строке (в главном модуле) увеличить в 2 раза значения объектов perm1, tt, qq
|
|
||||||
|
|
||||||
```py
|
|
||||||
>>> import Mod0
|
|
||||||
Mod1:Введите значение = 3
|
|
||||||
Mod1:Значение perm1= 3
|
|
||||||
perm1= 3
|
|
||||||
****ALPHA****
|
|
||||||
Значение t=3
|
|
||||||
tt= 3
|
|
||||||
****BETA****
|
|
||||||
qq= 12391.647807916694
|
|
||||||
t = 3
|
|
||||||
expi = 9.42477796076938
|
|
||||||
3 * perm1= 9
|
|
||||||
>>> print("2*perm1 = ", 2*int(Mod0.Mod1.perm1))
|
|
||||||
2*perm1 = 6
|
|
||||||
>>> print("2*tt = ", 2*int(Mod0.tt))
|
|
||||||
2*tt = 6
|
|
||||||
>>> print("2*qq = ", 2*int(Mod0.qq))
|
|
||||||
2*qq = 24782
|
|
||||||
```
|
|
||||||
@ -1,19 +0,0 @@
|
|||||||
# Общее контрольное задание по теме 8
|
|
||||||
|
|
||||||
Гордиевских Данил А-03-23
|
|
||||||
|
|
||||||
## Задание
|
|
||||||
|
|
||||||
Разработайте программу, состоящую из трех модулей:
|
|
||||||
|
|
||||||
- Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу.
|
|
||||||
- Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
|
|
||||||
- Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
|
|
||||||
|
|
||||||
## Решение
|
|
||||||
|
|
||||||
[Содержимое модуля 1](task1.py)
|
|
||||||
|
|
||||||
[Содержимое модуля 2](task2.py)
|
|
||||||
|
|
||||||
[Содержимое модуля 3](task3.py)
|
|
||||||
@ -1,7 +0,0 @@
|
|||||||
def readtextdata(nam):
|
|
||||||
f = open(nam)
|
|
||||||
aa = f.read()
|
|
||||||
aa = aa.replace("\n", " ")
|
|
||||||
aa = aa.split(" ")
|
|
||||||
aa = [int(item) for item in aa]
|
|
||||||
return aa
|
|
||||||
@ -1,10 +0,0 @@
|
|||||||
import pandas as pd
|
|
||||||
import numpy as np
|
|
||||||
|
|
||||||
def correl(list1, list2):
|
|
||||||
df = pd.DataFrame({
|
|
||||||
'col1': list1,
|
|
||||||
'col2': list2
|
|
||||||
})
|
|
||||||
correlation = df['col1'].corr(df['col2'])
|
|
||||||
return correlation
|
|
||||||
@ -1,10 +0,0 @@
|
|||||||
from task1 import *
|
|
||||||
from task2 import *
|
|
||||||
|
|
||||||
name1 = input("Введите имя первого файла: ")
|
|
||||||
name2 = input("Введите имя второго файла: ")
|
|
||||||
|
|
||||||
arr1 = readtextdata(name1)
|
|
||||||
arr2 = readtextdata(name2)
|
|
||||||
|
|
||||||
print(round(correl(arr1, arr2), 3))
|
|
||||||
@ -1,2 +0,0 @@
|
|||||||
1 3 5 66
|
|
||||||
7 5 55 44 32 2
|
|
||||||
@ -1,2 +0,0 @@
|
|||||||
1 3 5 66
|
|
||||||
7 0 44 44 20 2
|
|
||||||
Загрузка…
Ссылка в новой задаче