-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpid3.py
59 lines (47 loc) · 1009 Bytes
/
pid3.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import numpy as np
import matplotlib.pyplot as plt
Kp = 2.9556870827270654
Ti = 18.62385932338612
Td = 4.868346929787249
T = 1
q0 = Kp*(1 + T/Ti + Td/T)
q1 = -Kp*(1 + 2*Td/T)
q2 = Td*Kp / T
b1 = 0.00462
b2 = 0.00169
b3 = -0.00273
a1 = -2.48824
a2 = 2.05387
a3 = -0.56203
step_num = 100
e = np.zeros(step_num)
u = np.zeros(step_num)
y = np.zeros(step_num)
du = np.zeros(step_num)
for k in range(step_num):
e[k] = 1 - y[k-1]
du[k] = q0*e[k] + q1*e[k-1] + q2*e[k-2]
u[k] = du[k] + u[k-1]
y[k] = b1*u[k-1] + b2*u[k-2] + b3*u[k-3] - (a1*y[k-1] + a2*y[k-2]+ a3*y[k-3])
t = np.linspace(start=0, stop=step_num-1, num=step_num, dtype=int)
plt.subplot(2,2,1)
plt.plot(t, y)
plt.xlabel('t')
plt.ylabel('y')
plt.title('y(k)')
plt.subplot(2,2,2)
plt.plot(t, u)
plt.xlabel('t')
plt.ylabel('u')
plt.title('u(k)')
plt.subplot(2,2,3)
plt.plot(t, du)
plt.xlabel('t')
plt.ylabel('du')
plt.title('du(k)')
plt.subplot(2,2,4)
plt.plot(t, e)
plt.xlabel('t')
plt.ylabel('e')
plt.title('e(k)')
plt.show()