Loading...
Searching...
No Matches
kqRWallFunctionFvPatchField.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, 2019 OpenFOAM Foundation
9 Copyright (C) 2019-2022 OpenCFD Ltd.
10-------------------------------------------------------------------------------
11License
12 This file is part of OpenFOAM.
13
14 OpenFOAM is free software: you can redistribute it and/or modify it
15 under the terms of the GNU General Public License as published by
16 the Free Software Foundation, either version 3 of the License, or
17 (at your option) any later version.
18
19 OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
20 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
22 for more details.
23
24 You should have received a copy of the GNU General Public License
25 along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
26
27Class
28 Foam::kqRWallFunctionFvPatchField
29
30Group
31 grpWallFunctions
32
33Description
34 This boundary condition provides a simple wrapper around the zero-gradient
35 condition, which can be used for the turbulent kinetic energy (i.e. \c k),
36 square-root of turbulent kinetic energy (i.e. \c q) and Reynolds stress
37 symmetric-tensor fields (i.e. \c R) for the cases of high Reynolds number
38 flow using wall functions. It is not a wall-function condition.
39
40Usage
41 Example of the boundary condition specification:
42 \verbatim
43 <patchName>
44 {
45 // Mandatory entries
46 type kqRWallFunction;
47
48 // Inherited entries
49 ...
50 }
51 \endverbatim
52
53 where the entries mean:
54 \table
55 Property | Description | Type | Reqd | Deflt
56 type | Type name: kqRWallFunction | word | yes | -
57 \endtable
58
59 The inherited entries are elaborated in:
60 - \link zeroGradientFvPatchField.H \endlink
61
62SourceFiles
63 kqRWallFunctionFvPatchField.C
64
65\*---------------------------------------------------------------------------*/
66
67#ifndef kqRWallFunctionFvPatchField_H
68#define kqRWallFunctionFvPatchField_H
69
71
72// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
73
74namespace Foam
75{
76
77/*---------------------------------------------------------------------------*\
78 Class kqRWallFunctionFvPatchField Declaration
79\*---------------------------------------------------------------------------*/
80
81template<class Type>
83:
84 public zeroGradientFvPatchField<Type>
85{
86public:
87
88 //- Runtime type information
89 TypeName("kqRWallFunction");
90
91
92 // Constructors
93
94 //- Construct from patch and internal field
96 (
97 const fvPatch&,
99 );
100
101 //- Construct from patch, internal field and dictionary
103 (
104 const fvPatch&,
106 const dictionary&
107 );
108
109 //- Construct by mapping given
110 //- kqRWallFunctionFvPatchField
111 //- onto a new patch
113 (
115 const fvPatch&,
117 const fvPatchFieldMapper&
118 );
119
120 //- Construct as copy
122 (
124 );
125
126 //- Construct as copy setting internal field reference
128 (
131 );
132
133 //- Return a clone
134 virtual tmp<fvPatchField<Type>> clone() const
135 {
136 return fvPatchField<Type>::Clone(*this);
137 }
138
139 //- Clone with an internal field reference
141 (
143 ) const
144 {
145 return fvPatchField<Type>::Clone(*this, iF);
146 }
147
148
149 // Member Functions
150
151 //- Evaluate the patchField
152 virtual void evaluate
153 (
155 );
156
157 //- Write
158 virtual void write(Ostream&) const;
159};
160
161
162// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
164} // End namespace Foam
165
166// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
167
168#ifdef NoRepository
170#endif
171
172// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
173
174#endif
175
176// ************************************************************************* //
Field with dimensions and associated with geometry type GeoMesh which is used to size the field and a...
An Ostream is an abstract base class for all output systems (streams, files, token lists,...
Definition Ostream.H:59
commsTypes
Communications types.
Definition UPstream.H:81
@ buffered
"buffered" : (MPI_Bsend, MPI_Recv)
Definition UPstream.H:82
A list of keyword definitions, which are a keyword followed by a number of values (eg,...
Definition dictionary.H:133
A FieldMapper for finite-volume patch fields.
static tmp< fvPatchField< Type > > Clone(const DerivedPatchField &pf, Args &&... args)
Clone a patch field, optionally with internal field reference etc.
A finiteVolume patch using a polyPatch and a fvBoundaryMesh.
Definition fvPatch.H:71
This boundary condition provides a simple wrapper around the zero-gradient condition,...
TypeName("kqRWallFunction")
Runtime type information.
kqRWallFunctionFvPatchField(const fvPatch &, const DimensionedField< Type, volMesh > &)
Construct from patch and internal field.
virtual tmp< fvPatchField< Type > > clone() const
Return a clone.
virtual void evaluate(const Pstream::commsTypes commsType=Pstream::commsTypes::buffered)
Evaluate the patchField.
virtual tmp< fvPatchField< Type > > clone(const DimensionedField< Type, volMesh > &iF) const
Clone with an internal field reference.
A class for managing temporary objects.
Definition tmp.H:75
This boundary condition applies a zero-gradient condition from the patch internal field onto the patc...
zeroGradientFvPatchField(const fvPatch &, const DimensionedField< Type, volMesh > &)
Construct from patch and internal field.
Namespace for OpenFOAM.
runTime write()
#define TypeName(TypeNameString)
Declare a ClassName() with extra virtual type info.
Definition typeInfo.H:68