setCellMask.H
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration |
5  \\ / A nd | www.openfoam.com
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8  Copyright (C) 2016-2022 OpenCFD Ltd.
9 -------------------------------------------------------------------------------
10 License
11  This file is part of OpenFOAM.
12 
13  OpenFOAM is free software: you can redistribute it and/or modify it
14  under the terms of the GNU General Public License as published by
15  the Free Software Foundation, either version 3 of the License, or
16  (at your option) any later version.
17 
18  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
19  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
20  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
21  for more details.
22 
23  You should have received a copy of the GNU General Public License
24  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
25 
26 Description
27  Sets blocked cells mask field
28 
29 \*---------------------------------------------------------------------------*/
30 
31 {
32  const cellCellStencilObject& overlap = Stencil::New(mesh);
33  const labelList& cellTypes = overlap.cellTypes();
34 
35  cellMask.primitiveFieldRef() = 1.0;
36  forAll(cellMask, cellI)
37  {
38  if
39  (
40  cellTypes[cellI] == cellCellStencil::HOLE
41  || cellTypes[cellI] == cellCellStencil::SPECIAL
42  )
43  {
44  cellMask[cellI] = 0.0;
45  }
46  }
47  cellMask.correctBoundaryConditions();
48 
49  faceMask = localMin<scalar>(mesh).interpolate(cellMask);
50 }
51 
52 
53 // ************************************************************************* //
static tmp< GeometricField< Type, faePatchField, edgeMesh > > interpolate(const GeometricField< Type, faPatchField, areaMesh > &tvf, const edgeScalarField &faceFlux, Istream &schemeData)
Interpolate field onto faces using scheme given by Istream.
tmp< DimensionedField< TypeR, GeoMesh > > New(const tmp< DimensionedField< TypeR, GeoMesh >> &tf1, const word &name, const dimensionSet &dimensions, const bool initCopy=false)
Global function forwards to reuseTmpDimensionedField::New.
forAll(cellMask, cellI)
Definition: setCellMask.H:30
dynamicFvMesh & mesh
const cellCellStencilObject & overlap
Definition: correctPhi.H:57
faceMask
Definition: setCellMask.H:43
const labelList & cellTypes
Definition: setCellMask.H:27
List< label > labelList
A List of labels.
Definition: List.H:62