AryaWu's picture
Upload folder using huggingface_hub
78d2150 verified
@node float.h
@section @file{float.h}
POSIX specification:@* @url{https://pubs.opengroup.org/onlinepubs/9799919799/basedefs/float.h.html}
Gnulib module: float-h
@mindex float-h
Portability problems fixed by Gnulib:
@itemize
@item
The conversion from @code{int} to @code{long double} in incorrect on some
platforms:
glibc 2.7 on Linux/SPARC64.
@item
The values of @code{LDBL_*} macros are incorrect on some platforms:
On OpenBSD 4.0 and MirBSD 10, they are the same as the values of the
@code{DBL_*} macros, although @samp{long double} is a larger type than
@samp{double}.
On FreeBSD/x86 6.4, they represent the incorrect 53-bit precision assumptions
in the compiler, not the real 64-bit precision at runtime.
On PowerPC with gcc 8.3 and the default @option{-mabi=ibmlongdouble},
they don't reflect the ``double double'' representation of @code{long double}
correctly; the non-IEEE representation is tricky, as it is a pair of
IEEE @code{double} values such that adding the two elements and
rounding to even yields the high element of the pair, and arithmetic
overflow has undefined behavior instead of reliably yielding infinity.
@item
The macros
@code{FLT_HAS_SUBNORM}, @code{FLT_DECIMAL_DIG}, @code{FLT_TRUE_MIN},
@code{DBL_HAS_SUBNORM}, @code{DBL_DECIMAL_DIG}, @code{DBL_TRUE_MIN},
@code{LDBL_HAS_SUBNORM}, @code{LDBL_DECIMAL_DIG}, @code{LDBL_TRUE_MIN},
that were added in ISO C 11, are missing on some platforms:
gcc 4.5.4, clang 7, Solaris 11.3 with Sun C.
@item
The macro @code{LDBL_DECIMAL_DIG} is missing on some platforms:
MSVC 14.
@item
The value of macro @code{FLT_TRUE_MIN} is not a @code{float} on some platforms:
AIX 7.1 with xlc.
@item
The macros
@code{FLT_IS_IEC_60559}, @code{FLT_NORM_MAX}, @code{FLT_SNAN},
@code{DBL_IS_IEC_60559}, @code{DBL_NORM_MAX}, @code{DBL_SNAN},
@code{LDBL_IS_IEC_60559}, @code{LDBL_NORM_MAX}, @code{LDBL_SNAN},
that were added in ISO C 23, are missing on some platforms:
gcc 14 without @code{-std=c23} or @code{-std=gnu23}, clang 18, musl libc 1.2.5, AIX 7.3 with xlclang, Solaris 11.3 with Sun C, MSVC 14.
@end itemize
Portability problems not fixed by Gnulib:
@itemize
@item
The macro @code{FLT_ROUNDS} is a constant expression and does not represent
the current rounding mode on some platforms:
glibc 2.11, HP-UX 11, mingw.
@item
The value of @code{FLT_TRUE_MIN} is not a constant on some platforms:
FreeBSD/x86.
@item
The values of @code{FLT_SNAN}, @code{DBL_SNAN}, @code{LDBL_SNAN} are not
constants on some platforms:
AIX 7.3 with xlclang, and all platforms which use the gnulib replacements.
@end itemize