Go to the documentation of this file.
20 #ifndef LIBMESH_PARMETIS_PARTITIONER_H
21 #define LIBMESH_PARMETIS_PARTITIONER_H
24 #include "libmesh/id_types.h"
25 #include "libmesh/partitioner.h"
26 #include "libmesh/auto_ptr.h"
30 #include <unordered_map>
79 virtual std::unique_ptr<Partitioner>
clone ()
const override
81 return libmesh_make_unique<ParmetisPartitioner>(*
this);
94 const unsigned int n)
override;
100 const unsigned int n)
override;
102 #ifdef LIBMESH_HAVE_PARMETIS
129 #endif // LIBMESH_PARMETIS_PARTITIONER_H
ParmetisPartitioner & operator=(const ParmetisPartitioner &)=delete
This class contains a unique_ptr member, so it can't be default copy assigned.
void initialize(const MeshBase &mesh, const unsigned int n_sbdmns)
Initialize data structures.
The libMesh namespace provides an interface to certain functionality in the library.
virtual ~ParmetisPartitioner()
The destructor is out-of-line-defaulted to play nice with forward declarations.
The Partitioner class provides a uniform interface for partitioning algorithms.
This is the MeshBase class.
virtual void build_graph(const MeshBase &mesh) override
Build the graph.
virtual void _do_repartition(MeshBase &mesh, const unsigned int n) override
Parmetis can handle dynamically repartitioning a mesh such that the redistribution costs are minimize...
virtual std::unique_ptr< Partitioner > clone() const override
ParmetisPartitioner()
Default and copy ctors.
virtual void _do_partition(MeshBase &mesh, const unsigned int n) override
Partition the MeshBase into n subdomains.
std::unique_ptr< ParmetisHelper > _pmetis
Pointer to the Parmetis-specific data structures.
The ParmetisPartitioner uses the Parmetis graph partitioner to partition the elements.