Medical Imaging Interaction Toolkit
2016.11.0
Medical Imaging Interaction Toolkit
|
#include <mitkPointLocator.h>
Public Types | |
typedef int | IdType |
typedef ScalarType | DistanceType |
typedef float | PixelType |
typedef double | CoordRepType |
typedef itk::DefaultStaticMeshTraits< PixelType, 3, 2, CoordRepType, CoordRepType, PixelType > | MeshTraits |
typedef itk::PointSet< PixelType, 3, MeshTraits > | ITKPointSet |
Public Member Functions | |
mitkClassMacroItkParent (PointLocator, itk::Object) | |
Pointer | Clone () const |
void | SetPoints (vtkPointSet *points) |
void | SetPoints (mitk::PointSet *points) |
void | SetPoints (ITKPointSet *pointSet) |
IdType | FindClosestPoint (const double point[3]) |
IdType | FindClosestPoint (double x, double y, double z) |
IdType | FindClosestPoint (mitk::PointSet::PointType point) |
DistanceType | GetMinimalDistance (mitk::PointSet::PointType point) |
bool | FindClosestPointAndDistance (mitk::PointSet::PointType point, IdType *id, DistanceType *dist) |
Static Public Member Functions | |
static Pointer | New () |
Protected Types | |
typedef std::vector< IdType > | IdVectorType |
typedef double * | MyANNpoint |
typedef int | MyANNidx |
typedef double | MyANNdist |
typedef MyANNpoint * | MyANNpointArray |
typedef MyANNidx * | MyANNidxArray |
typedef MyANNdist * | MyANNdistArray |
Protected Member Functions | |
PointLocator () | |
~PointLocator () | |
void | InitANN () |
void | DestroyANN () |
IdType | FindClosestANNPoint (const MyANNpoint &point) |
DistanceType | GetMinimalDistance (const MyANNpoint &point) |
Protected Attributes | |
bool | m_SearchTreeInitialized |
IdVectorType | m_IndexToPointIdContainer |
vtkPoints * | m_VtkPoints |
mitk::PointSet * | m_MitkPoints |
ITKPointSet * | m_ItkPoints |
unsigned int | m_ANNK |
unsigned int | m_ANNDimension |
double | m_ANNEpsilon |
MyANNpointArray | m_ANNDataPoints |
MyANNpoint | m_ANNQueryPoint |
MyANNidxArray | m_ANNPointIndexes |
MyANNdistArray | m_ANNDistances |
ANNkd_tree * | m_ANNTree |
Convenience wrapper around ANN to provide fast nearest neighbour searches. Usage: set your points via SetPoints( vtkPointSet* Points ) or SetPoints(mitk::PointSet*). Then, you may query the closest point to an arbitrary coordinate by FindClosestPoint(). There is no further call to update etc. needed. Currently only calls for 1 nearest neighbour are supported. Feel free to add functions for K nearest neighbours. NOTE: At least 1 point must be contained in the point set.
Definition at line 43 of file mitkPointLocator.h.
typedef double mitk::PointLocator::CoordRepType |
Definition at line 54 of file mitkPointLocator.h.
Definition at line 51 of file mitkPointLocator.h.
typedef int mitk::PointLocator::IdType |
Definition at line 50 of file mitkPointLocator.h.
|
protected |
Definition at line 141 of file mitkPointLocator.h.
typedef itk::PointSet<PixelType, 3, MeshTraits> mitk::PointLocator::ITKPointSet |
Definition at line 56 of file mitkPointLocator.h.
typedef itk::DefaultStaticMeshTraits<PixelType, 3, 2, CoordRepType, CoordRepType, PixelType> mitk::PointLocator::MeshTraits |
Definition at line 55 of file mitkPointLocator.h.
|
protected |
Definition at line 151 of file mitkPointLocator.h.
|
protected |
Definition at line 154 of file mitkPointLocator.h.
|
protected |
Definition at line 150 of file mitkPointLocator.h.
|
protected |
Definition at line 153 of file mitkPointLocator.h.
|
protected |
Definition at line 149 of file mitkPointLocator.h.
|
protected |
Definition at line 152 of file mitkPointLocator.h.
typedef float mitk::PointLocator::PixelType |
Definition at line 53 of file mitkPointLocator.h.
|
protected |
constructor
Definition at line 21 of file mitkPointLocator.cpp.
|
protected |
destructor
Definition at line 37 of file mitkPointLocator.cpp.
Pointer mitk::PointLocator::Clone | ( | ) | const |
|
protected |
releases all memory occupied by the ann search tree and internal point set arrays
Definition at line 219 of file mitkPointLocator.cpp.
|
protected |
Finds the nearest neighbour in the point set previously defined by SetPoints(). The Id of the point is returned. Please note, that there is no case, in which no point is found, since as a precondition at least one point has to be contained in the point set.
point | the query point, for whom the nearest neighbour will be determined |
Definition at line 182 of file mitkPointLocator.cpp.
mitk::PointLocator::IdType mitk::PointLocator::FindClosestPoint | ( | const double | point[3] | ) |
Finds the nearest neighbour in the point set previously defined by SetPoints(). The Id of the point is returned. Please note, that there is no case, in which no point is found, since as a precondition at least one point has to be contained in the point set.
point | the query point, for whom the nearest neighbour will be determined |
Definition at line 158 of file mitkPointLocator.cpp.
mitk::PointLocator::IdType mitk::PointLocator::FindClosestPoint | ( | double | x, |
double | y, | ||
double | z | ||
) |
Finds the nearest neighbour in the point set previously defined by SetPoints(). The Id of the point is returned. Please note, that there is no case, in which no point is found, since as a precondition at least one point has to be contained in the point set.
x | the x coordinated of the query point, for whom the nearest neighbour will be determined |
y | the x coordinated of the query point, for whom the nearest neighbour will be determined |
z | the x coordinated of the query point, for whom the nearest neighbour will be determined |
Definition at line 166 of file mitkPointLocator.cpp.
mitk::PointLocator::IdType mitk::PointLocator::FindClosestPoint | ( | mitk::PointSet::PointType | point | ) |
Finds the nearest neighbour in the point set previously defined by SetPoints(). The Id of the point is returned. Please note, that there is no case, in which no point is found, since as a precondition at least one point has to be contained in the point set.
point | the query point, for whom the nearest neighbour will be determined |
Definition at line 174 of file mitkPointLocator.cpp.
bool mitk::PointLocator::FindClosestPointAndDistance | ( | mitk::PointSet::PointType | point, |
IdType * | id, | ||
DistanceType * | dist | ||
) |
Finds the nearest neighbour in the point set previously defined by SetPoints(). The Index and minimal distance between this point and the closest point of the point set is returned. Please note, that there is no case, in which no point is found, since as a precondition at least one point has to be contained in the point set.
point | the query point, for whom the minimal distance will be determined |
Definition at line 234 of file mitkPointLocator.cpp.
mitk::PointLocator::DistanceType mitk::PointLocator::GetMinimalDistance | ( | mitk::PointSet::PointType | point | ) |
Finds the nearest neighbour in the point set previously defined by SetPoints(). The minimal distance between this point and the closest point of the point set is returned. Please note, that there is no case, in which no point is found, since as a precondition at least one point has to be contained in the point set.
point | the query point, for whom the minimal distance will be determined |
Definition at line 190 of file mitkPointLocator.cpp.
|
protected |
Finds the minimal distance between the given point and a point in the previously defined point set. The distance is returned. Please note, that there is no case, in which no distance is found, since as a precondition at least one point has to be contained in the point set.
point | the query point, for whom the minimal distance to a point in the previously defined point set will be determined |
|
protected |
Initializes the ann search tree using previously defined points
Definition at line 206 of file mitkPointLocator.cpp.
mitk::PointLocator::mitkClassMacroItkParent | ( | PointLocator | , |
itk::Object | |||
) |
|
static |
void mitk::PointLocator::SetPoints | ( | vtkPointSet * | points | ) |
Sets the point which will be used for nearest-neighbour searches. Note there must be at least one point in the point set.
points | the point set containing points for nearest neighbours searches. |
Definition at line 43 of file mitkPointLocator.cpp.
void mitk::PointLocator::SetPoints | ( | mitk::PointSet * | points | ) |
Sets the point which will be used for nearest-neighbour searches. Note there must be at least one point in the point set.
points | the point set containing points for nearest neighbours searches. |
Definition at line 78 of file mitkPointLocator.cpp.
References mitk::BaseData::GetMTime(), mitk::PointSet::GetPointSet(), and mitk::PointSet::GetSize().
void mitk::PointLocator::SetPoints | ( | ITKPointSet * | pointSet | ) |
Sets the point which will be used for nearest-neighbour searches. Note there must be at least one point in the point set.
pointSet | the point set containing points for nearest neighbours searches. |
Definition at line 118 of file mitkPointLocator.cpp.
|
protected |
Definition at line 212 of file mitkPointLocator.h.
|
protected |
Definition at line 210 of file mitkPointLocator.h.
|
protected |
Definition at line 215 of file mitkPointLocator.h.
|
protected |
Definition at line 211 of file mitkPointLocator.h.
|
protected |
Definition at line 209 of file mitkPointLocator.h.
|
protected |
Definition at line 214 of file mitkPointLocator.h.
|
protected |
Definition at line 213 of file mitkPointLocator.h.
|
protected |
Definition at line 216 of file mitkPointLocator.h.
|
protected |
Definition at line 200 of file mitkPointLocator.h.
|
protected |
Definition at line 204 of file mitkPointLocator.h.
|
protected |
Definition at line 203 of file mitkPointLocator.h.
|
protected |
Definition at line 198 of file mitkPointLocator.h.
|
protected |
Definition at line 202 of file mitkPointLocator.h.