Pavel 2 месяцев назад
Родитель a20fa6826b
Сommit 0e0029a430

@ -0,0 +1,22 @@
# M0.py
import pickle
import pylab
import M2
# Получаем данные (они уже прочитаны в M2)
data = M2.original_data
# График
pylab.plot(data, marker='o')
pylab.title("Исходные данные")
pylab.xlabel("Номер")
pylab.ylabel("Значение")
pylab.grid(True)
pylab.show()
# Запись в бинарный файл
f = open("RES2a.bin", "wb")
pickle.dump(data, f)
f.close()
print("Исходные данные записаны в RES2a.bin")

@ -0,0 +1,53 @@
# M1.py
import os
import math
def func1(filename, KK):
numbers = []
f = open(filename, 'r')
for line in f:
parts = line.split()
for p in parts:
numbers.append(float(p))
f.close()
base, ext = os.path.splitext(filename)
f1 = open(base + '1' + ext, 'w')
f2 = open(base + '2' + ext, 'w')
for x in numbers:
if x > KK:
f1.write(str(x) + '\n')
else:
f2.write(str(x) + '\n')
f1.close()
f2.close()
return numbers
def func2(filename):
numbers = []
f = open(filename, 'r')
for line in f:
parts = line.split()
for p in parts:
numbers.append(float(p))
f.close()
if len(numbers) == 0:
return 0, 0, 0, 0, 0 # пустой файл
n = len(numbers)
mean = sum(numbers) / n
min_val = min(numbers)
max_val = max(numbers)
std_dev = math.sqrt(sum((x - mean) ** 2 for x in numbers) / n)
sorted_nums = sorted(numbers)
if n % 2 == 1:
median = sorted_nums[n // 2]
else:
median = (sorted_nums[n // 2 - 1] + sorted_nums[n // 2]) / 2
return mean, median, min_val, max_val, std_dev

@ -0,0 +1,38 @@
# M2.py
import os
from M1 import func1, func2
# Запрос имени файла с проверкой существования
filename = input("Введите имя файла с исходными данными: ")
while not os.path.isfile(filename):
print("Файл не найден.")
filename = input("Введите имя файла с исходными данными: ")
# Запрос порога
KK = float(input("Введите пороговое значение KK: "))
# Вызов func1
data = func1(filename, KK)
# Имена новых файлов
base, ext = os.path.splitext(filename)
file1 = base + '1' + ext
file2 = base + '2' + ext
# Три вызова func2
files = [filename, file1, file2]
labels = ["Исходный", "Больше KK", "Не больше KK"]
print("\nРезультаты статистики:")
print("-" * 50)
for i in range(3):
mean, median, minv, maxv, std = func2(files[i])
print(f"\n{labels[i]} файл:")
print(f" Среднее: {mean:.4f}")
print(f" Медиана: {median:.4f}")
print(f" Минимум: {minv:.4f}")
print(f" Максимум: {maxv:.4f}")
print(f" Ст. откл.: {std:.4f}")
# Возвращаем исходные данные для M0
original_data = data

@ -0,0 +1,11 @@
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)

Двоичные данные
TEMA9/RES2a.bin

Двоичный файл не отображается.

Двоичные данные
TEMA9/SAU.png

Двоичный файл не отображается.

После

Ширина:  |  Высота:  |  Размер: 25 KiB

@ -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])

@ -0,0 +1,4 @@
1.2 3.5
-2.1 4.8 5.0
2.3 1.1 6.7 0.0 3.3
7.2 -1.5

@ -0,0 +1,6 @@
3.5
4.8
5.0
6.7
3.3
7.2

@ -0,0 +1,6 @@
1.2
-2.1
2.3
1.1
0.0
-1.5

@ -0,0 +1,4 @@
10 20 30
15.5 -5
0 25 35.7 40
12.3 18.9

@ -0,0 +1,13 @@
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()

@ -0,0 +1,270 @@
# Отчет по теме 9
Анисенков Павел, А-01-23
## 1 Запуск интерактивной оболочки IDLE
Была запущена интерактивная оболочка IDLE.
## 2 Создание классов
## 2.1 Создание автономного класса
```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 методу класса у 1-го экз.
>>> z2.zad_zn(-632.453) #Обращение к 1 методу класса у 2-го экз.
>>> z1.otobrazh() # Обращение ко второму методу класса у 1-го экз.
экз.класса 1
>>> z2.otobrazh() # Обращение ко второму методу класса у 2-го экз.
-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() #Метод из Class2 (потому что он переопределяет родительский).
значение= Совсем новое
>>> z1.otobrazh() # z1 Не изменилось У каждого экземпляра — свой data
Новое значение атрибута у экз.1
>>> del z1,z2,z3
```
## 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)
```
Далее импортирован класс из этого модуля (при вызове метода otobrazh была выведена ошибка, так как не было задано значение обьекта с помощью метода zad_zn, которое и должно выводиться на печать):
```py
>>> from Mod3 import Class1 #Частичный импорт содержимого модуля
>>> z4=Class1()
>>> z4.otobrazh()
Traceback (most recent call last):
File "<pyshell#19>", line 1, in <module>
z4.otobrazh()
File "C:\Users\Professional\Desktop\python-labs\TEMA9\Mod3.py", line 5, in otobrazh
print(self.data)#Отображение данных экземпляра
AttributeError: 'Class1' object has no attribute 'data' #y z4 нет атрибута data
```
Далее была произведена еще попытка печати, но предварительно было задано знаечние обьекта:
```py
>>> from Mod3 import Class1
>>> z4=Class1()
>>> z4.data='значение данного data у экз.4'
>>> z4.otobrazh()
значение данного data у экз.4
```
Потом был импортирован весь модуль и из него с использованием разных методов был вызван otobrazh:
```py
>>> import Mod3 #Полный импорт содержимого модуля
>>> z4=Mod3.Class2()
>>> z4.zad_zn('Класс из модуля')
>>> z4.otobrazh() #метод класса Class2
значение= Класс из модуля
>>> Mod3.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
...
...
>>> z5=Class3('abc') #При создании экземпляра срабатывает конструктор
>>> z5.otobrazh()
значение= abc
>>> z6=z5+'def'
>>> 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='Иванов И.И.'
>>> z7=Class3(123)
>>> dir(z7)==dir(Class3)
False #У класса Class3 — нет 'data'
>>> dir(z7.fio)
['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getstate__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'removeprefix', 'removesuffix', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
>>> z7.rozden='1987'
>>> 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', 'rozden', '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'] #rozden был добавлен только к экземпляру z7, а не к классу Class3, если атрибут или метод добавлены к классу то к экземпляру автоматически тоже
```
## 6 Выявление родительских классов
```py
>>> Class3.__bases__
(<class '__main__.Class2'>,)
>>> Class2.__bases__
(<class '__main__.Class1'>,)
>>> Class1.__bases__
(<class 'object'>,) #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 Создание свойства класса
```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) #позволяет контролировать доступ к атрибуту через методы: obj.svojstvo → вызывает chten(). obj.svojstvo = 5 → вызывает zapis(5). del obj.svojstvo → вызывает stiran()
...
...
>>> exempl=Class4(12)
>>> exempl.svojstvo
12
>>> exempl.svojstvo=45
>>> print(exempl.svojstvo)
45
del exempl.svojstvo #атрибут __prm больше не существует
exempl.svojstvo
Traceback (most recent call last):
File "<pyshell#40>", line 1, in <module>
exempl.svojstvo
File "<pyshell#33>", line 5, in chten
return sam.__prm
AttributeError: 'Class4' object has no attribute '_Class4__prm'
```
## 8 представление в виде класса модели системы автоматического регулирования
Была создана программа с формированием класса для расчета САУ:
```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])
```
Была создана основная программа для формирования САУ с помощью модуля SAU:
```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()
```
Был запущен модуль MAIN_SAU
```py
= RESTART: C:\Users\Professional\Desktop\python-labs\TEMA9\main_SAU.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
```
![](SAU.png)
## 9 Завершение работы
Сеанс в IDLE был завершен!

@ -0,0 +1,99 @@
## Общее контрольное задание по теме 9
Анисенков Павел А-01-23
## Задание
Создайте и запишите в модуль класс, содержащий следующие компоненты:
- конструктор, задающий четырем атрибутам (fio, otdel, dolzhnost, oklad), представляющим фамилии сотрудников, название отделов, названия должностей сотрудников и размеры их окладов, некоторые начальные значения;
- метод для обеспечения операции повышения оклада сотрудника на заданное значение;
- метод для обеспечения перевода сотрудника из одного отдела в другой;
- метод для изменения должности сотрудника;
- свойство, содержащее перечень (список) поощрений сотрудника.
Создайте 2 экземпляра класса, задайте им некоторые значения атрибутов и свойства. Отобра-зите эти значения. Попробуйте с этими экземплярами операции перевода из отдела в отдел, изменения должности и оклада, объявления благодарности.
## Решение
Программа записанная в модуль:
```py
class Sotrudnik:
def __init__(self, fio, otdel, dolzhnost, oklad):
self.fio = fio
self.otdel = otdel
self.dolzhnost = dolzhnost
self.oklad = oklad
self.__pooshchreniya = []# Приватный атрибут для хранения поощрений Чтобы запретить прямое изменение списка поощрений извне.Все операции (добавление, чтение, очистка) происходят только через свойство pooshchreniya, где контролируется логика — например, при emp.pooshchreniya = "Премия" — значение добавляется в список, а не перезаписывает его.(публичный может сломать код emp.pooshchreniya = 123 ← тип не тот emp.pooshchreniya = None ← сломать логику)
def __chtenie_pooshchreniy(self): #возвращает список
return self.__pooshchreniya
def __zapis_pooshchreniy(self, pooshchrenie): #добавляет поощрение
self.__pooshchreniya.append(pooshchrenie)
def __stiran_pooshchreniy(self): # очищает список
self.__pooshchreniya = []
pooshchreniya = property(__chtenie_pooshchreniy, __zapis_pooshchreniy, __stiran_pooshchreniy, "Список поощрений сотрудника")
#Методы изменения данных:
def povysit_oklad(self, summa):
self.oklad += summa
def perevod_v_otdel(self, novyy_otdel):
self.otdel = novyy_otdel
def izmenit_dolzhnost(self, novaya_dolzhnost):
self.dolzhnost = novaya_dolzhnost
def __repr__(self): #чтобыпросто писать print(emp1) — и видеть все данные
return (f"Сотрудник: {self.fio}, Отдел: {self.otdel}, "
f"Должность: {self.dolzhnost}, Оклад: {self.oklad}, "
f"Поощрения: {self.pooshchreniya}")
# Создание экземпляров
emp1 = Sotrudnik("Иванова И.И.", "Секретариат", "Разносчица бумажек", 50000)
emp2 = Sotrudnik("Петрова А.С.", "Секретариат", "Разносчица кофе", 80000)
# Задание начальных поощрений
emp1.pooshchreniya = "Благодарность" #накапливает поощрения
emp2.pooshchreniya = "Премия"
emp2.pooshchreniya = "Премия 2"
# Отображение начальных значений
print("Начальные данные ")
print(emp1)
print(emp2)
# Операции с экземплярами
# Сотрудник 1: Повышение оклада и перевод
emp1.povysit_oklad(10000)
emp1.perevod_v_otdel("Генсекритариат")
# Сотрудник 2: Изменение должности и объявление благодарности
emp2.izmenit_dolzhnost("Старшая секретарша")
emp2.pooshchreniya = "Благодарность от руководства за вкусный кофе"
# Отображение измененных значений
print("Измененные данные")
print(emp1)
print(emp2)
```
Отображение результата:
```py
= RESTART: C:\Users\Professional\Desktop\python-labs\TEMA9\task.py
Начальные данные
Сотрудник: Иванова И.И., Отдел: Секретариат, Должность: Разносчица бумажек, Оклад: 50000, Поощрения: ['Благодарность']
Сотрудник: Петрова А.С., Отдел: Секретариат, Должность: Разносчица кофе, Оклад: 80000, Поощрения: ['Премия', 'Премия 2']
Измененные данные
Сотрудник: Иванова И.И., Отдел: Генсекритариат, Должность: Разносчица бумажек, Оклад: 60000, Поощрения: ['Благодарность']
Сотрудник: Петрова А.С., Отдел: Секретариат, Должность: Старшая секретарша, Оклад: 80000, Поощрения: ['Премия', 'Премия 2', 'Благодарность от руководства за вкусный кофе']
```

@ -0,0 +1,62 @@
class Sotrudnik:
def __init__(self, fio, otdel, dolzhnost, oklad):
self.fio = fio
self.otdel = otdel
self.dolzhnost = dolzhnost
self.oklad = oklad
self.__pooshchreniya = []# Приватный атрибут для хранения поощрений
def __chtenie_pooshchreniy(self): #возвращает список
return self.__pooshchreniya
def __zapis_pooshchreniy(self, pooshchrenie): #добавляет поощрение
self.__pooshchreniya.append(pooshchrenie)
def __stiran_pooshchreniy(self): # очищает список
self.__pooshchreniya = []
pooshchreniya = property(__chtenie_pooshchreniy, __zapis_pooshchreniy, __stiran_pooshchreniy, "Список поощрений сотрудника")
#Методы изменения данных:
def povysit_oklad(self, summa):
self.oklad += summa
def perevod_v_otdel(self, novyy_otdel):
self.otdel = novyy_otdel
def izmenit_dolzhnost(self, novaya_dolzhnost):
self.dolzhnost = novaya_dolzhnost
def __repr__(self): #чтобыпросто писать print(emp1) — и видеть все данные
return (f"Сотрудник: {self.fio}, Отдел: {self.otdel}, "
f"Должность: {self.dolzhnost}, Оклад: {self.oklad}, "
f"Поощрения: {self.pooshchreniya}")
# Создание экземпляров
emp1 = Sotrudnik("Иванова И.И.", "Секретариат", "Разносчица бумажек", 50000)
emp2 = Sotrudnik("Петрова А.С.", "Секретариат", "Разносчица кофе", 80000)
# Задание начальных поощрений
emp1.pooshchreniya = "Благодарность" #накапливает поощрения
emp2.pooshchreniya = "Премия"
emp2.pooshchreniya = "Премия 2"
# Отображение начальных значений
print("Начальные данные ")
print(emp1)
print(emp2)
# Операции с экземплярами
# Сотрудник 1: Повышение оклада и перевод
emp1.povysit_oklad(10000)
emp1.perevod_v_otdel("Генсекритариат")
# Сотрудник 2: Изменение должности и объявление благодарности
emp2.izmenit_dolzhnost("Старшая секретарша")
emp2.pooshchreniya = "Благодарность от руководства за вкусный кофе"
# Отображение измененных значений
print("Измененные данные")
print(emp1)
print(emp2)
Загрузка…
Отмена
Сохранить