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 :

Erreur de précision


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2002
    Messages : 97
    Par défaut Erreur de précision
    Bonjour à tous, voici grosso modo mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    double a = 720;
    double b = 152;
    double c = a/b;
    if (c==5){
       cout << "Youhou" << std::endl;
    }
    if (abs(c-5) < 1e-16){
       cout << "Bouhouhou" << std::endl;
    }
    et j'obtiens sur ma machine : "Youhou" et "Bouhouhou" mais lorsque j'envoie le code sur mon serveur, je le compile (machine linux), je n'obtiens que "Bouhouhou"

    Existe-t-il des règles à respecter pour bien écrire un calcul et ne pas avoir des erreurs d'approximation ?

  2. #2
    Membre Expert

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Août 2004
    Messages
    1 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Août 2004
    Messages : 1 391
    Par défaut
    Bonsoir,

    Faits touts tes calculs à "epsilon" près et tu n'auras pas de problème. C'est ainsi qu'on doit faire lorsque l'on travail avec des réels.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2002
    Messages : 97
    Par défaut
    En fait, ce qui m'ennuie, c'est que je fais après un ceil(c) par après. Sachant que mon c vaut 5.000...0001 le résultat vaudra 6 (sur ma machine, 5). Là je ne vois pas comment faire à epsilon près. Si quelqu'un a une idée de bonne pratique.

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2002
    Messages : 97
    Par défaut
    Je suis obligé de rester en "double". Là je suis tombé sur ce cas particulier, pour toutes autres valeurs, ça marche bien, sauf lorsqu'on tombe sur un entier. Enfin j'ai pas testé toutes les possibilités.

  5. #5
    Membre émérite Avatar de Steph_ng8
    Homme Profil pro
    Doctorant en Informatique
    Inscrit en
    Septembre 2010
    Messages
    677
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Doctorant en Informatique

    Informations forums :
    Inscription : Septembre 2010
    Messages : 677
    Par défaut
    Bonjour,
    Désolé de mettre mon grain de sel, mais 720 / 152 = 4,74 à 0,01 près.
    C'est étrange que tu obtiennes un c si près de 5.
    Après un ceil(), ok, mais pas avant.

    Tu es sûr de tes valeurs ?

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2002
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2002
    Messages : 97
    Par défaut
    j'accepte ce grain de sel, je me suis trompé en tapant. C'est 760 à la place de 720. Autant pour moi.

    J'ai fixé le problème avec des nombres à virgule fixe.

Discussions similaires

  1. [PHP 5.4] Point dans un polygone : erreurs de précision
    Par nakwakwak dans le forum Langage
    Réponses: 3
    Dernier message: 13/02/2013, 00h13
  2. Contourner une erreur de précision?
    Par Giansolo dans le forum MATLAB
    Réponses: 2
    Dernier message: 12/10/2011, 11h36
  3. Réponses: 19
    Dernier message: 21/12/2007, 17h27
  4. Changer un message d'erreur (précisions)
    Par byrdo dans le forum IHM
    Réponses: 5
    Dernier message: 16/08/2007, 14h19

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