Creating a legend inside a loop, using sprintf

I am trying to make a legend for a plot with 'beta' number of curves. Basically, beta would be beta = [1 : 5] if I decided to have five curves, but it can be any number. I want to make a legend for that number of curves, and specifically do this by using a for loop (I know there are other ways that don't need for loops but I want to use a for loop for this one specifically). The code that I have (below) just gives me a legend for one curve "beta=1beta=2beta=3beta=4beta=5". I would need a legend for five curves. Basically the first curve would be beta = 1, the second curve would be beta = 2, and so on. Can someone help me?
for beta_val = beta
plot(time, y);
hold on
lgd = sprintf('beta = %0.0f', beta);
legend(lgd);
end

 Réponse acceptée

Try something like this:
time = linspace(0, 2*pi); % Create Data
beta = 1:5; % Create Data
y = sin(time(:)*beta); % Create Data
for beta_val = beta
plot(time, y(:,beta_val));
hold on
lgd{beta_val} = sprintf('beta = %0.0f', beta(beta_val));
end
legend(lgd);

6 commentaires

positron96
positron96 le 28 Mai 2018
Modifié(e) : positron96 le 28 Mai 2018
So if I use your code, and append it to mine:
clear; clc;
alpha = 0.1; % degradation rate
time = [0 : 0.5 : 10]; % a vector for time ranging from 0 1o 10 seconds, in intervals of 0.5 second
beta = transpose([1 : 5]); % a vector for the production rate ranging from 1 to 5, in intervals of 1
y = zeros(5, 21); % initializing a matrix of zeros to store all mRNA expression levels (y) for each beta value (and each point in time); 5 beta values, 20 points in time
for time_point = 1 : length(time)
for beta_val = beta
y(beta_val, time_point) = beta ./ alpha .* (1 - exp(-alpha .* time(time_point)));
end
end
for beta_val = beta
plot(time, y(:,beta_val));
hold on
lgd{beta_val} = sprintf('beta = %0.0f', beta(beta_val));
end
legend(lgd);
I get the following error:
Error using plot Vectors must be the same length.
Error in testcode (line 23) plot(time, y(:,beta_val));
positron96
positron96 le 28 Mai 2018
Oh I figured it out! Thank you so much!
You have row vectors for ‘y’. My code has column vectors. So with that and one other tweak, and using MATLAB’s vector and matrix vectorisation abilities to eliminate the first loop, we have:
alpha = 0.1; % degradation rate
time = [0 : 0.5 : 10]; % a vector for time ranging from 0 1o 10 seconds, in intervals of 0.5 second
beta = transpose([1 : 5]); % a vector for the production rate ranging from 1 to 5, in intervals of 1
y = beta ./ alpha .* (1 - exp(-alpha .* time));
for beta_val = 1:numel(beta)
plot(time, y(beta_val,:));
hold on
lgd{beta_val} = sprintf('beta = %0.0f', beta(beta_val));
end
legend(lgd, 'Location','N')
See if that does what you want.
positron96
positron96 le 28 Mai 2018
This actually works a ton better! Thanks so much!
Star Strider
Star Strider le 28 Mai 2018
As always, my pleasure!
If this works, you can omit the loop:
plot(time, y);
lgd{beta_val} = sprintfc('beta = %0.0f', beta);
legend(lgd, 'Location','N')

Connectez-vous pour commenter.

Plus de réponses (1)

Kai Åsvik
Kai Åsvik le 22 Juil 2018

0 votes

I am getting this error message: "Function 'subsindex' is not defined for values of class 'cell'."

1 commentaire

Jan
Jan le 22 Juil 2018
@Kai: The problem is solved already and the readers cannot guess, which code causes your problem. Please open a new thread and include the code and the complete error message.

Connectez-vous pour commenter.

Catégories

Community Treasure Hunt

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

Start Hunting!

Translated by