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 :

lire une image enregistree en 32 bits float real .raw


Sujet :

C++

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    245
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2007
    Messages : 245
    Points : 110
    Points
    110
    Par défaut lire une image enregistree en 32 bits float real .raw
    Bonjour,

    j' essaye de lire une image enregistree en .raw.
    je connais la taille et le format des valeurs.

    j'arrive a lire l'image quand les valeurs sont codes en int avec ce code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    char *buffer = new char [length_reading];
     
    ifstream input_file;
    input_file.open(tfilename[proj].c_str(), ifstream::in);
    cout << "file opened: " << tfilename[proj] << endl;
     
    if(input_file == NULL)
      {
       cerr<<"Cannot open input file \n";
       return;
       }
     
    input_file.read(buffer3,length_reading);
     
    if (!input_file)
      {
        std::cout << "error: only " << input_file.gcount() << " could be read" << endl;
        return;
       }
     
    int buffer_i = 0;
     
    // fill the matrix data with all projections
       for(int jj=0; jj <= tsize[0]-1; jj++) {
           for(int kk=0; kk <= tsize[1]-1; kk++) {
     
    	  char num1 = buffer[buffer_i];
    	  buffer_i++;
    	  char num2 = buffer[buffer_i];
    	  buffer_i++;
     
    	  unsigned short number = 0;
    	  number |= (unsigned char)num2;
    	  number |= num1 << 8;
    	  unsigned short number2;
    	  number2 = (number>>8)|(number <<8);
     
    	  double value_corrected;
    	  value_corrected = -log((double(number2)-double(dark[jj][kk]))/(double(bright[jj][kk])-double(dark[jj][kk])));
    	   if (value_corrected<0)
    		{data[jj][kk]= 0;}
    	   else
    		{data[jj][kk] = int16_t(value_corrected*1000);}
               } //end for tsize[0]
    } //end for tsize[1]
     
    delete[] buffer;
     
    input_file.close();
    pour lire des 32 bits float j'ai multiplie length_reading par 2
    au lieu de unsigned short pour number et number2 j'ai mis float
    et au lieu de (number>>8)|(number <<8);
    j'essaye d'utiliser __builtin_bswap32

    mais ca ne marche pas. j'ai n'importe quoi comme valeur.

    qu'est-ce qu'il faudrait que je change d'autres dans mon code pour lire des 32 bits float ?

    Merci

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    2 764
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 2 764
    Points : 2 705
    Points
    2 705
    Par défaut
    Peux-tu me rappeler les specs du format raw ? Je ne me souviens même plus si c'est du texte ou si c'est binaire.

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    245
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2007
    Messages : 245
    Points : 110
    Points
    110
    Par défaut
    c' est du binaire

  4. #4
    Expert éminent sénior

    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    5 189
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 5 189
    Points : 17 141
    Points
    17 141
    Par défaut
    Et ton flux est ouvert en caractères. essaie donc:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ifstream input_file(tfilename[proj].c_str(), std::ios_base::binary);
    le ifstream::in est implicite par le fait d'être un ifstream

    Au passage, ouvrir le flux dans le constructeur plutot qu'avec open est en général une meilleure pratique (le RAII est un plus visible)
    Mes principes de bases du codeur qui veut pouvoir dormir:
    • Une variable de moins est une source d'erreur en moins.
    • Un pointeur de moins est une montagne d'erreurs en moins.
    • Un copier-coller, ça doit se justifier... Deux, c'est un de trop.
    • jamais signifie "sauf si j'ai passé trois jours à prouver que je peux".
    • La plus sotte des questions est celle qu'on ne pose pas.
    Pour faire des graphes, essayez yEd.
    le ter nel est le titre porté par un de mes personnages de jeu de rôle

  5. #5
    Membre émérite
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    2 764
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 2 764
    Points : 2 705
    Points
    2 705
    Par défaut
    C'est exactement la réponse que je voulais faire, mais je n'étais pas sûr de mon coup à cause de mon doute sur le format raw.

  6. #6
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Et si c'est binaire, ifstream::binary...

    Edit: ↓Il faut que je me rachète des yeux, je n'avais pas vu que tu le recommandais.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  7. #7
    Expert éminent sénior

    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    5 189
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 5 189
    Points : 17 141
    Points
    17 141
    Par défaut
    Qui est le même que std::ios_base::binary, que j'ai recommandé.
    Mes principes de bases du codeur qui veut pouvoir dormir:
    • Une variable de moins est une source d'erreur en moins.
    • Un pointeur de moins est une montagne d'erreurs en moins.
    • Un copier-coller, ça doit se justifier... Deux, c'est un de trop.
    • jamais signifie "sauf si j'ai passé trois jours à prouver que je peux".
    • La plus sotte des questions est celle qu'on ne pose pas.
    Pour faire des graphes, essayez yEd.
    le ter nel est le titre porté par un de mes personnages de jeu de rôle

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    245
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2007
    Messages : 245
    Points : 110
    Points
    110
    Par défaut
    ca n'a pas l' air de marcher, je n'ai toujours pas les bonnes valeurs.

    pour le moment j'ai converti mes floats en int16 avec matlab histoire de continuer a avancer un peu sur le reste du code.

  9. #9
    Membre éclairé
    Inscrit en
    Décembre 2010
    Messages
    290
    Détails du profil
    Informations forums :
    Inscription : Décembre 2010
    Messages : 290
    Points : 719
    Points
    719
    Par défaut
    Quand tu dis que tu n'as pas les bonnes valeurs, tu pourrais nous donner quelques exemples de ce que tu devrais avoir et de ce que tu obtiens ?
    Si possible affiché en hexadécimal.

Discussions similaires

  1. Lire une image PGM
    Par ToTo13 dans le forum Langage
    Réponses: 7
    Dernier message: 09/10/2006, 18h39
  2. Lire une image (IPictureDisp)
    Par uranium-design dans le forum VB 6 et antérieur
    Réponses: 30
    Dernier message: 19/08/2006, 11h13
  3. Lire une image Tiff en C/cpp avec Lib tiff
    Par syn_42 dans le forum MFC
    Réponses: 4
    Dernier message: 04/01/2006, 21h28
  4. lire une image et tracer une fonction
    Par Battosaiii dans le forum C
    Réponses: 4
    Dernier message: 23/11/2005, 15h21
  5. lire une image au format RAW
    Par Anonymous dans le forum OpenGL
    Réponses: 5
    Dernier message: 20/05/2002, 00h11

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