147 namebuf <<
"FE_ABF<" << dim <<
">(" << rt_order <<
")";
155std::unique_ptr<FiniteElement<dim, dim>>
158 return std::make_unique<FE_ABF<dim>>(rt_order);
179 const unsigned int face_no = 0;
183 for (
unsigned int d = 1; d < dim; ++d)
186 this->generalized_support_points.resize(
193 std::array<std::unique_ptr<AnisotropicPolynomials<dim>>, dim>
polynomials_abf;
196 for (
unsigned int dd = 0;
dd < dim; ++
dd)
198 std::vector<std::vector<Polynomials::Polynomial<double>>> poly(dim);
199 for (
unsigned int d = 0; d < dim; ++d)
222 this->generalized_face_support_points[
face_no][
k] =
227 for (
unsigned int i = 0; i < legendre.n(); ++i)
229 boundary_weights(
k, i) =
253 for (
unsigned int k = 0;
k < faces.
size(); ++
k)
257 boundary_weights_abf(
k, i) =
269 std::array<std::unique_ptr<AnisotropicPolynomials<dim>>, dim> polynomials;
271 for (
unsigned int dd = 0;
dd < dim; ++
dd)
273 std::vector<std::vector<Polynomials::Polynomial<double>>> poly(dim);
274 for (
unsigned int d = 0; d < dim; ++d)
278 polynomials[
dd] = std::make_unique<AnisotropicPolynomials<dim>>(poly);
281 interior_weights.reinit(
284 for (
unsigned int k = 0;
k < cell_quadrature.
size(); ++
k)
286 for (
unsigned int i = 0; i < polynomials[0]->n(); ++i)
287 for (
unsigned int d = 0; d < dim; ++d)
288 interior_weights(
k, i, d) =
289 cell_quadrature.weight(
k) *
290 polynomials[d]->compute_value(i, cell_quadrature.point(
k));
297 for (
unsigned int k = 0;
k < cell_quadrature.
size(); ++
k)
298 this->generalized_support_points[
current++] = cell_quadrature.point(
k);
309 for (
unsigned int k = 0;
k < cell_quadrature.
size(); ++
k)
315 cell_quadrature.point(
k)) *
316 cell_quadrature.weight(
k);
319 for (
unsigned int d = 0; d < dim; ++d)
320 interior_weights_abf(
k, i, d) = -
poly_grad[d];
371 for (
unsigned int i = 0; i < this->n_dofs_per_cell(); ++i)
383 this->reference_cell(),
q_base, face,
sub);
402 for (
unsigned int i_face = 0;
403 i_face < this->n_dofs_per_face(face);
411 this->restriction[
iso][child](
413 Utilities::fixed_power<dim - 1>(.5) *
q_sub.weight(
k) *
415 this->shape_value_component(
416 face * this->n_dofs_per_face(face) +
i_face,
429 std::array<std::unique_ptr<AnisotropicPolynomials<dim>>, dim> polynomials;
430 for (
unsigned int dd = 0;
dd < dim; ++
dd)
432 std::vector<std::vector<Polynomials::Polynomial<double>>> poly(dim);
433 for (
unsigned int d = 0; d < dim; ++d)
437 polynomials[
dd] = std::make_unique<AnisotropicPolynomials<dim>>(poly);
443 const unsigned int face_no = 0;
456 for (
unsigned int i = 0; i < this->n_dofs_per_cell(); ++i)
457 for (
unsigned int d = 0; d < dim; ++d)
459 this->shape_value_component(i,
q_cell.point(
k), d);
472 for (
unsigned int d = 0; d < dim; ++d)
488std::vector<unsigned int>
494 return std::vector<unsigned int>();
502 unsigned int dofs_per_face = 1;
503 for (
unsigned int d = 0; d < dim - 1; ++d)
504 dofs_per_face *= rt_order + 1;
507 const unsigned int interior_dofs = dim * (rt_order + 1) * dofs_per_face;
509 std::vector<unsigned int>
dpo(dim + 1);
510 dpo[dim - 1] = dofs_per_face;
523 const unsigned int face_index)
const
544 return (face_index !=
570 this->generalized_support_points.
size()));
573 this->n_components()));
582 for (
unsigned int i = 0; i < boundary_weights.size(1); ++i)
585 boundary_weights(
k, i) *
587 dim>::unit_normal_direction[face]];
593 const unsigned int face_no = 0;
600 for (
unsigned int k = 0;
k < interior_weights.
size(0); ++
k)
601 for (
unsigned int i = 0; i < interior_weights.size(1); ++i)
602 for (
unsigned int d = 0; d < dim; ++d)
604 interior_weights(
k, i, d) *
611 for (
unsigned int k = 0;
k < interior_weights_abf.
size(0); ++
k)
612 for (
unsigned int i = 0; i < interior_weights_abf.size(1); ++i)
613 for (
unsigned int d = 0; d < dim; ++d)
615 interior_weights_abf(
k, i, d) *
627 this->reference_cell(), face,
false,
false,
false,
n_face_points);
628 for (
unsigned int i = 0; i < boundary_weights_abf.size(1); ++i)
632 dim>::unit_normal_direction[face]];
637 for (
unsigned int i = 0; i < boundary_weights_abf.size(1); ++i)
655#include "fe_abf.inst"
void reinit(value_type *starting_element, const std::size_t n_elements)
void initialize_quad_dof_index_permutation_and_sign_change()
virtual std::unique_ptr< FiniteElement< dim, dim > > clone() const override
virtual void convert_generalized_support_point_values_to_dof_values(const std::vector< Vector< double > > &support_point_values, std::vector< double > &nodal_values) const override
virtual std::size_t memory_consumption() const override
void initialize_restriction()
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const override
virtual std::string get_name() const override
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
void initialize_support_points(const unsigned int rt_degree)
FullMatrix< double > inverse_node_matrix
std::vector< MappingKind > mapping_kind
unsigned int n_dofs_per_cell() const
unsigned int n_dofs_per_face(unsigned int face_no=0, unsigned int child=0) const
unsigned int n_unique_faces() const
void reinit_restriction_and_prolongation_matrices(const bool isotropic_restriction_only=false, const bool isotropic_prolongation_only=false)
FullMatrix< double > interface_constraints
std::vector< std::vector< FullMatrix< double > > > prolongation
void invert(const FullMatrix< number2 > &M)
static std::vector< Polynomial< double > > generate_complete_basis(const unsigned int degree)
static std::vector< Polynomial< number > > generate_complete_basis(const unsigned int degree)
static DataSetDescriptor face(const ReferenceCell &reference_cell, const unsigned int face_no, const bool face_orientation, const bool face_flip, const bool face_rotation, const unsigned int n_quadrature_points)
static Quadrature< dim > project_to_child(const ReferenceCell &reference_cell, const Quadrature< dim > &quadrature, const unsigned int child_no)
static Quadrature< dim > project_to_all_faces(const ReferenceCell &reference_cell, const hp::QCollection< dim - 1 > &quadrature)
static void project_to_subface(const ReferenceCell &reference_cell, const SubQuadrature &quadrature, const unsigned int face_no, const unsigned int subface_no, std::vector< Point< dim > > &q_points, const RefinementCase< dim - 1 > &ref_case=RefinementCase< dim - 1 >::isotropic_refinement)
static void project_to_face(const ReferenceCell &reference_cell, const SubQuadrature &quadrature, const unsigned int face_no, std::vector< Point< dim > > &q_points)
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
static ::ExceptionBase & ExcNotImplemented()
#define Assert(cond, exc)
static ::ExceptionBase & ExcImpossibleInDim(int arg1)
#define AssertDimension(dim1, dim2)
#define AssertIndexRange(index, range)
static ::ExceptionBase & ExcInternalError()
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
static unsigned int child_cell_on_face(const RefinementCase< dim > &ref_case, const unsigned int face, const unsigned int subface, const bool face_orientation=true, const bool face_flip=false, const bool face_rotation=false, const RefinementCase< dim - 1 > &face_refinement_case=RefinementCase< dim - 1 >::isotropic_refinement)
static std_cxx20::ranges::iota_view< unsigned int, unsigned int > face_indices()