Reference documentation for deal.II version 9.1.0-pre
mapping_cartesian.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2001 - 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_mapping_cartesian_h
17 #define dealii_mapping_cartesian_h
18 
19 
20 #include <deal.II/base/config.h>
21 
22 #include <deal.II/base/table.h>
23 
24 #include <deal.II/fe/mapping.h>
25 
26 #include <cmath>
27 
28 
29 DEAL_II_NAMESPACE_OPEN
30 
33 
62 template <int dim, int spacedim = dim>
63 class MappingCartesian : public Mapping<dim, spacedim>
64 {
65 public:
66  // for documentation, see the Mapping base class
67  virtual std::unique_ptr<Mapping<dim, spacedim>>
68  clone() const override;
69 
74  virtual bool
75  preserves_vertex_locations() const override;
76 
82  // for documentation, see the Mapping base class
83  virtual Point<spacedim>
86  const Point<dim> &p) const override;
87 
88  // for documentation, see the Mapping base class
89  virtual Point<dim>
92  const Point<spacedim> &p) const override;
93 
103  // for documentation, see the Mapping base class
104  virtual void
105  transform(const ArrayView<const Tensor<1, dim>> & input,
106  const MappingType type,
107  const typename Mapping<dim, spacedim>::InternalDataBase &internal,
108  const ArrayView<Tensor<1, spacedim>> &output) const override;
109 
110  // for documentation, see the Mapping base class
111  virtual void
113  const MappingType type,
114  const typename Mapping<dim, spacedim>::InternalDataBase &internal,
115  const ArrayView<Tensor<2, spacedim>> &output) const override;
116 
117  // for documentation, see the Mapping base class
118  virtual void
119  transform(const ArrayView<const Tensor<2, dim>> & input,
120  const MappingType type,
121  const typename Mapping<dim, spacedim>::InternalDataBase &internal,
122  const ArrayView<Tensor<2, spacedim>> &output) const override;
123 
124  // for documentation, see the Mapping base class
125  virtual void
127  const MappingType type,
128  const typename Mapping<dim, spacedim>::InternalDataBase &internal,
129  const ArrayView<Tensor<3, spacedim>> &output) const override;
130 
131  // for documentation, see the Mapping base class
132  virtual void
133  transform(const ArrayView<const Tensor<3, dim>> & input,
134  const MappingType type,
135  const typename Mapping<dim, spacedim>::InternalDataBase &internal,
136  const ArrayView<Tensor<3, spacedim>> &output) const override;
137 
143 private:
160  class InternalData : public Mapping<dim, spacedim>::InternalDataBase
161  {
162  public:
166  InternalData(const Quadrature<dim> &quadrature);
167 
171  virtual std::size_t
172  memory_consumption() const override;
173 
179 
183  mutable double volume_element;
184 
188  std::vector<Point<dim>> quadrature_points;
189  };
190 
191  // documentation can be found in Mapping::requires_update_flags()
192  virtual UpdateFlags
193  requires_update_flags(const UpdateFlags update_flags) const override;
194 
195  // documentation can be found in Mapping::get_data()
196  virtual std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
197  get_data(const UpdateFlags, const Quadrature<dim> &quadrature) const override;
198 
199  // documentation can be found in Mapping::get_face_data()
200  virtual std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
201  get_face_data(const UpdateFlags flags,
202  const Quadrature<dim - 1> &quadrature) const override;
203 
204  // documentation can be found in Mapping::get_subface_data()
205  virtual std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
206  get_subface_data(const UpdateFlags flags,
207  const Quadrature<dim - 1> &quadrature) const override;
208 
209  // documentation can be found in Mapping::fill_fe_values()
211  fill_fe_values(
212  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
213  const CellSimilarity::Similarity cell_similarity,
214  const Quadrature<dim> & quadrature,
215  const typename Mapping<dim, spacedim>::InternalDataBase & internal_data,
217  &output_data) const override;
218 
219  // documentation can be found in Mapping::fill_fe_face_values()
220  virtual void
221  fill_fe_face_values(
222  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
223  const unsigned int face_no,
224  const Quadrature<dim - 1> & quadrature,
225  const typename Mapping<dim, spacedim>::InternalDataBase & internal_data,
227  &output_data) const override;
228 
229  // documentation can be found in Mapping::fill_fe_subface_values()
230  virtual void
231  fill_fe_subface_values(
232  const typename Triangulation<dim, spacedim>::cell_iterator &cell,
233  const unsigned int face_no,
234  const unsigned int subface_no,
235  const Quadrature<dim - 1> & quadrature,
236  const typename Mapping<dim, spacedim>::InternalDataBase & internal_data,
238  &output_data) const override;
239 
249  void
251  const unsigned int face_no,
252  const unsigned int sub_no,
253  const CellSimilarity::Similarity cell_similarity,
254  const InternalData & data,
255  std::vector<Point<dim>> & quadrature_points,
256  std::vector<Tensor<1, dim>> & normal_vectors) const;
257 
262 };
263 
266 DEAL_II_NAMESPACE_CLOSE
267 
268 #endif
virtual Point< dim > transform_real_to_unit_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< spacedim > &p) const override
static const unsigned int invalid_unsigned_int
Definition: types.h:173
MappingType
Definition: mapping.h:61
std::vector< Point< dim > > quadrature_points
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_subface_data(const UpdateFlags flags, const Quadrature< dim-1 > &quadrature) const override
virtual std::size_t memory_consumption() const override
virtual std::unique_ptr< Mapping< dim, spacedim > > clone() const override
UpdateFlags
virtual void transform(const ArrayView< const Tensor< 1, dim >> &input, const MappingType type, const typename Mapping< dim, spacedim >::InternalDataBase &internal, const ArrayView< Tensor< 1, spacedim >> &output) const override
Abstract base class for mapping classes.
Definition: dof_tools.h:57
static const unsigned int invalid_face_number
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_face_data(const UpdateFlags flags, const Quadrature< dim-1 > &quadrature) const override
InternalData(const Quadrature< dim > &quadrature)
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_data(const UpdateFlags, const Quadrature< dim > &quadrature) const override
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const override
virtual bool preserves_vertex_locations() const override
virtual Point< spacedim > transform_unit_to_real_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< dim > &p) const override
void compute_fill(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const unsigned int sub_no, const CellSimilarity::Similarity cell_similarity, const InternalData &data, std::vector< Point< dim >> &quadrature_points, std::vector< Tensor< 1, dim >> &normal_vectors) const