Fix bugs with negative and mixed normal/denormal inputs in hypot implementation.
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
[libc] Fix bugs with negative and mixed normal/denormal inputs in hypot implementation.
libc/utils/MPFRWrapper/MPFRUtils.cpp | ||
---|---|---|
315–318 ↗ | (On Diff #390746) | based on my testing, the tests still pass if you don't update this file, could you add something to explain these changes, and possibly split them off into their own patch? |
libc/utils/MPFRWrapper/MPFRUtils.cpp | ||
---|---|---|
315–318 ↗ | (On Diff #390746) | This is because without this change, the ULPs are computed off by a factor of 2^(-mantissaWidth), and hence all the tests still pass. As in the comments in line 287-294, the factor that we divide is eps(...) which should be 2^(exponent - mantissaWidth) for normal numbers, and 2^(1 - exponentBias - mantissaWidth) for denormal numbers. With changes in this file, updated HypotTests without the fix in Hypot.h shall fail. In any case, I split the change in the ULP function to https://reviews.llvm.org/D114726 |
[libc] Fix bugs with negative and mixed normal/denormal inputs in hypot implementation.
[libc] Fix bugs with negative and mixed normal/denormal inputs in hypot implementation.
[libc] Fix bugs with negative and mixed normal/denormal inputs in hypot implementation.
[libc] Fix bugs with negative and mixed normal/denormal inputs in hypot implementation.