-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain_nonanalytical_example_3.py
executable file
·79 lines (63 loc) · 1.55 KB
/
main_nonanalytical_example_3.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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
from bernstein_optimizer import BernsteinOptimizer
import numpy as np
import matplotlib.pyplot as plt
plt.rcParams.update(
{
"text.usetex": True,
"font.family": "serif",
}
)
import sys
from nonanalytical_examples.example_3 import *
opt = BernsteinOptimizer(
dynamicsf=xdot,
costf=costf,
constraints=constraints,
u_sz=u_sz,
x_sz=x_sz,
u_is_sigm_limited=True,
u_sigm_bounds=u_bounds,
n_max=3,
u_bounds=[-100, 100],
tf_is_variable=tf_is_variable,
init_is_random=False,
n_is_adaptive=False,
initial_dynamics=initial_dynamics,
tf=tf,
tf_max=tf_max,
)
p = opt.minimize()
if opt.tf_is_variable:
tf = p[-1]
print(p)
x, u, s = opt.get_s_of_t(p)
t = np.linspace(0, tf, 100)
s_values = np.array([s(ti) for ti in t])
# plotting
t = np.linspace(0, tf, 100)
s_values = np.array([s(ti) for ti in t])
plt.figure()
for i in range(s_values.shape[1]):
if i < x_sz:
ylabel = "$x_" + str(i + 1) + "$"
else:
if i == x_sz:
plt.figure()
ylabel = "$u_" + str(i - x_sz + 1) + "$"
plt.plot(t, s_values[:, i], label=ylabel)
plt.xlabel("$t$")
plt.ylabel("$" + ylabel[1] + "$")
plt.legend()
plt.grid()
plt.gca().set_aspect("auto")
plt.savefig("figures/" + sys.argv[0][:-3] + "_" + ylabel[1] + ".pdf")
# xy plot
plt.figure()
plt.plot(s_values[:, 0], s_values[:, 1], label="path")
plt.xlabel("$x$")
plt.ylabel("$y$")
plt.legend()
plt.grid()
plt.gca().set_aspect("equal")
plt.savefig("figures/" + sys.argv[0][:-3] + "_" + "xy" + ".pdf")
plt.show()