Reference documentation for deal.II version 9.1.0-pre
fe_poly_face.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_poly_face_h
17 #define dealii_fe_poly_face_h
18 
19 
20 #include <deal.II/base/qprojector.h>
21 #include <deal.II/base/std_cxx14/memory.h>
22 
23 #include <deal.II/fe/fe.h>
24 
25 
26 DEAL_II_NAMESPACE_OPEN
27 
30 
56 template <class PolynomialType,
57  int dim = PolynomialType::dimension + 1,
58  int spacedim = dim>
59 class FE_PolyFace : public FiniteElement<dim, spacedim>
60 {
61 public:
65  FE_PolyFace(const PolynomialType & poly_space,
66  const FiniteElementData<dim> &fe_data,
67  const std::vector<bool> & restriction_is_additive_flags);
68 
73  unsigned int
74  get_degree() const;
75 
76  // for documentation, see the FiniteElement base class
77  virtual UpdateFlags
78  requires_update_flags(const UpdateFlags update_flags) const override;
79 
80 protected:
81  /*
82  * NOTE: The following functions have their definitions inlined into the class
83  * declaration because we otherwise run into a compiler error with MS Visual
84  * Studio.
85  */
86 
87 
88  virtual std::unique_ptr<
91  const UpdateFlags /*update_flags*/,
92  const Mapping<dim, spacedim> & /*mapping*/,
93  const Quadrature<dim> & /*quadrature*/,
95  spacedim>
96  & /*output_data*/) const override
97  {
98  return std_cxx14::make_unique<InternalData>();
99  }
100 
101  std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
103  const UpdateFlags update_flags,
104  const Mapping<dim, spacedim> & /*mapping*/,
105  const Quadrature<dim - 1> &quadrature,
107  spacedim>
108  & /*output_data*/) const override
109  {
110  // generate a new data object and
111  // initialize some fields
112  auto data = std_cxx14::make_unique<InternalData>();
113  data->update_each = requires_update_flags(update_flags);
114 
115  const unsigned int n_q_points = quadrature.size();
116 
117  // some scratch arrays
118  std::vector<double> values(0);
119  std::vector<Tensor<1, dim - 1>> grads(0);
120  std::vector<Tensor<2, dim - 1>> grad_grads(0);
121  std::vector<Tensor<3, dim - 1>> empty_vector_of_3rd_order_tensors;
122  std::vector<Tensor<4, dim - 1>> empty_vector_of_4th_order_tensors;
123 
124  // initialize fields only if really
125  // necessary. otherwise, don't
126  // allocate memory
127  if (data->update_each & update_values)
128  {
129  values.resize(poly_space.n());
130  data->shape_values.resize(poly_space.n(),
131  std::vector<double>(n_q_points));
132  for (unsigned int i = 0; i < n_q_points; ++i)
133  {
134  poly_space.compute(quadrature.point(i),
135  values,
136  grads,
137  grad_grads,
138  empty_vector_of_3rd_order_tensors,
139  empty_vector_of_4th_order_tensors);
140 
141  for (unsigned int k = 0; k < poly_space.n(); ++k)
142  data->shape_values[k][i] = values[k];
143  }
144  }
145  // No derivatives of this element
146  // are implemented.
147  if (data->update_each & update_gradients ||
148  data->update_each & update_hessians)
149  {
150  Assert(false, ExcNotImplemented());
151  }
152 
153  return std::move(data);
154  }
155 
156  std::unique_ptr<typename FiniteElement<dim, spacedim>::InternalDataBase>
158  const UpdateFlags update_flags,
159  const Mapping<dim, spacedim> &mapping,
160  const Quadrature<dim - 1> & quadrature,
162  spacedim>
163  &output_data) const override
164  {
165  return get_face_data(update_flags,
166  mapping,
168  quadrature),
169  output_data);
170  }
171 
172  virtual void
173  fill_fe_values(
174  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
175  const CellSimilarity::Similarity cell_similarity,
176  const Quadrature<dim> & quadrature,
177  const Mapping<dim, spacedim> & mapping,
178  const typename Mapping<dim, spacedim>::InternalDataBase &mapping_internal,
179  const ::internal::FEValuesImplementation::MappingRelatedData<dim,
180  spacedim>
181  & mapping_data,
182  const typename FiniteElement<dim, spacedim>::InternalDataBase &fe_internal,
184  spacedim>
185  &output_data) const override;
186 
187  virtual void
188  fill_fe_face_values(
189  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
190  const unsigned int face_no,
191  const Quadrature<dim - 1> & quadrature,
192  const Mapping<dim, spacedim> & mapping,
193  const typename Mapping<dim, spacedim>::InternalDataBase &mapping_internal,
194  const ::internal::FEValuesImplementation::MappingRelatedData<dim,
195  spacedim>
196  & mapping_data,
197  const typename FiniteElement<dim, spacedim>::InternalDataBase &fe_internal,
199  spacedim>
200  &output_data) const override;
201 
202  virtual void
203  fill_fe_subface_values(
204  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
205  const unsigned int face_no,
206  const unsigned int sub_no,
207  const Quadrature<dim - 1> & quadrature,
208  const Mapping<dim, spacedim> & mapping,
209  const typename Mapping<dim, spacedim>::InternalDataBase &mapping_internal,
210  const ::internal::FEValuesImplementation::MappingRelatedData<dim,
211  spacedim>
212  & mapping_data,
213  const typename FiniteElement<dim, spacedim>::InternalDataBase &fe_internal,
215  spacedim>
216  &output_data) const override;
217 
224  class InternalData : public FiniteElement<dim, spacedim>::InternalDataBase
225  {
226  public:
240  std::vector<std::vector<double>> shape_values;
241  };
242 
247  PolynomialType poly_space;
248 };
249 
252 DEAL_II_NAMESPACE_CLOSE
253 
254 #endif
Shape function values.
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
std::vector< std::vector< double > > shape_values
Definition: fe_poly_face.h:240
const Point< dim > & point(const unsigned int i) const
std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_face_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &, const Quadrature< dim-1 > &quadrature,::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &) const override
Definition: fe_poly_face.h:102
unsigned int size() const
#define Assert(cond, exc)
Definition: exceptions.h:1227
UpdateFlags
virtual std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags, const Mapping< dim, spacedim > &, const Quadrature< dim > &,::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &) const override
Definition: fe_poly_face.h:90
Abstract base class for mapping classes.
Definition: dof_tools.h:57
Second derivatives of shape functions.
PolynomialType poly_space
Definition: fe_poly_face.h:247
std::unique_ptr< typename FiniteElement< dim, spacedim >::InternalDataBase > get_subface_data(const UpdateFlags update_flags, const Mapping< dim, spacedim > &mapping, const Quadrature< dim-1 > &quadrature,::internal::FEValuesImplementation::FiniteElementRelatedData< dim, spacedim > &output_data) const override
Definition: fe_poly_face.h:157
unsigned int get_degree() const
Definition: mpi.h:55
Shape function gradients.
static::ExceptionBase & ExcNotImplemented()
FE_PolyFace(const PolynomialType &poly_space, const FiniteElementData< dim > &fe_data, const std::vector< bool > &restriction_is_additive_flags)
const std::vector< bool > restriction_is_additive_flags
Definition: fe.h:2586