#include <itkEuclideanDistancePointMetric.h>
Computes the minimum distance between a moving point-set and a fixed point-set. A vector of minimum closest point distance is created for each point in the moving point-set. No correspondence is needed. For speed consideration, the point-set with the minimum number of points should be used as the moving point-set. If the number of points is high, the possibility of setting a distance map should improve the speed of the closest point computation.
For more details see [11].
Definition at line 46 of file itkEuclideanDistancePointMetric.h.
Public Member Functions | |
virtual::itk::LightObject::Pointer | CreateAnother () const |
void | GetDerivative (const TransformParametersType ¶meters, DerivativeType &derivative) const override |
const char * | GetNameOfClass () const override |
unsigned int | GetNumberOfValues () const override |
MeasureType | GetValue (const TransformParametersType ¶meters) const override |
void | GetValueAndDerivative (const TransformParametersType ¶meters, MeasureType &value, DerivativeType &derivative) const |
virtual void | SetDistanceMap (const DistanceMapType *_arg) |
virtual const DistanceMapType * | GetDistanceMap () const |
virtual void | SetComputeSquaredDistance (bool _arg) |
virtual bool | GetComputeSquaredDistance () const |
virtual void | ComputeSquaredDistanceOn () |
virtual void | ComputeSquaredDistanceOff () |
![]() | |
virtual TransformType * | GetModifiableTransform () |
const char * | GetNameOfClass () const override |
unsigned int | GetNumberOfParameters () const override |
virtual const TransformType * | GetTransform () const |
virtual void | Initialize () |
virtual void | SetTransform (TransformType *_arg) |
void | SetTransformParameters (const ParametersType ¶meters) const |
virtual void | SetFixedPointSet (const FixedPointSetType *_arg) |
virtual const FixedPointSetType * | GetFixedPointSet () const |
virtual void | SetMovingPointSet (const MovingPointSetType *_arg) |
virtual const MovingPointSetType * | GetMovingPointSet () const |
![]() | |
virtual void | GetDerivative (const ParametersType ¶meters, DerivativeType &derivative) const =0 |
virtual MeasureType | GetValue (const ParametersType ¶meters) const =0 |
![]() | |
unsigned long | AddObserver (const EventObject &event, Command *cmd) const |
unsigned long | AddObserver (const EventObject &event, std::function< void(const EventObject &)> function) const |
LightObject::Pointer | CreateAnother () const override |
virtual void | DebugOff () const |
virtual void | DebugOn () const |
Command * | GetCommand (unsigned long tag) |
bool | GetDebug () const |
MetaDataDictionary & | GetMetaDataDictionary () |
const MetaDataDictionary & | GetMetaDataDictionary () const |
virtual ModifiedTimeType | GetMTime () const |
virtual const TimeStamp & | GetTimeStamp () 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) const |
void | SetDebug (bool debugFlag) const |
void | SetReferenceCount (int) override |
void | UnRegister () const noexcept override |
void | SetMetaDataDictionary (const MetaDataDictionary &rhs) |
void | SetMetaDataDictionary (MetaDataDictionary &&rrhs) |
virtual void | SetObjectName (std::string _arg) |
virtual const std::string & | GetObjectName () const |
![]() | |
Pointer | Clone () const |
virtual void | Delete () |
virtual int | GetReferenceCount () const |
void | Print (std::ostream &os, Indent indent=0) const |
Static Public Member Functions | |
static Pointer | New () |
![]() | |
static bool | GetGlobalWarningDisplay () |
static void | GlobalWarningDisplayOff () |
static void | GlobalWarningDisplayOn () |
static Pointer | New () |
static void | SetGlobalWarningDisplay (bool val) |
![]() | |
static void | BreakOnError () |
static Pointer | New () |
Protected Member Functions | |
EuclideanDistancePointMetric () | |
void | PrintSelf (std::ostream &os, Indent indent) const override |
~EuclideanDistancePointMetric () override=default | |
![]() | |
PointSetToPointSetMetric () | |
void | PrintSelf (std::ostream &os, Indent indent) const override |
~PointSetToPointSetMetric () override=default | |
![]() | |
MultipleValuedCostFunction ()=default | |
~MultipleValuedCostFunction () override | |
![]() | |
CostFunctionTemplate ()=default | |
CostFunctionTemplate ()=default | |
~CostFunctionTemplate () override=default | |
~CostFunctionTemplate () override=default | |
![]() | |
Object () | |
bool | PrintObservers (std::ostream &os, Indent indent) const |
virtual void | SetTimeStamp (const TimeStamp &timeStamp) |
~Object () override | |
![]() | |
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 () |
Private Attributes | |
bool | m_ComputeSquaredDistance { false } |
DistanceMapPointer | m_DistanceMap {} |
Additional Inherited Members | |
![]() | |
static constexpr unsigned int | FixedPointSetDimension = TFixedPointSet::PointDimension |
static constexpr unsigned int | MovingPointSetDimension = TMovingPointSet::PointDimension |
![]() | |
FixedPointSetConstPointer | m_FixedPointSet {} |
MovingPointSetConstPointer | m_MovingPointSet {} |
TransformPointer | m_Transform {} |
![]() | |
std::atomic< int > | m_ReferenceCount {} |
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::ConstPointer = SmartPointer<const Self> |
Definition at line 57 of file itkEuclideanDistancePointMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::DerivativeType |
Type of the derivative.
Definition at line 95 of file itkPointSetToPointSetMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::DistanceMapPointer = typename DistanceMapType::ConstPointer |
Definition at line 85 of file itkEuclideanDistancePointMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::DistanceMapType = TDistanceMap |
Definition at line 84 of file itkEuclideanDistancePointMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::FixedPointDataIterator |
Definition at line 76 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::FixedPointIterator |
Definition at line 75 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::FixedPointSetConstPointer |
Definition at line 69 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::FixedPointSetType |
Type of the fixed Pointset.
Definition at line 68 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::MeasureType |
Type of the measure.
Definition at line 92 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::MovingPointDataIterator |
Definition at line 79 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::MovingPointIterator |
Definition at line 78 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::MovingPointSetConstPointer |
Definition at line 65 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::MovingPointSetType |
Type of the moving Pointset.
Definition at line 63 of file itkPointSetToPointSetMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::Pointer = SmartPointer<Self> |
Definition at line 56 of file itkEuclideanDistancePointMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::Self = EuclideanDistancePointMetric |
Standard class type aliases.
Definition at line 53 of file itkEuclideanDistancePointMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::Superclass = PointSetToPointSetMetric<TFixedPointSet, TMovingPointSet> |
Definition at line 54 of file itkEuclideanDistancePointMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::TransformJacobianType |
Definition at line 89 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::TransformParametersType |
Definition at line 88 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::TransformPointer |
Definition at line 85 of file itkPointSetToPointSetMetric.h.
using itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet >::TransformType |
Type of the Transform Base class
Definition at line 82 of file itkPointSetToPointSetMetric.h.
|
protected |
Referenced by GetNameOfClass().
|
overrideprotecteddefault |
|
virtual |
Set/Get if the distance should be squared. When set to true, the filter's computational speed is substantially improved (by avoiding numerous sqrt() calls), but it will result in minimizing the sum of distances^4 instead of the sum of distances^2. Default is false.
|
virtual |
Set/Get if the distance should be squared. When set to true, the filter's computational speed is substantially improved (by avoiding numerous sqrt() calls), but it will result in minimizing the sum of distances^4 instead of the sum of distances^2. Default is false.
|
virtual |
Create an object from an instance, potentially deferring to a factory. This method allows you to create an instance of an object that is exactly the same type as the referring object. This is useful in cases where an object has been cast back to a base class.
Reimplemented from itk::LightObject.
|
virtual |
Set/Get if the distance should be squared. When set to true, the filter's computational speed is substantially improved (by avoiding numerous sqrt() calls), but it will result in minimizing the sum of distances^4 instead of the sum of distances^2. Default is false.
|
inlineoverride |
Get the derivatives of the match measure.
Definition at line 93 of file itkEuclideanDistancePointMetric.h.
|
virtual |
Set/Get the distance map.
|
overridevirtual |
Reimplemented from itk::CostFunctionTemplate< double >.
References EuclideanDistancePointMetric().
|
overridevirtual |
Get the number of values, i.e. the number of points in the moving set.
Implements itk::MultipleValuedCostFunction.
|
override |
Get the match measure, i.e. the value for single valued optimizers.
void itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::GetValueAndDerivative | ( | const TransformParametersType & | parameters, |
MeasureType & | value, | ||
DerivativeType & | derivative ) const |
Get value and derivatives for multiple valued optimizers.
|
static |
Method for creation through the object factory.
|
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::CostFunctionTemplate< double >.
|
virtual |
Set/Get if the distance should be squared. When set to true, the filter's computational speed is substantially improved (by avoiding numerous sqrt() calls), but it will result in minimizing the sum of distances^4 instead of the sum of distances^2. Default is false.
|
virtual |
Set/Get the distance map.
|
private |
Definition at line 130 of file itkEuclideanDistancePointMetric.h.
|
private |
Definition at line 129 of file itkEuclideanDistancePointMetric.h.