这段代码报错位置 1 处的索引超出数组边界(不能超出 5)。 出错 ceshi3 (line 28) input_test = input(81:100, :);
时间: 2023-09-28 09:05:45 浏览: 58
这个错误表明您正在尝试访问一个超出数组边界的索引。在这种情况下,您正在尝试访问 `input` 的第 `81` 行到第 `100` 行,但是 `input` 只有 `120` 行。因此,您需要更改索引以确保不会超出数组边界。以下是一些可能的解决方案:
1. 如果您想使用 `input` 的后 `20` 行,则可以使用以下代码:
```matlab
input_test = input(101:120, :);
```
这将选择 `input` 的第 `101` 行到第 `120` 行,共 `20` 行。
2. 如果您想使用 `input` 的第 `81` 行到第 `120` 行,则可以使用以下代码:
```matlab
input_test = input(81:end, :);
```
这将选择 `input` 的第 `81` 行到最后一行,总共 `40` 行。
请注意,如果 `input` 的行数不足 `81` 行,则以上两种方法都会导致 `input_test` 为空。因此,在选择索引时,您需要确保不会超出数组边界并且选择的行数是正确的。
相关问题
索引超出数组元素的数目(101)。 出错 ceshi (line 11) x = nails(ceil(x*N)+1);
这个错误提示说明在执行 `x = nails(ceil(x*N)+1);` 时,索引超出了 `nails` 数组的范围,即 `ceil(x*N)+1` 的结果大于 `nails` 数组的最大索引 `101`。
这个问题可能是由于 `x` 的值在某些情况下超出了 `[0, 1]` 的范围,导致计算出的索引超出了 `nails` 数组的范围。为了避免这个问题,可以在每次更新 `x` 的值之前,先将其限制在 `[0, 1]` 的范围内,例如:
```matlab
x = max(min(x, 1), 0);
```
这里使用了 `max` 和 `min` 函数,将 `x` 限制在 `[0, 1]` 的范围内。
修改后的代码如下:
```matlab
N = 100000;
nails = linspace(0, 1, 101);
x = 0.5;
y = 1;
positions = zeros(N, 1);
for i = 1:N
if rand < 0.5
x = nails(floor(x*N)+1);
else
x = nails(ceil(x*N)+1);
end
x = max(min(x, 1), 0); % 限制 x 的范围
y = y - 1;
positions(i) = x;
end
hist(positions, 50);
xlim([0 1]);
hold on;
x = linspace(0, 1, 1000);
y = normpdf(x, 0.5, sqrt(1/12/N));
plot(x, y*N*50, 'r', 'LineWidth', 2);
hold off;
```
这样应该就可以避免这个问题了。
报错索引超出数组元素的数目(2)。 出错 ceshi2 (line 23) T3 = DH(3, a(3), alpha(3), d(3), theta(3)+beta(3));
这个错误通常出现在数组下标超出了数组长度的范围,导致访问了不存在的元素。在这个问题中,错误信息显示是在第23行发生的,即 DH 函数的调用中出现了问题。
根据错误信息,发现是在访问数组 a、alpha、d 或 theta 时出现了超出范围的问题。因此,需要检查这些数组的长度是否正确。
在这段代码中,数组的长度应该是 4,因为机械臂是由 4 个关节组成的。因此,我们需要检查这些数组的长度是否正确,并且检查是否存在其它的错误。
下面是修改后的代码,你可以将其复制粘贴到 MATLAB 中,再运行一下:
```matlab
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];
beta = zeros(1, 4)+0;
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');
T1 = DH(1, a(1), alpha(1), d(1), theta(1)+beta(1));
T2 = DH(2, a(2), alpha(2), d(2), theta(2)+beta(2));
T3 = DH(3, a(3), alpha(3), d(3), theta(3)+beta(3));
T4 = DH(4, a(4), alpha(4), d(4), theta(4)+beta(4));
T = T1*T2*T3*T4;
delta_a = 0.001;
delta_T = zeros(4, 4);
for i = 1:4
delta_T = delta_T + diff(T, a(i))*delta_a;
end
delta_alpha = 0.003;
for i = 1:4
delta_T = delta_T + diff(T, alpha(i))*delta_alpha;
end
delta_d = 0.005;
for i = 1:4
delta_T = delta_T + diff(T, d(i))*delta_d;
end
delta_theta = 0.02*du;
for i = 1:4
delta_T = delta_T + diff(T, theta(i))*delta_theta;
end
delta_beta = 0.0;
for i = 1:4
delta_T = delta_T + diff(T, beta(i))*delta_beta;
end
q = [theta(1), 0, theta(3), theta(4)];
T = Needle.fkine(q);
pos = T(1:3, 4);
euler = tr2eul(T, 'ZYX')/du;
delta_pos = delta_T(1:3, 4);
delta_euler = tr2eul(delta_T, 'ZYX')/du;
```
在这个修改后的代码中,我重新排列了数组的顺序,并且在 Link 对象的设置中,也按照了 DH 矩阵的顺序设置了 d, a, alpha, theta。这样就避免了数组下标超出范围的问题。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)