Reference documentation for deal.II version 8.4.2
fe_dgq.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2001 - 2015 by the deal.II authors
4 //
5 // This file is part of the deal.II library.
6 //
7 // The deal.II library is free software; you can use it, redistribute
8 // it, and/or modify it under the terms of the GNU Lesser General
9 // Public License as published by the Free Software Foundation; either
10 // version 2.1 of the License, or (at your option) any later version.
11 // The full text of the license can be found in the file LICENSE at
12 // the top level of the deal.II distribution.
13 //
14 // ---------------------------------------------------------------------
15 
16 #ifndef dealii__fe_dgq_h
17 #define dealii__fe_dgq_h
18 
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>
23 
24 DEAL_II_NAMESPACE_OPEN
25 
26 template <int dim, int spacedim> class MappingQ;
27 template <int dim> class Quadrature;
28 
31 
80 template <int dim, int spacedim=dim>
81 class FE_DGQ : public FE_Poly<TensorProductPolynomials<dim>, dim, spacedim>
82 {
83 public:
90  FE_DGQ (const unsigned int p);
91 
97  virtual std::string get_name () const;
98 
108  virtual void
110  FullMatrix<double> &matrix) const;
111 
123  virtual void
125  FullMatrix<double> &matrix) const;
126 
138  virtual void
140  const unsigned int subface,
141  FullMatrix<double> &matrix) const;
142 
160  virtual const FullMatrix<double> &
161  get_restriction_matrix (const unsigned int child,
163 
185  virtual const FullMatrix<double> &
186  get_prolongation_matrix (const unsigned int child,
188 
212  virtual
213  std::vector<std::pair<unsigned int, unsigned int> >
215 
223  virtual
224  std::vector<std::pair<unsigned int, unsigned int> >
226 
234  virtual
235  std::vector<std::pair<unsigned int, unsigned int> >
237 
246  virtual bool hp_constraints_are_implemented () const;
247 
257  virtual
260 
269  virtual bool has_support_on_face (const unsigned int shape_index,
270  const unsigned int face_index) const;
271 
276  virtual std::pair<Table<2,bool>, std::vector<unsigned int> >
277  get_constant_modes () const;
278 
287  virtual std::size_t memory_consumption () const;
288 
289 
290 protected:
300  FE_DGQ (const Quadrature<1> &points);
301 
307  virtual FiniteElement<dim, spacedim> *clone() const;
308 
309 private:
316  static std::vector<unsigned int> get_dpo_vector (const unsigned int degree);
317 
333  void rotate_indices (std::vector<unsigned int> &indices,
334  const char direction) const;
335 
336  /*
337  * Mutex for protecting initialization of restriction and embedding matrix.
338  */
339  mutable Threads::Mutex mutex;
340 
344  template <int dim1, int spacedim1> friend class FE_DGQ;
345 
349  template <int dim1, int spacedim1> friend class MappingQ;
350 };
351 
352 
353 
369 template <int dim,int spacedim=dim>
370 class FE_DGQArbitraryNodes : public FE_DGQ<dim,spacedim>
371 {
372 public:
379  FE_DGQArbitraryNodes (const Quadrature<1> &points);
380 
386  virtual std::string get_name () const;
387 
388 protected:
394  virtual FiniteElement<dim,spacedim> *clone() const;
395 };
396 
397 
400 DEAL_II_NAMESPACE_CLOSE
401 
402 #endif
virtual FiniteElement< dim, spacedim > * clone() const
Definition: fe_dgq.cc:236
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const
Definition: fe_dgq.cc:451
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const
Definition: fe_dgq.cc:664
Definition: fe_dgq.h:81
const unsigned int degree
Definition: fe_base.h:299
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
Definition: fe_dgq.cc:424
virtual std::size_t memory_consumption() const
Definition: fe_dgq.cc:776
virtual const FullMatrix< double > & get_prolongation_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const
Definition: fe_dgq.cc:479
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const
Definition: fe_dgq.cc:763
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
Definition: fe_dgq.cc:249
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const
Definition: fe_dgq.cc:676
virtual const FullMatrix< double > & get_restriction_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const
Definition: fe_dgq.cc:545
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
Definition: fe_dgq.cc:340
void rotate_indices(std::vector< unsigned int > &indices, const char direction) const
Definition: fe_dgq.cc:262
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
Definition: fe_dgq.cc:650
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
Definition: fe_dgq.cc:635
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const
Definition: fe_dgq.cc:620
friend class FE_DGQ
Definition: fe_dgq.h:344
virtual bool hp_constraints_are_implemented() const
Definition: fe_dgq.cc:610
virtual std::string get_name() const
Definition: fe_dgq.cc:216