MeshWave.C
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) 2011-2013 OpenFOAM Foundation
9-------------------------------------------------------------------------------
10License
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\*---------------------------------------------------------------------------*/
27
28#include "MeshWave.H"
29#include "polyMesh.H"
30
31
32// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
33
34template<class Type, class TrackingData>
36
37
38// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
39
40// Iterate, propagating changedFacesInfo across mesh, until no change (or
41// maxIter reached).
42template<class Type, class TrackingData>
44(
45 const polyMesh& mesh,
46 const labelList& changedFaces,
47 const List<Type>& changedFacesInfo,
48 const label maxIter,
49 TrackingData& td
50)
51:
52 allFaceInfo_(mesh.nFaces()),
53 allCellInfo_(mesh.nCells()),
54 calc_
55 (
56 mesh,
57 changedFaces,
58 changedFacesInfo,
59 allFaceInfo_,
60 allCellInfo_,
61 maxIter,
62 td
63 )
64{}
65
66
67// Iterate, propagating changedFacesInfo across mesh, until no change (or
68// maxIter reached). Initial cell values specified.
69template<class Type, class TrackingData>
71(
72 const polyMesh& mesh,
73 const labelList& changedFaces,
74 const List<Type>& changedFacesInfo,
75 const List<Type>& allCellInfo,
76 const label maxIter,
77 TrackingData& td
78)
79:
80 allFaceInfo_(mesh.nFaces()),
81 allCellInfo_(allCellInfo),
82 calc_
83 (
84 mesh,
85 changedFaces,
86 changedFacesInfo,
87 allFaceInfo_,
88 allCellInfo_,
89 maxIter,
90 td
91 )
92{}
93
94
95// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
96
97
98// ************************************************************************* //
FaceCellWave plus data.
Definition: MeshWave.H:62
Mesh consisting of general polyhedral cells.
Definition: polyMesh.H:81
dynamicFvMesh & mesh
const labelList nFaces(UPstream::listGatherValues< label >(aMesh.nFaces()))