fpclassify, isfinite, isnormal, isnan, isinf - Macros de classification en
virgule flottante
Bibliothèque de math (
libm,
-lm)
#include <math.h>
int fpclassify(x);
int isfinite(x);
int isnormal(x);
int isnan(x);
int isinf(x);
fpclassify(),
isfinite(),
isnormal() :
_ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L
isnan():
_ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L
|| _XOPEN_SOURCE
|| /* Depuis la glibc 2.19 : */ _DEFAULT_SOURCE
|| /* glibc <= 2.19 : */ _BSD_SOURCE || _SVID_SOURCE
isinf():
_ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L
|| /* Depuis la glibc 2.19 : */ _DEFAULT_SOURCE
|| /* glibc <= 2.19 : */ _BSD_SOURCE || _SVID_SOURCE
Les nombres en virgule flottante peuvent avoir des valeurs spéciales,
telles que infini ou NaN. Avec la macro
fpclassify(x), il
est possible de connaître le type de
x. La macro prend en
paramètre n'importe quelle expression en virgule flottante. Le
résultat est l'une des valeurs suivantes :
- FP_NAN
-
x est non numérique (NaN, pour
« Not a Number »).
- FP_INFINITE
-
x est une valeur infinie positive ou
négative.
- FP_ZERO
-
x est nul.
- FP_SUBNORMAL
-
x est trop petit pour être
représenté au format normalisé.
- FP_NORMAL
- si aucune des valeurs précédentes n'est
vraie, alors c'est qu'il doit s'agir d'un nombre à virgule
flottante normal.
Les autres macros fournissent une réponse courte à des questions
standard.
-
isfinite(x)
- renvoie une valeur non nulle si
(fpclassify(x) != FP_NAN && fpclassify(x) != FP_INFINITE)
-
isnormal(x)
- renvoie une valeur non nulle si (fpclassify(x) ==
FP_NORMAL)
-
isnan(x)
- renvoie une valeur non nulle si (fpclassify(x) ==
FP_NAN)
-
isinf(x)
- renvoie 1 si x est une valeur infinie positive, et
-1 si x est une valeur infinie négative.
Pour une explication des termes utilisés dans cette section, consulter
attributes(7).
Interface |
Attribut |
Valeur |
fpclassify(), isfinite(), isnormal(),
isnan(), isinf() |
Sécurité des threads |
MT-Safe |
POSIX.1-2001, POSIX.1-2008, C99.
Pour
isinf(), les normes indiquent simplement que la valeur de retour est
non nulle si et seulement si le paramètre a une valeur infinie.
Dans la glibc 2.01 et les versions précédentes,
isinf() renvoie une valeur non nulle (habituellement, 1) si
x
est une valeur infinie positive ou négative. C'est tout ce qu'exige
C99.
finite(3),
INFINITY(3),
isgreater(3),
signbit(3)
La traduction française de cette page de manuel a été
créée par Christophe Blaess
<
https://www.blaess.fr/christophe/>, Stéphan Rafin
<
[email protected]>, Thierry Vignaud
<
[email protected]>, François Micaux, Alain Portal
<
[email protected]>, Jean-Philippe Guérard
<
[email protected]>, Jean-Luc Coulon (f5ibh)
<
[email protected]>, Julien Cristau
<
[email protected]>, Thomas Huriaux <
[email protected]>,
Nicolas François <
[email protected]>, Florentin
Duneau <
[email protected]>, Simon Paillard
<
[email protected]>, Denis Barbier
<
[email protected]>, David Prévot <
[email protected]> et
Cédric Boutillier <
[email protected]>
Cette traduction est une documentation libre ; veuillez vous reporter
à la
GNU
General Public License version 3 concernant les conditions de copie
et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.
Si vous découvrez un bogue dans la traduction de cette page de manuel,
veuillez envoyer un message à
[email protected]