Reference documentation for deal.II version 9.1.0-pre
fe_dgq.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2001 - 2018 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.md at
12 // the top level directory of deal.II.
13 //
14 // ---------------------------------------------------------------------
15 
16 #ifndef dealii_fe_dgq_h
17 #define dealii_fe_dgq_h
18 
19 #include <deal.II/base/config.h>
20 
21 #include <deal.II/base/tensor_product_polynomials.h>
22 #include <deal.II/base/thread_management.h>
23 
24 #include <deal.II/fe/fe_poly.h>
25 
26 DEAL_II_NAMESPACE_OPEN
27 
28 template <int dim, int spacedim>
29 class MappingQ;
30 template <int dim>
31 class Quadrature;
32 
35 
108 template <int dim, int spacedim = dim>
109 class FE_DGQ : public FE_Poly<TensorProductPolynomials<dim>, dim, spacedim>
110 {
111 public:
118  FE_DGQ(const unsigned int p);
119 
125  virtual std::string
126  get_name() const override;
127 
137  virtual void
139  FullMatrix<double> &matrix) const override;
140 
152  virtual void
154  FullMatrix<double> &matrix) const override;
155 
167  virtual void
169  const unsigned int subface,
170  FullMatrix<double> &matrix) const override;
171 
189  virtual const FullMatrix<double> &
191  const unsigned int child,
192  const RefinementCase<dim> &refinement_case =
194 
216  virtual const FullMatrix<double> &
218  const unsigned int child,
219  const RefinementCase<dim> &refinement_case =
221 
245  virtual std::vector<std::pair<unsigned int, unsigned int>>
247  const FiniteElement<dim, spacedim> &fe_other) const override;
248 
256  virtual std::vector<std::pair<unsigned int, unsigned int>>
258  const FiniteElement<dim, spacedim> &fe_other) const override;
259 
267  virtual std::vector<std::pair<unsigned int, unsigned int>>
269  const FiniteElement<dim, spacedim> &fe_other) const override;
270 
279  virtual bool
280  hp_constraints_are_implemented() const override;
281 
293  const FiniteElement<dim, spacedim> &fe_other) const override;
294 
303  virtual bool
304  has_support_on_face(const unsigned int shape_index,
305  const unsigned int face_index) const override;
306 
311  virtual std::pair<Table<2, bool>, std::vector<unsigned int>>
312  get_constant_modes() const override;
313 
321  virtual void
323  const std::vector<Vector<double>> &support_point_values,
324  std::vector<double> & nodal_values) const override;
325 
334  virtual std::size_t
335  memory_consumption() const override;
336 
337  virtual std::unique_ptr<FiniteElement<dim, spacedim>>
338  clone() const override;
339 
340 protected:
349  FE_DGQ(const std::vector<Polynomials::Polynomial<double>> &polynomials);
350 
351 private:
358  static std::vector<unsigned int>
359  get_dpo_vector(const unsigned int degree);
360 
377  void
378  rotate_indices(std::vector<unsigned int> &indices,
379  const char direction) const;
380 
381  /*
382  * Mutex for protecting initialization of restriction and embedding matrix.
383  */
384  mutable Threads::Mutex mutex;
385 
389  template <int dim1, int spacedim1>
390  friend class FE_DGQ;
391 
395  template <int dim1, int spacedim1>
396  friend class MappingQ;
397 };
398 
399 
400 
417 template <int dim, int spacedim = dim>
418 class FE_DGQArbitraryNodes : public FE_DGQ<dim, spacedim>
419 {
420 public:
427  FE_DGQArbitraryNodes(const Quadrature<1> &points);
428 
434  virtual std::string
435  get_name() const override;
436 
444  virtual void
446  const std::vector<Vector<double>> &support_point_values,
447  std::vector<double> & nodal_values) const override;
448  virtual std::unique_ptr<FiniteElement<dim, spacedim>>
449  clone() const override;
450 };
451 
452 
453 
464 template <int dim, int spacedim = dim>
465 class FE_DGQLegendre : public FE_DGQ<dim, spacedim>
466 {
467 public:
472  FE_DGQLegendre(const unsigned int degree);
473 
479  virtual std::pair<Table<2, bool>, std::vector<unsigned int>>
480  get_constant_modes() const override;
481 
488  virtual std::string
489  get_name() const override;
490 
491  virtual std::unique_ptr<FiniteElement<dim, spacedim>>
492  clone() const override;
493 };
494 
495 
496 
515 template <int dim, int spacedim = dim>
516 class FE_DGQHermite : public FE_DGQ<dim, spacedim>
517 {
518 public:
523  FE_DGQHermite(const unsigned int degree);
524 
531  virtual std::string
532  get_name() const override;
533 
534  virtual std::unique_ptr<FiniteElement<dim, spacedim>>
535  clone() const override;
536 };
537 
538 
541 DEAL_II_NAMESPACE_CLOSE
542 
543 #endif
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
Definition: fe_dgq.cc:589
virtual const FullMatrix< double > & get_prolongation_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const override
Definition: fe_dgq.cc:392
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const override
Definition: fe_dgq.cc:603
virtual bool hp_constraints_are_implemented() const override
Definition: fe_dgq.cc:552
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
Definition: fe_dgq.cc:561
Definition: fe_dgq.h:109
const unsigned int degree
Definition: fe_base.h:313
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const override
Definition: fe_dgq.cc:339
virtual std::size_t memory_consumption() const override
Definition: fe_dgq.cc:721
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const override
Definition: fe_dgq.cc:709
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
Definition: fe_dgq.cc:170
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
Definition: fe_dgq.cc:136
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const override
Definition: fe_dgq.cc:365
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override
Definition: fe_dgq.cc:157
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const override
Definition: fe_dgq.cc:616
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const override
Definition: fe_dgq.cc:260
void rotate_indices(std::vector< unsigned int > &indices, const char direction) const
Definition: fe_dgq.cc:183
virtual std::string get_name() const override
Definition: fe_dgq.cc:120
virtual const FullMatrix< double > & get_restriction_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const override
Definition: fe_dgq.cc:472
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
Definition: fe_dgq.cc:575
friend class FE_DGQ
Definition: fe_dgq.h:390