toggle and elseif in matlab
16 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Shivaani S
el 4 de Mayo de 2020
Comentada: Walter Roberson
el 16 de Ag. de 2024
Try adding a variable doDisplay to toggle if the densities are displayed. Add this condition with an elseif block.
i do not understand what we are supposed to do in the above question(bold). this question is a part of futher practice in mathlab oramp. decision branching topic futher practice section in matworks course for basic matlab. how do i solve tha bove question
1 comentario
Respuesta aceptada
Geoff Hayes
el 4 de Mayo de 2020
Shivaani - I think that all the code is asking you to do is to add another variable called doDisplay and an elseif that would check if this variable is true. If so, then you would plot the densities. So there would be two ways to plot the data - either through the doPlot or with the doDisplay
if doPlot
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
elseif doDisplay
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
else
disp("The density of " + element ...
+ " is " + density)
end
You would need to declare and initialize the doDisplay variable too.
4 comentarios
Geoff Hayes
el 5 de Mayo de 2020
I'm not sure then...I added the above code and was able to proceed/pass. Are you sure that you have defined doDisplay?
Elisa R
el 4 de Ag. de 2020
This is what I did. I ran it numerous times. both doPlot and doDisplay have to be 0 in this scenario in order for the text to display instead of the plot.
doPlot = randi([0 1])
load datafile
density = data(:,1);
doDisplay = randi([0 1])
if doPlot == 1
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
elseif doDisplay == 1
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
else
disp("The density of " + element ...
+ " is " + density)
end
Más respuestas (7)
Varot Pakavatsoontorn
el 1 de Mayo de 2021
Hi, I think the instructor might mean the following:
doDisplay = 1-doPlot
if doPlot == 1
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
elseif doDisplay == 1
disp("The density of " + element ...
+ " is " + density)
end
2 comentarios
Simone Silva
el 7 de Mzo. de 2022
Hi.
The instructor asks what hapenned when doPlot and doDisplay are both equal one or they both equal zero.
If we define doDisplay=1-doPlot, the cases above are not possible.
Rik
el 7 de Abr. de 2022
This is imo the best interpretation of the task at hand and a great solution.
Saif Alameri
el 26 de Ag. de 2022
My interpretation to this practice is to create another variable (doDisplay) with random number (0 or 1) just like the (doPlot), then use it as a second condtion for (elseif):
doPlot = randi([0 1])
doDisplay=randi([0 1])
load datafile
density = data(:,1);
if doPlot == 1
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
elseif doDisplay == 1
disp("The density of " + element + " is " + density)
end
When:
doPlot = 0 and doDisplay = 0, then nothing displaied
doPlot = 1 and doDisplay = 0, then plot displaied
doPlot = 0 and doDisplay = 1, then density displaied
doPlot = 1 and doDisplay = 1, then only plot displaied
The point of this practice is to explain that second condtion will executing only when it met it's condtion and first condtion is not.
1 comentario
DGM
el 16 de Ag. de 2024
I think this is the correct and most direct interpretation of the instructions. I can see why a person would be confused though, as it doesn't really make sense to use if/elseif for this. To me, it would be more sensible to do
if doPlot
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
end
if doDisplay
disp("The density of " + element + " is " + density)
end
Otherwise, there's not really any point in using multiple flags to control the behavior. As much as I think it's better, this isn't what the instructions describe.
Kakasaheb Nikam
el 14 de Mayo de 2020
a Simple trick that i follow is,
at beginning I also not understand,
so we read it thrice by breaking sentance.
apply simple common logic.
we understand it.
0 comentarios
Joanne Middour
el 13 de Feb. de 2021
This is the way I did it because I was under the impression that they are asking us to do recursion here, but I may be wrong.
doDisplay = randi([0 1])
if doPlot == 1
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
elseif doDisplay == 1
doPlot = 1
else
disp("The density of " + element ...
+ " is " + density)
end
1 comentario
ABINESH R
el 2 de Jul. de 2022
they are also asking what happens when they both equal zero, or when only doDisplay equals one?What's the ans for this
sai
el 4 de Abr. de 2021
if doPlot == 1
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
elseif doDisplay
disp("The density of " + element ...
+ " is " + density)
end
0 comentarios
kunku S M
el 3 de Feb. de 2022
try this, i think it's the answer
doDisplay=randi([0 1])
if doPlot == 0
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
elseif doDisplay == 1
disp("The density of " + element ...
+ " is " + density)
end
0 comentarios
Muhammad
el 7 de Ag. de 2024
Editada: Muhammad
el 8 de Ag. de 2024
I have tried: Here we can test what happens when both are equal to 1 or zero or only doDisplay is equal to 1. Nothing happens when both are equal to zero. When both are equal to 1, graph is printed. When only doDisplay is 1, it displays the densities. But still seems to be tricky quetion.
doPlot = randi([0 1])
doDisplay = randi([0 1])
density =
if doPlot == 1
plot(density)
title("Sample Densities")
xticklabels(element)
ylabel("Density (g/cm^3)")
elseif doDisplay ~= doPlot
disp("The dinsity of " + element ...
+ " is " + density)
else
doPlot
doDisplay
end
1 comentario
Walter Roberson
el 16 de Ag. de 2024
density =
That line is not valid MATLAB syntax.
Ver también
Categorías
Más información sobre Data Distribution Plots en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!