- NaN
-
NaN (« Not a Number », en français « pas un nombre ») est, en informatique, une valeur ou un symbole produit par le résultat d'une opération arithmétique invalide, plus spécialement dans les calculs utilisant la virgule flottante. Par exemple, la plupart des unités de calcul en virgule flottante étant incapables de calculer la racine carrée de nombres négatifs, elles indiqueront que l'opération est invalide et donneront alors un résultat équivalent à NaN.
Le NaN fait partie du standard IEEE 754.
Sommaire
Propriétés
Obtenir NaN comme résultat
On obtient NaN pour toutes les opérations qui sont des indéterminées mathématiques : 0/0, ∞-∞, ∞/∞, 0*∞, et dans certaines librairies 1∞.
Opérations avec NaN
NaN est en quelque sorte un élément absorbant. N'importe quoi additionné, multiplié, ou toute fonction mathématique appliquée à NaN donne NaN. Même NaN+∞ donne NaN, alors que pour tout nombre x, (donc, pas NaN ni -∞), x+∞ donne ∞.
Comparaisons
NaN est une valeur qui a des propriétés uniques par rapport à tous les nombres. En particulier, toute comparaison "égal", "supérieur", "inférieur", "supérieur ou égal", "inférieur ou égal" impliquant NaN donne la réponse booléenne "faux", alors que toute comparaison "différent" donne le résultat "vrai".
Cela conduit même à ce que la comparaison "NaN==NaN" ("==" signifie "est-ce que ces valeurs sont égales) donne la réponse "faux". C'est la seule valeur ayant cette propriété (même l'infini, en IEEE 754, donne "vrai" pour la requête "Inf==Inf").
NaN est également la seule valeur de x pour laquelle on ait la réponse "faux" à la question "x<=Inf" (« x est-il inférieur ou égal à l'infini ? »).
De ce qui précède, on déduit que si l'on veut vérifier si x vaut NaN, faire « x==NaN » serait une erreur. Il faut plutôt faire « x~=x », qui répondra « vrai » si x vaut NaN
Cela peut être un moyen efficace de poser au programme la question "est-ce que x est NaN ?" dans un langage qui ne dispose pas d'une fonction spécialisée pour cela[1].
Ces propriétés, en particulier le fait que deux NaN ne se valent pas, paraissent assez choquantes si on traite NaN comme un nombre. Elles se comprennent mieux quand on admet que NaN signifie que la valeur ne peut être connue.
Voir aussi
Références
Catégories :- Calcul informatique
- Norme IEEE
Wikimedia Foundation. 2010.