NaN - Définition

Source: Wikipédia sous licence CC-BY-SA 3.0.
La liste des auteurs de cet article est disponible ici.

Introduction

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.

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 unique 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.

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.

Page générée en 0.042 seconde(s) - site hébergé chez Contabo
Ce site fait l'objet d'une déclaration à la CNIL sous le numéro de dossier 1037632
A propos - Informations légales | Partenaire: HD-Numérique
Version anglaise | Version allemande | Version espagnole | Version portugaise