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.