deal.II version 9.7.0
\(\newcommand{\dealvcentcolon}{\mathrel{\mathop{:}}}\) \(\newcommand{\dealcoloneq}{\dealvcentcolon\mathrel{\mkern-1.2mu}=}\) \(\newcommand{\jump}[1]{\left[\!\left[ #1 \right]\!\right]}\) \(\newcommand{\average}[1]{\left\{\!\left\{ #1 \right\}\!\right\}}\)
Loading...
Searching...
No Matches
polynomials_vector_anisotropic.h
Go to the documentation of this file.
1// ------------------------------------------------------------------------
2//
3// SPDX-License-Identifier: LGPL-2.1-or-later
4// Copyright (C) 2004 - 2025 by the deal.II authors
5//
6// This file is part of the deal.II library.
7//
8// Part of the source code is dual licensed under Apache-2.0 WITH
9// LLVM-exception OR LGPL-2.1-or-later. Detailed license information
10// governing the source code and code contributions can be found in
11// LICENSE.md and CONTRIBUTING.md at the top level directory of deal.II.
12//
13// ------------------------------------------------------------------------
14
15#ifndef dealii_polynomials_vector_anisotropic_h
16#define dealii_polynomials_vector_anisotropic_h
17
18
19#include <deal.II/base/config.h>
20
22#include <deal.II/base/point.h>
25#include <deal.II/base/tensor.h>
28
29#include <mutex>
30#include <vector>
31
32
34
46template <int dim>
48{
49public:
56 const unsigned int degree_normal,
57 const unsigned int degree_tangential,
58 const std::vector<unsigned int> &polynomial_ordering);
59
64 default;
65
74 void
75 evaluate(const Point<dim> &unit_point,
76 std::vector<Tensor<1, dim>> &values,
77 std::vector<Tensor<2, dim>> &grads,
78 std::vector<Tensor<3, dim>> &grad_grads,
79 std::vector<Tensor<4, dim>> &third_derivatives,
80 std::vector<Tensor<5, dim>> &fourth_derivatives) const override;
81
86 std::string
87 name() const override;
88
94 static unsigned int
95 n_polynomials(const unsigned int normal_degree,
96 const unsigned int tangential_degree);
97
101 unsigned int
102 get_tangential_degree() const;
103
107 unsigned int
108 get_normal_degree() const;
109
113 virtual std::unique_ptr<TensorPolynomialsBase<dim>>
114 clone() const override;
115
123 std::vector<Point<dim>>
125
126private:
130 const unsigned int normal_degree;
131
135 const unsigned int tangential_degree;
136
143
149 std::vector<unsigned int> lexicographic_to_hierarchic;
150
155 std::vector<unsigned int> hierarchic_to_lexicographic;
156
160 std::array<std::vector<unsigned int>, dim> renumber_aniso;
161};
162
163
165
166#endif
Definition point.h:113
std::vector< unsigned int > hierarchic_to_lexicographic
std::array< std::vector< unsigned int >, dim > renumber_aniso
PolynomialsVectorAnisotropic(const unsigned int degree_normal, const unsigned int degree_tangential, const std::vector< unsigned int > &polynomial_ordering)
const AnisotropicPolynomials< dim > polynomial_space
std::vector< Point< dim > > get_polynomial_support_points() const
virtual std::unique_ptr< TensorPolynomialsBase< dim > > clone() const override
PolynomialsVectorAnisotropic(const PolynomialsVectorAnisotropic &other)=default
void evaluate(const Point< dim > &unit_point, std::vector< Tensor< 1, dim > > &values, std::vector< Tensor< 2, dim > > &grads, std::vector< Tensor< 3, dim > > &grad_grads, std::vector< Tensor< 4, dim > > &third_derivatives, std::vector< Tensor< 5, dim > > &fourth_derivatives) const override
std::vector< unsigned int > lexicographic_to_hierarchic
static unsigned int n_polynomials(const unsigned int normal_degree, const unsigned int tangential_degree)
TensorPolynomialsBase(const unsigned int deg, const unsigned int n_polynomials)
#define DEAL_II_NAMESPACE_OPEN
Definition config.h:40
#define DEAL_II_NAMESPACE_CLOSE
Definition config.h:41