data:image/s3,"s3://crabby-images/5d440/5d4400f43522cac086be5f734ba64406d60e5d73" alt=""
data:image/s3,"s3://crabby-images/5363d/5363dac784c72ef1423c84f632f58cb24418b8c9" alt=""
data:image/s3,"s3://crabby-images/c6827/c682743006a449f84afee386be6ca6c219487d83" alt=""
data:image/s3,"s3://crabby-images/87276/87276c771a1ec5b99397e808bc5ed1bc57ed6317" alt=""
data:image/s3,"s3://crabby-images/e331e/e331ee78c40c9d194218537dead1e1a7292bdf68" alt=""
data:image/s3,"s3://crabby-images/6c870/6c87070b3d2362299ebe2414987b3307afe5d8e4" alt=""
inertial frame -> fixed ->
moving frame -> point 's motion has two parts: translation and rotation of the frame
data:image/s3,"s3://crabby-images/8a652/8a652c24295e272353bf2b56a36c9f98922d32d4" alt=""
Rotations: typo?? ->
???
data:image/s3,"s3://crabby-images/9500e/9500e6eea7cce1472463f75a8aeb579fdddb35a0" alt=""
data:image/s3,"s3://crabby-images/93887/93887e41f89c4287ebe9b476416c3f3c6730d886" alt=""
r -> coordinate in x-y Cartesian
q -> local positions and angles
data:image/s3,"s3://crabby-images/61c13/61c138f886ed31e0dfdbd5b774214a5d55ee42fd" alt=""
data:image/s3,"s3://crabby-images/d22ca/d22ca0ec3a2cf71d141835c8425d47d15ba7a94d" alt=""
data:image/s3,"s3://crabby-images/dda61/dda6166373ba1bb3aef31a58c14196d3a6eb81d2" alt=""
data:image/s3,"s3://crabby-images/7581d/7581debad3627d08eeaea8e5e46873a91999ff94" alt=""
data:image/s3,"s3://crabby-images/d1816/d1816c2bd8c0af9b578064c6fe5788452276f1d5" alt=""
data:image/s3,"s3://crabby-images/19513/195131d6c7c87ad90f5894c986a142dc88c3664f" alt=""
data:image/s3,"s3://crabby-images/79848/79848d3a52b5ed009fd9325ced09879919a77c0f" alt=""
data:image/s3,"s3://crabby-images/d3334/d333409c836c1f4cd7e3a89f8be575d6a506cee7" alt=""
data:image/s3,"s3://crabby-images/9bb82/9bb821760f1248505ecc74d8569c98ce2933dce4" alt=""
data:image/s3,"s3://crabby-images/8a150/8a1501196afe30534afc3419d2cf74b9be25d1f4" alt=""
data:image/s3,"s3://crabby-images/59b14/59b1431cab36573d502488fd6e5c3ade4e3f042f" alt=""
data:image/s3,"s3://crabby-images/0e39e/0e39ede781d59800cb6516f51704236de851f850" alt=""
data:image/s3,"s3://crabby-images/62fe2/62fe2f057c962fcf061610d2b478446b199574d8" alt=""
data:image/s3,"s3://crabby-images/46ad7/46ad7bc49c83d4c322be0c1cac255e8835c70a9c" alt=""
% rotational matrices calculated in previous problem set
R_B1 = [1,0,0;0,cos(alpha),-sin(alpha);0,sin(alpha),cos(alpha)];
R_12 = [cos(beta),0,sin(beta);0,1,0;-sin(beta),0,cos(beta)];
R_23 = [cos(gamma),0,sin(gamma);0,1,0;-sin(gamma),0,cos(gamma)];
data:image/s3,"s3://crabby-images/5f121/5f1217f2345de07ca4ec2db8f49041d07353375e" alt=""
data:image/s3,"s3://crabby-images/3f82f/3f82f902455a448818a131c450e181c49e688b02" alt=""
alpha = sym('alpha','real');
beta = sym('beta','real');
gamma = sym('gamma','real');
% rotational matrices calculated in previous problem set
R_B1 = [1,0,0;0,cos(alpha),-sin(alpha);0,sin(alpha),cos(alpha)];
R_12 = [cos(beta),0,sin(beta);0,1,0;-sin(beta),0,cos(beta)];
R_23 = [cos(gamma),0,sin(gamma);0,1,0;-sin(gamma),0,cos(gamma)];
% write down the 3x1 relative position vectors for link length l_i=1
r_B1_inB = [0;1;0];
r_12_in1 = [0;0;-1];
r_23_in2 = [0;0;-1];
r_3F_in3 = [0;0;-1];
% write down the homogeneous transformation matrices
H_B1 = [1,0,0,0;
0,cos(alpha),-sin(alpha),1;
0,sin(alpha),cos(alpha),0;
0,0,0,1];
H_12 = [cos(beta),0,sin(beta),0;
0,1,0,0;
-sin(beta),0,cos(beta),-1;
0,0,0,1];
H_23 = [cos(gamma),0,sin(gamma),0;
0,1,0,0;
-sin(gamma),0,cos(gamma),-1;
0,0,0,1];
% create the cumulative transformation matrix
H_B3 = H_B1*H_12*H_23;
% find the foot point position vector
r_BF_inB = r_B1_inB + R_B1*r_12_in1 + R_B1*R_12*r_23_in2 + R_B1*R_12*R_23*r_3F_in3;
data:image/s3,"s3://crabby-images/54a58/54a5860b0a47494bbaa49dc8f3e2801aa26ef8c3" alt=""
data:image/s3,"s3://crabby-images/a3d1d/a3d1d8150ea165a46299c8c2cd3ed8e87f6caef8" alt=""
data:image/s3,"s3://crabby-images/ed5df/ed5dfc2544aaafe9e0885543f86c4ca97788ce88" alt=""
data:image/s3,"s3://crabby-images/52c93/52c93e8af7fabb35696f5ce508be5a718232fe0e" alt=""
r_BF_inB = @(alpha,beta,gamma)[...
-sin(beta + gamma) - sin(beta);...
sin(alpha)*(cos(beta + gamma) + cos(beta) + 1) + 1;...
-cos(alpha)*(cos(beta + gamma) + cos(beta) + 1)];
J_BF_inB = @(alpha,beta,gamma)[...
0, - cos(beta + gamma) - cos(beta), -cos(beta + gamma);...
cos(alpha)*(cos(beta + gamma) + cos(beta) + 1), -sin(alpha)*(sin(beta + gamma) + sin(beta)), -sin(beta + gamma)*sin(alpha);...
sin(alpha)*(cos(beta + gamma) + cos(beta) + 1), cos(alpha)*(sin(beta + gamma) + sin(beta)), sin(beta + gamma)*cos(alpha)];
data:image/s3,"s3://crabby-images/aa92b/aa92b36f2b555214ac93391149988526d7df2e4d" alt=""
data:image/s3,"s3://crabby-images/bde1e/bde1e63e7fd4e611e69fc01568e9012687f5a7c0" alt=""
data:image/s3,"s3://crabby-images/eed77/eed77e82a064bcabb477f0f0bc3dbb239f23e51e" alt=""
data:image/s3,"s3://crabby-images/0a1dc/0a1dc7bc251cb44dbb1101bc3fc1fabfbb340a02" alt=""
% given are the functions
% r_BF_inB(alpha,beta,gamma) and
% J_BF_inB(alpha,beta,gamma)
% for the foot positon respectively Jacobian
r_BF_inB = @(alpha,beta,gamma)[...
- sin(beta + gamma) - sin(beta);...
sin(alpha)*(cos(beta + gamma) + cos(beta) + 1) + 1;...
-cos(alpha)*(cos(beta + gamma) + cos(beta) + 1)];
J_BF_inB = @(alpha,beta,gamma)[...
0, - cos(beta + gamma) - cos(beta), -cos(beta + gamma);...
cos(alpha)*(cos(beta + gamma) + cos(beta) + 1), -sin(alpha)*(sin(beta + gamma) + sin(beta)), -sin(beta + gamma)*sin(alpha);...
sin(alpha)*(cos(beta + gamma) + cos(beta) + 1), cos(alpha)*(sin(beta + gamma) + sin(beta)), sin(beta + gamma)*cos(alpha)];
% write an algorithm for the inverse differential kinematics problem to
% find the generalized velocities dq to follow a circle in the body xz plane
% around the start point rCenter with a radius of r=0.5 and a
% frequeny of 0.25Hz. The start configuration is q = pi/180*([0,-60,120])',
% which defines the center of the circle
q0 = pi/180*([0,-60,120])';
dq0 = zeros(3,1);
rCenter = r_BF_inB(q0(1),q0(2),q0(3));
radius = 0.5;
f = 0.25;
rGoal = @(t) rCenter + radius*[sin(2*pi*f*t),0,cos(2*pi*f*t)]';
drGoal = @(t) 2*pi*f*radius*[cos(2*pi*f*t),0,-sin(2*pi*f*t)]';
% define here the time resolution
deltaT = 0.01;
timeArr = 0:deltaT:1/f;
% q, r, and rGoal are stored for every point in time in the following arrays
qArr = zeros(3,length(timeArr));
rArr = zeros(3,length(timeArr));
rGoalArr = zeros(3,length(timeArr));
q = q0;
dq = dq0;
for i=1:length(timeArr)
t = timeArr(i);
% data logging, don't change this!
q = q+deltaT*dq;
qArr(:,i) = q;
rArr(:,i) = r_BF_inB(q(1),q(2),q(3));
rGoalArr(:,i) = rGoal(t);
% controller:
% step 1: create a simple p controller to determine the desired foot
% point velocity
v = ...;
% step 2: perform inverse differential kinematics to calculate the
% generalized velocities
dq = ...;
end
plotTrajectory(timeArr, qArr, rArr, rGoalArr);
data:image/s3,"s3://crabby-images/ba480/ba480ec0a4cd478145d505bae2dc932fed834c3b" alt=""
https://homes.cs.washington.edu/~todorov/courses/cseP590/06_JacobianMethods.pdf
网友评论