Reference documentation for deal.II version 9.1.0-pre
fe_trace.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2000 - 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_trace_h
17 #define dealii_fe_trace_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_face.h>
24 #include <deal.II/fe/fe_poly_face.h>
25 #include <deal.II/fe/fe_q.h>
26 
27 DEAL_II_NAMESPACE_OPEN
28 
45 template <int dim, int spacedim = dim>
46 class FE_TraceQ
47  : public FE_PolyFace<TensorProductPolynomials<dim - 1>, dim, spacedim>
48 {
49 public:
55  FE_TraceQ(unsigned int p);
56 
62  virtual std::string
63  get_name() const override;
64 
65  virtual std::unique_ptr<FiniteElement<dim, spacedim>>
66  clone() const override;
67 
75  virtual void
77  const std::vector<Vector<double>> &support_point_values,
78  std::vector<double> & nodal_values) const override;
79 
84  virtual bool
85  has_support_on_face(const unsigned int shape_index,
86  const unsigned int face_index) const override;
87 
92  virtual std::pair<Table<2, bool>, std::vector<unsigned int>>
93  get_constant_modes() const override;
94 
99  virtual bool
100  hp_constraints_are_implemented() const override;
101 
110  virtual void
112  FullMatrix<double> &matrix) const override;
113 
122  virtual void
124  const unsigned int subface,
125  FullMatrix<double> &matrix) const override;
126 
138  const FiniteElement<dim, spacedim> &fe_other) const override;
139 
140 private:
145 
149  static std::vector<unsigned int>
150  get_dpo_vector(const unsigned int deg);
151 };
152 
153 
154 
158 template <int spacedim>
159 class FE_TraceQ<1, spacedim> : public FE_FaceQ<1, spacedim>
160 {
161 public:
165  FE_TraceQ(const unsigned int p);
166 
170  std::string
171  get_name() const override;
172 };
173 
174 
175 DEAL_II_NAMESPACE_CLOSE
176 
177 #endif
virtual std::pair< Table< 2, bool >, std::vector< unsigned int > > get_constant_modes() const override
Definition: fe_trace.cc:122
virtual bool has_support_on_face(const unsigned int shape_index, const unsigned int face_index) const override
Definition: fe_trace.cc:101
FE_TraceQ(unsigned int p)
Definition: fe_trace.cc:38
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source, FullMatrix< double > &matrix) const override
Definition: fe_trace.cc:217
Definition: fe_q.h:554
FE_Q< dim, spacedim > fe_q
Definition: fe_trace.h:144
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_trace.cc:134
virtual bool hp_constraints_are_implemented() const override
Definition: fe_trace.cc:172
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override
Definition: fe_trace.cc:75
static std::vector< unsigned int > get_dpo_vector(const unsigned int deg)
Definition: fe_trace.cc:154
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const override
Definition: fe_trace.cc:180
virtual std::string get_name() const override
Definition: fe_trace.cc:84
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source, const unsigned int subface, FullMatrix< double > &matrix) const override
Definition: fe_trace.cc:230