Visual Servoing Platform  version 3.3.0 under development (2020-02-17)

#include <visp3/vision/vpBasicKeyPoint.h>

+ Inheritance diagram for vpBasicKeyPoint:

Public Member Functions

 vpBasicKeyPoint ()
 
virtual ~vpBasicKeyPoint ()
 
virtual unsigned int buildReference (const vpImage< unsigned char > &I)=0
 
virtual unsigned int buildReference (const vpImage< unsigned char > &I, const vpImagePoint &iP, unsigned int height, unsigned int width)=0
 
virtual unsigned int buildReference (const vpImage< unsigned char > &I, const vpRect &rectangle)=0
 
virtual unsigned int matchPoint (const vpImage< unsigned char > &I)=0
 
virtual unsigned int matchPoint (const vpImage< unsigned char > &I, const vpImagePoint &iP, unsigned int height, unsigned int width)=0
 
virtual unsigned int matchPoint (const vpImage< unsigned char > &I, const vpRect &rectangle)=0
 
virtual void display (const vpImage< unsigned char > &Iref, const vpImage< unsigned char > &Icurrent, unsigned int size=3)=0
 
virtual void display (const vpImage< unsigned char > &Icurrent, unsigned int size=3, const vpColor &color=vpColor::green)=0
 
bool referenceBuilt () const
 
const vpImagePointgetAllPointsInReferenceImage ()
 
void getReferencePoint (unsigned int index, vpImagePoint &referencePoint)
 
void getMatchedPoints (unsigned int index, vpImagePoint &referencePoint, vpImagePoint &currentPoint)
 
unsigned int getIndexInAllReferencePointList (unsigned int indexInMatchedPointList)
 
unsigned int getReferencePointNumber () const
 
unsigned int getMatchedPointNumber () const
 
const std::vector< vpImagePoint > & getReferenceImagePointsList () const
 
const std::vector< vpImagePoint > & getCurrentImagePointsList () const
 
const std::vector< unsigned int > & getMatchedReferencePoints () const
 

Protected Attributes

std::vector< vpImagePointreferenceImagePointsList
 
std::vector< vpImagePointcurrentImagePointsList
 
std::vector< unsigned int > matchedReferencePoints
 
bool _reference_computed
 

Detailed Description

class that defines what is a Keypoint. This class provides all the basic elements to implement classes which aims to match points from an image to another.

Definition at line 62 of file vpBasicKeyPoint.h.

Constructor & Destructor Documentation

◆ vpBasicKeyPoint()

vpBasicKeyPoint::vpBasicKeyPoint ( )

Basic constructor.

Definition at line 44 of file vpBasicKeyPoint.cpp.

◆ ~vpBasicKeyPoint()

virtual vpBasicKeyPoint::~vpBasicKeyPoint ( )
inlinevirtual

Definition at line 67 of file vpBasicKeyPoint.h.

References vpColor::green.

Member Function Documentation

◆ buildReference() [1/3]

virtual unsigned int vpBasicKeyPoint::buildReference ( const vpImage< unsigned char > &  I)
pure virtual

Implemented in vpKeyPoint.

◆ buildReference() [2/3]

virtual unsigned int vpBasicKeyPoint::buildReference ( const vpImage< unsigned char > &  I,
const vpImagePoint iP,
unsigned int  height,
unsigned int  width 
)
pure virtual

Implemented in vpKeyPoint.

◆ buildReference() [3/3]

virtual unsigned int vpBasicKeyPoint::buildReference ( const vpImage< unsigned char > &  I,
const vpRect rectangle 
)
pure virtual

Implemented in vpKeyPoint.

◆ display() [1/2]

virtual void vpBasicKeyPoint::display ( const vpImage< unsigned char > &  Iref,
const vpImage< unsigned char > &  Icurrent,
unsigned int  size = 3 
)
pure virtual

Implemented in vpKeyPoint.

◆ display() [2/2]

virtual void vpBasicKeyPoint::display ( const vpImage< unsigned char > &  Icurrent,
unsigned int  size = 3,
const vpColor color = vpColor::green 
)
pure virtual

Implemented in vpKeyPoint.

◆ getAllPointsInReferenceImage()

const vpImagePoint* vpBasicKeyPoint::getAllPointsInReferenceImage ( )
inline

Get the pointer to the complete list of reference points. The pointer is const. Thus the points can not be modified

Returns
The pointer to the complete list of reference points.

Definition at line 107 of file vpBasicKeyPoint.h.

◆ getCurrentImagePointsList()

const std::vector<vpImagePoint>& vpBasicKeyPoint::getCurrentImagePointsList ( ) const
inline

Return the vector of current image point.

Warning
Should not be modified.
Returns
Vector of the current image point.

Definition at line 212 of file vpBasicKeyPoint.h.

◆ getIndexInAllReferencePointList()

unsigned int vpBasicKeyPoint::getIndexInAllReferencePointList ( unsigned int  indexInMatchedPointList)
inline

Get the nth matched reference point index in the complete list of reference point.

In the code below referencePoint1 and referencePoint2 correspond to the same matched reference point.

vpKeyPointSurf surf;
//Here the code to compute the reference points and the current points.
vpImagePoint referencePoint1;
vpImagePoint currentPoint;
surf.getMatchedPoints(1, referencePoint1, currentPoint); //Get the first matched points
vpImagePoint referencePoint2;
const vpImagePoint* referencePointsList = surf.getAllPointsInReferenceImage();
// Get the first matched reference point index in the complete reference point list
int index = surf.getIndexInAllReferencePointList(1);
// Get the first matched reference point
referencePoint2 = referencePointsList[index];

Definition at line 173 of file vpBasicKeyPoint.h.

References vpException::fatalError, and vpTRACE.

◆ getMatchedPointNumber()

unsigned int vpBasicKeyPoint::getMatchedPointNumber ( ) const
inline

Get the number of matched points.

Returns
the number of matched points.

Definition at line 194 of file vpBasicKeyPoint.h.

◆ getMatchedPoints()

void vpBasicKeyPoint::getMatchedPoints ( unsigned int  index,
vpImagePoint referencePoint,
vpImagePoint currentPoint 
)
inline

Get the nth couple of reference point and current point which have been matched. These points are copied in the vpImagePoint instances given in argument.

Parameters
index: The index of the desired couple of reference point and current point . The index must be between 0 and the number of matched points - 1.
referencePoint: The coordinates of the desired reference point are copied here.
currentPoint: The coordinates of the desired current point are copied here.
Examples:
tutorial-matching-keypoint-homography.cpp, tutorial-matching-keypoint-SIFT.cpp, and tutorial-matching-keypoint.cpp.

Definition at line 138 of file vpBasicKeyPoint.h.

References vpException::fatalError, vpImagePoint::set_ij(), and vpTRACE.

◆ getMatchedReferencePoints()

const std::vector<unsigned int>& vpBasicKeyPoint::getMatchedReferencePoints ( ) const
inline

Return the index of the matched associated to the current image point i. The ith element of the vector is the index of the reference image point matching with the current image point.

Warning
Should not be modified.
Returns
The vector of matching index.

Definition at line 223 of file vpBasicKeyPoint.h.

◆ getReferenceImagePointsList()

const std::vector<vpImagePoint>& vpBasicKeyPoint::getReferenceImagePointsList ( ) const
inline

Return the vector of reference image point.

Warning
Should not be modified.
Returns
Vector of reference image point.

Definition at line 203 of file vpBasicKeyPoint.h.

◆ getReferencePoint()

void vpBasicKeyPoint::getReferencePoint ( unsigned int  index,
vpImagePoint referencePoint 
)
inline

Get the nth reference point. This point is copied in the vpImagePoint instance given in argument.

Parameters
index: The index of the desired reference point. The index must be between 0 and the number of reference points - 1.
referencePoint: The coordinates of the desired reference point are copied there.

Definition at line 117 of file vpBasicKeyPoint.h.

References vpException::fatalError, vpImagePoint::set_ij(), and vpTRACE.

◆ getReferencePointNumber()

unsigned int vpBasicKeyPoint::getReferencePointNumber ( ) const
inline

Get the number of reference points.

Returns
the number of reference points.

Definition at line 187 of file vpBasicKeyPoint.h.

◆ matchPoint() [1/3]

virtual unsigned int vpBasicKeyPoint::matchPoint ( const vpImage< unsigned char > &  I)
pure virtual

Implemented in vpKeyPoint.

Referenced by vpKeyPoint::getTrainDescriptors().

◆ matchPoint() [2/3]

virtual unsigned int vpBasicKeyPoint::matchPoint ( const vpImage< unsigned char > &  I,
const vpImagePoint iP,
unsigned int  height,
unsigned int  width 
)
pure virtual

Implemented in vpKeyPoint.

◆ matchPoint() [3/3]

virtual unsigned int vpBasicKeyPoint::matchPoint ( const vpImage< unsigned char > &  I,
const vpRect rectangle 
)
pure virtual

Implemented in vpKeyPoint.

◆ referenceBuilt()

bool vpBasicKeyPoint::referenceBuilt ( ) const
inline

Indicate wether the reference has been built or not.

Returns
True if the reference of the current instance has been built.

Definition at line 99 of file vpBasicKeyPoint.h.

Member Data Documentation

◆ _reference_computed

bool vpBasicKeyPoint::_reference_computed
protected

flag to indicate if the reference has been built.

Definition at line 251 of file vpBasicKeyPoint.h.

Referenced by vpKeyPoint::buildReference(), vpKeyPoint::loadLearningData(), vpKeyPoint::matchPoint(), and vpKeyPoint::reset().

◆ currentImagePointsList

std::vector<vpImagePoint> vpBasicKeyPoint::currentImagePointsList
protected

List of the points which belong to the current image and have been matched with points belonging to the reference.

Definition at line 238 of file vpBasicKeyPoint.h.

Referenced by vpKeyPoint::getQueryKeyPoints(), vpKeyPoint::matchPoint(), and vpKeyPoint::reset().

◆ matchedReferencePoints

std::vector<unsigned int> vpBasicKeyPoint::matchedReferencePoints
protected

Array containing the index in the array "referenceImagePointsList" of the reference points which have been matched.

The first element of the "currentImagePointsList" array is matched with the nth element of the "referenceImagePointsList" array. The value of n is stored in the first element of the "matchedReferencePoints" array.

Definition at line 248 of file vpBasicKeyPoint.h.

Referenced by vpKeyPoint::matchPoint(), and vpKeyPoint::reset().

◆ referenceImagePointsList

std::vector<vpImagePoint> vpBasicKeyPoint::referenceImagePointsList
protected

List of the points which define the reference.

Definition at line 232 of file vpBasicKeyPoint.h.

Referenced by vpKeyPoint::buildReference(), vpKeyPoint::getTrainKeyPoints(), vpKeyPoint::loadLearningData(), and vpKeyPoint::reset().