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

Python Discussion :

Opérations sur floats [Python 3.X]


Sujet :

Python

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2015
    Messages : 7
    Points : 5
    Points
    5
    Par défaut Opérations sur floats
    Hello des développeurs, un petit merci déjà pour prendre le temps de lire ce post et la question qui va avec

    Voici mon souci, pas la peine que j'explique le contexte, mais c'est presque primordial qu'il soit résolu, je suis en stage dans un labo de recherche donc j'ai un peu la pression ! ^^

    J'ai des valeurs théoriques piochées dans un fichier, et j'ai des valeurs calculées. En gros, si la valeur calculée ets proche de la valeur théorique j'en déduit que VRAI, sinon j'en déduis que FAUX. J'ai donc un certain seuil de "vérité".
    Voici des exemples (ici on a VRAI pour le couple 1 et 3) :
    v_theo v_calc
    0.0014 0.00139999998
    0.002 0.077532
    0.0154 0.015500004

    Mais ! Pour affiner ma comparaison, je voulais savoir s'il était possible de
    - arrondir un float à une certaine décimale (faire passer le 0.001399999998 à 0.0014 par exemple)
    - tronquer un float à n décimales, par ex 0.0045854 et n = 4 => 0.0045
    - compter le nombre de décimales d'un float, par ex 0.045 => n = 3 (c'est pour utiliser ce chiffre dans le tronquage précédent)

    Merci beaucoup à vous !

  2. #2
    Membre éprouvé
    Homme Profil pro
    Aucune activité
    Inscrit en
    Novembre 2011
    Messages
    505
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Aucune activité

    Informations forums :
    Inscription : Novembre 2011
    Messages : 505
    Points : 926
    Points
    926
    Par défaut
    Citation Envoyé par Dayan42 Voir le message
    - arrondir un float à une certaine décimale (faire passer le 0.001399999998 à 0.0014 par exemple)
    - tronquer un float à n décimales, par ex 0.0045854 et n = 4 => 0.0045
    - compter le nombre de décimales d'un float, par ex 0.045 => n = 3 (c'est pour utiliser ce chiffre dans le tronquage précédent)
    Bonjour,
    Dans le shell de Python, il suffit de faire:
    Qui renvoie:
    Help on built-in function round in module builtins:

    round(...)
    round(number[, ndigits]) -> number

    Round a number to a given precision in decimal digits (default 0 digits).
    This returns an int when called with one argument, otherwise the
    same type as the number. ndigits may be negative.

    >>>
    Donc c'est bon pour les questions 1 et 2.

    Pour la question 3… Pas trop d'idée si ce n'est la conversion par str puis la recherche de la longueur par len…

    Clodion

    PS: sinon, bien sûr, ne pas oublier trunc, floor, ceil du module math!

    PS2: ce ne serait pas plus simple, plus exacte et moins sujet aux représentations des réels de plutôt utiliser des pourcentages? Ou des équivalents:
    d = abs(x - y)/(x + y)
    et de fixer un seuil?

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2015
    Messages : 7
    Points : 5
    Points
    5
    Par défaut
    Réponse parfaite, j'ai tout ce qu'il me faut, merci !

    A bientôt

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

Discussions similaires

  1. Opérations sur les matrices...
    Par aokiseiichiro dans le forum C
    Réponses: 32
    Dernier message: 28/07/2005, 17h10
  2. Besoin d'explications sur float et l'élasticité !
    Par KneXtasY dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 14/01/2005, 15h15
  3. opération sur fermeture de fenêtre
    Par java_math dans le forum Agents de placement/Fenêtres
    Réponses: 2
    Dernier message: 20/06/2004, 22h52
  4. opérations sur les bits d'un byte
    Par petitours dans le forum C++Builder
    Réponses: 4
    Dernier message: 10/02/2004, 20h42
  5. opérations sur les dates
    Par coucoucmoi dans le forum Débuter
    Réponses: 2
    Dernier message: 12/08/2003, 11h45

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