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 Delphi Discussion :

Delphi 7 problème avec floattostr et single


Sujet :

Langage Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 25
    Par défaut Delphi 7 problème avec floattostr et single
    Bonjour,
    Débutant sur D7, j'ai un problème avec floattostr() :
    Je déclare une variable a de type Single que j'initialise à 22.2
    Si je fais un FloatToStr(a) j'obtient 22.2000007629395;
    Si je déclare ma variable en Double, le résultat est OK (22.2).
    Pardonnez moi si cette question est idiote mais je ne trouve pas d'explication sur developper.com et je deviens chèvre.
    Merci d'avance pour votre aide et un grand merci à tous ceux qui participent à ce site magnifique.
    Thierry

  2. #2
    Rédacteur
    Avatar de Pedro
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    5 411
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 5 411
    Par défaut
    Salut
    c'est tout simplement une "erreur" d'approximation et de nombres significatifs... Le double est plus précis que le Single (mais prend plus de place en mémoire )
    Pedro
    Aucune réponse aux sollicitations techniques par MP

    Faut pas attendre d'en avoir besoin pour s'en servir... (Lucien Stéphane)

    Les pages Source C'est bon. Mangez-en!
    Le défi Delphi
    Règles du forum - FAQ Delphi - Pensez au chtit
    Aéroclub Bastia Saint-Exupéry

  3. #3
    Membre Expert
    Avatar de Juju_41
    Homme Profil pro
    Développeur en systèmes embarqués
    Inscrit en
    Février 2003
    Messages
    974
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur en systèmes embarqués

    Informations forums :
    Inscription : Février 2003
    Messages : 974
    Par défaut
    C'est exactement ça

    Pour aller un peu plus loin, dans un ordinateur, tout est codé en binaire (base 2).
    En base 10 un nombre se décompose comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    22,2 = 2 * (10^1) + 2 * (10^0) + 2 * (10^-1)
    Mais la base 10 ne permet pas de représenter tout nombre à virgule : par exemple : 1/3 est approximé à 0.3333333... et bien en base 2, c'est pareil, certains chiffrent doivent être approximés.

    En base 2, un nombre se décompose comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    abc,def = a * (2^2) + b * (2^1) + c * (2^0) + d * (2^-1) + e * (2^-2) + f * (2^-3)
    Ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    2,5 (base 10) = 10,1 (base 2) = 1 * (2^1) + 0 * (2^0) + 1 * (2^-1)
    Mais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    22,2 (base 10) = 10110,00110011001100110011... (base 2)
    22,2 est donc obligatoirement approximé par l'ordinateur ... mais l'approximation est bien meilleure avec la précision d'un double qu'avec la précision d'un single. Si tu veux plus de détails n'hésites pas

  4. #4
    Membre éprouvé Avatar de Guile
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    130
    Détails du profil
    Informations personnelles :
    Localisation : France, Yvelines (Île de France)

    Informations forums :
    Inscription : Avril 2002
    Messages : 130
    Par défaut
    utilise plutot :

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 25
    Par défaut
    Merci à tous les trois,
    FormatFloat() çà marche puisqu'on bloque à 2 décimales.
    Pour l'aproximation, j'entend bien, mais à quoi sert un single si les calculs qui en découlent sont erronés ?
    Dans le "Delphi 7 Studio" de Olivier et Paul, le programme exemple "Calculatrice1" utilise des Single et (après compile) les résultats de la calculatrice sur les reels sont bien évidemments faux.
    Utilisez vous systématiquement des doubles pour les programmes effectuant des calculs sur les reels ?
    Merci encore
    Thierry

  6. #6
    Rédacteur
    Avatar de Pedro
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    5 411
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 5 411
    Par défaut
    Salut
    pour ma part, oui j'utilise des double. Je suis un trnsfuge du TP 7.0 et les real étant là sous Delphi plus pour des raisons de compatibilité qu'autre chose (cf: ) je suis tout naturellement passé sur les double car les singles étaient comme tu le soulignes, trop imprécis... maintenant, tout dépend de ce que tu veux faire... Un Double prend le double (comme le monde est bien fait :lo de place qu'un Single (4 contre 8) et il a le double de précision également (chiffres significatifs: 7-8 contre 15-16).
    Si tu as un gros tableau de réels où la précision n'est pas tant importante, il vaut mieux se tourner vers les single... Si tu ne peux pas te passer d'une grosse précision (comme moi par exemple) et bien tu utilises les double...
    Pedro
    Aucune réponse aux sollicitations techniques par MP

    Faut pas attendre d'en avoir besoin pour s'en servir... (Lucien Stéphane)

    Les pages Source C'est bon. Mangez-en!
    Le défi Delphi
    Règles du forum - FAQ Delphi - Pensez au chtit
    Aéroclub Bastia Saint-Exupéry

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    25
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 25
    Par défaut
    Merci Pedro,
    Bonne journée

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 02/10/2005, 13h18
  2. [Delphi 2005] Problème avec JVCL
    Par jpminiscloux dans le forum EDI
    Réponses: 3
    Dernier message: 11/09/2005, 15h23
  3. [Delphi 6] Problèmes avec SendMessage
    Par KrusK dans le forum API, COM et SDKs
    Réponses: 2
    Dernier message: 09/09/2005, 11h49
  4. [Delphi 2005] : Problème avec MessageDlg.....
    Par babyface dans le forum Langage
    Réponses: 2
    Dernier message: 08/07/2005, 12h07
  5. [Delphi 3] Problème avec fichier ressource .RES
    Par delphim dans le forum EDI
    Réponses: 2
    Dernier message: 28/06/2005, 18h11

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