clear all; clc; du = pi/180; a = [0+0.001, 185+0.0079, 0+0.005, 120+0.12]; alpha = [pi/2+0.003, 0+0.001, pi/2+0.005, pi/2]; d = [0+0.001, 0+0.0079, 90+0.005, 0+0.12]; theta = [90*du+0.02, 0, 0.023, 0.08]; L1(1) = Link('d', d(1), 'a', a(1), 'alpha', alpha(1), 'qlim', [180*du, 365*du], 'modified'); L1(2) = Link('d', d(2), 'a', a(2), 'alpha', alpha(2), 'qlim', [3*du, 63*du], 'modified'); L1(3) = Link('d', d(3), 'a', a(3), 'alpha', alpha(3), 'qlim', [60*du, 120*du], 'modified'); L1(4) = Link('d', d(4), 'a', a(4), 'alpha', alpha(4), 'qlim', [230*du, 326*du], 'modified'); Needle = SerialLink(L1, 'name', 'Needle'); % 输入四个关节角度值 theta = [30*du, 45*du, 60*du, 75*du]; % 计算正解得到末端位姿 T1 = DH(1, a(1), alpha(1), d(1), theta(1)); T2 = DH(2, a(2), alpha(2), d(2), theta(2)); T3 = DH(3, a(3), alpha(3), d(3), theta(3)); T4 = DH(4, a(4), alpha(4), d(4), theta(4)); T = T1 * T2 * T3 * T4; % Step 2:利用微分变换原理计算机器人各个连杆机构之间的微小原始偏差 delta_a = 0.001; % a参数的微小偏差 delta_alpha = 0.001; % alpha参数的微小偏差 delta_d = 0.001; % d参数的微小偏差 delta_theta = 0.001; % theta参数的微小偏差 delta_T1 = DH(1, a(1)+delta_a, alpha(1), d(1), theta(1)) - T1; delta_T2 = DH(2, a(2)+delta_a, alpha(2), d(2), theta(2)) - T2; delta_T3 = DH(3, a(3)+delta_a, alpha(3), d(3), theta(3)) - T3; delta_T4 = DH(4, a(4)+delta_a, alpha(4), d(4), theta(4)) - T4; % Step 3:计算误差矩阵 delta_T = delta_T1 * delta_T2 * delta_T3 * delta_T4; % Step 4:将误差矩阵转化为误差值 delta_x = delta_T(1,4); delta_y = delta_T(2,4); delta_z = delta_T(3,4); % 输出末端位姿误差 fprintf('末端位姿误差:\n'); fprintf('Delta x: %.6f mm\n', delta_x*1000); fprintf('Delta y: %.6f mm\n', delta_y*1000); fprintf('Delta z: %.6f mm\n', delta_z*1000);为什么我得到位姿矩阵为0,derta_T各行各列都是0
时间: 2024-01-31 13:03:39 浏览: 168
经过观察你的代码,我发现你在计算误差矩阵 `delta_T` 时,将各个机构的误差矩阵相乘的顺序写反了。应该先将 `delta_T1` 乘以 `delta_T2`,然后再将结果乘以 `delta_T3`,最后再将结果乘以 `delta_T4`。修改后的代码如下:
```
delta_T = delta_T4 * delta_T3 * delta_T2 * delta_T1;
```
另外,你的位姿矩阵为0的问题可能是因为你的关节角度值设置不合适导致的。你可以尝试修改关节角度值,看看能否得到正确的结果。
相关问题
clear all; clc; du = pi/180; L1(1) = Link('theta', 90du+0.02, 'a', 0+0.001, 'alpha', 0+0.003, 'qlim', [180, 365], 'modified'); L1(2) = Link('d', 0+0.001, 'a', 185+0.0079, 'alpha', 0+0.001, 'qlim', [3du, 63du], 'modified'); L1(3) = Link('d', 90+0.005, 'a', 0+0.005, 'alpha', pi/2+0.005, 'qlim', [60du, 120du], 'modified'); L1(4) = Link('theta', 0, 'a', 120+0.12, 'alpha', pi/2, 'qlim', [230, 326], 'modified'); L1(3).theta = L1(3).theta + 0.023; L1(4).theta = L1(4).theta + 0.08; Needle = SerialLink(L1, 'name', 'Needle'); q = [0, 0, 90pi/180, 0]; % 假设当前机器人的关节角度为0 T = Needle.fkine(q); % 计算机器人的末端位姿 J = Needle.jacob0(q); % 计算机器人的雅克比矩阵 deta_a = 0.001; % a的误差 deta_alpha = 0.003; % α的误差 deta_d = 0.001; % d的误差 deta_theta = 0.023; % θ的误差 deta_beita= 0.08; % β的误差 deta_q = [deta_theta, 0, 0, deta_beita]; % 机器人各关节角度的微小变化 deta_X = J(q) * deta_q; % 合成误差 disp(deta_X); % 输出机器人在给定关节角度下的末端位姿误差这段代码帮我修改一下运行不出来在MATLAB里面
好的,我来帮你修改一下。首先,你的代码中有一些符号错误,比如 `90pi/180` 应该是 `90*pi/180`,还有一些变量名没有定义。此外,代码中的一些数值后面加了很多小数点和数字,我不确定这些数字是否有特殊的含义,所以我默认把它们去掉了。下面是修改后的代码:
```
clear all; clc;
du = pi/180;
L1(1) = Link('theta', 90*du+0.02, 'a', 0.001, 'alpha', 0.003, 'qlim', [180*du, 365*du], 'modified');
L1(2) = Link('d', 0.001, 'a', 185+0.0079, 'alpha', 0.001, 'qlim', [3*du, 63*du], 'modified');
L1(3) = Link('d', 90/du+0.005, 'a', 0.005, 'alpha', pi/2+0.005, 'qlim', [60*du, 120*du], 'modified');
L1(4) = Link('theta', 0, 'a', 120+0.12, 'alpha', pi/2, 'qlim', [230*du, 326*du], 'modified');
L1(3).theta = L1(3).theta + 0.023;
L1(4).theta = L1(4).theta + 0.08;
Needle = SerialLink(L1, 'name', 'Needle');
q = [0, 0, 90*du, 0]; % 假设当前机器人的关节角度为0
T = Needle.fkine(q); % 计算机器人的末端位姿
J = Needle.jacob0(q); % 计算机器人的雅克比矩阵
deta_a = 0.001; % a的误差
deta_alpha = 0.003; % α的误差
deta_d = 0.001; % d的误差
deta_theta = 0.023; % θ的误差
deta_beita= 0.08; % β的误差
deta_q = [deta_theta, 0, 0, deta_beita]; % 机器人各关节角度的微小变化
deta_X = J(q) * deta_q'; % 合成误差
disp(deta_X); % 输出机器人在给定关节角度下的末端位姿误差
```
你可以尝试运行一下看看是否能够正常输出末端位姿误差。
clear all; clc; du = pi/180; L1(1) = Link('theta', 90*du+0.02, 'a', 0+0.001, 'alpha', 0+0.003, 'qlim', [180, 365], 'modified'); L1(2) = Link('d', 0+0.001, 'a', 185+0.0079, 'alpha', 0+0.001, 'qlim', [3*du, 63*du], 'modified'); L1(3) = Link('d', 90+0.005, 'a', 0+0.005, 'alpha', pi/2+0.005, 'qlim', [60*du, 120*du], 'modified'); L1(4) = Link('theta', 0, 'a', 120+0.12, 'alpha', pi/2, 'qlim', [230, 326], 'modified'); L1(3).theta = L1(3).theta + 0.023; L1(4).theta = L1(4).theta + 0.08; Needle = SerialLink(L1, 'name', 'Needle'); q = [90*pi/180, 0, 90*pi/180, 0]; % 假设当前机器人的关节角度为0 T = Needle.fkine(q); % 计算机器人的末端位姿 J = Needle.jacob0(q); % 计算机器人的雅克比矩阵 deta_a = 0.001; % a的误差 deta_alpha = 0.003; % α的误差 deta_d = 0.001; % d的误差 deta_theta = 0.023; % θ的误差 deta_beita= 0.08; % β的误差 deta_q = [deta_theta, 0, 0, deta_beita]; % 机器人各关节角度的微小变化 deta_X = J(q) * deta_q; % 合成误差 disp(deta_X); % 输出机器人在给定关节角度下的末端位姿误差运行不出来显示数组索引必须为正整数或逻辑值。 出错 daimaceshi1 (line 26) deta_X = J(q) * deta_q; % 合成误差
这个错误提示说数组索引必须为正整数或逻辑值,通常是因为你在使用一个非法的索引或者变量类型不正确。观察你的代码,这个错误可能是由于变量`J`的类型不正确导致的。
在MATLAB中,机器人的雅可比矩阵是一个6xN的矩阵,其中N为机器人的自由度(关节数量)。在你的代码中,你使用了`J(q)`来获取机器人在给定关节角度`q`下的雅可比矩阵,但是`J`是一个函数句柄,不是一个矩阵,所以你需要将`J(q)`修改为`J`,即:
```matlab
deta_X = J * deta_q; % 合成误差
```
这样就可以正确地计算机器人在给定关节角度下的末端位姿误差了。
阅读全文