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

C Discussion :

comment représenter un float sur 16 bit


Sujet :

C

  1. #1
    Membre averti
    Inscrit en
    Mai 2006
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 35
    Par défaut comment représenter un float sur 16 bit
    Bonjour;

    je suis amenée à ecrire un float sur 16 bit dans 4 bits de poids forts sont a 0 les 8 bit qui suivent contiendrons la partie entiere et les 4 bits restants la decimale de la partie flottante!
    et je ne sais po trop par ou commencer si quelqu un peut m aider !

    merci

  2. #2
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par hamska2
    Bonjour;

    je suis amenée à ecrire un float sur 16 bit dans 4 bits de poids forts sont a 0 les 8 bit qui suivent contiendrons la partie entiere et les 4 bits restants la decimale de la partie flottante!
    et je ne sais po trop par ou commencer si quelqu un peut m aider !

    merci
    Alors c'est pas un 'float'. C'est un format 'virgule fixe' (fixed point).

    Pour la partie entière, je verrais ça comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    #include <stdio.h>
     
    int main (void)
    {
       double x = 123.45;
     
       unsigned n = 0;
     
       n |= (int) x << 4;
     
       printf ("n = %04X\n", n);
       return 0;
    }
    Pose des questions si tu ne comprends pas.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    n = 07B0
     
    Press ENTER to continue.
    soit
    0000 0111 1011 0000

    0111 1011 = 7B, soit 123

    Pour la partie fractionnaire, c'est pas facile de faire entrer ça dans 4 bits...

    4-bit, soit de 0.0 à 0.15 ( 2-digit). C'est bien pour 0 à 9. Il suffit donc de multiplier la partie fractionnaire par 10 et de prendre la partie entière :

    Ici, on a 0.45 : 0.45 * 10 = 4.5, prendre la partie entière (4) et la mettre dans les 4 bits de poids faible...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
       n |= (frac(x) * 10) & 0x000F;

  3. #3
    Expert confirmé
    Avatar de diogene
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Juin 2005
    Messages
    5 761
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 761
    Par défaut
    Tu n'as pas précisé le format attendu pour les nombres négatifs. Sinon, pour les positifs :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
      float f= 12.41;
      unsigned int i = f*16;
    résultat 12.375

    Avec un arrondi au plus proche :
    résultat 12.4375

  4. #4
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 77
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Par défaut
    Et pourquoi pas avec exposant et mantisse en base 2 ?
    ex :
    1011000000001001 = (1/2+1/8+1/16)*2^9
    Ce qu'on trouve est plus important que ce qu'on cherche.
    Maths de base pour les nuls (et les autres...)

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 14/12/2010, 19h35
  2. Réponses: 1
    Dernier message: 02/06/2009, 23h09
  3. Comment avoir des div sur une même ligne sans utiliser float ?
    Par Sergejack dans le forum Balisage (X)HTML et validation W3C
    Réponses: 10
    Dernier message: 13/10/2007, 15h31

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