16#ifndef dealii_non_matching_mapping_info_h
17#define dealii_non_matching_mapping_info_h
45 template <
int dim,
int spacedim = dim>
56 const UpdateFlags &update_flags)
58 return mapping->requires_update_flags(update_flags);
64 const UpdateFlags &update_flags_mapping,
69 &internal_mapping_data,
73 internal_mapping_data->reinit(update_flags_mapping, quadrature);
75 cell_similarity =
mapping->fill_fe_values(cell,
78 *internal_mapping_data,
87 const UpdateFlags &update_flags_mapping,
91 &internal_mapping_data,
94 mapping_data.
initialize(quadrature.size(), update_flags_mapping);
96 internal_mapping_data->reinit(update_flags_mapping, quadrature);
98 mapping->fill_fe_immersed_surface_values(cell,
100 *internal_mapping_data,
109 const UpdateFlags &update_flags_mapping,
111 const unsigned int face_no,
114 &internal_mapping_data,
125 *internal_mapping_data);
134 mapping_q->fill_mapping_data_for_face_quadrature(
135 cell, face_no, quadrature, *internal_mapping_data, mapping_data);
139 auto internal_mapping_data =
140 mapping->get_face_data(update_flags_mapping,
143 mapping->fill_fe_face_values(cell,
146 *internal_mapping_data,
152 template <
int dim,
int spacedim = dim>
155 const double diameter,
159 const auto jac_0 = inverse_jacobians[0];
160 const double zero_tolerance_double =
161 1e4 / diameter * std::numeric_limits<double>::epsilon() * 1024.;
162 bool jacobian_constant =
true;
163 for (
unsigned int q = 1; q < inverse_jacobians.size(); ++q)
166 for (
unsigned int d = 0; d < dim; ++d)
167 for (
unsigned int e = 0; e < spacedim; ++e)
168 if (std::fabs(jac_0[d][e] - jac[d][e]) > zero_tolerance_double)
169 jacobian_constant =
false;
170 if (!jacobian_constant)
176 bool cell_cartesian = jacobian_constant && dim == spacedim;
177 for (
unsigned int d = 0; d < dim; ++d)
178 for (
unsigned int e = 0; e < dim; ++e)
180 if (std::fabs(jac_0[d][e]) > zero_tolerance_double)
182 cell_cartesian =
false;
188 return ::internal::MatrixFreeFunctions::GeometryType::cartesian;
189 else if (jacobian_constant)
190 return ::internal::MatrixFreeFunctions::GeometryType::affine;
192 return ::internal::MatrixFreeFunctions::GeometryType::general;
218 template <
int dim,
int spacedim = dim,
typename Number =
double>
226 Number>::vectorized_value_type;
322 template <
typename ContainerType>
325 const ContainerType &cell_iterator_range,
326 const std::vector<std::vector<
Point<dim>>> &unit_points_vector,
335 template <
typename ContainerType>
338 const ContainerType &cell_iterator_range,
346 template <
typename ContainerType>
349 const ContainerType &cell_iterator_range,
357 template <
typename ContainerType>
360 const ContainerType &cell_iterator_range,
368 template <
typename CellIteratorType>
370 reinit_faces(
const std::vector<std::pair<CellIteratorType, unsigned int>>
371 &face_iterator_range_interior,
407 const bool is_interior =
true)
const;
415 const bool is_interior =
true)
const;
459 template <
bool is_face>
481 const unsigned int geometry_index)
const;
517 template <
typename NumberType>
544 const bool is_face_centric =
false);
551 const unsigned int n_q_points,
560 const unsigned int n_q_points,
569 const unsigned int n_q_points,
572 const std::vector<double> &weights,
573 const unsigned int compressed_unit_point_index_offset,
574 const bool affine_cell,
575 const bool is_interior =
true);
586 template <
typename ContainerType,
typename QuadratureType>
589 const ContainerType &cell_iterator_range,
590 const std::vector<QuadratureType> &quadrature_vector,
591 const unsigned int n_unfiltered_cells,
637 std::unique_ptr<typename Mapping<dim, spacedim>::InternalDataBase>
678 std::vector<::internal::MatrixFreeFunctions::GeometryType>
cell_type;
711 std::array<AlignedVector<DerivativeForm<1, dim, spacedim, Number>>, 2>
721 std::array<AlignedVector<DerivativeForm<1, spacedim, dim, Number>>, 2>
773 template <
int dim,
int spacedim,
typename Number>
776 const unsigned int offset,
777 const bool is_interior)
const
780 return is_interior ? face_pair.first : face_pair.second;
786 template <
int dim,
int spacedim,
typename Number>
821 template <
int dim,
int spacedim,
typename Number>
834 template <
int dim,
int spacedim,
typename Number>
838 const std::vector<
Point<dim>> &unit_points_in)
845 template <
int dim,
int spacedim,
typename Number>
857 template <
int dim,
int spacedim,
typename Number>
866 const unsigned int n_q_points =
869 const unsigned int n_q_points_data =
925 template <
int dim,
int spacedim,
typename Number>
926 template <
typename ContainerType>
929 const ContainerType &cell_iterator_range,
930 const std::vector<std::vector<
Point<dim>>> &unit_points_vector,
931 const unsigned int n_unfiltered_cells)
933 const unsigned int n_cells = unit_points_vector.size();
935 std::distance(cell_iterator_range.begin(),
936 cell_iterator_range.end()));
938 std::vector<Quadrature<dim>> quadrature_vector(n_cells);
939 for (
unsigned int cell_index = 0; cell_index < n_cells; ++cell_index)
940 quadrature_vector[cell_index] =
943 reinit_cells(cell_iterator_range, quadrature_vector, n_unfiltered_cells);
948 template <
int dim,
int spacedim,
typename Number>
949 template <
typename ContainerType,
typename QuadratureType>
952 const ContainerType &cell_iterator_range,
953 const std::vector<QuadratureType> &quadrature_vector,
954 const unsigned int n_unfiltered_cells,
965 const unsigned int n_cells = quadrature_vector.size();
967 std::distance(cell_iterator_range.begin(),
968 cell_iterator_range.end()));
982 for (
const auto &
quadrature : quadrature_vector)
984 const unsigned int n_points =
quadrature.size();
987 const unsigned int n_q_points =
991 const unsigned int n_q_points_data =
1009 unsigned int size_compressed_data = 0;
1010 unsigned int cell_index = 0;
1011 for (
const auto &cell : cell_iterator_range)
1019 const auto &
quadrature = quadrature_vector[cell_index];
1034 const unsigned int n_q_points_data =
1052 const bool affine_cells =
1061 1e4 / cell->
diameter() * std::numeric_limits<double>::epsilon() *
1066 const auto comparison_result =
1067 (!affine_cells ||
mapping_data.inverse_jacobians.empty() ||
1077 comparison_result ==
1085 const unsigned int n_compressed_data_last_cell =
1094 n_compressed_data_last_cell);
1118 size_compressed_data =
1131 jacobians[0].resize(size_compressed_data);
1145 template <
int dim,
int spacedim,
typename Number>
1146 template <
typename ContainerType>
1149 const ContainerType &cell_iterator_range,
1151 const unsigned int n_unfiltered_cells)
1153 auto compute_mapping_data_for_cells =
1170 cell_iterator_range,
1173 compute_mapping_data_for_cells);
1178 template <
int dim,
int spacedim,
typename Number>
1179 template <
typename ContainerType>
1182 const ContainerType &cell_iterator_range,
1184 const unsigned int n_unfiltered_cells)
1189 "There is no known use-case for AdditionalData::use_global_weights=true and reinit_surface()"));
1196 auto compute_mapping_data_for_surface =
1211 cell_iterator_range,
1214 compute_mapping_data_for_surface);
1219 template <
int dim,
int spacedim,
typename Number>
1220 template <
typename ContainerType>
1223 const ContainerType &cell_iterator_range,
1225 const unsigned int n_unfiltered_cells)
1234 const unsigned int n_cells = quadrature_vector.size();
1236 std::distance(cell_iterator_range.begin(),
1237 cell_iterator_range.end()));
1241 unsigned int n_faces = 0;
1242 unsigned int cell_index = 0;
1243 for (
const auto &cell : cell_iterator_range)
1246 n_faces += cell->n_faces();
1258 unsigned int n_unit_points = 0;
1259 unsigned int n_data_points = 0;
1260 for (
const auto &cell : cell_iterator_range)
1262 for (
const auto &f : cell->face_indices())
1264 const unsigned int current_face_index =
1270 const unsigned int n_points =
1271 quadrature_vector[cell_index][f].size();
1274 const unsigned int n_q_points =
1276 n_unit_points += n_q_points;
1278 const unsigned int n_q_points_data =
1280 n_data_points += n_q_points_data;
1300 bool first_set =
false;
1301 unsigned int size_compressed_data = 0;
1303 for (
const auto &cell : cell_iterator_range)
1305 const auto &quadratures_on_faces = quadrature_vector[cell_index];
1307 Assert(quadratures_on_faces.size() == cell->n_faces(),
1311 for (
const auto &f : cell->face_indices())
1313 const auto &quadrature_on_face = quadratures_on_faces[f];
1314 const bool empty = quadrature_on_face.empty();
1316 const unsigned int current_face_index =
1320 const unsigned int n_q_points =
1326 quadrature_on_face.get_points());
1354 if (current_face_index > 0)
1357 const bool affine_cells =
1366 1e4 / cell->diameter() *
1367 std::numeric_limits<double>::epsilon() * 1024.);
1371 const auto comparison_result =
1372 (!affine_cells ||
mapping_data.inverse_jacobians.empty() ||
1382 comparison_result ==
1388 else if (first_set &&
1395 double>::ComparisonResult::equal))
1401 const unsigned int n_compressed_data_last_cell =
1410 n_compressed_data_last_cell);
1425 quadrature_on_face.get_weights(),
1436 size_compressed_data =
1450 jacobians[0].resize(size_compressed_data);
1464 template <
int dim,
int spacedim,
typename Number>
1465 template <
typename CellIteratorType>
1468 const std::vector<std::pair<CellIteratorType, unsigned int>>
1469 &face_iterator_range_interior,
1479 const unsigned int n_faces = quadrature_vector.size();
1481 std::distance(face_iterator_range_interior.begin(),
1482 face_iterator_range_interior.end()));
1494 for (
const auto &
quadrature : quadrature_vector)
1496 const unsigned int n_points =
quadrature.size();
1499 const unsigned int n_q_points =
1503 const unsigned int n_q_points_data =
1517 std::array<MappingData, 2> mapping_data_previous_cell;
1518 std::array<MappingData, 2> mapping_data_first;
1519 bool first_set =
false;
1520 unsigned int size_compressed_data = 0;
1521 unsigned int face_index = 0;
1522 for (
const auto &cell_and_f : face_iterator_range_interior)
1524 const auto &quadrature_on_face = quadrature_vector[face_index];
1525 const bool empty = quadrature_on_face.empty();
1528 const auto &cell_m = cell_and_f.first;
1529 const auto f_m = cell_and_f.second;
1532 const auto &cell_p =
1533 cell_m->at_boundary(f_m) ? cell_m : cell_m->neighbor(f_m);
1535 cell_m->at_boundary(f_m) ? f_m : cell_m->neighbor_face_no(f_m);
1538 empty || (cell_m->level() == cell_p->level()),
1540 "Intersected faces with quadrature points need to have the same "
1541 "refinement level!"));
1546 cell_m->combined_face_orientation(f_m) ==
1548 cell_p->combined_face_orientation(f_p) ==
1551 "Non standard face orientation is currently not implemented."));
1559 quadrature_on_face.get_points());
1588 cell_m->diameter(),
mapping_data[0].inverse_jacobians),
1590 cell_m->diameter(),
mapping_data[1].inverse_jacobians)));
1607 const bool affine_cells =
1616 1e4 / cell_m->diameter() *
1617 std::numeric_limits<double>::epsilon() * 1024.);
1621 const auto comparison_result_m =
1622 (!affine_cells ||
mapping_data[0].inverse_jacobians.empty() ||
1629 const auto comparison_result_p =
1630 (!affine_cells ||
mapping_data[1].inverse_jacobians.empty() ||
1640 comparison_result_m ==
1642 comparison_result_p ==
1648 else if (first_set &&
1653 mapping_data_first[0].inverse_jacobians[0]) ==
1655 double>::ComparisonResult::equal) &&
1658 mapping_data_first[1].inverse_jacobians[0]) ==
1665 const unsigned int n_compressed_data_last_cell =
1674 n_compressed_data_last_cell);
1683 const unsigned int n_q_points_data =
1691 quadrature_on_face.get_weights(),
1703 quadrature_on_face.get_weights(),
1715 size_compressed_data =
1724 jacobians[0].resize(size_compressed_data);
1726 jacobians[1].resize(size_compressed_data);
1742 template <
int dim,
int spacedim,
typename Number>
1751 template <
int dim,
int spacedim,
typename Number>
1754 const unsigned int geometry_index)
const
1760 template <
int dim,
int spacedim,
typename Number>
1763 const unsigned int geometry_index)
const
1770 template <
int dim,
int spacedim,
typename Number>
1773 const unsigned int cell_index)
const
1778 "Cells have been not stored. You can enable this by Additional::store_cells."));
1786 template <
int dim,
int spacedim,
typename Number>
1787 template <
typename NumberType>
1792 const unsigned int n_lanes =
1794 const unsigned int n_filled_lanes_last_batch =
1797 if (n_filled_lanes_last_batch > 0)
1804 template <
int dim,
int spacedim,
typename Number>
1805 template <
bool is_face>
1808 const unsigned int cell_index,
1814 const unsigned int compressed_cell_index =
1820 "This mapping info is not reinitialized for a cell vector!"));
1821 return compressed_cell_index;
1827 "cell_index has to be set if face_number is specified!"));
1830 ExcMessage(
"This mapping info is not reinitialized for faces"
1831 " on cells in a vector!"));
1841 template <
int dim,
int spacedim,
typename Number>
1844 const unsigned int cell_index)
const
1850 ExcMessage(
"Mapping info object was not initialized for this"
1851 " active cell index!"));
1859 template <
int dim,
int spacedim,
typename Number>
1862 const unsigned int unit_points_index_offset,
1863 const unsigned int n_q_points,
1867 const unsigned int n_lanes =
1870 for (
unsigned int q = 0; q < n_q_points; ++q)
1872 const unsigned int offset = unit_points_index_offset + q;
1873 for (
unsigned int v = 0;
1876 for (
unsigned int d = 0; d < dim; ++d)
1878 unit_points[offset][d], v) = points[q * n_lanes + v][d];
1884 template <
int dim,
int spacedim,
typename Number>
1887 const unsigned int unit_points_index_offset,
1888 const unsigned int n_q_points,
1892 const unsigned int n_lanes =
1895 for (
unsigned int q = 0; q < n_q_points; ++q)
1897 const unsigned int offset = unit_points_index_offset + q;
1898 for (
unsigned int v = 0;
1901 for (
unsigned int d = 0; d < dim - 1; ++d)
1909 template <
int dim,
int spacedim,
typename Number>
1912 const unsigned int unit_points_index_offset,
1913 const unsigned int n_q_points,
1916 const std::vector<double> &weights,
1917 const unsigned int compressed_unit_point_index_offset,
1918 const bool affine_cell,
1919 const bool is_interior)
1921 const unsigned int n_lanes =
1924 for (
unsigned int q = 0; q < n_q_points; ++q)
1926 const unsigned int offset = unit_points_index_offset + q;
1927 const unsigned int compressed_offset =
1928 compressed_unit_point_index_offset + q;
1929 for (
unsigned int v = 0;
1933 if (q == 0 || !affine_cell)
1936 for (
unsigned int d = 0; d < dim; ++d)
1937 for (
unsigned int s = 0; s < spacedim; ++s)
1939 jacobians[is_interior ? 0 : 1][compressed_offset][d][s],
1943 for (
unsigned int d = 0; d < dim; ++d)
1944 for (
unsigned int s = 0; s < spacedim; ++s)
1947 [compressed_offset][d][s],
1959 JxW_values[offset], v) = weights[q * n_lanes + v];
1969 for (
unsigned int s = 0; s < spacedim; ++s)
1975 for (
unsigned int s = 0; s < spacedim; ++s)
1986 template <
int dim,
int spacedim,
typename Number>
1989 const unsigned int n_unit_point_batches)
1996 template <
int dim,
int spacedim,
typename Number>
1999 const unsigned int n_unit_point_batches)
2006 template <
int dim,
int spacedim,
typename Number>
2009 const unsigned int n_data_point_batches,
2010 const bool is_face_centric)
2014 jacobians[0].resize(n_data_point_batches);
2015 if (is_face_centric)
2016 jacobians[1].resize(n_data_point_batches);
2021 if (is_face_centric)
2034 template <
int dim,
int spacedim,
typename Number>
2039 const unsigned int offset)
const
2046 template <
int dim,
int spacedim,
typename Number>
2051 const unsigned int offset)
const
2058 template <
int dim,
int spacedim,
typename Number>
2061 const unsigned int offset)
const
2068 template <
int dim,
int spacedim,
typename Number>
2071 const unsigned int geometry_index)
const
2078 template <
int dim,
int spacedim,
typename Number>
2081 const unsigned int geometry_index)
const
2087 template <
int dim,
int spacedim,
typename Number>
2090 const unsigned int geometry_index)
const
2097 template <
int dim,
int spacedim,
typename Number>
2100 const bool is_interior)
const
2102 return jacobians[is_interior ? 0 : 1].data() + offset;
2107 template <
int dim,
int spacedim,
typename Number>
2110 const unsigned int offset,
2111 const bool is_interior)
const
2118 template <
int dim,
int spacedim,
typename Number>
2121 const unsigned int offset)
const
2128 template <
int dim,
int spacedim,
typename Number>
2129 inline const Number *
2137 template <
int dim,
int spacedim,
typename Number>
2146 template <
int dim,
int spacedim,
typename Number>
2155 template <
int dim,
int spacedim,
typename Number>
2164 template <
int dim,
int spacedim,
typename Number>
2186 memory +=
sizeof(*this);
ArrayView< std::remove_reference_t< typename std::iterator_traits< Iterator >::reference >, MemorySpaceType > make_array_view(const Iterator begin, const Iterator end)
double diameter(const Mapping< dim, spacedim > &mapping) const
unsigned int active_cell_index() const
friend class ObserverPointer
void initialize_face(const UpdateFlags update_flags, const Quadrature< dim > &quadrature, const unsigned int n_original_q_points)
Abstract base class for mapping classes.
const UpdateFlags update_flags
unsigned int compute_compressed_data_index_offset(const unsigned int geometry_index) const
const DerivativeForm< 1, spacedim, dim, Number > * get_inverse_jacobian(const unsigned int offset, const bool is_interior=true) const
typename ::internal::VectorizedArrayTrait< Number >::vectorized_value_type VectorizedArrayType
AlignedVector< Point< dim, VectorizedArrayType > > unit_points
std::array< AlignedVector< DerivativeForm< 1, dim, spacedim, Number > >, 2 > jacobians
AlignedVector< Number > JxW_values
::internal::MatrixFreeFunctions::GeometryType get_cell_type(const unsigned int geometry_index) const
::internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > MappingData
unsigned int get_face_number(const unsigned int offset, const bool is_interior) const
const Mapping< dim, spacedim > & get_mapping() const
void reinit_faces(const ContainerType &cell_iterator_range, const std::vector< std::vector< Quadrature< dim - 1 > > > &quadrature_vector, const unsigned int n_unfiltered_cells=numbers::invalid_unsigned_int)
std::array< AlignedVector< DerivativeForm< 1, spacedim, dim, Number > >, 2 > inverse_jacobians
const Point< dim, VectorizedArrayType > * get_unit_point(const unsigned int offset) const
unsigned int get_n_q_points_unvectorized(const unsigned int geometry_index) const
const ObserverPointer< const Mapping< dim, spacedim > > mapping
unsigned int compute_compressed_cell_index(const unsigned int cell_index) const
const Point< dim - 1, VectorizedArrayType > * get_unit_point_faces(const unsigned int offset) const
Quadrature< dim > quadrature
std::vector< unsigned int > cell_index_offset
void store_mapping_data(const unsigned int unit_points_index_offset, const unsigned int n_q_points, const unsigned int n_q_points_unvectorized, const MappingData &mapping_data, const std::vector< double > &weights, const unsigned int compressed_unit_point_index_offset, const bool affine_cell, const bool is_interior=true)
AlignedVector< Tensor< 1, spacedim, Number > > normal_vectors
unsigned int compute_geometry_index_offset(const unsigned int cell_index, const unsigned int face_number) const
std::vector<::internal::MatrixFreeFunctions::GeometryType > cell_type
MappingInfo & operator=(const MappingInfo &)=delete
ObserverPointer< const Triangulation< dim, spacedim > > triangulation
std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > internal_mapping_data
void reinit_surface(const ContainerType &cell_iterator_range, const std::vector< ImmersedSurfaceQuadrature< dim > > &quadrature_vector, const unsigned int n_unfiltered_cells=numbers::invalid_unsigned_int)
void resize_unit_points_faces(const unsigned int n_unit_point_batches)
const Tensor< 1, spacedim, Number > * get_normal_vector(const unsigned int offset) const
void reinit(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const std::vector< Point< dim > > &unit_points)
const DerivativeForm< 1, dim, spacedim, Number > * get_jacobian(const unsigned int offset, const bool is_interior=true) const
void reinit_cells(const ContainerType &cell_iterator_range, const std::vector< std::vector< Point< dim > > > &unit_points_vector, const unsigned int n_unfiltered_cells=numbers::invalid_unsigned_int)
void resize_data_fields(const unsigned int n_data_point_batches, const bool is_face_centric=false)
void resize_unit_points(const unsigned int n_unit_point_batches)
std::size_t memory_consumption() const
UpdateFlags get_update_flags() const
void store_unit_points_faces(const unsigned int unit_points_index_offset, const unsigned int n_q_points, const unsigned int n_q_points_unvectorized, const std::vector< Point< dim - 1 > > &points)
unsigned int compute_unit_point_index_offset(const unsigned int geometry_index) const
std::vector< unsigned int > cell_index_to_compressed_cell_index
AlignedVector< Point< spacedim, Number > > real_points
unsigned int compute_data_index_offset(const unsigned int geometry_index) const
@ faces_on_cells_in_vector
std::vector< std::pair< unsigned char, unsigned char > > face_number
MappingInfo(const Mapping< dim, spacedim > &mapping, const UpdateFlags update_flags, const AdditionalData additional_data=AdditionalData())
std::vector< unsigned int > unit_points_index
std::vector< std::pair< int, int > > cell_level_and_indices
std::vector< unsigned int > compressed_data_index_offsets
bool do_cell_index_compression
std::vector< unsigned int > data_index_offsets
bool is_face_state() const
std::vector< unsigned int > n_q_points_unvectorized
const Number * get_JxW(const unsigned int offset) const
const Point< spacedim, Number > * get_real_point(const unsigned int offset) const
void store_unit_points(const unsigned int unit_points_index_offset, const unsigned int n_q_points, const unsigned int n_q_points_unvectorized, const std::vector< Point< dim > > &points)
const AdditionalData additional_data
AlignedVector< Point< dim - 1, VectorizedArrayType > > unit_points_faces
unsigned int compute_n_q_points(const unsigned int n_q_points_unvectorized)
MappingInfo(const MappingInfo &)=delete
UpdateFlags update_flags_mapping
void do_reinit_cells(const ContainerType &cell_iterator_range, const std::vector< QuadratureType > &quadrature_vector, const unsigned int n_unfiltered_cells, const std::function< void(const typename Triangulation< dim, spacedim >::cell_iterator &cell, const QuadratureType &quadrature, MappingData &mapping_data)> &compute_mapping_data)
UpdateFlags get_update_flags_mapping() const
Triangulation< dim, spacedim >::cell_iterator get_cell_iterator(const unsigned int cell_index) const
static void compute_mapping_data_for_immersed_surface_quadrature(const ObserverPointer< const Mapping< dim, spacedim > > &mapping, const UpdateFlags &update_flags_mapping, const typename Triangulation< dim, spacedim >::cell_iterator &cell, const ImmersedSurfaceQuadrature< dim > &quadrature, std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > &internal_mapping_data, MappingData &mapping_data)
static void compute_mapping_data_for_face_quadrature(const ObserverPointer< const Mapping< dim, spacedim > > &mapping, const UpdateFlags &update_flags_mapping, const typename Triangulation< dim, spacedim >::cell_iterator &cell, const unsigned int face_no, const Quadrature< dim - 1 > &quadrature, std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > &internal_mapping_data, MappingData &mapping_data)
static void compute_mapping_data_for_quadrature(const ObserverPointer< const Mapping< dim, spacedim > > &mapping, const UpdateFlags &update_flags_mapping, const typename Triangulation< dim, spacedim >::cell_iterator &cell, CellSimilarity::Similarity &cell_similarity, const Quadrature< dim > &quadrature, std::unique_ptr< typename Mapping< dim, spacedim >::InternalDataBase > &internal_mapping_data, MappingData &mapping_data)
static UpdateFlags required_update_flags(const ObserverPointer< const Mapping< dim, spacedim > > &mapping, const UpdateFlags &update_flags)
::internal::FEValuesImplementation::MappingRelatedData< dim, spacedim > MappingData
static void project_to_face(const ReferenceCell &reference_cell, const SubQuadrature &quadrature, const unsigned int face_no, std::vector< Point< dim > > &q_points)
unsigned int size() const
const Triangulation< dim, spacedim > & get_triangulation() const
ReferenceCell reference_cell() const
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
static ::ExceptionBase & ExcNotImplemented()
#define Assert(cond, exc)
#define AssertDimension(dim1, dim2)
static ::ExceptionBase & ExcDimensionMismatch(std::size_t arg1, std::size_t arg2)
static ::ExceptionBase & ExcMessage(std::string arg1)
TriaIterator< CellAccessor< dim, spacedim > > cell_iterator
@ update_normal_vectors
Normal vectors.
@ update_JxW_values
Transformed quadrature weights.
@ update_covariant_transformation
Covariant transformation.
@ update_jacobians
Volume element.
@ update_inverse_jacobians
Volume element.
@ update_gradients
Shape function gradients.
@ update_quadrature_points
Transformed quadrature points.
@ update_default
No update.
types::geometric_orientation combined_face_orientation(const unsigned int face) const
MappingQ< dim, spacedim > StaticMappingQ1< dim, spacedim >::mapping
std::enable_if_t< std::is_fundamental_v< T >, std::size_t > memory_consumption(const T &t)
::internal::MatrixFreeFunctions::GeometryType compute_geometry_type(const double diameter, const std::vector< DerivativeForm< 1, spacedim, dim, double > > &inverse_jacobians)
constexpr unsigned int invalid_unsigned_int
constexpr types::geometric_orientation default_geometric_orientation
::VectorizedArray< Number, width > max(const ::VectorizedArray< Number, width > &, const ::VectorizedArray< Number, width > &)
ComparisonResult compare(const std::vector< T > &v1, const std::vector< T > &v2) const
AdditionalData(const bool use_global_weights=false, const bool store_cells=false)
static constexpr std::size_t width()
static value_type & get(value_type &value, unsigned int c)