Guaranteed precision of sqrt function in C/C++

前端 未结 2 1014
误落风尘
误落风尘 2021-01-05 16:44

Everyone knows sqrt function from math.h/cmath in C/C++ - it returns square root of its argument. Of course, it has to do it with some

相关标签:
2条回答
  • 2021-01-05 17:07

    This question was already answered here as Chris Dodd noticed in the comments section. In short: it's not guaranteed by C++ standard, but IEEE-754 standard guarantees me that the result will be as close to the 'real result' as possible, i.e. error will be less than or equal to 1/2 unit-in-the-last-place. In particular, if the result can be precisely stored, it should be.

    0 讨论(0)
  • 2021-01-05 17:11

    For C99, there are no specific requirements. But most implementations try to support Annex F: IEC 60559 floating-point arithmetic as good as possible. It says:

    An implementation that defines __STDC_IEC_559__ shall conform to the specifications in this annex.

    And:

    The sqrt functions in <math.h> provide the IEC 60559 square root operation.

    IEC 60559 (equivalent to IEEE 754) says about basic operations like sqrt:

    Except for binary <-> decimal conversion, each of the operations shall be performed as if it first produced an intermediate result correct to infinite precision and with unbounded range, and then coerced this intermediate result to fit in the destination's format.

    The final step consists of rounding according to several rounding modes but the result must always be the closest representable value in the target precision.

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