#include <mapping_box.h>
Classes | |
class | InternalData |
Public Member Functions | |
MappingBox (const std::vector< BoundingBox< dim > > &local_boxes, const std::map< types::global_cell_index, types::global_cell_index > &polytope_translator) | |
virtual std::unique_ptr< Mapping< dim, spacedim > > | clone () const override |
virtual bool | preserves_vertex_locations () const override |
virtual bool | is_compatible_with (const ReferenceCell &reference_cell) const override |
Mapping points between reference and real cells | |
virtual Point< spacedim > | transform_unit_to_real_cell (const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< dim > &p) const override |
virtual Point< dim > | transform_real_to_unit_cell (const typename Triangulation< dim, spacedim >::cell_iterator &cell, const Point< spacedim > &p) 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 |
Functions to transform tensors from reference to real coordinates | |
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 | 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 override |
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 override |
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 override |
virtual void | transform (const ArrayView< const Tensor< 3, dim > > &input, const MappingKind kind, const typename Mapping< dim, spacedim >::InternalDataBase &internal, const ArrayView< Tensor< 3, spacedim > > &output) const override |
![]() | |
virtual | ~Mapping () override=default |
virtual boost::container::small_vector< Point< spacedim >, ReferenceCells::max_n_vertices< dim >() > | get_vertices (const typename Triangulation< dim, spacedim >::cell_iterator &cell) const |
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 Point< spacedim > | get_center (const typename Triangulation< dim, spacedim >::cell_iterator &cell, const bool map_barycenter_of_reference_cell=true) const |
virtual BoundingBox< spacedim > | get_bounding_box (const typename Triangulation< dim, spacedim >::cell_iterator &cell) const |
void | serialize (Archive &ar, const unsigned int version) |
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 |
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 |
unsigned int | n_subscriptions () const |
unsigned int | n_subscriptions () const |
void | list_subscribers (StreamType &stream) const |
void | list_subscribers () const |
void | list_subscribers (StreamType &stream) const |
void | list_subscribers () const |
![]() | |
EnableObserverPointer () | |
EnableObserverPointer (const EnableObserverPointer &) | |
EnableObserverPointer (EnableObserverPointer &&) noexcept | |
virtual | ~EnableObserverPointer () |
EnableObserverPointer & | operator= (const EnableObserverPointer &) |
EnableObserverPointer & | operator= (EnableObserverPointer &&) noexcept |
void | serialize (Archive &ar, const unsigned int version) |
unsigned int | n_subscriptions () const |
void | list_subscribers (StreamType &stream) const |
void | list_subscribers () const |
unsigned int | n_subscriptions () const |
void | list_subscribers (StreamType &stream) const |
void | list_subscribers () const |
Private Member Functions | |
void | update_cell_extents (const typename Triangulation< dim, spacedim >::cell_iterator &cell, const CellSimilarity::Similarity cell_similarity, const InternalData &data) const |
void | maybe_update_cell_quadrature_points (const typename Triangulation< dim, spacedim >::cell_iterator &cell, const InternalData &data, const ArrayView< const Point< dim > > &unit_quadrature_points, std::vector< Point< dim > > &quadrature_points) const |
void | maybe_update_normal_vectors (const unsigned int face_no, const InternalData &data, std::vector< Tensor< 1, dim > > &normal_vectors) const |
void | maybe_update_jacobian_derivatives (const InternalData &data, const CellSimilarity::Similarity cell_similarity, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const |
void | maybe_update_volume_elements (const InternalData &data) const |
void | maybe_update_jacobians (const InternalData &data, const CellSimilarity::Similarity cell_similarity, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const |
void | maybe_update_inverse_jacobians (const InternalData &data, const CellSimilarity::Similarity cell_similarity, internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > &output_data) const |
Interface with FEValues | |
virtual UpdateFlags | requires_update_flags (const UpdateFlags update_flags) const override |
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > | get_data (const UpdateFlags, const Quadrature< dim > &quadrature) const override |
virtual std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > | get_subface_data (const UpdateFlags flags, const Quadrature< dim - 1 > &quadrature) const override |
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 | 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 |
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 override |
Private Attributes | |
std::vector< BoundingBox< dim > > | boxes |
std::map< types::global_cell_index, types::global_cell_index > | polytope_translator |
Additional Inherited Members | |
![]() | |
static ::ExceptionBase & | ExcInUse (int arg1, std::string arg2, std::string arg3) |
static ::ExceptionBase & | ExcNoSubscriber (std::string arg1, std::string arg2) |
static ::ExceptionBase & | ExcInvalidData () |
static ::ExceptionBase & | ExcInvalidData () |
static ::ExceptionBase & | ExcTransformationFailed () |
static ::ExceptionBase & | ExcTransformationFailed () |
static ::ExceptionBase & | ExcDistortedMappedCell (Point< spacedim > arg1, double arg2, int arg3) |
static ::ExceptionBase & | ExcDistortedMappedCell (Point< spacedim > arg1, double arg2, int arg3) |
![]() | |
static ::ExceptionBase & | ExcInUse (int arg1, std::string arg2, std::string arg3) |
static ::ExceptionBase & | ExcNoSubscriber (std::string arg1, std::string arg2) |
![]() | |
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_face_data (const UpdateFlags update_flags, const Quadrature< dim - 1 > &quadrature) 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_face_data (const UpdateFlags update_flags, const Quadrature< dim - 1 > &quadrature) 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 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 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 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 |
A class providing a mapping from the reference cell to cells that are axiparallel, i.e., that have the shape of rectangles (in 2d) or boxes (in 3d) with edges parallel to the coordinate directions. The class therefore provides functionality that is equivalent to what, for example, MappingQ would provide for such cells. However, knowledge of the shape of cells allows this class to be substantially more efficient.
Specifically, the mapping is meant for cells for which the mapping from the reference to the real cell is a scaling along the coordinate directions: The transformation from reference coordinates $\hat {\mathbf x}$ to real coordinates $\mathbf x$ on each cell is of the form
\begin{align*} {\mathbf x}(\hat {\mathbf x}) = \begin{pmatrix} h_x & 0 \\ 0 & h_y \end{pmatrix} \hat{\mathbf x} + {\mathbf v}_0 \end{align*}
in 2d, and
\begin{align*} {\mathbf x}(\hat {\mathbf x}) = \begin{pmatrix} h_x & 0 & 0 \\ 0 & h_y & 0 \\ 0 & 0 & h_z \end{pmatrix} \hat{\mathbf x} + {\mathbf v}_0 \end{align*}
in 3d, where ${\mathbf v}_0$ is the bottom left vertex and $h_x,h_y,h_z$ are the extents of the cell along the axes.
The class is intended for efficiency, and it does not do a whole lot of error checking. If you apply this mapping to a cell that does not conform to the requirements above, you will get strange results.
Definition at line 79 of file mapping_box.h.
MappingBox< dim, spacedim >::MappingBox | ( | const std::vector< BoundingBox< dim > > & | local_boxes, |
const std::map< types::global_cell_index, types::global_cell_index > & | polytope_translator ) |
Definition at line 68 of file mapping_box.cc.
References boxes, and polytope_translator.
|
overridevirtual |
Implements Mapping< dim, dim >.
Definition at line 975 of file mapping_box.cc.
|
overrideprivatevirtual |
Reimplemented from Mapping< dim, dim >.
Definition at line 467 of file mapping_box.cc.
References Quadrature< int dim >::get_points(), has_box(), internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::JxW_values, maybe_update_cell_quadrature_points(), maybe_update_inverse_jacobians(), maybe_update_jacobian_derivatives(), maybe_update_jacobians(), maybe_update_volume_elements(), CellSimilarity::none, NonMatching::ImmersedSurfaceQuadrature< int dim, int spacedim >::normal_vector(), internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::normal_vectors, polytope_translator, internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::quadrature_points, update_cell_extents(), and Quadrature< int dim >::weight().
|
overrideprivatevirtual |
Implements Mapping< dim, dim >.
Definition at line 445 of file mapping_box.cc.
|
overrideprivatevirtual |
Implements Mapping< dim, dim >.
Definition at line 395 of file mapping_box.cc.
References Quadrature< int dim >::get_points(), has_box(), internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::JxW_values, maybe_update_cell_quadrature_points(), maybe_update_inverse_jacobians(), maybe_update_jacobian_derivatives(), maybe_update_jacobians(), polytope_translator, internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::quadrature_points, CellSimilarity::translation, update_cell_extents(), and Quadrature< int dim >::weight().
|
overrideprivatevirtual |
Implements Mapping< dim, dim >.
Definition at line 168 of file mapping_box.cc.
References requires_update_flags().
|
overrideprivatevirtual |
Implements Mapping< dim, dim >.
Definition at line 182 of file mapping_box.cc.
|
overridevirtual |
Implements Mapping< dim, dim >.
Definition at line 133 of file mapping_box.cc.
References Utilities::to_string().
|
private |
Compute the quadrature points if the UpdateFlags of the incoming InternalData object say that they should be updated.
Called from fill_fe_values.
Definition at line 246 of file mapping_box.cc.
References boxes, and polytope_translator.
Referenced by fill_fe_immersed_surface_values(), and fill_fe_values().
|
private |
Compute the inverse Jacobians if the UpdateFlags of the incoming InternalData object say that they should be updated.
Definition at line 372 of file mapping_box.cc.
References internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::inverse_jacobians, and CellSimilarity::translation.
Referenced by fill_fe_immersed_surface_values(), and fill_fe_values().
|
private |
Since the Jacobian is constant for this mapping all derivatives of the Jacobian are identically zero. Fill these quantities with zeros if the corresponding update flags say that they should be updated.
Definition at line 282 of file mapping_box.cc.
References internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::jacobian_2nd_derivatives, internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::jacobian_3rd_derivatives, internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::jacobian_grads, internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::jacobian_pushed_forward_2nd_derivatives, internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::jacobian_pushed_forward_3rd_derivatives, internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::jacobian_pushed_forward_grads, and CellSimilarity::translation.
Referenced by fill_fe_immersed_surface_values(), and fill_fe_values().
|
private |
Compute the Jacobians if the UpdateFlags of the incoming InternalData object say that they should be updated.
Definition at line 350 of file mapping_box.cc.
References internal::FEValuesImplementation::MappingRelatedData< int dim, int spacedim >::jacobians, and CellSimilarity::translation.
Referenced by fill_fe_immersed_surface_values(), and fill_fe_values().
|
private |
Compute the normal vectors if the UpdateFlags of the incoming InternalData object say that they should be updated.
Definition at line 263 of file mapping_box.cc.
References GeometryInfo< int dim >::faces_per_cell, and GeometryInfo< int dim >::unit_normal_vector.
|
private |
Compute the volume elements if the UpdateFlags of the incoming InternalData object say that they should be updated.
Definition at line 334 of file mapping_box.cc.
Referenced by fill_fe_immersed_surface_values().
|
overridevirtual |
Return true
because MappingBox preserves vertex locations.
Implements Mapping< dim, dim >.
Definition at line 124 of file mapping_box.cc.
|
overrideprivatevirtual |
Implements Mapping< dim, dim >.
Definition at line 150 of file mapping_box.cc.
Referenced by get_data().
|
overridevirtual |
Implements Mapping< dim, dim >.
Definition at line 569 of file mapping_box.cc.
References FEValuesBase::ExcAccessToUninitializedField().
|
overridevirtual |
Implements Mapping< dim, dim >.
Definition at line 795 of file mapping_box.cc.
References FEValuesBase::ExcAccessToUninitializedField().
|
overridevirtual |
Implements Mapping< dim, dim >.
Definition at line 509 of file mapping_box.cc.
References FEValuesBase::ExcAccessToUninitializedField().
|
overridevirtual |
Implements Mapping< dim, dim >.
Definition at line 682 of file mapping_box.cc.
References FEValuesBase::ExcAccessToUninitializedField().
|
overridevirtual |
Implements Mapping< dim, dim >.
Definition at line 834 of file mapping_box.cc.
References FEValuesBase::ExcAccessToUninitializedField().
|
overridevirtual |
Reimplemented from Mapping< dim, dim >.
Definition at line 955 of file mapping_box.cc.
References boxes, has_box(), and polytope_translator.
|
overridevirtual |
Implements Mapping< dim, dim >.
Definition at line 940 of file mapping_box.cc.
References boxes, has_box(), and polytope_translator.
|
overridevirtual |
Implements Mapping< dim, dim >.
Definition at line 925 of file mapping_box.cc.
References boxes, has_box(), and polytope_translator.
|
private |
Update the cell_extents field of the incoming InternalData object with the size of the incoming cell.
Definition at line 196 of file mapping_box.cc.
References boxes, BoundingBox< int spacedim, typename Number >::get_boundary_points(), polytope_translator, BoundingBox< int spacedim, typename Number >::side_length(), and CellSimilarity::translation.
Referenced by fill_fe_immersed_surface_values(), and fill_fe_values().
|
private |
Vector of (local) bounding boxes
Definition at line 372 of file mapping_box.h.
Referenced by MappingBox(), maybe_update_cell_quadrature_points(), transform_points_real_to_unit_cell(), transform_real_to_unit_cell(), transform_unit_to_real_cell(), and update_cell_extents().
|
private |
Map from global cell index to bounding box index
Definition at line 378 of file mapping_box.h.
Referenced by fill_fe_immersed_surface_values(), fill_fe_values(), MappingBox(), maybe_update_cell_quadrature_points(), transform_points_real_to_unit_cell(), transform_real_to_unit_cell(), transform_unit_to_real_cell(), and update_cell_extents().