Visual Servoing Platform
version 3.6.1 under development (2024-10-13)
|
#include <visp3/core/vpPixelMeterConversion.h>
Static Public Member Functions | |
Using ViSP camera parameters <br> | |
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 <br> | |
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.
Transformation relies either on ViSP camera parameters implemented in vpCameraParameters or on OpenCV camera parameters that are set from a projection matrix and a distortion coefficients vector.
Definition at line 65 of file vpPixelMeterConversion.h.
|
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 nullptr/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 186 of file vpPixelMeterConversion.cpp.
References convertPoint().
|
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 55 of file vpPixelMeterConversion.cpp.
References convertPoint(), vpCameraParameters::get_px(), and vpCameraParameters::get_py().
|
static |
Line parameters conversion from pixel to normalized coordinates in meter using OpenCV camera parameters. This function doesn't use distortion 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 208 of file vpPixelMeterConversion.cpp.
References vpException::divideByZeroError, and vpMath::sqr().
|
static |
Line parameters conversion from pixel to normalized coordinates in meter using ViSP camera parameters. This function doesn't use distortion 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 77 of file vpPixelMeterConversion.cpp.
References vpException::divideByZeroError, and vpMath::sqr().
|
static |
Moments conversion from pixel to normalized coordinates in meter using OpenCV camera parameters. This function doesn't use distortion 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 237 of file vpPixelMeterConversion.cpp.
References vpMath::comb().
|
static |
Moments conversion from pixel to normalized coordinates in meter using ViSP camera parameters. This function doesn't use distortion 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 128 of file vpPixelMeterConversion.cpp.
References vpMath::comb().
|
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 nullptr/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 300 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 nullptr/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 324 of file vpPixelMeterConversion.cpp.
References vpImagePoint::get_u(), and vpImagePoint::get_v().
|
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 [22].
Definition at line 102 of file vpPixelMeterConversion.h.
References vpCameraParameters::perspectiveProjWithDistortion, vpCameraParameters::perspectiveProjWithoutDistortion, and vpCameraParameters::ProjWithKannalaBrandtDistortion.
Referenced by vpFeatureLuminance::buildFrom(), vpKeyPoint::compute3D(), vpKeyPoint::compute3DForPointsOnCylinders(), vpMbtFaceDepthNormal::computeDesiredFeatures(), vpMbtDistanceCircle::computeInteractionMatrixError(), vpPose::computePlanarObjectPoseFromRGBD(), convertEllipse(), vpFeatureBuilder::create(), vpImageConvert::depthToPointCloud(), vpMomentObject::fromImage(), vpImageSimulator::getImage(), vpMbTracker::initFromPoints(), vpMbGenericTracker::initFromPose(), 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 [22].
Definition at line 146 of file vpPixelMeterConversion.h.
References vpCameraParameters::perspectiveProjWithDistortion, vpCameraParameters::perspectiveProjWithoutDistortion, and vpCameraParameters::ProjWithKannalaBrandtDistortion.