/*---------------------------------------------------------------------
01 Feb 2001: compute the center of a dataset (DICOM coord order)
Adapted from part of thd_info.c -- RWCox
-----------------------------------------------------------------------*/
#include "mrilib.h"
THD_fvec3 THD_dataset_center( THD_3dim_dataset * dset )
{
THD_dataxes * daxes ;
THD_fvec3 fv1 , fv2 ;
ENTRY("THD_dataset_center") ;
if( !ISVALID_DSET(dset) ){ LOAD_FVEC3(fv1,0,0,0); RETURN(fv1); }
daxes = dset->daxes ;
LOAD_FVEC3(fv1 , daxes->xxorg , daxes->yyorg , daxes->zzorg) ;
fv1 = THD_3dmm_to_dicomm( dset , fv1 ) ;
LOAD_FVEC3(fv2 , daxes->xxorg + (daxes->nxx-1)*daxes->xxdel ,
daxes->yyorg + (daxes->nyy-1)*daxes->yydel ,
daxes->zzorg + (daxes->nzz-1)*daxes->zzdel ) ;
fv2 = THD_3dmm_to_dicomm( dset , fv2 ) ;
fv1.xyz[0] = 0.5*(fv1.xyz[0]+fv2.xyz[0]) ;
fv1.xyz[1] = 0.5*(fv1.xyz[1]+fv2.xyz[1]) ;
fv1.xyz[2] = 0.5*(fv1.xyz[2]+fv2.xyz[2]) ;
RETURN(fv1) ;
}
syntax highlighted by Code2HTML, v. 0.9.1