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_p1.h
Go to the documentation of this file.
1// ------------------------------------------------------------------------
2//
3// SPDX-License-Identifier: LGPL-2.1-or-later
4// Copyright (C) 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_p1_h
16#define dealii_mapping_p1_h
17
18
19#include <deal.II/base/config.h>
20
22
23#include <deal.II/fe/mapping.h>
24
25#include <cmath>
26
27
29
34
71template <int dim, int spacedim = dim>
72class MappingP1 : public Mapping<dim, spacedim>
73{
74public:
75 virtual std::unique_ptr<Mapping<dim, spacedim>>
76 clone() const override;
77
81 virtual bool
82 preserves_vertex_locations() const override;
83
87 virtual bool
88 is_compatible_with(const ReferenceCell &reference_cell) const override;
89
94
95 virtual Point<spacedim>
98 const Point<dim> &p) const override;
99
100 virtual Point<dim>
103 const Point<spacedim> &p) const override;
104
105 virtual void
108 const ArrayView<const Point<spacedim>> &real_points,
109 const ArrayView<Point<dim>> &unit_points) const override;
110
114
119
120 virtual void
121 transform(const ArrayView<const Tensor<1, dim>> &input,
122 const MappingKind kind,
124 const ArrayView<Tensor<1, spacedim>> &output) const override;
125
126 virtual void
128 const MappingKind kind,
130 const ArrayView<Tensor<2, spacedim>> &output) const override;
131
132 virtual void
133 transform(const ArrayView<const Tensor<2, dim>> &input,
134 const MappingKind kind,
136 const ArrayView<Tensor<2, spacedim>> &output) const override;
137
138 virtual void
140 const MappingKind kind,
142 const ArrayView<Tensor<3, spacedim>> &output) const override;
143
144 virtual void
145 transform(const ArrayView<const Tensor<3, dim>> &input,
146 const MappingKind kind,
148 const ArrayView<Tensor<3, spacedim>> &output) const override;
149
153
171 void
174 const ArrayView<const Point<dim>> &unit_points,
175 const UpdateFlags update_flags,
177 &output_data) const;
178
183
195 class InternalData : public Mapping<dim, spacedim>::InternalDataBase
196 {
197 public:
201 InternalData(const ArrayView<const Point<dim>> &quadrature_points);
202
207
208 virtual void
209 reinit(const UpdateFlags update_flags,
210 const Quadrature<dim> &quadrature) override;
211
215 virtual std::size_t
216 memory_consumption() const override;
217
222
227
232
236 mutable double determinant;
237
243 };
244
245private:
246 virtual UpdateFlags
247 requires_update_flags(const UpdateFlags update_flags) const override;
248
249 virtual std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
250 get_data(const UpdateFlags, const Quadrature<dim> &quadrature) const override;
251
252 using Mapping<dim, spacedim>::get_face_data;
253
254 virtual std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
255 get_face_data(const UpdateFlags flags,
256 const hp::QCollection<dim - 1> &quadrature) const override;
257
258 virtual std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
259 get_subface_data(const UpdateFlags flags,
260 const Quadrature<dim - 1> &quadrature) const override;
261
265 const CellSimilarity::Similarity cell_similarity,
266 const Quadrature<dim> &quadrature,
267 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
269 &output_data) const override;
270
271 using Mapping<dim, spacedim>::fill_fe_face_values;
272
273 virtual void
276 const unsigned int face_no,
277 const hp::QCollection<dim - 1> &quadrature,
278 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
280 &output_data) const override;
281
282 virtual void
285 const unsigned int face_no,
286 const unsigned int subface_no,
287 const Quadrature<dim - 1> &quadrature,
288 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
290 &output_data) const override;
291
295
300 void
303 const InternalData &data) const;
304
308 void
311 const InternalData &data,
312 const typename QProjector<dim>::DataSetDescriptor &offset,
313 std::vector<Point<spacedim>> &quadrature_points) const;
314
319 void
321 const unsigned int face_no,
322 const InternalData &data,
323 std::vector<Tensor<1, spacedim>> &normal_vectors) const;
324
330 void
332 const InternalData &data,
333 const CellSimilarity::Similarity cell_similarity,
335 &output_data) const;
336
341 void
343 const InternalData &data,
344 const CellSimilarity::Similarity cell_similarity,
346 &output_data) const;
347
352 void
354 const InternalData &data,
355 const CellSimilarity::Similarity cell_similarity,
357 &output_data) const;
358};
359
361
363
364#endif
DerivativeForm< 1, dim, spacedim > covariant
Definition mapping_p1.h:231
virtual void reinit(const UpdateFlags update_flags, const Quadrature< dim > &quadrature) override
Definition mapping_p1.cc:70
DerivativeForm< 1, dim, spacedim > linear_component
Definition mapping_p1.h:226
Tensor< 1, spacedim > affine_component
Definition mapping_p1.h:221
Quadrature< dim > quadrature
Definition mapping_p1.h:242
InternalData(const ArrayView< const Point< dim > > &quadrature_points)
Definition mapping_p1.cc:52
virtual std::size_t memory_consumption() const override
Definition mapping_p1.cc:82
Implementation of the classic affine transformation mapping used for simplices.
Definition mapping_p1.h:73
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 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 override
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 override
virtual bool is_compatible_with(const ReferenceCell &reference_cell) const override
void transform_quadrature_points(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const InternalData &data, const typename QProjector< dim >::DataSetDescriptor &offset, std::vector< Point< spacedim > > &quadrature_points) const
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_subface_data(const UpdateFlags flags, const Quadrature< dim - 1 > &quadrature) const override
virtual bool preserves_vertex_locations() const override
Definition mapping_p1.cc:96
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 override
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 override
virtual Point< spacedim > transform_unit_to_real_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< dim > &p) const override
void update_transformation(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const InternalData &data) const
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > get_face_data(const UpdateFlags flags, const hp::QCollection< dim - 1 > &quadrature) const override
virtual std::unique_ptr< Mapping< dim, spacedim > > clone() const override
void maybe_update_inverse_jacobians(const InternalData &data, const CellSimilarity::Similarity cell_similarity, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const
void fill_mapping_data_for_generic_points(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const ArrayView< const Point< dim > > &unit_points, const UpdateFlags update_flags, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const
void maybe_update_jacobian_derivatives(const InternalData &data, const CellSimilarity::Similarity cell_similarity, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const
virtual Point< dim > transform_real_to_unit_cell(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< spacedim > &p) const override
void maybe_update_normal_vectors(const unsigned int face_no, const InternalData &data, std::vector< Tensor< 1, spacedim > > &normal_vectors) const
void maybe_update_jacobians(const InternalData &data, const CellSimilarity::Similarity cell_similarity, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) 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 override
Abstract base class for mapping classes.
Definition mapping.h:320
Definition point.h:113
Class storing the offset index into a Quadrature rule created by project_to_all_faces() or project_to...
Definition qprojector.h:334
#define DEAL_II_NAMESPACE_OPEN
Definition config.h:40
#define DEAL_II_NAMESPACE_CLOSE
Definition config.h:41
TriaIterator< CellAccessor< dim, spacedim > > cell_iterator
Definition tria.h:1557