Attempted to access colors(6); index out of bounds because numel(colors)=5

1 visualización (últimos 30 días)
Hi, I tried executing this loop,
colors = ['m';'y';'b';'g';'c'];
loop_ind = 1;
for k1 = 1:5
figure(4);
linespec = colors(loop_ind);
plot(x, y, linespec, 'LineWidth', 1);
loop_ind = loop_ind + 1;
hold on
end
legend('-0.02','-0.01','0','0.01','0.02')
But I get an error,
Attempted to access colors(6); index out of bounds because numel(colors)=5. Error in test_contact_ellipse (line 228)
linespec = colors(loop_ind);
Now I'm getting the plot with the correct colors but the legend doesn't appear. How can I rectify this error.
Please give your suggestions.
Thanks
  5 comentarios
Sara
Sara el 24 de Jun. de 2014
Attach x and y, with random data it works fine. Are x and y multidimensional arrays by any chance?
Sara
Sara el 24 de Jun. de 2014
You'll need to include all the variables and the files, or I won't be able to run your code

Iniciar sesión para comentar.

Respuesta aceptada

Star Strider
Star Strider el 24 de Jun. de 2014
This is an example that plots in different colors with a matching legend:
c = [0 1 0; 1 0 0; 0 0 1; 1 0 1; 0 1 1];
x = linspace(0,2*pi);
figure(4)
hold on
for k1 = 1:size(c,1)
plot(x, sin(x*k1)+k1, 'Color', c(k1,:))
end
hold off
grid
legend('Color 1', 'Color 2', 'Color 3', 'Color 4', 'Color 5')
Adapt it as necessary to your application.
  9 comentarios

Iniciar sesión para comentar.

Más respuestas (1)

Sara
Sara el 24 de Jun. de 2014
In the last loop, replace with the following and see if it is what you are looking for:
figure(4);
plot(x, y, 'LineWidth', 1,'color',colors(k2))
axis square;
axis equal;
grid on;
xlabel('Longitudinal');ylabel('Lateral');title('Contact ellipse shape');
hold on
myh = line([xCenter, xCenter], [yCenter - yRadius(k2), yCenter + yRadius(k2)], ...
'LineWidth', 1, 'Color', [1,0,0]);
set(get(get(myh,'Annotation'),'LegendInformation'),'IconDisplayStyle','off');
myh = line([xCenter - xRadius(k2), xCenter + xRadius(k2)], [yCenter, yCenter], ...
'LineWidth', 1, 'Color', [1,0,0]);
set(get(get(myh,'Annotation'),'LegendInformation'),'IconDisplayStyle','off');
It seems that some of your ellipses are overwritten with others. Since I don't know what you are doing, this is the best I can recommend. I'd replace also:
for k2 = 1:size(a,2)

Categorías

Más información sobre Line Plots en Help Center y File Exchange.

Productos

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by