mirror of
https://develop.openfoam.com/Development/openfoam.git
synced 2025-11-28 03:28:01 +00:00
Within decomposeParDict, it is now possible to specify a different decomposition method, methods coefficients or number of subdomains for each region individually. The top-level numberOfSubdomains remains mandatory, since this specifies the number of domains for the entire simulation. The individual regions may use the same number or fewer domains. Any optional method coefficients can be specified in a general "coeffs" entry or a method-specific one, eg "metisCoeffs". For multiLevel, only the method-specific "multiLevelCoeffs" dictionary is used, and is also mandatory. ---- ENH: shortcut specification for multiLevel. In addition to the longer dictionary form, it is also possible to use a shorter notation for multiLevel decomposition when the same decomposition method applies to each level.
136 lines
3.6 KiB
C++
136 lines
3.6 KiB
C++
/*---------------------------------------------------------------------------*\
|
|
========= |
|
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
\\ / O peration |
|
|
\\ / A nd | Copyright (C) 2011-2015 OpenFOAM Foundation
|
|
\\/ M anipulation | Copyright (C) 2017 OpenCFD Ltd.
|
|
-------------------------------------------------------------------------------
|
|
License
|
|
This file is part of OpenFOAM.
|
|
|
|
OpenFOAM is free software: you can redistribute it and/or modify it
|
|
under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
Class
|
|
Foam::metisDecomp
|
|
|
|
Description
|
|
Metis domain decomposition
|
|
|
|
When run in parallel will collect the entire graph on to the master,
|
|
decompose and send back.
|
|
|
|
Coefficients dictionary: \a metisCoeffs, \a coeffs.
|
|
|
|
\verbatim
|
|
numberOfSubdomains N;
|
|
method metis;
|
|
|
|
metisCoeffs
|
|
{
|
|
method recursive; // k-way
|
|
options ( ...);
|
|
processorWeights ( ... );
|
|
}
|
|
\endverbatim
|
|
|
|
Method coefficients:
|
|
\table
|
|
Property | Description | Required | Default
|
|
method | recursive / k-way | no | recursive
|
|
options | metis options | no
|
|
processorWeights | list of weighting per partition | no
|
|
\endtable
|
|
|
|
SourceFiles
|
|
metisDecomp.C
|
|
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
#ifndef metisDecomp_H
|
|
#define metisDecomp_H
|
|
|
|
#include "metisLikeDecomp.H"
|
|
|
|
namespace Foam
|
|
{
|
|
|
|
/*---------------------------------------------------------------------------*\
|
|
Class metisDecomp Declaration
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
class metisDecomp
|
|
:
|
|
public metisLikeDecomp
|
|
{
|
|
|
|
// Private Member Functions
|
|
|
|
//- Call Metis with options from dictionary.
|
|
virtual label decomposeSerial
|
|
(
|
|
const labelUList& adjncy,
|
|
const labelUList& xadj,
|
|
const UList<scalar>& cellWeights,
|
|
List<label>& decomp
|
|
);
|
|
|
|
//- Disallow default bitwise copy construct and assignment
|
|
void operator=(const metisDecomp&) = delete;
|
|
metisDecomp(const metisDecomp&) = delete;
|
|
|
|
|
|
public:
|
|
|
|
//- Runtime type information
|
|
TypeName("metis");
|
|
|
|
|
|
// Constructors
|
|
|
|
//- Construct given the decomposition dictionary
|
|
metisDecomp(const dictionary& decompDict);
|
|
|
|
//- Construct given the decomposition dictionary and region name
|
|
metisDecomp
|
|
(
|
|
const dictionary& decompDict,
|
|
const word& regionName
|
|
);
|
|
|
|
|
|
//- Destructor
|
|
virtual ~metisDecomp()
|
|
{}
|
|
|
|
|
|
// Member Functions
|
|
|
|
virtual bool parallelAware() const
|
|
{
|
|
return true;
|
|
}
|
|
|
|
};
|
|
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
|
|
} // End namespace Foam
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
|
|
#endif
|
|
|
|
// ************************************************************************* //
|