ответвлено от main/python-labs
Сравнить коммиты
1 Коммитов
main
...
ae4d4f4b4b
| Автор | SHA1 | Дата | |
|---|---|---|---|
|
|
ae4d4f4b4b |
Двоичные данные
TEMA6/name.bin
Двоичные данные
TEMA6/name.bin
Двоичный файл не отображается.
Двоичные данные
TEMA6/name1.bin
Двоичные данные
TEMA6/name1.bin
Двоичный файл не отображается.
@@ -7,6 +7,7 @@ os.chdir('C:\\Users\\Ekaterina\\OneDrive\\Desktop\\Solovyova\\python-labs\\TEMA6
|
||||
```
|
||||
## 2 вывод данных на экран дисплея
|
||||
## 2.1 Вывод в командной строке
|
||||
|
||||
```py
|
||||
stroka='Автоматизированная система управления'
|
||||
stroka
|
||||
@@ -15,7 +16,9 @@ stroka
|
||||
|
||||
|
||||
## 2.2 Вывод с использованием функции print
|
||||
|
||||
Вывод информации на экран. Можно использовать и в теле функции и в командной строке
|
||||
|
||||
```py
|
||||
fff=234.5;gg='Значение температуры = '
|
||||
print(gg, fff)
|
||||
@@ -40,7 +43,9 @@ print("Здесь может выводиться",
|
||||
* Тройные кавычки сохраняют структуру многострочного текста
|
||||
|
||||
|
||||
|
||||
## 2.3 Вывод с использованием метода write объекта sys.stdout
|
||||
|
||||
```py
|
||||
import sys
|
||||
sys.stdout.write('Функция write')
|
||||
@@ -51,6 +56,7 @@ sys.stdout.write('Функция write\n')
|
||||
```
|
||||
|
||||
## 2 Ввод данных с клавиатуры
|
||||
|
||||
```py
|
||||
Введите пароль:1234
|
||||
print(psw)
|
||||
@@ -75,6 +81,8 @@ print(eval(input('введите выражение для расчета = ')))
|
||||
1.34504378689765
|
||||
```
|
||||
|
||||
|
||||
|
||||
## 4 Ввод-вывод при работе с файлами
|
||||
## 4.1 Функции для работы с путем к файлу
|
||||
|
||||
@@ -130,12 +138,12 @@ type(fp);dir(fp)
|
||||
['_CHUNK_SIZE', '__class__', '__del__', '__delattr__', '__dict__', '__dir__', '__doc__', '__enter__', '__eq__', '__exit__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__next__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '_checkClosed', '_checkReadable', '_checkSeekable', '_checkWritable', '_finalizing', 'buffer', 'close', 'closed', 'detach', 'encoding', 'errors', 'fileno', 'flush', 'isatty', 'line_buffering', 'mode', 'name', 'newlines', 'read', 'readable', 'readline', 'readlines', 'reconfigure', 'seek', 'seekable', 'tell', 'truncate', 'writable', 'write', 'write_through', 'writelines']
|
||||
```
|
||||
Для второго аргумента «mode=…» могут быть заданы следующие значения:
|
||||
* w – запись с созданием нового файла или перезапись существующего файла,
|
||||
* w+ - чтение и запись/перезапись файла,
|
||||
* r – только чтение (это значение - по умолчанию),
|
||||
* r+ - чтение и/или запись в существующий файл,
|
||||
* a – запись в конец существующего файла или, если его нет, запись с созданием файла,
|
||||
* a+ - то же, что и в «a», но с возможностью чтения из файла.
|
||||
w – запись с созданием нового файла или перезапись существующего файла,
|
||||
w+ - чтение и запись/перезапись файла,
|
||||
r – только чтение (это значение - по умолчанию),
|
||||
r+ - чтение и/или запись в существующий файл,
|
||||
a – запись в конец существующего файла или, если его нет, запись с созданием файла,
|
||||
a+ - то же, что и в «a», но с возможностью чтения из файла.
|
||||
В зависимости от значения этого аргумента тип создаваемой файловой переменной может быть разным.
|
||||
|
||||
При открытии бинарного файла к указанным выше буквам в аргументе-цели надо добавить сим-вол «b».
|
||||
@@ -171,9 +179,11 @@ fp2.close()
|
||||
[1, 2, 3, 4]
|
||||
[5, 6, 7, 8]
|
||||
[9, 10, 11, 12]
|
||||
|
||||
```
|
||||
|
||||
Попытка 1
|
||||
|
||||
```py
|
||||
sps3=[['Иванов И.',1],['Петров П.',2],['Сидоров С.',3]]
|
||||
fp3=open('zapis4.txt','w')
|
||||
@@ -182,21 +192,24 @@ for i in range(len(sps3)):
|
||||
fp3.write(stroka4)
|
||||
fp3.close()
|
||||
```
|
||||
|
||||
Содержимое текстового файла:
|
||||
|
||||
|
||||
```txt
|
||||
Иванов И. 1Петров П. 2Сидоров С. 3
|
||||
```
|
||||
|
||||
Попытка 2
|
||||
|
||||
```py
|
||||
gh = open('zapis5.txt','w')
|
||||
for r in sps3:
|
||||
gh.write(r[0]+' '+str(r[1])+'\n')
|
||||
|
||||
gh.close()
|
||||
```
|
||||
|
||||
Содержимое текстового файла:
|
||||
|
||||
```txt
|
||||
Иванов И. 1
|
||||
Петров П. 2
|
||||
@@ -271,7 +284,7 @@ pickle.dump(mnoz1,fp)
|
||||
fp.close()
|
||||
```
|
||||
```txt
|
||||
Содержание файла zapis6.mnz: 耄锣 鐨谆楐桯湥钌մ慢汥钌Ͱ敮钌Ѣ潯殔逮
|
||||
Вывод: 耄锣 鐨谆楐桯湥钌մ慢汥钌Ͱ敮钌Ѣ潯殔逮
|
||||
```
|
||||
```py
|
||||
fp=open('zapis6.mnz','rb')
|
||||
|
||||
@@ -1,61 +0,0 @@
|
||||
# Общее контрольное задание по теме 6
|
||||
|
||||
Соловьёва Екатерина, А-01-23
|
||||
|
||||
## Задание
|
||||
|
||||
Придумайте инструкции и запишите их в файл с расширением .py , которые выполняют следующие операции:
|
||||
|
||||
* Создаётся объект-кортеж со 125 целыми случайными числами из диапазона от 6 до 56, представленными в виде символьных строк.
|
||||
|
||||
* Создаётся объект-список с вашей фамилией и 4 фамилиями ваших одноклассников.
|
||||
|
||||
* Записывается кортеж в бинарный файл.
|
||||
|
||||
* Записывается в этот же файл список и закрывается файл.
|
||||
|
||||
* Открывается этот файл для чтения и считывает из него данные в 2 новых объекта.
|
||||
|
||||
* Проверяется на совпадение новых объектов с исходными и выводится соответствующее сообщение.
|
||||
|
||||
* Разделяется кортеж на совокупности по 5 чисел в каждой и они записываются в виде отдельных списков со своими именами.
|
||||
|
||||
## Решение
|
||||
|
||||
```py
|
||||
import pickle
|
||||
import random
|
||||
|
||||
kort = tuple(str(random.randint(6, 56)) for _ in range(125))
|
||||
spis = ['Соловьёва', 'Лыкова', 'Филиппова', 'Лазарев', 'Коваленко']
|
||||
|
||||
fp = open('zapis8.mnz','wb')
|
||||
pickle.dump(kort,fp)
|
||||
pickle.dump(spis,fp)
|
||||
fp.close()
|
||||
|
||||
fp = open('zapis8.mnz','rb')
|
||||
obj1 = pickle.load(fp)
|
||||
obj2 = pickle.load(fp)
|
||||
|
||||
if obj1 == kort:
|
||||
print('Объекты совпадают')
|
||||
else: print('Объекты не совпадают')
|
||||
|
||||
if obj2 == spis:
|
||||
print('Объекты совпадают')
|
||||
else: print('Объекты не совпадают')
|
||||
|
||||
lists = {}
|
||||
for i in range(0, 125, 5):
|
||||
lists[f'list{i//5 + 1}'] = list(obj1[i:i+5])
|
||||
|
||||
```
|
||||
|
||||
Вывод программы:
|
||||
|
||||
```py
|
||||
Объекты совпадают
|
||||
Объекты совпадают
|
||||
```
|
||||
|
||||
|
||||
@@ -1,26 +0,0 @@
|
||||
import pickle
|
||||
import random
|
||||
|
||||
kort = tuple(str(random.randint(6, 56)) for _ in range(125))
|
||||
spis = ['Соловьёва', 'Лыкова', 'Филиппова', 'Лазарев', 'Коваленко']
|
||||
|
||||
fp = open('zapis8.mnz','wb')
|
||||
pickle.dump(kort,fp)
|
||||
pickle.dump(spis,fp)
|
||||
fp.close()
|
||||
|
||||
fp = open('zapis8.mnz','rb')
|
||||
obj1 = pickle.load(fp)
|
||||
obj2 = pickle.load(fp)
|
||||
|
||||
if obj1 == kort:
|
||||
print('Объекты совпадают')
|
||||
else: print('Объекты не совпадают')
|
||||
|
||||
if obj2 == spis:
|
||||
print('Объекты совпадают')
|
||||
else: print('Объекты не совпадают')
|
||||
|
||||
lists = {}
|
||||
for i in range(0, 125, 5):
|
||||
lists[f'list{i//5 + 1}'] = list(obj1[i:i+5])
|
||||
@@ -1,76 +0,0 @@
|
||||
# Индивидуальное контрольное задание по теме 6
|
||||
|
||||
|
||||
|
||||
Соловьёва Екатерина, А-01-23
|
||||
|
||||
|
||||
|
||||
## Задание
|
||||
|
||||
|
||||
|
||||
M2_3
|
||||
|
||||
1) Создайте список с 5 фамилиями сотрудников некоторой фирмы (фамилии придумайте сами). Создайте кортеж с 5 числовыми элементами - окладами сотрудников из списка.
|
||||
|
||||
|
||||
|
||||
2) Запросите у пользователя и введите символьную строку с названием фирмы (латиницей). Удалите из названия пробелы.
|
||||
|
||||
|
||||
|
||||
3) Создайте словарь с именем - названием фирмы, ключами - фамилиями сотрудников из списка и значениями - их окладами из кортежа. Отобразите словарь.
|
||||
|
||||
|
||||
|
||||
4) Рассчитайте среднее значение оклада сотрудников фирмы и отобразите с заголовком.
|
||||
|
||||
|
||||
|
||||
5) Запишите список, кортеж и словарь в бинарный файл с именем - названием фирмы и расширением '.bin'.
|
||||
|
||||
|
||||
|
||||
## Решение
|
||||
|
||||
|
||||
|
||||
```py
|
||||
import pickle
|
||||
|
||||
spis = ["Бушманов", "Подольский", "Жалнин", "Голощапов", "Таболин"]
|
||||
kort = (5000, 200000, 120000, 70000, 60000)
|
||||
|
||||
company = input(" Введите название фирмы (латиницей): ")
|
||||
company = company.replace(' ', '')
|
||||
print(" Название фирмы:", company)
|
||||
|
||||
globals()[company] = dict(zip(spis, kort))
|
||||
|
||||
print("Словарь фирмы:")
|
||||
print(globals()[company])
|
||||
|
||||
average_salary = sum(kort) / len(kort)
|
||||
print(f" Средний оклад сотрудников: {average_salary:.2f} рублей")
|
||||
|
||||
filename = f"{company}.bin"
|
||||
with open(filename, 'wb') as fp:
|
||||
pickle.dump(spis, fp)
|
||||
pickle.dump(kort, fp)
|
||||
pickle.dump(globals()[company], fp)
|
||||
|
||||
print(f" Данные сохранены в файл: {filename}")
|
||||
```
|
||||
## Вывод
|
||||
```py
|
||||
Введите название фирмы (латиницей): name1
|
||||
Название фирмы: name1
|
||||
Словарь фирмы:
|
||||
{'name1': {'Бушманов': 5000, 'Подольский': 200000, 'Жалнин': 120000, 'Голощапов': 70000, 'Таболин': 60000}}
|
||||
Средний оклад сотрудников: 91000.00 рублей
|
||||
Данные сохранены в файл: name1.bin
|
||||
```
|
||||
|
||||
|
||||
|
||||
@@ -1,29 +0,0 @@
|
||||
import pickle
|
||||
|
||||
spis = ["Бушманов", "Подольский", "Жалнин", "Голощапов", "Таболин"]
|
||||
kort = (5000, 200000, 120000, 70000, 60000)
|
||||
|
||||
company = input(" Введите название фирмы (латиницей): ")
|
||||
company = company.replace(' ', '')
|
||||
print(" Название фирмы:", company)
|
||||
|
||||
# Создаем словарь с именем компании как ключом
|
||||
company_dict = {
|
||||
company: dict(zip(spis, kort))
|
||||
}
|
||||
|
||||
print("Словарь фирмы:")
|
||||
print(company_dict)
|
||||
|
||||
average_salary = sum(kort) / len(kort)
|
||||
print(f" Средний оклад сотрудников: {average_salary:.2f} рублей")
|
||||
|
||||
# Создаем имя файла из названия компании
|
||||
filename = f"{company}.bin"
|
||||
fp = open(filename, 'wb')
|
||||
pickle.dump(spis, fp)
|
||||
pickle.dump(kort, fp)
|
||||
pickle.dump(company_dict, fp)
|
||||
fp.close()
|
||||
|
||||
print(f" Данные сохранены в файл: {filename}")
|
||||
@@ -1,3 +1,3 @@
|
||||
Иванов И. 1
|
||||
Петров П. 2
|
||||
Сидоров С. 3
|
||||
Иванов И.;1
|
||||
Петров П.;2
|
||||
Сидоров С.;3
|
||||
|
||||
Двоичные данные
TEMA6/zapis7.2ob
Двоичные данные
TEMA6/zapis7.2ob
Двоичный файл не отображается.
Двоичные данные
TEMA6/zapis8.mnz
Двоичные данные
TEMA6/zapis8.mnz
Двоичный файл не отображается.
569
TEMA7/report.md
569
TEMA7/report.md
@@ -1,569 +0,0 @@
|
||||
# Отчёт по Теме 7
|
||||
|
||||
Соловьёва Екатерина, А-01-23
|
||||
|
||||
# 1. Запуск интерактивной оболочки IDLE
|
||||
|
||||
# 2. Создание пользовательской функции
|
||||
|
||||
Создание функции предполагает выполнение трех операций: формирование функции, ее сохранение и использование.
|
||||
В общем виде функция в языке Python представляется так:
|
||||
def <Имя функции>([<Список аргументов >]):
|
||||
[<отступы>"""<Комментарий по назначению функции>"""]
|
||||
<отступы><Блок инструкций – тело функции>
|
||||
[<отступы>return <Значение или вычисляемое выражение>]
|
||||
|
||||
# 2.1 Функция без аргументов
|
||||
```py
|
||||
def uspeh():
|
||||
"""Подтверждение успеха операции"""
|
||||
print('Выполнено успешно!')
|
||||
|
||||
uspeh()
|
||||
Выполнено успешно!
|
||||
|
||||
type(uspeh)
|
||||
<class 'function'>
|
||||
|
||||
dir()
|
||||
['__annotations__', '__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'os', 'uspeh']
|
||||
|
||||
help(uspeh)
|
||||
Help on function uspeh in module __main__:
|
||||
|
||||
uspeh()
|
||||
Подтверждение успеха операции
|
||||
```
|
||||
Вызов help(uspeh) показал справку по функции из модуля __main__ с документационной строкой "Подтверждение успеха операции". Это описание, указанное в тройных кавычках при создании функции, поясняет её назначение
|
||||
|
||||
## 2.2 Функция с аргументами
|
||||
```py
|
||||
def sravnenie(a,b):
|
||||
"""Сравнение a и b"""
|
||||
if a>b:
|
||||
print(a,' больше ',b)
|
||||
elif a<b:
|
||||
print(a, ' меньше ',b)
|
||||
else:
|
||||
print(a, ' равно ',b)
|
||||
n,m=16,5;sravnenie(n,m)
|
||||
16 больше 5
|
||||
n,m='16','5';sravnenie(n,m)
|
||||
16 меньше 5
|
||||
ord('1')
|
||||
49
|
||||
ord('5')
|
||||
53
|
||||
```
|
||||
Строка '16' считается "меньше" строки '5', потому что сравниваются первые символы: '1' и '5', а символ '1' в таблице Unicode/ASCII имеет меньший код, чем '5'. Сравнение прекращается на первом различающемся символе
|
||||
|
||||
|
||||
## 2.3 Пример функции, содержащей return.
|
||||
|
||||
```py
|
||||
def logistfun(b,a):
|
||||
"""Вычисление логистической функции"""
|
||||
import math
|
||||
return a/(1+math.exp(-b))
|
||||
|
||||
v,w=1,0.7;z=logistfun(w,v)
|
||||
z
|
||||
0.6681877721681662
|
||||
```
|
||||
Использует return вместо print - результат "возвращается", а не выводится
|
||||
|
||||
## 2.4 Сложение для разных типов аргументов
|
||||
|
||||
```py
|
||||
def slozh(a1,a2,a3,a4):
|
||||
""" Сложение значений четырех аргументов"""
|
||||
return a1+a2+a3+a4
|
||||
|
||||
slozh(1,2,3,4)
|
||||
10
|
||||
|
||||
slozh('1','2','3','4')
|
||||
'1234'
|
||||
|
||||
b1=[1,2];b2=[-1,-2]
|
||||
b3=[0,2];b4=[-1,-1]
|
||||
q=slozh(b1,b2,b3,b4)
|
||||
q
|
||||
[1, 2, -1, -2, 0, 2, -1, -1]
|
||||
|
||||
kort1 = (1, 2); kort2 = (3, 4); kort3 = (5,6); kort4 = (7, 8)
|
||||
slozh(kort1, kort2, kort3, kort4)
|
||||
(1, 2, 3, 4, 5, 6, 7, 8)
|
||||
|
||||
dict1 = {'a': 1}; dict2 = {'b': 2}; dict3 = {'c': 3}; dict4 = {'d': 4}
|
||||
slozh(dict1, dict2, dict3, dict4)
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#40>", line 1, in <module>
|
||||
slozh(dict1, dict2, dict3, dict4)
|
||||
File "<pyshell#26>", line 3, in slozh
|
||||
return a1+a2+a3+a4
|
||||
TypeError: unsupported operand type(s) for +: 'dict' and 'dict'
|
||||
|
||||
mnoz = slozh({1,3}, {6,9}, {"zxcv"}, {0,9})
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#38>", line 1, in <module>
|
||||
mnoz = slozh({1,3}, {6,9}, {"zxcv"}, {0,9})
|
||||
File "<pyshell#26>", line 3, in slozh
|
||||
return a1+a2+a3+a4
|
||||
TypeError: unsupported operand type(s) for +: 'set' and 'set'
|
||||
```
|
||||
|
||||
## 2.5 Функция, реализующая модель некоторого устройства, на вход которого в текущий момент поступает сигнал х, на выходе получается сигнал y:
|
||||
|
||||
```py
|
||||
def inerz(x,T,ypred):
|
||||
""" Модель устройства с памятью:
|
||||
x- текущее значение вх.сигнала,
|
||||
T -постоянная времени,
|
||||
ypred - предыдущее значение выхода устройства"""
|
||||
y=(x+T*ypred)/(T+1)
|
||||
return y
|
||||
|
||||
sps=[0]+[1]*100
|
||||
spsy=[]
|
||||
TT=20
|
||||
yy=0
|
||||
for xx in sps:
|
||||
yy=inerz(xx,TT,yy)
|
||||
spsy.append(yy)
|
||||
|
||||
|
||||
|
||||
import matplotlib.pyplot as plt
|
||||
plt.show()
|
||||
plt.plot(spsy)
|
||||
[<matplotlib.lines.Line2D object at 0x000002977187AC10>]
|
||||
plt.show()```
|
||||
|
||||

|
||||
```
|
||||
|
||||
# 3. Функции как объекты
|
||||
|
||||
## 3.1 Получение списка атрибутов объекта-функции
|
||||
|
||||
```py
|
||||
|
||||
dir(inerz)
|
||||
['__annotations__', '__builtins__', '__call__', '__class__', '__closure__', '__code__', '__defaults__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__get__', '__getattribute__', '__getstate__', '__globals__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__kwdefaults__', '__le__', '__lt__', '__module__', '__name__', '__ne__', '__new__', '__qualname__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__type_params__']
|
||||
|
||||
inerz.__doc__
|
||||
'Модель устройства с памятью:\nx- текущее значение вх.сигнала,\nT -постоянная времени,\nypred - предыдущее значение выхода устройства'
|
||||
|
||||
help(inerz)
|
||||
Help on function inerz in module __main__:
|
||||
|
||||
inerz(x, T, ypred)
|
||||
Модель устройства с памятью:
|
||||
x- текущее значение вх.сигнала,
|
||||
T -постоянная времени,
|
||||
ypred - предыдущее значение выхода устройства
|
||||
```
|
||||
|
||||
## 3.2 Сохранение ссылки на объект-функции в другой переменной
|
||||
|
||||
```py
|
||||
fnkt=sravnenie
|
||||
v=16
|
||||
fnkt(v,23)
|
||||
16 меньше 23
|
||||
```
|
||||
Выполнена операция присваивания функции переменной, а затем вызов функции через эту переменную
|
||||
|
||||
## 3.3 Возможность альтернативного определения функции в программе
|
||||
|
||||
```py
|
||||
typ_fun=8
|
||||
if typ_fun==1:
|
||||
def func():
|
||||
print('Функция 1')
|
||||
else:
|
||||
def func():
|
||||
print('Функция 2')
|
||||
func()
|
||||
Функция 2
|
||||
```
|
||||
|
||||
Условие typ_fun == 1 ложно, поэтому определяется и вызывается функция из блока else
|
||||
|
||||
# 4. Аргументы функции
|
||||
|
||||
## 4.1 Возможность использования функции в качестве аргумента другой функции
|
||||
|
||||
```py
|
||||
def fun_arg(fff,a,b,c):
|
||||
"""fff-имя функции, используемой
|
||||
в качестве аргумента функции fun_arg"""
|
||||
return a+fff(c,b)
|
||||
|
||||
zz=fun_arg(logistfun,-3,1,0.7)
|
||||
zz
|
||||
-2.3318122278318336
|
||||
```
|
||||
Функция fun_arg принимает другую функцию как аргумент (fff) и использует её в своих вычислениях
|
||||
|
||||
## 4.2 Обязательные и необязательные аргументы
|
||||
```py
|
||||
def logistfun(a,b=1): #Аргумент b – необязательный; значение по умолчанию=1
|
||||
"""Вычисление логистической функции"""
|
||||
import math
|
||||
return b/(1+math.exp(-a))
|
||||
|
||||
logistfun(0.7) #Вычисление со значением b по умолчанию
|
||||
0.6681877721681662
|
||||
|
||||
logistfun(0.7,2) #Вычисление с заданным значением b
|
||||
1.3363755443363323
|
||||
```
|
||||
|
||||
|
||||
## 4.3 Возможность обращения к функции с произвольным (непозиционным) расположением аргументов.
|
||||
При этом надо в обращении к функции указывать имена аргументов.
|
||||
```py
|
||||
logistfun(b=0.5,a=0.8) # Ссылки на аргументы поменялись местами
|
||||
0.34498724056380625
|
||||
```
|
||||
используются именованные аргументы
|
||||
|
||||
## 4.4 Пример со значениями аргументов функции, содержащимися в списке или кортеже
|
||||
```py
|
||||
b1234=[b1,b2,b3,b4] # Список списков из п.2.4
|
||||
qq=slozh(*b1234) #Перед ссылкой на список или кортеж надо ставить звездочку
|
||||
qq
|
||||
[1, 2, -1, -2, 0, 2, -1, -1]
|
||||
```
|
||||
|
||||
## 4.5 Пример со значениями аргументов функции, содержащимися в словаре
|
||||
|
||||
```py
|
||||
dic4={"a1":1,"a2":2,"a3":3,"a4":4}
|
||||
qqq=slozh(**dic4) #Перед ссылкой на словарь надо ставить две звездочки
|
||||
qqq
|
||||
10
|
||||
```
|
||||
|
||||
## 4.6 Смешанные ссылки
|
||||
|
||||
```py
|
||||
e1=(-1,6);dd2={'a3':3,'a4':9}
|
||||
qqqq=slozh(*e1,**dd2)
|
||||
qqqq #-1 + 6 + 3 + 9 = 17
|
||||
17
|
||||
```
|
||||
|
||||
## 4.7 Переменное число аргументов у функции
|
||||
|
||||
```py
|
||||
def func4(*kort7):
|
||||
"""Произвольное число аргументов в составе кортежа"""
|
||||
smm=0
|
||||
for elt in kort7:
|
||||
smm+=elt
|
||||
return smm
|
||||
|
||||
func4(-1,2) #Обращение к функции с 2 аргументами
|
||||
1
|
||||
func4(-1,2,0,3,6) #Обращение к функции с 5 аргументами
|
||||
10
|
||||
```
|
||||
a = -1 (первый позиционный)
|
||||
b = 2 (второй позиционный, переопределил значение по умолчанию 7)
|
||||
*kort7 = (0, 3, 6) (все остальные аргументы в кортеж)
|
||||
|
||||
Подобным же образом в списке аргументов функции также можно использовать словарь, предварив его имя двумя звездочками
|
||||
|
||||
```py
|
||||
def func5(a,b=7,**dict):
|
||||
"""Словарь"""
|
||||
smm=0
|
||||
smm = sum (dict.values())
|
||||
return a*smm+b
|
||||
|
||||
func5(-1,2,aa=0,bb=3,cc=6)
|
||||
-7
|
||||
```
|
||||
## 4.9 Изменение значений объектов, используемых в качестве аргументов функции.
|
||||
Такое изменение возможно только у объектов изменяемого типа
|
||||
```py
|
||||
a=90
|
||||
def func3(b):
|
||||
b=5*b+67
|
||||
func3(a)
|
||||
a
|
||||
```
|
||||
значение переменной а не поменялось
|
||||
|
||||
Пример со списком:
|
||||
|
||||
```py
|
||||
def func2(sps):
|
||||
sps[1]=99
|
||||
|
||||
func2(sps1) # передаем ссылку на список
|
||||
print(sps1)
|
||||
|
||||
[1, 99, 3, 4]
|
||||
```
|
||||
Изменяемые типы (списки, словари, множества) передаются по ссылке
|
||||
|
||||
Пример с кортежем:
|
||||
|
||||
```py
|
||||
kort=(1,2,3,4)
|
||||
func2(kort)
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#138>", line 1, in <module>
|
||||
func2(kort)
|
||||
File "<pyshell#134>", line 2, in func2
|
||||
sps[1]=99
|
||||
TypeError: 'tuple' object does not support item assignment
|
||||
```
|
||||
|
||||
# 5. Специальные типы пользовательских функций
|
||||
|
||||
## 5.1 Анонимные функции
|
||||
|
||||
Анонимные функции или по-другому их называют лямбда-функциями – это функции без имени, определяемые по следующей схеме:
|
||||
lambda [<Аргумент1>[,<Аргумент2>,…]]:<Возвращаемое значение или выражение>
|
||||
Анонимная функция возвращает ссылку на объект-функцию, которую можно присвоить другому объекту.
|
||||
|
||||
```py
|
||||
import math
|
||||
anfun1=lambda: 1.5+math.log10(17.23) #Анонимная функция без аргументов
|
||||
anfun1() # Обращение к объекту-функции
|
||||
2.7362852774480286
|
||||
|
||||
anfun2=lambda a,b : a+math.log10(b) #Анонимная функция с 2 аргументами
|
||||
anfun2(17,234)
|
||||
19.369215857410143
|
||||
|
||||
anfun3=lambda a,b=234: a+math.log10(b) #Функция с необязательным вторым аргументом
|
||||
anfun3(100)
|
||||
102.36921585741014
|
||||
```
|
||||
|
||||
## 5.2 Функции-генераторы
|
||||
|
||||
Это – такие функции, которые используются в итерационных процессах, позволяя на каждой итерации получать одно из значений. Для этого в функцию включают инструкцию yield приостанавливающую её выполнение и возвращающую очередное значение.
|
||||
Данный оператор в отличие от return не останавливает полностью выполнение программы. Когда выполнение функции возобновляется после yield, оно продолжается с того места, где было приостановлено, до следующего оператора yield (или до конца функции).
|
||||
```py
|
||||
def func5(diap,shag):
|
||||
""" Итератор, возвращающий значения
|
||||
из диапазона от 1 до diap с шагом shag"""
|
||||
for j in range(1,diap+1,shag):
|
||||
yield j
|
||||
for mm in func5(7,3):
|
||||
print(mm)
|
||||
|
||||
1
|
||||
4
|
||||
7
|
||||
|
||||
alp=func5(7,3)
|
||||
print(alp.__next__())
|
||||
1
|
||||
print(alp.__next__())
|
||||
4
|
||||
print(alp.__next__())
|
||||
7
|
||||
print(alp.__next__())
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#158>", line 1, in <module>
|
||||
print(alp.__next__())
|
||||
StopIteration
|
||||
```
|
||||
Генераторы "запоминают" своё состояние, но когда значения заканчиваются, они сигнализируют об этом через исключение StopIteration
|
||||
func5 с yield идеально подходит для обработки больших диапазонов без нагрузки на память
|
||||
|
||||
# 6. Локализация объектов в функциях
|
||||
|
||||
По отношению к функции все объекты подразделяются на локальные и глобальные. Локальными являются объекты, которые создаются в функциях присваиванием им некоторых значений. Глобальные – это те объекты, значения которых заданы вне функции.
|
||||
Локализация может быть переопределена путем прямого объявления объектов как глобальных с помощью дескриптора global.
|
||||
|
||||
## 6.1 Примеры на локализацию объектов
|
||||
|
||||
Пример 1. Одноименные локальный и глобальный объекты:
|
||||
|
||||
```py
|
||||
glb=10
|
||||
def func7(arg):
|
||||
loc1=15
|
||||
glb=8
|
||||
return loc1*arg
|
||||
|
||||
res=func7(glb)
|
||||
res
|
||||
150
|
||||
glb
|
||||
10
|
||||
```
|
||||
В функции использовалась глобальная переменная glb и локальная переменная loc1
|
||||
Глобальная переменная glb не поменялась
|
||||
|
||||
Пример 2. Ошибка в использовании локального объекта.
|
||||
|
||||
```py
|
||||
def func8(arg):
|
||||
loc1=15
|
||||
print(glb)
|
||||
glb=8
|
||||
return loc1*arg
|
||||
|
||||
res=func8(glb)
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#165>", line 1, in <module>
|
||||
res=func8(glb)
|
||||
File "<pyshell#164>", line 3, in func8
|
||||
print(glb)
|
||||
UnboundLocalError: cannot access local variable 'glb' where it is not associated with a value
|
||||
```
|
||||
Ошибка произошла потому что при выполнении print(glb) интерпретатор пытается найти локальную glb, но локальная glb еще не определена (определение на следующей строке)
|
||||
|
||||
Пример 3. Переопределение локализации объекта.
|
||||
|
||||
```py
|
||||
glb=11
|
||||
def func7(arg):
|
||||
loc1=15
|
||||
global glb
|
||||
print(glb)
|
||||
glb=8
|
||||
return loc1*arg
|
||||
|
||||
|
||||
res=func7(glb)
|
||||
11
|
||||
glb
|
||||
8
|
||||
```
|
||||
|
||||
Здесь мы прямо объявили переменную glb как глобальную, поэтому она изменилась
|
||||
|
||||
## 6.2 Выявление локализации объекта с помощью функций locals() и globals() из builtins
|
||||
|
||||
Эти функции возвращают словари, ключами в которых будут имена объектов, являющихся, соответственно, локальными или глобальными на уровне вызова этих функций.
|
||||
|
||||
```py
|
||||
globals().keys() #Перечень глобальных объектов
|
||||
globals().keys()
|
||||
dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', 'os', 'uspeh', 'n', 'm', 'sravnenie', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'kort1', 'kort2', 'kort3', 'kort4', 'dict1', 'dict2', 'dict3', 'dict4', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'plt', 'fnkt', 'typ_fun', 'func', 'fun_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'func5', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'mm', 'alp', 'glb', 'func7', 'res', 'func8'])
|
||||
|
||||
locals().keys() #Перечень локальных объектов
|
||||
dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', 'os', 'uspeh', 'n', 'm', 'sravnenie', 'logistfun', 'v', 'w', 'z', 'slozh', 'b1', 'b2', 'b3', 'b4', 'q', 'kort1', 'kort2', 'kort3', 'kort4', 'dict1', 'dict2', 'dict3', 'dict4', 'inerz', 'sps', 'spsy', 'TT', 'yy', 'xx', 'plt', 'fnkt', 'typ_fun', 'func', 'fun_arg', 'zz', 'b1234', 'qq', 'dic4', 'qqq', 'e1', 'dd2', 'qqqq', 'func4', 'func5', 'a', 'func3', 'sps1', 'func2', 'kort', 'anfun1', 'math', 'anfun2', 'anfun3', 'mm', 'alp', 'glb', 'func7', 'res', 'func8'])
|
||||
```
|
||||
Различий нет, потому что команды выполнены в глобальной области видимости, где globals() и locals() ссылаются на один и тот же словарь. Различия появляются только при вызове locals() внутри функций или методов.
|
||||
|
||||
```py
|
||||
def func8(arg):
|
||||
loc1=15
|
||||
glb=8
|
||||
print(globals().keys()) #Перечень глобальных объектов «изнутри» функции
|
||||
print(locals().keys()) #Перечень локальных объектов «изнутри» функции
|
||||
return loc1*arg
|
||||
|
||||
hh=func8(glb)
|
||||
dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', '__file__', 'func8', 'glb'])# Глобальное glb
|
||||
dict_keys(['arg', 'loc1', 'glb'])# Локальное glb
|
||||
|
||||
'glb' in globals().keys()
|
||||
True
|
||||
```
|
||||
locals() внутри функции показывает только её внутренние переменные, а globals() показывает все объекты модуля.
|
||||
|
||||
## 6.3 Локализация объектов при использовании вложенных функций
|
||||
|
||||
```py
|
||||
def func9(arg2,arg3):
|
||||
def func9_1(arg1):
|
||||
loc1=15
|
||||
glb1=8
|
||||
print('glob_func9_1:',globals().keys())
|
||||
print('locl_func9_1:',locals().keys())
|
||||
return loc1*arg1
|
||||
loc1=5
|
||||
glb=func9_1(loc1)
|
||||
print('loc_func9:',locals().keys())
|
||||
print('glob_func9:',globals().keys())
|
||||
return arg2+arg3*glb
|
||||
|
||||
kk=func9(10,1)
|
||||
glob_func9_1: dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', '__file__', 'func9'])
|
||||
locl_func9_1: dict_keys(['arg1', 'loc1', 'glb1'])
|
||||
loc_func9: dict_keys(['arg2', 'arg3', 'func9_1', 'loc1', 'glb'])
|
||||
glob_func9: dict_keys(['__name__', '__doc__', '__package__', '__loader__', '__spec__', '__annotations__', '__builtins__', '__file__', 'func9'])
|
||||
```
|
||||
Вложенная функция может использовать переменные внешней функции, но только если они явно переданы как аргументы
|
||||
|
||||
## 6.4 Моделирование системы
|
||||
|
||||
Моделирование системы, состоящей из последовательного соединения реального двигателя, охваченного отрицательной обратной связью с тахогенератором в ней, и нелинейного звена типа «зона нечувствительности», при подаче на неё синусоидального входного сигнала.
|
||||
Реальный двигатель: последовательное соединение усилителя с коэффициентом усиления k1,интегратора: y(t)=x(t)+y(t-1), и инерционного звена: y(t)=(x(t)+T*y(t-1)) / (T+1) с постоянной времени Т.
|
||||
Тахогенератор: последовательное соединение усилителя с коэффициентом усиления k2 и интегратора: y(t)=x(t)+y(t-1).
|
||||
Нелинейное звено типа «зона нечувствительности»: y=0 при -xm≤ x ≤xm, y=x-xm при x>xm, y=x+xm при x<-xm.
|
||||
Таким образом, система характеризуется параметрами: k1, T, k2, xm. Входной сигнал характеризуется параметрами: A (амплитуда синусоиды) и F (период синусоиды).
|
||||
Еще один параметр задачи : N – время (число тактов) подачи сигнала.
|
||||
|
||||
```py
|
||||
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))
|
||||
print(vhod)
|
||||
[0.0, 0.6038955602659801, 1.1830675653399556, 1.713804645284377, 2.17437836168736, 2.5459327724842526, 2.813256396441241, 2.9654049729843344, 2.9961495215131584, 2.904231356598613]```
|
||||

|
||||
|
||||
Создание функций реализующие компоненты системы
|
||||
|
||||
```py
|
||||
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
|
||||
```
|
||||
Реализуем соединение компонент в соответствии с заданием
|
||||
|
||||
```py
|
||||
yi1=0;yin1=0;yi2=0
|
||||
vyhod=[]
|
||||
for xt in vhod:
|
||||
xt1=xt-yi2 #отрицательная обратная связь
|
||||
[yi1,yin1]=realdvig(xt1,k1,T,yi1,yin1)
|
||||
yi2=tahogen(yin1,k2,yi2)
|
||||
yt=nechus(yin1,Xm)
|
||||
vyhod.append(yt)
|
||||
print('y=',vyhod)
|
||||
|
||||
y= [0.0, 0.0575138628824743, 0.19757451809698162, 0.37271445071909315, 0.44764431066344834, 0.24935818305562138, -0.3024162461562951, -1.0323481238173855, -1.4374313649904746, -0.8573979371237693]
|
||||
```
|
||||
# 7. Завершение сеанса работы с IDLE
|
||||
@@ -1,84 +0,0 @@
|
||||
# Общее контрольное задание по теме 7
|
||||
Соловьёва Екатерина, А-01-23
|
||||
|
||||
## Задание
|
||||
* Разработайте и проверьте функцию, реализующую для момента времени t расчет выхода y(t) для устройства задержки: на вход поступает сигнал, а на выходе повторяется этот сигнал с задержкой на заданное время Т.
|
||||
* Разработайте и проверьте функцию, реализующую расчет гистограммы по выборке случайной величины с каким-то распределением. Гистограмма при выводе на экран представляется в виде таблицы: границы интервала, число элементов выборки в интервале. Аргументы функции: выборка, число интервалов разбиения диапазона изменения случайной величины. Возвращаемый результат функции: список с числами элементов выборки в интервалах разбиения.
|
||||
* Разработайте и проверьте анонимную функцию, вычисляющую значение оценки отклика Y линейной регрессии при значении переменной Х
|
||||
Y=b1+b2*X
|
||||
и имеющую аргументы b1, b2 и X.
|
||||
|
||||
## Решение
|
||||
# 1.
|
||||
```py
|
||||
def del_signal (signal, T):
|
||||
'''Расчет выхода y(t) для устройства задержки'''
|
||||
output = []
|
||||
for i in range(len(signal)):
|
||||
if i<T:
|
||||
output.append(0)
|
||||
else:
|
||||
output.append(signal[i-T])
|
||||
return output
|
||||
|
||||
x=[1,0.5,3.6,4.5,1,2,0.5]
|
||||
y = del_signal(x,2)
|
||||
print(y)
|
||||
[0, 0, 1, 0.5, 3.6, 4.5, 1]
|
||||
```
|
||||
# 2.
|
||||
```py
|
||||
import random
|
||||
import matplotlib.pyplot as plt
|
||||
|
||||
def histogram(sample, number):
|
||||
min_1 = min(sample)
|
||||
max_1 = max(sample)
|
||||
bins = (max_1 - min_1) / number # Ширина одного интервала
|
||||
rows = [0] * number # Создание списка для подсчёта элементов в каждом интервале
|
||||
intervals = [] # Список для хранения границ интервалов
|
||||
|
||||
for i in range(number):
|
||||
lower = min_1 + i * bins
|
||||
upper = min_1 + (i + 1) * bins
|
||||
intervals.append((lower, upper))
|
||||
|
||||
for x in sample:
|
||||
i = int((x - min_1) / bins) # Вычисление номера интервала для текущего элемента
|
||||
if i == number:
|
||||
i = number - 1
|
||||
rows[i] += 1
|
||||
|
||||
print("Границы интервала | Число элементов")
|
||||
for i in range(number):
|
||||
lower, upper = intervals[i]
|
||||
print(lower, "-", upper, " |", rows[i])
|
||||
|
||||
plt.hist(sample, number)
|
||||
plt.xlabel('Значения выборки')
|
||||
plt.ylabel('Число элементов')
|
||||
plt.title('Гистограмма выборки')
|
||||
plt.show()
|
||||
|
||||
return rows
|
||||
|
||||
data = [random.gauss(1, 20) for _ in range(10)]
|
||||
histogram(data, 3)
|
||||
Границы интервала | Число элементов
|
||||
-41.93512946278788 - -17.371680704583262 | 1
|
||||
-17.371680704583262 - 7.191768053621352 | 3
|
||||
7.191768053621352 - 31.755216811825967 | 6
|
||||
```
|
||||
# 3.
|
||||
```py
|
||||
linreg = lambda b1, b2, x: b1 + b2 * x
|
||||
b1 = float(input("Введите коэффициент b1 линейной регрессии: "))
|
||||
b2 = float(input("Введите коэффициент b2 линейной регрессии: "))
|
||||
x_val = float(input("Введите значение x: "))
|
||||
print(linreg(b1, b2, x_val))
|
||||
|
||||
Введите коэффициент b1 линейной регрессии: 3
|
||||
Введите коэффициент b2 линейной регрессии: 4
|
||||
Введите значение x: 5
|
||||
23.0
|
||||
```
|
||||
357
TEMA7/test.md
357
TEMA7/test.md
@@ -1,357 +0,0 @@
|
||||
# Индивидуальное контрольное задание по теме 7
|
||||
|
||||
Соловьёва Екатерина, А-01-23
|
||||
|
||||
## Задание
|
||||
|
||||
Разработайте функцию с 3 аргументами: x, А и В, реализующую преобразование входного сигнала x по формуле:
|
||||
$y=B$, если $x>A$;
|
||||
$y= 2B\frac{x}{A}-B x^2 / A^2$ , если 0≤ x ≤ А;
|
||||
$y= 2B * x/A +B*x^2 /A^2$ , если $-A≤ x <0;$
|
||||
$y=-B$, если $x< -A$.
|
||||
Создайте список со 100 значениями входного сигнала х – случайными, равномерно распределенными числами в диапазоне значений от -5 до 12. Для элементов списка с помощью функции рассчитайте список со значениями выходного сигнала y при трех разных парах значений А и В. Записать результаты в текстовый файл в виде двух столбцов: $хi, yi$.
|
||||
|
||||
## Решение
|
||||
|
||||
```py
|
||||
import random
|
||||
|
||||
def func(x, A, B):
|
||||
if x > A:
|
||||
return B
|
||||
elif 0 <= x <= A:
|
||||
return (2 * B * x / A) - (B * x**2 / A**2)
|
||||
elif -A <= x < 0:
|
||||
return (2 * B * x / A) + (B * x**2 / A**2)
|
||||
else:
|
||||
return -B
|
||||
|
||||
x_values = [random.uniform(-5, 12) for _ in range(100)]
|
||||
|
||||
params = [(5, 7), (3, 4), (8, 12)]
|
||||
|
||||
with open('test.txt', 'w', encoding='utf-8') as f:
|
||||
for A, B in params:
|
||||
f.write(f'\nПараметры: A = {A}, B = {B}\n')
|
||||
f.write('xi yi\n')
|
||||
f.write('----------------\n')
|
||||
|
||||
for x in x_values:
|
||||
y = func(x, A, B)
|
||||
f.write(f'{x:10.5f} {y:10.5f}\n')
|
||||
```
|
||||
|
||||
## Вывод
|
||||
```txt
|
||||
Параметры: A = 5, B = 7
|
||||
xi yi
|
||||
----------------
|
||||
5.86982 7.00000
|
||||
10.60889 7.00000
|
||||
4.06461 6.75501
|
||||
5.29288 7.00000
|
||||
10.15479 7.00000
|
||||
3.86484 6.63920
|
||||
0.47680 1.27140
|
||||
-1.27013 -3.10467
|
||||
-1.24129 -3.04419
|
||||
-1.03170 -2.59073
|
||||
-1.50325 -3.57637
|
||||
6.95909 7.00000
|
||||
1.03174 2.59082
|
||||
1.91432 4.33400
|
||||
6.86539 7.00000
|
||||
10.89394 7.00000
|
||||
3.61242 6.46090
|
||||
7.85303 7.00000
|
||||
-4.35477 -6.88343
|
||||
-1.10787 -2.75836
|
||||
8.88241 7.00000
|
||||
-3.41076 -6.29281
|
||||
2.60220 5.39016
|
||||
5.28102 7.00000
|
||||
-4.78747 -6.98735
|
||||
-1.71943 -3.98660
|
||||
6.26656 7.00000
|
||||
10.65755 7.00000
|
||||
-2.27517 -4.92108
|
||||
9.47499 7.00000
|
||||
-0.31369 -0.85077
|
||||
7.62057 7.00000
|
||||
6.96683 7.00000
|
||||
8.14176 7.00000
|
||||
11.97237 7.00000
|
||||
10.89297 7.00000
|
||||
2.48892 5.23446
|
||||
6.69740 7.00000
|
||||
-4.11167 -6.77904
|
||||
4.94378 6.99912
|
||||
-4.48180 -6.92481
|
||||
7.27224 7.00000
|
||||
-0.83065 -2.13263
|
||||
1.01590 2.55555
|
||||
6.91175 7.00000
|
||||
10.08303 7.00000
|
||||
3.60696 6.45664
|
||||
0.72761 1.88906
|
||||
2.82893 5.68021
|
||||
7.15816 7.00000
|
||||
6.46978 7.00000
|
||||
3.33574 6.22447
|
||||
7.04571 7.00000
|
||||
2.60493 5.39382
|
||||
6.93663 7.00000
|
||||
2.92556 5.79507
|
||||
10.45675 7.00000
|
||||
9.22932 7.00000
|
||||
7.40673 7.00000
|
||||
1.40836 3.38804
|
||||
11.95106 7.00000
|
||||
-3.11935 -6.00968
|
||||
6.61976 7.00000
|
||||
-1.59679 -3.75709
|
||||
2.39406 5.09855
|
||||
8.98971 7.00000
|
||||
2.01005 4.49685
|
||||
-1.42513 -3.42169
|
||||
1.91515 4.33544
|
||||
4.75207 6.98279
|
||||
-3.22786 -6.12067
|
||||
2.18031 4.77382
|
||||
6.95316 7.00000
|
||||
-3.92956 -6.67917
|
||||
-1.97791 -4.44276
|
||||
7.95253 7.00000
|
||||
9.86943 7.00000
|
||||
-3.45314 -6.33002
|
||||
2.13008 4.69379
|
||||
-1.21212 -2.98255
|
||||
8.50756 7.00000
|
||||
1.85195 4.22513
|
||||
3.75620 6.56683
|
||||
4.47003 6.92136
|
||||
11.09999 7.00000
|
||||
-1.70654 -3.96287
|
||||
11.73001 7.00000
|
||||
1.90609 4.31977
|
||||
-2.36144 -5.05063
|
||||
0.04914 0.13690
|
||||
3.82695 6.61471
|
||||
6.12422 7.00000
|
||||
2.32662 4.99884
|
||||
9.35261 7.00000
|
||||
8.06504 7.00000
|
||||
2.97498 5.85181
|
||||
4.38768 6.89502
|
||||
4.20153 6.82148
|
||||
4.19242 6.81739
|
||||
-4.63619 -6.96294
|
||||
|
||||
Параметры: A = 3, B = 4
|
||||
xi yi
|
||||
----------------
|
||||
5.86982 4.00000
|
||||
10.60889 4.00000
|
||||
4.06461 4.00000
|
||||
5.29288 4.00000
|
||||
10.15479 4.00000
|
||||
3.86484 4.00000
|
||||
0.47680 1.17044
|
||||
-1.27013 -2.67003
|
||||
-1.24129 -2.62531
|
||||
-1.03170 -2.27813
|
||||
-1.50325 -3.00433
|
||||
6.95909 4.00000
|
||||
1.03174 2.27821
|
||||
1.91432 3.47613
|
||||
6.86539 4.00000
|
||||
10.89394 4.00000
|
||||
3.61242 4.00000
|
||||
7.85303 4.00000
|
||||
-4.35477 -4.00000
|
||||
-1.10787 -2.40881
|
||||
8.88241 4.00000
|
||||
-3.41076 -4.00000
|
||||
2.60220 3.92967
|
||||
5.28102 4.00000
|
||||
-4.78747 -4.00000
|
||||
-1.71943 -3.27117
|
||||
6.26656 4.00000
|
||||
10.65755 4.00000
|
||||
-2.27517 -3.76650
|
||||
9.47499 4.00000
|
||||
-0.31369 -0.79276
|
||||
7.62057 4.00000
|
||||
6.96683 4.00000
|
||||
8.14176 4.00000
|
||||
11.97237 4.00000
|
||||
10.89297 4.00000
|
||||
2.48892 3.88391
|
||||
6.69740 4.00000
|
||||
-4.11167 -4.00000
|
||||
4.94378 4.00000
|
||||
-4.48180 -4.00000
|
||||
7.27224 4.00000
|
||||
-0.83065 -1.90841
|
||||
1.01590 2.25038
|
||||
6.91175 4.00000
|
||||
10.08303 4.00000
|
||||
3.60696 4.00000
|
||||
0.72761 1.70499
|
||||
2.82893 3.98699
|
||||
7.15816 4.00000
|
||||
6.46978 4.00000
|
||||
3.33574 4.00000
|
||||
7.04571 4.00000
|
||||
2.60493 3.93063
|
||||
6.93663 4.00000
|
||||
2.92556 3.99754
|
||||
10.45675 4.00000
|
||||
9.22932 4.00000
|
||||
7.40673 4.00000
|
||||
1.40836 2.87409
|
||||
11.95106 4.00000
|
||||
-3.11935 -4.00000
|
||||
6.61976 4.00000
|
||||
-1.59679 -3.12489
|
||||
2.39406 3.83682
|
||||
8.98971 4.00000
|
||||
2.01005 3.56444
|
||||
-1.42513 -2.89769
|
||||
1.91515 3.47693
|
||||
4.75207 4.00000
|
||||
-3.22786 -4.00000
|
||||
2.18031 3.70138
|
||||
6.95316 4.00000
|
||||
-3.92956 -4.00000
|
||||
-1.97791 -3.53571
|
||||
7.95253 4.00000
|
||||
9.86943 4.00000
|
||||
-3.45314 -4.00000
|
||||
2.13008 3.66366
|
||||
-1.21212 -2.57933
|
||||
8.50756 4.00000
|
||||
1.85195 3.41421
|
||||
3.75620 4.00000
|
||||
4.47003 4.00000
|
||||
11.09999 4.00000
|
||||
-1.70654 -3.25642
|
||||
11.73001 4.00000
|
||||
1.90609 3.46816
|
||||
-2.36144 -3.81877
|
||||
0.04914 0.12996
|
||||
3.82695 4.00000
|
||||
6.12422 4.00000
|
||||
2.32662 3.79847
|
||||
9.35261 4.00000
|
||||
8.06504 4.00000
|
||||
2.97498 3.99972
|
||||
4.38768 4.00000
|
||||
4.20153 4.00000
|
||||
4.19242 4.00000
|
||||
-4.63619 -4.00000
|
||||
|
||||
Параметры: A = 8, B = 12
|
||||
xi yi
|
||||
----------------
|
||||
5.86982 11.14919
|
||||
10.60889 12.00000
|
||||
4.06461 9.09613
|
||||
5.29288 10.62591
|
||||
10.15479 12.00000
|
||||
3.86484 8.79384
|
||||
0.47680 1.38779
|
||||
-1.27013 -3.50792
|
||||
-1.24129 -3.43498
|
||||
-1.03170 -2.89553
|
||||
-1.50325 -4.08605
|
||||
6.95909 11.79685
|
||||
1.03174 2.89564
|
||||
1.91432 5.05583
|
||||
6.86539 11.75862
|
||||
10.89394 12.00000
|
||||
3.61242 8.39047
|
||||
7.85303 11.99595
|
||||
-4.35477 -9.50856
|
||||
-1.10787 -3.09347
|
||||
8.88241 12.00000
|
||||
-3.41076 -8.05104
|
||||
2.60220 6.53696
|
||||
5.28102 10.61384
|
||||
-4.78747 -10.06493
|
||||
-1.71943 -4.60396
|
||||
6.26656 11.43660
|
||||
10.65755 12.00000
|
||||
-2.27517 -5.85493
|
||||
9.47499 12.00000
|
||||
-0.31369 -0.92261
|
||||
7.62057 11.97301
|
||||
6.96683 11.79985
|
||||
8.14176 12.00000
|
||||
11.97237 12.00000
|
||||
10.89297 12.00000
|
||||
2.48892 6.30526
|
||||
6.69740 11.68186
|
||||
-4.11167 -9.16516
|
||||
4.94378 10.24866
|
||||
-4.48180 -9.67917
|
||||
7.27224 11.90069
|
||||
-0.83065 -2.36258
|
||||
1.01590 2.85420
|
||||
6.91175 11.77795
|
||||
10.08303 12.00000
|
||||
3.60696 8.38148
|
||||
0.72761 2.08355
|
||||
2.82893 6.98626
|
||||
7.15816 11.86712
|
||||
6.46978 11.56096
|
||||
3.33574 7.92088
|
||||
7.04571 11.82925
|
||||
2.60493 6.54247
|
||||
6.93663 11.78798
|
||||
2.92556 7.17188
|
||||
10.45675 12.00000
|
||||
9.22932 12.00000
|
||||
7.40673 11.93401
|
||||
1.40836 3.85319
|
||||
11.95106 12.00000
|
||||
-3.11935 -7.53361
|
||||
6.61976 11.64280
|
||||
-1.59679 -4.31230
|
||||
2.39406 6.10753
|
||||
8.98971 12.00000
|
||||
2.01005 5.27259
|
||||
-1.42513 -3.89459
|
||||
1.91515 5.05774
|
||||
4.75207 10.02206
|
||||
-3.22786 -7.73000
|
||||
2.18031 5.64961
|
||||
6.95316 11.79452
|
||||
-3.92956 -8.89341
|
||||
-1.97791 -5.20021
|
||||
7.95253 11.99958
|
||||
9.86943 12.00000
|
||||
-3.45314 -8.12363
|
||||
2.13008 5.53950
|
||||
-1.21212 -3.36088
|
||||
8.50756 12.00000
|
||||
1.85195 4.91277
|
||||
3.75620 8.62315
|
||||
4.47003 9.66362
|
||||
11.09999 12.00000
|
||||
-1.70654 -4.57356
|
||||
11.73001 12.00000
|
||||
1.90609 5.03706
|
||||
-2.36144 -6.03873
|
||||
0.04914 0.14695
|
||||
3.82695 8.73482
|
||||
6.12422 11.34027
|
||||
2.32662 5.96488
|
||||
9.35261 12.00000
|
||||
8.06504 12.00000
|
||||
2.97498 7.26547
|
||||
4.38768 9.55333
|
||||
4.20153 9.29468
|
||||
4.19242 9.28168
|
||||
-4.63619 -9.87840
|
||||
```
|
||||
312
TEMA7/test.txt
312
TEMA7/test.txt
@@ -1,312 +0,0 @@
|
||||
|
||||
Параметры: A = 5, B = 7
|
||||
xi yi
|
||||
----------------
|
||||
5.86982 7.00000
|
||||
10.60889 7.00000
|
||||
4.06461 6.75501
|
||||
5.29288 7.00000
|
||||
10.15479 7.00000
|
||||
3.86484 6.63920
|
||||
0.47680 1.27140
|
||||
-1.27013 -3.10467
|
||||
-1.24129 -3.04419
|
||||
-1.03170 -2.59073
|
||||
-1.50325 -3.57637
|
||||
6.95909 7.00000
|
||||
1.03174 2.59082
|
||||
1.91432 4.33400
|
||||
6.86539 7.00000
|
||||
10.89394 7.00000
|
||||
3.61242 6.46090
|
||||
7.85303 7.00000
|
||||
-4.35477 -6.88343
|
||||
-1.10787 -2.75836
|
||||
8.88241 7.00000
|
||||
-3.41076 -6.29281
|
||||
2.60220 5.39016
|
||||
5.28102 7.00000
|
||||
-4.78747 -6.98735
|
||||
-1.71943 -3.98660
|
||||
6.26656 7.00000
|
||||
10.65755 7.00000
|
||||
-2.27517 -4.92108
|
||||
9.47499 7.00000
|
||||
-0.31369 -0.85077
|
||||
7.62057 7.00000
|
||||
6.96683 7.00000
|
||||
8.14176 7.00000
|
||||
11.97237 7.00000
|
||||
10.89297 7.00000
|
||||
2.48892 5.23446
|
||||
6.69740 7.00000
|
||||
-4.11167 -6.77904
|
||||
4.94378 6.99912
|
||||
-4.48180 -6.92481
|
||||
7.27224 7.00000
|
||||
-0.83065 -2.13263
|
||||
1.01590 2.55555
|
||||
6.91175 7.00000
|
||||
10.08303 7.00000
|
||||
3.60696 6.45664
|
||||
0.72761 1.88906
|
||||
2.82893 5.68021
|
||||
7.15816 7.00000
|
||||
6.46978 7.00000
|
||||
3.33574 6.22447
|
||||
7.04571 7.00000
|
||||
2.60493 5.39382
|
||||
6.93663 7.00000
|
||||
2.92556 5.79507
|
||||
10.45675 7.00000
|
||||
9.22932 7.00000
|
||||
7.40673 7.00000
|
||||
1.40836 3.38804
|
||||
11.95106 7.00000
|
||||
-3.11935 -6.00968
|
||||
6.61976 7.00000
|
||||
-1.59679 -3.75709
|
||||
2.39406 5.09855
|
||||
8.98971 7.00000
|
||||
2.01005 4.49685
|
||||
-1.42513 -3.42169
|
||||
1.91515 4.33544
|
||||
4.75207 6.98279
|
||||
-3.22786 -6.12067
|
||||
2.18031 4.77382
|
||||
6.95316 7.00000
|
||||
-3.92956 -6.67917
|
||||
-1.97791 -4.44276
|
||||
7.95253 7.00000
|
||||
9.86943 7.00000
|
||||
-3.45314 -6.33002
|
||||
2.13008 4.69379
|
||||
-1.21212 -2.98255
|
||||
8.50756 7.00000
|
||||
1.85195 4.22513
|
||||
3.75620 6.56683
|
||||
4.47003 6.92136
|
||||
11.09999 7.00000
|
||||
-1.70654 -3.96287
|
||||
11.73001 7.00000
|
||||
1.90609 4.31977
|
||||
-2.36144 -5.05063
|
||||
0.04914 0.13690
|
||||
3.82695 6.61471
|
||||
6.12422 7.00000
|
||||
2.32662 4.99884
|
||||
9.35261 7.00000
|
||||
8.06504 7.00000
|
||||
2.97498 5.85181
|
||||
4.38768 6.89502
|
||||
4.20153 6.82148
|
||||
4.19242 6.81739
|
||||
-4.63619 -6.96294
|
||||
|
||||
Параметры: A = 3, B = 4
|
||||
xi yi
|
||||
----------------
|
||||
5.86982 4.00000
|
||||
10.60889 4.00000
|
||||
4.06461 4.00000
|
||||
5.29288 4.00000
|
||||
10.15479 4.00000
|
||||
3.86484 4.00000
|
||||
0.47680 1.17044
|
||||
-1.27013 -2.67003
|
||||
-1.24129 -2.62531
|
||||
-1.03170 -2.27813
|
||||
-1.50325 -3.00433
|
||||
6.95909 4.00000
|
||||
1.03174 2.27821
|
||||
1.91432 3.47613
|
||||
6.86539 4.00000
|
||||
10.89394 4.00000
|
||||
3.61242 4.00000
|
||||
7.85303 4.00000
|
||||
-4.35477 -4.00000
|
||||
-1.10787 -2.40881
|
||||
8.88241 4.00000
|
||||
-3.41076 -4.00000
|
||||
2.60220 3.92967
|
||||
5.28102 4.00000
|
||||
-4.78747 -4.00000
|
||||
-1.71943 -3.27117
|
||||
6.26656 4.00000
|
||||
10.65755 4.00000
|
||||
-2.27517 -3.76650
|
||||
9.47499 4.00000
|
||||
-0.31369 -0.79276
|
||||
7.62057 4.00000
|
||||
6.96683 4.00000
|
||||
8.14176 4.00000
|
||||
11.97237 4.00000
|
||||
10.89297 4.00000
|
||||
2.48892 3.88391
|
||||
6.69740 4.00000
|
||||
-4.11167 -4.00000
|
||||
4.94378 4.00000
|
||||
-4.48180 -4.00000
|
||||
7.27224 4.00000
|
||||
-0.83065 -1.90841
|
||||
1.01590 2.25038
|
||||
6.91175 4.00000
|
||||
10.08303 4.00000
|
||||
3.60696 4.00000
|
||||
0.72761 1.70499
|
||||
2.82893 3.98699
|
||||
7.15816 4.00000
|
||||
6.46978 4.00000
|
||||
3.33574 4.00000
|
||||
7.04571 4.00000
|
||||
2.60493 3.93063
|
||||
6.93663 4.00000
|
||||
2.92556 3.99754
|
||||
10.45675 4.00000
|
||||
9.22932 4.00000
|
||||
7.40673 4.00000
|
||||
1.40836 2.87409
|
||||
11.95106 4.00000
|
||||
-3.11935 -4.00000
|
||||
6.61976 4.00000
|
||||
-1.59679 -3.12489
|
||||
2.39406 3.83682
|
||||
8.98971 4.00000
|
||||
2.01005 3.56444
|
||||
-1.42513 -2.89769
|
||||
1.91515 3.47693
|
||||
4.75207 4.00000
|
||||
-3.22786 -4.00000
|
||||
2.18031 3.70138
|
||||
6.95316 4.00000
|
||||
-3.92956 -4.00000
|
||||
-1.97791 -3.53571
|
||||
7.95253 4.00000
|
||||
9.86943 4.00000
|
||||
-3.45314 -4.00000
|
||||
2.13008 3.66366
|
||||
-1.21212 -2.57933
|
||||
8.50756 4.00000
|
||||
1.85195 3.41421
|
||||
3.75620 4.00000
|
||||
4.47003 4.00000
|
||||
11.09999 4.00000
|
||||
-1.70654 -3.25642
|
||||
11.73001 4.00000
|
||||
1.90609 3.46816
|
||||
-2.36144 -3.81877
|
||||
0.04914 0.12996
|
||||
3.82695 4.00000
|
||||
6.12422 4.00000
|
||||
2.32662 3.79847
|
||||
9.35261 4.00000
|
||||
8.06504 4.00000
|
||||
2.97498 3.99972
|
||||
4.38768 4.00000
|
||||
4.20153 4.00000
|
||||
4.19242 4.00000
|
||||
-4.63619 -4.00000
|
||||
|
||||
Параметры: A = 8, B = 12
|
||||
xi yi
|
||||
----------------
|
||||
5.86982 11.14919
|
||||
10.60889 12.00000
|
||||
4.06461 9.09613
|
||||
5.29288 10.62591
|
||||
10.15479 12.00000
|
||||
3.86484 8.79384
|
||||
0.47680 1.38779
|
||||
-1.27013 -3.50792
|
||||
-1.24129 -3.43498
|
||||
-1.03170 -2.89553
|
||||
-1.50325 -4.08605
|
||||
6.95909 11.79685
|
||||
1.03174 2.89564
|
||||
1.91432 5.05583
|
||||
6.86539 11.75862
|
||||
10.89394 12.00000
|
||||
3.61242 8.39047
|
||||
7.85303 11.99595
|
||||
-4.35477 -9.50856
|
||||
-1.10787 -3.09347
|
||||
8.88241 12.00000
|
||||
-3.41076 -8.05104
|
||||
2.60220 6.53696
|
||||
5.28102 10.61384
|
||||
-4.78747 -10.06493
|
||||
-1.71943 -4.60396
|
||||
6.26656 11.43660
|
||||
10.65755 12.00000
|
||||
-2.27517 -5.85493
|
||||
9.47499 12.00000
|
||||
-0.31369 -0.92261
|
||||
7.62057 11.97301
|
||||
6.96683 11.79985
|
||||
8.14176 12.00000
|
||||
11.97237 12.00000
|
||||
10.89297 12.00000
|
||||
2.48892 6.30526
|
||||
6.69740 11.68186
|
||||
-4.11167 -9.16516
|
||||
4.94378 10.24866
|
||||
-4.48180 -9.67917
|
||||
7.27224 11.90069
|
||||
-0.83065 -2.36258
|
||||
1.01590 2.85420
|
||||
6.91175 11.77795
|
||||
10.08303 12.00000
|
||||
3.60696 8.38148
|
||||
0.72761 2.08355
|
||||
2.82893 6.98626
|
||||
7.15816 11.86712
|
||||
6.46978 11.56096
|
||||
3.33574 7.92088
|
||||
7.04571 11.82925
|
||||
2.60493 6.54247
|
||||
6.93663 11.78798
|
||||
2.92556 7.17188
|
||||
10.45675 12.00000
|
||||
9.22932 12.00000
|
||||
7.40673 11.93401
|
||||
1.40836 3.85319
|
||||
11.95106 12.00000
|
||||
-3.11935 -7.53361
|
||||
6.61976 11.64280
|
||||
-1.59679 -4.31230
|
||||
2.39406 6.10753
|
||||
8.98971 12.00000
|
||||
2.01005 5.27259
|
||||
-1.42513 -3.89459
|
||||
1.91515 5.05774
|
||||
4.75207 10.02206
|
||||
-3.22786 -7.73000
|
||||
2.18031 5.64961
|
||||
6.95316 11.79452
|
||||
-3.92956 -8.89341
|
||||
-1.97791 -5.20021
|
||||
7.95253 11.99958
|
||||
9.86943 12.00000
|
||||
-3.45314 -8.12363
|
||||
2.13008 5.53950
|
||||
-1.21212 -3.36088
|
||||
8.50756 12.00000
|
||||
1.85195 4.91277
|
||||
3.75620 8.62315
|
||||
4.47003 9.66362
|
||||
11.09999 12.00000
|
||||
-1.70654 -4.57356
|
||||
11.73001 12.00000
|
||||
1.90609 5.03706
|
||||
-2.36144 -6.03873
|
||||
0.04914 0.14695
|
||||
3.82695 8.73482
|
||||
6.12422 11.34027
|
||||
2.32662 5.96488
|
||||
9.35261 12.00000
|
||||
8.06504 12.00000
|
||||
2.97498 7.26547
|
||||
4.38768 9.55333
|
||||
4.20153 9.29468
|
||||
4.19242 9.28168
|
||||
-4.63619 -9.87840
|
||||
@@ -1,26 +0,0 @@
|
||||
import random
|
||||
|
||||
def func(x, A, B):
|
||||
if x > A:
|
||||
return B
|
||||
elif 0 <= x <= A:
|
||||
return (2 * B * x / A) - (B * x**2 / A**2)
|
||||
elif -A <= x < 0:
|
||||
return (2 * B * x / A) + (B * x**2 / A**2)
|
||||
else:
|
||||
return -B
|
||||
|
||||
x_values = [random.uniform(-5, 12) for _ in range(100)]
|
||||
|
||||
params = [(5, 7), (3, 4), (8, 12)]
|
||||
|
||||
with open('test.txt', 'w', encoding='utf-8') as f:
|
||||
for A, B in params:
|
||||
f.write(f'\nПараметры: A = {A}, B = {B}\n')
|
||||
f.write('xi yi\n')
|
||||
f.write('----------------\n')
|
||||
|
||||
for x in x_values:
|
||||
y = func(x, A, B)
|
||||
f.write(f'{x:10.5f} {y:10.5f}\n')
|
||||
|
||||
Двоичные данные
TEMA7/Рис1.png
Двоичные данные
TEMA7/Рис1.png
Двоичный файл не отображается.
|
До Ширина: | Высота: | Размер: 15 KiB |
Двоичные данные
TEMA7/Рис2.png
Двоичные данные
TEMA7/Рис2.png
Двоичный файл не отображается.
|
До Ширина: | Высота: | Размер: 14 KiB |
@@ -1,3 +0,0 @@
|
||||
import MM2
|
||||
print('y=',MM2.vyhod)
|
||||
|
||||
22
TEMA8/MM1.py
22
TEMA8/MM1.py
@@ -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
|
||||
|
||||
25
TEMA8/MM2.py
25
TEMA8/MM2.py
@@ -1,25 +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,9 +1,2 @@
|
||||
def reading (file):
|
||||
nums = []
|
||||
with open(file, 'r') as file:
|
||||
for line in file:
|
||||
nums.extend(map(float, line.split()))
|
||||
return nums
|
||||
|
||||
|
||||
|
||||
perm1=input('Mod1:Введите значение = ')
|
||||
print('Mod1:Значение perm1=',perm1)
|
||||
|
||||
@@ -1,17 +1,11 @@
|
||||
def alpha():
|
||||
print('****ALPHA****')
|
||||
t=input('Значение t=')
|
||||
return t
|
||||
|
||||
def beta(q):
|
||||
print('****BETA****')
|
||||
import math
|
||||
|
||||
def correlation(list1, list2):
|
||||
n = min(len(list1), len(list2))
|
||||
if n < 2:
|
||||
return None
|
||||
|
||||
x, y = list1[:n], list2[:n]
|
||||
mean_x, mean_y = sum(x)/n, sum(y)/n
|
||||
|
||||
num = sum((x[i]-mean_x)*(y[i]-mean_y) for i in range(n))
|
||||
den = math.sqrt(sum((x[i]-mean_x)**2 for i in range(n)) *
|
||||
sum((y[i]-mean_y)**2 for i in range(n)))
|
||||
|
||||
return num/den if den != 0 else None
|
||||
|
||||
expi=q*math.pi
|
||||
return math.exp(expi)
|
||||
|
||||
|
||||
@@ -1,15 +0,0 @@
|
||||
from Mod1 import reading
|
||||
from Mod2 import correlation
|
||||
|
||||
file1 = input("Введите имя первого файла: ")
|
||||
file2 = input("Введите имя второго файла: ")
|
||||
|
||||
arr1 = reading(file1)
|
||||
arr2 = reading(file2)
|
||||
|
||||
if arr1 is None or arr2 is None:
|
||||
print("Не удалось считать данные из файлов.")
|
||||
else:
|
||||
corr = correlation(arr1, arr2)
|
||||
if corr is not None:
|
||||
print(f"Коэффициент корреляции: {corr:.2f}")
|
||||
@@ -1,2 +0,0 @@
|
||||
1.0 2.0 3.0 4.0 5.0
|
||||
6.0 7.0 8.0 9.0 10.0
|
||||
@@ -1,2 +0,0 @@
|
||||
10.0 9.5 9.0 8.5 8.0
|
||||
7.5 7.0 6.5 6.0 1.0
|
||||
@@ -1,18 +0,0 @@
|
||||
import math
|
||||
|
||||
f = lambda x, a, b, c, d: a / (1 + math.exp(-b - c * x - d * x**2))
|
||||
|
||||
def calc_and_save(a, b, c, d, filename="results.txt"):
|
||||
if a <= 0 or b <= 0 or c <= 0 or d <= 0:
|
||||
raise ValueError("Все параметры должны быть положительными")
|
||||
|
||||
xs = list(range(-20, 21, 2))
|
||||
values = [f(x, a, b, c, d) for x in xs]
|
||||
|
||||
with open(filename, "w", encoding="utf-8") as file:
|
||||
for i in range(0, len(values), 3):
|
||||
chunk = values[i:i+3]
|
||||
line = " ".join(f"{v:.6f}" for v in chunk)
|
||||
file.write(line + "\n")
|
||||
|
||||
return xs, values
|
||||
@@ -1,25 +0,0 @@
|
||||
from func_module import calc_and_save
|
||||
|
||||
def main():
|
||||
print("Ввод параметров a, b, c, d (положительные числа):")
|
||||
a = float(input("a = "))
|
||||
b = float(input("b = "))
|
||||
c = float(input("c = "))
|
||||
d = float(input("d = "))
|
||||
|
||||
if a <= 0 or b <= 0 or c <= 0 or d <= 0:
|
||||
print("Ошибка: все параметры должны быть положительными!")
|
||||
return
|
||||
|
||||
filename = input("Имя выходного файла (по умолчанию results.txt): ").strip()
|
||||
if not filename:
|
||||
filename = "results.txt"
|
||||
|
||||
try:
|
||||
calc_and_save(a, b, c, d, filename)
|
||||
print(f"Результаты записаны в файл {filename}")
|
||||
except Exception as e:
|
||||
print(f"Ошибка: {e}")
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
333
TEMA8/report.md
333
TEMA8/report.md
@@ -1,333 +0,0 @@
|
||||
# Отчёт по Теме 8
|
||||
|
||||
Соловьёва Екатерина, А-01-23
|
||||
|
||||
## 1. Запуск интерактивной оболочки IDLE.
|
||||
|
||||
Следует начинать сеанс работы с IDLE со следующих инструкций:
|
||||
|
||||
```py
|
||||
import sys, importlib #Импорт трёх важных вспомогательных модулей
|
||||
import os
|
||||
|
||||
os.chdir("C:\\Users\\Ekaterina\\OneDrive\\Desktop\\Solovyova\\python-labs\\TEMA8")
|
||||
os.getcwd() #Контролируем корректность установки текущего каталога
|
||||
'C:\\Users\\Ekaterina\\OneDrive\\Desktop\\Solovyova\\python-labs\\TEMA8'
|
||||
```
|
||||
Большие программы делятся на части-модули, записываемые в отдельные файлы. Это делается для удобства отладки, обеспечения возможности коллективной разработки, создания возможности повторного использования программ и по другим соображениям. При этом возникают 2 проблемы:
|
||||
|
||||
* передача управления от одного модуля к другому в процессе выполнения программы;
|
||||
|
||||
* передача данных между модулями.
|
||||
|
||||
Поэтому техника структурирования программ на любом языке программирования предусматривает изучение способов решения этих проблем.
|
||||
## 2. Создание и использование модулей в среде Python.
|
||||
Модулем в среде Python называется любая часть программного кода на этом языке, записанная в отдельном файле. В языке Python модули также являются объектами класса module.
|
||||
## 2.1. Запуск модуля на выполнение путем его импорта.
|
||||
Cодержимое модуля становится доступным для исполнения после выполнения процедуры импорта. После импорта модуль становится объектом в пространстве имен той части программы, где осуществлен импорт. Модуль получает имя или псевдоним, заданные в инструкции импорта, а также набор атрибутов. При этом появляется возможность использования всех приемов, применяемых при работе с модулями. В Python импорт является одним из важных способов решения проблемы передачи управления между модулями.
|
||||
|
||||
Файл с именем Mod1.py содержит:
|
||||
```py
|
||||
perm1=input('Mod1:Введите значение = ')
|
||||
print('Mod1:Значение perm1=',perm1)
|
||||
```
|
||||
Пока введенный или измененный текст в этом окне не сохранен в файле, в заголовке перед именем файла стоит символ «*» (звёздочка).
|
||||
Теперь вспомним возможность запуска модуля из командной строки оболочки IDLE.
|
||||
```py
|
||||
import Mod1
|
||||
Mod1:Введите значение = 5
|
||||
Mod1:Значение perm1= 5
|
||||
```
|
||||
При этом управление передается от модуля с именем main (это имя модуля – командной строки) к модулю Mod1, который ищется в файле с именем Mod1.py в рабочем каталоге. Если бы он находился в другом каталоге, то в инструкции импорта пришлось бы указать не только имя файла с модулем, но и его каталог.
|
||||
|
||||
После выполнения записанной в модуль программы (после ввода значения объекта perm1 и его отображения) управление возвращается вызывающему модулю, т.е. в данном случае, в командную строку. Объекты, созданные при выполнении модуля, становятся его атрибутами.
|
||||
```py
|
||||
type(Mod1)
|
||||
<class 'module'>
|
||||
|
||||
dir(Mod1)
|
||||
['__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'perm1']
|
||||
```
|
||||
Доступ к значению созданного в модуле объекта perm1 – атрибута модуля Mod1:
|
||||
```py
|
||||
Mod1.perm1
|
||||
'5'
|
||||
import Mod1
|
||||
```
|
||||
Повторно выполнить модуль с помощью инструкции импорта не выходит. Для повторного выполнения ранее импортированного модуля следует применить функцию reload из модуля imp:
|
||||
```py
|
||||
importlib.reload(Mod1)
|
||||
Mod1:Введите значение = 3
|
||||
Mod1:Значение perm1= 3
|
||||
<module 'Mod1' from 'C:\\Users\\Ekaterina\\OneDrive\\Desktop\\Solovyova\\python-labs\\TEMA8\\Mod1.py'>
|
||||
Mod1.perm1
|
||||
'3'
|
||||
```
|
||||
## 2.2. Словарь импортированных модулей
|
||||
```py
|
||||
print(sorted(sys.modules.keys()))
|
||||
['Mod1', '__future__', '__main__', '_abc', '_ast', '_bisect', '_bz2', '_codecs', '_collections', '_collections_abc', '_colorize', '_compat_pickle', '_compression', '_datetime', '_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', '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']
|
||||
```
|
||||
|
||||
Для обеспечения возможности повторного импорта и, следовательно, выполнения программы из модуля, его надо удалить из этого словаря:
|
||||
```py
|
||||
sys.modules.pop('Mod1')
|
||||
```
|
||||
Mod1 из него исчез повторите импорт и проверьте, что записанная в нем программа будет снова выполнена. После этого еще раз удалите Mod1 из словаря.
|
||||
|
||||
```py
|
||||
sys.modules.pop('Mod1')
|
||||
<module 'Mod1' from 'C:\\Users\\Ekaterina\\OneDrive\\Desktop\\Solovyova\\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', '_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', '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:Введите значение = 5
|
||||
Mod1:Значение perm1= 5
|
||||
Mod1.perm1
|
||||
'5'
|
||||
sys.modules.pop('Mod1')
|
||||
<module 'Mod1' from 'C:\\Users\\Ekaterina\\OneDrive\\Desktop\\Solovyova\\python-labs\\TEMA8\\Mod1.py'>
|
||||
```
|
||||
|
||||
## 2.3. Запуск модуля на выполнение с помощью функции exec().
|
||||
Запуск модуля на выполнение может быть произведен с использованием ранее изученной функции exec. При этом модуль не требуется импортировать. Функция exec действует так, как будто на месте обращения к ней в программу вставлен код из объекта-аргумента функции.
|
||||
Внимание: объект-модуль при этом не создается! Созданные при выполнении модуля объекты становятся объектами главной программы!
|
||||
```py
|
||||
exec(open('Mod1.py', encoding='utf-8').read())
|
||||
Mod1:Введите значение = 1
|
||||
Mod1:Значение perm1= 1
|
||||
exec(open('Mod1.py', encoding='utf-8').read())
|
||||
Mod1:Введите значение = 2
|
||||
Mod1:Значение perm1= 2
|
||||
exec(open('Mod1.py', encoding='utf-8').read())
|
||||
Mod1:Введите значение = 3
|
||||
Mod1:Значение perm1= 3
|
||||
```
|
||||
Эту функцию можно вызывать любое число раз и каждый раз будет выполняться программа из модуля.
|
||||
|
||||
## 2.4. Использование инструкции from … import …
|
||||
В одном модуле может содержаться несколько программных единиц (например, функций или пользовательских объектов). Тогда можно осуществлять импорт модуля не целиком, а только часть содержащихся в нем объектов.
|
||||
```py
|
||||
from Mod1 import perm1
|
||||
Mod1:Введите значение = 4
|
||||
Mod1:Значение perm1= 4
|
||||
'Mod1' in dir()
|
||||
True
|
||||
perm1
|
||||
'4'
|
||||
```
|
||||
Пример 2.
|
||||
|
||||
Mod2, содержащий две функции
|
||||
```py
|
||||
def alpha():
|
||||
print('****ALPHA****')
|
||||
t=input('Значение t=')
|
||||
return t
|
||||
|
||||
def beta(q):
|
||||
import math
|
||||
expi=q*math.pi
|
||||
return math.exp(expi)
|
||||
```
|
||||
|
||||
```py
|
||||
g=beta(2)
|
||||
****BETA****
|
||||
g
|
||||
535.4916555247646
|
||||
|
||||
print(sorted(sys.modules.keys()))
|
||||
['Mod2', '__future__', '__main__', '_abc', '_ast', '_bisect', '_bz2', '_codecs', '_collections', '_collections_abc', '_colorize', '_compat_pickle', '_compression', '_datetime', '_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', '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']
|
||||
```
|
||||
```py
|
||||
alpha() #Функция alpha не была импортирована
|
||||
Traceback (most recent call last):
|
||||
File "<stdin>", line 1, in <module>
|
||||
NameError: name 'alpha' is not defined
|
||||
|
||||
from Mod2 import alpha as al
|
||||
del al,beta
|
||||
|
||||
from Mod2 import alpha as al, beta as bt
|
||||
del al,beta
|
||||
|
||||
from Mod2 import *
|
||||
tt = alpha()
|
||||
|
||||
from Mod2 import *
|
||||
tt=alpha()
|
||||
****ALPHA****
|
||||
Значение t=0.12
|
||||
uu=beta(float(tt))
|
||||
****BETA****
|
||||
uu
|
||||
1.4578913609506803
|
||||
```
|
||||
|
||||
## 3. Создание многомодульных программ.
|
||||
## 3.1. Пример простой многомодульной программы.
|
||||
Модуль Mod0
|
||||
```py
|
||||
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)
|
||||
```
|
||||
|
||||
Этот модуль содержит программу, вызывающую на выполнение ранее созданные модули Mod1, Mod2. Теперь программа будет состоять из 5 частей: главная программа, которой является командная строка IDLE и из которой будет вызываться модуль Mod0, и 3 модуля, вызываемых из модуля Mod0.
|
||||
```py
|
||||
import Mod0
|
||||
Mod1:Введите значение = 1
|
||||
Mod1:Значение perm1= 1
|
||||
perm1= 1
|
||||
****ALPHA****
|
||||
Значение t=2
|
||||
tt= 2
|
||||
****BETA****
|
||||
qq= 535.4916555247646
|
||||
Mod0.tt;Mod0.qq;Mod0.Mod1.perm1
|
||||
'2'
|
||||
535.4916555247646
|
||||
'1'
|
||||
```
|
||||
## 3.2. Еще пример.
|
||||
|
||||
Файл MM0.py:
|
||||
```py
|
||||
import MM2
|
||||
print('y =', MM2.vyhod)
|
||||
```
|
||||
Файл MM1.py:
|
||||
```py
|
||||
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
|
||||
```
|
||||
Файл MM2.py:
|
||||
```py
|
||||
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)
|
||||
```
|
||||
|
||||
```py
|
||||
k1,T,k2,Xm,A,F,N=9,6,4,11,3,0.5,1500
|
||||
y = [0, 0, ... 0, -70.20177063675057, 0, 257.73311334096866, -677.4095530135962, ... -6.270038281034423e+306, -1.198995988522659e+307]
|
||||
```
|
||||
|
||||
|
||||
## 3.3. Области действия объектов в модулях.
|
||||
|
||||
В ранее созданных модулях вводятся и используются следующие объекты:
|
||||
|
||||
Mod1: perm1
|
||||
Mod2: функции alpha, beta; переменные t, expi
|
||||
Mod0: переменные tt,qq
|
||||
|
||||
|
||||
Попробую вставить в функции alpha обращение к функции beta и, наоборот, из beta – к alpha.
|
||||
```py
|
||||
def alpha():
|
||||
print("Alpha called")
|
||||
result_beta = beta(5) # вызов beta из alpha
|
||||
print("Beta returned:", result_beta)
|
||||
return "alpha_finished"
|
||||
|
||||
def beta(x):
|
||||
print("Beta called with", x)
|
||||
if x > 0:
|
||||
pass
|
||||
return x * 2
|
||||
```
|
||||
|
||||
Отобразить на экране в модуле Mod0 значения объектов t и expi:
|
||||
```py
|
||||
import Mod2
|
||||
print("t =", Mod2.t)
|
||||
print("expi =", Mod2.expi)
|
||||
t = 10
|
||||
expi = 2.718
|
||||
```
|
||||
|
||||
В модуле Mod0 увеличить в 3 раза значение
|
||||
объекта perm1 и отобразить его после этого на экране.
|
||||
|
||||
Так как perm1 имеет тип str, то умножение напрямую без преобразования типов
|
||||
будет выглядеть так:
|
||||
|
||||
```py
|
||||
print('perm1 = ', Mod1.perm1)
|
||||
print('Умножено:' , Mod1.perm1 * 3)
|
||||
Mod1: Введите значение = 4
|
||||
Mod1: Значение perm1 = 4
|
||||
perm1 = 4
|
||||
Умножено: 444
|
||||
```
|
||||
Преобразовав тип perm1, можно получить классическое умножение:
|
||||
```py
|
||||
print('Умножено:' , int(Mod1.perm1) * 3)
|
||||
...
|
||||
Mod1: Введите значение = 4
|
||||
Mod1: Значение perm1 = 4
|
||||
perm1 = 4
|
||||
Умножено: 12
|
||||
```
|
||||
В командной строке (в главном модуле) увеличить в 2 раза значения объектов perm1, tt, qq:
|
||||
```py
|
||||
Mod1.perm1 * 2
|
||||
'55'
|
||||
Mod0.tt * 2
|
||||
'44'
|
||||
Mod0.qq * 2
|
||||
573502.6262733063
|
||||
```
|
||||
|
||||
## 4. Окончание сеанса работы с IDLE.
|
||||
|
||||
|
||||
|
||||
@@ -1,7 +0,0 @@
|
||||
1.000000 1.000000 1.000000
|
||||
1.000000 1.000000 1.000000
|
||||
1.000000 1.000000 1.000000
|
||||
0.999994 0.880797 1.000000
|
||||
1.000000 1.000000 1.000000
|
||||
1.000000 1.000000 1.000000
|
||||
1.000000 1.000000 1.000000
|
||||
@@ -1,65 +0,0 @@
|
||||
# Общее контрольное задание по Теме 8
|
||||
Соловьёва Екатерина, А-01-23
|
||||
## Задание
|
||||
Общее контрольное задание.
|
||||
Разработайте программу, состоящую из трех модулей:
|
||||
* Модуль 1 содержит функцию считывания числового списка из текстового файла с заданным именем (аргумент функции – имя файла). Элементы в файле могут располагаться по несколько на строке с разделением пробелом. Числа элементов в строках могут быть разными. Полученный список должен возвращаться в вызывающую программу.
|
||||
* Модуль 2 содержит функцию расчета коэффициента корреляции по двум числовым спискам (аргументы функции – имена двух списков). Числа элементов в списках могут различаться. Значение коэффициента должно возвращаться в вызывающую программу.
|
||||
* Модуль 3 запрашивает у пользователя и вводит имена двух файлов с исходными данными, дважды вызывает функцию из модуля 1 и считывает два списка из двух текстовых файлов. Затем вызывает функцию расчета коэффициента корреляции с помощью функции из модуля 2 и отображает рассчитанное значение на экране с округлением до трех цифр после точки.
|
||||
Подготовьте два текстовых файла с числовыми данными и проверьте по ним работу программы.
|
||||
|
||||
## Решение
|
||||
Mod1
|
||||
```py
|
||||
def reading (file):
|
||||
nums = []
|
||||
with open(file, 'r') as file:
|
||||
for line in file:
|
||||
nums.extend(map(float, line.split()))
|
||||
return nums
|
||||
|
||||
```
|
||||
Mod2
|
||||
```py
|
||||
import math
|
||||
|
||||
def correlation(list1, list2):
|
||||
n = min(len(list1), len(list2))
|
||||
if n < 2:
|
||||
return None
|
||||
|
||||
x, y = list1[:n], list2[:n]
|
||||
mean_x, mean_y = sum(x)/n, sum(y)/n
|
||||
|
||||
num = sum((x[i]-mean_x)*(y[i]-mean_y) for i in range(n))
|
||||
den = math.sqrt(sum((x[i]-mean_x)**2 for i in range(n)) *
|
||||
sum((y[i]-mean_y)**2 for i in range(n)))
|
||||
|
||||
return num/den if den != 0 else None
|
||||
```
|
||||
Mod3
|
||||
```py
|
||||
from Mod1 import reading
|
||||
from Mod2 import correlation
|
||||
|
||||
file1 = input("Введите имя первого файла: ")
|
||||
file2 = input("Введите имя второго файла: ")
|
||||
|
||||
arr1 = reading(file1)
|
||||
arr2 = reading(file2)
|
||||
|
||||
if arr1 is None or arr2 is None:
|
||||
print("Не удалось считать данные из файлов.")
|
||||
else:
|
||||
corr = correlation(arr1, arr2)
|
||||
if corr is not None:
|
||||
print(f"Коэффициент корреляции: {corr:.2f}")
|
||||
```
|
||||
## Вывод
|
||||
```py
|
||||
=================================================== RESTART: C:/Users/Ekaterina/OneDrive/Desktop/Solovyova/python-labs/TEMA8/Mod3.py ===================================================
|
||||
Введите имя первого файла: data1.txt
|
||||
Введите имя второго файла: data2.txt
|
||||
Коэффициент корреляции: -0.88
|
||||
```
|
||||
|
||||
@@ -1,38 +0,0 @@
|
||||
class Employee:
|
||||
"""Класс для работы с данными сотрудников"""
|
||||
|
||||
def __init__(self, fio, otdel, dolzhnost, oklad):
|
||||
self.fio = fio
|
||||
self.otdel = otdel
|
||||
self.dolzhnost = dolzhnost
|
||||
self.oklad = oklad
|
||||
self.__pooshreniya = []
|
||||
|
||||
def povysit_oklad(self, summa_povysheniya):
|
||||
"""
|
||||
Метод для повышения оклада сотрудника на заданное значение """
|
||||
if summa_povysheniya <= 0:
|
||||
raise ValueError("Сумма повышения должна быть положительной!")
|
||||
self.oklad += summa_povysheniya
|
||||
return self.oklad
|
||||
|
||||
def perevesti_v_drugoi_otdel(self, novy_otdel):
|
||||
"""Перевод сотрудника в другой отдел"""
|
||||
self.otdel = novy_otdel
|
||||
print(f"Сотрудник {self.fio} переведен в отдел: {novy_otdel}")
|
||||
|
||||
def izmenit_dolzhnost(self, novaya_dolzhnost):
|
||||
"""Метод изменения должности"""
|
||||
self.dolzhnost = novaya_dolzhnost
|
||||
|
||||
@property
|
||||
def pooshreniya(self):
|
||||
return self.__pooshreniya.copy()
|
||||
|
||||
def dobavit_pooshrenie(self, text):
|
||||
"""Добавить поощрение в список"""
|
||||
self.__pooshreniya.append(text)
|
||||
|
||||
|
||||
|
||||
|
||||
Двоичные данные
TEMA9/Figure_1.png
Двоичные данные
TEMA9/Figure_1.png
Двоичный файл не отображается.
|
До Ширина: | Высота: | Размер: 14 KiB |
@@ -1,11 +0,0 @@
|
||||
class Class1: #Объявление класса Class1 в модуле
|
||||
def zad_zn(self,znach): # 1 Метод класса
|
||||
self.data=znach # self - ссылка на экземпляр класса Class1
|
||||
def otobrazh(self): # 2 Метод класса
|
||||
print(self.data)#Отображение данных экземпляра
|
||||
class Class2(Class1): #Class2 - наследник класса Class1
|
||||
def otobrazh(self): # Метод класса Class2
|
||||
print('значение=',self.data)#Отображение данных экземпляра
|
||||
def otobrazh(objekt): #Объявление самостоятельной функции
|
||||
print('значение объекта=',objekt)
|
||||
|
||||
21
TEMA9/SAU.py
21
TEMA9/SAU.py
@@ -1,21 +0,0 @@
|
||||
class SAU:
|
||||
def __init__(self,zn_param):
|
||||
self.param=zn_param
|
||||
self.ypr=[0,0]
|
||||
|
||||
def zdn_zn(self,upr):
|
||||
self.x=upr
|
||||
|
||||
def model(self):
|
||||
def inerz(x,T,yy):
|
||||
return (x+T*yy)/(T+1)
|
||||
|
||||
y0=self.x-self.ypr[1]*self.param[3] #Обр.связь с усилителем 2
|
||||
y1=self.param[0]*y0 #Усилитель1
|
||||
y2=inerz(y1,self.param[1],self.ypr[0]) #Инерционное звено1
|
||||
y3=inerz(y2,self.param[2],self.ypr[1]) #Инерционное звено2
|
||||
self.ypr[0]=y2
|
||||
self.ypr[1]=y3
|
||||
|
||||
def otobraz(self):
|
||||
print('y=',self.ypr[1])
|
||||
@@ -1,15 +0,0 @@
|
||||
###main_SAU
|
||||
prm=[2.5,4,1.3,0.8] #Параметры модели: коэф.усиления, 2 пост.времени, обратная связь
|
||||
from SAU import *
|
||||
xx=[0]+[1]*20 #Входной сигнал – «ступенька»
|
||||
SAUe=SAU(prm) # Создаём экземпляр класса
|
||||
yt=[]
|
||||
for xt in xx: # Прохождение входного сигнала
|
||||
SAUe.zdn_zn(xt)
|
||||
SAUe.model()
|
||||
SAUe.otobraz()
|
||||
yt.append(SAUe.ypr[1])
|
||||
import pylab
|
||||
pylab.plot(yt)
|
||||
pylab.show()
|
||||
|
||||
295
TEMA9/report.md
295
TEMA9/report.md
@@ -1,295 +0,0 @@
|
||||
# Отчёт по Теме 9
|
||||
|
||||
Соловьёва Екатерина. А-01-23
|
||||
|
||||
|
||||
|
||||
## 1. Запуск интерактивной оболочки IDLE.
|
||||
|
||||
## 2. Создание классов и их наследников
|
||||
|
||||
## 2.1. Создание автономного класса
|
||||
|
||||
Класс с именем Class1, содержащий 2 функции:
|
||||
|
||||
```py
|
||||
class Class1: #Объявление класса
|
||||
def zad_zn(self,znach): #Метод 1 класса1 – задание значения data
|
||||
self.data=znach # self - ссылка на экземпляр класса
|
||||
def otobrazh(self): # Метод 2 класса1
|
||||
print(self.data)#Отображение данных экземпляра класса
|
||||
|
||||
z1=Class1() #Создаём 1-й экземпляр класса
|
||||
z2=Class1() #Создаём 2-й экземпляр класса
|
||||
z1.zad_zn('экз.класса 1') #Обращение к методу класса у 1-го экз.
|
||||
z1
|
||||
<__main__.Class1 object at 0x00000244872A6660>
|
||||
z2.zad_zn(-632.453) #Обращение к методу класса у 2-го экз.
|
||||
z2
|
||||
<__main__.Class1 object at 0x0000024487293C50>
|
||||
z1.otobrazh()
|
||||
экз.класса 1
|
||||
z2.otobrazh()
|
||||
-632.453
|
||||
z1.data='Новое значение атрибута у экз.1' # Измените значение атрибута у первого экземпляра
|
||||
z1.otobrazh()
|
||||
Новое значение атрибута у экз.1
|
||||
```
|
||||
|
||||
## 2.2. Создание класса-наследника
|
||||
|
||||
В объявлении класса после его имени в скобках перечисляются его «родительские классы»
|
||||
|
||||
```py
|
||||
class Class2(Class1): #Class2 - наследник класса Class1
|
||||
def otobrazh(self): # Метод класса Class2 – переопределяет метод родителя
|
||||
print('значение=',self.data)#Отображение данных экземпляра
|
||||
|
||||
z3=Class2()
|
||||
dir(z3)
|
||||
['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'otobrazh', 'zad_zn']
|
||||
z3.zad_zn('Совсем новое')
|
||||
z3.otobrazh()
|
||||
значение= Совсем новое
|
||||
z1.otobrazh()
|
||||
Новое значение атрибута у экз.1
|
||||
del z1,z2,z3
|
||||
```
|
||||
|
||||
Когда вызывается метод объекта, Python:
|
||||
|
||||
* Сначала ищет метод в классе объекта (Class2)
|
||||
|
||||
* Если не находит - ищет в родительских классах (Class1)
|
||||
|
||||
* Продолжает по цепочке наследования
|
||||
|
||||
|
||||
|
||||
## 3. Использование классов, содержащихся в модулях
|
||||
|
||||
Модуль с именем Mod3:
|
||||
|
||||
```py
|
||||
class Class1: #Объявление класса Class1 в модуле
|
||||
def zad_zn(self,znach): # 1 Метод класса
|
||||
self.data=znach # self - ссылка на экземпляр класса Class1
|
||||
def otobrazh(self): # 2 Метод класса
|
||||
print(self.data)#Отображение данных экземпляра
|
||||
|
||||
class Class2(Class1): #Class2 - наследник класса Class1
|
||||
def otobrazh(self): # Метод класса Class2
|
||||
print('значение=',self.data)#Отображение данных экземпляра
|
||||
|
||||
def otobrazh(objekt): #Объявление самостоятельной функции
|
||||
print('значение объекта=',objekt)
|
||||
```
|
||||
```py
|
||||
from Mod3 import Class1
|
||||
z4=Class1()
|
||||
z4.otobrazh()
|
||||
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#31>", line 1, in <module>
|
||||
z4.otobrazh()
|
||||
File "C:\Users/Ekaterina/OneDrive/Desktop/Solovyova/python-labs/TEMA9\Mod3.py", line 5, in otobrazh
|
||||
print(self.data)#Отображение данных экземпляра
|
||||
AttributeError: 'Class1' object has no attribute 'data'
|
||||
```
|
||||
При создании z4 не вызывается метод zad_zn(), поэтому атрибут data не создаётся. При вызове z4.otobrazh() метод пытается обратиться к self.data, но этого атрибута не существует.
|
||||
|
||||
```py
|
||||
from Mod3 import Class1
|
||||
z4=Class1() # Вызывается метод otobrazh() из класса Class1, который просто печатает self.data
|
||||
z4.data='значение данного data у экз.4'
|
||||
z4.otobrazh()
|
||||
значение данного data у экз.4
|
||||
```
|
||||
Сравним с:
|
||||
```py
|
||||
del z4
|
||||
import Mod3
|
||||
z4=Mod3.Class2() # Вызывается ПЕРЕОПРЕДЕЛЁННЫЙ метод otobrazh() из класса Class2
|
||||
z4.zad_zn('Класс из модуля')
|
||||
z4.otobrazh()
|
||||
значение= Класс из модуля
|
||||
Mod3.otobrazh('Объект') # Вызывается ОТДЕЛЬНАЯ ФУНКЦИЯ otobrazh()
|
||||
значение объекта= Объект
|
||||
```
|
||||
Разница в выводе объясняется тем, что во втором случае вызывается переопределённый метод Class2.otobrazh() (с префиксом "значение ="), а в третьем - самостоятельная функция из модуля.
|
||||
|
||||
## 4. Использование специальных методов
|
||||
|
||||
Имена специальных методов предваряются одним или двумя подчерками и имеют вид: <имя специального метода>
|
||||
Для примера создам класс, содержащий два специальных метода
|
||||
|
||||
```py
|
||||
class Class3(Class2): #Наследник класса Class2, а через него – и класса Class1
|
||||
def __init__(self,znach): #Конструктор вызывается при создании нового экземпляра класса
|
||||
self.data=znach
|
||||
def __add__(self,drug_zn): #Вызывается, когда экземпляр участвует в операции «+»
|
||||
return Class3(self.data+drug_zn)
|
||||
def zad_dr_zn(self,povtor): #А это - обычный метод
|
||||
self.data*=povtor
|
||||
```
|
||||
Метод add - это один из методов, осуществляющих так называемую «перегрузку» операторов.
|
||||
Перегрузка операторов — это возможность определять поведение стандартных операторов (+, -, *, /, <, > и т.д.) для объектов собственных классов.
|
||||
|
||||
Для иллюстрации работы этих методов создам экземпляр класса Class3
|
||||
|
||||
```py
|
||||
z5=Class3('abc') #При создании экземпляра срабатывает конструктор
|
||||
z5.otobrazh()
|
||||
значение= abc
|
||||
z6=z5+'def' № должен сработать специальный метод __add__
|
||||
z6.otobrazh()
|
||||
значение= abcdef
|
||||
z6.zad_dr_zn(3)
|
||||
z6.otobrazh()
|
||||
значение= abcdefabcdefabcdef
|
||||
```
|
||||
|
||||
## 5. Присоединение атрибутов к классу.
|
||||
|
||||
```py
|
||||
dir(Class3)
|
||||
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'otobrazh', 'zad_dr_zn', 'zad_zn']
|
||||
Class3.fio='Иванов И.И.'
|
||||
dir(Class3)
|
||||
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'fio', 'otobrazh', 'zad_dr_zn', 'zad_zn']
|
||||
z7=Class3(123)
|
||||
dir(z7)==dir(Class3)
|
||||
False
|
||||
dir(z7)
|
||||
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'data', 'fio', 'otobrazh', 'zad_dr_zn', 'zad_zn']
|
||||
dir(Class3)
|
||||
['__add__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__firstlineno__', '__format__', '__ge__', '__getattribute__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__static_attributes__', '__str__', '__subclasshook__', '__weakref__', 'fio', 'otobrazh', 'zad_dr_zn', 'zad_zn']
|
||||
```
|
||||
|
||||
## 6. Выявление родительских классов
|
||||
Такое выявление делается с помощью специального атрибута bases, например, выведу родительский класс для созданного класса Class3:
|
||||
```py
|
||||
Class3.__bases__
|
||||
(<class '__main__.Class2'>,)
|
||||
|
||||
Class2.__bases__
|
||||
(<class '__main__.Class1'>,)
|
||||
|
||||
Class1.__bases__
|
||||
(<class 'object'>,)
|
||||
|
||||
Class3.__mro__
|
||||
(<class '__main__.Class3'>, <class '__main__.Class2'>, <class '__main__.Class1'>, <class 'object'>)
|
||||
|
||||
ZeroDivisionError.__mro__
|
||||
(<class 'ZeroDivisionError'>, <class 'ArithmeticError'>, <class 'Exception'>, <class 'BaseException'>, <class 'object'>)
|
||||
```
|
||||
## 7. Создание свойства класса.
|
||||
Свойство (property) класса – это особый атрибут класса, с которым можно производить операции чтения или задания его значения, а также удаление значения этого атрибута.
|
||||
|
||||
Создам, например, новый класс с определенным в нем свойством
|
||||
```py
|
||||
class Class4:
|
||||
def __init__(sam,znach):
|
||||
sam.__prm=znach
|
||||
def chten(sam):
|
||||
return sam.__prm
|
||||
def zapis(sam,znch):
|
||||
sam.__prm=znch
|
||||
def stiran(sam):
|
||||
del sam.__prm
|
||||
svojstvo=property(chten,zapis,stiran)
|
||||
|
||||
```
|
||||
Здесь имеется 3 метода: chten, zapis, stiran, которые обслуживают созданное свойство, реализуя операции, соответственно, чтения, записи или удаления значений свойства. Теперь попробую некоторые операции с этим свойством
|
||||
```py
|
||||
exempl=Class4(12) # Вызывается __init__(12)
|
||||
exempl.svojstvo Вызывается chten() → возвращает self.__prm (12)
|
||||
12
|
||||
exempl.svojstvo=45 # Вызывается zapis(45) → self.__prm = 45
|
||||
print(exempl.svojstvo) # Вызывается chten() → возвращает 45
|
||||
45
|
||||
del exempl.svojstvo # Вызывается stiran() → del self.__prm
|
||||
exempl.svojstvo # атрибут удалён
|
||||
Traceback (most recent call last):
|
||||
File "<pyshell#48>", line 1, in <module>
|
||||
exempl.svojstvo
|
||||
File "<pyshell#42>", line 5, in chten
|
||||
return sam.__prm
|
||||
AttributeError: 'Class4' object has no attribute '_Class4__prm'
|
||||
```
|
||||
|
||||
|
||||
## 8. Рассмотрите пример представления в виде класса модели системы автоматического регулирования (САР), состоящей из последовательного соединения усилителя и двух инерционных звеньев, охваченных отрицательной обратной связью с усилителем.
|
||||
Создадим модуль SAU.py с классом:
|
||||
```py
|
||||
class SAU:
|
||||
def init(self,zn_param):
|
||||
self.param=zn_param
|
||||
self.ypr=[0,0]
|
||||
|
||||
def zdn_zn(self,upr):
|
||||
self.x=upr
|
||||
|
||||
def model(self):
|
||||
def inerz(x,T,yy):
|
||||
return (x+T*yy)/(T+1)
|
||||
|
||||
y0=self.x-self.ypr[1]*self.param[3] #Обр.связь с усилителем 2
|
||||
y1=self.param[0]*y0 #Усилитель1
|
||||
y2=inerz(y1,self.param[1],self.ypr[0]) #Инерционное звено1
|
||||
y3=inerz(y2,self.param[2],self.ypr[1]) #Инерционное звено2
|
||||
self.ypr[0]=y2
|
||||
self.ypr[1]=y3
|
||||
|
||||
def otobraz(self):
|
||||
print('y=',self.ypr[1])
|
||||
```
|
||||
модуль main_Sau.py:
|
||||
```py
|
||||
###main_SAU
|
||||
prm=[2.5,4,1.3,0.8] #Параметры модели: коэф.усиления, 2 пост.времени, обратная связь
|
||||
from SAU import *
|
||||
xx=[0]+[1]*20 #Входной сигнал – «ступенька»
|
||||
SAUe=SAU(prm) # Создаём экземпляр класса
|
||||
yt=[]
|
||||
for xt in xx: # Прохождение входного сигнала
|
||||
SAUe.zdn_zn(xt)
|
||||
SAUe.model()
|
||||
SAUe.otobraz()
|
||||
yt.append(SAUe.ypr[1])
|
||||
import pylab
|
||||
pylab.plot(yt)
|
||||
pylab.show()
|
||||
```
|
||||
Тестирование:
|
||||
```py
|
||||
y= 0.0
|
||||
y= 0.2173913043478261
|
||||
y= 0.4763705103969754
|
||||
y= 0.686594887811293
|
||||
y= 0.8199324616478645
|
||||
y= 0.8837201137353929
|
||||
y= 0.8994188484874774
|
||||
y= 0.8892777072047301
|
||||
y= 0.870097963179993
|
||||
y= 0.8518346102696789
|
||||
y= 0.8387499784485772
|
||||
y= 0.8314204114211459
|
||||
y= 0.8286051955249649
|
||||
y= 0.8285656555914835
|
||||
y= 0.8297915186846528
|
||||
y= 0.8312697736438287
|
||||
y= 0.8324765218921963
|
||||
y= 0.8332456979978418
|
||||
y= 0.8336163607592184
|
||||
y= 0.8337101315489143
|
||||
y= 0.833654237067147
|
||||
```
|
||||
|
||||

|
||||
|
||||
|
||||
|
||||
## 9. Сохраните созданный текстовый файл протокола в своем рабочем каталоге. Закончите сеанс работы с IDLE.
|
||||
|
||||
@@ -1,78 +0,0 @@
|
||||
# Общее контрольное задание по Теме 9
|
||||
Соловьёва Екатерина, А-01-23
|
||||
## Задание
|
||||
Создайте и запишите в модуль класс, содержащий следующие компоненты:
|
||||
- конструктор, задающий четырем атрибутам (fio, otdel, dolzhnost, oklad), представляющим фамилии сотрудников, название отделов, названия должностей сотрудников и размеры их окладов, некоторые начальные значения;
|
||||
- метод для обеспечения операции повышения оклада сотрудника на заданное значение;
|
||||
- метод для обеспечения перевода сотрудника из одного отдела в другой;
|
||||
- метод для изменения должности сотрудника;
|
||||
- свойство, содержащее перечень (список) поощрений сотрудника.
|
||||
Создайте 2 экземпляра класса, задайте им некоторые значения атрибутов и свойства. Отобразите эти значения. Попробуйте с этими экземплярами операции перевода из отдела в отдел, изменения должности и оклада, объявления благодарности.
|
||||
## Решение
|
||||
```py
|
||||
class Employee:
|
||||
"""Класс для работы с данными сотрудников"""
|
||||
|
||||
def __init__(self, fio, otdel, dolzhnost, oklad):
|
||||
self.fio = fio
|
||||
self.otdel = otdel
|
||||
self.dolzhnost = dolzhnost
|
||||
self.oklad = oklad
|
||||
self.__pooshreniya = []
|
||||
|
||||
def povysit_oklad(self, summa_povysheniya):
|
||||
"""
|
||||
Метод для повышения оклада сотрудника на заданное значение
|
||||
"""
|
||||
if summa_povysheniya <= 0:
|
||||
raise ValueError("Сумма повышения должна быть положительной!")
|
||||
self.oklad += summa_povysheniya
|
||||
return self.oklad
|
||||
|
||||
def perevesti_v_drugoi_otdel(self, novy_otdel):
|
||||
"""Перевод сотрудника в другой отдел"""
|
||||
self.otdel = novy_otdel
|
||||
print(f"Сотрудник {self.fio} переведен в отдел: {novy_otdel}")
|
||||
|
||||
def izmenit_dolzhnost(self, novaya_dolzhnost):
|
||||
"""Метод изменения должности"""
|
||||
self.dolzhnost = novaya_dolzhnost
|
||||
|
||||
def get_pooshreniya(self):
|
||||
"""Получить список поощрений"""
|
||||
return self.__pooshreniya.copy()
|
||||
|
||||
def dobavit_pooshrenie(self, text):
|
||||
"""Добавить поощрение в список"""
|
||||
self.__pooshreniya.append(text)
|
||||
|
||||
@property #вызывает метод, который возвращает копию текущего списка поощрений.
|
||||
def pooshreniya(self):
|
||||
"""Свойство для получения списка поощрений"""
|
||||
return self.__pooshreniya.copy()
|
||||
```
|
||||
|
||||
## Вывод программы
|
||||
```py
|
||||
emp1=Employee ("Обычайко Д.С.", "Кафедра Управления и информационных технологий", "Ассистент", 100000)
|
||||
emp2=Employee ("Пронин А.С.", "Кафедра Управления и информационных технологий", "Ассистент", 100000)
|
||||
|
||||
print(f"{emp1.fio}, {emp1.otdel}, {emp1.dolzhnost}, оклад: {emp1.oklad}")
|
||||
Обычайко Д.С., Кафедра Управления и информационных технологий, Ассистент, оклад: 100000
|
||||
print(f"{emp2.fio}, {emp2.otdel}, {emp2.dolzhnost}, оклад: {emp2.oklad}")
|
||||
Пронин А.С., Кафедра Управления и информационных технологий, Ассистент, оклад: 100000
|
||||
|
||||
emp2.perevesti_v_drugoi_otdel("Деканат")
|
||||
Сотрудник Пронин А.С. переведен в отдел: Деканат
|
||||
|
||||
emp1.izmenit_dolzhnost("Старший преподаватель")
|
||||
print(f"Новая должность {emp1.fio}: {emp1.dolzhnost}")
|
||||
Новая должность Обычайко Д.С.: Старший преподаватель
|
||||
|
||||
novy_oklad1 = emp1.povysit_oklad(20000)
|
||||
emp2.dobavit_pooshrenie("За публикацию научной статьи")
|
||||
print(f" Поощрения: {emp2.get_pooshreniya()}")
|
||||
Поощрения: ['За публикацию научной статьи']
|
||||
employee1.povysit_oklad(15000)
|
||||
65000
|
||||
```
|
||||
187
TEMA9/test.md
187
TEMA9/test.md
@@ -1,187 +0,0 @@
|
||||
# Общее контрольно задание по Теме 9
|
||||
Соловьёва Екатерина, А-01-23
|
||||
## Задание:
|
||||
1) Создайте модуль М1, содержащий 2 функции:
|
||||
|
||||
- функция 1: аргумент - список или кортеж с отсчетами некоторого сигнала; функция должна определить и вернуть число элементов, значение которых превышает значение предыдущего элемента;
|
||||
|
||||
- функция 2: аргумент - список или кортеж с последовательностью отсчетов сигнала; функция должна рассчитать список с накопленными суммами: первый элемент равен первому элементу исходной последовательности, второй - равен сумме двух первых элементов последовательности, третий - сумме первых трех элементов и т.д.
|
||||
|
||||
2) Создайте еще один модуль М2, в котором должны выполняться следующие операции:
|
||||
|
||||
- запрашивается имя бинарного файла с выборкой, проверяется его наличие и при отсутствии - повторяется запрос;
|
||||
|
||||
- выборка вводится из файла;
|
||||
|
||||
- с помощью функции 1 производится определение числа элементов со значениями, превышающими значения их предшественников;
|
||||
|
||||
- с помощью функции 2 рассчитывается список с кумулятивными суммами;
|
||||
|
||||
- выборка отображается в виде графика.
|
||||
|
||||
3) Создайте модуль М0 - главную программу, которая вызывает М2 и отображает результаты расчета на экране.
|
||||
|
||||
4) Проведите расчеты при 2-х разных исходных файлах.
|
||||
|
||||
## Решение:
|
||||
M1.py
|
||||
```py
|
||||
|
||||
def count_increasing_elements(sequence):
|
||||
""" Функция 1: подсчитывает число элементов, значение которых превышает значение предыдущего элемента"""
|
||||
if len(sequence) <= 1:
|
||||
return 0
|
||||
|
||||
count = 0
|
||||
for i in range(1, len(sequence)):
|
||||
if sequence[i] > sequence[i-1]:
|
||||
count += 1
|
||||
|
||||
return count
|
||||
|
||||
|
||||
def cumulative_sum(sequence):
|
||||
"""Функция 2: рассчитывает список с накопленными суммами"""
|
||||
result = []
|
||||
current_sum = 0
|
||||
|
||||
for value in sequence:
|
||||
current_sum += value
|
||||
result.append(current_sum)
|
||||
|
||||
return result
|
||||
```
|
||||
M2.py
|
||||
```py
|
||||
import os
|
||||
import struct
|
||||
import matplotlib.pyplot as plt
|
||||
from M1 import count_increasing_elements, cumulative_sum
|
||||
|
||||
|
||||
def read_binary_file(filename):
|
||||
"""
|
||||
Читает бинарный файл с числами с плавающей точкой
|
||||
"""
|
||||
data = []
|
||||
try:
|
||||
with open(filename, 'rb') as f:
|
||||
while True:
|
||||
bytes_data = f.read(8)
|
||||
if not bytes_data:
|
||||
break
|
||||
value = struct.unpack('d', bytes_data)[0]
|
||||
data.append(value)
|
||||
except Exception as e:
|
||||
print(f"Ошибка при чтении файла: {e}")
|
||||
|
||||
return data
|
||||
|
||||
|
||||
def display_plots(original_data, cumulative_data):
|
||||
"""
|
||||
Отображает графики исходных данных и кумулятивных сумм
|
||||
"""
|
||||
fig, (ax1, ax2) = plt.subplots(2, 1, figsize=(12, 8))
|
||||
|
||||
ax1.plot(original_data, 'b-', linewidth=1.5, label='Исходный сигнал')
|
||||
ax1.set_xlabel('Отсчеты')
|
||||
ax1.set_ylabel('Амплитуда')
|
||||
ax1.set_title('Исходный сигнал')
|
||||
ax1.grid(True, alpha=0.3)
|
||||
ax1.legend()
|
||||
|
||||
ax2.plot(cumulative_data, 'r-', linewidth=1.5, label='Накопленные суммы')
|
||||
ax2.set_xlabel('Отсчеты')
|
||||
ax2.set_ylabel('Сумма')
|
||||
ax2.set_title('Кумулятивные суммы сигнала')
|
||||
ax2.grid(True, alpha=0.3)
|
||||
ax2.legend()
|
||||
|
||||
plt.tight_layout()
|
||||
plt.show()
|
||||
|
||||
|
||||
def process_signal_data():
|
||||
""" Основная функция модуля M2 - выполняет все требуемые операции """
|
||||
while True:
|
||||
filename = input("Введите имя бинарного файла с выборкой: ").strip()
|
||||
|
||||
if os.path.exists(filename):
|
||||
print(f"Файл '{filename}' найден.")
|
||||
break
|
||||
else:
|
||||
print(f"Файл '{filename}' не существует. Пожалуйста, попробуйте еще раз.")
|
||||
|
||||
print("Чтение данных из файла...")
|
||||
signal_data = read_binary_file(filename)
|
||||
|
||||
if not signal_data:
|
||||
print("Файл пуст или содержит некорректные данные.")
|
||||
return None, None, None
|
||||
|
||||
print(f"Прочитано {len(signal_data)} отсчетов сигнала.")
|
||||
|
||||
|
||||
increasing_count = count_increasing_elements(signal_data)
|
||||
print(f"Количество элементов, превышающих предыдущий: {increasing_count}")
|
||||
|
||||
|
||||
cumulative_sums = cumulative_sum(signal_data)
|
||||
print("Список с кумулятивными суммами рассчитан.")
|
||||
|
||||
display_plots(signal_data, cumulative_sums)
|
||||
|
||||
return signal_data, increasing_count, cumulative_sums
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
|
||||
process_signal_data()
|
||||
```
|
||||
M0.py
|
||||
```py
|
||||
from M2 import process_signal_data
|
||||
|
||||
def main():
|
||||
"""
|
||||
Главная функция программы
|
||||
"""
|
||||
print("=" * 60)
|
||||
print("ПРОГРАММА ОБРАБОТКИ СИГНАЛОВ")
|
||||
print("=" * 60)
|
||||
|
||||
print("\n" + "=" * 60)
|
||||
print("РАСЧЕТ №1")
|
||||
print("=" * 60)
|
||||
|
||||
data1, count1, sums1 = process_signal_data()
|
||||
|
||||
if data1:
|
||||
print(f"\nРезультаты расчета №1:")
|
||||
print(f" • Общее количество отсчетов: {len(data1)}")
|
||||
print(f" • Элементов, превышающих предыдущий: {count1}")
|
||||
print(f" • Процент возрастающих элементов: {count1/len(data1)*100:.2f}%")
|
||||
|
||||
print("\n" + "=" * 60)
|
||||
print("РАСЧЕТ №2")
|
||||
print("=" * 60)
|
||||
|
||||
data2, count2, sums2 = process_signal_data()
|
||||
|
||||
if data2:
|
||||
print(f"\nРезультаты расчета №2:")
|
||||
print(f" • Общее количество отсчетов: {len(data2)}")
|
||||
print(f" • Элементов, превышающих предыдущий: {count2}")
|
||||
print(f" • Процент возрастающих элементов: {count2/len(data2)*100:.2f}%")
|
||||
|
||||
print("\n" + "=" * 60)
|
||||
print("ОБРАБОТКА ЗАВЕРШЕНА")
|
||||
print("=" * 60)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
```
|
||||
|
||||
|
||||
Ссылка в новой задаче
Block a user