Skip to content

Commit

Permalink
Merge pull request #1 from baxter-flowers/master
Browse files Browse the repository at this point in the history
Allow providing a seed for FK and Jacobian + cast IK result into a list of joint values
  • Loading branch information
Ian McMahon committed Jul 28, 2015
2 parents 8299286 + 4235b03 commit 8b95af3
Showing 1 changed file with 27 additions and 24 deletions.
51 changes: 27 additions & 24 deletions src/baxter_pykdl/baxter_pykdl.py
Original file line number Diff line number Diff line change
Expand Up @@ -81,15 +81,19 @@ def print_kdl_chain(self):
for idx in xrange(self._arm_chain.getNrOfSegments()):
print '* ' + self._arm_chain.getSegment(idx).getName()

def joints_to_kdl(self, type):
def joints_to_kdl(self, type, values=None):
kdl_array = PyKDL.JntArray(self._num_jnts)

if type == 'positions':
cur_type_values = self._limb_interface.joint_angles()
elif type == 'velocities':
cur_type_values = self._limb_interface.joint_velocities()
elif type == 'torques':
cur_type_values = self._limb_interface.joint_efforts()
if values is None:
if type == 'positions':
cur_type_values = self._limb_interface.joint_angles()
elif type == 'velocities':
cur_type_values = self._limb_interface.joint_velocities()
elif type == 'torques':
cur_type_values = self._limb_interface.joint_efforts()
else:
cur_type_values = values

for idx, name in enumerate(self._joint_names):
kdl_array[idx] = cur_type_values[name]
if type == 'velocities':
Expand All @@ -103,19 +107,19 @@ def kdl_to_mat(self, data):
mat[i,j] = data[i,j]
return mat

def forward_position_kinematics(self):
def forward_position_kinematics(self,joint_values=None):
end_frame = PyKDL.Frame()
self._fk_p_kdl.JntToCart(self.joints_to_kdl('positions'),
self._fk_p_kdl.JntToCart(self.joints_to_kdl('positions',joint_values),
end_frame)
pos = end_frame.p
rot = PyKDL.Rotation(end_frame.M)
rot = rot.GetQuaternion()
return np.array([pos[0], pos[1], pos[2],
rot[0], rot[1], rot[2], rot[3]])

def forward_velocity_kinematics(self):
def forward_velocity_kinematics(self,joint_velocities=None):
end_frame = PyKDL.FrameVel()
self._fk_v_kdl.JntToCart(self.joints_to_kdl('velocities'),
self._fk_v_kdl.JntToCart(self.joints_to_kdl('velocities',joint_velocities),
end_frame)
return end_frame.GetTwist()

Expand Down Expand Up @@ -143,30 +147,29 @@ def inverse_kinematics(self, position, orientation=None, seed=None):
result_angles = PyKDL.JntArray(self._num_jnts)

if self._ik_p_kdl.CartToJnt(seed_array, goal_pose, result_angles) >= 0:
result = np.array(result_angles)
result = np.array(list(result_angles))
return result
else:
print 'No IK Solution Found'
return None

def jacobian(self):
def jacobian(self,joint_values=None):
jacobian = PyKDL.Jacobian(self._num_jnts)
self._jac_kdl.JntToJac(self.joints_to_kdl('positions'), jacobian)
self._jac_kdl.JntToJac(self.joints_to_kdl('positions',joint_values), jacobian)
return self.kdl_to_mat(jacobian)

def jacobian_transpose(self):
return self.jacobian().T
def jacobian_transpose(self,joint_values=None):
return self.jacobian(joint_values).T

def jacobian_pseudo_inverse(self):
return np.linalg.pinv(self.jacobian())
def jacobian_pseudo_inverse(self,joint_values=None):
return np.linalg.pinv(self.jacobian(joint_values))


def inertia(self):
def inertia(self,joint_values=None):
inertia = PyKDL.JntSpaceInertiaMatrix(self._num_jnts)
self._dyn_kdl.JntToMass(self.joints_to_kdl('positions'), inertia)
self._dyn_kdl.JntToMass(self.joints_to_kdl('positions',joint_values), inertia)
return self.kdl_to_mat(inertia)

def cart_inertia(self):
js_inertia = self.inertia()
jacobian = self.jacobian()
def cart_inertia(self,joint_values=None):
js_inertia = self.inertia(joint_values)
jacobian = self.jacobian(joint_values)
return np.linalg.inv(jacobian * np.linalg.inv(js_inertia) * jacobian.T)

0 comments on commit 8b95af3

Please sign in to comment.