108 using namespace Foam;
113 const word standardRegionName(
"region");
129 forAll(patchesToRename, i)
140 template<
class GeoField>
154 mesh.objectRegistry::lookupClass<GeoField>()
158 const GeoField& fld = *iter();
160 Info<<
"Mapping field " << fld.name() <<
endl;
180 tSubFld.ref().boundaryFieldRef()[
patchi] ==
181 typename GeoField::value_type(
Zero);
186 GeoField* subFld = tSubFld.ptr();
187 subFld->rename(fld.name());
194 template<
class GeoField>
195 void subsetSurfaceFields
208 mesh.objectRegistry::lookupClass<GeoField>()
212 const GeoField& fld = *iter();
214 Info<<
"Mapping field " << fld.name() <<
endl;
234 tSubFld.ref().boundaryFieldRef()[
patchi] ==
235 typename GeoField::value_type(
Zero);
240 GeoField* subFld = tSubFld.ptr();
241 subFld->rename(fld.name());
253 if (cellRegion[celli] != regioni)
255 nonRegionCells.append(celli);
258 return nonRegionCells.shrink();
266 const label ownRegion,
267 const label neiRegion,
273 min(ownRegion, neiRegion),
274 max(ownRegion, neiRegion)
282 if (iter != regionsToSize.
end())
286 if (zoneFnd != iter().end())
301 zoneToSize.
insert(zoneID, 1);
302 regionsToSize.
insert(interface, zoneToSize);
309 void getInterfaceSizes
312 const bool useFaceZones,
335 if (ownRegion != neiRegion)
357 coupledRegion[i] = cellRegion[celli];
365 label neiRegion = coupledRegion[i];
367 if (ownRegion != neiRegion)
400 regionsToSize.
find(slaveIter.key());
402 if (masterIter != regionsToSize.
end())
410 label zoneID = iter.key();
411 label slaveSize = iter();
417 if (zoneFnd != masterInfo.
end())
419 zoneFnd() += slaveSize;
423 masterInfo.
insert(zoneID, slaveSize);
429 regionsToSize.
insert(slaveIter.key(), slaveIter());
443 toMaster << regionsToSize;
456 label nInterfaces = 0;
460 nInterfaces += info.
size();
463 interfaces.
setSize(nInterfaces);
464 interfaceNames.
setSize(nInterfaces);
465 interfaceSizes.
setSize(nInterfaces);
471 const edge& e = iter.key();
472 const word& name0 = regionNames[e[0]];
473 const word& name1 = regionNames[e[1]];
478 interfaces[nInterfaces] = iter.key();
479 label zoneID = infoIter.key();
484 name0 +
"_to_" + name1,
485 name1 +
"_to_" + name0
493 zoneName +
"_" + name0 +
"_to_" + name1,
494 zoneName +
"_" + name1 +
"_to_" + name0
497 interfaceSizes[nInterfaces] = infoIter();
499 if (regionsToInterface.found(e))
501 regionsToInterface[
e].insert(zoneID, nInterfaces);
506 zoneAndInterface.
insert(zoneID, nInterfaces);
507 regionsToInterface.insert(e, zoneAndInterface);
529 if (ownRegion != neiRegion)
539 min(ownRegion, neiRegion),
540 max(ownRegion, neiRegion)
543 faceToInterface[facei] = regionsToInterface[interface][zoneID];
550 label neiRegion = coupledRegion[i];
552 if (ownRegion != neiRegion)
562 min(ownRegion, neiRegion),
563 max(ownRegion, neiRegion)
566 faceToInterface[facei] = regionsToInterface[interface][zoneID];
579 const word& regionName,
600 Info<<
"Testing:" << io.objectPath() <<
endl;
605 Info<<
"Writing dummy " << regionName/io.name() <<
endl;
608 dummyDict.
add(
"divSchemes", divDict);
610 dummyDict.
add(
"gradSchemes", gradDict);
612 dummyDict.
add(
"laplacianSchemes", laplDict);
621 mesh.time().system(),
632 Info<<
"Writing dummy " << regionName/io.name() <<
endl;
640 labelList coupledRegion(mesh.nFaces()-mesh.nInternalFaces());
644 label celli = mesh.faceOwner()[i+mesh.nInternalFaces()];
645 coupledRegion[i] = cellRegion[celli];
657 labelList cellsToRemove(getNonRegionCells(cellRegion, regioni));
662 labelList exposedFaces = cellRemover.getExposedFaces(cellsToRemove);
667 label facei = exposedFaces[i];
668 label interfacei = faceToInterface[facei];
670 label ownRegion = cellRegion[mesh.faceOwner()[facei]];
671 label neiRegion = -1;
673 if (mesh.isInternalFace(facei))
675 neiRegion = cellRegion[mesh.faceNeighbour()[facei]];
679 neiRegion = coupledRegion[facei-mesh.nInternalFaces()];
686 label otherRegion = -1;
688 if (ownRegion == regioni && neiRegion != regioni)
690 otherRegion = neiRegion;
692 else if (ownRegion != regioni && neiRegion == regioni)
694 otherRegion = ownRegion;
699 <<
"Exposed face:" << facei
700 <<
" fc:" << mesh.faceCentres()[facei]
701 <<
" has owner region " << ownRegion
702 <<
" and neighbour region " << neiRegion
703 <<
" when handling region:" << regioni
708 if (regioni < otherRegion)
710 exposedPatchIDs[i] = interfacePatches[interfacei];
714 exposedPatchIDs[i] = interfacePatches[interfacei]+1;
719 cellRemover.setRefinement
733 mesh.time().timeName(),
745 void createAndWriteRegion
750 const bool prefixRegion,
754 const word& newMeshInstance
757 Info<<
"Creating mesh for region " << regioni
758 <<
' ' << regionNames[regioni] <<
endl;
766 regionNames[regioni],
775 forAll(interfacePatches, interfacei)
777 addedPatches.
insert(interfacePatches[interfacei]);
778 addedPatches.
insert(interfacePatches[interfacei]+1);
785 newMesh().updateMesh(map());
788 subsetVolFields<volScalarField>
796 subsetVolFields<volVectorField>
804 subsetVolFields<volSphericalTensorField>
812 subsetVolFields<volSymmTensorField>
820 subsetVolFields<volTensorField>
829 subsetSurfaceFields<surfaceScalarField>
837 subsetSurfaceFields<surfaceVectorField>
845 subsetSurfaceFields<surfaceSphericalTensorField>
853 subsetSurfaceFields<surfaceSymmTensorField>
861 subsetSurfaceFields<surfaceTensorField>
872 newPatches.checkParallelSync(
true);
878 labelList oldToNew(newPatches.size(), -1);
882 Info<<
"Deleting empty patches" <<
endl;
889 if (!isA<processorPolyPatch>(pp))
896 sharedPatches.append(newI);
908 if (isA<processorPolyPatch>(pp) && pp.size())
910 oldToNew[
patchi] = newI++;
914 const label nNewPatches = newI;
919 if (oldToNew[
patchi] == -1)
921 oldToNew[
patchi] = newI++;
931 Info<<
"Prefixing patches with region name" <<
endl;
933 renamePatches(newMesh(), regionNames[regioni], sharedPatches);
939 newMesh().setInstance(newMeshInstance);
943 Info<<
"Writing addressing to base mesh" <<
endl;
949 "pointRegionAddressing",
950 newMesh().facesInstance(),
951 newMesh().meshSubDir,
959 Info<<
"Writing map " << pointProcAddressing.name()
960 <<
" from region" << regioni
961 <<
" points back to base mesh." <<
endl;
962 pointProcAddressing.
write();
968 "faceRegionAddressing",
969 newMesh().facesInstance(),
970 newMesh().meshSubDir,
982 label oldFacei = map().faceMap()[facei];
986 map().cellMap()[newMesh().faceOwner()[facei]]
987 == mesh.faceOwner()[oldFacei]
998 <<
" from region" << regioni
999 <<
" faces back to base mesh." <<
endl;
1006 "cellRegionAddressing",
1007 newMesh().facesInstance(),
1008 newMesh().meshSubDir,
1016 Info<<
"Writing map " <<cellProcAddressing.name()
1017 <<
" from region" << regioni
1018 <<
" cells back to base mesh." <<
endl;
1019 cellProcAddressing.
write();
1025 "boundaryRegionAddressing",
1026 newMesh().facesInstance(),
1027 newMesh().meshSubDir,
1037 if (!addedPatches.
found(i))
1039 label newI = oldToNew[i];
1040 if (newI >= 0 && newI < nNewPatches)
1042 boundaryProcAddressing[oldToNew[i]] = i;
1046 Info<<
"Writing map " << boundaryProcAddressing.name()
1047 <<
" from region" << regioni
1048 <<
" boundary back to base mesh." <<
endl;
1049 boundaryProcAddressing.
write();
1069 forAll(interfaces, interI)
1071 const edge& e = interfaces[interI];
1072 const Pair<word>& names = interfaceNames[interI];
1122 Info<<
"For interface between region " << regionNames[e[0]]
1123 <<
" and " << regionNames[e[1]] <<
" added patches" << endl
1124 <<
" " << interfacePatches[interI]
1127 <<
" " << interfacePatches[interI]+1
1131 return interfacePatches;
1136 label findCorrespondingRegion
1140 const label nCellRegions,
1142 const label minOverlapSize
1148 forAll(cellRegion, celli)
1150 if (existingZoneID[celli] == zoneI)
1152 cellsInZone[cellRegion[celli]]++;
1163 if (cellsInZone[regioni] < minOverlapSize)
1171 forAll(cellRegion, celli)
1173 if (cellRegion[celli] == regioni && existingZoneID[celli] != zoneI)
1206 const cellZone& cz = cellZones[zoneI];
1210 label celli = cz[i];
1211 if (zoneID[celli] == -1)
1213 zoneID[celli] = zoneI;
1218 <<
"Cell " << celli <<
" with cell centre " 1220 <<
" is multiple zones. This is not allowed." << endl
1221 <<
"It is in zone " << cellZones[zoneID[celli]].
name()
1222 <<
" and in zone " << cellZones[zoneI].
name()
1241 const bool sloppyCellZones,
1244 const label nCellRegions,
1247 const word& defaultRegionName,
1256 regionToZone.
setSize(nCellRegions, -1);
1257 regionNames.
setSize(nCellRegions);
1263 getZoneID(mesh, cellZones, zoneID, neiZoneID);
1275 if (zoneNames[proci] != zoneNames[0])
1278 <<
"cellZones not synchronised across processors." << endl
1279 <<
"Master has cellZones " << zoneNames[0] << endl
1280 <<
"Processor " << proci
1281 <<
" has cellZones " << zoneNames[proci]
1290 cellZones[zoneI].size(),
1297 if (sloppyCellZones)
1299 Info<<
"Trying to match regions to existing cell zones;" 1300 <<
" region can be subset of cell zone." <<
nl <<
endl;
1304 label regioni = findCorrespondingRegion
1310 label(0.5*zoneSizes[zoneI])
1315 Info<<
"Sloppily matched region " << regioni
1317 <<
" to zone " << zoneI <<
" size " << zoneSizes[zoneI]
1319 zoneToRegion[zoneI] = regioni;
1320 regionToZone[regioni] = zoneI;
1321 regionNames[regioni] = cellZones[zoneI].
name();
1327 Info<<
"Trying to match regions to existing cell zones." <<
nl <<
endl;
1331 label regioni = findCorrespondingRegion
1342 zoneToRegion[zoneI] = regioni;
1343 regionToZone[regioni] = zoneI;
1344 regionNames[regioni] = cellZones[zoneI].
name();
1349 label nUnmatchedRegions = 0;
1351 forAll(regionToZone, regioni)
1353 if (regionToZone[regioni] == -1)
1355 nUnmatchedRegions++;
1359 if (nUnmatchedRegions)
1361 label nUnmatchedi = 1;
1364 forAll(regionToZone, regioni)
1366 if (regionToZone[regioni] == -1)
1370 nUnmatchedRegions == 1
1371 && defaultRegionName != standardRegionName
1374 regionNames[regioni] = defaultRegionName;
1378 regionNames[regioni] =
1379 defaultRegionName +
Foam::name(nUnmatchedi++);
1387 void writeCellToRegion(
const fvMesh& mesh,
const labelList& cellRegion)
1404 cellToRegion.write();
1406 Info<<
"Writing region per cell file (for manual decomposition) to " 1407 << cellToRegion.localObjectPath() <<
nl <<
endl;
1424 zeroGradientFvPatchScalarField::typeName
1426 forAll(cellRegion, celli)
1428 cellToRegion[celli] = cellRegion[celli];
1430 cellToRegion.write();
1432 Info<<
"Writing region per cell as volScalarField to " 1433 << cellToRegion.localObjectPath() <<
nl <<
endl;
1440 int main(
int argc,
char *argv[])
1444 "splits mesh into multiple regions (detected by walking across faces)" 1451 "additionally split cellZones off into separate regions" 1456 "use cellZones only to split mesh into regions; do not use walking" 1460 "cellZonesFileOnly",
1462 "like -cellZonesOnly, but use specified file" 1468 "specify additional region boundaries that walking does not cross" 1473 "place cells into cellZones instead of splitting mesh" 1478 "only write largest region" 1484 "only write region containing point" 1494 "try to match heuristically regions to existing cell zones" 1499 "use faceZones to patch inter-region faces instead of single patch" 1504 "prefix region name to all patches, not just coupling patches" 1508 "defaultRegionName",
1510 "base name of the unspecified regions, defaults to \"region\"" 1515 "do not update fields" 1527 word blockedFacesName;
1530 Info<<
"Reading blocked internal faces from faceSet " 1531 << blockedFacesName <<
nl <<
endl;
1549 (useCellZonesOnly || useCellZonesFile)
1550 && (useCellZones || blockedFacesName.size())
1554 <<
"You cannot specify both -cellZonesOnly or -cellZonesFileOnly" 1555 <<
" (which specify complete split)" 1556 <<
" in combination with -blockedFaces or -cellZones" 1557 <<
" (which imply a split based on topology)" 1564 Info<<
"Using current faceZones to divide inter-region interfaces" 1565 <<
" into multiple patches." 1570 Info<<
"Creating single patch per inter-region interface." 1575 if (insidePoint && largestOnly)
1578 <<
"You cannot specify both -largestOnly" 1579 <<
" (keep region with most cells)" 1580 <<
" and -insidePoint (keep region containing point)" 1584 const word defaultRegionName
1595 getZoneID(mesh, cellZones, zoneID, neiZoneID);
1611 label nCellRegions = 0;
1612 if (useCellZonesOnly)
1614 Info<<
"Using current cellZones to split mesh into regions." 1615 <<
" This requires all" 1616 <<
" cells to be in one and only one cellZone." <<
nl <<
endl;
1619 if (unzonedCelli != -1)
1622 <<
"For the cellZonesOnly option all cells " 1623 <<
"have to be in a cellZone." << endl
1624 <<
"Cell " << unzonedCelli
1626 <<
" is not in a cellZone. There might be more unzoned cells." 1629 cellRegion = zoneID;
1630 nCellRegions =
gMax(cellRegion)+1;
1631 regionToZone.
setSize(nCellRegions);
1632 regionNames.
setSize(nCellRegions);
1633 zoneToRegion.
setSize(cellZones.size(), -1);
1634 for (
label regioni = 0; regioni < nCellRegions; regioni++)
1636 regionToZone[regioni] = regioni;
1637 zoneToRegion[regioni] = regioni;
1638 regionNames[regioni] = cellZones[regioni].name();
1641 else if (useCellZonesFile)
1644 Info<<
"Reading split from cellZones file " << zoneFile << endl
1645 <<
"This requires all" 1646 <<
" cells to be in one and only one cellZone." <<
nl <<
endl;
1665 getZoneID(mesh, newCellZones, newZoneID, newNeiZoneID);
1668 if (unzonedCelli != -1)
1671 <<
"For the cellZonesFileOnly option all cells " 1672 <<
"have to be in a cellZone." << endl
1673 <<
"Cell " << unzonedCelli
1675 <<
" is not in a cellZone. There might be more unzoned cells." 1678 cellRegion = newZoneID;
1679 nCellRegions =
gMax(cellRegion)+1;
1680 zoneToRegion.
setSize(newCellZones.size(), -1);
1681 regionToZone.
setSize(nCellRegions);
1682 regionNames.
setSize(nCellRegions);
1683 for (
label regioni = 0; regioni < nCellRegions; regioni++)
1685 regionToZone[regioni] = regioni;
1686 zoneToRegion[regioni] = regioni;
1687 regionNames[regioni] = newCellZones[regioni].name();
1699 if (blockedFacesName.size())
1701 faceSet blockedFaceSet(mesh, blockedFacesName);
1704 <<
" blocked faces from set " << blockedFacesName <<
nl <<
endl;
1710 blockedFace[iter.key()] =
true;
1724 if (zoneID[own] != zoneID[nei])
1726 blockedFace[facei] =
true;
1735 if (zoneID[mesh.
faceOwner()[facei]] != neiZoneID[i])
1737 blockedFace[facei] =
true;
1744 nCellRegions = regions.nRegions();
1762 if (largestOnly || insidePoint)
1764 forAll(regionToZone, regioni)
1766 if (regionToZone[regioni] == -1)
1772 else if (insidePoint)
1774 regionNames[regioni] =
"insidePoint";
1776 else if (largestOnly)
1778 regionNames[regioni] =
"largestOnly";
1785 Info<< endl <<
"Number of regions:" << nCellRegions <<
nl <<
endl;
1789 writeCellToRegion(mesh, cellRegion);
1798 forAll(cellRegion, celli)
1800 regionSizes[cellRegion[celli]]++;
1802 forAll(regionSizes, regioni)
1807 Info<<
"Region\tCells" <<
nl 1808 <<
"------\t-----" <<
endl;
1810 forAll(regionSizes, regioni)
1812 Info<< regioni <<
'\t' << regionSizes[regioni] <<
nl;
1819 Info<<
"Region\tZone\tName" <<
nl 1820 <<
"------\t----\t----" <<
endl;
1821 forAll(regionToZone, regioni)
1823 Info<< regioni <<
'\t' << regionToZone[regioni] <<
'\t' 1824 << regionNames[regioni] <<
nl;
1861 Info<<
"Sizes of interfaces between regions:" <<
nl <<
nl 1862 <<
"Interface\tRegion\tRegion\tFaces" <<
nl 1863 <<
"---------\t------\t------\t-----" <<
endl;
1865 forAll(interfaces, interI)
1867 const edge& e = interfaces[interI];
1870 <<
"\t\t" << e[0] <<
'\t' << e[1]
1871 <<
'\t' << interfaceSizes[interI] <<
nl;
1887 if (fields)
Info<<
"Reading geometric fields" <<
nl <<
endl;
1900 if (nCellRegions == 1)
1902 Info<<
"Only one region. Doing nothing." <<
endl;
1904 else if (makeCellZones)
1906 Info<<
"Putting cells into cellZones instead of splitting mesh." 1911 for (
label regioni = 0; regioni < nCellRegions; regioni++)
1913 label zoneI = regionToZone[regioni];
1917 Info<<
" Region " << regioni <<
" : corresponds to existing" 1919 << zoneI <<
' ' << cellZones[zoneI].name() <<
endl;
1928 zoneI = cellZones.findZoneID(zoneName);
1932 zoneI = cellZones.size();
1951 Info<<
" Region " << regioni <<
" : created new cellZone " 1952 << zoneI <<
' ' << cellZones[zoneI].name() <<
endl;
1976 Info<<
"Writing cellSets corresponding to cellZones." <<
nl <<
endl;
1980 const cellZone& cz = cellZones[zoneI];
2024 Info<<
nl <<
"Found point " << insidePoint <<
" in cell " << celli
2029 regioni = cellRegion[celli];
2035 <<
"Subsetting region " << regioni
2036 <<
" containing point " << insidePoint <<
endl;
2041 <<
"Point " << insidePoint
2042 <<
" is not inside the mesh." <<
nl 2043 <<
"Bounding box of the mesh:" << mesh.
bounds()
2047 createAndWriteRegion
2059 else if (largestOnly)
2064 <<
"Subsetting region " << regioni
2065 <<
" of size " << regionSizes[regioni]
2066 <<
" as named region " << regionNames[regioni] <<
endl;
2068 createAndWriteRegion
2083 for (
label regioni = 0; regioni < nCellRegions; regioni++)
2086 <<
"Region " << regioni <<
nl 2087 <<
"-------- " <<
endl;
2089 createAndWriteRegion
const polyBoundaryMesh & boundaryMesh() const
Return boundary mesh.
This class separates the mesh into distinct unconnected regions, each of which is then given a label ...
void clearOut()
Clear all geometry and addressing.
static void scatterList(const List< commsStruct > &comms, List< T > &Values, const int tag, const label comm)
Scatter data. Reverse of gatherList.
static void listCombineScatter(const List< commsStruct > &comms, List< T > &Value, const int tag, const label comm)
Scatter data. Reverse of combineGather.
#define forAll(list, i)
Loop across all elements in list.
virtual Ostream & write(const char)=0
Write character.
intWM_LABEL_SIZE_t label
A label is an int32_t or int64_t as specified by the pre-processor macro WM_LABEL_SIZE.
static int masterNo()
Process index of the master.
const word & name() const
Return name.
bool set(const label) const
Is element set.
List of IOobjects with searching and retrieving facilities.
errorManipArg< error, int > exit(error &err, const int errNo=1)
const fileName & facesInstance() const
Return the current instance directory for faces.
static iteratorEnd end()
iteratorEnd set to beyond the end of any HashTable
void off()
Switch the function objects off.
const meshCellZones & cellZones() const
Return cell zones.
A list of keyword definitions, which are a keyword followed by any number of values (e...
dimensioned< Type > max(const dimensioned< Type > &, const dimensioned< Type > &)
#define FatalErrorInFunction
Report an error message using Foam::FatalError.
label nInternalFaces() const
virtual const labelList & faceNeighbour() const
Return face neighbour.
void renamePatches(const wordUList &newNames, const bool validBoundary)
Rename the patches. If validBoundary is set this calls updateMesh()
const labelIOList & tetBasePtIs() const
Return the tetBasePtIs.
static int firstSlave()
Process index of first slave.
PtrList< labelIOList > & faceProcAddressing
static word meshSubDir
Return the mesh sub-directory name (usually "polyMesh")
void size(const label)
Override size to be inconsistent with allocated storage.
static int myProcNo(const label communicator=0)
Number of this process (starting from masterNo() = 0)
Given list of cells to remove insert all the topology changes.
static word defaultRegion
Return the default region name.
Ostream & endl(Ostream &os)
Add newline and flush stream.
bool checkParallelSync(const bool report=false) const
Check whether all procs have all zones and in same order. Return.
bool optionFound(const word &opt) const
Return true if the named option is found.
static bool master(const label communicator=0)
Am I the master process.
labelList identity(const label len)
Create identity map (map[i] == i) of given length.
Field reading functions for post-processing utilities.
static word timeName(const scalar, const int precision=precision_)
Return time name of given scalar time.
const dimensionSet dimless
Info<< "Calculating turbulent flame speed field St\"<< endl;volScalarField St(IOobject("St", runTime.timeName(), mesh, IOobject::NO_READ, IOobject::AUTO_WRITE), flameWrinkling->Xi() *Su);multivariateSurfaceInterpolationScheme< scalar >::fieldTable fields
const Time & time() const
Return the top-level database.
labelList findIndices(const ListType &, typename ListType::const_reference, const label start=0)
Find all occurrences of given element. Linear search.
virtual bool write(const bool write=true) const
Write mesh using IO settings from time.
bool insert(const Key &key)
Insert a new entry.
static void listCombineGather(const List< commsStruct > &comms, List< T > &Value, const CombineOp &cop, const int tag, const label comm)
bool optionReadIfPresent(const word &opt, T &) const
Read a value from the named option if present.
label size() const
Return number of elements in table.
bool add(entry *, bool mergeEntry=false)
Add a new entry.
IOdictionary is derived from dictionary and IOobject to give the dictionary automatic IO functionalit...
Input inter-processor communications stream.
wordList names() const
Return a list of zone names.
bool insert(const edge &, const T &newElmt)
Insert a new hashedEntry.
iterator find(const edge &)
Find and return an iterator set at the hashedEntry.
T optionLookupOrDefault(const word &opt, const T &deflt) const
Read a value from the named option if present.
const fileName & pointsInstance() const
Return the current instance directory for points.
T optionRead(const word &opt) const
Read a value from the named option.
An edge is a list of two point labels. The functionality it provides supports the discretisation on a...
bool found(const Key &) const
Return true if hashedEntry is found in table.
A class for handling words, derived from string.
Determines a mapping between patch face centres and mesh cell or face centres and processors they're ...
wordList names() const
Return a list of patch names.
This boundary condition is not designed to be evaluated; it is assumed that the value is assigned via...
static void addOption(const word &opt, const string ¶m="", const string &usage="")
Add to an option to validOptions with usage information.
virtual const labelList & faceOwner() const
Return face owner.
void write(std::ostream &os, const bool binary, List< floatScalar > &fField)
Write floats ascii or binary.
List< label > labelList
A List of labels.
const word & name() const
Return name.
An STL-conforming hash table.
const vectorField & cellCentres() const
forAllConstIter(PtrDictionary< phaseModel >, mixture.phases(), phase)
void setSize(const label)
Reset size of PtrList. If extending the PtrList, new entries are.
const word & system() const
Return system name.
static void scatter(const List< commsStruct > &comms, T &Value, const int tag, const label comm)
Scatter data. Distribute without modification. Reverse of gather.
label findMax(const ListType &, const label start=0)
Find index of max element (and larger than given element).
bool checkParallelSync(const bool report=false) const
Check whether all procs have all patches and in same order. Return.
Map from edge (expressed as its endpoints) to value.
Type gMax(const FieldField< Field, Type > &f)
Output inter-processor communications stream.
label findIndex(const ListType &, typename ListType::const_reference, const label start=0)
Find first occurrence of given element and return index,.
dimensioned< Type > min(const dimensioned< Type > &, const dimensioned< Type > &)
void reduce(const List< UPstream::commsStruct > &comms, T &Value, const BinaryOp &bop, const int tag, const label comm)
word name(const complex &)
Return a string representation of a complex.
void setInstance(const fileName &)
Set the instance for mesh files.
label size() const
Return the number of elements in the UPtrList.
void setSize(const label)
Reset size of List.
label whichZone(const label objectIndex) const
Given a global object index, return the zone it is in.
const boundBox & bounds() const
Return mesh bounding box.
static tmp< GeometricField< Type, fvPatchField, volMesh > > interpolate(const GeometricField< Type, fvPatchField, volMesh > &, const fvMesh &sMesh, const labelList &patchMap, const labelList &cellMap, const labelList &faceMap)
Map volume field.
writeOption writeOpt() const
static bool & parRun()
Is this a parallel run?
static label nProcs(const label communicator=0)
Number of processes in parallel run.
const functionObjectList & functionObjects() const
Return the list of function objects.
dimensioned< scalar > dimensionedScalar
Dimensioned scalar obtained from generic dimensioned type.
A collection of cell labels.
const meshFaceZones & faceZones() const
Return face zones.
Mesh data needed to do the Finite Volume discretisation.
Direct mesh changes based on v1.3 polyTopoChange syntax.
label findCell(const point &p, const cellDecomposition=CELL_TETS) const
Find cell enclosing this location and return index.
T returnReduce(const T &Value, const BinaryOp &bop, const int tag=Pstream::msgType(), const label comm=UPstream::worldComm)
An auto-pointer similar to the STL auto_ptr but with automatic casting to a reference to the type and...
const doubleScalar e
Elementary charge.
Mesh consisting of general polyhedral cells.
static void addBoolOption(const word &opt, const string &usage="")
Add to a bool option to validOptions with usage information.
static void addNote(const string &)
Add extra notes for the usage information.
A class for managing temporary objects.
A patch is a list of labels that address the faces in the global face list.
Foam::argList args(argc, argv)
IOobject defines the attributes of an object for which implicit objectRegistry management is supporte...
void clearAddressing()
Clear addressing.
static void gatherList(const List< commsStruct > &comms, List< T > &Values, const int tag, const label comm)
Gather data but keep individual values separate.
void transfer(List< T > &)
Transfer the contents of the argument List into this list.
static const Vector< scalar > zero
const string & option(const word &opt) const
Return the argument string associated with the named option.
static int lastSlave(const label communicator=0)
Process index of last slave.