IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C# Discussion :

Problème avec Math.Pow()


Sujet :

C#

  1. #1
    darkloy
    Invité(e)
    Par défaut Problème avec Math.Pow()
    Bonjour,

    J'ai une erreur avec la méthode Pow de Math qui me sort un résultat incohérent pour moi :

    Ceci me retourne 999.9999 ... Pour moi le résultat devrait être 1000...

    Pour info je suis sous le .NET d'Unity d'où le Math(f)

    Une idée ?

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Les nombres à virgule flottante binaires (float ou double) ne permettent pas de stocker toutes les valeurs décimales de façon exacte, car le nombre n'est pas en base 10 mais en base 2. Donc 0.1 n'est pas stocké comme exactement 0.1, mais plutôt comme 0.999999999.... et des poussières. Cette approximation se propage dans l'opération Math.Pow, d'où le résultat inexact. Si tu veux plus d'infos à ce sujet, je te suggère cet article (en anglais).

    Sache en tous cas que double est plus précis que float, et dans ton cas ça donne bien 1000 (enfin, c'est affiché comme 1000, mais en réalité la valeur n'est pas exactement 1000)

    Si tu dois travailler avec des valeurs exactes (calculs financiers par exemple), utilise le type decimal plutôt que float ou double.

Discussions similaires

  1. problème avec Math.cos
    Par sassoul dans le forum C#
    Réponses: 4
    Dernier message: 19/11/2012, 21h38
  2. Problème fonction Math.pow
    Par suNiz dans le forum Débuter avec Java
    Réponses: 21
    Dernier message: 13/01/2012, 12h47
  3. problème avec Math::Trig
    Par alainbb dans le forum Modules
    Réponses: 0
    Dernier message: 04/01/2012, 13h50
  4. Multiplication d'un float avec Math.Pow()
    Par Lelio1407 dans le forum C#
    Réponses: 8
    Dernier message: 06/11/2011, 11h20
  5. erreur avec math.pow
    Par ricky78 dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 30/01/2011, 20h51

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo