15#ifndef dealii_polynomial_h
16#define dealii_polynomial_h
31#include <shared_mutex>
66 template <
typename number>
93 const unsigned int evaluation_point);
123 value(
const number x, std::vector<number> &values)
const;
143 template <
typename Number2>
145 value(
const Number2 x,
146 const unsigned int n_derivatives,
147 Number2 *values)
const;
161 template <std::
size_t n_entries,
typename Number2>
167 const unsigned int n_derivatives,
168 std::array<Number2, n_entries> *values)
const;
186 scale(
const number factor);
203 template <
typename number2>
205 shift(
const number2 offset);
254 print(std::ostream &out)
const;
261 template <
class Archive>
281 template <
typename number2>
333 template <
typename number>
341 Monomial(
const unsigned int n,
const double coefficient = 1.);
349 static std::vector<Polynomial<number>>
356 static std::vector<number>
357 make_vector(
unsigned int n,
const double coefficient);
394 static std::vector<Polynomial<double>>
404 const unsigned int support_point,
405 std::vector<double> &a);
416 std::vector<Polynomial<double>>
448 static std::vector<Polynomial<double>>
478 Lobatto(
const unsigned int p = 0);
484 static std::vector<Polynomial<double>>
553 static std::vector<Polynomial<double>>
567 static const std::vector<double> &
578 static std::vector<std::unique_ptr<const std::vector<double>>>
631 static std::vector<Polynomial<double>>
746 const unsigned int index);
752 static std::vector<Polynomial<double>>
767 template <
typename Number>
787 template <
typename Number>
801 template <
typename number>
809 template <
typename number>
826 template <
typename number>
837 for (
int k = m - 2; k >= 0; --k)
846 for (
unsigned int j = 0; j < m; ++j)
855 template <
typename number>
856 template <
typename Number2>
859 const unsigned int n_derivatives,
860 Number2 *values)
const
864 reinterpret_cast<std::array<Number2, 1ul> *
>(values));
869 template <
typename number>
870 template <std::
size_t n_entries,
typename Number2>
877 const std::array<Number2, n_entries> &x,
878 const unsigned int n_derivatives,
879 std::array<Number2, n_entries> *values)
const
889 switch (n_derivatives)
892 for (
unsigned int e = 0; e < n_entries; ++e)
893 values[0][e] = weight;
894 for (
unsigned int k = 1; k <= n_derivatives; ++k)
895 for (
unsigned int e = 0; e < n_entries; ++e)
897 for (
unsigned int i = 0; i < n_supp; ++i)
899 std::array<Number2, n_entries> v = x;
900 for (
unsigned int e = 0; e < n_entries; ++e)
909 for (
unsigned int k = n_derivatives; k > 0; --k)
910 for (
unsigned int e = 0; e < n_entries; ++e)
911 values[k][e] = (values[k][e] * v[e] + values[k - 1][e]);
912 for (
unsigned int e = 0; e < n_entries; ++e)
913 values[0][e] *= v[e];
918 number k_factorial = 2;
919 for (
unsigned int k = 2; k <= n_derivatives; ++k)
921 for (
unsigned int e = 0; e < n_entries; ++e)
922 values[k][e] *= k_factorial;
923 k_factorial *=
static_cast<number
>(k + 1);
935 std::array<Number2, n_entries>
value;
936 for (
unsigned int e = 0; e < n_entries; ++e)
938 for (
unsigned int i = 0; i < n_supp; ++i)
939 for (
unsigned int e = 0; e < n_entries; ++e)
942 for (
unsigned int e = 0; e < n_entries; ++e)
943 values[0][e] =
value[e];
950 for (
unsigned int e = 0; e < n_entries; ++e)
952 for (
unsigned int i = 0; i < n_supp; ++i)
953 for (
unsigned int e = 0; e < n_entries; ++e)
960 for (
unsigned int e = 0; e < n_entries; ++e)
962 values[0][e] =
value[e];
972 for (
unsigned int e = 0; e < n_entries; ++e)
974 for (
unsigned int i = 0; i < n_supp; ++i)
975 for (
unsigned int e = 0; e < n_entries; ++e)
983 for (
unsigned int e = 0; e < n_entries; ++e)
985 values[0][e] =
value[e];
987 values[2][e] =
static_cast<number
>(2) * second[e];
1000 std::vector<std::array<Number2, n_entries>> a(
coefficients.size());
1002 for (
unsigned int e = 0; e < n_entries; ++e)
1005 unsigned int j_factorial = 1;
1010 const unsigned int min_valuessize_m =
std::min(n_derivatives + 1, m);
1011 for (
unsigned int j = 0; j < min_valuessize_m; ++j)
1013 for (
int k = m - 2; k >=
static_cast<int>(j); --k)
1014 for (
unsigned int e = 0; e < n_entries; ++e)
1015 a[k][e] += x[e] * a[k + 1][e];
1016 for (
unsigned int e = 0; e < n_entries; ++e)
1017 values[j][e] =
static_cast<number
>(j_factorial) * a[j][e];
1019 j_factorial *= j + 1;
1023 for (
unsigned int j = min_valuessize_m; j <= n_derivatives; ++j)
1024 for (
unsigned int e = 0; e < n_entries; ++e)
1030 template <
typename number>
1031 template <
class Archive>
1045 template <
typename Number>
1052 Assert(alpha >= 0 && beta >= 0,
1059 const Number xeval = Number(-1) + 2. * x;
1065 p1 = ((alpha + beta + 2) * xeval + (alpha - beta)) / 2;
1069 for (
unsigned int i = 1; i < degree; ++i)
1071 const Number v = 2 * i + (alpha + beta);
1072 const Number a1 = 2 * (i + 1) * (i + (alpha + beta + 1)) * v;
1073 const Number a2 = (v + 1) * (alpha * alpha - beta * beta);
1074 const Number a3 = v * (v + 1) * (v + 2);
1075 const Number a4 = 2 * (i + alpha) * (i + beta) * (v + 2);
1077 const Number pn = ((a2 + a3 * xeval) * p1 - a4 * p0) / a1;
1086 template <
typename Number>
1092 std::vector<Number> x(degree, 0.5);
1103 const Number tolerance =
1104 4 *
std::max(
static_cast<Number
>(std::numeric_limits<double>::epsilon()),
1105 std::numeric_limits<Number>::epsilon());
1113 const unsigned int n_points = (alpha == beta ? degree / 2 : degree);
1114 for (
unsigned int k = 0; k < n_points; ++k)
1118 Number r = 0.5 - 0.5 *
std::cos(
static_cast<Number
>(2 * k + 1) /
1121 r = (r + x[k - 1]) / 2;
1124 for (
unsigned int it = 1; it < 1000; ++it)
1127 for (
unsigned int i = 0; i < k; ++i)
1128 s += 1. / (r - x[i]);
1132 (alpha + beta + degree + 1) *
1137 const Number delta = f / (f * s - J_x);
1145 if (it == converged + 1)
1150 ExcMessage(
"Newton iteration for zero of Jacobi polynomial "
1151 "did not converge."));
1157 for (
unsigned int k = n_points; k < degree; ++k)
1158 x[k] = 1.0 - x[degree - k - 1];
HermiteInterpolation(const unsigned int p)
static std::vector< Polynomial< double > > generate_complete_basis(const unsigned int p)
static std::vector< Polynomial< double > > generate_complete_basis(const unsigned int degree)
HermiteLikeInterpolation(const unsigned int degree, const unsigned int index)
static std::vector< std::unique_ptr< const std::vector< double > > > recursive_coefficients
Hierarchical(const unsigned int p)
static void compute_coefficients(const unsigned int p)
static const std::vector< double > & get_coefficients(const unsigned int p)
static std::vector< Polynomial< double > > generate_complete_basis(const unsigned int degree)
static std::shared_mutex coefficients_lock
static void compute_coefficients(const unsigned int n, const unsigned int support_point, std::vector< double > &a)
LagrangeEquidistant(const unsigned int n, const unsigned int support_point)
static std::vector< Polynomial< double > > generate_complete_basis(const unsigned int degree)
static std::vector< Polynomial< double > > generate_complete_basis(const unsigned int degree)
Legendre(const unsigned int p)
std::vector< double > compute_coefficients(const unsigned int p)
Lobatto(const unsigned int p=0)
static std::vector< Polynomial< double > > generate_complete_basis(const unsigned int p)
static std::vector< Polynomial< number > > generate_complete_basis(const unsigned int degree)
Monomial(const unsigned int n, const double coefficient=1.)
static std::vector< number > make_vector(unsigned int n, const double coefficient)
Polynomial(const std::vector< number > &coefficients)
number value(const number x) const
bool operator==(const Polynomial< number > &p) const
std::vector< number > coefficients
Polynomial< number > primitive() const
Polynomial< number > & operator+=(const Polynomial< number > &p)
void values_of_array(const std::array< Number2, n_entries > &points, const unsigned int n_derivatives, std::array< Number2, n_entries > *values) const
Polynomial< number > derivative() const
void transform_into_standard_form()
void scale(const number factor)
Polynomial< number > & operator-=(const Polynomial< number > &p)
std::vector< number > lagrange_support_points
void shift(const number2 offset)
void print(std::ostream &out) const
bool in_lagrange_product_form
void serialize(Archive &ar, const unsigned int version)
static void multiply(std::vector< number > &coefficients, const number factor)
Polynomial< number > & operator*=(const double s)
virtual std::size_t memory_consumption() const
unsigned int degree() const
#define DEAL_II_ALWAYS_INLINE
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
static ::ExceptionBase & ExcNotImplemented()
static ::ExceptionBase & ExcEmptyObject()
#define Assert(cond, exc)
static ::ExceptionBase & ExcMessage(std::string arg1)
const bool IsBlockVector< VectorType >::value
Number jacobi_polynomial_value(const unsigned int degree, const int alpha, const int beta, const Number x)
std::vector< Polynomial< double > > generate_complete_Lagrange_basis(const std::vector< Point< 1 > > &points)
std::vector< Number > jacobi_polynomial_roots(const unsigned int degree, const int alpha, const int beta)
constexpr unsigned int invalid_unsigned_int
::VectorizedArray< Number, width > min(const ::VectorizedArray< Number, width > &, const ::VectorizedArray< Number, width > &)
::VectorizedArray< Number, width > max(const ::VectorizedArray< Number, width > &, const ::VectorizedArray< Number, width > &)
::VectorizedArray< Number, width > cos(const ::VectorizedArray< Number, width > &)
::VectorizedArray< Number, width > abs(const ::VectorizedArray< Number, width > &)