[英]MATLAB: error Subscripted assignment dimension mismatch
我不断收到x_values行的错误“Subscripted assignment dimension mismatch”。 我试过切换括号,但我无法弄明白。 我对MATLAB不是很好,这段代码超长,所以我不想发布整个内容。
for m = 1:num_part;
for n = 2:num_steps;
x_values(m,n) = x_values(m,n-1)+ stride_length .* (cos(step_angle(m,n)));
y_values(m,n) = y_values(m,n-1)+ stride_length .* (sin(step_angle(m,n)));
r_values (m,n) = sqrt(x_values(m,n).^2 + y_values(m,n).^2);
if bound_cross(m)~=0;
continue;
elseif bound <= r_values(m,n);
bound_cross (m,1) = n;
end
end
正如我bound_cross
,错误在变量bound_cross
。 如果您已按照在注释中回复的方式将其定义为' bound_cross = [num_part, 1]
',则它仅创建1 * 2元素矩阵。 但是如果你需要20 * 1矩阵,你必须专门定义它。 我要检查代码,我使用了一个空矩阵,它运行正常。
num_part = 20;
num_steps = 1000;
stride_length = 100;
bound = 1;
bound_cross = ones(num_part, 1) ;
x_values = zeros(num_part, num_steps);
y_values = x_values;
r_values = x_values;
step_angle = x_values;
for m = 1:num_part;
for n = 2:num_steps;
x_values(m,n) = x_values(m,n-1)+ stride_length .* (cos(step_angle(m,n)));
y_values(m,n) = y_values(m,n-1)+ stride_length .* (sin(step_angle(m,n)));
r_values (m,n) = sqrt(x_values(m,n).^2 + y_values(m,n).^2);
if bound_cross(m)~=0;
continue;
elseif bound <= r_values(m,n);
bound_cross (m,1) = n;
end
end
end
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.