How do I create a legend involving multiple plots created in a for loop?

I am trying to create a figure with 3 plots and a legend detailing what each plot is. Each plot is created in a for loop.
for j= 1:3
y = j;
figure(1);
plot(y);
hold on;
end
Thus, there will be 3 lines labeled in the legend. I appreciate any help that you all can provide!

Answers (3)

Here are some demos you can follow.
Option 1: add legend labels when you call legend
figure()
axes
hold on
nLoops = 3;
ph = gobjects(1,nLoops);
for j= 1:nLoops
y = randn(10,1)+j;
ph(j) = plot(y, '-o');
end
legend(ph, {'first', 'second', 'third'})
Option 2: add legend labels within the loop
figure()
axes
hold on
nLoops = 3;
ph = gobjects(1,nLoops);
for j= 1:nLoops
y = randn(10,1)+j;
ph(j) = plot(y, '-o', 'DisplayName', sprintf('line %d',j));
end
legend(ph)

4 Comments

Thank you so much for your answer!
Unfortunately, both options gave me the error "Unable to use a value of type 'matlab.graphics.chart.primitive.Line' as an index." on the line with legend
What version of Matlab are you using? Did you get that error running my sample code or after adapting it to your code?
I got the error on your sample code and when I adapted it to my own.
MATLAB_R2019a
I just triple-checked and the two demos I wrote function perfectly in 2019a. What was the error message?
Could you share a reproducible version of your code? I'm sure it's a small error; easy to fix.

Sign in to comment.

Try this:
figure()
hold on
numberOfLoops = 3;
for k = 1 : numberOfLoops
y = randn(10,1) + k;
plot(y, '.-', 'MarkerSize', 20, 'LineWidth', 2);
% Make up a string for this particular line plot.
legends{k} = sprintf('This is plot #%d', k);
end
legend(legends) % Display all the legend texts.
grid on;
0000 Screenshot.png
I appreciate all of your help. The problem was due to an undiagnosed error at the beginning of my script, so I have figured out the problem, and my legend is now displaying appropriately.

Asked:

on 26 Apr 2019

Commented:

on 28 May 2020

Community Treasure Hunt

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

Start Hunting!