34template <
int structdim>
38 , manifold_id(
numbers::flat_manifold_id)
43template <
int structdim>
50 for (
unsigned int i = 0; i <
vertices.size(); ++i)
54 if (material_id !=
other.material_id)
57 if (boundary_id !=
other.boundary_id)
60 if (manifold_id !=
other.manifold_id)
90 template <
int dim,
int spacedim>
91 struct DescriptionTemp
97 template <
class Archive>
99 serialize(
Archive &
ar,
const unsigned int )
117 const auto create_request = [&](
const unsigned int other_rank) {
131 [&](
const unsigned int,
158 std::map<Point<spacedim>,
171 std::map<unsigned int, unsigned int>
212 other.coarse_cell_index_to_coarse_cell_id.
begin(),
213 other.coarse_cell_index_to_coarse_cell_id.
end());
215 for (
unsigned int i = 0; i < this->
cell_infos.size(); ++i)
216 this->cell_infos[i].
insert(this->cell_infos[i].
end(),
234 for (
unsigned int i = 0; i < this->
coarse_cells.size(); ++i)
235 temp.emplace_back(
this->coarse_cell_index_to_coarse_cell_id[i],
236 this->coarse_cells[i],
241 [](
const auto &a,
const auto &b) {
242 return std::get<0>(a) < std::get<0>(b);
246 [](
const auto &a,
const auto &b) {
247 return std::get<0>(a) == std::get<0>(b);
252 [](
const auto &a,
const auto &b) {
253 return std::get<2>(a) < std::get<2>(b);
259 for (
unsigned int i = 0; i <
temp.
size(); ++i)
262 std::get<0>(
temp[i]);
270 this->coarse_cell_vertices.
end(),
271 [](
const auto &a,
const auto &b) {
272 return a.first < b.first;
276 this->coarse_cell_vertices.
end(),
277 [](
const auto &a,
const auto &b) {
278 if (a.first == b.first)
280 Assert(a.second.distance(b.second) < 10e-8,
290 for (
unsigned int i = 0; i < this->
cell_infos.size(); ++i)
292 if (this->cell_infos[i].size() == 0)
295 std::sort(this->cell_infos[i].
begin(),
296 this->cell_infos[i].
end(),
297 [](
const auto &a,
const auto &b) {
301 std::vector<CellData<dim>>
temp;
302 temp.push_back(this->cell_infos[i][0]);
304 for (
unsigned int j = 1;
j < this->
cell_infos[i].size(); ++
j)
305 if (
temp.back().id == cell_infos[i][
j].id)
307 temp.back().subdomain_id =
309 this->cell_infos[i][
j].subdomain_id);
310 temp.back().level_subdomain_id =
312 this->cell_infos[i][
j].level_subdomain_id);
316 temp.push_back(this->cell_infos[i][
j]);
337 description.comm =
comm;
344 std::map<unsigned int, unsigned int> map;
348 description.coarse_cell_vertices.push_back(
356 for (unsigned
int v = 0; v < cell.vertices.size(); ++v)
357 cell.vertices[v] = map[cell.vertices[v]];
359 description.coarse_cell_index_to_coarse_cell_id =
368 std::vector<std::pair<unsigned int, Point<spacedim>>>
379 template <
int dim,
int spacedim>
386 if (cell->level() != 0)
395 template <
int dim,
int spacedim>
396 class CreateDescriptionFromTriangulationHelper
399 CreateDescriptionFromTriangulationHelper(
400 const ::Triangulation<dim, spacedim> &tria,
402 const typename ::Triangulation<dim, spacedim>::cell_iterator
403 &)> & subdomain_id_function,
405 const typename ::Triangulation<dim, spacedim>::cell_iterator
406 &)> & level_subdomain_id_function,
421 (
tria.get_mesh_smoothing() &
423 spacedim>::limit_level_difference_at_vertices),
425 "Source triangulation has to be set up with "
426 "limit_level_difference_at_vertices if the construction of the "
427 "multigrid hierarchy is requested!"));
430 tria, coinciding_vertex_groups, vertex_to_coinciding_vertex_group);
433 template <
typename T>
445 [
this](
const auto & cell,
454 cell->vertex_index(v));
466 for (
unsigned int l = 0;
l <
tria.n_levels(); ++
l)
469 for (
int level =
tria.get_triangulation().n_global_levels() - 1;
477 for (
const auto &cell :
tria.cell_iterators_on_level(
level))
483 for (
const auto &cell :
tria.active_cell_iterators())
494 [cell->vertex_index(v)])
500 for (
const auto &cell :
tria.cell_iterators_on_level(
level))
511 for (
const auto &cell :
tria.cell_iterators_on_level(0))
518 cell_data.material_id = cell->material_id();
519 cell_data.manifold_id = cell->manifold_id();
521 cell_data.
vertices[v] = cell->vertex_index(v);
530 cell->id().get_coarse_cell_id());
539 tria.get_triangulation().n_global_levels());
544 for (
const auto &cell :
tria.active_cell_iterators())
552 [&](
const auto &cell) {
553 if (cell->is_active())
556 [cell->vertex_index(v)])
561 for (
unsigned int level = 0;
562 level <
tria.get_triangulation().n_global_levels();
568 for (
const auto &cell :
tria.cell_iterators_on_level(
level))
571 (cell->is_active() &&
581 [cell->vertex_index(v)])
587 for (
const auto &cell :
tria.cell_iterators_on_level(
level))
599 for (
const auto f : cell->face_indices())
602 cell->face(f)->boundary_id();
610 cell_info.manifold_id = cell->manifold_id();
614 for (
const auto line : cell->line_indices())
620 for (
const auto f : cell->face_indices())
682 tria.get_vertices()[i]);
688 for (unsigned
int v = 0; v < cell.vertices.size(); ++v)
700 i,
tria.get_vertices()[i]);
704 const ::Triangulation<dim, spacedim> &
tria;
706 const typename ::Triangulation<dim, spacedim>::cell_iterator &)>
709 const typename ::Triangulation<dim, spacedim>::cell_iterator &)>
716 std::map<unsigned int, std::vector<unsigned int>>
724 template <
int dim,
int spacedim>
727 const ::Triangulation<dim, spacedim> &
tria,
732 if (
const auto tria_pdt =
dynamic_cast<
735 ExcMessage(
"MPI communicators do not match."));
742 ExcMessage(
"Rank has to be smaller than available processes."));
750 "For creation from a parallel::distributed::Triangulation, "
751 "my_rank has to equal global rank."));
756 dynamic_cast<const ::Triangulation<dim, spacedim> *
>(
765 ExcMessage(
"This type of triangulation is not supported!"));
769 return cell->subdomain_id();
773 return cell->level_subdomain_id();
788 template <
int dim,
int spacedim>
801#ifndef DEAL_II_WITH_MPI
811 const unsigned int my_rank =
826 typename ::Triangulation<dim, spacedim>::MeshSmoothing
>(
829 spacedim>::limit_level_difference_at_vertices) :
891 std::vector<char>
buf(
len);
918 template <
int dim,
int spacedim>
926 (partition.size() > 0) &&
932 (
tria.get_mesh_smoothing() &
935 "Source triangulation has to be set up with "
936 "limit_level_difference_at_vertices if the construction of the "
937 "multigrid hierarchy is requested!"));
939 std::vector<LinearAlgebra::distributed::Vector<double>>
partitions_mg;
949 partition.update_ghost_values();
953 for (
unsigned int l = 0; l <
tria.n_global_levels(); ++l)
955 tria_parallel->global_level_cell_index_partitioner(l).lock());
959 for (
const auto &cell :
tria.cell_iterators_on_level(
level))
961 if (cell->is_locally_owned_on_level() ==
false)
964 if (cell->is_active())
966 partition[cell->global_active_cell_index()];
970 [cell->child(0)->global_level_cell_index()];
985 template <
int dim,
int spacedim>
994#ifdef DEAL_II_WITH_MPI
999 if (partition.size() == 0)
1003 tria.get_communicator(),
1007 partition.update_ghost_values();
1010 partition.update_ghost_values();
1016 for (
unsigned int i = 0; i < partition.locally_owned_size(); ++i)
1018 static_cast<unsigned int>(partition.local_element(i)));
1021 for (
unsigned int i = 0; i < partition.locally_owned_size(); ++i)
1023 static_cast<unsigned int>(partition.local_element(i)));
1039 if ((cell->is_active() && (cell->is_artificial() ==
false)))
1040 return static_cast<unsigned int>(
1041 partition[cell->global_active_cell_index()]);
1049 return static_cast<unsigned int>(
1050 partitions_mg[cell->level()][cell->global_level_cell_index()]);
1059 tria.get_communicator(),
1078 partition.get_mpi_communicator(),
1088 tria.get_mesh_smoothing(),
1098#include "tria_description.inst"
value_type * data() const noexcept
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_NAMESPACE_CLOSE
#define Assert(cond, exc)
#define AssertDimension(dim1, dim2)
#define AssertThrowMPI(error_code)
static ::ExceptionBase & ExcInternalError()
static ::ExceptionBase & ExcMessage(std::string arg1)
Tensor< 2, dim, Number > l(const Tensor< 2, dim, Number > &F, const Tensor< 2, dim, Number > &dF_dt)
SymmetricTensor< 2, dim, Number > b(const Tensor< 2, dim, Number > &F)
Description< dim, spacedim > create_description_from_triangulation(const ::Triangulation< dim, spacedim > &tria, const MPI_Comm comm, const TriangulationDescription::Settings settings=TriangulationDescription::Settings::default_setting, const unsigned int my_rank_in=numbers::invalid_unsigned_int)
Description< dim, spacedim > create_description_from_triangulation_in_groups(const std::function< void(::Triangulation< dim, spacedim > &)> &serial_grid_generator, const std::function< void(::Triangulation< dim, spacedim > &, const MPI_Comm, const unsigned int)> &serial_grid_partitioner, const MPI_Comm comm, const int group_size=1, const typename Triangulation< dim, spacedim >::MeshSmoothing smoothing=::Triangulation< dim, spacedim >::none, const TriangulationDescription::Settings setting=TriangulationDescription::Settings::default_setting)
@ construct_multigrid_hierarchy
VectorType::value_type * end(VectorType &V)
VectorType::value_type * begin(VectorType &V)
std::vector< unsigned int > selector(const std::vector< unsigned int > &targets, const std::function< RequestType(const unsigned int)> &create_request, const std::function< AnswerType(const unsigned int, const RequestType &)> &answer_request, const std::function< void(const unsigned int, const AnswerType &)> &process_answer, const MPI_Comm comm)
unsigned int n_mpi_processes(const MPI_Comm mpi_communicator)
unsigned int this_mpi_process(const MPI_Comm mpi_communicator)
T reduce(const T &local_value, const MPI_Comm comm, const std::function< T(const T &, const T &)> &combiner, const unsigned int root_process=0)
size_t pack(const T &object, std::vector< char > &dest_buffer, const bool allow_compression=true)
DEAL_II_HOST constexpr TableIndices< 2 > merge(const TableIndices< 2 > &previous_indices, const unsigned int new_index, const unsigned int position)
const types::boundary_id internal_face_boundary_id
const types::subdomain_id artificial_subdomain_id
static const unsigned int invalid_unsigned_int
::VectorizedArray< Number, width > min(const ::VectorizedArray< Number, width > &, const ::VectorizedArray< Number, width > &)
::VectorizedArray< Number, width > max(const ::VectorizedArray< Number, width > &, const ::VectorizedArray< Number, width > &)
global_cell_index coarse_cell_id
unsigned int subdomain_id
bool operator==(const CellData< structdim > &other) const
CellData(const unsigned int n_vertices=ReferenceCells::get_hypercube< structdim >().n_vertices())
std::vector< CellData< 2 > > boundary_quads
bool check_consistency(const unsigned int dim) const
std::vector< CellData< 1 > > boundary_lines
std::vector< std::pair< unsigned int, Point< spacedim > > > coarse_cell_vertices
const TriangulationDescription::Settings settings
const bool construct_multigrid
std::map< unsigned int, unsigned int > vertex_to_coinciding_vertex_group
const std::function< types::subdomain_id(const typename ::Triangulation< dim, spacedim >::cell_iterator &)> subdomain_id_function
const std::function< types::subdomain_id(const typename ::Triangulation< dim, spacedim >::cell_iterator &)> level_subdomain_id_function
std::vector< types::coarse_cell_id > coarse_cell_index_to_coarse_cell_id
std::vector< std::vector< CellData< dim > > > cell_infos
std::map< unsigned int, std::vector< unsigned int > > coinciding_vertex_groups
const ::Triangulation< dim, spacedim > & tria
std::vector<::CellData< dim > > coarse_cells