15#ifndef dealii_distributed_tria_h
16#define dealii_distributed_tria_h
31#include <boost/range/iterator_range.hpp>
40#ifdef DEAL_II_WITH_P4EST
42# include <p4est_connectivity.h>
43# include <p4est_ghost.h>
45# include <p8est_connectivity.h>
46# include <p8est_ghost.h>
58 template <
int,
int,
class>
59 class ExtrapolateImplementation;
66 template <
typename CellIterator>
87 template <
int dim,
int spacedim>
90 ::parallel::distributed::Triangulation<dim, spacedim> &);
99#ifdef DEAL_II_WITH_P4EST
300 template <
int dim,
int spacedim = dim>
324 typename ::Triangulation<dim, spacedim>::cell_iterator;
345 typename ::Triangulation<dim, spacedim>::active_cell_iterator;
422 const typename ::Triangulation<dim, spacedim>::MeshSmoothing
424 const Settings settings = default_setting);
444 is_multilevel_hierarchy_constructed()
const override;
450 are_vertices_communicated_to_p4est()
const;
467 const typename ::internal::p4est::types<dim>::forest
469 const typename ::internal::p4est::types<dim>::gloidx
470 *previous_global_first_quadrant);
481 const ::Triangulation<dim, spacedim> &other_tria)
override;
503 create_triangulation(
505 &construction_data)
override;
534 std::vector<types::subdomain_id>
535 find_point_owner_rank(
const std::vector<
Point<dim>> &points);
570 execute_coarsening_and_refinement()
override;
585 prepare_coarsening_and_refinement()
override;
634 memory_consumption()
const override;
642 memory_consumption_p4est()
const;
657 write_mesh_vtk(
const std::string &file_basename)
const;
664 get_checksum()
const;
677 save(
const std::string &file_basename)
const override;
699 load(
const std::string &file_basename)
override;
707 load(
const typename ::internal::p4est::types<dim>::forest *forest);
715 const std::vector<types::global_dof_index> &
716 get_p4est_tree_to_coarse_cell_permutation()
const;
723 const std::vector<types::global_dof_index> &
724 get_coarse_cell_to_p4est_tree_permutation()
const;
733 const typename ::internal::p4est::types<dim>::forest *
828 std::vector<types::global_dof_index>
830 std::vector<types::global_dof_index>
837 typename ::internal::p4est::types<dim>::tree *
838 init_tree(
const int dealii_coarse_cell_index)
const;
876 std::vector<unsigned int>
897 const unsigned int coarse_cell_index)
const override;
899 template <
int,
int,
class>
900 friend class ::FETools::internal::ExtrapolateImplementation;
914 template <
int spacedim>
938 const typename ::Triangulation<1, spacedim>::MeshSmoothing
940 const Settings settings = default_setting);
953 const std::vector<types::global_dof_index> &
954 get_p4est_tree_to_coarse_cell_permutation()
const;
961 load(
const std::string &filename)
override;
968 save(
const std::string &filename)
const override;
975 is_multilevel_hierarchy_constructed()
const override;
982 are_vertices_communicated_to_p4est()
const;
989 update_cell_relations();
995 std::vector<types::global_dof_index>
997 std::vector<types::global_dof_index>
1004 virtual std::map<unsigned int, std::set<::types::subdomain_id>>
1006 const unsigned int level)
const;
1012 virtual std::vector<bool>
1015 virtual unsigned int
1021 const unsigned int coarse_cell_index)
const override;
1034 namespace distributed
1049 template <
int dim,
int spacedim = dim>
1073 const typename ::Triangulation<dim, spacedim>::MeshSmoothing
1103 save(
const std::string & )
const override
1111 load(
const std::string & )
override
1151 template <
int dim,
int spacedim = dim>
friend class ObserverPointer
DistributedTriangulationBase(const MPI_Comm mpi_communicator, const typename ::Triangulation< dim, spacedim >::MeshSmoothing smooth_grid=(::Triangulation< dim, spacedim >::none), const bool check_for_distorted_cells=false)
TemporarilyMatchRefineFlags(::Triangulation< dim, spacedim > &tria)
~TemporarilyMatchRefineFlags()
const ObserverPointer< ::parallel::distributed::Triangulation< dim, spacedim > > distributed_tria
std::vector< bool > saved_refine_flags
std::vector< bool > saved_coarsen_flags
friend class TemporarilyMatchRefineFlags
Triangulation(const MPI_Comm mpi_communicator, const typename ::Triangulation< 1, spacedim >::MeshSmoothing smooth_grid=(::Triangulation< 1, spacedim >::none), const Settings settings=default_setting)
std::vector< types::global_dof_index > p4est_tree_to_coarse_cell_permutation
virtual std::map< unsigned int, std::set<::types::subdomain_id > > compute_level_vertices_with_ghost_neighbors(const unsigned int level) const
virtual types::coarse_cell_id coarse_cell_index_to_coarse_cell_id(const unsigned int coarse_cell_index) const override
virtual unsigned int coarse_cell_id_to_coarse_cell_index(const types::coarse_cell_id coarse_cell_id) const override
@ communicate_vertices_to_p4est
@ construct_multigrid_hierarchy
@ no_automatic_repartitioning
@ mesh_reconstruction_after_repartitioning
std::vector< types::global_dof_index > coarse_cell_to_p4est_tree_permutation
virtual std::vector< bool > mark_locally_active_vertices_on_level(const unsigned int level) const
void setup_coarse_cell_to_p4est_tree_permutation()
@ no_automatic_repartitioning
@ construct_multigrid_hierarchy
@ mesh_reconstruction_after_repartitioning
@ communicate_vertices_to_p4est
bool are_vertices_communicated_to_p4est() const
bool triangulation_has_content
virtual types::coarse_cell_id coarse_cell_index_to_coarse_cell_id(const unsigned int coarse_cell_index) const override
friend class TemporarilyMatchRefineFlags
virtual void save(const std::string &file_basename) const override
std::vector< unsigned int > get_cell_weights() const
std::vector< types::global_dof_index > p4est_tree_to_coarse_cell_permutation
void copy_new_triangulation_to_p4est(std::integral_constant< int, 3 >)
virtual void load(const std::string &file_basename) override
typename::internal::p4est::types< dim >::tree * init_tree(const int dealii_coarse_cell_index) const
void update_cell_relations()
std::vector< bool > mark_locally_active_vertices_on_level(const int level) const
typename::internal::p4est::types< dim >::forest * parallel_forest
typename::internal::p4est::types< dim >::connectivity * connectivity
void copy_local_forest_to_triangulation()
virtual unsigned int coarse_cell_id_to_coarse_cell_index(const types::coarse_cell_id coarse_cell_id) const override
void copy_new_triangulation_to_p4est(std::integral_constant< int, 2 >)
Triangulation(const MPI_Comm mpi_communicator, const typename ::Triangulation< dim, spacedim >::MeshSmoothing smooth_grid=(::Triangulation< dim, spacedim >::none), const Settings settings=default_setting)
bool is_multilevel_hierarchy_constructed() const override
std::vector< types::global_dof_index > coarse_cell_to_p4est_tree_permutation
typename::internal::p4est::types< dim >::ghost * parallel_ghost
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_CXX20_REQUIRES(condition)
#define DEAL_II_NAMESPACE_CLOSE
typename ::Triangulation< dim, spacedim >::cell_iterator cell_iterator
typename ::Triangulation< dim, spacedim >::active_cell_iterator active_cell_iterator
void exchange_refinement_flags(::parallel::distributed::Triangulation< dim, spacedim > &tria)
unsigned int subdomain_id
global_cell_index coarse_cell_id