How to get the smallest next or previous possible double value supported by the architecture?

后端 未结 1 1706
夕颜
夕颜 2021-01-17 12:25

Lets say I have a double variable d. Is there a way to get the next or previous value that is supported by the CPU architecture.

As a triv

相关标签:
1条回答
  • 2021-01-17 12:28

    Actually, an IEEE 754 floating-point architecture makes this easy: thanks to the standard, the function is called nextafter in nearly all languages that support it, and this uniformity allowed me to write an answer to your question with very little familiarity with Java:

    The java.lang.Math.nextAfter(double start, double direction) returns the floating-point number adjacent to the first argument in the direction of the second argument.

    Remember that -infinity and +infinity are floating-point values, and these values are convenient to give the direction (second argument). Do not make the common mistake of writing something like Math.nextAfter(x, x+1), which only works as long as 1 is greater than the ULP of x.

    Anyone who writes the above probably means instead Math.nextAfter(x, Double.POSITIVE_INFINITY), which saves an addition and works for all values of x.

    0 讨论(0)
提交回复
热议问题