diff --git a/TEMA9/Employee.py b/TEMA9/Employee.py new file mode 100644 index 0000000..a3e0f85 --- /dev/null +++ b/TEMA9/Employee.py @@ -0,0 +1,38 @@ +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) + + + + diff --git a/TEMA9/Figure_1.png b/TEMA9/Figure_1.png new file mode 100644 index 0000000..cd4c2be Binary files /dev/null and b/TEMA9/Figure_1.png differ diff --git a/TEMA9/SAU.py b/TEMA9/SAU.py new file mode 100644 index 0000000..6f0cc48 --- /dev/null +++ b/TEMA9/SAU.py @@ -0,0 +1,21 @@ +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]) diff --git a/TEMA9/main_SAU.py b/TEMA9/main_SAU.py new file mode 100644 index 0000000..f8c5e92 --- /dev/null +++ b/TEMA9/main_SAU.py @@ -0,0 +1,15 @@ +###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() + diff --git a/TEMA9/report.md b/TEMA9/report.md index 1bd5716..d1ac201 100644 --- a/TEMA9/report.md +++ b/TEMA9/report.md @@ -1,430 +1,293 @@ -\# Отчёт по Теме 9 +# Отчёт по Теме 9 Соловьёва Екатерина. А-01-23 -\## 1. Запуск интерактивной оболочки IDLE. +## 1. Запуск интерактивной оболочки IDLE. -\## 2. Создание классов и их наследников +## 2. Создание классов и их наследников -\## 2.1. Создание автономного класса +## 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)#Отображение данных экземпляра класса -  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=Class1() #Создаём 1-й экземпляр класса +z2=Class1() #Создаём 2-й экземпляр класса +z1.zad_zn('экз.класса 1') #Обращение к методу класса у 1-го экз. z1 - -<\_\_main\_\_.Class1 object at 0x00000244872A6660> - -z2.zad\_zn(-632.453) #Обращение к методу класса у 2-го экз. - +<__main__.Class1 object at 0x00000244872A6660> +z2.zad_zn(-632.453) #Обращение к методу класса у 2-го экз. z2 - -<\_\_main\_\_.Class1 object at 0x0000024487293C50> - +<__main__.Class1 object at 0x0000024487293C50> z1.otobrazh() - экз.класса 1 - z2.otobrazh() - -632.453 - z1.data='Новое значение атрибута у экз.1' # Измените значение атрибута у первого экземпляра - z1.otobrazh() - Новое значение атрибута у экз.1 - ``` -\## 2.2. Создание класса-наследника +## 2.2. Создание класса-наследника В объявлении класса после его имени в скобках перечисляются его «родительские классы» ```py - class Class2(Class1): #Class2 - наследник класса Class1 - -  def otobrazh(self): # Метод класса Class2 – переопределяет метод родителя - -  print('значение=',self.data)#Отображение данных экземпляра - - + 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('Совсем новое') - +['__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 - +del z1,z2,z3 ``` -Объекты класса Class2 всегда используют переопределенные методы из Class2, даже если идентичные методы существуют в родительском классе Class1 +Когда вызывается метод объекта, Python: + +* Сначала ищет метод в классе объекта (Class2) + +* Если не находит - ищет в родительских классах (Class1) + +* Продолжает по цепочке наследования -\## 3. Использование классов, содержащихся в модулях +## 3. Использование классов, содержащихся в модулях Модуль с именем Mod3: ```py - class Class1: #Объявление класса Class1 в модуле - -  def zad\_zn(self,znach): # 1 Метод класса - -  self.data=znach # self - ссылка на экземпляр класса Class1 - -  def otobrazh(self): # 2 Метод класса - -  print(self.data)#Отображение данных экземпляра + 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(self): # Метод класса Class2 + print('значение=',self.data)#Отображение данных экземпляра def otobrazh(objekt): #Объявление самостоятельной функции - -  print('значение объекта=',objekt) - + print('значение объекта=',objekt) ``` - ```py - from Mod3 import Class1 - z4=Class1() - z4.otobrazh() - - Traceback (most recent call last): - -  File "", line 1, in - -  z4.otobrazh() - -  File "C:\\Users/Ekaterina/OneDrive/Desktop/Solovyova/python-labs/TEMA9\\Mod3.py", line 5, in otobrazh - -  print(self.data)#Отображение данных экземпляра - + File "", line 1, in + 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' - ``` - -Ошибка возникла потому, что метод otobrazh() был вызван до того, как был вызван метод zad\_zn(), который создает атрибут data. +При создании z4 не вызывается метод zad_zn(), поэтому атрибут data не создаётся. При вызове z4.otobrazh() метод пытается обратиться к self.data, но этого атрибута не существует. ```py - from Mod3 import Class1 - - - -z4=Class1() - +z4=Class1() # Вызывается метод otobrazh() из класса Class1, который просто печатает self.data z4.data='значение данного data у экз.4' - z4.otobrazh() - значение данного data у экз.4 - -del z4 - -import Mod3 - -z4=Mod3.Class2() - - - -z4.zad\_zn('Класс из модуля') - -z4.otobrazh() - -значение= Класс из модуля - -Mod3.otobrazh('Объект') - -значение объекта= Объект - ``` +Сравним с: +```py +del z4 +import Mod3 +z4=Mod3.Class2() # Вызывается ПЕРЕОПРЕДЕЛЁННЫЙ метод otobrazh() из класса Class2 +z4.zad_zn('Класс из модуля') +z4.otobrazh() +значение= Класс из модуля +Mod3.otobrazh('Объект') # Вызывается ОТДЕЛЬНАЯ ФУНКЦИЯ otobrazh() +значение объекта= Объект +``` +Разница в выводе объясняется тем, что во втором случае вызывается переопределённый метод Class2.otobrazh() (с префиксом "значение ="), а в третьем - самостоятельная функция из модуля. -Результаты различаются потому, что в первом случае использовался метод из Class1, а во втором - переопределенный метод из Class2 плюс самостоятельная функция с таким же именем - - - -\## 4. Использование специальных методов - -Имена специальных методов предваряются одним или двумя подчерками и имеют вид: \_\_<имя специального метода>\_\_ +## 4. Использование специальных методов +Имена специальных методов предваряются одним или двумя подчерками и имеют вид: <имя специального метода> Для примера создам класс, содержащий два специальных метода - - -  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 +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=Class3('abc') #При создании экземпляра срабатывает конструктор z5.otobrazh() - значение= abc - -z6=z5+'def' - +z6=z5+'def' № должен сработать специальный метод __add__ z6.otobrazh() - значение= abcdef - -z6.zad\_dr\_zn(3) - +z6.zad_dr_zn(3) z6.otobrazh() - значение= abcdefabcdefabcdef - ``` - - -\## 5. Присоединение атрибутов к классу. +## 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'] - +['__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'] - +['__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'] - +['__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'] - +['__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. Выявление родительских классов +## 6. Выявление родительских классов +Такое выявление делается с помощью специального атрибута bases, например, выведу родительский класс для созданного класса Class3: +```py +Class3.__bases__ +(,) -Такое выявление делается с помощью специального атрибута \_\_bases\_\_, например, выведите родительский класс для созданного класса Class3: +Class2.__bases__ +(,) -  Class3.\_\_bases\_\_ +Class1.__bases__ +(,) -Или для класса Class2: - -  Class2.\_\_bases\_\_ - -Самостоятельно проверьте, какой родительский класс у класса Class1. - -Для получения всей цепочки наследования используйте атрибут \_\_mro\_\_: - -  Class3.\_\_mro\_\_ - -Например, получите всю цепочку наследования для встроенного класса ошибок «деление на ноль»: - -  ZeroDivisionError.\_\_mro\_\_ - - - -\## 7. Создание свойства класса. +Class3.__mro__ +(, , , ) +ZeroDivisionError.__mro__ +(, , , , ) +``` +## 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) - 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 "", line 1, in + exempl.svojstvo + File "", line 5, in chten + return sam.__prm +AttributeError: 'Class4' object has no attribute '_Class4__prm' +``` - -Обратите внимание на то, что здесь имеется 3 метода: chten, zapis, stiran, которые обслуживают созданное свойство, реализуя операции, соответственно, чтения, записи или удаления значений свойства. Теперь попробуйте некоторые операции с этим свойством - -  exempl=Class4(12) - -  exempl.svojstvo - -  exempl.svojstvo=45 - -  print(exempl.svojstvo) - -  del exempl.svojstvo - -После этого попробуйте еще раз отобразить значение свойства. - -  exempl.svojstvo - -Объясните полученный результат. - - - -\## 8. Рассмотрите пример представления в виде класса модели системы автоматического регулиро-вания (САР), состоящей из последовательного соединения усилителя и двух инерционных звень-ев, охваченных отрицательной обратной связью с усилителем. - -Создайте модуль SAU.py с классом: - +## 8. Рассмотрите пример представления в виде класса модели системы автоматического регулирования (САР), состоящей из последовательного соединения усилителя и двух инерционных звеньев, охваченных отрицательной обратной связью с усилителем. +Создадим модуль SAU.py с классом: +```py class SAU: +def init(self,zn_param): +self.param=zn_param +self.ypr=[0,0] -  def \_\_init\_\_(self,zn\_param): +def zdn_zn(self,upr): + self.x=upr -  self.param=zn\_param +def model(self): + def inerz(x,T,yy): + return (x+T*yy)/(T+1) -  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 - -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]) + 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 +``` -Запустите программу на выполнение и изучите вид выходного сигнала при разных значениях параметров САР. +![График](Figure_1.png) -\## 9. Сохраните созданный текстовый файл протокола в своем рабочем каталоге. Закончите се-анс работы с IDLE. - - +## 9. Сохраните созданный текстовый файл протокола в своем рабочем каталоге. Закончите сеанс работы с IDLE. diff --git a/TEMA9/task.md b/TEMA9/task.md index e69de29..7cdb728 100644 --- a/TEMA9/task.md +++ b/TEMA9/task.md @@ -0,0 +1,70 @@ +# Общее контрольное задание по Теме 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 + + @property + def pooshreniya(self): + return self.__pooshreniya.copy() + + def dobavit_pooshrenie(self, text): + """Добавить поощрение в список""" + self.__pooshreniya.append(text) +``` + +## Вывод программы +```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.pooshreniya}") + Поощрения: ['За публикацию научной статьи'] +```