[Insight-users] question about BSplineDefomableTransform
Kaveh Kohan
kaveh.kohan at yahoo.com
Sun Mar 7 21:36:47 EST 2010
Hi All,
I have a question about one of functions of itk::BSplineDeformableTransform and I would be thankful if somebody answers:
I would like to simulate some deformation fields by changing the identity transformation locally. I thought that perhaps BSpline model is a good candidate but I don't know how to use "SetCoefficientImages" function. It seems that if I want to know which part of image is perturbed from identity map this is a good option because using parameter type is very implicit. Here is how I tried but apparently it is not correct:
[...]
typedef itk::BSplineDeformableTransform< double,
Dimension,
3 > BSplineTransformType;
BSplineTransformType::Pointer bsplineTransform = BSplineTransformType::New();
typedef BSplineTransformType::RegionType RegionType;
RegionType bsplineRegion;
RegionType::SizeType gridSizeOnImage;
RegionType::SizeType gridBorderSize;
RegionType::SizeType totalGridSize;
gridSizeOnImage.Fill( 8 );
gridBorderSize.Fill( 3 );
totalGridSize = gridSizeOnImage + gridBorderSize;
bsplineRegion.SetSize( totalGridSize );
typedef BSplineTransformType::SpacingType SpacingType;
SpacingType bsplineSpacing = reader->GetOutput()->GetSpacing();
typedef BSplineTransformType::OriginType OriginType;
OriginType bsplineOrigin = reader->GetOutput()->GetOrigin();;
InputImageType::SizeType ImageSize = reader->GetOutput()->GetLargestPossibleRegion().GetSize();
for(unsigned int r=0; r<Dimension; r++)
{
bsplineSpacing[r] *= floor( static_cast<double>(ImageSize[r] ) /
static_cast<double>(gridSizeOnImage[r] ) );
bsplineOrigin[r] -= bsplineSpacing[r];
}
bsplineTransform->SetGridSpacing( bsplineSpacing );
bsplineTransform->SetGridOrigin( bsplineOrigin );
bsplineTransform->SetGridRegion( bsplineRegion );
typedef BSplineTransformType::ImageType ParamImageType ;
ParamImageType::Pointer bsplineImageParameters[3] ;
[...]
then I don't know what to do next! should I go ahead and define image size,origin.direction and then allocate memory for each bsplineImageParameters[0,1,2] but I have already specified grid size! how do they relate? I am confused how to use it.
Any comment is highly appreciated.
Regards,
kaveh
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://www.itk.org/pipermail/insight-users/attachments/20100307/1047199d/attachment.htm>
More information about the Insight-users
mailing list