PetscExternalPartitioner
Allow users to use several external partitioning packages (parmetis, chaco, ptscotch and party) via PETSc.
ParMETIS
ParMETIS is an MPI-based parallel graph partitioner implementing mainly a multilevel K-way algorithm. The basic idea of the multilevel K-way algorithm is to coarsen the graph firstly, partition the coarsened graph and then refine the the partition. It is solving a multi-constraints optimization problem.
PTScotch
PTScotch is a software package which compute parallel static mappings and parallel sparse matrix block orderings of graphs. It implements graph bipartitioning methods including band, diffusion and multilevel methods.
Chaco
Chaco contains a wide variety of algorithms and options. Some of the algorithms exploit the geometry of the mesh, others its local connectivity or its global structure as captured by eigenvectors of a related matrix.
Party
The party package aims at providing a recursive partitioning laboratory assembling various high- and low-level tools for building tree-based regression and classification models.
Use
These packages can be accessed via an unified interface in MOOSE, PetscExternalPartitioner
. The use of the packages is accomplished by adding a subblock in Mesh
block of input file. For example
[Mesh]
type = GeneratedMesh
dim = 2
nx = 10
ny = 10
[Partitioner]
# You need to use PetscExternalPartitioner to gain an access to these external packages
type = PetscExternalPartitioner
# specify which package you want to use
# you could choose one of {Chaco, Party, PTScotch, ParMETIS}
part_package = parmetis
[]
parallel_type = distributed
[]
Note that in order to use {Chaco, Party, PTScotch}, you need to upgrade PETSc to PETSc-3.9.3 or higher with additional options: –download-chaco, –download-party, and –download-ptscotch. But we do NOT encourage regular users to upgrade PETSc on their own. We will officially upgrade PETSc soon that will carries all these packages.
Partitioning Examples
4 subdomains
data:image/s3,"s3://crabby-images/1785d/1785dec9028171f3eb7bf3d6b4543ab9e6e783de" alt=""
Party
data:image/s3,"s3://crabby-images/ab0b0/ab0b0e080d57f3c53c305133d3858d1ce5886852" alt=""
chaco
data:image/s3,"s3://crabby-images/bb59f/bb59f4ea82d99cc6a0fc8823d2777f31c9d75c38" alt=""
parmetis
data:image/s3,"s3://crabby-images/00f81/00f81d77c62ed149305116a66e57264c50630a7a" alt=""
ptscotch
8 subdomains
data:image/s3,"s3://crabby-images/a01d9/a01d9c799d308cab421fdae895b43542a887fc47" alt=""
Party
data:image/s3,"s3://crabby-images/7a0e3/7a0e313764c504a0db27615721c589d9f040ea2e" alt=""
chaco
data:image/s3,"s3://crabby-images/716ce/716ceae6d9206501d5fae32123f443a578f5c59e" alt=""
parmetis
data:image/s3,"s3://crabby-images/0d2e1/0d2e1941d9f4d95dab2bb639438671bf5adffd7f" alt=""
ptscotch