Loading...
Searching...
No Matches
symmetryPlaneFvPatchField.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-------------------------------------------------------------------------------
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
26Class
27 Foam::symmetryPlaneFvPatchField
28
29Group
30 grpConstraintBoundaryConditions
31
32Description
33 This boundary condition enforces a symmetryPlane constraint
34
35Usage
36 Example of the boundary condition specification:
37 \verbatim
38 <patchName>
39 {
40 type symmetryPlane;
41 }
42 \endverbatim
43
44SourceFiles
45 symmetryPlaneFvPatchField.C
46 symmetryPlaneFvPatchFields.C
47 symmetryPlaneFvPatchFields.H
48 symmetryPlaneFvPatchFieldsFwd.H
49
50\*---------------------------------------------------------------------------*/
51
52#ifndef Foam_symmetryPlaneFvPatchField_H
53#define Foam_symmetryPlaneFvPatchField_H
54
57
58// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
59
60namespace Foam
61{
62
63/*---------------------------------------------------------------------------*\
64 Class symmetryPlaneFvPatchField Declaration
65\*---------------------------------------------------------------------------*/
66
67template<class Type>
69:
70 public basicSymmetryFvPatchField<Type>
71{
72 // Private data
73
74 //- Local reference cast into the symmetryPlane patch
75 const symmetryPlaneFvPatch& symmetryPlanePatch_;
76
77
78public:
79
80 //- Runtime type information
81 TypeName(symmetryPlaneFvPatch::typeName_());
82
83
84 // Constructors
85
86 //- Construct from patch and internal field
88 (
89 const fvPatch&,
91 );
92
93 //- Construct from patch, internal field and dictionary
95 (
96 const fvPatch&,
98 const dictionary&
99 );
100
101 //- Construct by mapping given symmetryPlaneFvPatchField
102 // onto a new patch
104 (
106 const fvPatch&,
108 const fvPatchFieldMapper&
109 );
110
111 //- Construct as copy
113 (
115 );
116
117 //- Construct as copy setting internal field reference
119 (
122 );
123
124 //- Return a clone
125 virtual tmp<fvPatchField<Type>> clone() const
126 {
127 return fvPatchField<Type>::Clone(*this);
128 }
129
130 //- Clone with an internal field reference
132 (
134 ) const
135 {
136 return fvPatchField<Type>::Clone(*this, iF);
138
139
140 // Member functions
141
142 //- Return gradient at boundary
143 virtual tmp<Field<Type>> snGrad() const;
144
145 //- Evaluate the patch field
146 virtual void evaluate
147 (
149 );
150
151 //- Return face-gradient transform diagonal
152 virtual tmp<Field<Type>> snGradTransformDiag() const;
153};
154
155
156// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
157
158} // End namespace Foam
159
160// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
161
162#ifdef NoRepository
164#endif
165
166// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
167
168#endif
169
170// ************************************************************************* //
Field with dimensions and associated with geometry type GeoMesh which is used to size the field and a...
commsTypes
Communications types.
Definition UPstream.H:81
@ buffered
"buffered" : (MPI_Bsend, MPI_Recv)
Definition UPstream.H:82
basicSymmetryFvPatchField(const fvPatch &, const DimensionedField< Type, volMesh > &)
Construct from patch and internal field.
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
virtual tmp< Field< Type > > snGrad() const
Return gradient at boundary.
symmetryPlaneFvPatchField(const fvPatch &, const DimensionedField< Type, volMesh > &)
Construct from patch and internal field.
TypeName(symmetryPlaneFvPatch::typeName_())
Runtime type information.
virtual tmp< fvPatchField< Type > > clone() const
Return a clone.
virtual tmp< Field< Type > > snGradTransformDiag() const
Return face-gradient transform diagonal.
virtual void evaluate(const Pstream::commsTypes commsType=Pstream::commsTypes::buffered)
Evaluate the patch field.
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
Namespace for OpenFOAM.
#define TypeName(TypeNameString)
Declare a ClassName() with extra virtual type info.
Definition typeInfo.H:68