Reference documentation for deal.II version 9.1.0-pre
fe_bernstein.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2000 - 2017 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_bernstein_h
17 #define dealii_fe_bernstein_h
18 
19 #include <deal.II/base/config.h>
20 
21 #include <deal.II/base/tensor_product_polynomials.h>
22 
23 #include <deal.II/fe/fe_q_base.h>
24 
25 DEAL_II_NAMESPACE_OPEN
26 
27 
30 
66 template <int dim, int spacedim = dim>
68  : public FE_Q_Base<TensorProductPolynomials<dim>, dim, spacedim>
69 {
70 public:
74  FE_Bernstein(const unsigned int p);
75 
83  virtual void
85  FullMatrix<double> &matrix) const override;
86 
94  virtual const FullMatrix<double> &
96  const unsigned int child,
97  const RefinementCase<dim> &refinement_case =
99 
107  virtual const FullMatrix<double> &
109  const unsigned int child,
110  const RefinementCase<dim> &refinement_case =
112 
122  virtual void
124  FullMatrix<double> &matrix) const override;
125 
135  virtual void
137  const unsigned int subface,
138  FullMatrix<double> &matrix) const override;
139 
144  virtual bool
145  hp_constraints_are_implemented() const override;
146 
162  virtual std::vector<std::pair<unsigned int, unsigned int>>
164  const FiniteElement<dim, spacedim> &fe_other) const override;
165 
170  virtual std::vector<std::pair<unsigned int, unsigned int>>
172  const FiniteElement<dim, spacedim> &fe_other) const override;
173 
178  virtual std::vector<std::pair<unsigned int, unsigned int>>
180  const FiniteElement<dim, spacedim> &fe_other) const override;
181 
193  const FiniteElement<dim, spacedim> &fe_other) const override;
194 
195 
201  virtual std::string
202  get_name() const override;
203 
204  virtual std::unique_ptr<FiniteElement<dim, spacedim>>
205  clone() const override;
206 
207 protected:
214  static std::vector<unsigned int>
215  get_dpo_vector(const unsigned int degree);
216 
222  renumber_bases(const unsigned int degree);
223 };
224 
225 
226 
229 DEAL_II_NAMESPACE_CLOSE
230 
231 #endif
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const override
Definition: fe_bernstein.cc:51
FE_Bernstein(const unsigned int p)
Definition: fe_bernstein.cc:37
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
const unsigned int degree
Definition: fe_base.h:313
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const override
TensorProductPolynomials< dim > renumber_bases(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 override
Definition: fe_bernstein.cc:80
virtual bool hp_constraints_are_implemented() const override
virtual std::string get_name() const override
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const override
Definition: fe_bernstein.cc:95
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
virtual const FullMatrix< double > & get_restriction_matrix(const unsigned int child, const RefinementCase< dim > &refinement_case=RefinementCase< dim >::isotropic_refinement) const override
Definition: fe_bernstein.cc:65
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const override