deal.II version 9.7.1
\(\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:
78 MappingP1() = default;
79
80 virtual std::unique_ptr<Mapping<dim, spacedim>>
81 clone() const override;
82
86 virtual bool
87 preserves_vertex_locations() const override;
88
92 virtual bool
93 is_compatible_with(const ReferenceCell &reference_cell) const override;
94
99
100 virtual Point<spacedim>
103 const Point<dim> &p) const override;
104
105 virtual Point<dim>
108 const Point<spacedim> &p) const override;
109
110 virtual void
113 const ArrayView<const Point<spacedim>> &real_points,
114 const ArrayView<Point<dim>> &unit_points) const override;
115
119
124
125 virtual void
126 transform(const ArrayView<const Tensor<1, dim>> &input,
127 const MappingKind kind,
129 const ArrayView<Tensor<1, spacedim>> &output) const override;
130
131 virtual void
133 const MappingKind kind,
135 const ArrayView<Tensor<2, spacedim>> &output) const override;
136
137 virtual void
138 transform(const ArrayView<const Tensor<2, dim>> &input,
139 const MappingKind kind,
141 const ArrayView<Tensor<2, spacedim>> &output) const override;
142
143 virtual void
145 const MappingKind kind,
147 const ArrayView<Tensor<3, spacedim>> &output) const override;
148
149 virtual void
150 transform(const ArrayView<const Tensor<3, dim>> &input,
151 const MappingKind kind,
153 const ArrayView<Tensor<3, spacedim>> &output) const override;
154
158
176 void
179 const ArrayView<const Point<dim>> &unit_points,
180 const UpdateFlags update_flags,
182 &output_data) const;
183
188
200 class InternalData : public Mapping<dim, spacedim>::InternalDataBase
201 {
202 public:
206 InternalData(const ArrayView<const Point<dim>> &quadrature_points);
207
212
213 virtual void
214 reinit(const UpdateFlags update_flags,
215 const Quadrature<dim> &quadrature) override;
216
220 virtual std::size_t
221 memory_consumption() const override;
222
227
232
237
241 mutable double determinant;
242
248 };
249
250private:
251 virtual UpdateFlags
252 requires_update_flags(const UpdateFlags update_flags) const override;
253
254 virtual std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
255 get_data(const UpdateFlags, const Quadrature<dim> &quadrature) const override;
256
257 using Mapping<dim, spacedim>::get_face_data;
258
259 virtual std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
260 get_face_data(const UpdateFlags flags,
261 const hp::QCollection<dim - 1> &quadrature) const override;
262
263 virtual std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
264 get_subface_data(const UpdateFlags flags,
265 const Quadrature<dim - 1> &quadrature) const override;
266
270 const CellSimilarity::Similarity cell_similarity,
271 const Quadrature<dim> &quadrature,
272 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
274 &output_data) const override;
275
276 using Mapping<dim, spacedim>::fill_fe_face_values;
277
278 virtual void
281 const unsigned int face_no,
282 const hp::QCollection<dim - 1> &quadrature,
283 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
285 &output_data) const override;
286
287 virtual void
290 const unsigned int face_no,
291 const unsigned int subface_no,
292 const Quadrature<dim - 1> &quadrature,
293 const typename Mapping<dim, spacedim>::InternalDataBase &internal_data,
295 &output_data) const override;
296
300
305 void
308 const InternalData &data) const;
309
313 void
316 const InternalData &data,
317 const typename QProjector<dim>::DataSetDescriptor &offset,
318 std::vector<Point<spacedim>> &quadrature_points) const;
319
324 void
326 const unsigned int face_no,
327 const InternalData &data,
328 std::vector<Tensor<1, spacedim>> &normal_vectors) const;
329
335 void
337 const InternalData &data,
338 const CellSimilarity::Similarity cell_similarity,
340 &output_data) const;
341
346 void
348 const InternalData &data,
349 const CellSimilarity::Similarity cell_similarity,
351 &output_data) const;
352
357 void
359 const InternalData &data,
360 const CellSimilarity::Similarity cell_similarity,
362 &output_data) const;
363};
364
366
368
369#endif
DerivativeForm< 1, dim, spacedim > covariant
Definition mapping_p1.h:236
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:231
Tensor< 1, spacedim > affine_component
Definition mapping_p1.h:226
Quadrature< dim > quadrature
Definition mapping_p1.h:247
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
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
MappingP1()=default
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