16 #ifndef dealii_fe_face_h 17 #define dealii_fe_face_h 19 #include <deal.II/base/config.h> 21 #include <deal.II/base/polynomial_space.h> 22 #include <deal.II/base/tensor_product_polynomials.h> 24 #include <deal.II/fe/fe_poly_face.h> 26 DEAL_II_NAMESPACE_OPEN
56 template <
int dim,
int spacedim = dim>
58 :
public FE_PolyFace<TensorProductPolynomials<dim - 1>, dim, spacedim>
68 virtual std::unique_ptr<FiniteElement<dim, spacedim>>
69 clone()
const override;
89 std::vector<double> & nodal_values)
const override;
113 const unsigned int subface,
122 const unsigned int face_index)
const override;
146 virtual std::vector<std::pair<unsigned int, unsigned int>>
156 virtual std::vector<std::pair<unsigned int, unsigned int>>
166 virtual std::vector<std::pair<unsigned int, unsigned int>>
197 virtual std::pair<Table<2, bool>, std::vector<unsigned int>>
204 static std::vector<unsigned int>
222 template <
int spacedim>
231 virtual std::unique_ptr<FiniteElement<1, spacedim>>
232 clone()
const override;
268 const unsigned int subface,
277 const unsigned int face_index)
const override;
303 virtual std::vector<std::pair<unsigned int, unsigned int>>
313 virtual std::vector<std::pair<unsigned int, unsigned int>>
323 virtual std::vector<std::pair<unsigned int, unsigned int>>
344 virtual std::pair<Table<2, bool>, std::vector<unsigned int>>
355 virtual std::unique_ptr<typename FiniteElement<1, spacedim>::InternalDataBase>
364 return std_cxx14::make_unique<
368 std::unique_ptr<typename FiniteElement<1, spacedim>::InternalDataBase>
378 auto data = std_cxx14::make_unique<
382 const unsigned int n_q_points = quadrature.
size();
393 return std::move(data);
396 std::unique_ptr<typename FiniteElement<1, spacedim>::InternalDataBase>
403 &output_data)
const override 405 return get_face_data(update_flags, mapping, quadrature, output_data);
415 const ::internal::FEValuesImplementation::MappingRelatedData<1,
421 &output_data)
const override;
426 const unsigned int face_no,
430 const ::internal::FEValuesImplementation::MappingRelatedData<1,
436 &output_data)
const override;
439 fill_fe_subface_values(
441 const unsigned int face_no,
442 const unsigned int sub_no,
446 const ::internal::FEValuesImplementation::MappingRelatedData<1,
452 &output_data)
const override;
458 static std::vector<unsigned int>
488 template <
int dim,
int spacedim = dim>
499 virtual std::unique_ptr<FiniteElement<dim, spacedim>>
500 clone()
const override;
532 const unsigned int subface,
541 const unsigned int face_index)
const override;
569 virtual std::pair<Table<2, bool>, std::vector<unsigned int>>
576 static std::vector<unsigned int>
586 template <
int spacedim>
603 DEAL_II_NAMESPACE_CLOSE
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const override
#define AssertDimension(dim1, dim2)
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const override
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override
std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_face_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &, const Quadrature< dim-1 > &quadrature,::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &) const override
unsigned int size() const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
#define Assert(cond, exc)
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags, const Mapping< dim, spacedim > &, const Quadrature< dim > &,::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &) const override
Abstract base class for mapping classes.
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const override
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const override
FE_FaceQ(const unsigned int p)
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual std::string get_name() const override
Second derivatives of shape functions.
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_subface_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim-1 > &quadrature,::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
Shape function gradients.
static std::vector< unsigned int > get_dpo_vector(const unsigned int deg)
static::ExceptionBase & ExcNotImplemented()
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) 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 hp_constraints_are_implemented() const override