47 PONCA_MULTIARCH_STD_MATH(sqrt);
48 PONCA_MULTIARCH_STD_MATH(numeric_limits);
54 VectorType barycenter = Base::barycenterLocal();
55 VectorArray dBarycenter = Base::barycenterDerivatives();
58 Scalar epsilon =
Scalar(2) * Eigen::NumTraits<Scalar>::epsilon();
59 Scalar consider_as_zero =
Scalar(2) * numeric_limits<Scalar>::denorm_min();
63 Eigen::Matrix<Scalar,2,1> shifted_eivals = Base::m_solver.eigenvalues().template tail<2>().array() - Base::m_solver.eigenvalues()(0);
64 if(shifted_eivals(0) < consider_as_zero || shifted_eivals(0) < epsilon * shifted_eivals(1)) shifted_eivals(0) = 0;
65 if(shifted_eivals(1) < consider_as_zero) shifted_eivals(1) = 0;
68 for(
int k=0; k<Base::NbDerivatives; ++k)
79 Eigen::Matrix<Scalar,2,1> z = - Base::m_solver.eigenvectors().template rightCols<2>().transpose() * (Base::m_dCov[k] * normal);
80 if(shifted_eivals(0)>0) z(0) /= shifted_eivals(0);
81 if(shifted_eivals(1)>0) z(1) /= shifted_eivals(1);
82 m_dNormal.col(k) = Base::m_solver.eigenvectors().template rightCols<2>() * z;
85 if(k>0 || !Base::isScaleDer())
86 dDiff(Base::isScaleDer() ? k-1 : k) += 1;
87 m_dDist(k) = m_dNormal.col(k).dot(barycenter) + normal.dot(dDiff);
91 return Base::m_eCurrentState;