Clear Filters
Clear Filters

For Loop Not Executing

5 views (last 30 days)
Matthew Worker
Matthew Worker on 17 Sep 2016
Commented: Rena Berman on 8 Feb 2017
Hi all!
Consider the following example:
h=(2/1000);
for i=8*h+h:h:9*h
i
end
i =
0.0180
And similarly,
>> for i=11*h+h:h:12*h
i
end
i =
0.0240
But when I do this:
>> for i=9*h+h:h:10*h
i
end
it doesn't enter the for loop! What is going on? Thanks for the help!
  2 Comments
Star Strider
Star Strider on 29 Jan 2017
You can go as far as you did, but Rena Berman will reconstitute it in a few days.
Does Sisyphus begin to sound relevant?
Rena Berman
Rena Berman on 8 Feb 2017
(Answers dev) Restored edit

Sign in to comment.

Accepted Answer

Mischa Kim
Mischa Kim on 17 Sep 2016
Edited: Mischa Kim on 17 Sep 2016
Gopal, this is because
9*h+h - 10*h
ans =
3.469446951953614e-18
and
11*h+h - 12*h
ans =
0
Just because the terms above are all symbolically equal to zero, does not necessarily mean they are also numerically equal to zero. The first expression is not which is why the loop does not get executed.
Star Strider provides more detail below.
  4 Comments
Star Strider
Star Strider on 17 Sep 2016
As always, my pleasure.
N/A
N/A on 17 Sep 2016
Of course! Thanks so much I should have realized this.

Sign in to comment.

More Answers (1)

David Goodmanson
David Goodmanson on 17 Sep 2016
For the floating point number h you are basically asking if n*h + h == (n+1)*h for various values of n. Well, sometimes the two sides are equal (to machine precision), sometimes not. For n=9 the left hand side is bigger than the right hand side by 3e-18, so the for loop doesn't do anything.
It's never a good idea to do exact equality tests with floating point numbers.

Categories

Find more on Loops and Conditional Statements in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!