filmTurbulenceModel.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) 2013-2017 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 Class
27  Foam::regionModels::surfaceFilmModels::filmTurbulenceModel
28 
29 Description
30  Base class for film turbulence models
31 
32 SourceFiles
33  filmTurbulenceModel.C
34  filmTurbulenceModelNew.C
35 
36 \*---------------------------------------------------------------------------*/
37 
38 #ifndef filmTurbulenceModel_H
39 #define filmTurbulenceModel_H
40 
41 #include "filmSubModelBase.H"
42 #include "runTimeSelectionTables.H"
43 #include "fvMatricesFwd.H"
44 #include "volFieldsFwd.H"
45 
46 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
47 
48 namespace Foam
49 {
50 namespace regionModels
51 {
52 namespace surfaceFilmModels
53 {
54 
55 /*---------------------------------------------------------------------------*\
56  Class filmTurbulenceModel Declaration
57 \*---------------------------------------------------------------------------*/
58 
60 :
61  public filmSubModelBase
62 {
63 private:
64 
65  // Private Member Functions
66 
67  //- No copy construct
69 
70  //- No copy assignment
71  void operator=(const filmTurbulenceModel&) = delete;
72 
73 
74 public:
75 
76  //- Runtime type information
77  TypeName("filmTurbulenceModel");
78 
79 
80  // Declare runtime constructor selection table
81 
83  (
84  autoPtr,
86  dictionary,
87  (
89  const dictionary& dict
90  ),
91  (film, dict)
92  );
93 
94  // Constructors
95 
96  //- Construct null
98 
99  //- Construct from type name, dictionary and surface film model
101  (
102  const word& modelType,
104  const dictionary& dict
105  );
106 
107 
108  // Selectors
109 
110  //- Return a reference to the selected injection model
112  (
114  const dictionary& dict
115  );
116 
117 
118  //- Destructor
119  virtual ~filmTurbulenceModel();
120 
121 
122  // Member Functions
123 
124  // Evolution
125 
126  //- Return the film surface velocity
127  virtual tmp<volVectorField> Us() const = 0;
128 
129  //- Return the film turbulence viscosity
130  virtual tmp<volScalarField> mut() const = 0;
131 
132  //- Correct/update the model
133  virtual void correct() = 0;
134 
135  //- Return the source for the film momentum equation
136  virtual tmp<fvVectorMatrix> Su(volVectorField& U) const = 0;
137 };
138 
139 
140 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
141 
142 } // End namespace surfaceFilmModels
143 } // End namespace regionModels
144 } // End namespace Foam
145 
146 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
147 
148 #endif
149 
150 // ************************************************************************* //
volFieldsFwd.H
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:65
Foam::tmp
A class for managing temporary objects.
Definition: PtrList.H:61
Foam::regionModels::surfaceFilmModels::filmTurbulenceModel::mut
virtual tmp< volScalarField > mut() const =0
Return the film turbulence viscosity.
Foam::regionModels::surfaceFilmModels::filmTurbulenceModel
Base class for film turbulence models.
Definition: filmTurbulenceModel.H:58
Foam::regionModels::surfaceFilmModels::filmSubModelBase::film
const surfaceFilmRegionModel & film() const
Return const access to the film surface film model.
Definition: filmSubModelBaseI.H:39
fvMatricesFwd.H
Forward declarations of fvMatrix specializations.
Foam::regionModels::surfaceFilmModels::filmTurbulenceModel::~filmTurbulenceModel
virtual ~filmTurbulenceModel()
Destructor.
Definition: filmTurbulenceModel.C:65
Foam::regionModels::surfaceFilmModels::surfaceFilmRegionModel
Base class for surface film models.
Definition: surfaceFilmRegionModel.H:55
Foam::subModelBase::dict
const dictionary & dict() const
Return const access to the cloud dictionary.
Definition: subModelBase.C:113
Foam::regionModels::surfaceFilmModels::filmTurbulenceModel::Su
virtual tmp< fvVectorMatrix > Su(volVectorField &U) const =0
Return the source for the film momentum equation.
Foam::dictionary
A list of keyword definitions, which are a keyword followed by a number of values (eg,...
Definition: dictionary.H:123
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
Foam::subModelBase::modelType
const word & modelType() const
Return const access to the sub-model type.
Definition: subModelBase.C:125
Foam::autoPtr
Pointer management similar to std::unique_ptr, with some additional methods and type checking.
Definition: HashPtrTable.H:53
U
U
Definition: pEqn.H:72
Foam::regionModels::surfaceFilmModels::filmTurbulenceModel::Us
virtual tmp< volVectorField > Us() const =0
Return the film surface velocity.
runTimeSelectionTables.H
Macros to ease declaration of run-time selection tables.
Foam::regionModels::surfaceFilmModels::filmTurbulenceModel::correct
virtual void correct()=0
Correct/update the model.
Foam::GeometricField< vector, fvPatchField, volMesh >
Foam::regionModels::surfaceFilmModels::filmTurbulenceModel::New
static autoPtr< filmTurbulenceModel > New(surfaceFilmRegionModel &film, const dictionary &dict)
Return a reference to the selected injection model.
Definition: filmTurbulenceModelNew.C:43
Foam::regionModels::surfaceFilmModels::filmSubModelBase
Base class for surface film sub-models.
Definition: filmSubModelBase.H:56
Foam::regionModels::surfaceFilmModels::filmTurbulenceModel::declareRunTimeSelectionTable
declareRunTimeSelectionTable(autoPtr, filmTurbulenceModel, dictionary,(surfaceFilmRegionModel &film, const dictionary &dict),(film, dict))
Foam::regionModels::surfaceFilmModels::filmTurbulenceModel::TypeName
TypeName("filmTurbulenceModel")
Runtime type information.