/* Create a grid transform from an existing MINC volume.
*/
#include <stdio.h>
#include <volume_io.h>
#include "time_stamp.h"
int main( int ac, char* av[] )
{
Volume v;
minc_input_options mio;
General_transform t;
Status st;
if ( ac != 3 ) {
fprintf( stderr, "usage: %s in_grid.mnc out.xfm\n", av[0] );
return 1;
}
/* The displacement volume must retain the vector dimension,
* so we turn off "vector -> scalar" conversion.
*/
set_minc_input_vector_to_scalar_flag( &mio, 0 );
st = input_volume( av[1],
0, NULL,
MI_ORIGINAL_TYPE, FALSE, 0.0, 0.0,
TRUE, &v,
&mio );
if ( st != OK ) {
fprintf( stderr, "failed to read grid volume \"%s\"\n", av[1] );
return 1;
}
create_grid_transform( &t, v );
st = output_transform_file( av[2], time_stamp(ac,av), &t );
if ( st != OK ) {
fprintf( stderr, "error writing to xfm file \"%s\"\n", av[2] );
return 1;
}
return 0;
}
syntax highlighted by Code2HTML, v. 0.9.1