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

Java Discussion :

Probleme de calcul: resultat different avec long et float


Sujet :

Java

  1. #1
    Membre du Club
    Inscrit en
    Mai 2005
    Messages
    82
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 82
    Points : 48
    Points
    48
    Par défaut Probleme de calcul: resultat different avec long et float
    Bonjour,

    Je souhaite faire le calcul suivant:
    ((((56459264-56165032)-(56459264-56351904))*27000000)/(((1018407817*300)+207)-((1018404453*300)+299)))*8

    Voila ce que me donne la calculatrice Google:
    ((((56 459 264 - 56 165 032) - (56 459 264 - 56 351 904)) * 27 000 000) / (((1 018 407 817 * 300) + 207) - ((1 018 404 453 * 300) + 299))) * 8 = 40 000 031.7
    et qui me semble etre le bon resultat.

    Mais en Java, quand je fais le calcul en utilisant uniquement des types float, voila le resultat:
    3.97362E7

    Et quand j'utilise uniquement des types long, voila le resultat:
    40000024

    Avez vous une idee de ce qu'il se passe?
    Comment retrouver le bon resultat? (D'ailleurs lequel est le bon?)

    Merci,

    Dazdh

  2. #2
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Points : 7 163
    Points
    7 163
    Par défaut
    Le bon résultat est celui donné par Google.
    Lorsque des doubles sont utilisé, le résultat est correct en Java.
    Avec des long, le résultat est erroné car les divisions ne sont pas entières.
    Avec des float, le résultat est également erroné car la granularité dans les grandes valeurs augmente. Exemple simpliste :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    if( Float.MAX_VALUE == Float.MAX_VALUE - 1 ) { System.out.println( "egal" ); }
    else { System.out.println( "pas egal" ); }
    affichera :
    Le type double connait le même "problème", mais avec des valeurs bien supérieures, ce qui explique qu'en double on a le bon résultat.

    Note bien que ce fonctionnement est commun à tout les langages et n'a rien à voir avec Java. Cela provient du mode de représentation interne des types au niveau matériel.

  3. #3
    Membre du Club
    Inscrit en
    Mai 2005
    Messages
    82
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 82
    Points : 48
    Points
    48
    Par défaut
    Merci.

    Tres interressant cet exemple. A lire comme ca, on dirait qu'il y a un gros bug! Mais tu as raison, c'est la representation interne qui change.

    Ok pour les doubles, je vais utiliser ca.

    A+

  4. #4
    Modérateur
    Avatar de nouknouk
    Homme Profil pro
    Inscrit en
    Décembre 2006
    Messages
    1 655
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 655
    Points : 2 161
    Points
    2 161
    Par défaut
    +1 avec dinobogan.

    A noter qu'en java, tu peux utiliser les classes BigDecimal et BigInteger pour manipuler des très grand nombres et/ou des nombres décimaux en avec une précision garantie.

  5. #5
    Membre éprouvé
    Avatar de hasalex
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2009
    Messages
    879
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Java

    Informations forums :
    Inscription : Janvier 2009
    Messages : 879
    Points : 1 269
    Points
    1 269
    Par défaut
    Il y a déjà eu des discussions sur ce sujet. Si bug il y a, il n'est pas du à java, pais au fonctionnement en virgule flottante. Les mêmes résultats seront observable en C, par exemple. De plus, il faut aussi se méfier des résultats avec les double.

    J'avais recensé des résultats assez spectaculaires sur mon wiki. La conclusion de tout ça, c'est que BigDecimal est utile même pour des nombres de taille limitée.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 8
    Dernier message: 30/05/2012, 21h57
  2. [AC-2010] probleme table de resultat sur 2 tables avec regroupement
    Par anofer dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 29/11/2010, 22h15
  3. Réponses: 1
    Dernier message: 16/06/2009, 20h28
  4. probleme d'affichage d'un resultat webservice avec PHP
    Par anouarsurvive dans le forum Services Web
    Réponses: 4
    Dernier message: 29/05/2007, 14h23
  5. [FLASH 8] Problemes de calcul précis avec FLASH
    Par ZecMan dans le forum Flash
    Réponses: 1
    Dernier message: 20/02/2006, 14h03

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