deal.II version 9.7.0
\(\newcommand{\dealvcentcolon}{\mathrel{\mathop{:}}}\) \(\newcommand{\dealcoloneq}{\dealvcentcolon\mathrel{\mkern-1.2mu}=}\) \(\newcommand{\jump}[1]{\left[\!\left[ #1 \right]\!\right]}\) \(\newcommand{\average}[1]{\left\{\!\left\{ #1 \right\}\!\right\}}\)
Loading...
Searching...
No Matches
fully_distributed_tria.h
Go to the documentation of this file.
1// ------------------------------------------------------------------------
2//
3// SPDX-License-Identifier: LGPL-2.1-or-later
4// Copyright (C) 2019 - 2025 by the deal.II authors
5//
6// This file is part of the deal.II library.
7//
8// Part of the source code is dual licensed under Apache-2.0 WITH
9// LLVM-exception OR LGPL-2.1-or-later. Detailed license information
10// governing the source code and code contributions can be found in
11// LICENSE.md and CONTRIBUTING.md at the top level directory of deal.II.
12//
13// ------------------------------------------------------------------------
14
15#ifndef dealii_fully_distributed_tria_h
16#define dealii_fully_distributed_tria_h
17
18
19#include <deal.II/base/config.h>
20
22
25
27
28#include <vector>
29
31
32// Forward declarations
33#ifndef DOXYGEN
34// forward declaration of the data type for periodic face pairs
35namespace GridTools
36{
37 template <typename CellIterator>
38 struct PeriodicFacePair;
39}
40#endif
41
42namespace parallel
43{
47 namespace fullydistributed
48 {
110 template <int dim, int spacedim = dim>
111 DEAL_II_CXX20_REQUIRES((concepts::is_valid_dim_spacedim<dim, spacedim>))
113 : public parallel::DistributedTriangulationBase<dim, spacedim>
114 {
115 public:
117 typename ::Triangulation<dim, spacedim>::cell_iterator;
118
120 typename ::Triangulation<dim, spacedim>::active_cell_iterator;
121
129
133 virtual ~Triangulation() = default;
134
151 void
154 &construction_data) override;
155
162 virtual void
164 const std::vector<::CellData<dim>> &cells,
165 const SubCellData &subcelldata) override;
166
177 void
179 const ::Triangulation<dim, spacedim> &other_tria) override;
180
198 void
200 const std::function<void(::Triangulation<dim, spacedim> &,
201 const unsigned int)> &partitioner,
203
208 void
212
217 void
218 repartition();
219
226 virtual void
228
235 virtual bool
237
241 virtual std::size_t
242 memory_consumption() const override;
243
244 virtual bool
246
254 virtual void
255 save(const std::string &filename) const override;
256
267 virtual void
268 load(const std::string &filename) override;
269
270 private:
271 virtual unsigned int
273 const types::coarse_cell_id coarse_cell_id) const override;
274
277 const unsigned int coarse_cell_index) const override;
278
290 void
292
293 virtual void
294 update_number_cache() override;
295
300
304 std::function<void(::Triangulation<dim, spacedim> &,
305 const unsigned int)>
307
313
317 std::vector<std::pair<types::coarse_cell_id, unsigned int>>
319
324 std::vector<types::coarse_cell_id>
326
332
337 bool
339 };
340
341 } // namespace fullydistributed
342} // namespace parallel
343
344
346
347#endif
Definition point.h:113
std::vector< Point< spacedim > > vertices
Definition tria.h:4498
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)
Definition tria_base.cc:674
typename ::Triangulation< dim, spacedim >::cell_iterator cell_iterator
TriangulationDescription::Settings settings
Triangulation(const MPI_Comm mpi_communicator)
std::vector< types::coarse_cell_id > coarse_cell_index_to_coarse_cell_id_vector
virtual types::coarse_cell_id coarse_cell_index_to_coarse_cell_id(const unsigned int coarse_cell_index) const override
void copy_triangulation(const ::Triangulation< dim, spacedim > &other_tria) override
void set_partitioner(const std::function< void(::Triangulation< dim, spacedim > &, const unsigned int)> &partitioner, const TriangulationDescription::Settings &settings)
ObserverPointer< const RepartitioningPolicyTools::Base< dim, spacedim > > partitioner_distributed
virtual unsigned int coarse_cell_id_to_coarse_cell_index(const types::coarse_cell_id coarse_cell_id) const override
std::vector< std::pair< types::coarse_cell_id, unsigned int > > coarse_cell_id_to_coarse_cell_index_vector
virtual void save(const std::string &filename) const override
std::function< void(::Triangulation< dim, spacedim > &, const unsigned int)> partitioner
typename ::Triangulation< dim, spacedim >::active_cell_iterator active_cell_iterator
virtual bool is_multilevel_hierarchy_constructed() const override
void create_triangulation(const TriangulationDescription::Description< dim, spacedim > &construction_data) override
virtual void load(const std::string &filename) override
virtual std::size_t memory_consumption() const override
#define DEAL_II_NAMESPACE_OPEN
Definition config.h:40
#define DEAL_II_CXX20_REQUIRES(condition)
Definition config.h:248
#define DEAL_II_NAMESPACE_CLOSE
Definition config.h:41
global_cell_index coarse_cell_id
Definition types.h:147