-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_tmotor.py
78 lines (60 loc) · 1.72 KB
/
test_tmotor.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
from rPyControl.hardware.can import CANSocket
from rPyControl.hardware.actuators.tmotor import TMotorQDD
from time import perf_counter
import matplotlib.pyplot as plt
from numpy import sin, cos, pi
bus = CANSocket(interface='can0')
motor = TMotorQDD(bus, device_id=0x002)
motor.torque_limit = 6
time = []
angle = []
err = []
desired = []
t0 = perf_counter()
t_con = 1./2000.
t_log = 1e-2
tl = 0
tc = 0
alpha, dalpha, ddalpha= 0, 0, 0
kp = 6.
kd = 1.1
try:
motor.enable()
while True:
t = perf_counter() - t0
if t - tc >= t_con:
# alpha_d, dalpha_d, ddalpha_d = sin(t*2), 2*cos(t*2), -4*sin(t*2)
alpha_d, dalpha_d = 0, 0
alpha = motor.state['pos']
dalpha = motor.state['vel']
e, de= alpha_d - alpha, dalpha_d - dalpha
u = kp*e + kd*de
motor.set_torque(u)
tc = t
if t - tl >= t_log:
print(f"time {round(t, 4)}, pos: {round(alpha, 3)}, speed: {round(dalpha, 3)}")
print(motor.state['tor'])
time.append(t)
angle.append(alpha)
desired.append(alpha_d)
err.append(alpha-alpha_d)
tl = t
except KeyboardInterrupt:
motor.set_torque(0)
motor.disable()
# except:
# motor.set_torque(0)
# motor.disable()
plt.figure(figsize=(7, 3))
plt.plot(time, desired, 'b--', label=r'$\alpha_d$')
plt.plot(time, angle, 'r', label=r'$\alpha$')
plt.plot(time, err, 'g', label='err')
plt.ylabel(r'Angle $\alpha$ (rad)')
plt.xlabel(r'Time $t$ (s)')
plt.grid(color='gray', linestyle='--', alpha=0.7)
plt.grid(True)
plt.xlim([time[0], time[-1]])
plt.legend()
plt.tight_layout()
plt.savefig('angles.png', dpi=300)
plt.show()