Reference documentation for deal.II version 9.1.0-pre
fe_q_dg0.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2012 - 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 
17 #ifndef dealii_fe_q_dg0_h
18 #define dealii_fe_q_dg0_h
19 
20 #include <deal.II/base/config.h>
21 
22 #include <deal.II/base/tensor_product_polynomials_const.h>
23 
24 #include <deal.II/fe/fe_q_base.h>
25 
26 DEAL_II_NAMESPACE_OPEN
27 
28 
31 
238 template <int dim, int spacedim = dim>
239 class FE_Q_DG0
240  : public FE_Q_Base<TensorProductPolynomialsConst<dim>, dim, spacedim>
241 {
242 public:
247  FE_Q_DG0(const unsigned int p);
248 
255  FE_Q_DG0(const Quadrature<1> &points);
256 
262  virtual std::string
263  get_name() const override;
264 
265  // documentation inherited from the base class
266  virtual void
268  const std::vector<Vector<double>> &support_point_values,
269  std::vector<double> & nodal_values) const override;
270 
280  virtual void
282  FullMatrix<double> &matrix) const override;
283 
284 
289  virtual bool
290  has_support_on_face(const unsigned int shape_index,
291  const unsigned int face_index) const override;
292 
299  virtual std::pair<Table<2, bool>, std::vector<unsigned int>>
300  get_constant_modes() const override;
301 
302  virtual std::unique_ptr<FiniteElement<dim, spacedim>>
303  clone() const override;
304 
305 private:
310  static std::vector<bool>
311  get_riaf_vector(const unsigned int degree);
312 
319  static std::vector<unsigned int>
320  get_dpo_vector(const unsigned int degree);
321 };
322 
323 
324 
328 DEAL_II_NAMESPACE_CLOSE
329 
330 #endif
const unsigned int degree
Definition: fe_base.h:313
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const override
Definition: fe_q_dg0.cc:277
static std::vector< bool > get_riaf_vector(const unsigned int degree)
Definition: fe_q_dg0.cc:236
FE_Q_DG0(const unsigned int p)
Definition: fe_q_dg0.cc:35
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override
Definition: fe_q_dg0.cc:173
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const override
Definition: fe_q_dg0.cc:261
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const override
Definition: fe_q_dg0.cc:210
virtual std::string get_name() const override
Definition: fe_q_dg0.cc:94
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_q_dg0.cc:182
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
Definition: fe_q_dg0.cc:247