Version of donorBasedOverlapFringe that compiles
Note: still not tested
This commit is contained in:
parent
6a5117ed51
commit
ba114c1b5d
4 changed files with 32 additions and 24 deletions
|
@ -4,6 +4,7 @@ oversetFringe/oversetFringe/oversetFringe.C
|
||||||
oversetFringe/oversetFringe/newOversetFringe.C
|
oversetFringe/oversetFringe/newOversetFringe.C
|
||||||
oversetFringe/manualFringe/manualFringe.C
|
oversetFringe/manualFringe/manualFringe.C
|
||||||
oversetFringe/faceCellsFringe/faceCellsFringe.C
|
oversetFringe/faceCellsFringe/faceCellsFringe.C
|
||||||
|
oversetFringe/donorBasedLayeredOverlapFringe/donorBasedLayeredOverlapFringe.C
|
||||||
oversetFringe/overlapFringe/overlapFringe/overlapFringe.C
|
oversetFringe/overlapFringe/overlapFringe/overlapFringe.C
|
||||||
oversetFringe/overlapFringe/layeredOverlapFringe/layeredOverlapFringe.C
|
oversetFringe/overlapFringe/layeredOverlapFringe/layeredOverlapFringe.C
|
||||||
oversetFringe/overlapFringe/adaptiveOverlapFringe/adaptiveOverlapFringe.C
|
oversetFringe/overlapFringe/adaptiveOverlapFringe/adaptiveOverlapFringe.C
|
||||||
|
|
|
@ -3,11 +3,13 @@ EXE_INC = \
|
||||||
-I$(LIB_SRC)/meshTools/lnInclude \
|
-I$(LIB_SRC)/meshTools/lnInclude \
|
||||||
-I$(LIB_SRC)/surfMesh/lnInclude \
|
-I$(LIB_SRC)/surfMesh/lnInclude \
|
||||||
-I$(LIB_SRC)/sampling/lnInclude \
|
-I$(LIB_SRC)/sampling/lnInclude \
|
||||||
-I$(LIB_SRC)/dynamicMesh/dynamicMesh/lnInclude
|
-I$(LIB_SRC)/dynamicMesh/dynamicMesh/lnInclude \
|
||||||
|
-I$(LIB_SRC)/dynamicMesh/dynamicFvMesh/lnInclude
|
||||||
|
|
||||||
EXE_LIBS = \
|
EXE_LIBS = \
|
||||||
-lfiniteVolume \
|
-lfiniteVolume \
|
||||||
-lmeshTools \
|
-lmeshTools \
|
||||||
-lsurfMesh \
|
-lsurfMesh \
|
||||||
-lsampling \
|
-lsampling \
|
||||||
-ldynamicMesh
|
-ldynamicMesh \
|
||||||
|
-ldynamicFvMesh
|
||||||
|
|
|
@ -24,10 +24,13 @@ License
|
||||||
\*---------------------------------------------------------------------------*/
|
\*---------------------------------------------------------------------------*/
|
||||||
|
|
||||||
#include "donorBasedLayeredOverlapFringe.H"
|
#include "donorBasedLayeredOverlapFringe.H"
|
||||||
|
#include "oversetMesh.H"
|
||||||
|
#include "oversetRegion.H"
|
||||||
#include "faceCellsFringe.H"
|
#include "faceCellsFringe.H"
|
||||||
#include "oversetRegion.H"
|
#include "oversetRegion.H"
|
||||||
#include "addToRunTimeSelectionTable.H"
|
#include "addToRunTimeSelectionTable.H"
|
||||||
#include "syncTools.H"
|
#include "syncTools.H"
|
||||||
|
#include "dynamicFvMesh.H"
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
@ -46,7 +49,7 @@ namespace Foam
|
||||||
const Foam::debug::tolerancesSwitch
|
const Foam::debug::tolerancesSwitch
|
||||||
Foam::donorBasedLayeredOverlapFringe::distTol_
|
Foam::donorBasedLayeredOverlapFringe::distTol_
|
||||||
(
|
(
|
||||||
"donorBasedLayeredOverlapDistanceTolerance"
|
"donorBasedLayeredOverlapDistanceTolerance",
|
||||||
0.0
|
0.0
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -97,7 +100,7 @@ void Foam::donorBasedLayeredOverlapFringe::calcAddressing() const
|
||||||
<< " with faceCells fringe as a connected region fringe."
|
<< " with faceCells fringe as a connected region fringe."
|
||||||
<< nl
|
<< nl
|
||||||
<< "Connected overset region " << region.name()
|
<< "Connected overset region " << region.name()
|
||||||
<< " has " << fringe.type() " fringe type. "
|
<< " has " << fringe.type() << " fringe type. "
|
||||||
<< nl
|
<< nl
|
||||||
<< "Proceed with care!"
|
<< "Proceed with care!"
|
||||||
<< endl;
|
<< endl;
|
||||||
|
@ -109,6 +112,7 @@ void Foam::donorBasedLayeredOverlapFringe::calcAddressing() const
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sets containing all acceptors and all holes for all connected regions
|
// Sets containing all acceptors and all holes for all connected regions
|
||||||
|
const polyMesh& mesh = this->mesh();
|
||||||
labelHashSet allAcceptors(0.02*mesh.nCells());
|
labelHashSet allAcceptors(0.02*mesh.nCells());
|
||||||
labelHashSet allFringeHoles(0.02*mesh.nCells());
|
labelHashSet allFringeHoles(0.02*mesh.nCells());
|
||||||
|
|
||||||
|
@ -175,9 +179,9 @@ void Foam::donorBasedLayeredOverlapFringe::calcAddressing() const
|
||||||
}
|
}
|
||||||
|
|
||||||
// Loop through extended donor cells
|
// Loop through extended donor cells
|
||||||
donorAcceptor::DynamicLabelList& extDonors =
|
const donorAcceptor::DynamicLabelList& extDonors =
|
||||||
daPair.extendedDonorCells();
|
daPair.extendedDonorCells();
|
||||||
donorAcceptor::DynamicPointList& extDonorPoints =
|
const donorAcceptor::DynamicPointList& extDonorPoints =
|
||||||
daPair.extendedDonorPoints();
|
daPair.extendedDonorPoints();
|
||||||
|
|
||||||
forAll (extDonors, i)
|
forAll (extDonors, i)
|
||||||
|
@ -210,7 +214,8 @@ void Foam::donorBasedLayeredOverlapFringe::calcAddressing() const
|
||||||
// User did not specify centre points and the centre point holds
|
// User did not specify centre points and the centre point holds
|
||||||
// the sum of all the points. Reduce the data
|
// the sum of all the points. Reduce the data
|
||||||
reduce(centrePoint, sumOp<vector>());
|
reduce(centrePoint, sumOp<vector>());
|
||||||
nUniqueDonors = returnReduce(donors.size(), sumOp<label>());
|
const label nUniqueDonors =
|
||||||
|
returnReduce(donors.size(), sumOp<label>());
|
||||||
|
|
||||||
// Calculate the final centre point by finding the arithmetic mean
|
// Calculate the final centre point by finding the arithmetic mean
|
||||||
centrePoint /= nUniqueDonors;
|
centrePoint /= nUniqueDonors;
|
||||||
|
@ -221,7 +226,6 @@ void Foam::donorBasedLayeredOverlapFringe::calcAddressing() const
|
||||||
labelHashSet acceptors(donors.size()); // Reasonable size estimate
|
labelHashSet acceptors(donors.size()); // Reasonable size estimate
|
||||||
|
|
||||||
// Get necessary mesh data (from polyMesh/primitiveMesh)
|
// Get necessary mesh data (from polyMesh/primitiveMesh)
|
||||||
const polyMesh& mesh = this->mesh();
|
|
||||||
const vectorField& cc = mesh.cellCentres();
|
const vectorField& cc = mesh.cellCentres();
|
||||||
const vectorField& fc = mesh.faceCentres();
|
const vectorField& fc = mesh.faceCentres();
|
||||||
const cellList& meshCells = mesh.cells();
|
const cellList& meshCells = mesh.cells();
|
||||||
|
@ -247,7 +251,7 @@ void Foam::donorBasedLayeredOverlapFringe::calcAddressing() const
|
||||||
{
|
{
|
||||||
// Get the cell index and the cell
|
// Get the cell index and the cell
|
||||||
const label& cellI = iter.key();
|
const label& cellI = iter.key();
|
||||||
const label& cell = meshCells[cellI];
|
const cell& cFaces = meshCells[cellI];
|
||||||
|
|
||||||
// Get cell centre of this donor and calculate distance to
|
// Get cell centre of this donor and calculate distance to
|
||||||
// centre point
|
// centre point
|
||||||
|
@ -382,7 +386,7 @@ void Foam::donorBasedLayeredOverlapFringe::calcAddressing() const
|
||||||
{
|
{
|
||||||
// Get the cell index and the cell
|
// Get the cell index and the cell
|
||||||
const label& cellI = iter.key();
|
const label& cellI = iter.key();
|
||||||
const label& cell = meshCells[cellI];
|
const cell& cFaces = meshCells[cellI];
|
||||||
|
|
||||||
// Note: there's no need to check for the distance here
|
// Note: there's no need to check for the distance here
|
||||||
// because there's always at least one "buffer" layer
|
// because there's always at least one "buffer" layer
|
||||||
|
@ -496,7 +500,7 @@ void Foam::donorBasedLayeredOverlapFringe::calcAddressing() const
|
||||||
// and holes, which will be deleted when asked for again from the
|
// and holes, which will be deleted when asked for again from the
|
||||||
// iterative procedure (see candidateAcceptors() and fringeHoles())
|
// iterative procedure (see candidateAcceptors() and fringeHoles())
|
||||||
acceptorsPtr_ = new labelList(0);
|
acceptorsPtr_ = new labelList(0);
|
||||||
holesPtr_ = new labelList(0);
|
fringeHolesPtr_ = new labelList(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -523,7 +527,11 @@ Foam::donorBasedLayeredOverlapFringe::donorBasedLayeredOverlapFringe
|
||||||
connectedRegionIDs_(),
|
connectedRegionIDs_(),
|
||||||
regionCentrePoints_
|
regionCentrePoints_
|
||||||
(
|
(
|
||||||
dict.lookupOrDefault<pointList>("regionCentrePoints", pointList(0))
|
dict.lookupOrDefault<List<point> >
|
||||||
|
(
|
||||||
|
"regionCentrePoints",
|
||||||
|
List<point>(0)
|
||||||
|
)
|
||||||
),
|
),
|
||||||
nLayers_(readLabel(dict.lookup("nLayers"))),
|
nLayers_(readLabel(dict.lookup("nLayers"))),
|
||||||
fringeHolesPtr_(nullptr),
|
fringeHolesPtr_(nullptr),
|
||||||
|
@ -543,7 +551,7 @@ Foam::donorBasedLayeredOverlapFringe::donorBasedLayeredOverlapFringe
|
||||||
" const dictionary& dict\n"
|
" const dictionary& dict\n"
|
||||||
")",
|
")",
|
||||||
dict
|
dict
|
||||||
) << "Invalid number of layers specified, nLayers = " nLayers_
|
) << "Invalid number of layers specified, nLayers = " << nLayers_
|
||||||
<< nl
|
<< nl
|
||||||
<< "The number should be greater than 0."
|
<< "The number should be greater than 0."
|
||||||
<< abort(FatalError);
|
<< abort(FatalError);
|
||||||
|
@ -573,7 +581,7 @@ Foam::donorBasedLayeredOverlapFringe::donorBasedLayeredOverlapFringe
|
||||||
const word& crName = connectedRegionNames[crI];
|
const word& crName = connectedRegionNames[crI];
|
||||||
|
|
||||||
// Find this region in the list of all regions
|
// Find this region in the list of all regions
|
||||||
const label regionID = findIndex(allRegions, crName);
|
const label regionID = findIndex(allRegionNames, crName);
|
||||||
|
|
||||||
if (regionID == -1)
|
if (regionID == -1)
|
||||||
{
|
{
|
||||||
|
@ -732,7 +740,7 @@ bool Foam::donorBasedLayeredOverlapFringe::updateIteration
|
||||||
// Set the flag to true and return
|
// Set the flag to true and return
|
||||||
updateSuitableOverlapFlag(true);
|
updateSuitableOverlapFlag(true);
|
||||||
|
|
||||||
return foundSuitablaOverlap();
|
return foundSuitableOverlap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -803,16 +811,14 @@ Foam::donorAcceptorList& Foam::donorBasedLayeredOverlapFringe::finalDonorAccepto
|
||||||
|
|
||||||
void Foam::donorBasedLayeredOverlapFringe::update() const
|
void Foam::donorBasedLayeredOverlapFringe::update() const
|
||||||
{
|
{
|
||||||
if (updateFringe_)
|
|
||||||
{
|
|
||||||
Info<< "donorBasedLayeredOverlapFringe::update() const" << endl;
|
Info<< "donorBasedLayeredOverlapFringe::update() const" << endl;
|
||||||
|
|
||||||
// Clear out
|
// Clear out
|
||||||
clearAddressing();
|
clearAddressing();
|
||||||
}
|
|
||||||
|
|
||||||
// Set flag to false and clear final donor/acceptors only
|
// Set flag to false and clear final donor/acceptors only
|
||||||
deleteDemandDrivenData(finalDonorAcceptorsPtr_);
|
deleteDemandDrivenData(finalDonorAcceptorsPtr_);
|
||||||
|
updateSuitableOverlapFlag(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -49,7 +49,6 @@ SourceFiles
|
||||||
#define donorBasedLayeredOverlapFringe_H
|
#define donorBasedLayeredOverlapFringe_H
|
||||||
|
|
||||||
#include "oversetFringe.H"
|
#include "oversetFringe.H"
|
||||||
#include "pointList.H"
|
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
@ -68,13 +67,13 @@ class donorBasedLayeredOverlapFringe
|
||||||
|
|
||||||
//- Regions IDs from which the donors will be collected as a starting
|
//- Regions IDs from which the donors will be collected as a starting
|
||||||
// point
|
// point
|
||||||
labelList connectedRegionsIDs_;
|
labelList connectedRegionIDs_;
|
||||||
|
|
||||||
//- Optional list of points representing a rough estimate of the centre
|
//- Optional list of points representing a rough estimate of the centre
|
||||||
// for each underlying connected region. If these are not provided, the
|
// for each underlying connected region. If these are not provided, the
|
||||||
// centre is calculated as the centre of all donors for a given
|
// centre is calculated as the centre of all donors for a given
|
||||||
// connected region
|
// connected region
|
||||||
pointList regionCentrePoints_;
|
List<point> regionCentrePoints_;
|
||||||
|
|
||||||
//- How many layers to move away from connected region donors to define
|
//- How many layers to move away from connected region donors to define
|
||||||
// acceptor (and holes)
|
// acceptor (and holes)
|
Reference in a new issue