Reference documentation for deal.II version 8.4.2
fe_q_dg0.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2012 - 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 
17 #ifndef dealii__fe_q_dg0_h
18 #define dealii__fe_q_dg0_h
19 
20 #include <deal.II/base/config.h>
21 #include <deal.II/base/tensor_product_polynomials_const.h>
22 #include <deal.II/fe/fe_q_base.h>
23 
24 DEAL_II_NAMESPACE_OPEN
25 
26 
29 
236 template <int dim, int spacedim=dim>
237 class FE_Q_DG0 : public FE_Q_Base<TensorProductPolynomialsConst<dim>,dim,spacedim>
238 {
239 public:
244  FE_Q_DG0 (const unsigned int p);
245 
252  FE_Q_DG0 (const Quadrature<1> &points);
253 
259  virtual std::string get_name () const;
260 
265  virtual void interpolate(std::vector<double> &local_dofs,
266  const std::vector<double> &values) const;
267 
277  virtual void interpolate(std::vector<double> &local_dofs,
278  const std::vector<Vector<double> > &values,
279  unsigned int offset = 0) const;
280 
285  virtual void interpolate(
286  std::vector<double> &local_dofs,
287  const VectorSlice<const std::vector<std::vector<double> > > &values) const;
288 
298  virtual void
300  FullMatrix<double> &matrix) const;
301 
302 
307  virtual bool has_support_on_face (const unsigned int shape_index,
308  const unsigned int face_index) const;
309 
316  virtual std::pair<Table<2,bool>, std::vector<unsigned int> >
317  get_constant_modes () const;
318 
319 protected:
325  virtual FiniteElement<dim,spacedim> *clone() const;
326 
327 private:
328 
333  static std::vector<bool> get_riaf_vector(const unsigned int degree);
334 
341  static std::vector<unsigned int> get_dpo_vector(const unsigned int degree);
342 };
343 
344 
345 
349 DEAL_II_NAMESPACE_CLOSE
350 
351 #endif
virtual void interpolate(std::vector< double > &local_dofs, const std::vector< double > &values) const
Definition: fe_q_dg0.cc:176
const unsigned int degree
Definition: fe_base.h:299
virtual std::string get_name() const
Definition: fe_q_dg0.cc:93
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const
Definition: fe_q_dg0.cc:305
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const
Definition: fe_q_dg0.cc:319
static std::vector< bool > get_riaf_vector(const unsigned int degree)
Definition: fe_q_dg0.cc:280
FE_Q_DG0(const unsigned int p)
Definition: fe_q_dg0.cc:33
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
Definition: fe_q_dg0.cc:252
virtual FiniteElement< dim, spacedim > * clone() const
Definition: fe_q_dg0.cc:167
static std::vector< unsigned int > get_dpo_vector(const unsigned int degree)
Definition: fe_q_dg0.cc:291