Main Page   Groups   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Concepts

itkSiemensVisionImageIO.h

Go to the documentation of this file.
00001 /*=========================================================================
00002 
00003 Program:   Insight Segmentation & Registration Toolkit
00004 Module:    $RCSfile: itkSiemensVisionImageIO.h,v $
00005 Language:  C++
00006 Date:      $Date: 2004/11/10 19:22:13 $
00007 Version:   $Revision: 1.8 $
00008 
00009 Copyright (c) Insight Software Consortium. All rights reserved.
00010 See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
00011 
00012 This software is distributed WITHOUT ANY WARRANTY; without even
00013 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
00014 PURPOSE.  See the above copyright notices for more information.
00015 
00016 =========================================================================*/
00017 
00031 #ifndef __itkSiemensVisionImageIO_h
00032 #define __itkSiemensVisionImageIO_h
00033 
00034 #ifdef _MSC_VER
00035 #pragma warning ( disable : 4786 )
00036 #endif
00037 
00038 #include <fstream>
00039 #include "itkImageIOBase.h"
00040 #include "itkIPLCommonImageIO.h"
00041 #include "itkGEImageHeader.h"
00042 
00043 namespace itk
00044 {
00049 class ITK_EXPORT SiemensVisionImageIO : public IPLCommonImageIO
00050 {
00051 public:
00053   typedef SiemensVisionImageIO            Self;
00054   typedef IPLCommonImageIO  Superclass;
00055   typedef SmartPointer<Self>  Pointer;
00056 
00058   itkNewMacro(Self);
00059 
00061   itkTypeMacro(SiemensVisionImageIO, Superclass);
00062 
00063   /*-------- This part of the interfaces deals with reading data. ----- */
00064 
00071   virtual bool CanReadFile(const char* FileNameToRead) ;
00072 
00074   // Implemented in superclass
00075   //      virtual void ReadImageInformation();
00076 
00078   // Implemented in superclass
00079   //      virtual const std::type_info& GetPixelType() const;
00080 
00082   // Implemented in superclass
00083   //      virtual void Read(void* buffer);
00084 
00088   // Implemented in superclass
00089   //      virtual unsigned int GetComponentSize() const;
00090 
00091   /*-------- This part of the interfaces deals with writing data. ----- */
00092 
00099   // Implemented in superclass
00100   //      virtual bool CanWriteFile(const char * FileNameToWrite);
00101 
00103   // Implemented in superclass
00104   //      virtual void WriteImageInformation();
00105 
00108   // Implemented in superclass
00109   //      virtual void Write(const void* buffer);
00110 protected:
00111   SiemensVisionImageIO();
00112   ~SiemensVisionImageIO();
00113   // Implemented in superclass
00114   //      void PrintSelf(std::ostream& os, Indent indent) const;
00115   virtual struct GEImageHeader *ReadHeader(const char *FileNameToRead);
00116 private:
00117   typedef enum {
00118     HDR_STUDY_YEAR= 0,      // Study date year, u_int
00119     HDR_STUDY_YEAR_LEN= 4,
00120     HDR_STUDY_MONTH= 4,     // Study date month, u_int
00121     HDR_STUDY_MONTH_LEN= 4,
00122     HDR_STUDY_DAY= 8,       // Study date day, u_int
00123     HDR_STUDY_DAY_LEN= 4,           
00124     HDR_ACQ_YEAR= 12,       // Acquisition date year, u_int
00125     HDR_ACQ_YEAR_LEN= 4,
00126     HDR_ACQ_MONTH= 16,      // Acquisition date month, u_int
00127     HDR_ACQ_MONTH_LEN= 4,
00128     HDR_ACQ_DAY= 20,        // Acquisition date day, u_int
00129     HDR_ACQ_DAY_LEN= 4,
00130     HDR_IMAGE_YEAR= 24,     // Image date year, u_int
00131     HDR_IMAGE_YEAR_LEN= 4,
00132     HDR_IMAGE_MONTH= 28,    // Image date month, u_int
00133     HDR_IMAGE_MONTH_LEN= 4,
00134     HDR_IMAGE_DAY= 32,      // Image date day, u_int
00135     HDR_IMAGE_DAY_LEN= 4,
00136     HDR_STUDY_HOUR= 36,     // Study time hour, u_int
00137     HDR_STUDY_HOUR_LEN= 4,
00138     HDR_STUDY_MIN= 40,      // Study time minute, u_int
00139     HDR_STUDY_MIN_LEN= 4,
00140     HDR_STUDY_SEC= 44,      // Study time second, u_int
00141     HDR_STUDY_SEC_LEN= 4,
00142     HDR_ACQ_HOUR= 52,       // Acquisition time second, u_int
00143     HDR_ACQ_HOUR_LEN= 4,
00144     HDR_ACQ_MIN= 56,        // Acquisition time second, u_int
00145     HDR_ACQ_MIN_LEN= 4,
00146     HDR_ACQ_SEC= 60,        // Acquisition time second, u_int
00147     HDR_ACQ_SEC_LEN= 4,
00148     HDR_IMAGE_HOUR= 68,     // Image Creation time second, u_int
00149     HDR_IMAGE_HOUR_LEN= 4,
00150     HDR_IMAGE_MIN= 72,      // Image Creation time second, u_int
00151     HDR_IMAGE_MIN_LEN= 4,
00152     HDR_IMAGE_SEC= 76,      // Image Creation time second, u_int
00153     HDR_IMAGE_SEC_LEN= 4,
00154     HDR_MANUFAC= 96,        // Scanner Manufacturer, char
00155     HDR_MANUFAC_LEN= 7,
00156     HDR_INSTUTE_NAME= 105,  // Institution Name, char
00157     HDR_INSTUTE_NAME_LEN= 25,
00158     HDR_ANNOTATION= 186,    // Annotation, char
00159     HDR_ANNOTATION_LEN= 32,
00160     HDR_MODEL_NAME= 281,    // Scanner Model Name, char
00161     HDR_MODEL_NAME_LEN= 12,
00162     HDR_LMOVE_YEAR= 412,  // Date of Last Image Move - year, u_int
00163     HDR_LMOVE_YEAR_LEN= 4,
00164     HDR_LMOVE_MONTH= 416, // Date of Last Image Move - month, u_int
00165     HDR_LMOVE_MONTH_LEN= 4,
00166     HDR_LMOVE_DAY= 420,    // Date of Last Image Move - day, u_int
00167     HDR_LMOVE_DAY_LEN= 4,
00168     HDR_LMOVE_HOUR= 424,  // Date of Last Image Move - hour, u_int
00169     HDR_LMOVE_HOUR_LEN= 4,
00170     HDR_LMOVE_MIN= 428, // Date of Last Image Move - minute, u_int
00171     HDR_LMOVE_MIN_LEN= 4,
00172     HDR_LMOVE_SEC= 432, // Date of Last Image Move - second, u_int
00173     HDR_LMOVE_SEC_LEN= 4,
00174     HDR_PAT_NAME= 768,      // Patient Name, char
00175     HDR_PAT_NAME_LEN= 25,
00176     HDR_PAT_ID= 795,        // Patient ID Number, char
00177     HDR_PAT_ID_LEN= 12,
00178     HDR_DOB_YEAR= 808,      // Date of Birth year, u_int
00179     HDR_DOB_YEAR_LEN= 4,
00180     HDR_DOB_MONTH= 812,     // Date of Birth month, u_int
00181     HDR_DOB_MONTH_LEN= 4,
00182     HDR_DOB_DAY= 816,       // Date of Birth day, u_int
00183     HDR_DOB_DAY_LEN= 4,
00184     HDR_PAT_AGE= 851,       // Patient Age, char
00185     HDR_PAT_AGE_LEN= 3,
00186     HDR_AGE_UNIT= 854,      // Patient Age Unit, char
00187     HDR_AGE_UNIT_LEN= 1,
00188     HDR_REG_YEAR= 1052,     // Registration Date year, u_int
00189     HDR_REG_YEAR_LEN= 4,
00190     HDR_REG_MONTH= 1056,    // Registration Date month, u_int
00191     HDR_REG_MONTH_LEN= 4,
00192     HDR_REG_DAY= 1060,      // Registration Date day, u_int
00193     HDR_REG_DAY_LEN= 4,
00194     HDR_REG_HOUR= 1064,     // Registration Time hour, u_int
00195     HDR_REG_HOUR_LEN= 4,
00196     HDR_REG_MIN= 1068,      // Registration Time minute, u_int
00197     HDR_REG_MIN_LEN= 4,
00198     HDR_REG_SEC= 1072,      // Registration Time second, u_int
00199     HDR_REG_SEC_LEN= 4,
00200     HDR_SLICE_THCK= 1544,   // Slice thickness, double
00201     HDR_SLICE_THCK_LEN= 8,
00202     HDR_TR= 1560,           // TR, double
00203     HDR_TR_LEN= 8,
00204     HDR_TE= 1568,           // TE, double
00205     HDR_TE_LEN= 8,
00206     HDR_FREQ= 1592,         // Center Frequency, double
00207     HDR_FREQ_LEN= 8,
00208     HDR_STATION= 1639,      // Station Name, char
00209     HDR_STATION_LEN= 5,
00210     HDR_CAL_YEAR= 1712,     // Calibration Date - year, u_int
00211     HDR_CAL_YEAR_LEN= 4,
00212     HDR_CAL_MONTH= 1716,    // Calibration Date - month, u_int
00213     HDR_CAL_MONTH_LEN= 4,
00214     HDR_CAL_DAY= 1720,      // Calibration Date - day, u_int
00215     HDR_CAL_DAY_LEN= 4,
00216     HDR_CAL_HOUR= 1724,     // Calibration Time - hour, u_int
00217     HDR_CAL_HOUR_LEN= 4,
00218     HDR_CAL_MIN= 1728,      // Calibration Time - minute, u_int
00219     HDR_CAL_MIN_LEN= 4,
00220     HDR_CAL_SEC= 1732,      // Calibration Time - second, u_int
00221     HDR_CAL_SEC_LEN= 4,
00222     HDR_COIL= 1767,         // Recieve Coil, char
00223     HDR_COIL_LEN= 16,
00224     HDR_IMAGE_NUC= 1828,    // Imaged Nucleus, char
00225     HDR_IMAGE_NUC_LEN= 4,
00226     HDR_FLIP_ANGLE= 2112,   // Flip Angle, double
00227     HDR_FLIP_ANGLE_LEN= 8,
00228     HDR_FIELD= 2560,        // Field Strength, double
00229     HDR_FIELD_LEN= 8,
00230     HDR_DISPLAY_SIZE= 2864, // Displayed Matrix Size, u_int
00231     HDR_DISPLAY_SIZE_LEN= 4,
00232     HDR_SEQPROG_NAME= 2944, // Pulse Sequence Program Name, cha
00233     HDR_SEQPROG_NAME_LEN= 65,
00234     HDR_WKC_NAME= 3009,     // Pulse Sequence Name, char
00235     HDR_WKC_NAME_LEN= 65,
00236     HDR_AUTHOR= 3074,       // Pulse Sequence Author, char
00237     HDR_AUTHOR_LEN= 9,
00238     HDR_SEQUENCE_TYPE= 3083, // Pulse Sequence Type, char
00239     HDR_SEQUENCE_TYPE_LEN= 8,
00240     HDR_FOV_ROW= 3744,      // Row FOV, double
00241     HDR_FOV_ROW_LEN= 8,
00242     HDR_FOV_COLUMN= 3752,   // Column FOV, double
00243     HDR_FOV_COLUMN_LEN= 8,
00244     HDR_CENTER_X= 3768,     // X Center Point, double
00245     HDR_CENTER_X_LEN= 8,
00246     HDR_CENTER_Y= 3776,     // Y Center Point, double
00247     HDR_CENTER_Y_LEN= 8,
00248     HDR_CENTER_Z= 3784,     // Z Center Point, double
00249     HDR_CENTER_Z_LEN= 8,
00250     HDR_NORMV_X= 3792,      // Nornal Vector X, double
00251     HDR_NORMV_X_LEN= 8,
00252     HDR_NORMV_Y= 3800,      // Nornal Vector Y, double
00253     HDR_NORMV_Y_LEN= 8,
00254     HDR_NORMV_Z= 3808,      // Nornal Vector Z, double
00255     HDR_NORMV_Z_LEN= 8,
00256     HDR_DIST_ISO= 3816,     // Distance from Isocenter, double
00257     HDR_DIST_ISO_LEN= 8,
00258     HDR_ROWV_X= 3832,       // Row vector X, double
00259     HDR_ROWV_X_LEN= 8,
00260     HDR_ROWV_Y= 3840,       // Row vector Y, double
00261     HDR_ROWV_Y_LEN= 8,
00262     HDR_ROWV_Z= 3848,       // Row vector Z, double
00263     HDR_ROWV_Z_LEN= 8,
00264     HDR_COLMNV_X= 3856,     // Column vector X, double
00265     HDR_COLMNV_X_LEN= 8,
00266     HDR_COLMNV_Y= 3864,     // Column vector Y, double
00267     HDR_COLMNV_Y_LEN= 8,
00268     HDR_COLMNV_Z= 3872,     // Column vector Z, double
00269     HDR_COLMNV_Z_LEN= 8,
00270     HDR_ORNT_SET1X= 3880,   // Orientation Set 1 - X, char
00271     HDR_ORNT_SET1X_LEN= 3,
00272     HDR_ORNT_SET1Y= 3884,   // Orientation Set 1 - Y, char
00273     HDR_ORNT_SET1Y_LEN= 3,
00274     HDR_ORNT_SET1Z= 3888,   // Orientation Set 1 - Z, char
00275     HDR_ORNT_SET1Z_LEN= 3,
00276     HDR_ORNT_SET2X= 3892,   // Orientation Set 2 - X, char
00277     HDR_ORNT_SET2X_LEN= 3,
00278     HDR_ORNT_SET2Y= 3896,   // Orientation Set 2 - Y, char
00279     HDR_ORNT_SET2Y_LEN= 3,
00280     HDR_ORNT_SET2Z= 3900,   // Orientation Set 2 - Z, char
00281     HDR_ORNT_SET2Z_LEN= 3,
00282     HDR_PROTOCOL_NAME= 2944, // Pulse Sequence Name, char
00283     HDR_PROTOCOL_NAME_LEN= 64,
00284     HDR_PIXELSIZE_ROW= 5000, // Row Pixel Size, double
00285     HDR_PIXELSIZE_ROW_LEN= 8,
00286     HDR_PIXELSIZE_CLMN= 5008, // Column Pixel Size, double
00287     HDR_PIXELSIZE_CLMN_LEN= 8,
00288     TEXT_PAT_ID= 5504,      // Text Patient ID, char
00289     TEXT_PAT_ID_LEN= 12,
00290     TEXT_PAT_SEX= 5517,     // Text Patient Sex, char
00291     TEXT_PAT_SEX_LEN= 1,
00292     TEXT_PAT_AGE= 5518,     // Text Patient Age, char
00293     TEXT_PAT_AGE_LEN= 3,
00294     TEXT_AGE_UNIT= 5521,   // Text Patient Age Unit (Y=year), char
00295     TEXT_AGE_UNIT_LEN= 1,
00296     TEXT_PAT_POS= 5529,     // Text Patient Postion, char
00297     TEXT_PAT_POS_LEN= 7,
00298     TEXT_IMG_FLAG= 5541,    // Text Image Flag (IMAGE=image), char
00299     TEXT_IMG_FLAG_LEN= 5,
00300     TEXT_IMG_NUMBER= 5546,  // Text Image Number, char
00301     TEXT_IMG_NUMBER_LEN= 4,
00302     TEXT_IMG_DAY= 5559,     // Text Date - Day, char
00303     TEXT_IMG_DAY_LEN= 2,
00304     TEXT_IMG_MONTH= 5562,   // Text Date - Month, char
00305     TEXT_IMG_MONTH_LEN= 3,
00306     TEXT_IMG_YEAR= 5566,    // Text Date - Year, char
00307     TEXT_IMG_YEAR_LEN= 4,
00308     TEXT_IMG_HOUR= 5571,    // Text Time - hour, char
00309     TEXT_IMG_HOUR_LEN= 2,
00310     TEXT_IMG_MIN= 5574,     // Text Time - minute, char
00311     TEXT_IMG_MIN_LEN= 2,
00312     TEXT_ACQ_FLAG= 5577, // Text Acq. Time Flag (TA=time of acq), char
00313     TEXT_ACQ_FLAG_LEN= 2,
00314     TEXT_ACQ_MIN= 5583,     // Text Acq Time - minute, char
00315     TEXT_ACQ_MIN_LEN= 2,
00316     TEXT_ACQ_SEC= 5586,     // Text Acq Time - second, char
00317     TEXT_ACQ_SEC_LEN= 2,
00318     TEXT_ANNOTATION= 5601,  // Text Annotation, char
00319     TEXT_ANNOTATION_LEN= 32,
00320     TEXT_ORGANIZATION= 5655, // Text Organization, char
00321     TEXT_ORGANIZATION_LEN= 25,
00322     TEXT_STATION= 5682,     // Text Station Name, char
00323     TEXT_STATION_LEN= 5,
00324     TEXT_ACQ_MTRX_PHASE= 5695, // Acq. Matrix Phase Axis, char
00325     TEXT_ACQ_MTRX_PHASE_LEN= 3,
00326     TEXT_ACQ_PHASE_DIR= 5698, // Acq. phase direction (h=hor, v=vert), char
00327     TEXT_ACQ_PHASE_DIR_LEN= 1,
00328     TEXT_ACQ_MTRX_FREQ= 5700, // Acq. matrix Freq Axis, char 
00329     TEXT_ACQ_MTRX_FREQ_LEN= 3,
00330     TEXT_ACQ_MTRX_FREQO= 5703, // Acq freq (o=o  " "=blank), char
00331     TEXT_ACQ_MTRX_FREQO_LEN= 1,
00332     TEXT_ACQ_MTRX_FREQS= 5704, // Acq freq (s=s  " "=blank), char
00333     TEXT_ACQ_MTRX_FREQS_LEN= 1,
00334     TEXT_SEQUENCE= 5706,    // Sequence Type, char
00335     TEXT_SEQUENCE_LEN= 8,
00336     TEXT_FLIP_ANGLE= 5714,  // Flip Angle, char
00337     TEXT_FLIP_ANGLE_LEN= 3,
00338     TEXT_SCAN_FLAG= 5718,   // Scan flag ("SCAN"), char */ 
00339     TEXT_SCAN_FLAG_LEN= 4,
00340     TEXT_SCANA_NUM= 5723,   // Scan Number A, char
00341     TEXT_SCANA_NUM_LEN= 3,
00342     TEXT_SCANB_NUM= 5726,   // Scan Number B, char
00343     TEXT_SCANB_NUM_LEN= 3,
00344     TEXT_TR_FLAG= 5730,     // TR flag ("TR"), char
00345     TEXT_TR_FLAG_LEN= 2,
00346     TEXT_TR= 5734,          // TR, char
00347     TEXT_TR_LEN= 7,
00348     TEXT_TE_FLAG= 5742,     // TE flag ("TE"), char
00349     TEXT_TE_FLAG_LEN= 2,
00350     TEXT_TE= 5746,          // TE, char
00351     TEXT_TE_LEN= 5,
00352     TEXT_ECHO_NUM= 5752,    // Echo number, char
00353     TEXT_ECHO_NUM_LEN= 1,
00354     TEXT_THCK_FLAG= 5790,   // SLice thickness flag ("SL"), char
00355     TEXT_THCK_FLAG_LEN= 2,
00356     TEXT_SLICE_THCK= 5794,  // Slice thickness
00357     TEXT_SLICE_THCK_LEN= 7,
00358     TEXT_POS_FLAG= 5802,    // Slice postion flag ("SP"), char
00359     TEXT_POS_FLAG_LEN= 2,
00360     TEXT_SLICE_POS= 5806,   // Slice postion, char
00361     TEXT_SLICE_POS_LEN= 7,
00362     TEXT_ANGLE_FLAG1= 5814, // Angle flag 1 ("Sag","Cor",or,"Tra"), char
00363     TEXT_ANGLE_FLAG1_LEN= 3,
00364     TEXT_ANGLE_FLAG2= 5817, // Angle flag 2 ("<", or ">"), char
00365     TEXT_ANGLE_FLAG2_LEN= 1,
00366     TEXT_ANGLE_FLAG3= 5818, // Angle flag 3 ("Sag","Cor",or,"Tra"), char
00367     TEXT_ANGLE_FLAG3_LEN= 3,
00368     TEXT_ANGLE= 5821,       // Angle, char
00369     TEXT_ANGLE_LEN= 4,
00370     TEXT_FOV_FLAG= 5838,    // FOV flag ("FOV"), char
00371     TEXT_FOV_FLAG_LEN= 3,
00372     TEXT_FOVH= 5842,        // Horizontal FOV, char
00373     TEXT_FOVH_LEN= 3,
00374     TEXT_FOVV= 5846,        // Vertical FOV, char
00375     TEXT_FOVV_LEN= 3,
00376     TEXT_TABLEPOS_FLAG= 5874, // Table Postion flag ("TP"), char
00377     TEXT_TABLEPOS_FLAG_LEN= 2,
00378     TEXT_TABLE_POS= 5878,   // Table postion
00379     TEXT_TABLE_POS_LEN= 7,
00380     TEXT_STUDY_FLAG= 5938,  // Study flag ("STUDY"), char
00381     TEXT_STUDY_FLAG_LEN= 5,
00382     TEXT_STUDY_NUM= 5943,   // Study number, char
00383     TEXT_STUDY_NUM_LEN= 2,
00384     TEXT_DOB_DAY= 5956,     // Date of Birth - day, char
00385     TEXT_DOB_DAY_LEN= 2,
00386     TEXT_DOB_MONTH= 5959,   // Date of Birth - month, char
00387     TEXT_DOB_MONTH_LEN= 3,
00388     TEXT_DOB_YEAR= 5963,    // Date of Birth - year, char
00389     TEXT_DOB_YEAR_LEN= 4,
00390     TEXT_STUDY_FLAG2= 5992, // Study flag 2 ("STU"), char
00391     TEXT_STUDY_FLAG2_LEN= 3,
00392     TEXT_IMAGE_FLAG2= 5996, // Image flag 2 ("IMA"), char
00393     TEXT_IMAGE_FLAG2_LEN= 3,
00394     TEXT_STUDY_NUM2= 5999,  // Study number 2, char
00395     TEXT_STUDY_NUM2_LEN= 2,
00396     TEXT_IMAGE_NUM2= 6002,  // Image number 2, char
00397     TEXT_IMAGE_NUM2_LEN= 2,
00398     TEXT_IMAGE_NUM3= 6013,  // Image number 3, char
00399     TEXT_IMAGE_NUM3_LEN= 5,
00400     TEXT_MODEL_NAME= 6031,  // Model Name, char
00401     TEXT_MODEL_NAME_LEN= 15,
00402     TEXT_PAT_NAME= 6058,    // Patient Name, char
00403     TEXT_PAT_NAME_LEN= 25,
00404     TEXT_START_HOUR= 6085,  // Scan start time - hour, char
00405     TEXT_START_HOUR_LEN= 2,
00406     TEXT_START_MIN= 6088,   // Scan start time - minute, char
00407     TEXT_START_MIN_LEN= 2,
00408     TEXT_START_SEC= 6091,   // Scan start time - second, char
00409     TEXT_START_SEC_LEN= 2,
00410     HDR_TOTAL_LENGTH= 6144 // Total length of Siemens Header
00411   } SiemensVisionHeaderInfo;
00412   SiemensVisionImageIO(const Self&); //purposely not implemented
00413   void operator=(const Self&); //purposely not implemented
00414 };
00415 
00416 } // end namespace itk
00417 
00418 #endif // __itkSiemensVisionImageIO_h

Generated at Wed Mar 30 00:11:02 2005 for ITK by doxygen 1.3.9.1 written by Dimitri van Heesch, © 1997-2000