force.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) 2011-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::force
28 
29 Description
30  Base class for film (stress-based) force models
31 
32 SourceFiles
33  force.C
34  forceNew.C
35 
36 \*---------------------------------------------------------------------------*/
37 
38 #ifndef force_H
39 #define force_H
40 
41 #include "filmSubModelBase.H"
42 #include "runTimeSelectionTables.H"
43 #include "fvMatrices.H"
44 
45 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
46 
47 namespace Foam
48 {
49 namespace regionModels
50 {
51 namespace surfaceFilmModels
52 {
53 
54 /*---------------------------------------------------------------------------*\
55  Class force Declaration
56 \*---------------------------------------------------------------------------*/
57 
58 class force
59 :
60  public filmSubModelBase
61 {
62 private:
63 
64  // Private Member Functions
65 
66  //- No copy construct
67  force(const force&) = delete;
68 
69  //- No copy assignment
70  void operator=(const force&) = delete;
71 
72 
73 public:
74 
75  //- Runtime type information
76  TypeName("force");
77 
78 
79  // Declare runtime constructor selection table
80 
82  (
83  autoPtr,
84  force,
85  dictionary,
86  (
88  const dictionary& dict
89  ),
90  (film, dict)
91  );
92 
93  // Constructors
94 
95  //- Construct null
97 
98  //- Construct from type name, dictionary and surface film model
99  force
100  (
101  const word& modelType,
103  const dictionary& dict
104  );
105 
106 
107  // Selectors
108 
109  //- Return a reference to the selected force model
110  static autoPtr<force> New
111  (
113  const dictionary& dict,
114  const word& modelType
115  );
116 
117 
118  //- Destructor
119  virtual ~force();
120 
121 
122  // Member Functions
123 
124  // Evolution
125 
126  //- Correct
128 };
129 
130 
131 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
132 
133 } // End namespace surfaceFilmModels
134 } // End namespace regionModels
135 } // End namespace Foam
136 
137 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
138 
139 #endif
140 
141 // ************************************************************************* //
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:65
Foam::regionModels::surfaceFilmModels::force::correct
virtual tmp< fvVectorMatrix > correct(volVectorField &U)=0
Correct.
Foam::tmp
A class for managing temporary objects.
Definition: PtrList.H:61
Foam::regionModels::surfaceFilmModels::force::declareRunTimeSelectionTable
declareRunTimeSelectionTable(autoPtr, force, dictionary,(surfaceFilmRegionModel &film, const dictionary &dict),(film, dict))
Foam::regionModels::surfaceFilmModels::filmSubModelBase::film
const surfaceFilmRegionModel & film() const
Return const access to the film surface film model.
Definition: filmSubModelBaseI.H:39
Foam::regionModels::surfaceFilmModels::force::~force
virtual ~force()
Destructor.
Definition: force.C:65
Foam::regionModels::surfaceFilmModels::force::TypeName
TypeName("force")
Runtime type information.
fvMatrices.H
A special matrix type and solver, designed for finite volume solutions of scalar equations.
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::force::New
static autoPtr< force > New(surfaceFilmRegionModel &film, const dictionary &dict, const word &modelType)
Return a reference to the selected force model.
Definition: forceNew.C:43
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
runTimeSelectionTables.H
Macros to ease declaration of run-time selection tables.
Foam::regionModels::surfaceFilmModels::force
Base class for film (stress-based) force models.
Definition: force.H:57
Foam::GeometricField< vector, fvPatchField, volMesh >
Foam::regionModels::surfaceFilmModels::filmSubModelBase
Base class for surface film sub-models.
Definition: filmSubModelBase.H:56