18#ifndef itkAdvancedCombinationTransform_h
19#define itkAdvancedCombinationTransform_h
55template <
typename TScalarType,
unsigned int NDimensions = 3>
77 using typename Superclass::ScalarType;
78 using typename Superclass::ParametersType;
79 using typename Superclass::FixedParametersType;
80 using typename Superclass::ParametersValueType;
81 using typename Superclass::NumberOfParametersType;
82 using typename Superclass::DerivativeType;
83 using typename Superclass::JacobianType;
84 using typename Superclass::InputVectorType;
85 using typename Superclass::OutputVectorType;
86 using typename Superclass::InputCovariantVectorType;
87 using typename Superclass::OutputCovariantVectorType;
88 using typename Superclass::InputVnlVectorType;
89 using typename Superclass::OutputVnlVectorType;
90 using typename Superclass::InputPointType;
91 using typename Superclass::OutputPointType;
99 using typename Superclass::InverseTransformBasePointer;
100 using typename Superclass::TransformCategoryEnum;
153 itkGetConstMacro(UseComposition,
bool);
159 itkGetConstMacro(UseAddition,
bool);
173 <<
"TransformVector(const InputVectorType &) is not implemented for AdvancedCombinationTransform");
181 <<
"TransformVector(const InputVnlVectorType &) is not implemented for AdvancedCombinationTransform");
185 OutputCovariantVectorType
188 itkExceptionMacro(<<
"TransformCovariantVector(const InputCovariantVectorType &) is not implemented for "
189 "AdvancedCombinationTransform");
194 NumberOfParametersType
198 NumberOfParametersType
202 const ParametersType &
206 const FixedParametersType &
245 TransformCategoryEnum
265 DerivativeType & imageJacobian,
551 constexpr static const char * NoCurrentTransformSet =
"No current transform set in the AdvancedCombinationTransform";
602 &Self::EvaluateJacobianWithImageGradientProductNoInitialTransform
607 &Self::GetJacobianOfSpatialJacobianNoCurrentTransform
610 &Self::GetJacobianOfSpatialJacobianNoCurrentTransform
613 &Self::GetJacobianOfSpatialHessianNoCurrentTransform
616 &Self::GetJacobianOfSpatialHessianNoCurrentTransform
620 bool m_UseAddition{
false };
621 bool m_UseComposition{
true };
626#ifndef ITK_MANUAL_INSTANTIATION
627# include "itkAdvancedCombinationTransform.hxx"