Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033 #include "cmtkGroupwiseRegistrationFunctionalIO.h"
00034
00035 #include <Base/cmtkAffineXform.h>
00036 #include <Base/cmtkSplineWarpXform.h>
00037 #include <IO/cmtkClassStreamAffineXform.h>
00038
00039 namespace
00040 cmtk
00041 {
00042
00045
00046 ClassStream&
00047 operator<<
00048 ( ClassStream& stream, const GroupwiseRegistrationFunctionalBase& func )
00049 {
00050 const UniformVolume* templateGrid = func.GetTemplateGrid();
00051 stream.Begin( "template" );
00052 stream.WriteIntArray( "dims", templateGrid->GetDims().begin(), 3 );
00053 stream.WriteCoordinateArray( "delta", templateGrid->Deltas().begin(), 3 );
00054 stream.WriteCoordinateArray( "size", templateGrid->Size.begin(), 3 );
00055 stream.WriteCoordinateArray( "origin", templateGrid->m_Offset.begin(), 3 );
00056 stream.End();
00057
00058 for ( size_t idx = 0; idx < func.GetNumberOfTargetImages(); ++idx )
00059 {
00060 const UniformVolume* target = func.GetOriginalTargetImage( idx );
00061 stream.WriteString( "target", target->m_MetaInformation[META_FS_PATH].c_str() );
00062
00063 const Xform* xform = func.GetGenericXformByIndex( idx );
00064
00065 const AffineXform* affineXform = dynamic_cast<const AffineXform*>( xform );
00066 if ( affineXform )
00067 stream << (*affineXform);
00068
00069 const SplineWarpXform* splineXform = dynamic_cast<const SplineWarpXform*>( xform );
00070 if ( splineXform )
00071 stream << splineXform;
00072 }
00073
00074 return stream;
00075 }
00076
00077 }