Next: Errors accumulate, Previous: Inexact representation, Up: Inexactness of computations [Contents][Index]
Because the underlying representation can be a little bit off from the exact value, comparing floating-point values to see if they are exactly equal is generally a bad idea. Here is an example where it does not work like you would expect:
$ gawk 'BEGIN { print (0.1 + 12.2 == 12.3) }' -| 0
The general wisdom when comparing floating-point values is to see if they are within some small range of each other (called a delta, or tolerance). You have to decide how small a delta is important to you. Code to do this looks something like the following:
delta = 0.00001 # for example difference = abs(a - b) # subtract the two values if (difference < delta) # all ok else # not ok
(We assume that you have a simple absolute value function named
abs()
defined elsewhere in your program.) If you write a
function to compare values with a delta, you should be sure
to use ‘difference < abs(delta)’ in case someone passes
in a negative delta value.