#include <fstream>
int main( int argc, char * argv[] )
{
if( argc < 3 )
{
std::cerr << "Missing Parameters " << std::endl;
std::cerr << "Usage: " << argv[0];
std::cerr << " landmarksFile fixedImage outputDisplacementField"
<< std::endl;
return EXIT_FAILURE;
}
typedef float VectorComponentType;
typedef unsigned char PixelType;
FixedReaderType::Pointer fixedReader = FixedReaderType::New();
fixedReader->SetFileName( argv[2] );
try
{
fixedReader->Update();
}
{
std::cerr << "Exception thrown " << std::endl;
std::cerr << excp << std::endl;
return EXIT_FAILURE;
}
FixedImageType::ConstPointer fixedImage = fixedReader->GetOutput();
DisplacementFieldType
> FilterType;
FilterType::Pointer filter = FilterType::New();
filter->SetOutputSpacing( fixedImage->GetSpacing() );
filter->SetOutputOrigin( fixedImage->GetOrigin() );
filter->SetOutputRegion( fixedImage->GetLargestPossibleRegion() );
filter->SetOutputDirection( fixedImage->GetDirection() );
typedef FilterType::LandmarkContainer LandmarkContainerType;
typedef FilterType::LandmarkPointType LandmarkPointType;
LandmarkContainerType::Pointer sourceLandmarks
= LandmarkContainerType::New();
LandmarkContainerType::Pointer targetLandmarks
= LandmarkContainerType::New();
std::ifstream pointsFile;
pointsFile.open( argv[1] );
LandmarkPointType sourcePoint;
pointsFile >> sourcePoint;
LandmarkPointType targetPoint;
pointsFile >> targetPoint;
unsigned int pointId = 0;
while( !pointsFile.fail() )
{
sourceLandmarks->InsertElement( pointId, sourcePoint );
targetLandmarks->InsertElement( pointId, targetPoint );
pointId++;
pointsFile >> sourcePoint;
pointsFile >> targetPoint;
}
pointsFile.close();
filter->SetSourceLandmarks( sourceLandmarks.GetPointer() );
filter->SetTargetLandmarks( targetLandmarks.GetPointer() );
try
{
filter->UpdateLargestPossibleRegion();
}
{
std::cerr << "Exception thrown " << std::endl;
std::cerr << excp << std::endl;
return EXIT_FAILURE;
}
WriterType::Pointer writer = WriterType::New();
writer->SetInput ( filter->GetOutput() );
writer->SetFileName( argv[3] );
filter->Print( std::cout );
try
{
writer->Update();
}
{
std::cerr << "Exception thrown by writer" << std::endl;
std::cerr << excp << std::endl;
return EXIT_FAILURE;
}
return EXIT_SUCCESS;
}