-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathfree_fall_cart_and_pendulum.py
46 lines (33 loc) · 1.5 KB
/
free_fall_cart_and_pendulum.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
import numpy as np
import cv2
from InvertedPendulum import InvertedPendulum
from scipy.integrate import solve_ivp
# Pendulum and Cart system.
# Y : [ x, x_dot, theta, theta_dot]
# returns expression for Y_dot.
def func2( t, y ):
g = 9.8 # Gravitational Acceleration
L = 1.5 # Length of pendulum
m = 1.0 #mass of bob (kg)
M = 5.0 # mass of cart (kg)
x_ddot = L * y[3]*y[3] * np.cos( y[2] ) - g * np.cos(y[2]) * np.sin(y[2])
x_ddot = m / ( m* np.sin(y[2])* np.sin(y[2]) - M -m ) * x_ddot
theta_ddot = -g/L * np.cos( y[2] ) - 1./L * np.sin( y[2] ) * x_ddot
damping_theta = - 0.5*y[3]
damping_x = - 1.0*y[1]
return [ y[1], x_ddot + damping_x, y[3], theta_ddot + damping_theta ]
pass
# Both cart and the pendulum can move.
if __name__=="__main__":
# We need to write the Euler-lagrange equations for the both the
# systems (bob and cart). The equations are complicated expressions. Although
# it is possible to derive with hand. The entire notes are in media folder or the
# blog post for this entry. Otherwse in essense it is very similar to free_fall_pendulum.py
# For more comments see free_fall_pendulum.py
sol = solve_ivp(func2, [0, 20], [ -1.0, 0., np.pi/2 + 0.1, 0. ], t_eval=np.linspace( 0, 20, 300) )
syst = InvertedPendulum()
for i, t in enumerate(sol.t):
rendered = syst.step( [sol.y[0,i], sol.y[1,i], sol.y[2,i], sol.y[3,i] ], t )
cv2.imshow( 'im', rendered )
if cv2.waitKey(30) == ord('q'):
break