16 #ifndef dealii__fe_dgq_h 17 #define dealii__fe_dgq_h 19 #include <deal.II/base/config.h> 20 #include <deal.II/base/tensor_product_polynomials.h> 21 #include <deal.II/base/thread_management.h> 22 #include <deal.II/fe/fe_poly.h> 24 DEAL_II_NAMESPACE_OPEN
26 template <
int dim,
int spacedim>
class MappingQ;
80 template <
int dim,
int spacedim=dim>
81 class FE_DGQ :
public FE_Poly<TensorProductPolynomials<dim>, dim, spacedim>
90 FE_DGQ (
const unsigned int p);
97 virtual std::string
get_name ()
const;
140 const unsigned int subface,
213 std::vector<std::pair<unsigned int, unsigned int> >
224 std::vector<std::pair<unsigned int, unsigned int> >
235 std::vector<std::pair<unsigned int, unsigned int> >
270 const unsigned int face_index)
const;
276 virtual std::pair<Table<2,bool>, std::vector<unsigned int> >
334 const char direction)
const;
344 template <
int dim1,
int spacedim1>
friend class FE_DGQ;
349 template <
int dim1,
int spacedim1>
friend class MappingQ;
369 template <
int dim,
int spacedim=dim>
386 virtual std::string
get_name ()
const;
400 DEAL_II_NAMESPACE_CLOSE
virtual FiniteElement< dim, spacedim > * clone() const
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const
const unsigned int degree
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
virtual std::size_t memory_consumption() const
virtual const FullMatrix< double > & get_prolongation_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const
virtual const FullMatrix< double > & get_restriction_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
void rotate_indices(std::vector< unsigned int > &indices, const char direction) const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
virtual bool hp_constraints_are_implemented() const
virtual std::string get_name() const