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

R Discussion :

Soustraction qui retourne un mauvais résultat


Sujet :

R

  1. #1
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Janvier 2013
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2013
    Messages : 16
    Points : 4
    Points
    4
    Par défaut Soustraction qui retourne un mauvais résultat
    Bonjour,
    J'ai un problème très étrange dans mon script R

    La partie qui pose problème est celle-ci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    print(paste("heureArrivee[i]",heureArrivee[i]))
    print(paste("tempsCourant",tempsCourant))
    tempsAttendu <- heureArrivee[i] - tempsCourant
    print(paste("tempsAttendu",tempsAttendu))
    cela me retourne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    [1] "heureArrivee[i] 4.1"
    [1] "tempsCourant 4"
    [1] "tempsAttendu 0.0999999999999996"

    Comment est-il possible qu'une simple soustraction correspondant à 4.1 - 1 renvoi 0.0999999999999996

    Ce qui est d'autant plus étrange, est que dans certain cas, le programme fait comme ci ce nombre était vraiment 0.1:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    print(paste("caisse avant",caisse[j]))
    caisse[j] <- caisse[j] - tempsAttendu
    print(paste("tempsAttendu",tempsAttendu))
    print(paste("caisse apres",caisse[j]))
    retourne:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    [1] "caisse avant 1"
    [1] "tempsAttendu 0.0999999999999996"
    [1] "caisse apres 0.9"
    [1] "tempsCourant 4.1"
    Si cela fonctionnait dans tout les cas, je m'en inquiéterais pas trop, mais dans certains ça cela me foire mon résultat et donc ça pose vraiment un problème
    Voici un exemple de cas où ça me foire le résultat:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    [1] "heureArrivee[i] 4.2"
    [1] "tempsCourant 4.1"
    [1] "tempsAttendu 0.100000000000001"
    [1] "caisse avant 0.9"
    [1] "tempsAttendu 0.100000000000001"
    [1] "caisse apres 0.8"
    [1] "heureArrivee[i] 4.2"
    [1] "tempsCourant 4.1"
    [1] "tempsAttendu 0.100000000000001"
    [1] "caisse avant 1"
    [1] "tempsAttendu 0.100000000000001"
    [1] "caisse apres 0.899999999999999"
    [1] "tempsCourant 4.2"

    Je n'arrive pas à comprendre comment cela est possible, et je ne pense pas que cela ai un rapport avec le reste de mon code étant donné que les valeur heureArrivee[i] et tempsCourant sont bonne dans les print

    Si quelqu'un aurait une piste pour m'aider à résoudre ce problème...
    Merci d'avance

  2. #2
    Membre éclairé
    Homme Profil pro
    Ingénieur de recherche
    Inscrit en
    Janvier 2012
    Messages
    325
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur de recherche
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Janvier 2012
    Messages : 325
    Points : 888
    Points
    888
    Par défaut
    C'est un cas très classique en informatique, quand un nombre est stocké en mémoire, il ne l'est qu'avec une certaine précision, du coup sur certaines opérations on a une petite erreur qui apparait.
    Ex :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    > 1e-15+1-1
    [1] 1.110223e-15
    > 1e-20+1-1
    [1] 0
    Cela dit ce genre de problème n'est censé apparaitre que quand on manipule des nombres avec beaucoup de chiffres (qu'ils soient avant ou après la virgule). Dans ton cas avec une seule décimale il ne devrait pas y avoir de problèmes. Il faudrait plus de précision sur comment tu obtiens tes variables et quelle est leur classe, je pense que ça viens d'elles.

Discussions similaires

  1. [MySQL] Requête qui retourne un mauvais résultat
    Par chris22 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 07/03/2012, 16h15
  2. Requete sql retourne un mauvais résultat
    Par ramoucha23 dans le forum Oracle
    Réponses: 2
    Dernier message: 29/08/2011, 11h11
  3. [MySQL] requête qui renvoie un mauvais résultat
    Par Souri84 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 03/12/2010, 09h18
  4. Réponses: 34
    Dernier message: 24/05/2007, 16h19
  5. [VB.NET] DataSet qui ne retourne pas de résultat
    Par Lois dans le forum Windows Forms
    Réponses: 4
    Dernier message: 02/06/2004, 17h07

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