MRPT
2.0.4
|
#include <pnp/p3p.h>
Public Member Functions | |
p3p (double fx, double fy, double cx, double cy) | |
Constructor for p3p class using C. More... | |
p3p (Eigen::MatrixXd cam_intrinsic) | |
Constructor using Eigen matrix. More... | |
p3p (cv::Mat cameraMatrix) | |
Constructor using OpenCV matrix. More... | |
bool | solve (cv::Mat &R, cv::Mat &tvec, const cv::Mat &opoints, const cv::Mat &ipoints) |
Function to compute pose by P3P using OpenCV. More... | |
bool | solve (Eigen::Ref< Eigen::Matrix3d > R, Eigen::Ref< Eigen::Vector3d > t, Eigen::MatrixXd obj_pts, Eigen::MatrixXd img_pts) |
int | solve (double R[4][3][3], double t[4][3], double mu0, double mv0, double X0, double Y0, double Z0, double mu1, double mv1, double X1, double Y1, double Z1, double mu2, double mv2, double X2, double Y2, double Z2) |
Function to compute pose from 3 points using C function. More... | |
bool | solve (double R[3][3], double t[3], double mu0, double mv0, double X0, double Y0, double Z0, double mu1, double mv1, double X1, double Y1, double Z1, double mu2, double mv2, double X2, double Y2, double Z2, double mu3, double mv3, double X3, double Y3, double Z3) |
Function to compute pose from 4 points using C function. More... | |
Private Member Functions | |
template<typename T > | |
void | init_camera_parameters (const cv::Mat &cameraMatrix) |
OpenCV Initialization function to access camera intrinsic matrix. More... | |
template<typename OpointType , typename IpointType > | |
void | extract_points (const cv::Mat &opoints, const cv::Mat &ipoints, std::vector< double > &points) |
OpoenCV wrapper for extracting object and image points. More... | |
void | extract_points (Eigen::MatrixXd obj_pts, Eigen::MatrixXd img_pts, std::vector< double > &points) |
Eigen wrapper for extracting object and image points. More... | |
void | init_inverse_parameters () |
Function to compute inverse parameters of camera intrinsic matrix. More... | |
int | solve_for_lengths (double lengths[4][3], double distances[3], double cosines[3]) |
Helper function to solve() More... | |
bool | align (double M_start[3][3], double X0, double Y0, double Z0, double X1, double Y1, double Z1, double X2, double Y2, double Z2, double R[3][3], double T[3]) |
bool | jacobi_4x4 (double *A, double *D, double *U) |
Function used to compute the SVD. More... | |
Private Attributes | |
double | fx |
double | fy |
Focal length x. More... | |
double | cx |
Focal length y. More... | |
double | cy |
Image center x. More... | |
double | inv_fx |
Image center y. More... | |
double | inv_fy |
Inverse of focal length x. More... | |
double | cx_fx |
Inverse of focal length y. More... | |
double | cy_fy |
Inverse of image center point x. More... | |
mrpt::vision::pnp::p3p::p3p | ( | double | fx, |
double | fy, | ||
double | cx, | ||
double | cy | ||
) |
mrpt::vision::pnp::p3p::p3p | ( | Eigen::MatrixXd | cam_intrinsic | ) |
mrpt::vision::pnp::p3p::p3p | ( | cv::Mat | cameraMatrix | ) |
|
private |
|
inlineprivate |
|
inlineprivate |
|
inlineprivate |
|
private |
|
private |
Function used to compute the SVD.
[in] | A | Input Matrix for which SVD is to be computed |
[out] | D | Diagonal Matrix |
[out] | U | Matrix of left eigen vectors |
Definition at line 412 of file p3p.cpp.
References mrpt::system::os::memcpy(), and mrpt::math::sum().
bool mrpt::vision::pnp::p3p::solve | ( | cv::Mat & | R, |
cv::Mat & | tvec, | ||
const cv::Mat & | opoints, | ||
const cv::Mat & | ipoints | ||
) |
Function to compute pose by P3P using OpenCV.
[out] | R | Rotation Matrix |
[out] | tvec | Translation Vector |
[in] | opoints | Object points |
[in] | ipoints | Image points |
Definition at line 54 of file p3p.cpp.
References R.
Referenced by mrpt::vision::pnp::CPnP::p3p().
bool mrpt::vision::pnp::p3p::solve | ( | Eigen::Ref< Eigen::Matrix3d > | R, |
Eigen::Ref< Eigen::Vector3d > | t, | ||
Eigen::MatrixXd | obj_pts, | ||
Eigen::MatrixXd | img_pts | ||
) |
int mrpt::vision::pnp::p3p::solve | ( | double | R[4][3][3], |
double | t[4][3], | ||
double | mu0, | ||
double | mv0, | ||
double | X0, | ||
double | Y0, | ||
double | Z0, | ||
double | mu1, | ||
double | mv1, | ||
double | X1, | ||
double | Y1, | ||
double | Z1, | ||
double | mu2, | ||
double | mv2, | ||
double | X2, | ||
double | Y2, | ||
double | Z2 | ||
) |
Function to compute pose from 3 points using C function.
[out] | R | Rotation Matrix |
[out] | t | Translation Vector |
[in] | mu0 | x- coordinate of image point 1 |
[in] | mv0 | y- coordinate of image point 1 |
[in] | X0 | X- coordinate of object point 1 |
[in] | Y0 | Y- coordinate of object point 1 |
[in] | Z0 | Z- coordinate of object point 1 |
[in] | mu1 | x- coordinate of image point 2 |
[in] | mv1 | y- coordinate of image point 2 |
[in] | X1 | X- coordinate of object point 2 |
[in] | Y1 | Y- coordinate of object point 2 |
[in] | Z1 | Z- coordinate of object point 2 |
[in] | mu2 | x- coordinate of image point 3 |
[in] | mv2 | y- coordinate of image point 3 |
[in] | X2 | X- coordinate of object point 3 |
[in] | Y2 | Y- coordinate of object point 3 |
[in] | Z2 | Z- coordinate of object point 3 |
Definition at line 144 of file p3p.cpp.
References mrpt::math::norm(), and R.
bool mrpt::vision::pnp::p3p::solve | ( | double | R[3][3], |
double | t[3], | ||
double | mu0, | ||
double | mv0, | ||
double | X0, | ||
double | Y0, | ||
double | Z0, | ||
double | mu1, | ||
double | mv1, | ||
double | X1, | ||
double | Y1, | ||
double | Z1, | ||
double | mu2, | ||
double | mv2, | ||
double | X2, | ||
double | Y2, | ||
double | Z2, | ||
double | mu3, | ||
double | mv3, | ||
double | X3, | ||
double | Y3, | ||
double | Z3 | ||
) |
Function to compute pose from 4 points using C function.
[out] | R | Rotation Matrix |
[out] | t | Translation Vector |
[in] | mu0 | x- coordinate of image point 1 |
[in] | mv0 | y- coordinate of image point 1 |
[in] | X0 | X- coordinate of object point 1 |
[in] | Y0 | Y- coordinate of object point 1 |
[in] | Z0 | Z- coordinate of object point 1 |
[in] | mu1 | x- coordinate of image point 2 |
[in] | mv1 | y- coordinate of image point 2 |
[in] | X1 | X- coordinate of object point 2 |
[in] | Y1 | Y- coordinate of object point 2 |
[in] | Z1 | Z- coordinate of object point 2 |
[in] | mu2 | x- coordinate of image point 3 |
[in] | mv2 | y- coordinate of image point 3 |
[in] | X2 | X- coordinate of object point 3 |
[in] | Y2 | Y- coordinate of object point 3 |
[in] | Z2 | Z- coordinate of object point 3 |
[in] | mu3 | x- coordinate of image point 4 |
[in] | mv3 | y- coordinate of image point 4 |
[in] | X3 | X- coordinate of object point 4 |
[in] | Y3 | Y- coordinate of object point 4 |
[in] | Z3 | Z- coordinate of object point 4 |
Definition at line 100 of file p3p.cpp.
References R.
|
private |
Helper function to solve()
Given 3D distances between three points and cosines of 3 angles at the apex, calculates the lentghs of the line segments connecting projection center (P) and the three 3D points (A, B, C).
[out] | lengths | Internal lengths used for P3P |
[in] | distances | Internal distances used for computation of lengths |
[in] | cosines | Internal cosines used for computation of lengths |
Returned distances are for |PA|, |PB|, |PC| respectively. Only the solution to the main branch. Reference : X.S. Gao, X.-R. Hou, J. Tang, H.-F. Chang; "Complete Solution Classification for the Perspective-Three-Point Problem" IEEE Trans. on PAMI, vol. 25, No. 8, August 2003
lengths3D | Lengths of line segments up to four solutions. |
dist3D | Distance between 3D points in pairs |BC|, |AC|, |AB|. |
cosines | Cosine of the angles /_BPC, /_APC, /_APB. |
Definition at line 233 of file p3p.cpp.
References mrpt::obs::gnss::a2, mrpt::obs::gnss::b0, mrpt::obs::gnss::b1, mrpt::obs::gnss::b2, and solve_deg4().
|
private |
Focal length y.
Definition at line 208 of file p3p.h.
Referenced by extract_points(), init_camera_parameters(), and init_inverse_parameters().
|
private |
Inverse of focal length y.
Definition at line 212 of file p3p.h.
Referenced by init_inverse_parameters().
|
private |
Image center x.
Definition at line 209 of file p3p.h.
Referenced by extract_points(), init_camera_parameters(), and init_inverse_parameters().
|
private |
Inverse of image center point x.
Definition at line 213 of file p3p.h.
Referenced by init_inverse_parameters().
|
private |
Definition at line 206 of file p3p.h.
Referenced by extract_points(), init_camera_parameters(), and init_inverse_parameters().
|
private |
Focal length x.
Definition at line 207 of file p3p.h.
Referenced by extract_points(), init_camera_parameters(), and init_inverse_parameters().
|
private |
|
private |
Inverse of focal length x.
Definition at line 211 of file p3p.h.
Referenced by init_inverse_parameters().
Page generated by Doxygen 1.8.14 for MRPT 2.0.4 Git: 33de1d0ad Sat Jun 20 11:02:42 2020 +0200 at sáb jun 20 17:35:17 CEST 2020 |