IRDYn/complie/R1000 DVT GravityModel V1/mr/FKinBody.m

29 lines
1011 B
Mathematica
Raw Permalink Normal View History

2024-12-16 16:33:21 +00:00
function T = FKinBody(M, Blist, thetalist)
% *** CHAPTER 4: FORWARD KINEMATICS ***
% Takes M: the home configuration (position and orientation) of the
% end-effector,
% Blist: The joint screw axes in the end-effector frame when the
% manipulator is at the home position,
% thetalist: A list of joint coordinates.
% Returns T in SE(3) representing the end-effector frame when the joints
% are at the specified coordinates (i.t.o Body Frame).
% Example Inputs:
%
% clear; clc;
% M = [[-1, 0, 0, 0]; [0, 1, 0, 6]; [0, 0, -1, 2]; [0, 0, 0, 1]];
% Blist = [[0; 0; -1; 2; 0; 0], [0; 0; 0; 0; 1; 0], [0; 0; 1; 0; 0; 0.1]];
% thetalist = [pi / 2; 3; pi];
% T = FKinBody(M, Blist, thetalist)
%
% Output:
% T =
% -0.0000 1.0000 0 -5.0000
% 1.0000 0.0000 0 4.0000
% 0 0 -1.0000 1.6858
% 0 0 0 1.0000
T = M;
for i = 1: size(thetalist)
T = T * MatrixExp6(VecTose3(Blist(:, i) * thetalist(i)));
end
end