“…#include <math.h> #include <complex> transformations_t fourpt( const RelativeAdapterBase & adapter, const Indices & indices ){ MatrixXd A(4,8); Matrix3d rotation = adapter.getR12(); for( size_t i = 0; i < numberCorrespondences; i++ ){ bearingVector_t d1 = adapter.getBearingVector1(indices[i]); bearingVector_t d2 = adapter.getBearingVector2(indices[i]); translation_t v1 = adapter.getCamOffset1(indices[i]); translation_t v2 = adapter.getCamOffset2(indices[i]); rotation_t R11 = adapter.getCamRotation1(indices[i]); rotation_t R21 = adapter.getCamRotation2(indices[i]); d1 = R11*d1; d2 = R21*d2; Eigen::Matrix<double,6,1> l1,l2_pr; l1.block<3,1>(0,0) = d1; l1.block<3,1>(3,0) = v1.cross(d1); l2_pr.block<3,1>(0,0) = rotation*d2; l2_pr.block<3,1>(3,0) = rotation*(v2.cross(d2)); A(i,0) = l1(0)*l2_pr(3) + l1(1)*l2_pr(4) + l1(2)*l2_pr(5) + l1(3)*l2_pr(0) + l1(4)*l2_pr(1) + l1(5)*l2_pr(2); A(i,1) = l1(2)*l2_pr(1) -l1(1)*l2_pr(2); A(i,2) = l1(0)*l2_pr(2) -l1(2)*l2_pr(0); A(i,3) = l1(1)*l2_pr(0) -l1(0)*l2_pr(1); A(i,4) = l1(1)*l2_pr(3) -l1(3)*l2_pr(1) + l1(4)*l2_pr(0) -l1(0)*l2_pr(4); A(i,5) = l1(2)*l2_pr(0); A(i,6) = l1(2)*l2_pr(1); A(i,7) = -l1(0)*l2_pr(0) -l1(1)*l2_pr(1);} // Form a quartic equation of x^4+a3*x^3+a2*x^2+a1*x+a0=0 double a0 =(-A(0,0)*A(1,1)*A(2,2)*A(3,3)+A(0,0)*A(1,1)*A(2,3)*A(3,2)+A(0,0)*A(1,2)*A(2,1)*A(3,3)-A(0,0)*A(1,2)*A(2,3)*A(3,1)-A(0,0)* A(1,3)*A(2,1)*A(3,2)+A(0,0)*A(1,3)*A(2,2)*A(3,1)+A(0,1)*A(1,0)* A(2,2)*A(3,3)-A(0,1)*A(1,0)*A(2,3)*A(3,2)-A(0,1)*A(1,2)*A(2,0)* A(3,3)+A(0,1)*A(1,2)*A(2,3)*A(3,0)+A(0,1)*A(1,3)*A(2,0)*A(3,2)-A(0,1)*A(1,3)*A(2,2)*A(3,0)-A(0,2)*A(1,0)*A(2,1)*A(3,3)+A(0,2)* A(1,0)*A(2,3)*A(3,1)+A(0,2)*A(1,1)*A(2,0)*A(3,3)-A(0,2)*A(1,1)* A(2,3)*A(3,0)-A(0,2)*A(1,3)*A(2,0)*A(3,1)+A(0,2)*A(1,3)*A(2,1)* A(3,0)+A(0,3)*A(1,0)*A(2,1)*A(3,2)-A(0,3)*A(1,0)*A(2,2)*A(3,1)-A(0,3)*A(1,1)*A(2,0)*A(3,2)+A(0,3)*A(1,1)*A(2,2)*A(3,0)+A(0,3)* A(1,2)*A(2,0)*A(3,1)-A(0,3)*A(1,2)*A(2,1)*A(3,0))/(-A(0,4)*A(1,5) *A(2,6)*A(3,7)+A(0,4)*A(1,5)*A(2,7)*A(3,6)+A(0,4)*A(1,6)*A(2,5)* A(3,7)-A(0,4)*A(1,6)*A(2,7)*A(3,5)-A(0,4)*A(1,7)*A(2,5)*A(3,6)+ A(0,4)*A(1,7)*A(2,6)*A(3,5)+A(0,5)*A(1,4)*A(2,6)*A(3,7)-A(0,5)* A(1,4)*A(2,7)*A(3,6)-A(0,5)*A(1,6)*A(2,4)*A(3,7)+A(0,5)*A(1,6)* A(2,7)*A(3,4)+A(0,5)*A(1,7)*A(2,4)*A(3,6)-A(0,5)*A(1,7)*A(2,6)* A(3,4)-A(0,6)*A(1,4)*A(2,5)*A(3,7)+A(0,6)*A(1,4)*A(2,7)*A(3,5)+ A(0,6)*A(1,5)*A(2,4)*A(3,7)-A(0,6)*A(1,5)*A(2,7)*A(3,4)-A(0,6)* A(1,7)*A(2,4)*A(3,5)+A(0,6)*A(1,7)*A(2,5)*A(3,4)+A(0,7)*A(1,4)* A(2,5)*A(3,6)-A(0,7)*A(1,4)*A(2,6)*A(3,5)-A(0,7)*A(1,5)*A(2,4)* A(3,6)+A(0,7)*A(1,5)*A(2,6)*A(3,4)+A(0,7)*A(1,6)*A(2,4)*A(3,5)-A(0,7)*A(1,6)*A(2,5)*A(3,4)); double a1 = (-A(0,0)*A(1,1)*A(2,2)*A(3,7)+A(0,0)*A(1,1)*A(2,3)* A(3,6)-A(0,0)*A(1,1)*A(2,6)*A(3,3)+A(0,0)*A(1,1)*A(2,7)*A(3,2)+ A(0,0)*A(1,2)*A(2,1)*A(3,7)-A(0,0)*A(1,2)*A(2,3)*A(3,5)+A(0,0)* A(1,2)*A(2,5)*A(3,3)-A(0,0)*A(1,2)*A(2,7)*A(3,1)-A(0,0)*A(1,3)* A(2,1)*A(3,6)+A(0,0)*A(1,3)*A(2,2)*A(3,5)-A(0,0)*A(1,3)*A(2,5)* A(3,2)+A(0,0)*A(1,3)*A(2,6)*A(3,1)-A(0,0)*A(1,5)*A(2,2)*A(3,3)+ A(0,0)*A(1,5)*A(2,3)*A(3,2)+A(0,0)*A(1,6)*A(2,1)*A(3,3)-A(0,0)* A(1,6)*A(2,3)*A(3,1)-A(0,0)*A(1,7)*A(2,1)*A(3,2)+A(0,0)*A(1,7)* A(2,2)*A(3,1)+A(0,1)*A(1,0)*A(2,2)*A(3,7)-A(0,1)*A(1,0)*A(2,3)* A(3,6)+A(0,1)*A(1,0)*A(2,6)*A(3,3)-A(0,1)*A(1,0)*A(2,7)*A(3,2)-A(0,1)*A(1,2)*A(2,0)*A(3,7)+A(0,1)*A(1,2)*A(2,3)*A(3,4)-A(0,1)*A(1,2)*A(2,4)*A(3,3)+A(0,1)*A(1,2)*A(2,7)*A(3,0)+A(0,1)*A(1,3)* A(2,0)*A(3,6)-A(0,1)*A(1,3)*A(2,2)*A(3,4)+A(0,1)*A(1,3)*A(2,4)* A(3,2)-A(0,1)*A(1,3)*A(2,6)*A(3,0)+A(0,1)*A(1,4)*A(2,2)*A(3,3)-A(0,1)*A(1,4)*A(2,3)*A(3,2)-A(0,1)*A(1,6)*A(2,0)*A(3,3)+A(0,1)* A(1,6)*A(2,3)*A(3,0)+A(0,1)*A(1,7)*A(2,0)*A(3,2)-A(0,1)*A(1,7)* A(2,2)*A(3,0)-A(0,2)*A(1,0)*A(2,1)*A(3,7)+A(0,2)*A(1,0)*A(2,3)* A(3,5)-A(0,2)*A(1,0)*A(2,5)*A(3,3)+A(0,2)*A(1,0)*A(2,7)*A(3,1)+ A(0,2)*A(1,1)*A(2,0)*A(3,7)-A(0,2)*A(1,1)*A(2,3)*A(3,4)+A(0,2)* A(1,1)*A(2,4)*A(3,3)-A(0,2)*A(1,1)*A(2,7)*A(3,0)-A(0,2)...…”