Visual Servoing Platform
version 3.4.0
|
#include <vpPixelMeterConversion.h>
Static Public Member Functions | |
Using ViSP camera parameters | |
static void | convertEllipse (const vpCameraParameters &cam, const vpImagePoint ¢er_p, double n20_p, double n11_p, double n02_p, double &xc_m, double &yc_m, double &n20_m, double &n11_m, double &n02_m) |
static void | convertLine (const vpCameraParameters &cam, const double &rho_p, const double &theta_p, double &rho_m, double &theta_m) |
static void | convertMoment (const vpCameraParameters &cam, unsigned int order, const vpMatrix &moment_pixel, vpMatrix &moment_meter) |
static void | convertPoint (const vpCameraParameters &cam, const double &u, const double &v, double &x, double &y) |
static void | convertPoint (const vpCameraParameters &cam, const vpImagePoint &iP, double &x, double &y) |
Using OpenCV camera parameters | |
static void | convertEllipse (const cv::Mat &cameraMatrix, const cv::Mat &distCoeffs, const vpImagePoint ¢er_p, double n20_p, double n11_p, double n02_p, double &xc_m, double &yc_m, double &n20_m, double &n11_m, double &n02_m) |
static void | convertLine (const cv::Mat &cameraMatrix, const double &rho_p, const double &theta_p, double &rho_m, double &theta_m) |
static void | convertMoment (const cv::Mat &cameraMatrix, unsigned int order, const vpMatrix &moment_pixel, vpMatrix &moment_meter) |
static void | convertPoint (const cv::Mat &cameraMatrix, const cv::Mat &distCoeffs, const double &u, const double &v, double &x, double &y) |
static void | convertPoint (const cv::Mat &cameraMatrix, const cv::Mat &distCoeffs, const vpImagePoint &iP, double &x, double &y) |
Various conversion functions to transform primitives (2D line, moments, 2D point) from pixel to normalized coordinates in meter in the image plane.
Tranformation relies either on ViSP camera parameters implemented in vpCameraParameters or on OpenCV camera parameters that are set from a projection matrix and a distorsion coefficients vector.
Definition at line 71 of file vpPixelMeterConversion.h.
|
static |
Convert ellipse parameters (ie ellipse center and normalized centered moments) from pixels to meters in the image plane.
[in] | cam | : Camera parameters. |
[in] | center_p | : Center of the ellipse (uc, vc) with pixel coordinates. |
[in] | n20_p,n11_p,n02_p | : Normalized second order moments of the ellipse in pixels. |
[out] | xc_m,yc_m | : Center of the ellipse with coordinates in meters in the image plane. |
[out] | n20_m,n11_m,n02_m | : Normalized second order moments of the ellipse in meters in the image plane. |
Definition at line 60 of file vpPixelMeterConversion.cpp.
References convertPoint(), vpCameraParameters::get_px(), and vpCameraParameters::get_py().
Referenced by vpFeatureBuilder::create().
|
static |
Convert ellipse parameters (ie ellipse center and normalized centered moments) from pixels to meters in the image plane.
[in] | cameraMatrix | : Camera Matrix |
[in] | distCoeffs | : Input vector of distortion coefficients of 4, 5, 8, 12 or 14 elements. If the vector is NULL/empty, the zero distortion coefficients are assumed. |
[in] | center_p | : Center of the ellipse (uc, vc) with pixel coordinates. |
[in] | n20_p,n11_p,n02_p | : Normalized second order moments of the ellipse in pixels. |
[out] | xc_m,yc_m | : Center of the ellipse with coordinates in meters in the image plane. |
[out] | n20_m,n11_m,n02_m | : Normalized second order moments of the ellipse in meters in the image plane. |
Definition at line 188 of file vpPixelMeterConversion.cpp.
References convertPoint().
|
static |
Line parameters conversion from pixel to normalized coordinates in meter using ViSP camera parameters. This function doesn't use distorsion coefficients.
[in] | cam | : camera parameters. |
[in] | rho_p,theta_p | : Line parameters expressed in pixels. |
[out] | rho_m,theta_m | : Line parameters expressed in meters in the image plane. |
Definition at line 82 of file vpPixelMeterConversion.cpp.
References vpException::divideByZeroError, vpMath::sqr(), and vpERROR_TRACE.
Referenced by vpFeatureBuilder::create().
|
static |
Line parameters conversion from pixel to normalized coordinates in meter using OpenCV camera parameters. This function doesn't use distorsion coefficients.
[in] | cameraMatrix | : Camera Matrix |
[in] | rho_p,theta_p | : Line parameters expressed in pixels. |
[out] | rho_m,theta_m | : Line parameters expressed in meters in the image plane. |
Definition at line 210 of file vpPixelMeterConversion.cpp.
References vpException::divideByZeroError, vpMath::sqr(), and vpERROR_TRACE.
|
static |
Moments conversion from pixel to normalized coordinates in meter using ViSP camera parameters. This function doesn't use distorsion coefficients.
[in] | cam | : camera parameters. |
[in] | order | : Moment order. |
[in] | moment_pixel | : Moment values in pixels. |
[out] | moment_meter | : Moment values in meters in the image plane. |
The following example show how to use this function.
Definition at line 135 of file vpPixelMeterConversion.cpp.
References vpMath::comb().
|
static |
Moments conversion from pixel to normalized coordinates in meter using OpenCV camera parameters. This function doesn't use distorsion coefficients.
[in] | cameraMatrix | : Camera Matrix |
[in] | order | : Moment order. |
[in] | moment_pixel | : Moment values in pixels. |
[out] | moment_meter | : Moment values in meters in the image plane. |
Definition at line 241 of file vpPixelMeterConversion.cpp.
References vpMath::comb().
|
inlinestatic |
Point coordinates conversion from pixel coordinates to normalized coordinates in meter using ViSP camera parameters.
The used formula depends on the projection model of the camera. To know the currently used projection model use vpCameraParameter::get_projModel()
[in] | cam | : camera parameters. |
[in] | u | : input coordinate in pixels along image horizontal axis. |
[in] | v | : input coordinate in pixels along image vertical axis. |
[out] | x | : output coordinate in meter along image plane x-axis. |
[out] | y | : output coordinate in meter along image plane y-axis. |
and in the case of perspective projection without distortion.
and with in the case of perspective projection with distortion.
In the case of a projection with Kannala-Brandt distortion, refer to [21].
Definition at line 109 of file vpPixelMeterConversion.h.
References vpCameraParameters::perspectiveProjWithDistortion, vpCameraParameters::perspectiveProjWithoutDistortion, and vpCameraParameters::ProjWithKannalaBrandtDistortion.
Referenced by vpCalibration::addPoint(), vpFeatureLuminance::buildFrom(), vpKeyPoint::compute3D(), vpKeyPoint::compute3DForPointsOnCylinders(), vpMbtFaceDepthNormal::computeDesiredFeatures(), vpMbtDistanceKltCylinder::computeInteractionMatrixAndResidu(), vpMbtDistanceKltPoints::computeInteractionMatrixAndResidu(), vpMbtDistanceCircle::computeInteractionMatrixError(), vpPose::computePlanarObjectPoseFromRGBD(), convertEllipse(), vpFeatureBuilder::create(), vpMomentObject::fromImage(), vpImageSimulator::getImage(), vpMbtDistanceKltCylinder::init(), vpMbTracker::initClick(), vpMbTracker::initFromPoints(), vpKeyPoint::matchPoint(), and vpKinect::warpRGBFrame().
|
inlinestatic |
Point coordinates conversion from pixel coordinates Coordinates in pixel to normalized coordinates in meter using ViSP camera parameters.
The used formula depends on the projection model of the camera. To know the currently used projection model use vpCameraParameter::get_projModel()
[in] | cam | : camera parameters. |
[in] | iP | : input coordinates in pixels. |
[out] | x | : output coordinate in meter along image plane x-axis. |
[out] | y | : output coordinate in meter along image plane y-axis. |
Thanks to the pixel coordinates in the frame (u,v), the meter coordinates are given by :
and in the case of perspective projection without distortion.
and with in the case of perspective projection with distortion.
In the case of a projection with Kannala-Brandt distortion, refer to [21].
Definition at line 152 of file vpPixelMeterConversion.h.
References vpImagePoint::get_u(), vpImagePoint::get_v(), vpCameraParameters::getKannalaBrandtDistortionCoefficients(), vpCameraParameters::perspectiveProjWithDistortion, vpCameraParameters::perspectiveProjWithoutDistortion, vpCameraParameters::ProjWithKannalaBrandtDistortion, and vpMath::sqr().
|
static |
Point coordinates conversion from pixel coordinates to normalized coordinates in meter using OpenCV camera parameters.
[in] | cameraMatrix | : Camera Matrix |
[in] | distCoeffs | : Input vector of distortion coefficients of 4, 5, 8, 12 or 14 elements. If the vector is NULL/empty, the zero distortion coefficients are assumed. |
[in] | u | : input coordinate in pixels along image horizontal axis. |
[in] | v | : input coordinate in pixels along image vertical axis. |
[out] | x | : output coordinate in meter along image plane x-axis. |
[out] | y | : output coordinate in meter along image plane y-axis. |
Definition at line 299 of file vpPixelMeterConversion.cpp.
|
static |
Point coordinates conversion from pixel coordinates to normalized coordinates in meter using OpenCV camera parameters.
[in] | cameraMatrix | : Camera Matrix |
[in] | distCoeffs | : Input vector of distortion coefficients of 4, 5, 8, 12 or 14 elements. If the vector is NULL/empty, the zero distortion coefficients are assumed. |
[in] | iP | : input coordinates in pixels. |
[out] | x | : output coordinate in meter along image plane x-axis. |
[out] | y | : output coordinate in meter along image plane y-axis. |
Definition at line 323 of file vpPixelMeterConversion.cpp.
References vpImagePoint::get_u(), and vpImagePoint::get_v().