generated from microsoft/python-package-template
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMDH2MR.py
109 lines (92 loc) · 3.21 KB
/
MDH2MR.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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
import xml.etree.ElementTree as ET
import numpy as np
np.set_printoptions(suppress=True)
class MDHParameters:
def __init__(self, alpha, a, d, theta):
self.alpha = alpha
self.a = a
self.d = d
self.theta = theta
def TransInv(T):
# Extract the rotation matrix R and the position vector p from the transformation matrix T
R = T[0:3, 0:3]
p = T[0:3, 3]
# Compute the inverse transformation matrix
invT = np.eye(4)
invT[0:3,0:3] = R.T;
val = -R.T@p;
invT[0,3] = val[0];
invT[1,3] = val[1];
invT[2,3] = val[2];
return invT
def JacobianBodyMDH(MDH, thetalist):
T = np.eye(4)
N = len(thetalist)
Jb = np.zeros((6, N))
for i in range(0,N):
Si = np.zeros((N, 1))
Si[i] = 1
Ei = np.array([[0, 0, 0, 0, 0, 1]]).T
T_ = RotX(MDH.alpha[i]) @ TransX(MDH.a[i]) @ TransZ(MDH.d[i]) @ RotZ(thetalist[i] + MDH.theta[i])
AdInv = Adjoint(TransInv(T_))
Jb = AdInv @ Jb + Ei @ Si.T
T = T @ T_
return Jb,T
def VecToso3(omg):
# Build the 3x3 skew-symmetric matrix in so(3)
so3mat = np.array([[0, -omg[2], omg[1]],
[omg[2], 0, -omg[0]],
[-omg[1], omg[0], 0]])
return so3mat
def Adjoint(T):
# Extract the rotation matrix R and the position vector p from the transformation matrix T
R = T[:3, :3]
p = T[:3, 3]
# Build the 6x6 adjoint representation [AdT]
AdT = np.eye(6)
AdT[0:3,0:3] = R;
AdT[0:3,3:6] = VecToso3(p)@R;
AdT[3:6,3:6] = R;
return AdT
def RotX(alpha):
return np.array([[1, 0, 0, 0],
[0, np.cos(alpha), -np.sin(alpha), 0],
[0, np.sin(alpha), np.cos(alpha), 0],
[0, 0, 0, 1]])
def TransX(a):
return np.array([[1, 0, 0, a],
[0, 1, 0, 0],
[0, 0, 1, 0],
[0, 0, 0, 1]])
def TransZ(d):
return np.array([[1, 0, 0, 0],
[0, 1, 0, 0],
[0, 0, 1, d],
[0, 0, 0, 1]])
def RotZ(theta):
return np.array([[np.cos(theta), -np.sin(theta), 0, 0],
[np.sin(theta), np.cos(theta), 0, 0],
[0, 0, 1, 0],
[0, 0, 0, 1]])
alpha = np.array([0.027 ,90.0671, 0.048, 89.931 ,90.0741 ,-89.9951])*np.pi/180.0;
a = np.array([0.9083 ,0.0165, 448.1241 ,-0.0472 ,0.0218 ,0.319 ])/1000;
d = np.array([300.3872, -0.4393, 3.0607, 349.5632 ,182.7953 ,227.0154 ])/1000;
theta = np.array([0.0196, 89.9967 ,89.9783, 179.9989 ,0.1645 ,-0.0724])*np.pi/180.0;
# Create an instance of MDHParameters
MDH = MDHParameters(alpha, a, d, theta)
# Now you can use the MDH and JacobianBodyMDH as before
# For example:
thetalist = np.array([0 ,0 ,0 ,0 ,0, 0]) # Sample thetalist
Blist,M = JacobianBodyMDH(MDH, thetalist)
Slist = Adjoint(M)@ Blist
Slist_flip = np.zeros(len(thetalist),1)
Blist_flip = np.zeros(len(thetalist),1)
Slist_flip[0:3,:] = Slist[3:6,:]
Slist_flip[3:6,:] = Slist[0:3,:]
Blist_flip[0:3,:] = Blist[3:6,:]
Blist_flip[3:6,:] = Blist[0:3,:]
print("M:\n" ,M)
print("LR Blist : \n",Blist)
print("LR Slist : \n",Slist)
print("MR Blist : \n",Blist_flip)
print("MR Slist : \n",Slist_flip)