ITK
6.0.0
Insight Toolkit
|
#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.
Reference: "A Method for Registration of 3-D Shapes", IEEE PAMI, Vol 14, No. 2, February 1992
Definition at line 47 of file itkEuclideanDistancePointMetric.h.
Public Member Functions | |
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 () |
Public Member Functions inherited from itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet > | |
virtual TransformType * | GetModifiableTransform () |
const char * | GetNameOfClass () const override |
unsigned int | GetNumberOfParameters () const override |
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 |
Public Member Functions inherited from itk::MultipleValuedCostFunction | |
virtual void | GetDerivative (const ParametersType ¶meters, DerivativeType &derivative) const =0 |
virtual MeasureType | GetValue (const ParametersType ¶meters) const =0 |
Public Member Functions inherited from itk::Object | |
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 |
Public Member Functions inherited from itk::LightObject | |
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 Public Member Functions inherited from itk::Object | |
static bool | GetGlobalWarningDisplay () |
static void | GlobalWarningDisplayOff () |
static void | GlobalWarningDisplayOn () |
static Pointer | New () |
static void | SetGlobalWarningDisplay (bool val) |
Static Public Member Functions inherited from itk::LightObject | |
static void | BreakOnError () |
static Pointer | New () |
Protected Member Functions | |
EuclideanDistancePointMetric () | |
void | PrintSelf (std::ostream &os, Indent indent) const override |
~EuclideanDistancePointMetric () override=default | |
Protected Member Functions inherited from itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet > | |
PointSetToPointSetMetric () | |
void | PrintSelf (std::ostream &os, Indent indent) const override |
~PointSetToPointSetMetric () override=default | |
Protected Member Functions inherited from itk::MultipleValuedCostFunction | |
MultipleValuedCostFunction ()=default | |
~MultipleValuedCostFunction () override | |
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 &timeStamp) |
~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 () |
Private Attributes | |
bool | m_ComputeSquaredDistance { false } |
DistanceMapPointer | m_DistanceMap {} |
Additional Inherited Members | |
Static Public Attributes inherited from itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet > | |
static constexpr unsigned int | FixedPointSetDimension = TFixedPointSet::PointDimension |
static constexpr unsigned int | MovingPointSetDimension = TMovingPointSet::PointDimension |
Protected Attributes inherited from itk::PointSetToPointSetMetric< TFixedPointSet, TMovingPointSet > | |
FixedPointSetConstPointer | m_FixedPointSet {} |
MovingPointSetConstPointer | m_MovingPointSet {} |
TransformPointer | m_Transform {} |
Protected Attributes inherited from itk::LightObject | |
std::atomic< int > | m_ReferenceCount {} |
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::ConstPointer = SmartPointer<const Self> |
Definition at line 58 of file itkEuclideanDistancePointMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::DistanceMapPointer = typename DistanceMapType::ConstPointer |
Definition at line 86 of file itkEuclideanDistancePointMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::DistanceMapType = TDistanceMap |
Definition at line 85 of file itkEuclideanDistancePointMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::Pointer = SmartPointer<Self> |
Definition at line 57 of file itkEuclideanDistancePointMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::Self = EuclideanDistancePointMetric |
Standard class type aliases.
Definition at line 54 of file itkEuclideanDistancePointMetric.h.
using itk::EuclideanDistancePointMetric< TFixedPointSet, TMovingPointSet, TDistanceMap >::Superclass = PointSetToPointSetMetric<TFixedPointSet, TMovingPointSet> |
Definition at line 55 of file itkEuclideanDistancePointMetric.h.
|
protected |
|
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.
|
override |
Get the derivatives of the match measure.
|
virtual |
Set/Get the distance map.
|
overridevirtual |
Reimplemented from itk::MultipleValuedCostFunction.
|
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< TInternalComputationValueType >.
|
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 129 of file itkEuclideanDistancePointMetric.h.
|
private |
Definition at line 128 of file itkEuclideanDistancePointMetric.h.