-
Notifications
You must be signed in to change notification settings - Fork 180
/
Copy pathcartpole_swing_up.py
91 lines (73 loc) · 2.9 KB
/
cartpole_swing_up.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
80
81
82
83
84
85
86
87
88
89
90
91
# Display the solution
import numpy as np
from cartpole_utils import animateCartpole
import crocoddyl
class DifferentialActionModelCartpole(crocoddyl.DifferentialActionModelAbstract):
def __init__(self):
crocoddyl.DifferentialActionModelAbstract.__init__(
self, crocoddyl.StateVector(4), 1, 6
) # nu = 1; nr = 6
self.unone = np.zeros(self.nu)
self.m1 = 1.0
self.m2 = 0.1
self.length = 0.5
self.g = 9.81
self.costWeights = [
1.0,
1.0,
0.1,
0.001,
0.001,
1.0,
] # sin, 1-cos, x, xdot, thdot, f
def calc(self, data, x, u=None):
if u is None:
u = model.unone
# Getting the state and control variables
y, th, ydot, thdot = x[0], x[1], x[2], x[3]
f = u[0]
# Shortname for system parameters
m1, m2, length, g = self.m1, self.m2, self.length, self.g
s, c = np.sin(th), np.cos(th)
# Defining the equation of motions
m = m1 + m2
mu = m1 + m2 * s**2
xddot = (f + m2 * c * s * g - m2 * length * s * thdot**2) / mu
thddot = (c * f / length + m * g * s / length - m2 * c * s * thdot**2) / mu
data.xout = np.matrix([xddot, thddot]).T
# Computing the cost residual and value
data.r = np.matrix(self.costWeights * np.array([s, 1 - c, y, ydot, thdot, f])).T
data.cost = 0.5 * sum(np.asarray(data.r) ** 2)
def calcDiff(self, data, x, u=None):
# Advance user might implement the derivatives
pass
# Creating the DAM for the cartpole
cartpoleDAM = DifferentialActionModelCartpole()
cartpoleData = cartpoleDAM.createData()
cartpoleDAM = model = DifferentialActionModelCartpole()
# Using NumDiff for computing the derivatives. We specify the
# withGaussApprox=True to have approximation of the Hessian based on the
# Jacobian of the cost residuals.
cartpoleND = crocoddyl.DifferentialActionModelNumDiff(cartpoleDAM, True)
# Getting the IAM using the simpletic Euler rule
timeStep = 5e-2
cartpoleIAM = crocoddyl.IntegratedActionModelEuler(cartpoleND, timeStep)
# Creating the shooting problem
x0 = np.array([0.0, 3.14, 0.0, 0.0])
T = 50
terminalCartpole = DifferentialActionModelCartpole()
terminalCartpoleDAM = crocoddyl.DifferentialActionModelNumDiff(terminalCartpole, True)
terminalCartpoleIAM = crocoddyl.IntegratedActionModelEuler(terminalCartpoleDAM)
terminalCartpole.costWeights[0] = 100
terminalCartpole.costWeights[1] = 100
terminalCartpole.costWeights[2] = 1.0
terminalCartpole.costWeights[3] = 0.1
terminalCartpole.costWeights[4] = 0.01
terminalCartpole.costWeights[5] = 0.0001
problem = crocoddyl.ShootingProblem(x0, [cartpoleIAM] * T, terminalCartpoleIAM)
# Solving it using DDP
ddp = crocoddyl.SolverDDP(problem)
ddp.setCallbacks([crocoddyl.CallbackVerbose()])
ddp.solve([], [], 300)
# Display animation
animateCartpole(ddp.xs, show=True)