#include <elxBSplineStackTransform.h>
A B-spline transform based on the itkStackTransform.
This transform is a B-spline transformation, with for every time point a separate D-1 dimensional B-spline transform. Calls to TransformPoint and GetJacobian are redirected to the appropriate sub transform based on the last dimension (time) index.
This transform uses the size, spacing and origin of the last dimension of the fixed image to set the number of sub transforms the origin of the first transform and the spacing between the transforms.
When supplying the B-spline parameters (grid) make sure to provide dimension - 1 elements.
The parameters used in this class are:
Transform: Select this transform as follows:
(Transform "BSplineStackTransform")
BSplineTransformSplineOrder: choose a B-spline order 1,2, or 3.
example: (BSplineTransformSplineOrder 3)
Default value: 3 (cubic B-splines).
FinalGridSpacingInVoxels: the grid spacing of the B-spline transform for each dimension.
example: (FinalGridSpacingInVoxels 8.0 8.0 8.0)
If only one argument is given, that factor is used for each dimension. The spacing is not in millimeters, but in "voxel size units". The default is 16.0 in every dimension.
FinalGridSpacingInPhysicalUnits: the grid spacing of the B-spline transform for each dimension.
example: (FinalGridSpacingInPhysicalUnits 8.0 8.0 8.0)
If only one argument is given, that factor is used for each dimension. The spacing is specified in millimeters. If not specified, the FinalGridSpacingInVoxels is used, or the FinalGridSpacing, to compute a FinalGridSpacingInPhysicalUnits. If those are not specified, the default value for FinalGridSpacingInVoxels is used to compute a FinalGridSpacingInPhysicalUnits. If an affine transformation is provided as initial transformation, the control grid will be scaled to cover the fixed image domain in the space defined by the initial transformation.
GridSpacingSchedule: the grid spacing downsampling factors for the B-spline transform for each dimension and each resolution.
example: (GridSpacingSchedule 4.0 4.0 2.0 2.0 1.0 1.0)
Which is an example for a 2D image, using 3 resolutions.
For convenience, you may also specify only one value for each resolution:
example: (GridSpacingSchedule 4.0 2.0 1.0 )
which is equivalent to the example above.
PassiveEdgeWidth: the width of a band of control points at the border of the B-spline coefficient image that should remain passive during optimisation.
Can be specified for each resolution.
example: (PassiveEdgeWidth 0 1 2)
The default is zero for all resolutions. A value of 4 will avoid all deformations at the edge of the image. Make sure that 2*PassiveEdgeWidth < ControlPointGridSize in each dimension.
The transform parameters necessary for transformix, additionally defined by this class, are:
GridSize: stores the size of the B-spline grid.
example: (GridSize 16 16 16)
GridIndex: stores the index of the B-spline grid.
example: (GridIndex 0 0 0)
GridSpacing: stores the spacing of the B-spline grid.
example: (GridSpacing 16.0 16.0 16.0)
GridOrigin: stores the origin of the B-spline grid.
example: (GridOrigin 0.0 0.0 0.0)
GridDirection: stores the direction cosines of the B-spline grid.
example: (GridDirection 1.0 0.0 0.0 0.0 1.0 0.0 0.0 0.0 0.1)
BSplineTransformSplineOrder: stores the B-spline order 1,2, or 3.
example: (BSplineTransformSplineOrder 3)
Default value: 3 (cubic B-splines).
StackSpacing: stores the spacing between the sub transforms.
exanoke: (StackSpacing 1.0)
StackOrigin: stores the origin of the first sub transform.
exanoke: (StackOrigin 0.0)
NumberOfSubTransforms: stores the number of sub transforms.
exanoke: (NumberOfSubTransforms 10)
Definition at line 112 of file elxBSplineStackTransform.h.
Public Member Functions | |
int | BeforeAll () override |
void | BeforeEachResolution () override |
void | BeforeRegistration () override |
elxClassNameMacro ("BSplineStackTransform") | |
virtual const char * | GetClassName () const |
virtual void | IncreaseScale () |
ITK_DISALLOW_COPY_AND_MOVE (BSplineStackTransform) | |
itkStaticConstMacro (ReducedSpaceDimension, unsigned int, Superclass2::FixedImageDimension - 1) | |
itkStaticConstMacro (SpaceDimension, unsigned int, Superclass2::FixedImageDimension) | |
void | ReadFromFile () override |
virtual void | SetOptimizerScales (const unsigned int edgeWidth) |
Public Member Functions inherited from itk::AdvancedCombinationTransform< TScalarType, NDimensions > | |
void | EvaluateJacobianWithImageGradientProduct (const InputPointType &inputPoint, const MovingImageGradientType &movingImageGradient, DerivativeType &imageJacobian, NonZeroJacobianIndicesType &nonZeroJacobianIndices) const override |
const FixedParametersType & | GetFixedParameters () const override |
bool | GetHasNonZeroSpatialHessian () const override |
bool | GetInverse (Self *inverse) const |
void | GetJacobian (const InputPointType &inputPoint, JacobianType &j, NonZeroJacobianIndicesType &nonZeroJacobianIndices) const override |
void | GetJacobianOfSpatialHessian (const InputPointType &inputPoint, JacobianOfSpatialHessianType &jsh, NonZeroJacobianIndicesType &nonZeroJacobianIndices) const override |
void | GetJacobianOfSpatialHessian (const InputPointType &inputPoint, SpatialHessianType &sh, JacobianOfSpatialHessianType &jsh, NonZeroJacobianIndicesType &nonZeroJacobianIndices) const override |
void | GetJacobianOfSpatialJacobian (const InputPointType &inputPoint, JacobianOfSpatialJacobianType &jsj, NonZeroJacobianIndicesType &nonZeroJacobianIndices) const override |
void | GetJacobianOfSpatialJacobian (const InputPointType &inputPoint, SpatialJacobianType &sj, JacobianOfSpatialJacobianType &jsj, NonZeroJacobianIndicesType &nonZeroJacobianIndices) const override |
const TransformTypePointer | GetNthTransform (SizeValueType n) const |
NumberOfParametersType | GetNumberOfNonZeroJacobianIndices () const override |
NumberOfParametersType | GetNumberOfParameters () const override |
SizeValueType | GetNumberOfTransforms () const |
const ParametersType & | GetParameters () const override |
void | GetSpatialHessian (const InputPointType &inputPoint, SpatialHessianType &sh) const override |
void | GetSpatialJacobian (const InputPointType &inputPoint, SpatialJacobianType &sj) const override |
TransformCategoryEnum | GetTransformCategory () const override |
virtual bool | GetUseAddition () const |
virtual bool | GetUseComposition () const |
bool | HasNonZeroJacobianOfSpatialHessian () const |
bool | IsLinear () const override |
ITK_DISALLOW_COPY_AND_MOVE (AdvancedCombinationTransform) | |
itkGetModifiableObjectMacro (CurrentTransform, CurrentTransformType) | |
itkGetModifiableObjectMacro (InitialTransform, InitialTransformType) | |
itkStaticConstMacro (SpaceDimension, unsigned int, NDimensions) | |
void | SetCurrentTransform (CurrentTransformType *_arg) |
void | SetFixedParameters (const FixedParametersType &fixedParam) override |
void | SetInitialTransform (InitialTransformType *_arg) |
void | SetParameters (const ParametersType ¶m) override |
void | SetParametersByValue (const ParametersType ¶m) override |
void | SetUseAddition (bool _arg) |
void | SetUseComposition (bool _arg) |
OutputCovariantVectorType | TransformCovariantVector (const InputCovariantVectorType &) const override |
OutputPointType | TransformPoint (const InputPointType &point) const override |
OutputVectorType | TransformVector (const InputVectorType &) const override |
OutputVnlVectorType | TransformVector (const InputVnlVectorType &) const override |
Public Member Functions inherited from itk::AdvancedTransform< TScalarType, 3, 3 > | |
void | ComputeJacobianWithRespectToParameters (const InputPointType &, JacobianType &) const override |
virtual bool | GetHasNonZeroJacobianOfSpatialHessian () const |
ITK_DISALLOW_COPY_AND_MOVE (AdvancedTransform) | |
itkStaticConstMacro (InputSpaceDimension, unsigned int, NInputDimensions) | |
itkStaticConstMacro (OutputSpaceDimension, unsigned int, NOutputDimensions) | |
Public Member Functions inherited from elastix::TransformBase< TElastix > | |
int | BeforeAllTransformix () |
void | ComputeAndWriteSpatialJacobianDeterminantImage () const |
void | ComputeAndWriteSpatialJacobianMatrixImage () const |
SpatialJacobianDeterminantImageType::Pointer | ComputeSpatialJacobianDeterminantImage () const |
SpatialJacobianMatrixImageType::Pointer | ComputeSpatialJacobianMatrixImage () const |
void | CreateTransformParameterMap (const ParametersType ¶m, ParameterMapType ¶meterMap, const bool includeDerivedTransformParameters=true) const |
ITKBaseType * | GetAsITKBaseType () |
const ITKBaseType * | GetAsITKBaseType () const |
ITK_DISALLOW_COPY_AND_MOVE (TransformBase) | |
itkStaticConstMacro (FixedImageDimension, unsigned int, FixedImageType::ImageDimension) | |
itkStaticConstMacro (MovingImageDimension, unsigned int, MovingImageType::ImageDimension) | |
void | ReadInitialTransformFromFile (const std::string &transformParameterFileName) |
void | SetFinalParameters () |
void | SetInitialTransform (InitialTransformType *_arg) |
void | SetReadWriteTransformParameters (const bool _arg) |
void | SetTransformParameterFileName (const std::string &filename) |
template<typename TMesh > | |
TMesh::Pointer | TransformMesh (const TMesh &mesh) const |
void | TransformPoints () const |
void | WriteToFile (std::ostream &transformationParameterInfo, const ParametersType ¶m) const |
Public Member Functions inherited from elastix::BaseComponentSE< TElastix > | |
void | AddTargetCellToIterationInfo (const char *const name) |
const Configuration * | GetConfiguration () const |
ElastixType * | GetElastix () const |
auto & | GetIterationInfoAt (const char *const name) |
RegistrationType * | GetRegistration () const |
ITK_DISALLOW_COPY_AND_MOVE (BaseComponentSE) | |
void | RemoveTargetCellFromIterationInfo (const char *const name) |
void | SetConfiguration (const Configuration *_arg) |
void | SetElastix (ElastixType *_arg) |
Public Member Functions inherited from elastix::BaseComponent | |
virtual void | AfterEachIteration () |
virtual void | AfterEachIterationBase () |
virtual void | AfterEachResolution () |
virtual void | AfterEachResolutionBase () |
virtual void | AfterRegistration () |
virtual void | BeforeEachResolutionBase () |
virtual const char * | elxGetClassName () const |
const char * | GetComponentLabel () const |
ITK_DISALLOW_COPY_AND_MOVE (BaseComponent) | |
itkTypeMacroNoParent (BaseComponent) | |
void | SetComponentLabel (const char *label, unsigned int idx) |
Static Public Member Functions | |
static Pointer | New () |
Static Public Member Functions inherited from itk::AdvancedCombinationTransform< TScalarType, NDimensions > | |
static Pointer | New () |
Static Public Member Functions inherited from elastix::BaseComponent | |
template<typename TBaseComponent > | |
static auto | AsITKBaseType (TBaseComponent *const baseComponent) -> decltype(baseComponent->GetAsITKBaseType()) |
static void | InitializeElastixExecutable () |
static bool | IsElastixLibrary () |
Private Types | |
using | StackTransformType = itk::BSplineStackTransform<SpaceDimension> |
Private Member Functions | |
ParameterMapType | CreateDerivedTransformParameterMap () const override |
unsigned int | InitializeBSplineTransform () |
void | InitializeTransform () |
Additional Inherited Members | |
Protected Attributes inherited from itk::AdvancedTransform< TScalarType, 3, 3 > | |
bool | m_HasNonZeroJacobianOfSpatialHessian |
bool | m_HasNonZeroSpatialHessian |
Protected Attributes inherited from elastix::BaseComponentSE< TElastix > | |
Configuration::ConstPointer | m_Configuration {} |
itk::WeakPointer< TElastix > | m_Elastix {} |
RegistrationType * | m_Registration {} |
using elastix::BSplineStackTransform< TElastix >::BSplineTransformBasePointer = typename BSplineTransformBaseType::Pointer |
Definition at line 150 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::BSplineTransformBaseType |
The ITK-class that provides most of the functionality, and that is set as the "CurrentTransform" in the CombinationTransform.
Definition at line 147 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::CombinationTransformType = typename Superclass2::CombinationTransformType |
Definition at line 181 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ConstPointer = itk::SmartPointer<const Self> |
Definition at line 126 of file elxBSplineStackTransform.h.
using elastix::TransformBase< TElastix >::CoordRepType |
Elastix typedef's.
Definition at line 156 of file elxTransformBase.h.
using elastix::BSplineStackTransform< TElastix >::DirectionType = typename BSplineTransformBaseType::DirectionType |
Definition at line 172 of file elxBSplineStackTransform.h.
using elastix::TransformBase< TElastix >::FixedImageType |
Definition at line 157 of file elxTransformBase.h.
using elastix::BSplineStackTransform< TElastix >::GridScheduleComputerPointer = typename GridScheduleComputerType::Pointer |
Definition at line 194 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::GridScheduleComputerType = itk::GridScheduleComputer<CoordRepType, ReducedSpaceDimension> |
Typedef's for the GridScheduleComputer and the UpsampleBSplineParametersFilter.
Definition at line 193 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::GridScheduleType = typename GridScheduleComputerType ::VectorGridSpacingFactorType |
Definition at line 195 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::GridUpsamplerPointer = typename GridUpsamplerType::Pointer |
Definition at line 197 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::GridUpsamplerType = itk::UpsampleBSplineParametersFilter<ParametersType, ReducedDimensionImageType> |
Definition at line 196 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ImagePointer = typename BSplineTransformBaseType::ImagePointer |
Definition at line 166 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ImageType = typename BSplineTransformBaseType::ImageType |
Definition at line 165 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::IndexType = typename BSplineTransformBaseType::IndexType |
Definition at line 168 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ITKBaseType = typename Superclass2::ITKBaseType |
Definition at line 180 of file elxBSplineStackTransform.h.
using elastix::TransformBase< TElastix >::MovingImageType |
Definition at line 158 of file elxTransformBase.h.
using elastix::BSplineStackTransform< TElastix >::OriginType = typename BSplineTransformBaseType::OriginType |
Definition at line 171 of file elxBSplineStackTransform.h.
using elastix::TransformBase< TElastix >::ParameterMapType |
Typedef that is used in the elastix dll version.
Definition at line 199 of file elxTransformBase.h.
using elastix::BSplineStackTransform< TElastix >::ParameterValueType = std::vector<std::string> |
Typedef's creation of parameter map
Definition at line 200 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::Pointer = itk::SmartPointer<Self> |
Definition at line 125 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ReducedDimensionBSplineTransformBasePointer = typename ReducedDimensionBSplineTransformBaseType::Pointer |
Definition at line 156 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ReducedDimensionBSplineTransformBaseType |
The ITK-class for the sub transforms, which have a reduced dimension.
Definition at line 153 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ReducedDimensionDirectionType = typename ReducedDimensionImageType::DirectionType |
Definition at line 189 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ReducedDimensionImageType = itk::Image<PixelType, Self::ReducedSpaceDimension> |
Reduced dimension image typedefs.
Definition at line 184 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ReducedDimensionIndexType = typename ReducedDimensionRegionType::IndexType |
Definition at line 187 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ReducedDimensionOriginType = typename ReducedDimensionImageType::PointType |
Definition at line 190 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ReducedDimensionRegionType = itk::ImageRegion<Self::ReducedSpaceDimension> |
Definition at line 185 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ReducedDimensionSizeType = typename ReducedDimensionRegionType::SizeType |
Definition at line 186 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::ReducedDimensionSpacingType = typename ReducedDimensionImageType::SpacingType |
Definition at line 188 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::RegionType = typename BSplineTransformBaseType::RegionType |
Definition at line 167 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::Self = BSplineStackTransform |
Standard ITK-stuff.
Definition at line 121 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::SizeType = typename BSplineTransformBaseType::SizeType |
Definition at line 169 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::SpacingType = typename BSplineTransformBaseType::SpacingType |
Definition at line 170 of file elxBSplineStackTransform.h.
|
private |
The deleted copy constructor and assignment operator. Typedef for stack transform.
Definition at line 278 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::Superclass1 |
Definition at line 122 of file elxBSplineStackTransform.h.
using elastix::BSplineStackTransform< TElastix >::Superclass2 = elx::TransformBase<TElastix> |
Definition at line 124 of file elxBSplineStackTransform.h.
|
inlineprotected |
The constructor.
Definition at line 252 of file elxBSplineStackTransform.h.
|
overrideprotecteddefault |
The destructor.
|
overridevirtual |
Execute stuff before anything else is done:
Reimplemented from elastix::BaseComponent.
|
overridevirtual |
Execute stuff before each new pyramid resolution:
Reimplemented from elastix::BaseComponent.
|
overridevirtual |
Execute stuff before the actual registration:
Reimplemented from elastix::BaseComponent.
|
overrideprivatevirtual |
Creates a map of the parameters specific for this (derived) transform type.
Implements elastix::TransformBase< TElastix >.
elastix::BSplineStackTransform< TElastix >::elxClassNameMacro | ( | "BSplineStackTransform< TElastix >" | ) |
Name of this class. Use this name in the parameter file to select this specific transform.
example: (Transform "BSplineStackTransform")
|
virtual |
Run-time type information (and related methods).
Reimplemented from itk::AdvancedCombinationTransform< TScalarType, NDimensions >.
|
virtual |
Method to increase the density of the B-spline grid.
|
private |
Initialize the right B-spline transform based on the spline order.
|
private |
Method to set the initial B-spline grid and grid scheduler and initialize the parameters (to 0).
elastix::BSplineStackTransform< TElastix >::ITK_DISALLOW_COPY_AND_MOVE | ( | BSplineStackTransform< TElastix > | ) |
elastix::BSplineStackTransform< TElastix >::itkStaticConstMacro | ( | ReducedSpaceDimension | , |
unsigned int | , | ||
Superclass2::FixedImageDimension - | 1 ) |
elastix::BSplineStackTransform< TElastix >::itkStaticConstMacro | ( | SpaceDimension | , |
unsigned int | , | ||
Superclass2::FixedImageDimension | ) |
(Reduced) dimension of the fixed image.
|
static |
Method for creation through the object factory.
|
protectedvirtual |
Read user-specified gridspacing and call the itkGridScheduleComputer.
|
overridevirtual |
Function to read transform-parameters from a file.
Reimplemented from elastix::TransformBase< TElastix >.
|
virtual |
Set the scales of the edge B-spline coefficients to zero.
|
private |
Definition at line 262 of file elxBSplineStackTransform.h.
|
private |
Dummy sub transform to be used to set sub transforms of stack transform.
Definition at line 284 of file elxBSplineStackTransform.h.
|
private |
Grid schedule computer and grid upsampler.
Definition at line 287 of file elxBSplineStackTransform.h.
|
private |
Definition at line 288 of file elxBSplineStackTransform.h.
|
private |
Stack variables.
Definition at line 294 of file elxBSplineStackTransform.h.
|
private |
Variable to remember order of B-spline transform.
Definition at line 291 of file elxBSplineStackTransform.h.
|
private |
Definition at line 295 of file elxBSplineStackTransform.h.
|
private |
Definition at line 295 of file elxBSplineStackTransform.h.
|
private |
The B-spline stack transform.
Definition at line 281 of file elxBSplineStackTransform.h.
Generated on 2024-07-17 for elastix by 1.11.0 (9b424b03c9833626cd435af22a444888fbbb192d) |