kinematicSingleLayerTemplates.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-2016 OpenFOAM Foundation
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 \*---------------------------------------------------------------------------*/
27 
28 #include "kinematicSingleLayer.H"
29 
30 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
31 
32 namespace Foam
33 {
34 namespace regionModels
35 {
36 namespace surfaceFilmModels
37 {
38 
39 // * * * * * * * * * * * * Protected Member Functions * * * * * * * * * * * //
40 
41 template<class Type>
43 (
44  Type& field,
45  const typename Type::cmptType& value
46 )
47 {
48  typename Type::Boundary& fieldBf = field.boundaryFieldRef();
49 
50  forAll(intCoupledPatchIDs_, i)
51  {
52  label patchi = intCoupledPatchIDs_[i];
53  fieldBf[patchi] = value;
54  if (debug)
55  {
56  Info<< "Constraining " << field.name()
57  << " boundary " << field.boundaryField()[patchi].patch().name()
58  << " to " << value << endl;
59  }
60  }
61 
62  forAll(passivePatchIDs_, i)
63  {
64  label patchi = passivePatchIDs_[i];
65  fieldBf[patchi] = value;
66  if (debug)
67  {
68  Info<< "Constraining " << field.name()
69  << " boundary " << field.boundaryField()[patchi].patch().name()
70  << " to " << value << endl;
71  }
72  }
73 }
74 
75 
76 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
77 
78 } // End namespace Foam
79 } // End namespace regionModels
80 } // End namespace surfaceFilmModels
81 
82 // ************************************************************************* //
Foam::expressions::patchExpr::debug
int debug
Static debugging option.
Foam::endl
Ostream & endl(Ostream &os)
Add newline and flush stream.
Definition: Ostream.H:369
forAll
#define forAll(list, i)
Loop across all elements in list.
Definition: stdFoam.H:296
Foam::Info
messageStream Info
Information stream (stdout output on master, null elsewhere)
field
rDeltaTY field()
kinematicSingleLayer.H
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::regionModels::surfaceFilmModels::kinematicSingleLayer::constrainFilmField
void constrainFilmField(Type &field, const typename Type::cmptType &value)
Constrain a film region master/slave boundaries of a field to a.
Definition: kinematicSingleLayerTemplates.C:43