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

Langage Java Discussion :

Additionner des doubles


Sujet :

Langage Java

  1. #1
    Débutant  
    Profil pro
    Inscrit en
    Juin 2013
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2013
    Messages : 1 225
    Points : 132
    Points
    132
    Par défaut Additionner des doubles
    Bonjour,

    J'ai des double, et je souhaite leur ajouté une valeur à chaque fois:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    	Double d1= 2.3960228;
    	Double d2 = 48.925613;
     
        	d1 = d1 + 0.0000005;
        	d2 = d2 + 0.000005;
    Résultat:
    d1 : 2.3960233
    d2 : 48.925618
    d1: 2.3960238
    d2 : 48.925623
    d1 : 2.3960243
    d2 : 48.925628
    d1 : 2.3960248
    d2 : 48.925633000000005
    d1 : 2.3960253000000002
    d2 : 48.925638000000006
    d1 : 2.3960258000000003
    d2 : 48.92564300000001

    Le porblème, c'est que au bout d'un moment, il m'ajoute plein de 0 comme on peut le voir

    Je vois pas d'où vient le problème.

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Le problème est qu'un double est représenté sur un nombre finis de bits (64) et tous les nombres compris entre 2-1074et (2-2-52)×21023, un nombre infini de nombres en théorie. Or, il est impossible de représenter une infinité de nombres sur un nombre fini de bits, donc il y a des valeurs qui manquent. Les résultats des calculs sont donc approximés lorsqu'ils tombent sur ces valeurs.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    la conversion base 10 => binaire pour les nombres à virgule flottante est approximative. Il y a une légère erreur. Celle-ci se cumule sur chaque addition jusqu'à dépasser l'arrondi que fait l'algorithme qui convertis le nombre flottant en base 10 pour affichage.

    3 possibilités:
    1) utiliser un decimal format pour cacher les erreur d'arrondis, en précisant par exemple que tu veux juste les 7 premières décimales
    2) ne pas cumuler les erreurs: ajouter directement le totale plutot que de faire plein de minuscules additions
    3) ne pas utiliser des nombres flottants


    un nombre flottant doit toujours être vue comme une "valeur +- delta de précision". Après 5 additions, tu en est déjà à "valeur +- 5 delta". Je te renvoie à l'analyse numérique pour les calculs avec erreur.

Discussions similaires

  1. Réponses: 4
    Dernier message: 14/10/2005, 14h02
  2. IBExpert : troncature des double precision ?
    Par Magnus dans le forum Outils
    Réponses: 1
    Dernier message: 25/08/2005, 15h07
  3. [TList]: trier des doubles
    Par PpPool dans le forum Langage
    Réponses: 6
    Dernier message: 11/08/2005, 11h34
  4. [C/C++] afficher des doubles dans une message box
    Par lalaurie40 dans le forum MFC
    Réponses: 1
    Dernier message: 24/05/2005, 14h55
  5. [CR] Additionner des heures
    Par sbis dans le forum Formules
    Réponses: 4
    Dernier message: 22/03/2004, 15h34

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