/usr/include/InsightToolkit/Review/itkMRCHeaderObject.h is in libinsighttoolkit3-dev 3.20.1+git20120521-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 | /*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: itkMRCHeaderObject.h
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) Insight Software Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
=========================================================================*/
#ifndef __itkMRCHeaderObject_h
#define __itkMRCHeaderObject_h
#include "itkLightObject.h"
#include "itkByteSwapper.h"
#include "itkIntTypes.h"
namespace itk
{
/** \fixme This is a very easy way to declare a string constant */
const char * const magicMAP = "MAP ";
/** \class MRCHeaderObject
* \brief This class is a light wrapper for a couple of plain old data
* structures, so that they can be utilized in a MetaDataDictionary.
*
* The class is designed to be intialized from a chuck of bytes that
* are read in from a file. Verification is performed to ensure that
* the bytes appear to be the correct format for the headers.
*
* The POD structures a publicly avaible without access methods.
*
* \sa MetaDataDictionary
*/
class ITK_EXPORT MRCHeaderObject :
public itk::LightObject
{
public:
/** Standard class typedefs. */
typedef MRCHeaderObject Self;
typedef LightObject Superclass;
typedef SmartPointer<Self> Pointer;
typedef SmartPointer<const Self> ConstPointer;
/** plain old data structure of the MRC header as used by IMOD. This
* header must be 1024 bytes.
*
* The structure of the MRC header taken from:
* http://bio3d.colorado.edu/imod/doc/mrc_format.txt with permision
* from David Mastronarde on 8/21/2009
*/
struct Header
{
int32_t nx; /**< Number of Columns */
int32_t ny; /**< Number of Rows */
int32_t nz; /**< Number of Sections */
/** Types of pixel in image. Values used by IMOD:
* 0 = unsigned bytes,
* 1 = signed short integers (16 bits),
* 2 = float,
* 3 = short * 2, (used for complex data)
* 4 = float * 2, (used for complex data)
* 6 = unsigned 16-bit integers (non-standard)
* 16 = unsigned char * 3 (for rgb data, non-standard)
*/
int32_t mode;
/** Starting point of sub image. (ignored) */
int32_t nxstart;
int32_t nystart;
int32_t nzstart;
/** Grid size in X, Y, and Z */
int32_t mx;
int32_t my;
int32_t mz;
/** Cell size; pixel spacing = xlen/mx */
float xlen;
float ylen;
float zlen;
/**cell angles (ignored) */
float alpha;
float beta;
float gamma;
int32_t mapc; /**< map column 1=x,2=y,3=z. (ignored) */
int32_t mapr; /**< map row 1=x,2=y,3=z. (ignored) */
int32_t maps; /**< map section 1=x,2=y,3=z. (ignored) */
// These need to be set for proper scaling of
// non byte data.
float amin; /**< Minimum pixel value. */
float amax; /**< Maximum pixel value. */
float amean; /**< Mean pixel value. */
int16_t ispg; /**< image type */
int16_t nsymbt; /**< space group number */
int32_t next; /**< number of bytes in extended header */
int16_t creatid; /**< Creator ID */
int8_t notused1[30]; /**< extra data (not used) */
// These two values specify the structure of data in the
// extended header; their meaning depend on whether the
// extended header has the Agard format, a series of
// 4-byte integers then real numbers, or has data
// produced by SerialEM, a series of short integers.
// SerialEM stores a float as two shorts, s1 and s2, by:
// value = (sign of s1)*(|s1|*256 + (|s2| modulo 256))
// * 2**((sign of s2) * (|s2|/256))
int16_t nint; // Number of integers per section (Agard format) or
// number of bytes per section (SerialEM format)
int16_t nreal; // Number of reals per section (Agard format) or
// flags for which types of short data (SerialEM format):
// 1 = tilt angle * 100 (2 bytes)
// 2 = piece coordinates for montage (6 bytes)
// 4 = Stage position * 25 (4 bytes)
// 8 = Magnification / 100 (2 bytes)
// 16 = Intensity * 25000 (2 bytes)
// 32 = Exposure dose in e-/A2, a float in 4 bytes
// 128, 512: Reserved for 4-byte items
// 64, 256, 1024: Reserved for 2-byte items
// If the number of bytes implied by these flags does
// not add up to the value in nint, then nint and nreal
// are interpreted as ints and reals per section
/** extra data (not used) */
int8_t notused2[28];
// Explanation of type of data.
int16_t idtype; // ( 0 = mono, 1 = tilt, 2 = tilts, 3 = lina, 4 = lins)
int16_t lens;
int16_t nd1; // for idtype = 1, nd1 = axis (1, 2, or 3)
int16_t nd2;
int16_t vd1; // vd1 = 100. * tilt increment
int16_t vd2; // vd2 = 100. * starting angle
// Used to rotate model to match new rotated image.
float tiltangles[6]; // 0,1,2 = original: 3,4,5 = current
// NEW-STYLE MRC image2000 HEADER - IMOD 2.6.20 and above:
float xorg; // Origin of image. Used to auto translate model
float yorg; // to match a new image that has been translated.
float zorg;
char cmap[4]; /**< Contains "MAP " */
char stamp[4]; /**< First byte has 17 for big- or 68 for little-endian */
float rms;
// ALL HEADERS:
int32_t nlabl; /**< Number of labels with useful data. */
char label[10][80]; /**< 10 labels of 80 charactors. */
};
/** Fei/Agard extended header */
struct FeiExtendedHeader
{
float atilt; /**< alpha tilt */
float btilt; /**< beta tilt */
float xstage; /**< Stage x position (unit=m, huh if > 1) */
float ystage; /**< Stage y position (unit=m, huh if > 1) */
float zstage; /**< Stage z position (unit=m, huh if > 1) */
float xshift; /**< Image shift x (unit=m, huh if > 1) */
float yshift; /**< Image shift y (unit=m, huh if > 1) */
float defocus; /**< (unit=m, huh if > 1) */
float exptime; /**< time is seconds */
float meanint; /**< mean value */
float tiltaxis; /**< tilt axis in degree */
float pixelsize; /**< pixel size (unit=m, huh if > 1) */
float magnification;
char notused[76]; /**< fill up 128 bytes */
};
/** pixel type enumeration */
enum {MRCHEADER_MODE_UINT8 = 0,
MRCHEADER_MODE_IN16 = 1,
MRCHEADER_MODE_FLOAT = 2,
MRCHEADER_MODE_COMPLEX_INT16 = 3,
MRCHEADER_MODE_COMPLEX_FLOAT = 4,
MRCHEADER_MODE_UINT16 = 6,
MRCHEADER_MODE_RGB_BYTE = 16};
/** map enumeration */
enum {MRCHEADER_MAP_X = 1,
MRCHEADER_MAP_Y = 2,
MRCHEADER_MAP_Z = 3};
public:
/** Method for creation through the object factory. */
itkNewMacro(Self);
/** Run-time type information (and related methods). */
itkTypeMacro(MRCHeaderObject, LightObject);
void DeepCopy(ConstPointer h);
/** \param buffer is assumed to point to a 1024 block of memory
* which has the header
*
* The return value indicates if buffer appears valid. If
* false is returned then the header member varible is in an undefined
* state.
*
* If the byte order of the header then byte swapping will be
* performed.
*/
bool SetHeader(const Header *buffer);
const Header & GetHeader() const;
/** After SetHeader is called GetExtendedHeaderSize contains the
* extected size of the buffer argument. This buffer is expected to
* be the bytes which follow the header in the file.
*
* The return value indicates if the extended header buffer is valid
* and known. If false is returned then extended header information
* is not available.
*/
bool SetExtendedHeader(const void *buffer);
/** the expected number of bytes in the extended header, this is only
* valid after a successful call to SetHeader.
*/
size_t GetExtendedHeaderSize(void) const;
/** the expected number of bytes in the header */
size_t GetHeaderSize(void) const { return sizeof(Header); }
/** returns true if the original header from SetHeader was big
* endian.
*/
bool IsOriginalHeaderBigEndian(void) const;
/** Public avaiable data : FIXME : NO MEMBER VARIABLES SHOULD BE PUBLIC. */
Header m_Header; // FIXME : This should be private and should have Get/Set Methods.
protected:
MRCHeaderObject(void);
~MRCHeaderObject(void);
/** Methods to fix the order of a set header */
void swapHeader(bool bigEndian);
/** Prints loads of information from the header */
void PrintSelf(std::ostream& os, Indent indent) const;
private:
MRCHeaderObject(const Self&); //purposely not implemented
void operator=(const Self&); //purposely not implemented
size_t m_ExtendedHeaderSize;
void * m_ExtendedHeader;
FeiExtendedHeader * m_ExtendedFeiHeader;
bool m_BigEndianHeader;
};
} // namespace itk
#endif
|