15#ifndef dealii_distributed_shared_tria_h
16#define dealii_distributed_shared_tria_h
39#ifdef DEAL_II_WITH_MPI
106 template <
int dim,
int spacedim = dim>
113 typename ::Triangulation<dim, spacedim>::active_cell_iterator;
115 typename ::Triangulation<dim, spacedim>::cell_iterator;
260 const typename ::Triangulation<dim, spacedim>::MeshSmoothing =
262 const bool allow_artificial_cells =
false,
263 const Settings settings = partition_auto);
306 &construction_data)
override;
320 const ::Triangulation<dim, spacedim> &other_tria)
override;
328 template <
class Archive>
330 serialize(Archive &archive,
const unsigned int version);
334 BOOST_SERIALIZATION_SPLIT_MEMBER()
361 template <
class Archive>
363 load(Archive &ar,
const unsigned int version);
373 const std::vector<types::subdomain_id> &
384 const std::vector<types::subdomain_id> &
434 std::vector<std::vector<types::subdomain_id>>
440 template <
int dim,
int spacedim>
442 template <
class Archive>
444 const unsigned int version)
468 template <
int dim,
int spacedim = dim>
489 const std::vector<types::subdomain_id> &
495 const std::vector<types::subdomain_id> &
547 template <
int dim,
int spacedim = dim>
575 const ::parallel::shared::Triangulation<dim, spacedim>>
void save(Archive &ar, const unsigned int version) const
std::vector< Point< spacedim > > vertices
std::vector< unsigned int > saved_subdomain_ids
const SmartPointer< const ::parallel::shared::Triangulation< dim, spacedim > > shared_tria
~TemporarilyRestoreSubdomainIds()
TemporarilyRestoreSubdomainIds(const Triangulation< dim, spacedim > &tria)
virtual void update_number_cache()
TriangulationBase(const MPI_Comm mpi_communicator, const typename ::Triangulation< dim, spacedim >::MeshSmoothing smooth_grid=(::Triangulation< dim, spacedim >::none), const bool check_for_distorted_cells=false)
virtual void execute_coarsening_and_refinement() override
std::vector< types::subdomain_id > true_subdomain_ids_of_cells
typename ::Triangulation< dim, spacedim >::cell_iterator cell_iterator
virtual void copy_triangulation(const ::Triangulation< dim, spacedim > &other_tria) override
const std::vector< types::subdomain_id > & get_true_subdomain_ids_of_cells() const
std::vector< std::vector< types::subdomain_id > > true_level_subdomain_ids_of_cells
@ partition_custom_signal
@ construct_multigrid_hierarchy
bool with_artificial_cells() const
const std::vector< types::subdomain_id > & get_true_level_subdomain_ids_of_cells(const unsigned int level) const
void serialize(Archive &archive, const unsigned int version)
virtual ~Triangulation() override=default
Triangulation(const MPI_Comm mpi_communicator, const typename ::Triangulation< dim, spacedim >::MeshSmoothing=(::Triangulation< dim, spacedim >::none), const bool allow_artificial_cells=false, const Settings settings=partition_auto)
typename ::Triangulation< dim, spacedim >::active_cell_iterator active_cell_iterator
virtual bool is_multilevel_hierarchy_constructed() const override
void load(Archive &ar, const unsigned int version)
const bool allow_artificial_cells
virtual void create_triangulation(const std::vector< Point< spacedim > > &vertices, const std::vector< CellData< dim > > &cells, const SubCellData &subcelldata) override
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_CXX20_REQUIRES(condition)
#define DEAL_II_NAMESPACE_CLOSE