Reference documentation for deal.II version 9.1.0-pre
fe_nothing.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2009 - 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_nothing_h
17 #define dealii_fe_nothing_h
18 
19 #include <deal.II/base/config.h>
20 
21 #include <deal.II/fe/fe.h>
22 
23 DEAL_II_NAMESPACE_OPEN
24 
25 
28 
80 template <int dim, int spacedim = dim>
81 class FE_Nothing : public FiniteElement<dim, spacedim>
82 {
83 public:
95  FE_Nothing(const unsigned int n_components = 1, const bool dominate = false);
96 
97  virtual std::unique_ptr<FiniteElement<dim, spacedim>>
98  clone() const override;
99 
104  virtual std::string
105  get_name() const override;
106 
107  // for documentation, see the FiniteElement base class
108  virtual UpdateFlags
109  requires_update_flags(const UpdateFlags update_flags) const override;
110 
118  virtual double
119  shape_value(const unsigned int i, const Point<dim> &p) const override;
120 
121  virtual void
122  fill_fe_values(
123  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
124  const CellSimilarity::Similarity cell_similarity,
125  const Quadrature<dim> & quadrature,
126  const Mapping<dim, spacedim> & mapping,
127  const typename Mapping<dim, spacedim>::InternalDataBase &mapping_internal,
128  const ::internal::FEValuesImplementation::MappingRelatedData<dim,
129  spacedim>
130  & mapping_data,
131  const typename FiniteElement<dim, spacedim>::InternalDataBase &fe_internal,
133  spacedim>
134  &output_data) const override;
135 
136  virtual void
137  fill_fe_face_values(
138  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
139  const unsigned int face_no,
140  const Quadrature<dim - 1> & quadrature,
141  const Mapping<dim, spacedim> & mapping,
142  const typename Mapping<dim, spacedim>::InternalDataBase &mapping_internal,
143  const ::internal::FEValuesImplementation::MappingRelatedData<dim,
144  spacedim>
145  & mapping_data,
146  const typename FiniteElement<dim, spacedim>::InternalDataBase &fe_internal,
148  spacedim>
149  &output_data) const override;
150 
151  virtual void
152  fill_fe_subface_values(
153  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
154  const unsigned int face_no,
155  const unsigned int sub_no,
156  const Quadrature<dim - 1> & quadrature,
157  const Mapping<dim, spacedim> & mapping,
158  const typename Mapping<dim, spacedim>::InternalDataBase &mapping_internal,
159  const ::internal::FEValuesImplementation::MappingRelatedData<dim,
160  spacedim>
161  & mapping_data,
162  const typename FiniteElement<dim, spacedim>::InternalDataBase &fe_internal,
164  spacedim>
165  &output_data) const override;
166 
176  virtual std::unique_ptr<
178  get_data(
179  const UpdateFlags update_flags,
180  const Mapping<dim, spacedim> &mapping,
181  const Quadrature<dim> & quadrature,
183  spacedim>
184  &output_data) const override;
185 
202  const FiniteElement<dim, spacedim> &fe_other) const override;
203 
204 
205 
206  virtual std::vector<std::pair<unsigned int, unsigned int>>
208  const FiniteElement<dim, spacedim> &fe_other) const override;
209 
210  virtual std::vector<std::pair<unsigned int, unsigned int>>
212  const FiniteElement<dim, spacedim> &fe_other) const override;
213 
214  virtual std::vector<std::pair<unsigned int, unsigned int>>
216  const FiniteElement<dim, spacedim> &fe_other) const override;
217 
218  virtual bool
219  hp_constraints_are_implemented() const override;
220 
226  virtual void
228  const FiniteElement<dim, spacedim> &source_fe,
229  FullMatrix<double> & interpolation_matrix) const override;
230 
240  virtual void
242  const FiniteElement<dim, spacedim> &source_fe,
243  FullMatrix<double> & interpolation_matrix) const override;
244 
245 
255  virtual void
257  const FiniteElement<dim, spacedim> &source_fe,
258  const unsigned int index,
259  FullMatrix<double> & interpolation_matrix) const override;
260 
264  bool
265  is_dominating() const;
266 
274  virtual bool
275  operator==(const FiniteElement<dim, spacedim> &fe) const override;
276 
277 private:
282  const bool dominate;
283 };
284 
285 
288 DEAL_II_NAMESPACE_CLOSE
289 
290 #endif
virtual double shape_value(const unsigned int i, const Point< dim > &p) const override
Definition: fe_nothing.cc:84
virtual FiniteElementDomination::Domination compare_for_face_domination(const FiniteElement< dim, spacedim > &fe_other) const override
Definition: fe_nothing.cc:209
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_line_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
Definition: fe_nothing.cc:245
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_vertex_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
Definition: fe_nothing.cc:232
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim > &quadrature,::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
Definition: fe_nothing.cc:95
virtual std::vector< std::pair< unsigned int, unsigned int > > hp_quad_dof_identities(const FiniteElement< dim, spacedim > &fe_other) const override
Definition: fe_nothing.cc:258
bool is_dominating() const
Definition: fe_nothing.cc:178
virtual void get_face_interpolation_matrix(const FiniteElement< dim, spacedim > &source_fe, FullMatrix< double > &interpolation_matrix) const override
Definition: fe_nothing.cc:298
virtual void get_interpolation_matrix(const FiniteElement< dim, spacedim > &source_fe, FullMatrix< double > &interpolation_matrix) const override
Definition: fe_nothing.cc:280
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
Definition: fe_nothing.cc:75
virtual void get_subface_interpolation_matrix(const FiniteElement< dim, spacedim > &source_fe, const unsigned int index, FullMatrix< double > &interpolation_matrix) const override
Definition: fe_nothing.cc:315
UpdateFlags
virtual bool hp_constraints_are_implemented() const override
Definition: fe_nothing.cc:271
Abstract base class for mapping classes.
Definition: dof_tools.h:57
virtual std::unique_ptr< FiniteElement< dim, spacedim > > clone() const override
Definition: fe_nothing.cc:46
virtual std::string get_name() const override
Definition: fe_nothing.cc:55
unsigned int n_components() const
virtual bool operator==(const FiniteElement< dim, spacedim > &fe) const override
Definition: fe_nothing.cc:188
const bool dominate
Definition: fe_nothing.h:282
FE_Nothing(const unsigned int n_components=1, const bool dominate=false)
Definition: fe_nothing.cc:25