34 #include <Eigen/Geometry>
45 const std::vector<X_t>& points1,
const std::vector<Y_t>& points2) {
46 CHECK_EQ(points1.size(), points2.size());
48 const size_t N = points1.size();
51 std::vector<X_t> normed_points1;
52 std::vector<Y_t> normed_points2;
53 Eigen::Matrix3d points1_norm_matrix;
54 Eigen::Matrix3d points2_norm_matrix;
59 Eigen::Matrix<double, Eigen::Dynamic, 9> A = Eigen::MatrixXd::Zero(2 * N, 9);
61 for (
size_t i = 0, j = N; i < points1.size(); ++i, ++j) {
62 const double s_0 = normed_points1[i](0);
63 const double s_1 = normed_points1[i](1);
64 const double d_0 = normed_points2[i](0);
65 const double d_1 = normed_points2[i](1);
83 Eigen::JacobiSVD<Eigen::Matrix<double, Eigen::Dynamic, 9>> svd(
84 A, Eigen::ComputeFullV);
86 const Eigen::VectorXd nullspace = svd.matrixV().col(8);
87 Eigen::Map<const Eigen::Matrix3d> H_t(nullspace.data());
89 const std::vector<M_t> models = {points2_norm_matrix.inverse() *
90 H_t.transpose() * points1_norm_matrix};
95 const std::vector<Y_t>& points2,
97 std::vector<double>* residuals) {
98 CHECK_EQ(points1.size(), points2.size());
100 residuals->resize(points1.size());
105 const double H_00 = H(0, 0);
106 const double H_01 = H(0, 1);
107 const double H_02 = H(0, 2);
108 const double H_10 = H(1, 0);
109 const double H_11 = H(1, 1);
110 const double H_12 = H(1, 2);
111 const double H_20 = H(2, 0);
112 const double H_21 = H(2, 1);
113 const double H_22 = H(2, 2);
115 for (
size_t i = 0; i < points1.size(); ++i) {
116 const double s_0 = points1[i](0);
117 const double s_1 = points1[i](1);
118 const double d_0 = points2[i](0);
119 const double d_1 = points2[i](1);
121 const double pd_0 = H_00 * s_0 + H_01 * s_1 + H_02;
122 const double pd_1 = H_10 * s_0 + H_11 * s_1 + H_12;
123 const double pd_2 = H_20 * s_0 + H_21 * s_1 + H_22;
125 const double inv_pd_2 = 1.0 / pd_2;
126 const double dd_0 = d_0 - pd_0 * inv_pd_2;
127 const double dd_1 = d_1 - pd_1 * inv_pd_2;
129 (*residuals)[i] = dd_0 * dd_0 + dd_1 * dd_1;
static std::vector< M_t > Estimate(const std::vector< X_t > &points1, const std::vector< Y_t > &points2)
static void Residuals(const std::vector< X_t > &points1, const std::vector< Y_t > &points2, const M_t &H, std::vector< double > *residuals)
void CenterAndNormalizeImagePoints(const std::vector< Eigen::Vector2d > &points, std::vector< Eigen::Vector2d > *normed_points, Eigen::Matrix3d *matrix)