small floating point has been considred as zero value!

5 views (last 30 days)
hi,
x=0.16
if x>0.1
d=1
else
d=0
end
the answer is 0
I do not know where is the problem?
  1 Comment
Les Beckham
Les Beckham on 1 Mar 2024
I don't see a problem. Are you sure this is really the code that you are having the problem with?
x = 0.16
x = 0.1600
if x > 0.1
d = 1
else
d = 0
end
d = 1

Sign in to comment.

Answers (2)

Steven Lord
Steven Lord on 1 Mar 2024
More likely than not, your value for x is not what you think it is. If we run your code on Answers:
x=0.16
x = 0.1600
if x>0.1
d=1
else
d=0
end
d = 1
Now if your number was part of a larger array with numbers of varying magnitudes, part of the display may look like 0.16 without it actually being 0.16:
x = [1e-6 0.16e-3]
x = 1x2
1.0e-03 * 0.0010 0.1600
Note that x(2) displays as 0.16 but there's that "1.0e-03 *" right below the name of the variable. So it's actually much smaller; basically one one-thousandth of 0.16:
y = x(2)
y = 1.6000e-04
1000*y-0.16
ans = 0
and that is not greater than 0.1 (aka 1.0000e-01)
format shorte
z = 0.1
z =
1.0000e-01
So when we use y in place of 0.16, MATLAB correctly identifies that y is not greater than 0.1:
if y > 0.1
d = 1
else
d = 0
end
d =
0

Star Strider
Star Strider on 1 Mar 2024
Your code works correctly when I run it here —
x=0.16
x = 0.1600
if x>0.1
d=1
else
d=0
end
d = 1
d
d = 1
.

Categories

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

Products


Release

R2022b

Community Treasure Hunt

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

Start Hunting!