36template <
int dim,
int spacedim>
45template <
int dim,
int spacedim>
55template <
int dim,
int spacedim>
68template <
int dim,
int spacedim>
69std::unique_ptr<Mapping<dim, spacedim>>
72 return std::make_unique<MappingQCache<dim, spacedim>>(*this);
77template <
int dim,
int spacedim>
86template <
int dim,
int spacedim>
100 const auto mapping_q =
102 if (mapping_q !=
nullptr && this->
get_degree() == mapping_q->get_degree())
104 return mapping_q->compute_mapping_support_points(cell);
111 auto &fe_values = fe_values_all.
get();
112 if (fe_values.get() ==
nullptr)
117 std::vector<Point<dim>> quadrature_points;
121 quadrature_points.push_back(quadrature_gl.point(i));
124 fe_values = std::make_unique<FEValues<dim, spacedim>>(
128 fe_values->reinit(cell);
129 return fe_values->get_quadrature_points();
136template <
int dim,
int spacedim>
142 &compute_points_on_cell)
149 std::make_shared<std::vector<std::vector<std::vector<Point<spacedim>>>>>(
151 for (
unsigned int l = 0; l < triangulation.
n_levels(); ++l)
155 triangulation.
begin(),
160 (*support_point_cache)[cell->level()][cell->index()] =
161 compute_points_on_cell(cell);
165 [[maybe_unused]] const unsigned int d = this->get_degree() + 1;
167 (*support_point_cache)[cell->level()][cell->index()].size(),
168 Utilities::pow(d, dim));
170 std::function<
void(
void *)>(),
181template <
int dim,
int spacedim>
189 const bool function_describes_relative_displacement)
199 std::vector<Point<spacedim>> points;
201 const auto mapping_q =
204 if (mapping_q !=
nullptr && this->
get_degree() == mapping_q->get_degree())
206 points = mapping_q->compute_mapping_support_points(cell);
213 auto &fe_values = fe_values_all.
get();
214 if (fe_values.get() ==
nullptr)
219 std::vector<Point<dim>> quadrature_points;
223 quadrature_points.push_back(quadrature_gl.point(i));
226 fe_values = std::make_unique<FEValues<dim, spacedim>>(
230 fe_values->reinit(cell);
231 points = fe_values->get_quadrature_points();
234 for (
auto &p : points)
235 if (function_describes_relative_displacement)
236 p += transformation_function(cell, p);
238 p = transformation_function(cell, p);
248template <
int dim,
int spacedim>
254 const bool function_describes_relative_displacement)
261 [&](
const auto &,
const auto &point) {
263 for (
unsigned int c = 0; c < spacedim; ++c)
264 new_point[c] = transformation_function.
value(point, c);
267 function_describes_relative_displacement);
276 template <
typename VectorType>
278 copy_locally_owned_data_from(
279 const VectorType &vector,
284 temp.
reinit(vector.locally_owned_elements());
292template <
int dim,
int spacedim>
293template <
typename VectorType>
298 const VectorType &vector,
299 const bool vector_describes_relative_displacement)
306 const unsigned int is_fe_q =
308 const unsigned int is_fe_dgq =
311 const auto lexicographic_to_hierarchic_numbering =
320 const IndexSet locally_relevant_dofs =
323 locally_relevant_dofs,
325 copy_locally_owned_data_from(vector, vector_ghosted);
336 const bool interpolation_of_values_is_needed =
344 const bool is_active_non_artificial_cell =
345 (cell_tria->is_active() == true) &&
346 (cell_tria->is_artificial() == false);
348 const typename DoFHandler<dim, spacedim>::cell_iterator cell_dofs(
349 &cell_tria->get_triangulation(),
354 const auto mapping_q =
355 dynamic_cast<const MappingQ<dim, spacedim> *>(&mapping);
359 ((vector_describes_relative_displacement ||
360 (is_active_non_artificial_cell == false)) &&
361 ((mapping_q != nullptr &&
362 this->get_degree() == mapping_q->get_degree()) ==
365 (is_active_non_artificial_cell && interpolation_of_values_is_needed) )
370 auto &fe_values = fe_values_all.get();
371 if (fe_values.get() == nullptr)
373 const QGaussLobatto<dim> quadrature_gl(this->polynomial_degree +
376 std::vector<Point<dim>> quadrature_points;
378 FETools::hierarchic_to_lexicographic_numbering<dim>(
379 this->polynomial_degree))
380 quadrature_points.push_back(quadrature_gl.point(i));
381 const Quadrature<dim> quadrature(quadrature_points);
383 fe_values = std::make_unique<FEValues<dim, spacedim>>(
385 interpolation_of_values_is_needed ?
387 static_cast<const FiniteElement<dim, spacedim> &>(fe_nothing),
389 update_quadrature_points | update_values);
392 if (interpolation_of_values_is_needed)
393 fe_values->reinit(cell_dofs);
395 fe_values->reinit(cell_tria);
403 if (vector_describes_relative_displacement ||
404 is_active_non_artificial_cell ==
false)
406 if (mapping_q !=
nullptr &&
407 this->
get_degree() == mapping_q->get_degree())
408 result = mapping_q->compute_mapping_support_points(cell_tria);
410 result = fe_values_all.
get()->get_quadrature_points();
415 if (is_active_non_artificial_cell ==
false)
425 if (interpolation_of_values_is_needed ==
false)
429 std::vector<types::global_dof_index> dof_indices(
431 cell_dofs->get_dof_indices(dof_indices);
433 for (
unsigned int i = 0; i < dof_indices.size(); ++i)
440 if (vector_describes_relative_displacement)
441 result[
id.second][
id.first] +=
442 vector_ghosted(dof_indices[i]);
444 result[
id.second][
id.first] =
445 vector_ghosted(dof_indices[i]);
450 if (vector_describes_relative_displacement)
451 result[lexicographic_to_hierarchic_numbering[
id.second]]
452 [
id.first] += vector_ghosted(dof_indices[i]);
454 result[lexicographic_to_hierarchic_numbering[
id.second]]
455 [
id.first] = vector_ghosted(dof_indices[i]);
465 auto &fe_values = fe_values_all.
get();
467 std::vector<Vector<typename VectorType::value_type>> values(
468 fe_values->n_quadrature_points,
471 fe_values->get_function_values(vector_ghosted, values);
473 for (
unsigned int q = 0; q < fe_values->n_quadrature_points; ++q)
474 for (
unsigned int c = 0; c < spacedim; ++c)
475 if (vector_describes_relative_displacement)
476 result[q][c] += values[q][c];
478 result[q][c] = values[q][c];
484 uses_level_info =
false;
489template <
int dim,
int spacedim>
490template <
typename VectorType>
496 const bool vector_describes_relative_displacement)
506 const unsigned int is_fe_q =
508 const unsigned int is_fe_dgq =
511 const auto lexicographic_to_hierarchic_numbering =
524 const IndexSet locally_relevant_dofs =
527 locally_relevant_dofs,
529 copy_locally_owned_data_from(vectors[l], vectors_ghosted[l]);
530 vectors_ghosted[l].update_ghost_values();
541 const bool interpolation_of_values_is_needed =
549 const bool is_non_artificial_cell =
550 cell_tria->level_subdomain_id() != numbers::artificial_subdomain_id;
552 const typename DoFHandler<dim, spacedim>::level_cell_iterator cell_dofs(
553 &cell_tria->get_triangulation(),
558 const auto mapping_q =
559 dynamic_cast<const MappingQ<dim, spacedim> *>(&mapping);
563 ((vector_describes_relative_displacement ||
564 (is_non_artificial_cell == false)) &&
565 ((mapping_q != nullptr &&
566 this->get_degree() == mapping_q->get_degree()) ==
569 (is_non_artificial_cell == true && interpolation_of_values_is_needed) )
574 auto &fe_values = fe_values_all.get();
575 if (fe_values.get() == nullptr)
577 const QGaussLobatto<dim> quadrature_gl(this->polynomial_degree +
580 std::vector<Point<dim>> quadrature_points;
582 FETools::hierarchic_to_lexicographic_numbering<dim>(
583 this->polynomial_degree))
584 quadrature_points.push_back(quadrature_gl.point(i));
585 const Quadrature<dim> quadrature(quadrature_points);
587 fe_values = std::make_unique<FEValues<dim, spacedim>>(
589 interpolation_of_values_is_needed ?
591 static_cast<const FiniteElement<dim, spacedim> &>(fe_nothing),
593 update_quadrature_points | update_values);
596 if (interpolation_of_values_is_needed)
597 fe_values->reinit(cell_dofs);
599 fe_values->reinit(cell_tria);
607 if (vector_describes_relative_displacement ||
608 (is_non_artificial_cell ==
false))
610 if (mapping_q !=
nullptr &&
611 this->
get_degree() == mapping_q->get_degree())
612 result = mapping_q->compute_mapping_support_points(cell_tria);
614 result = fe_values_all.
get()->get_quadrature_points();
619 if (is_non_artificial_cell ==
false)
629 if (interpolation_of_values_is_needed ==
false)
633 std::vector<types::global_dof_index> dof_indices(
635 cell_dofs->get_mg_dof_indices(dof_indices);
637 for (
unsigned int i = 0; i < dof_indices.size(); ++i)
644 if (vector_describes_relative_displacement)
645 result[
id.second][
id.first] +=
646 vectors_ghosted[cell_tria->
level()](dof_indices[i]);
648 result[
id.second][
id.first] =
649 vectors_ghosted[cell_tria->
level()](dof_indices[i]);
654 if (vector_describes_relative_displacement)
655 result[lexicographic_to_hierarchic_numbering[
id.second]]
657 vectors_ghosted[cell_tria->
level()](dof_indices[i]);
659 result[lexicographic_to_hierarchic_numbering[
id.second]]
661 vectors_ghosted[cell_tria->
level()](dof_indices[i]);
671 auto &fe_values = fe_values_all.
get();
673 std::vector<types::global_dof_index> dof_indices(
675 cell_dofs->get_mg_dof_indices(dof_indices);
677 std::vector<typename VectorType::value_type> dof_values(
681 dof_values[i] = vectors_ghosted[cell_tria->
level()](dof_indices[i]);
683 for (
unsigned int c = 0; c < spacedim; ++c)
685 for (
unsigned int q = 0; q < fe_values->n_quadrature_points; ++q)
686 if (vector_describes_relative_displacement ==
false && i == 0)
688 dof_values[i] * fe_values->shape_value_component(i, q, c);
691 dof_values[i] * fe_values->shape_value_component(i, q, c);
697 uses_level_info =
true;
702template <
int dim,
int spacedim>
707 return sizeof(*this) +
710 return sizeof(*this);
715template <
int dim,
int spacedim>
716std::vector<Point<spacedim>>
721 ExcMessage(
"Must call MappingQCache::initialize() before "
722 "using it or after mesh has changed!"));
733template <
int dim,
int spacedim>
734boost::container::small_vector<Point<spacedim>,
745 ExcMessage(
"Must call MappingQCache::initialize() before "
746 "using it or after mesh has changed!"));
752 const auto ptr = (*support_point_cache)[cell->
level()][cell->
index()].begin();
753 return boost::container::small_vector<Point<spacedim>,
765#include "fe/mapping_q_cache.inst"
const hp::FECollection< dim, spacedim > & get_fe_collection() const
const FiniteElement< dim, spacedim > & get_fe(const types::fe_index index=0) const
const IndexSet & locally_owned_mg_dofs(const unsigned int level) const
const Triangulation< dim, spacedim > & get_triangulation() const
const IndexSet & locally_owned_dofs() const
MPI_Comm get_mpi_communicator() const
const unsigned int degree
unsigned int n_dofs_per_cell() const
virtual const FiniteElement< dim, spacedim > & base_element(const unsigned int index) const
std::pair< unsigned int, unsigned int > system_to_component_index(const unsigned int index) const
unsigned int element_multiplicity(const unsigned int index) const
unsigned int n_base_elements() const
const unsigned int n_components
virtual RangeNumberType value(const Point< dim > &p, const unsigned int component=0) const
void import_elements(const ::Vector< Number > &vec, VectorOperation::values operation, const std::shared_ptr< const Utilities::MPI::CommunicationPatternBase > &communication_pattern={})
virtual void reinit(const size_type size, const bool omit_zeroing_entries=false)
void update_ghost_values() const
void import_elements(const Vector< Number, MemorySpace2 > &src, VectorOperation::values operation)
void reinit(const size_type size, const bool omit_zeroing_entries=false)
unsigned int max_level() const
unsigned int min_level() const
std::shared_ptr< std::vector< std::vector< std::vector< Point< spacedim > > > > > support_point_cache
std::size_t memory_consumption() const
virtual bool preserves_vertex_locations() const override
virtual std::vector< Point< spacedim > > compute_mapping_support_points(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const override
MappingQCache(const unsigned int polynomial_degree)
virtual boost::container::small_vector< Point< spacedim >, ReferenceCells::max_n_vertices< dim >() > get_vertices(const typename Triangulation< dim, spacedim >::cell_iterator &cell) const override
virtual std::unique_ptr< Mapping< dim, spacedim > > clone() const override
void initialize(const Mapping< dim, spacedim > &mapping, const Triangulation< dim, spacedim > &triangulation)
boost::signals2::connection clear_signal
friend class MappingQCache
const unsigned int polynomial_degree
MappingQ(const unsigned int polynomial_degree)
unsigned int get_degree() const
Abstract base class for mapping classes.
static unsigned int n_threads()
A class that provides a separate storage location on each thread that accesses the object.
unsigned int n_vertices() const
cell_iterator begin(const unsigned int level=0) const
unsigned int n_levels() const
cell_iterator end() const
unsigned int n_raw_cells(const unsigned int level) const
virtual unsigned int n_global_levels() const
unsigned int size() const
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define Assert(cond, exc)
#define AssertDimension(dim1, dim2)
#define AssertIndexRange(index, range)
static ::ExceptionBase & ExcInternalError()
static ::ExceptionBase & ExcMessage(std::string arg1)
TriaIterator< CellAccessor< dim, spacedim > > cell_iterator
@ update_quadrature_points
Transformed quadrature points.
MappingQ< dim, spacedim > StaticMappingQ1< dim, spacedim >::mapping
std::enable_if_t< std::is_fundamental_v< T >, std::size_t > memory_consumption(const T &t)
constexpr unsigned int max_n_vertices()
constexpr T pow(const T base, const int iexp)
std::vector< Integer > invert_permutation(const std::vector< Integer > &permutation)
void run(const std::vector< std::vector< Iterator > > &colored_iterators, Worker worker, Copier copier, const ScratchData &sample_scratch_data, const CopyData &sample_copy_data, const unsigned int queue_length=2 *MultithreadInfo::n_threads(), const unsigned int chunk_size=8)
static constexpr unsigned int vertices_per_cell
boost::signals2::signal< void()> any_change