1 /*---------------------------------------------------------------------------*\
3 \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
5 \\ / A nd | Copyright (C) 2011 OpenFOAM Foundation
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 "regionModel1D.H"
28 // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
32 namespace regionModels
34 defineTypeNameAndDebug(regionModel1D, 0);
38 // * * * * * * * * * * * * Private Member Functions * * * * * * * * * * * * //
40 void Foam::regionModels::regionModel1D::constructMeshObjects()
42 const fvMesh& regionMesh = regionMeshPtr_();
46 new surfaceScalarField
57 dimensionedScalar("zero", dimArea, 0.0)
63 void Foam::regionModels::regionModel1D::initialise()
67 Pout<< "regionModel1D::initialise()" << endl;
70 // Calculate boundaryFaceFaces and boundaryFaceCells
72 DynamicList<label> faceIDs;
73 DynamicList<label> cellIDs;
75 label localPyrolysisFaceI = 0;
77 const polyBoundaryMesh& rbm = regionMesh().boundaryMesh();
79 forAll(intCoupledPatchIDs_, i)
81 const label patchI = intCoupledPatchIDs_[i];
82 const polyPatch& ppCoupled = rbm[patchI];
83 forAll(ppCoupled, localFaceI)
85 label faceI = ppCoupled.start() + localFaceI;
91 label ownCellI = regionMesh().faceOwner()[faceI];
92 if (ownCellI != cellI)
98 cellI = regionMesh().faceNeighbour()[faceI];
101 cellIDs.append(cellI);
102 const cell& cFaces = regionMesh().cells()[cellI];
103 faceI = cFaces.opposingFaceLabel(faceI, regionMesh().faces());
104 faceIDs.append(faceI);
106 } while (regionMesh().isInternalFace(faceI));
108 boundaryFaceOppositeFace_[localPyrolysisFaceI] = faceI;
109 faceIDs.remove(); //remove boundary face.
112 boundaryFaceFaces_[localPyrolysisFaceI].transfer(faceIDs);
113 boundaryFaceCells_[localPyrolysisFaceI].transfer(cellIDs);
115 localPyrolysisFaceI++;
120 boundaryFaceOppositeFace_.setSize(localPyrolysisFaceI);
122 surfaceScalarField& nMagSf = nMagSfPtr_();
124 forAll(intCoupledPatchIDs_, i)
126 const label patchI = intCoupledPatchIDs_[i];
127 const polyPatch& ppCoupled = rbm[patchI];
128 const vectorField& pNormals = ppCoupled.faceNormals();
129 nMagSf.boundaryField()[patchI] =
130 regionMesh().Sf().boundaryField()[patchI] & pNormals;
131 forAll(pNormals, localFaceI)
133 const vector& n = pNormals[localFaceI];
134 const labelList& faces = boundaryFaceFaces_[localFaceI];
135 forAll (faces, faceI)
137 const label faceID = faces[faceI];
138 nMagSf[faceID] = regionMesh().Sf()[faceID] & n;
145 // * * * * * * * * * * * * Protected Member Functions * * * * * * * * * * * //
147 bool Foam::regionModels::regionModel1D::read()
149 if (regionModel::read())
151 moveMesh_.readIfPresent("moveMesh", coeffs_);
162 bool Foam::regionModels::regionModel1D::read(const dictionary& dict)
164 if (regionModel::read(dict))
166 moveMesh_.readIfPresent("moveMesh", coeffs_);
177 Foam::tmp<Foam::labelField> Foam::regionModels::regionModel1D::moveMesh
179 const scalarList& deltaV,
180 const scalar minDelta
183 tmp<labelField> tcellMoveMap(new labelField(regionMesh().nCells(), 0));
184 labelField& cellMoveMap = tcellMoveMap();
191 pointField oldPoints = regionMesh().points();
192 pointField newPoints = oldPoints;
194 const polyBoundaryMesh& bm = regionMesh().boundaryMesh();
196 forAll(intCoupledPatchIDs_, localPatchI)
198 label patchI = intCoupledPatchIDs_[localPatchI];
199 const polyPatch pp = bm[patchI];
200 const vectorField& cf = regionMesh().Cf().boundaryField()[patchI];
202 forAll(pp, patchFaceI)
204 const labelList& faces = boundaryFaceFaces_[patchFaceI];
205 const labelList& cells = boundaryFaceCells_[patchFaceI];
206 const vector n = pp.faceNormals()[patchFaceI];
207 const vector sf = pp.faceAreas()[patchFaceI];
209 List<point> oldCf(faces.size() + 1);
210 oldCf[0] = cf[patchFaceI];
213 oldCf[i + 1] = regionMesh().faceCentres()[faces[i]];
216 vector newDelta = vector::zero;
217 point nbrCf = oldCf[0];
221 const label faceI = faces[i];
222 const label cellI = cells[i];
224 const face f = regionMesh().faces()[faceI];
226 newDelta += (deltaV[cellI]/mag(sf))*n;
228 vector localDelta = vector::zero;
231 const label pointI = f[pti];
235 ((nbrCf - (oldPoints[pointI] + newDelta)) & n)
239 newPoints[pointI] = oldPoints[pointI] + newDelta;
240 localDelta = newDelta;
241 cellMoveMap[cellI] = 1;
244 nbrCf = oldCf[i + 1] + localDelta;
248 const label bFaceI = boundaryFaceOppositeFace_[patchFaceI];
249 const face f = regionMesh().faces()[bFaceI];
250 const label cellI = cells[cells.size() - 1];
251 newDelta += (deltaV[cellI]/mag(sf))*n;
254 const label pointI = f[pti];
258 ((nbrCf - (oldPoints[pointI] + newDelta)) & n)
262 newPoints[pointI] = oldPoints[pointI] + newDelta;
263 cellMoveMap[cellI] = 1;
270 regionMesh().movePoints(newPoints);
276 // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
278 Foam::regionModels::regionModel1D::regionModel1D(const fvMesh& mesh)
281 boundaryFaceFaces_(),
282 boundaryFaceCells_(),
283 boundaryFaceOppositeFace_(),
290 Foam::regionModels::regionModel1D::regionModel1D
293 const word& regionType,
294 const word& modelName,
298 regionModel(mesh, regionType, modelName, false),
299 boundaryFaceFaces_(regionMesh().nCells()),
300 boundaryFaceCells_(regionMesh().nCells()),
301 boundaryFaceOppositeFace_(regionMesh().nCells()),
308 constructMeshObjects();
319 Foam::regionModels::regionModel1D::regionModel1D
322 const word& regionType,
323 const word& modelName,
324 const dictionary& dict,
328 regionModel(mesh, regionType, modelName, dict, readFields),
329 boundaryFaceFaces_(regionMesh().nCells()),
330 boundaryFaceCells_(regionMesh().nCells()),
331 boundaryFaceOppositeFace_(regionMesh().nCells()),
338 constructMeshObjects();
349 // * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
351 Foam::regionModels::regionModel1D::~regionModel1D()
355 // ************************************************************************* //