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++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    245
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2007
    Messages : 245
    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 éprouvé
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    2 766
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2004
    Messages : 2 766
    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 confirmé
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    245
    Détails du profil
    Informations personnelles :
    Localisation : Canada

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

  4. #4
    Expert éminent

    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    5 202
    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 202
    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)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 2 766
    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
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    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.

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