-
Notifications
You must be signed in to change notification settings - Fork 2
/
export_disturbed_chain_mass_model.py
61 lines (43 loc) · 1.37 KB
/
export_disturbed_chain_mass_model.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
from acados_template import AcadosModel
from casadi import SX, vertcat, sin, cos, norm_2
import numpy as np
def export_disturbed_chain_mass_model(n_mass, m, D, L):
model_name = 'chain_mass_ds_' + str(n_mass)
x0 = np.array([0, 0, 0]) # fix mass (at wall)
M = n_mass - 2 # number of intermediate massesu
nx = (2*M + 1)*3 # differential states
nu = 3 # control inputs
xpos = SX.sym('xpos', (M+1)*3, 1) # position of fix mass eliminated
xvel = SX.sym('xvel', M*3, 1)
u = SX.sym('u', nu, 1)
xdot = SX.sym('xdot', nx, 1)
w = SX.sym('w', M*3, 1)
f = SX.zeros(3*M, 1) # force on intermediate masses
for i in range(M):
f[3*i+2] = - 9.81
for i in range(M+1):
if i == 0:
dist = xpos[i*3:(i+1)*3] - x0
else:
dist = xpos[i*3:(i+1)*3] - xpos[(i-1)*3:i*3]
scale = D/m*(1-L/ norm_2(dist))
F = scale*dist
# mass on the right
if i < M:
f[i*3:(i+1)*3] -= F
# mass on the left
if i > 0:
f[(i-1)*3:i*3] += F
x = vertcat(xpos, xvel)
# dynamics
f_expl = vertcat(xvel, u, f+w)
f_impl = xdot - f_expl
model = AcadosModel()
model.f_impl_expr = f_impl
model.f_expl_expr = f_expl
model.x = x
model.xdot = xdot
model.u = u
model.p = w
model.name = model_name
return model