ENH: ptscotchDecomp: handle locally zero cells

This commit is contained in:
mattijs
2014-04-04 11:07:16 +01:00
committed by Andrew Heather
parent dfd957514d
commit fbb80e2373

View File

@ -2,7 +2,7 @@
========= | ========= |
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
\\ / O peration | \\ / O peration |
\\ / A nd | Copyright (C) 2011-2012 OpenFOAM Foundation \\ / A nd | Copyright (C) 2011-2014 OpenFOAM Foundation
\\/ M anipulation | \\/ M anipulation |
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
License License
@ -532,12 +532,23 @@ Foam::label Foam::ptscotchDecomp::decompose
if (maxWeights > minWeights) if (maxWeights > minWeights)
{ {
// Convert to integers. if (cWeights.size())
velotab.setSize(cWeights.size());
forAll(velotab, i)
{ {
velotab[i] = int((cWeights[i]/minWeights - 1)*rangeScale) + 1; // Convert to integers.
velotab.setSize(cWeights.size());
forAll(velotab, i)
{
velotab[i] = int((cWeights[i]/minWeights - 1)*rangeScale) + 1;
}
}
else
{
// Locally zero cells but not globally. Make sure we have
// some size so .begin() does not return null pointer. Data
// itself is never used.
velotab.setSize(1);
velotab[0] = 1;
} }
} }