1 /*---------------------------------------------------------------------------*\
3 \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
5 \\ / A nd | Copyright (C) 1991-2010 OpenCFD Ltd.
7 -------------------------------------------------------------------------------
9 This file is part of OpenFOAM.
11 OpenFOAM is free software: you can redistribute it and/or modify it
12 under the terms of the GNU General Public License as published by
13 the Free Software Foundation, either version 3 of the License, or
14 (at your option) any later version.
16 OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
21 You should have received a copy of the GNU General Public License
22 along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
24 \*---------------------------------------------------------------------------*/
26 #include "smoothDelta.H"
27 #include "addToRunTimeSelectionTable.H"
28 #include "FaceCellWave.H"
30 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
35 // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
37 defineTypeNameAndDebug(smoothDelta, 0);
38 addToRunTimeSelectionTable(LESdelta, smoothDelta, dictionary);
40 scalar smoothDelta::deltaData::maxDeltaRatio = 1.2;
43 // * * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * //
45 // Fill changedFaces (with face labels) and changedFacesInfo (with delta)
46 // This is the initial set of faces from which to start the waves.
47 // Since there might be lots of places with delta jumps we can follow various
48 // strategies for this initial 'seed'.
49 // - start from single cell/face and let FaceCellWave pick up all others
50 // from there. might be quite a few waves before everything settles.
51 // - start from all faces. Lots of initial transfers.
52 // We do something inbetween:
53 // - start from all faces where there is a jump. Since we cannot easily
54 // determine this across coupled patches (cyclic, processor) introduce
55 // all faces of these and let FaceCellWave sort it out.
56 void smoothDelta::setChangedFaces
59 const volScalarField& delta,
60 DynamicList<label>& changedFaces,
61 DynamicList<deltaData>& changedFacesInfo
64 for (label faceI = 0; faceI < mesh.nInternalFaces(); faceI++)
66 scalar ownDelta = delta[mesh.faceOwner()[faceI]];
68 scalar neiDelta = delta[mesh.faceNeighbour()[faceI]];
70 // Check if owner delta much larger than neighbour delta or vice versa
72 if (ownDelta > deltaData::maxDeltaRatio * neiDelta)
74 changedFaces.append(faceI);
75 changedFacesInfo.append(deltaData(ownDelta));
77 else if (neiDelta > deltaData::maxDeltaRatio * ownDelta)
79 changedFaces.append(faceI);
80 changedFacesInfo.append(deltaData(neiDelta));
84 // Insert all faces of coupled patches no matter what. Let FaceCellWave
86 forAll(mesh.boundaryMesh(), patchI)
88 const polyPatch& patch = mesh.boundaryMesh()[patchI];
92 forAll(patch, patchFaceI)
94 label meshFaceI = patch.start() + patchFaceI;
96 scalar ownDelta = delta[mesh.faceOwner()[meshFaceI]];
98 changedFaces.append(meshFaceI);
99 changedFacesInfo.append(deltaData(ownDelta));
104 changedFaces.shrink();
105 changedFacesInfo.shrink();
109 void smoothDelta::calcDelta()
111 deltaData::maxDeltaRatio = maxDeltaRatio_;
112 const volScalarField& geometricDelta = geometricDelta_();
114 // Fill changed faces with info
115 DynamicList<label> changedFaces(mesh_.nFaces()/100 + 100);
116 DynamicList<deltaData> changedFacesInfo(changedFaces.size());
118 setChangedFaces(mesh_, geometricDelta, changedFaces, changedFacesInfo);
120 // Set initial field on cells.
121 List<deltaData> cellDeltaData(mesh_.nCells());
123 forAll(geometricDelta, cellI)
125 cellDeltaData[cellI] = geometricDelta[cellI];
128 // Set initial field on faces.
129 List<deltaData> faceDeltaData(mesh_.nFaces());
132 // Propagate information over whole domain.
133 FaceCellWave<deltaData> deltaCalc
140 mesh_.globalData().nTotalCells() // max iterations
143 forAll(delta_, cellI)
145 delta_[cellI] = cellDeltaData[cellI].delta();
150 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
152 smoothDelta::smoothDelta
159 LESdelta(name, mesh),
162 LESdelta::New("geometricDelta", mesh, dd.subDict(type() + "Coeffs"))
166 readScalar(dd.subDict(type() + "Coeffs").lookup("maxDeltaRatio"))
173 // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
175 void smoothDelta::read(const dictionary& d)
177 const dictionary& dd(d.subDict(type() + "Coeffs"));
179 geometricDelta_().read(dd);
180 dd.lookup("maxDeltaRatio") >> maxDeltaRatio_;
185 void smoothDelta::correct()
187 geometricDelta_().correct();
189 if (mesh_.changing())
196 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
198 } // End namespace Foam
200 // ************************************************************************* //