📄 analyzeformat.txt
字号:
hdr.dime.dim[3] = atoi(argv[4]); /* volume depth in slices */
hdr.dime.dim[4] = atoi(argv[5]); /* number of volumes per file */
hdr.dime.glmax = atoi(argv[7]); /* maximum voxel value */
hdr.dime.glmin = atoi(argv[8]); /* minimum voxel value */
/* Set the voxel dimension fields:
A value of 0.0 for these fields implies that the value is unknown.
Change these values to what is appropriate for your data
or pass additional command line arguments */
hdr.dime.pixdim[1] = 0.0; /* voxel x dimension */
hdr.dime.pixdim[2] = 0.0; /* voxel y dimension */
hdr.dime.pixdim[3] = 0.0; /* pixel z dimension, slice thickness */
/* Assume zero offset in .img file, byte at which pixel
data starts in the image file */
hdr.dime.vox_offset = 0.0;
/* Planar Orientation; */
/* Movie flag OFF: 0 = transverse, 1 = coronal, 2 = sagittal
Movie flag ON: 3 = transverse, 4 = coronal, 5 = sagittal */
hdr.hist.orient = 0;
/* up to 3 characters for the voxels units label; i.e.
mm., um., cm. */
strcpy(hdr.dime.vox_units," ");
/* up to 7 characters for the calibration units label; i.e. HU */
strcpy(hdr.dime.cal_units," ");
/* Calibration maximum and minimum values;
values of 0.0 for both fields imply that no
calibration max and min values are used */
hdr.dime.cal_max = 0.0;
hdr.dime.cal_min = 0.0;
fwrite(&hdr,sizeof(struct dsr),1,fp);
fclose(fp);
}
usage()
{
printf("usage: make_hdr name.hdr x y z t datatype max min \n\n");
printf(" name.hdr = the name of the header file\n");
printf(" x = width, y = height, z = depth, t = number of volumes\n");
printf(" acceptable datatype values are: BINARY, CHAR, SHORT,\n");
printf(" INT, FLOAT, COMPLEX, DOUBLE, and RGB\n");
printf(" max = maximum voxel value, min = minimum voxel value\n");
}
The following program displays information in an Analyze header file.
#include <stdio.h>
#include "dbh.h"
void ShowHdr(char *, struct dsr *);
void swap_long(unsigned char *);
void swap_short(unsigned char *);
main(argc,argv)
int argc;
char **argv;
{
struct dsr hdr;
int size;
double cmax, cmin;
FILE *fp;
if((fp=fopen(argv[1],"r"))==NULL)
{
fprintf(stderr,"Can't open:<%s>\n", argv[1]);
exit(0);
}
fread(&hdr,1,sizeof(struct dsr),fp);
if(hdr.dime.dim[0] < 0 || hdr.dime.dim[0] > 15)
swap_hdr(&hdr);
ShowHdr(argv[1], &hdr);
}
void ShowHdr(fileName,hdr)
struct dsr *hdr;
char *fileName;
{
int i;
char string[128];
printf("Analyze Header Dump of: <%s> \n", fileName);
/* Header Key */
printf("sizeof_hdr: <%d> \n", hdr->hk.sizeof_hdr);
printf("data_type: <%s> \n", hdr->hk.data_type);
printf("db_name: <%s> \n", hdr->hk.db_name);
printf("extents: <%d> \n", hdr->hk.extents);
printf("session_error: <%d> \n", hdr->hk.session_error);
printf("regular: <%c> \n", hdr->hk.regular);
printf("hkey_un0: <%c> \n", hdr->hk.hkey_un0);
/* Image Dimension */
for(i=0;i<8;i++)
printf("dim[%d]: <%d> \n", i, hdr->dime.dim[i]);
strncpy(string,hdr->dime.vox_units,4);
printf("vox_units: <%s> \n", string);
strncpy(string,hdr->dime.cal_units,8);
printf("cal_units: <%s> \n", string);
printf("unused1: <%d> \n", hdr->dime.unused1);
printf("datatype: <%d> \n", hdr->dime.datatype);
printf("bitpix: <%d> \n", hdr->dime.bitpix);
for(i=0;i<8;i++)
printf("pixdim[%d]: <%6.4f> \n",i, hdr->dime.pixdim[i]);
printf("vox_offset: <%6.4> \n", hdr->dime.vox_offset);
printf("funused1: <%6.4f> \n", hdr->dime.funused1);
printf("funused2: <%6.4f> \n", hdr->dime.funused2);
printf("funused3: <%6.4f> \n", hdr->dime.funused3);
printf("cal_max: <%6.4f> \n", hdr->dime.cal_max);
printf("cal_min: <%6.4f> \n", hdr->dime.cal_min);
printf("compressed: <%d> \n", hdr->dime.compressed);
printf("verified: <%d> \n", hdr->dime.verified);
printf("glmax: <%d> \n", hdr->dime.glmax);
printf("glmin: <%d> \n", hdr->dime.glmin);
/* Data History */
strncpy(string,hdr->hist.descrip,80);
printf("descrip: <%s> \n", string);
strncpy(string,hdr->hist.aux_file,24);
printf("aux_file: <%s> \n", string);
printf("orient: <%d> \n", hdr->hist.orient);
strncpy(string,hdr->hist.originator,10);
printf("originator: <%s> \n", string);
strncpy(string,hdr->hist.generated,10);
printf("generated: <%s> \n", string);
strncpy(string,hdr->hist.scannum,10);
printf("scannum: <%s> \n", string);
strncpy(string,hdr->hist.patient_id,10);
printf("patient_id: <%s> \n", string);
strncpy(string,hdr->hist.exp_date,10);
printf("exp_date: <%s> \n", string);
strncpy(string,hdr->hist.exp_time,10);
printf("exp_time: <%s> \n", string);
strncpy(string,hdr->hist.hist_un0,10);
printf("hist_un0: <%s> \n", string);
printf("views: <%d> \n", hdr->hist.views);
printf("vols_added: <%d> \n", hdr->hist.vols_added);
printf("start_field:<%d> \n", hdr->hist.start_field);
printf("field_skip: <%d> \n", hdr->hist.field_skip);
printf("omax: <%d> \n", hdr->hist.omax);
printf("omin: <%d> \n", hdr->hist.omin);
printf("smin: <%d> \n", hdr->hist.smax);
printf("smin: <%d> \n", hdr->hist.smin);
}
swap_hdr(pntr)
struct dsr *pntr;
{
swap_long(&pntr->hk.sizeof_hdr) ;
swap_long(&pntr->hk.extents) ;
swap_short(&pntr->hk.session_error) ;
swap_short(&pntr->dime.dim[0]) ;
swap_short(&pntr->dime.dim[1]) ;
swap_short(&pntr->dime.dim[2]) ;
swap_short(&pntr->dime.dim[3]) ;
swap_short(&pntr->dime.dim[4]) ;
swap_short(&pntr->dime.dim[5]) ;
swap_short(&pntr->dime.dim[6]) ;
swap_short(&pntr->dime.dim[7]) ;
swap_short(&pntr->dime.unused1) ;
swap_short(&pntr->dime.datatype) ;
swap_short(&pntr->dime.bitpix) ;
swap_long(&pntr->dime.pixdim[0]) ;
swap_long(&pntr->dime.pixdim[1]) ;
swap_long(&pntr->dime.pixdim[2]) ;
swap_long(&pntr->dime.pixdim[3]) ;
swap_long(&pntr->dime.pixdim[4]) ;
swap_long(&pntr->dime.pixdim[5]) ;
swap_long(&pntr->dime.pixdim[6]) ;
swap_long(&pntr->dime.pixdim[7]) ;
swap_long(&pntr->dime.vox_offset) ;
swap_long(&pntr->dime.funused1) ;
swap_long(&pntr->dime.funused2) ;
swap_long(&pntr->dime.cal_max) ;
swap_long(&pntr->dime.cal_min) ;
swap_long(&pntr->dime.compressed) ;
swap_long(&pntr->dime.verified) ;
swap_short(&pntr->dime.dim_un0) ;
swap_long(&pntr->dime.glmax) ;
swap_long(&pntr->dime.glmin) ;
}
swap_long(pntr)
unsigned char *pntr;
{
unsigned char b0, b1, b2, b3;
b0 = *pntr;
b1 = *(pntr+1);
b2 = *(pntr+2);
b3 = *(pntr+3);
*pntr = b3;
*(pntr+1) = b2;
*(pntr+2) = b1;
*(pntr+3) = b0;
}
swap_short(pntr)
unsigned char *pntr;
{
unsigned char b0, b1;
b0 = *pntr;
b1 = *(pntr+1);
*pntr = b1;
*(pntr+1) = b0;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -