Reference documentation for deal.II version 8.4.2
mapping_cartesian.h
1 // ---------------------------------------------------------------------
2 //
3 // Copyright (C) 2001 - 2016 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__mapping_cartesian_h
17 #define dealii__mapping_cartesian_h
18 
19 
20 #include <deal.II/base/config.h>
21 #include <deal.II/base/table.h>
22 #include <cmath>
23 #include <deal.II/fe/mapping.h>
24 
25 DEAL_II_NAMESPACE_OPEN
26 
29 
58 template <int dim, int spacedim=dim>
59 class MappingCartesian : public Mapping<dim,spacedim>
60 {
61 public:
62 
63  // for documentation, see the Mapping base class
64  virtual
65  Mapping<dim, spacedim> *clone () const;
66 
71  bool preserves_vertex_locations () const;
72 
78  // for documentation, see the Mapping base class
79  virtual
82  const Point<dim> &p) const;
83 
84  // for documentation, see the Mapping base class
85  virtual
88  const Point<spacedim> &p) const;
89 
99  // for documentation, see the Mapping base class
100  virtual
101  void
102  transform (const ArrayView<const Tensor<1,dim> > &input,
103  const MappingType type,
104  const typename Mapping<dim,spacedim>::InternalDataBase &internal,
105  const ArrayView<Tensor<1,spacedim> > &output) const;
106 
107  // for documentation, see the Mapping base class
108  virtual
109  void
111  const MappingType type,
112  const typename Mapping<dim,spacedim>::InternalDataBase &internal,
113  const ArrayView<Tensor<2,spacedim> > &output) const;
114 
115  // for documentation, see the Mapping base class
116  virtual
117  void
118  transform (const ArrayView<const Tensor<2, dim> > &input,
119  const MappingType type,
120  const typename Mapping<dim,spacedim>::InternalDataBase &internal,
121  const ArrayView<Tensor<2,spacedim> > &output) const;
122 
123  // for documentation, see the Mapping base class
124  virtual
125  void
127  const MappingType type,
128  const typename Mapping<dim,spacedim>::InternalDataBase &internal,
129  const ArrayView<Tensor<3,spacedim> > &output) const;
130 
131  // for documentation, see the Mapping base class
132  virtual
133  void
134  transform (const ArrayView<const Tensor<3, dim> > &input,
135  const MappingType type,
136  const typename Mapping<dim,spacedim>::InternalDataBase &internal,
137  const ArrayView<Tensor<3,spacedim> > &output) const;
138 
144 private:
145 
162  class InternalData : public Mapping<dim, spacedim>::InternalDataBase
163  {
164  public:
168  InternalData (const Quadrature<dim> &quadrature);
169 
173  virtual std::size_t memory_consumption () const;
174 
180 
184  mutable double volume_element;
185 
189  std::vector<Point<dim> > quadrature_points;
190  };
191 
192  // documentation can be found in Mapping::requires_update_flags()
193  virtual
195  requires_update_flags (const UpdateFlags update_flags) const;
196 
197  // documentation can be found in Mapping::get_data()
198  virtual
200  get_data (const UpdateFlags,
201  const Quadrature<dim> &quadrature) const;
202 
203  // documentation can be found in Mapping::get_face_data()
204  virtual
206  get_face_data (const UpdateFlags flags,
207  const Quadrature<dim-1>& quadrature) const;
208 
209  // documentation can be found in Mapping::get_subface_data()
210  virtual
212  get_subface_data (const UpdateFlags flags,
213  const Quadrature<dim-1>& quadrature) const;
214 
215  // documentation can be found in Mapping::fill_fe_values()
216  virtual
217  CellSimilarity::Similarity
218  fill_fe_values (const typename Triangulation<dim,spacedim>::cell_iterator &cell,
219  const CellSimilarity::Similarity cell_similarity,
220  const Quadrature<dim> &quadrature,
221  const typename Mapping<dim,spacedim>::InternalDataBase &internal_data,
223 
224  // documentation can be found in Mapping::fill_fe_face_values()
225  virtual void
226  fill_fe_face_values (const typename Triangulation<dim,spacedim>::cell_iterator &cell,
227  const unsigned int face_no,
228  const Quadrature<dim-1> &quadrature,
229  const typename Mapping<dim,spacedim>::InternalDataBase &internal_data,
231 
232  // documentation can be found in Mapping::fill_fe_subface_values()
233  virtual void
234  fill_fe_subface_values (const typename Triangulation<dim,spacedim>::cell_iterator &cell,
235  const unsigned int face_no,
236  const unsigned int subface_no,
237  const Quadrature<dim-1> &quadrature,
238  const typename Mapping<dim,spacedim>::InternalDataBase &internal_data,
240 
250  void compute_fill (const typename Triangulation<dim,spacedim>::cell_iterator &cell,
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
static const unsigned int invalid_unsigned_int
Definition: types.h:164
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
MappingType
Definition: mapping.h:50
virtual Mapping< dim, spacedim >::InternalDataBase * get_data(const UpdateFlags, const Quadrature< dim > &quadrature) const
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
bool preserves_vertex_locations() const
std::vector< Point< dim > > quadrature_points
virtual Mapping< dim, spacedim >::InternalDataBase * get_subface_data(const UpdateFlags flags, const Quadrature< dim-1 > &quadrature) const
virtual std::size_t memory_consumption() const
virtual Point< spacedim > transform_unit_to_real_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< dim > &p) const
UpdateFlags
Abstract base class for mapping classes.
Definition: dof_tools.h:52
virtual Point< dim > transform_real_to_unit_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< spacedim > &p) const
virtual Mapping< dim, spacedim >::InternalDataBase * get_face_data(const UpdateFlags flags, const Quadrature< dim-1 > &quadrature) const
static const unsigned int invalid_face_number
virtual Mapping< dim, spacedim > * clone() const
InternalData(const Quadrature< dim > &quadrature)
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const