ViSP  2.8.0
vpPlane Class Reference

#include <vpPlane.h>

Public Member Functions

 vpPlane ()
 
 vpPlane (const vpPlane &P)
 
 vpPlane (const double A, const double B, const double C, const double D)
 
 vpPlane (const vpPoint &P, const vpColVector &n)
 
 vpPlane (const vpPoint &P, const vpPoint &Q, const vpPoint &R)
 
void init (const vpPoint &P, const vpPoint &Q, const vpPoint &R)
 
void init (const vpColVector &P, const vpColVector &n)
 
void init (const vpPlane &P)
 
void setA (const double A)
 
void setB (const double B)
 
void setC (const double C)
 
void setD (const double D)
 
void setABCD (const double A, const double B, const double C, const double D)
 
vpPlaneoperator= (const vpPlane &f)
 
double getA () const
 
double getB () const
 
double getC () const
 
double getD () const
 
vpColVector getABCD () const
 
vpColVector abcd () const
 
vpColVector getNormal () const
 
void getNormal (vpColVector &n) const
 
void projectionPointOnPlan (const vpPoint &P, vpPoint &Pproj) const
 
double rayIntersection (const vpPoint &M0, const vpPoint &M1, vpColVector &H) const
 
double getIntersection (const vpColVector &M1, vpColVector &H) const
 
void changeFrame (const vpHomogeneousMatrix &cMo)
 

Public Attributes

double A
 
double B
 
double C
 
double D
 

Friends

VISP_EXPORT std::ostream & operator<< (std::ostream &os, vpPlane &p)
 

Detailed Description

This class defines the container for a plane geometrical structure.

A plane is given by the equation $Ax + By + Cz + D = 0$ where (x,y,z) are the coordinates of a point and $[A,B,C]^T$ is normal vector of the plane.

Examples:
homographyHartleyDLT2DObject.cpp, homographyHLM2DObject.cpp, homographyHLM3DObject.cpp, homographyRansac2DObject.cpp, manServoMomentsSimple.cpp, servoMomentImage.cpp, servoMomentPoints.cpp, servoMomentPolygon.cpp, and testDisplacement.cpp.

Definition at line 67 of file vpPlane.h.

Constructor & Destructor Documentation

vpPlane::vpPlane ( )

Basic constructor that set the plane parameters A, B, C, D to zero.

Definition at line 71 of file vpPlane.cpp.

References setA(), setB(), setC(), and setD().

vpPlane::vpPlane ( const vpPlane P)

Copy constructor.

Definition at line 100 of file vpPlane.cpp.

References getA(), getB(), getC(), getD(), setA(), setB(), setC(), and setD().

vpPlane::vpPlane ( const double  A,
const double  B,
const double  C,
const double  D 
)

Plane constructor from A, B, C, D parameters.

A plane is given by the equation $Ax + By + Cz + D = 0$ where (x,y,z) are the coordinates of a point and $[A,B,C]^T$ is the normal vector of the plane.

Parameters
A,B,C,D: Parameters of the plane.

Definition at line 89 of file vpPlane.cpp.

References setA(), setB(), setC(), and setD().

vpPlane::vpPlane ( const vpPoint P,
const vpColVector n 
)

Plane constructor from a point P on the plane and the normal n to the plane.

A plane is given by the equation $Ax + By + Cz + D = 0$ where (x,y,z) are the coordinates of a point and $[A,B,C]^T$ is the normal vector of the plane.

Parameters
P: A point with coordinates (x,y,z) on the plane.
n: The normal to the plane.

Definition at line 122 of file vpPlane.cpp.

References A, B, C, D, vpPoint::get_X(), vpPoint::get_Y(), and vpPoint::get_Z().

vpPlane::vpPlane ( const vpPoint P,
const vpPoint Q,
const vpPoint R 
)

Compute the equation of a plane given three point P, Q, R.

The normal to the plane is given by n = PQ x PR

See also
init(const vpPoint &, const vpPoint &, const vpPoint &)

Definition at line 213 of file vpPlane.cpp.

References init().

Member Function Documentation

vpColVector vpPlane::abcd ( ) const
inline
Warning
This method is provided for compatibility with the previous versions. Users should now use getABCD().
Returns
Return the four dimension vector $[A,B,C,D]^T$ corresponding to the plane parameters.
See also
getABCD()

Definition at line 145 of file vpPlane.h.

void vpPlane::changeFrame ( const vpHomogeneousMatrix cMo)

Considering the plane in the Ro frame computes the equation of the plane in the Rc frame.

Parameters
cMo: Homogeneous transformation from Rc to Ro frames.
Examples:
manServoMomentsSimple.cpp, servoMomentImage.cpp, servoMomentPoints.cpp, and servoMomentPolygon.cpp.

Definition at line 352 of file vpPlane.cpp.

References A, B, C, and D.

Referenced by vpMbKltTracker::setPose().

double vpPlane::getA ( ) const
inline
Returns
The value of the plane parameter A.
Examples:
manServoMomentsSimple.cpp, servoMomentImage.cpp, servoMomentPoints.cpp, and servoMomentPolygon.cpp.

Definition at line 112 of file vpPlane.h.

Referenced by init(), rayIntersection(), and vpPlane().

vpColVector vpPlane::getABCD ( ) const
inline
Returns
Return the four dimension vector $[A,B,C,D]^T$ corresponding to the plane parameters.

Definition at line 126 of file vpPlane.h.

double vpPlane::getB ( ) const
inline
Returns
The value of the plane parameter B.
Examples:
manServoMomentsSimple.cpp, servoMomentImage.cpp, servoMomentPoints.cpp, and servoMomentPolygon.cpp.

Definition at line 114 of file vpPlane.h.

Referenced by init(), rayIntersection(), and vpPlane().

double vpPlane::getC ( ) const
inline
Returns
The value of the plane parameter C.
Examples:
manServoMomentsSimple.cpp, servoMomentImage.cpp, servoMomentPoints.cpp, and servoMomentPolygon.cpp.

Definition at line 116 of file vpPlane.h.

Referenced by init(), rayIntersection(), and vpPlane().

double vpPlane::getD ( ) const
inline
double vpPlane::getIntersection ( const vpColVector M1,
vpColVector H 
) const

Definition at line 325 of file vpPlane.cpp.

References A, B, C, and getD().

vpColVector vpPlane::getNormal ( ) const

Return the normal to the plane.

A plane is given by the equation $Ax + By + Cz + D = 0$ where (x,y,z) is a point of R^3 and (A,B,C) are the coordinates of the normal.

See also
getNormal(vpColVector &n)

Definition at line 226 of file vpPlane.cpp.

References A, B, and C.

Referenced by vpHomography::build(), vpMbtKltPolygon::init(), and vpMbKltTracker::setPose().

void vpPlane::getNormal ( vpColVector n) const

Return the normal to the plane.

A plane is given by the equation $Ax + By + Cz + D = 0$ where (x,y,z) are the coordinates of a point and $[A,B,C]^T$ is normal vector of the plane.

See also
getNormal()

Definition at line 246 of file vpPlane.cpp.

References A, B, C, and vpColVector::resize().

void vpPlane::init ( const vpPoint P,
const vpPoint Q,
const vpPoint R 
)

Compute the equation of a plane given three point P, Q, R.

The normal to the plane is given by n = PQ x PR

Definition at line 173 of file vpPlane.cpp.

References A, B, C, vpColVector::cross(), D, vpPoint::get_X(), vpPoint::get_Y(), and vpPoint::get_Z().

Referenced by vpPlane().

void vpPlane::init ( const vpColVector P,
const vpColVector n 
)

Initialize the plane from a point P on the plane and the normal n to the plane.

Parameters
P: A point with coordinates (x,y,z) on the plane.
n: The normal to the plane.
See also
vpPlane(const vpPoint&, const vpColVector &)

Definition at line 155 of file vpPlane.cpp.

References A, B, C, and D.

void vpPlane::init ( const vpPlane P)

Initialize the plane with the parameters of an other plane P.

Parameters
P: Plane used as initializer.

Definition at line 137 of file vpPlane.cpp.

References getA(), getB(), getC(), getD(), setA(), setB(), setC(), and setD().

vpPlane & vpPlane::operator= ( const vpPlane p)

Copy operator.

Definition at line 58 of file vpPlane.cpp.

References A, B, C, and D.

void vpPlane::projectionPointOnPlan ( const vpPoint P,
vpPoint Pproj 
) const

Compute the coordinates of the projection of a point on the plane.

Parameters
P: point to be projected on the plane
Pproj: result of the projection (pproj belongs to the plane)

Definition at line 261 of file vpPlane.cpp.

References A, B, C, D, vpPoint::get_W(), vpPoint::get_X(), vpPoint::get_Y(), vpPoint::get_Z(), vpPoint::set_W(), vpPoint::set_X(), vpPoint::set_Y(), and vpPoint::set_Z().

double vpPlane::rayIntersection ( const vpPoint M0,
const vpPoint M1,
vpColVector H 
) const

Definition at line 280 of file vpPlane.cpp.

References vpPoint::get_X(), vpPoint::get_Y(), vpPoint::get_Z(), getA(), getB(), getC(), and getD().

void vpPlane::setA ( const double  A)
inline

Set plane parameter A.

Definition at line 91 of file vpPlane.h.

Referenced by init(), and vpPlane().

void vpPlane::setABCD ( const double  A,
const double  B,
const double  C,
const double  D 
)
inline

Set plane parameters A, B, C, D.

Examples:
manServoMomentsSimple.cpp, servoMomentImage.cpp, servoMomentPoints.cpp, and servoMomentPolygon.cpp.

Definition at line 99 of file vpPlane.h.

void vpPlane::setB ( const double  B)
inline

Set plane parameter B.

Definition at line 93 of file vpPlane.h.

Referenced by init(), and vpPlane().

void vpPlane::setC ( const double  C)
inline

Set plane parameter C.

Definition at line 95 of file vpPlane.h.

Referenced by init(), and vpPlane().

void vpPlane::setD ( const double  D)
inline

Set plane parameter D.

Definition at line 97 of file vpPlane.h.

Referenced by init(), and vpPlane().

Friends And Related Function Documentation

VISP_EXPORT std::ostream& operator<< ( std::ostream &  os,
vpPlane p 
)
friend

Print the plane parameters as a stream like "(A,B,C,D) " where A,B,C and D correspond to the parameters of the plane.

Definition at line 165 of file vpPlane.h.

Member Data Documentation

double vpPlane::A
double vpPlane::B
double vpPlane::C
double vpPlane::D

Definition at line 76 of file vpPlane.h.

Referenced by changeFrame(), init(), operator=(), projectionPointOnPlan(), and vpPlane().