10 #ifndef EIGEN_POLYNOMIAL_UTILS_H 11 #define EIGEN_POLYNOMIAL_UTILS_H 14 #include "./InternalHeaderCheck.h" 29 template <
typename Polynomials,
typename T>
31 T val = poly[poly.size() - 1];
32 for (DenseIndex i = poly.size() - 2; i >= 0; --i) {
33 val = val * x + poly[i];
46 template <
typename Polynomials,
typename T>
47 inline T
poly_eval(
const Polynomials& poly,
const T& x) {
50 if (numext::abs2(x) <= Real(1)) {
55 for (DenseIndex i = 1; i < poly.size(); ++i) {
56 val = val * inv_x + poly[i];
59 return numext::pow(x, (T)(poly.size() - 1)) * val;
73 template <
typename Polynomial>
76 typedef typename Polynomial::Scalar Scalar;
79 eigen_assert(Scalar(0) != poly[poly.size() - 1]);
80 const Scalar inv_leading_coeff = Scalar(1) / poly[poly.size() - 1];
83 for (DenseIndex i = 0; i < poly.size() - 1; ++i) {
84 cb +=
abs(poly[i] * inv_leading_coeff);
95 template <
typename Polynomial>
98 typedef typename Polynomial::Scalar Scalar;
102 while (i < poly.size() - 1 && Scalar(0) == poly(i)) {
105 if (poly.size() - 1 == i) {
109 const Scalar inv_min_coeff = Scalar(1) / poly[i];
111 for (DenseIndex j = i + 1; j < poly.size(); ++j) {
112 cb +=
abs(poly[j] * inv_min_coeff);
127 template <
typename RootVector,
typename Polynomial>
129 typedef typename Polynomial::Scalar Scalar;
131 poly.setZero(rv.size() + 1);
134 for (DenseIndex i = 1; i < rv.size(); ++i) {
135 for (DenseIndex j = i + 1; j > 0; --j) {
136 poly[j] = poly[j - 1] - rv[i] * poly[j];
138 poly[0] = -rv[i] * poly[0];
144 #endif // EIGEN_POLYNOMIAL_UTILS_H NumTraits< typename Polynomial::Scalar >::Real cauchy_max_bound(const Polynomial &poly)
Definition: PolynomialUtils.h:74
Namespace containing all symbols from the Eigen library.
void roots_to_monicPolynomial(const RootVector &rv, Polynomial &poly)
Definition: PolynomialUtils.h:128
NumTraits< typename Polynomial::Scalar >::Real cauchy_min_bound(const Polynomial &poly)
Definition: PolynomialUtils.h:96
T poly_eval(const Polynomials &poly, const T &x)
Definition: PolynomialUtils.h:47
T poly_eval_horner(const Polynomials &poly, const T &x)
Definition: PolynomialUtils.h:30
const Eigen::CwiseUnaryOp< Eigen::internal::scalar_abs_op< typename Derived::Scalar >, const Derived > abs(const Eigen::ArrayBase< Derived > &x)