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
fe_raviart_thomas.h
Go to the documentation of this file.
1// ------------------------------------------------------------------------
2//
3// SPDX-License-Identifier: LGPL-2.1-or-later
4// Copyright (C) 2003 - 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_fe_raviart_thomas_h
16#define dealii_fe_raviart_thomas_h
17
18#include <deal.II/base/config.h>
19
20#include <deal.II/base/mutex.h>
21#include <deal.II/base/table.h>
22
23#include <deal.II/fe/fe.h>
25
26#include <vector>
27
29
34
126template <int dim>
128{
129public:
133 FE_RaviartThomas(const unsigned int p);
134
140 virtual std::string
141 get_name() const override;
142
143 // documentation inherited from the base class
144 virtual std::unique_ptr<FiniteElement<dim, dim>>
145 clone() const override;
146
151 static std::vector<unsigned int>
152 get_lexicographic_numbering(const unsigned int degree);
153
161 virtual bool
162 has_support_on_face(const unsigned int shape_index,
163 const unsigned int face_index) const override;
164
165 // documentation inherited from the base class
166 virtual void
168 const std::vector<Vector<double>> &support_point_values,
169 std::vector<double> &nodal_values) const override;
170
175 virtual std::pair<Table<2, bool>, std::vector<unsigned int>>
176 get_constant_modes() const override;
177
178 virtual std::size_t
179 memory_consumption() const override;
180
181private:
188 static std::vector<unsigned int>
189 get_dpo_vector(const unsigned int degree);
190
196 void
197 initialize_support_points(const unsigned int rt_degree);
198
205 void
207
219
227
301 void
303
304 // Allow access from other dimensions.
305 template <int dim1>
306 friend class FE_RaviartThomas;
307};
308
309
310
341template <int dim>
343{
344public:
348 FE_RaviartThomasNodal(const unsigned int p);
349
355 virtual std::string
356 get_name() const override;
357
358 // documentation inherited from the base class
359 virtual std::unique_ptr<FiniteElement<dim, dim>>
360 clone() const override;
361
362 virtual void
364 FullMatrix<double> &matrix,
365 const unsigned int face_no = 0) const override;
366
367 virtual void
369 const FiniteElement<dim> &source,
370 const unsigned int subface,
371 FullMatrix<double> &matrix,
372 const unsigned int face_no = 0) const override;
373
374 virtual void
376 const std::vector<Vector<double>> &support_point_values,
377 std::vector<double> &nodal_values) const override;
378
379 virtual bool
380 hp_constraints_are_implemented() const override;
381
382 virtual std::vector<std::pair<unsigned int, unsigned int>>
383 hp_vertex_dof_identities(const FiniteElement<dim> &fe_other) const override;
384
385 virtual std::vector<std::pair<unsigned int, unsigned int>>
386 hp_line_dof_identities(const FiniteElement<dim> &fe_other) const override;
387
388 virtual std::vector<std::pair<unsigned int, unsigned int>>
390 const unsigned int face_no = 0) const override;
391
397 const unsigned int codim = 0) const override final;
398
399 virtual const FullMatrix<double> &
401 const unsigned int child,
402 const RefinementCase<dim> &refinement_case =
404
405 virtual const FullMatrix<double> &
407 const unsigned int child,
408 const RefinementCase<dim> &refinement_case =
410
411private:
416 virtual bool
417 has_support_on_face(const unsigned int shape_index,
418 const unsigned int face_index) const override;
419
423 void
425
432};
433
435
436/* -------------- declaration of explicit specializations ------------- */
437
438#ifndef DOXYGEN
439
440template <>
441void
443
444#endif // DOXYGEN
445
447
448#endif
FE_PolyTensor(const TensorPolynomialsBase< dim > &polynomials, const FiniteElementData< dim > &fe_data, const std::vector< bool > &restriction_is_additive_flags, const std::vector< ComponentMask > &nonzero_components)
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 bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const override
Threads::Mutex restriction_matrix_mutex
virtual const FullMatrix< double > & get_restriction_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const override
void initialize_quad_dof_index_permutation_and_sign_change()
Threads::Mutex prolongation_matrix_mutex
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim > &fe_other) const override
virtual void get_face_interpolation_matrix(const FiniteElement< dim > &source, FullMatrix< double > &matrix, const unsigned int face_no=0) const override
virtual std::string get_name() const override
virtual bool hp_constraints_are_implemented() const override
virtual void get_subface_interpolation_matrix(const FiniteElement< dim > &source, const unsigned int subface, FullMatrix< double > &matrix, const unsigned int face_no=0) const override
virtual FiniteElementDomination::Domination compare_for_domination(const FiniteElement< dim > &fe_other, const unsigned int codim=0) const override final
virtual const FullMatrix< double > & get_prolongation_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const override
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim > &fe_other) const override
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim > &fe_other, const unsigned int face_no=0) const override
FE_RaviartThomasNodal(const unsigned int p)
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
Table< 3, double > interior_weights
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const override
Table< 2, double > boundary_weights
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
static std::vector< unsigned int > get_lexicographic_numbering(const unsigned int degree)
const unsigned int degree
Definition fe_data.h:452
FiniteElement(const FiniteElementData< dim > &fe_data, const std::vector< bool > &restriction_is_additive_flags, const std::vector< ComponentMask > &nonzero_components)
#define DEAL_II_NAMESPACE_OPEN
Definition config.h:40
#define DEAL_II_NAMESPACE_CLOSE
Definition config.h:41