Hi, my following piece of code does not work as it expected to and I don't know how to fix it yet. Any suggestions? Thanks!
A = [5;5;5;3;3;2];
B = [10;4;10;10;4;4];
if A == 5
plot(A,B,'rx')
elseif A == 3
hold on
plot(A,B,'bx')
else
hold on
plot(A,B,'gx')
end

2 Kommentare

Stephen23
Stephen23 am 5 Apr. 2019
"if statement not working"
Did you read the IF documentation (to know how it works with non-scalar conditions), before deciding that it is "not working" ?
Rik
Rik am 5 Apr. 2019
Bearbeitet: Rik am 5 Apr. 2019
@Stephen I think Matlab should throw a warning on non-scalar inputs, maybe even an error. I've many people surprised by the implicit call to all that happens here.
%actually, if does this:
if ~isempty(expression) && all(expression)

Melden Sie sich an, um zu kommentieren.

 Akzeptierte Antwort

Rik
Rik am 5 Apr. 2019
Bearbeitet: Rik am 5 Apr. 2019

1 Stimme

What you probably think should happen is in the code below, however, there is a better way.
A = [5;5;5;3;3;2];
B = [10;4;10;10;4;4];
figure(1)
clf(1),axes;
for n=1:numel(A)
if A(n) == 5
plot(A(n),B(n),'rx')
elseif A(n) == 3
hold on
plot(A(n),B(n),'bx')
else
hold on
plot(A(n),B(n),'gx')
end
end
axis([1 6 3 11])
The better way is to use logical indexing:
A = [5;5;5;3;3;2];
B = [10;4;10;10;4;4];
figure(1),clf(1)
already_plotted=false(size(A));
L= A == 5;
plot(A(L),B(L),'rx')
already_plotted(L)=true;
hold on
L= A == 3 & ~already_plotted;
plot(A(L),B(L),'bx')
already_plotted(L)=true;
L= ~already_plotted;
plot(A(L),B(L),'gx')
axis([1 6 3 11])
axis([1 6 3 11])

3 Kommentare

Marisabel Gonzalez
Marisabel Gonzalez am 5 Apr. 2019
Bearbeitet: Marisabel Gonzalez am 5 Apr. 2019
Thanks Rik! Also, only 4 of my 6 points show up...
Rik
Rik am 5 Apr. 2019
See my edited answer. You will only see 5 points, because two of them overlap (5,10).
Marisabel Gonzalez
Marisabel Gonzalez am 5 Apr. 2019
Makes sense. Thank you once again!

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Produkte

Version

R2018a

Community Treasure Hunt

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

Start Hunting!

Translated by