Reference documentation for deal.II version 8.4.2
fe_trace.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2000 - 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_trace_h
17 #define dealii__fe_trace_h
18 
19 #include <deal.II/base/config.h>
20 #include <deal.II/base/tensor_product_polynomials.h>
21 #include <deal.II/fe/fe_poly_face.h>
22 #include <deal.II/fe/fe_q.h>
23 #include <deal.II/fe/fe_face.h>
24 
25 DEAL_II_NAMESPACE_OPEN
26 
45 template <int dim, int spacedim=dim>
46 class FE_TraceQ : public FE_PolyFace<TensorProductPolynomials<dim-1>, dim, spacedim>
47 {
48 public:
54  FE_TraceQ(unsigned int p);
55 
61  virtual FiniteElement<dim,spacedim> *clone() const;
62 
68  virtual std::string get_name () const;
69 
74  virtual bool has_support_on_face (const unsigned int shape_index,
75  const unsigned int face_index) const;
76 
81  virtual std::pair<Table<2,bool>, std::vector<unsigned int> >
82  get_constant_modes () const;
83 
88  virtual bool hp_constraints_are_implemented () const;
89 
98  virtual void
100  FullMatrix<double> &matrix) const;
101 
110  virtual void
112  const unsigned int subface,
113  FullMatrix<double> &matrix) const;
114 
124  virtual
127 
128 private:
133 
137  static std::vector<unsigned int> get_dpo_vector (const unsigned int deg);
138 };
139 
140 
141 
145 template <int spacedim>
146 class FE_TraceQ<1,spacedim> : public FE_FaceQ<1,spacedim>
147 {
148 public:
152  FE_TraceQ (const unsigned int p);
153 
157  std::string get_name() const;
158 };
159 
160 
161 DEAL_II_NAMESPACE_CLOSE
162 
163 #endif
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const
Definition: fe_trace.cc:194
FE_TraceQ(unsigned int p)
Definition: fe_trace.cc:35
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const
Definition: fe_trace.cc:182
Definition: fe_q.h:522
FE_Q< dim, spacedim > fe_q
Definition: fe_trace.h:132
virtual bool hp_constraints_are_implemented() const
Definition: fe_trace.cc:138
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const
Definition: fe_trace.cc:87
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const
Definition: fe_trace.cc:147
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const
Definition: fe_trace.cc:107
virtual FiniteElement< dim, spacedim > * clone() const
Definition: fe_trace.cc:60
static std::vector< unsigned int > get_dpo_vector(const unsigned int deg)
Definition: fe_trace.cc:120
virtual std::string get_name() const
Definition: fe_trace.cc:69