10#ifndef EIGEN_POLYNOMIAL_UTILS_H
11#define EIGEN_POLYNOMIAL_UTILS_H
14#include "./InternalHeaderCheck.h"
29template <
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];
46template <
typename Polynomials,
typename T>
47inline 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;
73template <
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);
95template <
typename Polynomial>
98 typedef typename Polynomial::Scalar
Scalar;
102 while (i < poly.size() - 1 &&
Scalar(0) == poly(i)) {
105 if (poly.size() - 1 == i) {
111 for (DenseIndex j = i + 1; j < poly.size(); ++j) {
112 cb +=
abs(poly[j] * inv_min_coeff);
127template <
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];
NumTraits< typenamePolynomial::Scalar >::Real cauchy_max_bound(const Polynomial &poly)
Definition PolynomialUtils.h:74
T poly_eval_horner(const Polynomials &poly, const T &x)
Definition PolynomialUtils.h:30
NumTraits< typenamePolynomial::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
void roots_to_monicPolynomial(const RootVector &rv, Polynomial &poly)
Definition PolynomialUtils.h:128
Namespace containing all symbols from the Eigen library.
const Eigen::CwiseUnaryOp< Eigen::internal::scalar_abs_op< typename Derived::Scalar >, const Derived > abs(const Eigen::ArrayBase< Derived > &x)