π
<-
Chat plein-écran
[^]

Puissance de 10 négative en python

Discussions scientifiques et scolaires

Puissance de 10 négative en python

Message non lude Krit » 12 Oct 2019, 18:42

Bonjour à tous,
quand j'exécute print(35 * 10**-5) en python, je trouve 0.00035000000000000005
Je suis perplexe.
Avatar de l’utilisateur
Krit
Niveau 3: MH (Membre Habitué)
Niveau 3: MH (Membre Habitué)
Prochain niv.: 12%
 
Messages: 8
Inscription: 20 Juin 2017, 16:58
Genre: Non spécifié
Calculatrice(s):
MyCalcs profile

Re: Puissance de 10 négative en python

Message non lude critor » 12 Oct 2019, 18:54

Bonjour.


Le Python ne travaille pas en base 10/décimale, et ne gère qu'un minuscule sous-ensemble des nombres réels.

Les nombres non entiers sont représentés en Python en virgule flottante binaire, soit au format suivant :
$mathjax$\pm M\times 2^{E-E_{min}}$mathjax$
avec
$mathjax$M\in [1;2[$mathjax$


La mantisse M est codée sur 53 bits (plus 1 bit de signe).

Bref, quand on demande un calcul en Python il y a une double conversion derrière :
  • saisie décimale → virgule flottante binaire
  • puis le calcul est effectué en binaire
  • puis enfin résultat → décimal pour l'affichage
Il n'est pas rare donc que cela introduise des erreurs d'approximation sur les toutes dernières décimales.
Surtout quand il n'y a pas d'équivalent exact entre ces deux bases.
Image
Avatar de l’utilisateur
critorAdmin
Niveau 19: CU (Créateur Universel)
Niveau 19: CU (Créateur Universel)
Prochain niv.: 41.8%
 
Messages: 41465
Images: 14479
Inscription: 25 Oct 2008, 00:00
Localisation: Montpellier
Genre: Homme
Calculatrice(s):
MyCalcs profile
YouTube: critor3000
Twitter/X: critor2000
GitHub: critor

Re: Puissance de 10 négative en python

Message non lude Krit » 12 Oct 2019, 19:01

Merci Critor pour l'explication.
On est quand même loin d'un nombre fabuleusement grand ou petit.
Avatar de l’utilisateur
Krit
Niveau 3: MH (Membre Habitué)
Niveau 3: MH (Membre Habitué)
Prochain niv.: 12%
 
Messages: 8
Inscription: 20 Juin 2017, 16:58
Genre: Non spécifié
Calculatrice(s):
MyCalcs profile

Re: Puissance de 10 négative en python

Message non lude critor » 12 Oct 2019, 19:14

Ce n'est pas une histoire de grand petit.

La question pour la conversion d'une mantisse M telle que
$mathjax$M\in[1;2[$mathjax$
en binaire, c'est est-ce qu'il en existe développement binaire vérifiant
$mathjax$\sum\limits_{k=0}^{53}a_k\times2^{-k}=M$mathjax$
.
(ce qui prendrait 54 bits en fait, mais si je me souviens bien le
$mathjax$1\times 2^0=1$mathjax$
obligatoire n'est pas codé donc c'est bon)
Image
Avatar de l’utilisateur
critorAdmin
Niveau 19: CU (Créateur Universel)
Niveau 19: CU (Créateur Universel)
Prochain niv.: 41.8%
 
Messages: 41465
Images: 14479
Inscription: 25 Oct 2008, 00:00
Localisation: Montpellier
Genre: Homme
Calculatrice(s):
MyCalcs profile
YouTube: critor3000
Twitter/X: critor2000
GitHub: critor

Re: Puissance de 10 négative en python

Message non lude critor » 12 Oct 2019, 19:19

Prenons par exemple 11 en virgule flottante.
La plus grande puissance de 2 inférieure est
$mathjax$2^3=8$mathjax$

On écrit donc en virgule flottante binaire
$mathjax$11=1,375\times 2^3$mathjax$

Question, 1,375 dispose-t-il d'un développement binaire ?
Ici, la réponse est oui :
$mathjax$1,375=1+\frac{1}{4}+\frac{1}{8}$mathjax$
Image
Avatar de l’utilisateur
critorAdmin
Niveau 19: CU (Créateur Universel)
Niveau 19: CU (Créateur Universel)
Prochain niv.: 41.8%
 
Messages: 41465
Images: 14479
Inscription: 25 Oct 2008, 00:00
Localisation: Montpellier
Genre: Homme
Calculatrice(s):
MyCalcs profile
YouTube: critor3000
Twitter/X: critor2000
GitHub: critor

Re: Puissance de 10 négative en python

Message non lude cent20 » 12 Oct 2019, 19:24

critor a écrit:Bonjour.


Le Python ne travaille pas en base 10/décimale, et ne gère qu'un minuscule sous-ensemble des nombres réels.

Les nombres non entiers sont représentés en Python en virgule flottante binaire, soit au format suivant :
$mathjax$\pm M\times 2^{E-E_{min}}$mathjax$
avec
$mathjax$M\in [1;2[$mathjax$


La mantisse M est codée sur 53 bits (plus 1 bit de signe).

Bref, quand on demande un calcul en Python il y a une double conversion derrière :
  • saisie décimale → virgule flottante binaire
  • puis le calcul est effectué en binaire
  • puis enfin résultat → décimal pour l'affichage
Il n'est pas rare donc que cela introduise des erreurs d'approximation sur les toutes dernières décimales.
Surtout quand il n'y a pas d'équivalent exact entre ces deux bases.


C'était l'info que je cherchais ... Je viens de finir mon DS de seconde et j'ai ajouté une question, en gros un 0.1+0.2 pour faire échouer les algorithmes qu'on a fait en classe et leur apprendre que la calculatrice ne sait pas tout et qu'elle se trompe... J'ai fabriqué mon exemple au hasard maintenant je sais comment m'y prendre (je devais trouver ça pdt les vacances...)

Merci :favorite:
Image
Enseignant de mathématiques et d'informatique. Spécialité NSI : Des projets, des tutos, mais aussi de l'art
Calculatrice NumWorks : Des applications et des jeux, scripts, 📙 Découvrir la NumWorks
Avatar de l’utilisateur
cent20VIP++
Niveau 14: CI (Calculateur de l'Infini)
Niveau 14: CI (Calculateur de l'Infini)
Prochain niv.: 45.9%
 
Messages: 1009
Images: 64
Inscription: 17 Mai 2012, 09:49
Localisation: Avignon
Genre: Homme
Calculatrice(s):
MyCalcs profile
Twitter/X: nsi_xyz


Retourner vers Maths, physique, informatique et autre...

Qui est en ligne

Utilisateurs parcourant ce forum: Aucun utilisateur enregistré et 39 invités

-
Rechercher
-
Social TI-Planet
-
Sujets à la une
Comparaisons des meilleurs prix pour acheter sa calculatrice !
Aidez la communauté à documenter les révisions matérielles en listant vos calculatrices graphiques !
Phi NumWorks jailbreak
123
-
Faire un don / Premium
Pour plus de concours, de lots, de tests, nous aider à payer le serveur et les domaines...
Faire un don
Découvrez les avantages d'un compte donateur !
JoinRejoignez the donors and/or premium!les donateurs et/ou premium !


Partenaires et pub
Notre partenaire Jarrety Calculatrices à acheter chez Calcuso
-
Stats.
2264 utilisateurs:
>2251 invités
>9 membres
>4 robots
Record simultané (sur 6 mois):
6892 utilisateurs (le 07/06/2017)
-
Autres sites intéressants
Texas Instruments Education
Global | France
 (English / Français)
Banque de programmes TI
ticalc.org
 (English)
La communauté TI-82
tout82.free.fr
 (Français)