Bonjour à tous,
quand j'exécute print(35 * 10**-5) en python, je trouve 0.00035000000000000005
Je suis perplexe.
Puissance de 10 négative en python
6 posts
• Page 1 of 1
-
Krit
Niveau 3: MH (Membre Habitué)- Posts: 8
- Joined: 20 Jun 2017, 16:58
- Gender:
- Calculator(s):→ MyCalcs profile
Re: Puissance de 10 négative en python
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 :
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 :
Surtout quand il n'y a pas d'équivalent exact entre ces deux bases.
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
Surtout quand il n'y a pas d'équivalent exact entre ces deux bases.
-
critorAdmin
Niveau 19: CU (Créateur Universel)- Posts: 42132
- Images: 16453
- Joined: 25 Oct 2008, 00:00
- Location: Montpellier
- Gender:
- Calculator(s):→ MyCalcs profile
- YouTube: critor3000
- Twitter: critor2000
- GitHub: critor
Re: Puissance de 10 négative en python
Merci Critor pour l'explication.
On est quand même loin d'un nombre fabuleusement grand ou petit.
On est quand même loin d'un nombre fabuleusement grand ou petit.
-
Krit
Niveau 3: MH (Membre Habitué)- Posts: 8
- Joined: 20 Jun 2017, 16:58
- Gender:
- Calculator(s):→ MyCalcs profile
Re: Puissance de 10 négative en python
Ce n'est pas une histoire de grand petit.
La question pour la conversion d'une mantisse M telle que
(ce qui prendrait 54 bits en fait, mais si je me souviens bien le
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)-
critorAdmin
Niveau 19: CU (Créateur Universel)- Posts: 42132
- Images: 16453
- Joined: 25 Oct 2008, 00:00
- Location: Montpellier
- Gender:
- Calculator(s):→ MyCalcs profile
- YouTube: critor3000
- Twitter: critor2000
- GitHub: critor
Re: Puissance de 10 négative en python
Prenons par exemple 11 en virgule flottante.
La plus grande puissance de 2 inférieure est
On écrit donc en virgule flottante binaire
Question, 1,375 dispose-t-il d'un développement binaire ?
Ici, la réponse est oui :
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$
-
critorAdmin
Niveau 19: CU (Créateur Universel)- Posts: 42132
- Images: 16453
- Joined: 25 Oct 2008, 00:00
- Location: Montpellier
- Gender:
- Calculator(s):→ MyCalcs profile
- YouTube: critor3000
- Twitter: critor2000
- GitHub: critor
Re: Puissance de 10 négative en python
critor wrote: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 :Il n'est pas rare donc que cela introduise des erreurs d'approximation sur les toutes dernières décimales.
- saisie décimale → virgule flottante binaire
- puis le calcul est effectué en binaire
- puis enfin résultat → décimal pour l'affichage
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
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
-
cent20VIP++
Niveau 14: CI (Calculateur de l'Infini)- Posts: 1073
- Images: 67
- Joined: 17 May 2012, 09:49
- Location: Avignon
- Gender:
- Calculator(s):→ MyCalcs profile
- Twitter: nsi_xyz
6 posts
• Page 1 of 1
Return to Maths, physique, informatique et autre...
Who is online
Users browsing this forum: ClaudeBot [spider] and 2 guests