100 FETools::compute_face_embedding_matrices<dim, double>(*
this,
139 namebuf <<
"FE_RaviartThomas<" << dim <<
">(" << this->degree - 1 <<
")";
146std::unique_ptr<FiniteElement<dim, dim>>
149 return std::make_unique<FE_RaviartThomas<dim>>(*this);
168 const unsigned int face_no = 0;
172 for (
unsigned int d = 1; d < dim; ++d)
176 this->generalized_support_points.resize(
193 this->generalized_face_support_points[
face_no][
k] =
198 for (
unsigned int i = 0; i < legendre.n(); ++i)
200 boundary_weights(
k, i) =
214 this->generalized_support_points[
current] = faces.point(
217 this->reference_cell(), 0,
true,
false,
false,
n_face_points));
225 std::unique_ptr<AnisotropicPolynomials<dim>> polynomials[dim];
226 for (
unsigned int dd = 0;
dd < dim; ++
dd)
228 std::vector<std::vector<Polynomials::Polynomial<double>>> poly(dim);
229 for (
unsigned int d = 0; d < dim; ++d)
233 polynomials[
dd] = std::make_unique<AnisotropicPolynomials<dim>>(poly);
236 interior_weights.reinit(
239 for (
unsigned int k = 0;
k < cell_quadrature.
size(); ++
k)
241 this->generalized_support_points[
current++] = cell_quadrature.point(
k);
242 for (
unsigned int i = 0; i < polynomials[0]->n(); ++i)
243 for (
unsigned int d = 0; d < dim; ++d)
244 interior_weights(
k, i, d) =
245 cell_quadrature.weight(
k) *
246 polynomials[d]->compute_value(i, cell_quadrature.point(
k));
270 const unsigned int face_no = 0;
273 this->adjust_quad_dof_index_for_face_orientation_table[0].
n_elements() ==
274 this->reference_cell().n_face_orientations(
face_no) *
275 this->n_dofs_per_quad(
face_no),
279 const unsigned int n = this->tensor_degree();
351 if (((!face_orientation) && (!face_rotation)) ||
352 ((face_orientation) && (face_rotation)))
356 this->adjust_quad_dof_index_for_face_orientation_table[
face_no](
362 this->adjust_quad_dof_index_for_face_orientation_table[
face_no](
369 this->adjust_quad_dof_index_for_face_orientation_table[
face_no](
380 if (!face_flip && face_rotation)
382 this->adjust_quad_dof_sign_for_face_orientation_table[
face_no](
386 else if (face_flip && !face_rotation)
390 this->adjust_quad_dof_sign_for_face_orientation_table[
face_no](
394 else if (face_flip && face_rotation)
396 this->adjust_quad_dof_sign_for_face_orientation_table[
face_no](
406 if (!face_orientation)
407 this->adjust_quad_dof_sign_for_face_orientation_table[
face_no](
409 !this->adjust_quad_dof_sign_for_face_orientation_table[
face_no](
424 this->restriction[0][i].
reinit(0, 0);
463 for (
unsigned int i = 0; i < this->n_dofs_per_cell(); ++i)
475 this->reference_cell(),
q_base, face,
sub);
494 for (
unsigned int i_face = 0;
495 i_face < this->n_dofs_per_face(face);
503 this->restriction[
iso][child](
505 Utilities::fixed_power<dim - 1>(.5) *
q_sub.weight(
k) *
507 this->shape_value_component(
508 face * this->n_dofs_per_face(face) +
i_face,
515 if (this->degree == 1)
520 std::unique_ptr<AnisotropicPolynomials<dim>> polynomials[dim];
521 for (
unsigned int dd = 0;
dd < dim; ++
dd)
523 std::vector<std::vector<Polynomials::Polynomial<double>>> poly(dim);
524 for (
unsigned int d = 0; d < dim; ++d)
530 polynomials[
dd] = std::make_unique<AnisotropicPolynomials<dim>>(poly);
536 const unsigned int face_no = 0;
549 for (
unsigned int i = 0; i < this->n_dofs_per_cell(); ++i)
550 for (
unsigned int d = 0; d < dim; ++d)
552 this->shape_value_component(i,
q_cell.point(
k), d);
565 for (
unsigned int d = 0; d < dim; ++d)
581std::vector<unsigned int>
586 unsigned int dofs_per_face = 1;
587 for (
unsigned int d = 1; d < dim; ++d)
588 dofs_per_face *=
deg + 1;
593 std::vector<unsigned int>
dpo(dim + 1);
594 dpo[dim - 1] = dofs_per_face;
603std::pair<Table<2, bool>, std::vector<unsigned int>>
607 for (
unsigned int d = 0; d < dim; ++d)
608 for (
unsigned int i = 0; i < this->n_dofs_per_cell(); ++i)
609 constant_modes(d, i) =
true;
610 std::vector<unsigned int> components;
611 for (
unsigned int d = 0; d < dim; ++d)
612 components.push_back(d);
613 return std::pair<Table<2, bool>, std::vector<unsigned int>>(constant_modes,
627 const unsigned int face_index)
const
635 switch (this->degree)
648 return (face_index !=
674 this->generalized_support_points.
size()));
679 this->n_components()));
686 for (
unsigned int i = 0; i < boundary_weights.size(1); ++i)
689 boundary_weights(
k, i) *
697 const unsigned int face_no = 0;
704 for (
unsigned int k = 0;
k < interior_weights.
size(0); ++
k)
705 for (
unsigned int i = 0; i < interior_weights.size(1); ++i)
706 for (
unsigned int d = 0; d < dim; ++d)
708 interior_weights(
k, i, d) *
725#include "fe_raviart_thomas.inst"
void reinit(value_type *starting_element, const std::size_t n_elements)
FullMatrix< double > inverse_node_matrix
std::vector< MappingKind > mapping_kind
virtual std::size_t memory_consumption() 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 bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const override
void initialize_restriction()
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const override
void initialize_quad_dof_index_permutation_and_sign_change()
virtual std::unique_ptr< FiniteElement< dim, dim > > clone() const override
friend class FE_RaviartThomas
void initialize_support_points(const unsigned int rt_degree)
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
virtual std::string get_name() const override
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 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)
bool get_bit(const unsigned char number, const unsigned int n)
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()