17 #ifndef __deal2__fe_q_base_h 18 #define __deal2__fe_q_base_h 20 #include <deal.II/base/config.h> 21 #include <deal.II/fe/fe_poly.h> 22 #include <deal.II/base/thread_management.h> 37 template <
class POLY,
int dim=POLY::dimension,
int spacedim=dim>
86 const unsigned int subface,
98 const unsigned int face_index)
const;
193 const unsigned int face,
194 const bool face_orientation =
true,
195 const bool face_flip =
false,
196 const bool face_rotation =
false)
const;
231 std::vector<std::pair<unsigned int, unsigned int> >
239 std::vector<std::pair<unsigned int, unsigned int> >
247 std::vector<std::pair<unsigned int, unsigned int> >
309 struct Implementation;
314 friend struct FE_Q_Base<POLY,dim,spacedim>::Implementation;
326 DEAL_II_NAMESPACE_CLOSE
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual unsigned int face_to_cell_index(const unsigned int face_dof_index, const unsigned int face, const bool face_orientation=true, const bool face_flip=false, const bool face_rotation=false) const
const unsigned int degree
virtual const FullMatrix< double > & get_prolongation_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual const FullMatrix< double > & get_restriction_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const
virtual bool hp_constraints_are_implemented() const
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const
void initialize_constraints(const std::vector< Point< 1 > > &points)
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const
FE_Q_Base(const POLY &poly_space, const FiniteElementData< dim > &fe_data, const std::vector< bool > &restriction_is_additive_flags)
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
void initialize_quad_dof_index_permutation()
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
void initialize(const std::vector< Point< 1 > > &support_points_1d)
void initialize_unit_face_support_points(const std::vector< Point< 1 > > &points)
void initialize_unit_support_points(const std::vector< Point< 1 > > &points)
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
const std::vector< bool > restriction_is_additive_flags