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 :

Codage d'un entier en python et taille en octet


Sujet :

Python

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 6
    Par défaut Codage d'un entier en python et taille en octet
    Sujet : Codage d'un entier en python et taille en octet


    Bonjour,

    Je me permets de vous solliciter sur une problématique propre à Python sur la codage des entiers et leurs tailles variables respectives.
    J'ai essayé d'utiliser mes connaissances en VBA pour transposer ce mode de fonctionnement mais malheureusement je n'arrive pas au même résultat.

    J'ai mis en pièce jointe un fichier au format Excel reprenant ce que je vous ai formulé ci-dessous (peut être plus facile à la compréhension.

    Hypothèse : 1 octet = 8 bits

    Constat : la taille d'un entier (i.e. en utilisant getsizeof) varie en fonction du nombre
    Par exemple :
    1. a = 2**32-1 => Taille en octet : 28
    2. a = 2**32 => Taille en octet : 32 (+ 4 octets)

    En utilisant mes connaissances en VBA je sais qu'un "gros" entier (i.e. de type Long) a une taille de 4 octets :
    - 1 octets est codé sur 8 bits donc 4 octets sont codés sur 32 bits
    - 2^32 => 4 294 967 296 valeurs possibles allant de : -2 147 483 648 à +2 147 483 647

    Ce principe n'est pas applicable en Python. En effet :
    - 2 147 483 647 valeurs possibles allant de -1 073 741 823 à -1 073 741 823 a une taille de 28 octets

    La question qui me tarode :
    Pourquoi 28 octets pour 2 fois moins de valeurs possibles qu'en VBA ayant une taille de 4 octets ?
    Quelle doit être le raisonnement en Python ?

    Merci d'avance de vos lumières,
    Cordialement.
    El Gringo 123456
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 699
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 699
    Par défaut
    Salut,

    Citation Envoyé par elgringo123456 Voir le message
    Par exemple :
    1. a = 2**32-1 => Taille en octet : 28
    2. a = 2**32 => Taille en octet : 32 (+ 4 octets)
    Vous comptez quoi?
    La seule information pertinente que vous retournera Python est le nombre de bits "significatifs":
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    >>> n = int('0xfffffffe', 16)
    >>> n.bit_length()
    32
    >>> n = int('0xfffffffffffe', 16)
    >>> n.bit_length()
    48
    >>>
    Et elle n'a rien à voir avec la représentation "machine" (nombre d'octets) des nombres car Python utilise une abstraction de plus haut niveau (bignum) qui permet de s'en affranchir.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 6
    Par défaut
    Bonjour WizTricks,

    Merci beaucoup de votre réponse.
    Effectivement je ne suis pas du tout claire et j'ai encore pas mal de chemin à parcourir pour arriver à comprendre le raisonnement qu'il y a derrière.
    Par ailleurs j'ai fait une erreur donc vraiment désolé.

    a = 2**30-1 = 1 073 741 823 => sys.getsizeof(a) = 28 octets => a.bit_length() => 30
    a = 2**30 = 1 073 741 824 => sys.getsizeof(a) = 32 octets => a.bit_length() => 31

    Pourquoi le fait de passer du chiffre 2**30-1 à 2**30 fait augmenter la taille de 4 octets ?

    D'après votre réponse l'utilisation de getsizeof est inutile car l'information n'est pas pertinente et il est préférable d'utiliser comme vous me l'indiquez bit_length() qui renvoi le nombre de bit nécessaires pour répresenter un nombre en binaire.
    J'aurais aimé faire le lien entre le nombre de bits nécessaire pour la réprésentation et la taille en octet mais de ce que j'en comprends à priori cela n'est pas possible en direct et simplement du fait de la couche d'abstraction ?

    Encore désolé pour toutes ces questions car je me sens un peu perdu.
    Cordialement.
    El Gringo 123456

  4. #4
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 699
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 699
    Par défaut
    Citation Envoyé par elgringo123456 Voir le message
    D'après votre réponse l'utilisation de getsizeof est inutile car l'information n'est pas pertinente et il est préférable d'utiliser comme vous me l'indiquez bit_length() qui renvoi le nombre de bit nécessaires pour répresenter un nombre en binaire.
    La taille de l'objet (ici un entier) n'a rien à voir avec le nombre qu'il représente. Dans mon post précédent, je vous ai indiqué une URL correspondant au PEP 237 qui décrit la représentation interne des entier "bignum" en Python.

    J'aurais aimé faire le lien entre le nombre de bits nécessaire pour la réprésentation et la taille en octet mais de ce que j'en comprends à priori cela n'est pas possible en direct et simplement du fait de la couche d'abstraction ?
    Le document en question devrait sinon vous indiquer comment faire au moins vous donner des idées pour y arriver.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 6
    Par défaut
    Merci beaucoup

Discussions similaires

  1. [WD17] Formule Codage de 2 entiers 16 bits en 1 réel 32 bits
    Par davcaz dans le forum WinDev
    Réponses: 17
    Dernier message: 10/09/2014, 12h37
  2. Est-il possible de connaitre la taille en octet d'un enregistre ?
    Par berceker united dans le forum Requêtes
    Réponses: 4
    Dernier message: 19/03/2008, 13h22
  3. Compression COMP taille en octets
    Par ptit.homm dans le forum Cobol
    Réponses: 19
    Dernier message: 09/02/2008, 23h32
  4. utilisation d'entier de tres grande taille
    Par HoB dans le forum Langage
    Réponses: 3
    Dernier message: 27/04/2007, 14h19
  5. [ImageMagick] Taille en octet d'une image
    Par Oberown dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 28/08/2006, 09h32

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