ITK  5.0.0
Insight Segmentation and Registration Toolkit
Public Types | Public Member Functions | Static Public Attributes | Protected Types | Protected Member Functions | Protected Attributes | Private Attributes | List of all members
itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType > Class Template Referenceabstract

#include <itkPointSetToPointSetMetricv4.h>

+ Inheritance diagram for itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >:
+ Collaboration diagram for itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >:

Detailed Description

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
class itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >

Computes similarity between two point sets.

This class is templated over the type of the two point-sets. It expects a Transform to be plugged in for each of fixed and moving point sets. The transforms default to IdenityTransform types. This particular class is the base class for a hierarchy of point-set to point-set metrics.

This class computes a value that measures the similarity between the fixed point-set and the moving point-set in the moving domain. The fixed point set is transformed into the virtual domain by computing the inverse of the fixed transform, then transformed into the moving domain using the moving transform.

Since the PointSet class permits each Point to be associated with a PixelType, there are potential applications which could make use of this additional information. For example, the derived LabeledPointSetToPointSetMetric class uses the PixelType as a LabelType for estimating total metric values and gradients from the individual label-wise point subset metric and derivatives

If a virtual domain is not defined by the user, one of two things happens: 1) If the moving transform is a global type, then the virtual domain is left undefined and every point is considered to be within the virtual domain. 2) If the moving transform is a local-support type, then the virtual domain is taken during initialization from the moving transform displacement field, and all fixed points are verified to be within the virtual domain after transformation by the inverse fixed transform. Points outside the virtual domain are not used. See GetNumberOfValidPoints() to verify how many fixed points were used during evaluation.

See ObjectToObjectMetric documentation for more discussion on the virutal domain.

Note
When used with an RegistrationParameterScalesEstimator estimator, a VirtualDomainPointSet must be defined and assigned to the estimator, for use in shift estimation. The virtual domain point set can be retrieved from the metric using the GetVirtualTransformedPointSet() method.

Definition at line 71 of file itkPointSetToPointSetMetricv4.h.

Public Types

using ConstPointer = SmartPointer< const Self >
 
using CoordRepType = typename PointType::CoordRepType
 
using DerivativeType = typename Superclass::DerivativeType
 
using DerivativeValueType = typename DerivativeType::ValueType
 
using DimensionType = typename Superclass::DimensionType
 
using DisplacementFieldTransformType = typename Superclass::MovingDisplacementFieldTransformType
 
using FixedInputPointType = typename Superclass::FixedInputPointType
 
using FixedOutputPointType = typename Superclass::FixedOutputPointType
 
using FixedPixelType = typename TFixedPointSet::PixelType
 
using FixedPointsContainer = typename TFixedPointSet::PointsContainer
 
using FixedPointSetType = TFixedPointSet
 
using FixedPointType = typename TFixedPointSet::PointType
 
using FixedTransformedPointSetType = PointSet< FixedPixelType, Self::PointDimension >
 
using FixedTransformJacobianType = typename Superclass::FixedTransformJacobianType
 
using FixedTransformParametersType = typename Superclass::FixedTransformParametersType
 
using FixedTransformPointer = typename Superclass::FixedTransformPointer
 
using FixedTransformType = typename Superclass::FixedTransformType
 
using JacobianType = typename Superclass::JacobianType
 
using LocalDerivativeType = FixedArray< DerivativeValueType, Self::PointDimension >
 
using MeasureType = typename Superclass::MeasureType
 
using MovingInputPointType = typename Superclass::MovingInputPointType
 
using MovingOutputPointType = typename Superclass::MovingOutputPointType
 
using MovingPixelType = typename TMovingPointSet::PixelType
 
using MovingPointsContainer = typename TMovingPointSet::PointsContainer
 
using MovingPointSetType = TMovingPointSet
 
using MovingPointType = typename TMovingPointSet::PointType
 
using MovingTransformedPointSetType = PointSet< MovingPixelType, Self::PointDimension >
 
using MovingTransformJacobianType = typename Superclass::MovingTransformJacobianType
 
using MovingTransformParametersType = typename Superclass::MovingTransformParametersType
 
using MovingTransformPointer = typename Superclass::MovingTransformPointer
 
using MovingTransformType = typename Superclass::MovingTransformType
 
using NeighborsIdentifierType = typename PointsLocatorType::NeighborsIdentifierType
 
using NumberOfParametersType = typename Superclass::NumberOfParametersType
 
using ObjectType = typename Superclass::ObjectType
 
using ParametersType = typename Superclass::ParametersType
 
using ParametersValueType = typename Superclass::ParametersValueType
 
using PixelType = FixedPixelType
 
using Pointer = SmartPointer< Self >
 
using PointIdentifier = typename PointsContainer::ElementIdentifier
 
using PointsConstIterator = typename PointsContainer::ConstIterator
 
using PointsContainer = FixedPointsContainer
 
using PointsLocatorType = PointsLocator< PointsContainer >
 
using PointType = FixedPointType
 
using Self = PointSetToPointSetMetricv4
 
using Superclass = ObjectToObjectMetric< TFixedPointSet::PointDimension, TMovingPointSet::PointDimension, Image< TInternalComputationValueType, TFixedPointSet::PointDimension >, TInternalComputationValueType >
 
using VirtualDirectionType = typename Superclass::VirtualDirectionType
 
using VirtualImagePointer = typename Superclass::VirtualImagePointer
 
using VirtualImageType = typename Superclass::VirtualImageType
 
using VirtualIndexType = typename Superclass::VirtualIndexType
 
using VirtualOriginType = typename Superclass::VirtualPointType
 
using VirtualPixelType = typename Superclass::VirtualPixelType
 
using VirtualPointSetPointer = typename Superclass::VirtualPointSetPointer
 
using VirtualPointSetType = typename Superclass::VirtualPointSetType
 
using VirtualPointType = typename Superclass::VirtualPointType
 
using VirtualRadiusType = typename Superclass::VirtualSizeType
 
using VirtualRegionType = typename Superclass::VirtualRegionType
 
using VirtualSizeType = typename Superclass::VirtualSizeType
 
using VirtualSpacingType = typename Superclass::VirtualSpacingType
 
- Public Types inherited from itk::ObjectToObjectMetric< TFixedPointSet::PointDimension, TMovingPointSet::PointDimension, Image< TInternalComputationValueType, TFixedPointSet::PointDimension >, TInternalComputationValueType >
using ConstPointer = SmartPointer< const Self >
 
using CoordinateRepresentationType = TInternalComputationValueType
 
using DerivativeType = typename Superclass::DerivativeType
 
using DerivativeValueType = typename Superclass::DerivativeValueType
 
using DimensionType = SizeValueType
 
using FixedInputPointType = typename FixedTransformType::InputPointType
 
using FixedOutputPointType = typename FixedTransformType::OutputPointType
 
using FixedTransformJacobianType = typename FixedTransformType::JacobianType
 
using FixedTransformParametersType = typename FixedTransformType::ParametersType
 
using FixedTransformPointer = typename FixedTransformType::Pointer
 
using FixedTransformType = Transform< TInternalComputationValueType, Image< TInternalComputationValueType, TFixedPointSet::PointDimension >::ImageDimension, TFixedDimension >
 
using GradientSourceType = typename Superclass::GradientSourceType
 
using InternalComputationValueType = TInternalComputationValueType
 
using JacobianType = typename FixedTransformType::JacobianType
 
using MeasureType = typename Superclass::MeasureType
 
using MetricCategoryType = typename Superclass::MetricCategoryType
 
using MovingDisplacementFieldTransformType = DisplacementFieldTransform< CoordinateRepresentationType, Self::MovingDimension >
 
using MovingInputPointType = typename MovingTransformType::InputPointType
 
using MovingOutputPointType = typename MovingTransformType::OutputPointType
 
using MovingTransformJacobianType = typename MovingTransformType::JacobianType
 
using MovingTransformParametersType = typename MovingTransformType::ParametersType
 
using MovingTransformPointer = typename MovingTransformType::Pointer
 
using MovingTransformType = Transform< TInternalComputationValueType, Image< TInternalComputationValueType, TFixedPointSet::PointDimension >::ImageDimension, TMovingDimension >
 
using NumberOfParametersType = typename Superclass::NumberOfParametersType
 
using ObjectType = typename Superclass::Object
 
using ParametersType = typename Superclass::ParametersType
 
using Pointer = SmartPointer< Self >
 
using Self = ObjectToObjectMetric
 
using Superclass = ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >
 
using VirtualDirectionType = typename VirtualImageType::DirectionType
 
using VirtualImageConstPointer = typename VirtualImageType::ConstPointer
 
using VirtualImagePointer = typename VirtualImageType::Pointer
 
using VirtualImageType = Image< TInternalComputationValueType, TFixedPointSet::PointDimension >
 
using VirtualIndexType = typename VirtualImageType::IndexType
 
using VirtualOriginType = typename VirtualImageType::PointType
 
using VirtualPixelType = typename VirtualImageType::PixelType
 
using VirtualPointSetPointer = typename VirtualPointSetType::Pointer
 
using VirtualPointSetType = PointSet< VirtualPixelType, Self::VirtualDimension >
 
using VirtualPointType = typename VirtualImageType::PointType
 
using VirtualRadiusType = typename VirtualImageType::SizeType
 
using VirtualRegionType = typename VirtualImageType::RegionType
 
using VirtualSizeType = typename VirtualRegionType::SizeType
 
using VirtualSpacingType = typename VirtualImageType::SpacingType
 
- Public Types inherited from itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >
using ConstPointer = SmartPointer< const Self >
 
using CoordinateRepresentationType = TInternalComputationValueType
 
using DerivativeType = typename Superclass::DerivativeType
 
using DerivativeValueType = typename DerivativeType::ValueType
 
enum  GradientSourceType {
  GRADIENT_SOURCE_FIXED =0,
  GRADIENT_SOURCE_MOVING,
  GRADIENT_SOURCE_BOTH
}
 
using MeasureType = typename Superclass::MeasureType
 
enum  MetricCategoryType {
  UNKNOWN_METRIC = 0,
  OBJECT_METRIC = 1,
  IMAGE_METRIC = 2,
  POINT_SET_METRIC = 3,
  MULTI_METRIC = 4
}
 
using NumberOfParametersType = unsigned int
 
using ObjectConstPointer = typename ObjectType::ConstPointer
 
using ObjectType = Object
 
using ParametersType = typename Superclass::ParametersType
 
using ParametersValueType = TInternalComputationValueType
 
using Pointer = SmartPointer< Self >
 
using Self = ObjectToObjectMetricBaseTemplate
 
using Superclass = SingleValuedCostFunctionv4Template< TInternalComputationValueType >
 
- Public Types inherited from itk::SingleValuedCostFunctionv4Template< TInternalComputationValueType >
using ConstPointer = SmartPointer< const Self >
 
using DerivativeType = Array< TInternalComputationValueType >
 
using MeasureType = TInternalComputationValueType
 
using ParametersType = typename Superclass::ParametersType
 
using Pointer = SmartPointer< Self >
 
using Self = SingleValuedCostFunctionv4Template
 
using Superclass = CostFunctionTemplate< TInternalComputationValueType >
 
- Public Types inherited from itk::CostFunctionTemplate< TInternalComputationValueType >
using ConstPointer = SmartPointer< const Self >
 
using ParametersType = OptimizerParameters< TInternalComputationValueType >
 
using ParametersValueType = TInternalComputationValueType
 
using Pointer = SmartPointer< Self >
 
using Self = CostFunctionTemplate
 
using Superclass = Object
 
- Public Types inherited from itk::Object
using ConstPointer = SmartPointer< const Self >
 
using Pointer = SmartPointer< Self >
 
using Self = Object
 
using Superclass = LightObject
 
- Public Types inherited from itk::LightObject
using ConstPointer = SmartPointer< const Self >
 
using Pointer = SmartPointer< Self >
 
using Self = LightObject
 

Public Member Functions

void GetDerivative (DerivativeType &) const override
 
virtual const
FixedTransformedPointSetType
GetFixedTransformedPointSet () const
 
virtual LocalDerivativeType GetLocalNeighborhoodDerivative (const PointType &, const PixelType &pixel) const
 
virtual MeasureType GetLocalNeighborhoodValue (const PointType &, const PixelType &pixel) const =0
 
virtual void GetLocalNeighborhoodValueAndDerivative (const PointType &, MeasureType &, LocalDerivativeType &, const PixelType &pixel) const =0
 
virtual
FixedTransformedPointSetType
GetModifiableFixedTransformedPointSet ()
 
virtual
MovingTransformedPointSetType
GetModifiableMovingTransformedPointSet ()
 
virtual const
MovingTransformedPointSetType
GetMovingTransformedPointSet () const
 
virtual const char * GetNameOfClass () const
 
SizeValueType GetNumberOfComponents () const
 
MeasureType GetValue () const override
 
void GetValueAndDerivative (MeasureType &, DerivativeType &) const override
 
const VirtualPointSetTypeGetVirtualTransformedPointSet () const
 
void Initialize () override
 
bool SupportsArbitraryVirtualDomainSamples () const override
 
void SetFixedObject (const ObjectType *object) override
 
void SetMovingObject (const ObjectType *object) override
 
virtual void SetFixedPointSet (const FixedPointSetType *_arg)
 
virtual const FixedPointSetTypeGetFixedPointSet () const
 
virtual void SetMovingPointSet (const MovingPointSetType *_arg)
 
virtual const MovingPointSetTypeGetMovingPointSet () const
 
virtual void SetStoreDerivativeAsSparseFieldForLocalSupportTransforms (bool _arg)
 
virtual bool GetStoreDerivativeAsSparseFieldForLocalSupportTransforms () const
 
virtual void StoreDerivativeAsSparseFieldForLocalSupportTransformsOn ()
 
virtual void StoreDerivativeAsSparseFieldForLocalSupportTransformsOff ()
 
virtual void SetCalculateValueAndDerivativeInTangentSpace (bool _arg)
 
virtual bool GetCalculateValueAndDerivativeInTangentSpace () const
 
virtual void CalculateValueAndDerivativeInTangentSpaceOn ()
 
virtual void CalculateValueAndDerivativeInTangentSpaceOff ()
 
- Public Member Functions inherited from itk::ObjectToObjectMetric< TFixedPointSet::PointDimension, TMovingPointSet::PointDimension, Image< TInternalComputationValueType, TFixedPointSet::PointDimension >, TInternalComputationValueType >
OffsetValueType ComputeParameterOffsetFromVirtualIndex (const VirtualIndexType &index, const NumberOfParametersType &numberOfLocalParameters) const
 
OffsetValueType ComputeParameterOffsetFromVirtualPoint (const VirtualPointType &point, const NumberOfParametersType &numberOfLocalParameters) const
 
virtual const FixedTransformTypeGetFixedTransform () const
 
MetricCategoryType GetMetricCategory () const override
 
virtual FixedTransformTypeGetModifiableFixedTransform ()
 
virtual MovingTransformTypeGetModifiableMovingTransform ()
 
virtual VirtualImageTypeGetModifiableVirtualImage ()
 
virtual const MovingTransformTypeGetMovingTransform () const
 
NumberOfParametersType GetNumberOfLocalParameters () const override
 
NumberOfParametersType GetNumberOfParameters () const override
 
virtual SizeValueType GetNumberOfValidPoints () const
 
const ParametersTypeGetParameters () const override
 
const MovingTransformTypeGetTransform ()
 
VirtualDirectionType GetVirtualDirection () const
 
virtual const TimeStampGetVirtualDomainTimeStamp () const
 
virtual const VirtualImageTypeGetVirtualImage () const
 
VirtualOriginType GetVirtualOrigin () const
 
const VirtualRegionTypeGetVirtualRegion () const
 
VirtualSpacingType GetVirtualSpacing () const
 
bool HasLocalSupport () const override
 
void Initialize () override
 
virtual void SetFixedTransform (FixedTransformType *_arg)
 
virtual void SetMovingTransform (MovingTransformType *_arg)
 
void SetParameters (ParametersType &params) override
 
void SetTransform (MovingTransformType *transform)
 
void SetVirtualDomain (const VirtualSpacingType &spacing, const VirtualOriginType &origin, const VirtualDirectionType &direction, const VirtualRegionType &region)
 
void SetVirtualDomainFromImage (const VirtualImageType *virtualImage)
 
void UpdateTransformParameters (const DerivativeType &derivative, TInternalComputationValueTypefactor) override
 
bool IsInsideVirtualDomain (const VirtualPointType &point) const
 
bool IsInsideVirtualDomain (const VirtualIndexType &index) const
 
- Public Member Functions inherited from itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >
MeasureType GetCurrentValue () const
 
virtual GradientSourceType GetGradientSource () const
 
bool GetGradientSourceIncludesFixed () const
 
bool GetGradientSourceIncludesMoving () const
 
virtual void SetGradientSource (GradientSourceType _arg)
 
virtual const ObjectTypeGetFixedObject () const
 
virtual const ObjectTypeGetMovingObject () const
 
- Public Member Functions inherited from itk::SingleValuedCostFunctionv4Template< TInternalComputationValueType >
virtual void GetValueAndDerivative (MeasureType &value, DerivativeType &derivative) const =0
 
- Public Member Functions inherited from itk::Object
unsigned long AddObserver (const EventObject &event, Command *)
 
unsigned long AddObserver (const EventObject &event, Command *) const
 
LightObject::Pointer CreateAnother () const override
 
virtual void DebugOff () const
 
virtual void DebugOn () const
 
CommandGetCommand (unsigned long tag)
 
bool GetDebug () const
 
MetaDataDictionaryGetMetaDataDictionary ()
 
const MetaDataDictionaryGetMetaDataDictionary () const
 
virtual ModifiedTimeType GetMTime () const
 
virtual const TimeStampGetTimeStamp () const
 
bool HasObserver (const EventObject &event) const
 
void InvokeEvent (const EventObject &)
 
void InvokeEvent (const EventObject &) const
 
virtual void Modified () const
 
void Register () const override
 
void RemoveAllObservers ()
 
void RemoveObserver (unsigned long tag)
 
void SetDebug (bool debugFlag) const
 
void SetReferenceCount (int) override
 
void UnRegister () const noexceptoverride
 
void SetMetaDataDictionary (const MetaDataDictionary &rhs)
 
void SetMetaDataDictionary (MetaDataDictionary &&rrhs)
 
virtual void SetObjectName (std::string _arg)
 
virtual const std::string & GetObjectName () const
 
- Public Member Functions inherited from itk::LightObject
virtual void Delete ()
 
virtual int GetReferenceCount () const
 
 itkCloneMacro (Self)
 
void Print (std::ostream &os, Indent indent=0) const
 

Static Public Attributes

static constexpr DimensionType FixedPointDimension = Superclass::FixedDimension
 
static constexpr DimensionType MovingPointDimension = Superclass::MovingDimension
 
static constexpr DimensionType PointDimension = Superclass::FixedDimension
 
- Static Public Attributes inherited from itk::ObjectToObjectMetric< TFixedPointSet::PointDimension, TMovingPointSet::PointDimension, Image< TInternalComputationValueType, TFixedPointSet::PointDimension >, TInternalComputationValueType >
static constexpr DimensionType FixedDimension
 
static constexpr DimensionType MovingDimension
 
static constexpr DimensionType VirtualDimension
 

Protected Types

using MetricCategoryType = typename Superclass::MetricCategoryType
 

Protected Member Functions

virtual SizeValueType CalculateNumberOfValidFixedPoints () const
 
void CalculateValueAndDerivative (MeasureType &value, DerivativeType &derivative, bool calculateValue) const
 
MetricCategoryType GetMetricCategory () const override
 
virtual void InitializeForIteration () const
 
virtual void InitializePointSets () const
 
void InitializePointsLocators () const
 
 PointSetToPointSetMetricv4 ()
 
void PrintSelf (std::ostream &os, Indent indent) const override
 
void StorePointDerivative (const VirtualPointType &, const DerivativeType &, DerivativeType &) const
 
void TransformFixedAndCreateVirtualPointSet () const
 
void TransformMovingPointSet () const
 
 ~PointSetToPointSetMetricv4 () override=default
 
- Protected Member Functions inherited from itk::ObjectToObjectMetric< TFixedPointSet::PointDimension, TMovingPointSet::PointDimension, Image< TInternalComputationValueType, TFixedPointSet::PointDimension >, TInternalComputationValueType >
const
MovingDisplacementFieldTransformType
GetMovingDisplacementFieldTransform () const
 
 ObjectToObjectMetric ()
 
void PrintSelf (std::ostream &os, Indent indent) const override
 
bool TransformPhysicalPointToVirtualIndex (const VirtualPointType &, VirtualIndexType &) const
 
void TransformVirtualIndexToPhysicalPoint (const VirtualIndexType &, VirtualPointType &) const
 
virtual void VerifyDisplacementFieldSizeAndPhysicalSpace ()
 
bool VerifyNumberOfValidPoints (MeasureType &value, DerivativeType &derivative) const
 
 ~ObjectToObjectMetric () override=default
 
- Protected Member Functions inherited from itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >
 ObjectToObjectMetricBaseTemplate ()
 
 ~ObjectToObjectMetricBaseTemplate () override=default
 
- Protected Member Functions inherited from itk::SingleValuedCostFunctionv4Template< TInternalComputationValueType >
 SingleValuedCostFunctionv4Template ()=default
 
 ~SingleValuedCostFunctionv4Template () override=default
 
- Protected Member Functions inherited from itk::CostFunctionTemplate< TInternalComputationValueType >
 CostFunctionTemplate ()=default
 
 ~CostFunctionTemplate () override=default
 
- Protected Member Functions inherited from itk::Object
 Object ()
 
bool PrintObservers (std::ostream &os, Indent indent) const
 
virtual void SetTimeStamp (const TimeStamp &time)
 
 ~Object () override
 
- Protected Member Functions inherited from itk::LightObject
virtual LightObject::Pointer InternalClone () const
 
 LightObject ()
 
virtual void PrintHeader (std::ostream &os, Indent indent) const
 
virtual void PrintTrailer (std::ostream &os, Indent indent) const
 
virtual ~LightObject ()
 

Protected Attributes

bool m_CalculateValueAndDerivativeInTangentSpace
 
FixedPointSetType::ConstPointer m_FixedPointSet
 
FixedTransformedPointSetType::Pointer m_FixedTransformedPointSet
 
PointsLocatorType::Pointer m_FixedTransformedPointsLocator
 
MovingPointSetType::ConstPointer m_MovingPointSet
 
MovingTransformedPointSetType::Pointer m_MovingTransformedPointSet
 
PointsLocatorType::Pointer m_MovingTransformedPointsLocator
 
bool m_UsePointSetData
 
VirtualPointSetPointer m_VirtualTransformedPointSet
 
- Protected Attributes inherited from itk::ObjectToObjectMetric< TFixedPointSet::PointDimension, TMovingPointSet::PointDimension, Image< TInternalComputationValueType, TFixedPointSet::PointDimension >, TInternalComputationValueType >
FixedTransformPointer m_FixedTransform
 
MovingTransformPointer m_MovingTransform
 
SizeValueType m_NumberOfValidPoints
 
bool m_UserHasSetVirtualDomain
 
VirtualImagePointer m_VirtualImage
 
- Protected Attributes inherited from itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >
ObjectConstPointer m_FixedObject
 
GradientSourceType m_GradientSource
 
ObjectConstPointer m_MovingObject
 
MeasureType m_Value
 
- Protected Attributes inherited from itk::LightObject
std::atomic< int > m_ReferenceCount
 

Private Attributes

ModifiedTimeType m_FixedTransformedPointSetTime
 
bool m_FixedTransformPointLocatorsNeedInitialization
 
bool m_HaveWarnedAboutNumberOfValidPoints
 
ModifiedTimeType m_MovingTransformedPointSetTime
 
bool m_MovingTransformPointLocatorsNeedInitialization
 
bool m_StoreDerivativeAsSparseFieldForLocalSupportTransforms
 

Additional Inherited Members

- Static Public Member Functions inherited from itk::Object
static bool GetGlobalWarningDisplay ()
 
static void GlobalWarningDisplayOff ()
 
static void GlobalWarningDisplayOn ()
 
static Pointer New ()
 
static void SetGlobalWarningDisplay (bool flag)
 
- Static Public Member Functions inherited from itk::LightObject
static void BreakOnError ()
 
static Pointer New ()
 

Member Typedef Documentation

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::ConstPointer = SmartPointer<const Self>

Definition at line 85 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::CoordRepType = typename PointType::CoordRepType

Definition at line 151 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::DerivativeType = typename Superclass::DerivativeType

Type of the derivative.

Definition at line 99 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::DerivativeValueType = typename DerivativeType::ValueType

Definition at line 163 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::DimensionType = typename Superclass::DimensionType

Dimension type

Definition at line 123 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::DisplacementFieldTransformType = typename Superclass::MovingDisplacementFieldTransformType

Definition at line 118 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedInputPointType = typename Superclass::FixedInputPointType

Definition at line 104 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedOutputPointType = typename Superclass::FixedOutputPointType

Definition at line 105 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedPixelType = typename TFixedPointSet::PixelType

Definition at line 128 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedPointsContainer = typename TFixedPointSet::PointsContainer

Definition at line 129 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedPointSetType = TFixedPointSet

Type of the fixed point set.

Definition at line 126 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedPointType = typename TFixedPointSet::PointType

Definition at line 127 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedTransformedPointSetType = PointSet<FixedPixelType, Self::PointDimension >

Definition at line 160 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedTransformJacobianType = typename Superclass::FixedTransformJacobianType

Definition at line 115 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedTransformParametersType = typename Superclass::FixedTransformParametersType

Definition at line 106 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedTransformPointer = typename Superclass::FixedTransformPointer

Definition at line 103 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedTransformType = typename Superclass::FixedTransformType

Transform types from Superclass

Definition at line 102 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::JacobianType = typename Superclass::JacobianType

Definition at line 114 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::LocalDerivativeType = FixedArray<DerivativeValueType, Self::PointDimension >

Definition at line 164 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MeasureType = typename Superclass::MeasureType

Type of the measure.

Definition at line 91 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MetricCategoryType = typename Superclass::MetricCategoryType
protected

Definition at line 413 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingInputPointType = typename Superclass::MovingInputPointType

Definition at line 110 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingOutputPointType = typename Superclass::MovingOutputPointType

Definition at line 111 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingPixelType = typename TMovingPointSet::PixelType

Definition at line 136 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingPointsContainer = typename TMovingPointSet::PointsContainer

Definition at line 137 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingPointSetType = TMovingPointSet

Type of the moving point set.

Definition at line 134 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingPointType = typename TMovingPointSet::PointType

Definition at line 135 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingTransformedPointSetType = PointSet<MovingPixelType, Self::PointDimension >

Definition at line 161 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingTransformJacobianType = typename Superclass::MovingTransformJacobianType

Definition at line 116 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingTransformParametersType = typename Superclass::MovingTransformParametersType

Definition at line 112 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingTransformPointer = typename Superclass::MovingTransformPointer

Definition at line 109 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingTransformType = typename Superclass::MovingTransformType

Definition at line 108 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::NeighborsIdentifierType = typename PointsLocatorType::NeighborsIdentifierType

Definition at line 158 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::NumberOfParametersType = typename Superclass::NumberOfParametersType

Definition at line 96 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::ObjectType = typename Superclass::ObjectType

Definition at line 120 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::ParametersType = typename Superclass::ParametersType

Type of the parameters.

Definition at line 94 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::ParametersValueType = typename Superclass::ParametersValueType

Definition at line 95 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::PixelType = FixedPixelType

Definition at line 150 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::Pointer = SmartPointer<Self>

Definition at line 84 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::PointIdentifier = typename PointsContainer::ElementIdentifier

Definition at line 154 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::PointsConstIterator = typename PointsContainer::ConstIterator

Definition at line 153 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::PointsContainer = FixedPointsContainer

Definition at line 152 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::PointsLocatorType = PointsLocator< PointsContainer>

Typedef for points locator class to speed up finding neighboring points

Definition at line 157 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::PointType = FixedPointType

Definition at line 149 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::Self = PointSetToPointSetMetricv4

Standard class type aliases.

Definition at line 79 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::Superclass = ObjectToObjectMetric<TFixedPointSet::PointDimension, TMovingPointSet::PointDimension, Image<TInternalComputationValueType, TFixedPointSet::PointDimension>, TInternalComputationValueType>

Definition at line 83 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualDirectionType = typename Superclass::VirtualDirectionType

Definition at line 175 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualImagePointer = typename Superclass::VirtualImagePointer

Definition at line 168 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualImageType = typename Superclass::VirtualImageType

Types for the virtual domain

Definition at line 167 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualIndexType = typename Superclass::VirtualIndexType

Definition at line 177 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualOriginType = typename Superclass::VirtualPointType

Definition at line 173 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualPixelType = typename Superclass::VirtualPixelType

Definition at line 169 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualPointSetPointer = typename Superclass::VirtualPointSetPointer

Definition at line 179 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualPointSetType = typename Superclass::VirtualPointSetType

Definition at line 178 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualPointType = typename Superclass::VirtualPointType

Definition at line 174 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualRadiusType = typename Superclass::VirtualSizeType

Definition at line 176 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualRegionType = typename Superclass::VirtualRegionType

Definition at line 170 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualSizeType = typename Superclass::VirtualSizeType

Definition at line 171 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
using itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::VirtualSpacingType = typename Superclass::VirtualSpacingType

Definition at line 172 of file itkPointSetToPointSetMetricv4.h.

Constructor & Destructor Documentation

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::PointSetToPointSetMetricv4 ( )
protected
template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::~PointSetToPointSetMetricv4 ( )
overrideprotecteddefault

Member Function Documentation

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual SizeValueType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::CalculateNumberOfValidFixedPoints ( ) const
protectedvirtual

Determine the number of valid fixed points. A fixed point is valid if, when transformed into the virtual domain using the inverse of the FixedTransform, it is within the defined virtual domain bounds.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::CalculateValueAndDerivative ( MeasureType value,
DerivativeType derivative,
bool  calculateValue 
) const
protected

Helper method allows for code reuse while skipping the metric value calculation when appropriate

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::CalculateValueAndDerivativeInTangentSpaceOff ( )
virtual
template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::CalculateValueAndDerivativeInTangentSpaceOn ( )
virtual
template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual bool itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetCalculateValueAndDerivativeInTangentSpace ( ) const
virtual
template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetDerivative ( DerivativeType ) const
overridevirtual

This method returns the derivative based on the current transformation(s). This function can be redefined in derived classes but many point set metrics follow the same structure—one iterates through the points and, for each point a derivative is calculated. The set of all these local derivatives constitutes the total derivative. Note that this might not be applicable to all point set metrics. For those cases, the developer will have to redefine the GetDerivative() function.

Implements itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual const FixedPointSetType* itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetFixedPointSet ( ) const
virtual

Get/Set the fixed pointset.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual const FixedTransformedPointSetType* itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetFixedTransformedPointSet ( ) const
virtual
template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual LocalDerivativeType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetLocalNeighborhoodDerivative ( const PointType ,
const PixelType pixel 
) const
virtual

Calculates the local derivative for a single point. The PixelType may or may not be used. See class description for further explanation.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual MeasureType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetLocalNeighborhoodValue ( const PointType ,
const PixelType pixel 
) const
pure virtual

Function to be defined in the appropriate derived classes. Calculates the local metric value for a single point. The PixelType may or may not be used. See class description for further explanation.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetLocalNeighborhoodValueAndDerivative ( const PointType ,
MeasureType ,
LocalDerivativeType ,
const PixelType pixel 
) const
pure virtual

Calculates the local value/derivative for a single point. The PixelType may or may not be used. See class description for further explanation.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
MetricCategoryType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetMetricCategory ( ) const
inlineoverrideprotectedvirtual

Get metric category

Reimplemented from itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >.

Definition at line 416 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual FixedTransformedPointSetType* itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetModifiableFixedTransformedPointSet ( )
virtual

Get the fixed transformed point set.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual MovingTransformedPointSetType* itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetModifiableMovingTransformedPointSet ( )
virtual

Get the moving transformed point set.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual const MovingPointSetType* itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetMovingPointSet ( ) const
virtual

Get/Set the moving point set.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual const MovingTransformedPointSetType* itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetMovingTransformedPointSet ( ) const
virtual
template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual const char* itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetNameOfClass ( ) const
virtual
template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
SizeValueType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetNumberOfComponents ( ) const

For now return the number of points used in the value/derivative calculations.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual bool itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetStoreDerivativeAsSparseFieldForLocalSupportTransforms ( ) const
virtual

By default, the point set metric derivative for a displacement field transform is stored by saving the gradient for every voxel in the displacement field (see the function StorePointDerivative()). Since the "fixed points" will typically constitute a sparse set, this means that the field will have zero gradient values at every voxel that doesn't have a corresponding point. This might cause additional computation time for certain transforms (e.g. B-spline SyN). To avoid this, this option permits storing the point derivative only at the fixed point locations. If this variable is set to false, then the derivative array will be of length = PointDimension * m_FixedPointSet->GetNumberOfPoints().

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
MeasureType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetValue ( ) const
overridevirtual

This method returns the value of the metric based on the current transformation(s). This function can be redefined in derived classes but many point set metrics follow the same structure—one iterates through the points and, for each point a metric value is calculated. The summation of these individual point metric values gives the total value of the metric. Note that this might not be applicable to all point set metrics. For those cases, the developer will have to redefine the GetValue() function.

Implements itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetValueAndDerivative ( MeasureType ,
DerivativeType  
) const
overridevirtual

This method returns the derivative and value based on the current transformation(s). This function can be redefined in derived classes but many point set metrics follow the same structure—one iterates through the points and, for each point a derivative and value is calculated. The set of all these local derivatives/values constitutes the total derivative and value. Note that this might not be applicable to all point set metrics. For those cases, the developer will have to redefine the GetValue() and GetDerivative() functions.

Implements itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
const VirtualPointSetType* itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::GetVirtualTransformedPointSet ( ) const

Get the virtual point set, derived from the fixed point set. If the virtual point set has not yet been derived, it will be in this call.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::Initialize ( )
overridevirtual

Initialize the metric by making sure that all the components are present and plugged together correctly.

Implements itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::InitializeForIteration ( ) const
protectedvirtual

Initialize to prepare for a particular iteration, generally an iteration of optimization. Distinct from Initialize() which is a one-time initialization.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::InitializePointSets ( ) const
protectedvirtual

Prepare point sets for use.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::InitializePointsLocators ( ) const
protected

Build point locators for the fixed and moving point sets to speed up derivative and value calculations.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::PrintSelf ( std::ostream &  os,
Indent  indent 
) const
overrideprotectedvirtual

Methods invoked by Print() to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.

Reimplemented from itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::SetCalculateValueAndDerivativeInTangentSpace ( bool  _arg)
virtual
template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::SetFixedObject ( const ObjectType object)
inlineoverridevirtual

Set fixed point set

Reimplemented from itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >.

Definition at line 182 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::SetFixedPointSet ( const FixedPointSetType _arg)
virtual

Get/Set the fixed pointset.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::SetMovingObject ( const ObjectType object)
inlineoverridevirtual

Set moving point set

Reimplemented from itk::ObjectToObjectMetricBaseTemplate< TInternalComputationValueType >.

Definition at line 197 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::SetMovingPointSet ( const MovingPointSetType _arg)
virtual

Get/Set the moving point set.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::SetStoreDerivativeAsSparseFieldForLocalSupportTransforms ( bool  _arg)
virtual

By default, the point set metric derivative for a displacement field transform is stored by saving the gradient for every voxel in the displacement field (see the function StorePointDerivative()). Since the "fixed points" will typically constitute a sparse set, this means that the field will have zero gradient values at every voxel that doesn't have a corresponding point. This might cause additional computation time for certain transforms (e.g. B-spline SyN). To avoid this, this option permits storing the point derivative only at the fixed point locations. If this variable is set to false, then the derivative array will be of length = PointDimension * m_FixedPointSet->GetNumberOfPoints().

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::StoreDerivativeAsSparseFieldForLocalSupportTransformsOff ( )
virtual

By default, the point set metric derivative for a displacement field transform is stored by saving the gradient for every voxel in the displacement field (see the function StorePointDerivative()). Since the "fixed points" will typically constitute a sparse set, this means that the field will have zero gradient values at every voxel that doesn't have a corresponding point. This might cause additional computation time for certain transforms (e.g. B-spline SyN). To avoid this, this option permits storing the point derivative only at the fixed point locations. If this variable is set to false, then the derivative array will be of length = PointDimension * m_FixedPointSet->GetNumberOfPoints().

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
virtual void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::StoreDerivativeAsSparseFieldForLocalSupportTransformsOn ( )
virtual

By default, the point set metric derivative for a displacement field transform is stored by saving the gradient for every voxel in the displacement field (see the function StorePointDerivative()). Since the "fixed points" will typically constitute a sparse set, this means that the field will have zero gradient values at every voxel that doesn't have a corresponding point. This might cause additional computation time for certain transforms (e.g. B-spline SyN). To avoid this, this option permits storing the point derivative only at the fixed point locations. If this variable is set to false, then the derivative array will be of length = PointDimension * m_FixedPointSet->GetNumberOfPoints().

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::StorePointDerivative ( const VirtualPointType ,
const DerivativeType ,
DerivativeType  
) const
protected

Store a derivative from a single point in a field. Only relevant when active transform has local support.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
bool itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::SupportsArbitraryVirtualDomainSamples ( ) const
inlineoverridevirtual

Returns a flag. True if arbitrary virtual domain points will always correspond to data points. False if not. For example, point-set metrics return false because only some virtual domain points will correspond to points within the point sets.

Implements itk::ObjectToObjectMetric< TFixedPointSet::PointDimension, TMovingPointSet::PointDimension, Image< TInternalComputationValueType, TFixedPointSet::PointDimension >, TInternalComputationValueType >.

Definition at line 300 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::TransformFixedAndCreateVirtualPointSet ( ) const
protected

Warp the fixed point set into the moving domain based on the fixed transform, passing through the virtual domain and storing a virtual domain set. Note that the warped moving point set is of type FixedPointSetType since the transform takes the points from the fixed to the moving domain.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
void itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::TransformMovingPointSet ( ) const
protected

Warp the moving point set based on the moving transform. Note that the warped moving point set is of type FixedPointSetType since the transform takes the points from the moving to the fixed domain. FIXME: needs update.

Member Data Documentation

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
constexpr DimensionType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::FixedPointDimension = Superclass::FixedDimension
static

Definition at line 131 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
bool itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_CalculateValueAndDerivativeInTangentSpace
protected

Flag to calculate value and/or derivative at tangent space. This is needed for the diffeomorphic registration methods. The fixed and moving points are warped to the virtual domain where the metric is calculated. Derived point set metrics might have associated gradient information which will need to be warped if this flag is true. Default = false.

Definition at line 362 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
FixedPointSetType::ConstPointer itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_FixedPointSet
protected

Definition at line 336 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
FixedTransformedPointSetType::Pointer itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_FixedTransformedPointSet
mutableprotected

Definition at line 337 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
ModifiedTimeType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_FixedTransformedPointSetTime
mutableprivate

Definition at line 435 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
PointsLocatorType::Pointer itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_FixedTransformedPointsLocator
mutableprotected

Definition at line 339 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
bool itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_FixedTransformPointLocatorsNeedInitialization
mutableprivate

Definition at line 424 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
bool itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_HaveWarnedAboutNumberOfValidPoints
mutableprivate

Definition at line 428 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
MovingPointSetType::ConstPointer itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_MovingPointSet
protected

Definition at line 341 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
MovingTransformedPointSetType::Pointer itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_MovingTransformedPointSet
mutableprotected

Definition at line 342 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
ModifiedTimeType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_MovingTransformedPointSetTime
mutableprivate

Definition at line 434 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
PointsLocatorType::Pointer itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_MovingTransformedPointsLocator
mutableprotected

Definition at line 344 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
bool itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_MovingTransformPointLocatorsNeedInitialization
mutableprivate

Definition at line 423 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
bool itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_StoreDerivativeAsSparseFieldForLocalSupportTransforms
private

Definition at line 432 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
bool itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_UsePointSetData
protected

Bool set by derived classes on whether the point set data (i.e. PixelType) should be used. Default = false.

Definition at line 353 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
VirtualPointSetPointer itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::m_VirtualTransformedPointSet
mutableprotected

Holds the fixed points after transformation into virtual domain.

Definition at line 347 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
constexpr DimensionType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::MovingPointDimension = Superclass::MovingDimension
static

Definition at line 139 of file itkPointSetToPointSetMetricv4.h.

template<typename TFixedPointSet, typename TMovingPointSet, class TInternalComputationValueType = double>
constexpr DimensionType itk::PointSetToPointSetMetricv4< TFixedPointSet, TMovingPointSet, TInternalComputationValueType >::PointDimension = Superclass::FixedDimension
static

typedefs for the data types used in the point set metric calculations. It is assumed that the constants of the fixed point set, such as the point dimension, are the same for the "common space" in which the metric calculation occurs.

Definition at line 147 of file itkPointSetToPointSetMetricv4.h.


The documentation for this class was generated from the following file: