deal.II version 9.7.0
\(\newcommand{\dealvcentcolon}{\mathrel{\mathop{:}}}\) \(\newcommand{\dealcoloneq}{\dealvcentcolon\mathrel{\mkern-1.2mu}=}\) \(\newcommand{\jump}[1]{\left[\!\left[ #1 \right]\!\right]}\) \(\newcommand{\average}[1]{\left\{\!\left\{ #1 \right\}\!\right\}}\)
Loading...
Searching...
No Matches
mapping.h
Go to the documentation of this file.
1// ------------------------------------------------------------------------
2//
3// SPDX-License-Identifier: LGPL-2.1-or-later
4// Copyright (C) 2001 - 2025 by the deal.II authors
5//
6// This file is part of the deal.II library.
7//
8// Part of the source code is dual licensed under Apache-2.0 WITH
9// LLVM-exception OR LGPL-2.1-or-later. Detailed license information
10// governing the source code and code contributions can be found in
11// LICENSE.md and CONTRIBUTING.md at the top level directory of deal.II.
12//
13// ------------------------------------------------------------------------
14
15#ifndef dealii_mapping_h
16#define dealii_mapping_h
17
18
19#include <deal.II/base/config.h>
20
23
26
27#include <deal.II/grid/tria.h>
28
30
32
33#include <boost/container/small_vector.hpp>
34
35#include <array>
36#include <cmath>
37#include <memory>
38
40
41template <typename ElementType, typename MemorySpaceType>
42class ArrayView;
43template <int dim>
44class Quadrature;
45template <int dim, int spacedim>
46class FEValues;
47template <int dim, int spacedim>
48class FEValuesBase;
49template <int dim, int spacedim>
50class FEValues;
51template <int dim, int spacedim>
52class FEFaceValues;
53template <int dim, int spacedim>
54class FESubfaceValues;
55namespace NonMatching
56{
57 template <int dim>
59 namespace internal
60 {
61 template <int dim, int spacedim>
63 }
64 template <int dim, int spacedim, typename Number>
65 class MappingInfo;
66} // namespace NonMatching
67
68
166
167
318template <int dim, int spacedim = dim>
320{
321public:
325 virtual ~Mapping() override = default;
326
336 virtual std::unique_ptr<Mapping<dim, spacedim>>
337 clone() const = 0;
338
353 virtual boost::container::small_vector<Point<spacedim>,
354#ifndef _MSC_VER
356#else
358#endif
359 >
361 const typename Triangulation<dim, spacedim>::cell_iterator &cell) const;
362
371 boost::container::small_vector<Point<spacedim>,
372#ifndef _MSC_VER
374#else
376#endif
377 >
379 const unsigned int face_no) const;
380
404 virtual Point<spacedim>
406 const bool map_barycenter_of_reference_cell = true) const;
407
427 const typename Triangulation<dim, spacedim>::cell_iterator &cell) const;
428
440 virtual bool
442
447 virtual bool
448 is_compatible_with(const ReferenceCell &reference_cell) const = 0;
449
454
466 virtual Point<spacedim>
469 const Point<dim> &p) const = 0;
470
499 virtual Point<dim>
502 const Point<spacedim> &p) const = 0;
503
516 virtual void
519 const ArrayView<const Point<spacedim>> &real_points,
520 const ArrayView<Point<dim>> &unit_points) const;
521
532 Point<dim - 1>
535 const unsigned int face_no,
536 const Point<spacedim> &p) const;
537
541
542
547
552
553
563 "Computing the mapping between a real space point and a point in reference "
564 "space failed, typically because the given point lies outside the cell "
565 "where the inverse mapping is not unique.");
566
576 double,
577 int,
578 << "The image of the mapping applied to cell with center ["
579 << arg1 << "] is distorted. The cell geometry or the "
580 << "mapping are invalid, giving a non-positive volume "
581 << "fraction of " << arg2 << " in quadrature point " << arg3
582 << '.');
583
587
592
593public:
660 {
661 public:
667
672
682 virtual void
683 reinit(const UpdateFlags update_flags, const Quadrature<dim> &quadrature);
684
688 virtual ~InternalDataBase() = default;
689
704 UpdateFlags update_each;
705
709 virtual std::size_t
711 };
712
713protected:
737 virtual UpdateFlags
738 requires_update_flags(const UpdateFlags update_flags) const = 0;
739
781 virtual std::unique_ptr<InternalDataBase>
782 get_data(const UpdateFlags update_flags,
783 const Quadrature<dim> &quadrature) const = 0;
784
805 virtual std::unique_ptr<InternalDataBase>
806 get_face_data(const UpdateFlags update_flags,
807 const hp::QCollection<dim - 1> &quadrature) const;
808
812 virtual std::unique_ptr<InternalDataBase>
813 get_face_data(const UpdateFlags update_flags,
814 const Quadrature<dim - 1> &quadrature) const;
815
837 virtual std::unique_ptr<InternalDataBase>
838 get_subface_data(const UpdateFlags update_flags,
839 const Quadrature<dim - 1> &quadrature) const = 0;
840
927 const CellSimilarity::Similarity cell_similarity,
928 const Quadrature<dim> &quadrature,
929 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
931 &output_data) const = 0;
932
957 virtual void
960 const unsigned int face_no,
961 const hp::QCollection<dim - 1> &quadrature,
962 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
964 &output_data) const;
965
969 virtual void
972 const unsigned int face_no,
973 const Quadrature<dim - 1> &quadrature,
974 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
976 &output_data) const;
977
1004 virtual void
1007 const unsigned int face_no,
1008 const unsigned int subface_no,
1009 const Quadrature<dim - 1> &quadrature,
1010 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
1012 &output_data) const = 0;
1013
1020 virtual void
1024 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
1026 &output_data) const;
1027
1031
1032public:
1037
1101 virtual void
1103 const MappingKind kind,
1105 const ArrayView<Tensor<1, spacedim>> &output) const = 0;
1106
1154 virtual void
1156 const MappingKind kind,
1158 const ArrayView<Tensor<2, spacedim>> &output) const = 0;
1159
1212 virtual void
1214 const MappingKind kind,
1216 const ArrayView<Tensor<2, spacedim>> &output) const = 0;
1217
1259 virtual void
1261 const MappingKind kind,
1263 const ArrayView<Tensor<3, spacedim>> &output) const = 0;
1264
1312 virtual void
1314 const MappingKind kind,
1316 const ArrayView<Tensor<3, spacedim>> &output) const = 0;
1317
1321
1322
1323 // Give class @p FEValues access to the private <tt>get_...data</tt> and
1324 // <tt>fill_fe_...values</tt> functions.
1325 friend class FEValuesBase<dim, spacedim>;
1326 friend class FEValues<dim, spacedim>;
1327 friend class FEFaceValues<dim, spacedim>;
1328 friend class FESubfaceValues<dim, spacedim>;
1329 friend class NonMatching::FEImmersedSurfaceValues<dim>;
1330 friend class NonMatching::internal::ComputeMappingDataHelper<dim, spacedim>;
1331 template <int, int, typename>
1333};
1334
1335
1343template <int dim, int spacedim>
1346
1347
1349
1350#endif
UpdateFlags update_each
Definition mapping.h:704
InternalDataBase(const InternalDataBase &)=delete
virtual ~InternalDataBase()=default
virtual std::size_t memory_consumption() const
virtual void reinit(const UpdateFlags update_flags, const Quadrature< dim > &quadrature)
Abstract base class for mapping classes.
Definition mapping.h:320
virtual ~Mapping() override=default
Point< dim - 1 > project_real_point_to_unit_point_on_face(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const Point< spacedim > &p) const
virtual bool is_compatible_with(const ReferenceCell &reference_cell) const =0
virtual void transform(const ArrayView< const Tensor< 1, dim > > &input, const MappingKind kind, const typename Mapping< dim, spacedim >::InternalDataBase &internal, const ArrayView< Tensor< 1, spacedim > > &output) const =0
boost::container::small_vector< Point< spacedim >, ReferenceCells::max_n_vertices< dim - 1 >() > get_vertices(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no) const
virtual void fill_fe_subface_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const unsigned int subface_no, const Quadrature< dim - 1 > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const =0
virtual std::unique_ptr< InternalDataBase > get_data(const UpdateFlags update_flags, const Quadrature< dim > &quadrature) const =0
virtual UpdateFlags requires_update_flags(const UpdateFlags update_flags) const =0
virtual BoundingBox< spacedim > get_bounding_box(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const
virtual void fill_fe_immersed_surface_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const NonMatching::ImmersedSurfaceQuadrature< dim > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const
virtual void fill_fe_face_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const hp::QCollection< dim - 1 > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const
virtual std::unique_ptr< Mapping< dim, spacedim > > clone() const =0
virtual Point< spacedim > transform_unit_to_real_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< dim > &p) const =0
virtual void transform_points_real_to_unit_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const ArrayView< const Point< spacedim > > &real_points, const ArrayView< Point< dim > > &unit_points) const
virtual Point< dim > transform_real_to_unit_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< spacedim > &p) const =0
virtual void transform(const ArrayView< const DerivativeForm< 1, dim, spacedim > > &input, const MappingKind kind, const typename Mapping< dim, spacedim >::InternalDataBase &internal, const ArrayView< Tensor< 2, spacedim > > &output) const =0
virtual void transform(const ArrayView< const DerivativeForm< 2, dim, spacedim > > &input, const MappingKind kind, const typename Mapping< dim, spacedim >::InternalDataBase &internal, const ArrayView< Tensor< 3, spacedim > > &output) const =0
virtual boost::container::small_vector< Point< spacedim >, ReferenceCells::max_n_vertices< dim >() > get_vertices(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const
virtual void fill_fe_face_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const Quadrature< dim - 1 > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const
virtual std::unique_ptr< InternalDataBase > get_face_data(const UpdateFlags update_flags, const Quadrature< dim - 1 > &quadrature) const
virtual bool preserves_vertex_locations() const =0
virtual CellSimilarity::Similarity fill_fe_values(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const CellSimilarity::Similarity cell_similarity, const Quadrature< dim > &quadrature, const typename Mapping< dim, spacedim >::InternalDataBase &internal_data, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const =0
virtual void transform(const ArrayView< const Tensor< 2, dim > > &input, const MappingKind kind, const typename Mapping< dim, spacedim >::InternalDataBase &internal, const ArrayView< Tensor< 2, spacedim > > &output) const =0
virtual Point< spacedim > get_center(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const bool map_barycenter_of_reference_cell=true) const
virtual std::unique_ptr< InternalDataBase > get_face_data(const UpdateFlags update_flags, const hp::QCollection< dim - 1 > &quadrature) const
virtual std::unique_ptr< InternalDataBase > get_subface_data(const UpdateFlags update_flags, const Quadrature< dim - 1 > &quadrature) const =0
ObserverPointer< const Triangulation< dim, spacedim > > triangulation
Definition point.h:113
#define DEAL_II_NAMESPACE_OPEN
Definition config.h:40
#define DEAL_II_NAMESPACE_CLOSE
Definition config.h:41
#define DeclException0(Exception0)
static ::ExceptionBase & ExcDistortedMappedCell(Point< spacedim > arg1, double arg2, int arg3)
static ::ExceptionBase & ExcTransformationFailed()
#define DeclExceptionMsg(Exception, defaulttext)
static ::ExceptionBase & ExcInvalidData()
#define DeclException3(Exception3, type1, type2, type3, outsequence)
TriaIterator< CellAccessor< dim, spacedim > > cell_iterator
Definition tria.h:1557
MappingKind
Definition mapping.h:81
@ mapping_piola
Definition mapping.h:116
@ mapping_covariant_gradient
Definition mapping.h:102
@ mapping_covariant
Definition mapping.h:91
@ mapping_nedelec
Definition mapping.h:131
@ mapping_contravariant
Definition mapping.h:96
@ mapping_raviart_thomas
Definition mapping.h:136
@ mapping_contravariant_hessian
Definition mapping.h:158
@ mapping_covariant_hessian
Definition mapping.h:152
@ mapping_contravariant_gradient
Definition mapping.h:108
@ mapping_none
Definition mapping.h:86
@ mapping_bdm
Definition mapping.h:141
@ mapping_piola_gradient
Definition mapping.h:122
@ mapping_piola_hessian
Definition mapping.h:164
const Mapping< dim, spacedim > & get_default_linear_mapping(const Triangulation< dim, spacedim > &triangulation)
Definition mapping.cc:316
constexpr unsigned int max_n_vertices()
static constexpr unsigned int vertices_per_cell