BerezhkovDA 7 дней назад
Родитель 8067fa1b02 bc7bd0ebea
Сommit 13d772824c

@ -2,16 +2,20 @@
Бережков Дмитрий, А-01-23
<<<<<<< HEAD
## 1.Начало работы, настройка текущего каталога
=======
# 1.Начало работы, настройка текущего каталога
>>>>>>> bc7bd0ebeae5d8fc756d40c4363503abc883dff9
```py
>>> import os
>>> os.chdir('C:\\\\MPEI\\\\PO\_ASY\\\\BerezhkovGit\\\\python-labs\\\\Tema7')
```
\## 2. Создание пользовательской функции
# 2. Создание пользовательской функции
\# 2.1 Функция без аргументов
## 2.1 Функция без аргументов
```py
@ -33,21 +37,17 @@
>>> dir()
\['\_\_annotations\_\_', '\_\_builtins\_\_', '\_\_doc\_\_', '\_\_loader\_\_', '\_\_name\_\_', '\_\_package\_\_', '\_\_spec\_\_', 'os', 'uspeh']
['\_\_annotations\_\_', '\_\_builtins\_\_', '\_\_doc\_\_', '\_\_loader\_\_', '\_\_name\_\_', '\_\_package\_\_', '\_\_spec\_\_', 'os', 'uspeh']
>>> help(uspeh)
Help on function uspeh in module \_\_main\_\_:
uspeh()
&nbsp; Подтверждение успеха операции
>>> uspeh()
Подтверждение успеха операции
```
\# 2.2 Функция с аргументами
## 2.2 Функция с аргументами
```py
@ -81,7 +81,7 @@ uspeh()
\# 2.3 Функция, содержащая return
## 2.3 Функция, содержащая return
```py
@ -101,7 +101,7 @@ uspeh()
```
\# 2.4 Сложение для разных типов аргументов
## 2.4 Сложение для разных типов аргументов
```py
@ -121,7 +121,7 @@ uspeh()
'1234'
>>> b1=\[1,2];b2=\[-1,-2];b3=\[0,2];b4=\[-1,-1]
>>> b1=[1,2];b2=[-1,-2];b3=[0,2];b4=[-1,-1]
>>> q=slozh(b1,b2,b3,b4) #Сложение списков
@ -129,7 +129,7 @@ uspeh()
>>> q
\[1, 2, -1, -2, 0, 2, -1, -1]
[1, 2, -1, -2, 0, 2, -1, -1]
```
@ -143,13 +143,13 @@ uspeh()
Traceback (most recent call last):
&nbsp; File "<pyshell#29>", line 1, in <module>
File "<pyshell#29>", line 1, in <module>
&nbsp; slozh({"A" : 1, "B" : 2}, {"C" : 3, "D" : 4}, {"E" : 5, "F" : 6}, {"G" : 7, "H" : 8}) # Сложение словарей
slozh({"A" : 1, "B" : 2}, {"C" : 3, "D" : 4}, {"E" : 5, "F" : 6}, {"G" : 7, "H" : 8}) # Сложение словарей
&nbsp; File "<pyshell#21>", line 3, in slozh
File "<pyshell#21>", line 3, in slozh
&nbsp; return a1+a2+a3+a4
return a1+a2+a3+a4
TypeError: unsupported operand type(s) for +: 'dict' and 'dict'
@ -157,13 +157,13 @@ TypeError: unsupported operand type(s) for +: 'dict' and 'dict'
Traceback (most recent call last):
&nbsp; File "<pyshell#30>", line 1, in <module>
File "<pyshell#30>", line 1, in <module>
&nbsp; slozh({1, 2}, {3, 4}, {5, 6}, {7, 8}) # Сложение множеств
slozh({1, 2}, {3, 4}, {5, 6}, {7, 8}) # Сложение множеств
&nbsp; File "<pyshell#21>", line 3, in slozh
File "<pyshell#21>", line 3, in slozh
&nbsp; return a1+a2+a3+a4
return a1+a2+a3+a4
TypeError: unsupported operand type(s) for +: 'set' and 'set'
@ -173,7 +173,7 @@ TypeError: unsupported operand type(s) for +: 'set' and 'set'
2.5 Функция, реализующая модель некоторого устройства
## 2.5 Функция, реализующая модель некоторого устройства
```py
@ -187,15 +187,15 @@ TypeError: unsupported operand type(s) for +: 'set' and 'set'
... ypred - предыдущее значение выхода устройства"""
... y=(x+T\*ypred)/(T+1)
... y=(x+T*ypred)/(T+1)
... return y
...
>>> sps=\[0]+\[1]\*100
>>> sps=[0]+[1]*100
>>> spsy=\[] #Заготовили список для значений выхода
>>> spsy=[] #Заготовили список для значений выхода
>>> TT=20 #Постоянная времени
@ -213,7 +213,7 @@ TypeError: unsupported operand type(s) for +: 'set' and 'set'
>>> pylab.plot(spsy)
\[<matplotlib.lines.Line2D object at 0x000001EF6C25CA50>]
[<matplotlib.lines.Line2D object at 0x000001EF6C25CA50>]
>>> pylab.xlabel("Время, сек.")
@ -237,15 +237,15 @@ Text(0, 0.5, 'Выходной сигнал')
\## 3. Функции как объекты
## 3. Функции как объекты
\# 3.1 Атрибуты объекта-функции
# 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\_\_']
['\_\_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\_\_ # Использование атрибута объекта-функции
@ -258,18 +258,17 @@ Help on function inerz in module \_\_main\_\_:
inerz(x, T, ypred)
Модель устройства с памятью:
&nbsp; Модель устройства с памятью:
x- текущее значение вх.сигнала,
&nbsp; x- текущее значение вх.сигнала,
T -постоянная времени,
&nbsp; T -постоянная времени,
&nbsp; ypred - предыдущее значение выхода устройства
ypred - предыдущее значение выхода устройства
```
\# 3.2 Сохранение ссылки на объект-функцию в другой переменной
## 3.2 Сохранение ссылки на объект-функцию в другой переменной
```py
@ -283,13 +282,13 @@ inerz(x, T, ypred)
```
\# 3.3 Возможность альтернативного определения функции в программе
## 3.3 Возможность альтернативного определения функции в программе
```py
>>> typ\_fun=8
>>> typ_fun=8
>>> if typ\_fun==1:
>>> if typ_fun==1:
... def func():
@ -309,23 +308,23 @@ inerz(x, T, ypred)
```
\## 4. Аргументы функции
# 4. Аргументы функции
\# 4.1 Использование функции в качестве аргумента другой функции
## 4.1 Использование функции в качестве аргумента другой функции
```py
>>> def fun\_arg(fff,a,b,c):
>>> def fun_arg(fff,a,b,c):
... """fff-имя функции, используемой
... в качестве аргумента функции fun\_arg"""
... в качестве аргумента функции fun_arg"""
... return a+fff(c,b)
...
>>> zz=fun\_arg(logistfun,-3,1,0.7)
>>> zz=fun_arg(logistfun,-3,1,0.7)
>>> zz
@ -333,7 +332,7 @@ inerz(x, T, ypred)
```
\# 4.2 Обязательные и необязательные аргументы
## 4.2 Обязательные и необязательные аргументы
```py
@ -357,7 +356,7 @@ inerz(x, T, ypred)
```
\## 4.3 Обращения к функции с произвольным (непозиционным) расположением аргументов
## 4.3 Обращения к функции с произвольным (непозиционным) расположением аргументов
```py
@ -367,27 +366,27 @@ inerz(x, T, ypred)
```
\## 4.4 Аргументы функции, содержащиеся в списке или кортеже
## 4.4 Аргументы функции, содержащиеся в списке или кортеже
```py
>>> b1234=\[b1,b2,b3,b4] # Список списков из п.2.4
>>> b1234=[b1,b2,b3,b4] # Список списков из п.2.4
>>> qq=slozh(\*b1234) #Перед ссылкой на список или кортеж надо ставить звездочку
>>> qq=slozh(*b1234) #Перед ссылкой на список или кортеж надо ставить звездочку
>>> qq
\[1, 2, -1, -2, 0, 2, -1, -1]
[1, 2, -1, -2, 0, 2, -1, -1]
```
\## 4.5 Аргументы функции, содержащиеся в словаре
## 4.5 Аргументы функции, содержащиеся в словаре
```py
>>> dic4={"a1":1,"a2":2,"a3":3,"a4":4}
>>> qqq=slozh(\*\*dic4) #Перед ссылкой на словарь надо ставить две звездочки
>>> qqq=slozh(**dic4) #Перед ссылкой на словарь надо ставить две звездочки
>>> qqq
@ -395,13 +394,13 @@ inerz(x, T, ypred)
```
\## 4.6 Смешанные ссылки
## 4.6 Смешанные ссылки
```py
>>> e1=(-1,6);dd2={'a3':3,'a4':9}
>>> qqqq=slozh(\*e1,\*\*dd2)
>>> qqqq=slozh(*e1,**dd2)
>>> qqqq
@ -409,11 +408,11 @@ inerz(x, T, ypred)
```
\## 4.7 Переменное число аргументов у функции
## 4.7 Переменное число аргументов у функции
```py
>>> def func4(\*kort7):
>>> def func4(*kort7):
... """Произвольное число аргументов в составе кортежа"""
@ -437,11 +436,11 @@ inerz(x, T, ypred)
```
\## 4.8 Комбинация аргументов
## 4.8 Комбинация аргументов
```py
>>> def func4(a,b=7,\*kort7): #Аргументы: a-позиционный, b- по умолчанию + кортеж
>>> def func4(a,b=7,*kort7): #Аргументы: a-позиционный, b- по умолчанию + кортеж
... """Кортеж - сборка аргументов - должен быть последним!"""
@ -451,7 +450,7 @@ inerz(x, T, ypred)
... smm+=elt
... return a\*smm+b
... return a*smm+b
...
@ -463,7 +462,7 @@ inerz(x, T, ypred)
```py
>>> def func4(a, b = 7, \*\*dict7):
>>> def func4(a, b = 7, **dict7):
... """Словарь - сборка аргументов - должен быть последним!"""
@ -473,11 +472,11 @@ inerz(x, T, ypred)
... smm += el
... return a \* smm + b
... return a * smm + b
...
>>> func4(-1, 2, \*\*{"a1" : 0, "a2" : 3, "a3" : 6})
>>> func4(-1, 2, **{"a1" : 0, "a2" : 3, "a3" : 6})
-7
@ -487,7 +486,7 @@ inerz(x, T, ypred)
\## 4.9 Изменение значений объектов с помощью функций
## 4.9 Изменение значений объектов с помощью функций
```py
@ -495,7 +494,7 @@ inerz(x, T, ypred)
>>> def func3(b):
... b=5\*b+67
... b=5*b+67
...
@ -505,11 +504,11 @@ inerz(x, T, ypred)
90
>>> sps1=\[1,2,3,4] #Список – изменяемый тип объекта
>>> sps1=[1,2,3,4] #Список – изменяемый тип объекта
>>> def func2(sps):
... sps\[1]=99
... sps[1]=99
...
@ -517,7 +516,7 @@ inerz(x, T, ypred)
>>> print(sps1)
\[1, 99, 3, 4]
[1, 99, 3, 4]
>>> kort=(1,2,3,4) #Кортеж – неизменяемый тип объекта
@ -525,21 +524,21 @@ inerz(x, T, ypred)
Traceback (most recent call last):
&nbsp; File "<pyshell#90>", line 1, in <module>
File "<pyshell#90>", line 1, in <module>
&nbsp; func2(kort)
func2(kort)
&nbsp; File "<pyshell#86>", line 2, in func2
File "<pyshell#86>", line 2, in func2
&nbsp; sps\[1]=99
sps[1]=99
TypeError: 'tuple' object does not support item assignment
```
\# 5. Специальные типы пользовательских функций.
# 5. Специальные типы пользовательских функций.
\## 5.1 Анонимные функции
## 5.1 Анонимные функции
@ -577,7 +576,7 @@ lambda \[<Список аргументов >]: <Возвращаемое зна
```
\## 5.2 Функции-генераторы
## 5.2 Функции-генераторы
Функции-генераторы – функции, которые используются в итерационных процессах, позволяя на каждой итерации получать одно из значений. Для этого в функцию включают инструкцию yield приостанавливающую её выполнение и возвращающую очередное значение.
@ -625,9 +624,9 @@ lambda \[<Список аргументов >]: <Возвращаемое зна
Traceback (most recent call last):
&nbsp; File "<pyshell#106>", line 1, in <module>
File "<pyshell#106>", line 1, in <module>
&nbsp; print(alp.\_\_next\_\_())
print(alp.\_\_next\_\_())
StopIteration
@ -637,9 +636,9 @@ StopIteration
\# 6. Локализация объектов
# 6. Локализация объектов
\## 6.1 Примеры на локализацию объектов
## 6.1 Примеры на локализацию объектов
```py
@ -651,7 +650,7 @@ StopIteration
... glb=8
... return loc1\*arg
... return loc1*arg
...
@ -679,19 +678,19 @@ StopIteration
... glb=8
... return loc1\*arg
... return loc1*arg
>>> res=func8(glb)
Traceback (most recent call last):
&nbsp; File "<pyshell#114>", line 1, in <module>
File "<pyshell#114>", line 1, in <module>
&nbsp; res=func8(glb)
res=func8(glb)
&nbsp; File "<pyshell#113>", line 3, in func8
File "<pyshell#113>", line 3, in func8
&nbsp; print(glb)
print(glb)
UnboundLocalError: cannot access local variable 'glb' where it is not associated with a value
@ -715,7 +714,7 @@ UnboundLocalError: cannot access local variable 'glb' where it is not associated
... glb=8
... return loc1\*arg
... return loc1*arg
...
@ -737,7 +736,7 @@ UnboundLocalError: cannot access local variable 'glb' where it is not associated
\# 6.2 Функции для выявления локализации объектов
## 6.2 Функции для выявления локализации объектов
```py
@ -767,33 +766,33 @@ True
```
\# 6.3 Локализация объектов при использовании вложенных функций
## 6.3 Локализация объектов при использовании вложенных функций
```py
>>> def func9(arg2,arg3):
... def func9\_1(arg1):
... def func9_1(arg1):
... loc1=15
... glb1=8
... print('glob\_func9\_1:',globals().keys())
... print('glob_func9_1:',globals().keys())
... print('locl\_func9\_1:',locals().keys())
... print('locl_func9_1:',locals().keys())
... return loc1\*arg1
... return loc1*arg1
... loc1=5
... glb=func9\_1(loc1)
... glb=func9_1(loc1)
... print('loc\_func9:',locals().keys())
... print('loc_func9:',locals().keys())
... print('glob\_func9:',globals().keys())
... print('glob_func9:',globals().keys())
... return arg2+arg3\*glb
... return arg2+arg3*glb
...
@ -813,7 +812,7 @@ glob\_func9: dict\_keys(\['\_\_name\_\_', '\_\_doc\_\_', '\_\_package\_\_', '\_\
```
\# 6.4 Моделирование некоторой системы с помощью нескольких функций
## 6.4 Моделирование некоторой системы с помощью нескольких функций
@ -827,19 +826,19 @@ glob\_func9: dict\_keys(\['\_\_name\_\_', '\_\_doc\_\_', '\_\_package\_\_', '\_\
k1,T,k2,Xm,A,F,N=5,2,7,1,3,0.1,50
>>> k1=float(znach\[0])
>>> k1=float(znach[0])
>>> T = float(znach\[1])
>>> T = float(znach[1])
>>> k2 = float(znach\[2])
>>> k2 = float(znach[2])
>>> Xm = float(znach\[3])
>>> Xm = float(znach[3])
>>> A = float(znach\[4])
>>> A = float(znach[4])
>>> F = float(znach\[5])
>>> F = float(znach[5])
>>> N = int(znach\[6])
>>> N = int(znach[6])
```
@ -851,17 +850,17 @@ k1,T,k2,Xm,A,F,N=5,2,7,1,3,0.1,50
>>> import math
>>> vhod=\[]
>>> vhod=[]
>>> for i in range(N):
... vhod.append(A\*math.sin((2\*i\*math.pi)/F))
... vhod.append(A*math.sin((2*i*math.pi)/F))
...
>>> vhod
\[0.0, -7.34788079488412e-15, -1.469576158976824e-14, -6.467620653025836e-14, -2.939152317953648e-14, -1.6463709641123863e-13, -1.2935241306051673e-13, -9.406772970979485e-14, -5.878304635907296e-14, -2.3498363008351057e-14, -3.2927419282247726e-13, -2.9398950947175535e-13, -2.5870482612103345e-13, 1.1764037039453651e-13, -1.881354594195897e-13, -4.939112892337158e-13, -1.1756609271814592e-13, -8.228140936742402e-14, -4.6996726016702114e-14, -6.938330689956763e-13, -6.585483856449545e-13, 5.885732403546355e-14, -5.879790189435107e-13, -5.526943355927888e-13, -5.174096522420669e-13, -4.82124968891345e-13, 2.3528074078907303e-13, -4.115556021899013e-13, -3.762709188391794e-13, -3.409862354884575e-13, -9.878225784674317e-13, -9.525378951167099e-13, -2.3513218543629184e-13, -8.819685284152661e-13, -1.6456281873484803e-13, -8.113991617138223e-13, -9.399345203340423e-14, -7.408297950123785e-13, -1.3876661379913526e-12, -6.702604283109348e-13, -1.317096771289909e-12, -1.9639331142688832e-12, 1.177146480709271e-13, -5.291216949080472e-13, -1.1759580378870214e-12, -4.585523282066034e-13, -1.1053886711855776e-12, -3.879829615051596e-13, -1.0348193044841338e-12, -1.6816556474631084e-12]
[0.0, -7.34788079488412e-15, -1.469576158976824e-14, -6.467620653025836e-14, -2.939152317953648e-14, -1.6463709641123863e-13, -1.2935241306051673e-13, -9.406772970979485e-14, -5.878304635907296e-14, -2.3498363008351057e-14, -3.2927419282247726e-13, -2.9398950947175535e-13, -2.5870482612103345e-13, 1.1764037039453651e-13, -1.881354594195897e-13, -4.939112892337158e-13, -1.1756609271814592e-13, -8.228140936742402e-14, -4.6996726016702114e-14, -6.938330689956763e-13, -6.585483856449545e-13, 5.885732403546355e-14, -5.879790189435107e-13, -5.526943355927888e-13, -5.174096522420669e-13, -4.82124968891345e-13, 2.3528074078907303e-13, -4.115556021899013e-13, -3.762709188391794e-13, -3.409862354884575e-13, -9.878225784674317e-13, -9.525378951167099e-13, -2.3513218543629184e-13, -8.819685284152661e-13, -1.6456281873484803e-13, -8.113991617138223e-13, -9.399345203340423e-14, -7.408297950123785e-13, -1.3876661379913526e-12, -6.702604283109348e-13, -1.317096771289909e-12, -1.9639331142688832e-12, 1.177146480709271e-13, -5.291216949080472e-13, -1.1759580378870214e-12, -4.585523282066034e-13, -1.1053886711855776e-12, -3.879829615051596e-13, -1.0348193044841338e-12, -1.6816556474631084e-12]
```
@ -875,13 +874,13 @@ k1,T,k2,Xm,A,F,N=5,2,7,1,3,0.1,50
... #Модель реального двигателя
... yp=kk1\*xtt #усилитель
... yp=kk1*xtt #усилитель
... yti1=yp+yti1 #Интегратор
... ytin1=(yti1+TT\*ytin1)/(TT+1)
... ytin1=(yti1+TT*ytin1)/(TT+1)
... return \[yti1,ytin1]
... return [yti1,ytin1]
...
@ -889,7 +888,7 @@ k1,T,k2,Xm,A,F,N=5,2,7,1,3,0.1,50
... #Модель тахогенератора
... yp=kk2\*xtt #усилитель
... yp=kk2*xtt #усилитель
... yti2=yp+yti2 #интегратор
@ -925,13 +924,13 @@ k1,T,k2,Xm,A,F,N=5,2,7,1,3,0.1,50
>>> yi1=0;yin1=0;yi2=0
>>> vyhod=\[]
>>> vyhod=[]
>>> for xt in vhod:
... xt1=xt-yi2 #отрицательная обратная связь
... \[yi1,yin1]=realdvig(xt1,k1,T,yi1,yin1)
... [yi1,yin1]=realdvig(xt1,k1,T,yi1,yin1)
... yi2=tahogen(yin1,k2,yi2)
@ -945,7 +944,7 @@ k1,T,k2,Xm,A,F,N=5,2,7,1,3,0.1,50
>>> print('y=',vyhod)
y= \[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0.6089539155942427, -13.036146587349938, 121.44813795602693, -1067.2095969566972, 9317.816619654644, -81294.22842535547, 709200.0106510338, -6186906.685120374, 53973168.988947384, -470849610.29481155, 4107584498.8890133, -35833629291.65392, 312604400058.94775, -2727089409189.0786, 23790505329708.062, -207542936412563.75, 1810557189004300.2, -1.579488751252292e+16, 1.3779099221408792e+17, -1.2020571542715681e+18, 1.0486472148269562e+19, -9.148158864631634e+19, 7.980644913680371e+20, -6.962132400705417e+21, 6.073605340072578e+22, -5.298474620106407e+23, 4.622268278560269e+24, -4.032361306008378e+25, 3.517739932494396e+26, -3.0687959965857205e+27, 2.677147557631607e+28, -2.335482401993116e+29, 2.037421521451343e+30, -1.7774000148879483e+31]
y= [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0.6089539155942427, -13.036146587349938, 121.44813795602693, -1067.2095969566972, 9317.816619654644, -81294.22842535547, 709200.0106510338, -6186906.685120374, 53973168.988947384, -470849610.29481155, 4107584498.8890133, -35833629291.65392, 312604400058.94775, -2727089409189.0786, 23790505329708.062, -207542936412563.75, 1810557189004300.2, -1.579488751252292e+16, 1.3779099221408792e+17, -1.2020571542715681e+18, 1.0486472148269562e+19, -9.148158864631634e+19, 7.980644913680371e+20, -6.962132400705417e+21, 6.073605340072578e+22, -5.298474620106407e+23, 4.622268278560269e+24, -4.032361306008378e+25, 3.517739932494396e+26, -3.0687959965857205e+27, 2.677147557631607e+28, -2.335482401993116e+29, 2.037421521451343e+30, -1.7774000148879483e+31]
```

@ -1,28 +1,28 @@
\# Общее контрольное задание по теме 7
# Общее контрольное задание по теме 7
Бережков Дмитрий А-01-23
\## Задание:
## Задание:
1\.Разработайте и проверьте функцию, реализующую для момента времени t расчет выхода y(t) для устройства задержки: на вход поступает сигнал, а на выходе повторяется этот сигнал с задержкой на заданное время Т.
1.Разработайте и проверьте функцию, реализующую для момента времени t расчет выхода y(t) для устройства задержки: на вход поступает сигнал, а на выходе повторяется этот сигнал с задержкой на заданное время Т.
2\.Разработайте и проверьте функцию, реализующую расчет гистограммы по выборке случайной величины с каким-то распределением. Гистограмма при выводе на экран представляется в виде таблицы: границы интервала, число элементов выборки в интервале. Аргументы функции: выборка, число интервалов разбиения диапазона изменения случайной величины. Возвращаемый результат функции: список с числами элементов выборки в интервалах разбиения.
2.Разработайте и проверьте функцию, реализующую расчет гистограммы по выборке случайной величины с каким-то распределением. Гистограмма при выводе на экран представляется в виде таблицы: границы интервала, число элементов выборки в интервале. Аргументы функции: выборка, число интервалов разбиения диапазона изменения случайной величины. Возвращаемый результат функции: список с числами элементов выборки в интервалах разбиения.
3\.Разработайте и проверьте анонимную функцию, вычисляющую значение оценки отклика Y линейной регрессии при значении переменной Х
3.Разработайте и проверьте анонимную функцию, вычисляющую значение оценки отклика Y линейной регрессии при значении переменной Х
Y=b1+b2\*X
Y=b1+b2*X
и имеющую аргументы b1, b2 и X.
\## Решение:
## Решение:
1\.
1.
```py
@ -30,53 +30,53 @@ Y=b1+b2\*X
... """Функция для реализации задержки сигнала в определенный момент времени x - исходный сигнал T - заданная задержка"""
... return\[0] \*T+x
... return[0] *T+x
...
>>> x=\[1,2,3,4]
>>> x=[1,2,3,4]
>>> y=crDelay(x,4)
>>> print(y)
\[0, 0, 0, 0, 1, 2, 3, 4]
[0, 0, 0, 0, 1, 2, 3, 4]
```
2\.
2.
```py
>>> def raschet\_gistogrammy(viborka,kol\_int):
>>> def raschet_gistogrammy(viborka,kol_int):
... Min=min(viborka)
... Max=max(viborka)
... shirina\_int=(Max-Min)/kol\_int
... shirina_int=(Max-Min)/kol_int
... x=\[0]\*kol\_int
... x=[0]*kol_int
... for znach in viborka:
... num\_int=int((znach-Max)/shirina\_int)
... num_int=int((znach-Max)/shirina_int)
... if num\_int == kol\_int:
... if num_int == kol_int:
... num\_int = kol\_int - 1
... num_int = kol_int - 1
... x\[num\_int] += 1
... x[num_int] += 1
... print("Гистограмма:")
... for i in range(kol\_int):
... for i in range(kol_int):
... start = Max + i \* shirina\_int
... start = Max + i * shirina_int
... end = Max + (i + 1) \* shirina\_int
... end = Max + (i + 1) * shirina_int
... print(f"\[{start:.2f}, {end:.2f}]: {x\[i]}")
... print(f"[{start:.2f}, {end:.2f}]: {x[i]}")
... return x
@ -84,33 +84,33 @@ Y=b1+b2\*X
>>> import random
>>> rand=\[random.gauss(0, 1) for \_ in range(100)]
>>> rand=[random.gauss(0, 1) for _ in range(100)]
>>> kol\_int=5
>>> kol_int=5
res = raschet\_gistogrammy(rand, kol\_int)
res = raschet_gistogrammy(rand, kol_int)
Гистограмма:
\[2.31, 3.30]: 8
[2.31, 3.30]: 8
\[3.30, 4.30]: 5
[3.30, 4.30]: 5
\[4.30, 5.30]: 21
[4.30, 5.30]: 21
\[5.30, 6.29]: 44
[5.30, 6.29]: 44
\[6.29, 7.29]: 22
[6.29, 7.29]: 22
```
3\.
3.
```py
anonim\_f = lambda b1, b2, X: b1 + b2 \* X
anonim_f = lambda b1, b2, X: b1 + b2 * X
print(anonim\_f(3,8,2))
print(anonim_f(3,8,2))
19

@ -0,0 +1,39 @@
# Модуль 2, тема 7 (вариант 10)
Бережков Дмитрий А-01-23
## Задание:
10. Разработайте функцию c 3 аргументами, реализующую запись заданной последовательности – списка или кортежа (аргумент функции) в текстовый файл с заданным именем (аргумент функции) с заданным числом (аргумент функции) элементов на строке файла, разделенных запятыми. Проверьте её на записи в файл кортежа с 50 случайными, нормально распределенными числами с математическим ожиданием 23 и дисперсией 144 по 3 элемента в строке.
## Выполнение:
```py
>>> def writef(obj,file,elem):
... """Запись последовательности списка или кортежа в текстовый файл с заданным числом элементов на строке"""
... with open (file,'w') as f:
... for i in range (0, len(obj), elem):
... line=obj[i:i+elem]
... f.write(','.join(str(x) for x in line) + '\n')
...
...
>>> numbers = [random.gauss(23,144) for x in range(50)]
>>> writef(numbers,'data1.txt',3)
```
Содержание файла data1.txt:
```py
241.71253896985093,248.0922049180413,63.93243805946962
-2.5613050572585365,-233.7356532046805,-43.71100872873404
-41.49388804453271,-18.877485553159943,-173.17954591286244
-34.188892969567426,269.22621427055026,-23.4777258431589
-150.0402089008563,-138.74013440973553,-44.13484238897196
155.8084571292971,124.18947811800096,-301.857271693554
123.73124009550004,-35.81862040280841,25.20824985373494
41.75645794585994,176.94308189535528,-146.535894889846
-14.5752858782325,244.43818392211853,74.31067862406104
54.861820682068505,140.74882354369083,204.004266081046
-291.65666897188805,-106.89837867764746,166.50068888913614
-38.919945617204526,111.8105712401512,208.76866045851344
105.23012130358175,-47.31240986990848,-86.86012792518429
-163.38008193138268,-90.34734159020095,45.12346410839757
197.16134782865944,-69.11221675096985,54.195564115622666
-42.973125559518735,-124.44829722682891,-89.63808266609591
-5.301952011199695,263.76559727114915
```
Загрузка…
Отмена
Сохранить