Loading...
Searching...
No Matches
zeroGradientFaPatchField.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) 2016-2017 Wikki Ltd
9 Copyright (C) 2019 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::zeroGradientFaPatchField
29
30Description
31
32Author
33 Zeljko Tukovic, FMENA
34 Hrvoje Jasak, Wikki Ltd.
35
36SourceFiles
37 zeroGradientFaPatchField.C
38
39\*---------------------------------------------------------------------------*/
40
41#ifndef Foam_zeroGradientFaPatchField_H
42#define Foam_zeroGradientFaPatchField_H
43
44#include "faPatchField.H"
45
46// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
47
48namespace Foam
49{
50
51/*---------------------------------------------------------------------------*\
52 Class zeroGradientFaPatchField Declaration
53\*---------------------------------------------------------------------------*/
54
55template<class Type>
57:
58 public faPatchField<Type>
59{
60public:
61
62 //- Runtime type information
63 TypeName("zeroGradient"); // fieldTypes::zeroGradientTypeName_()
64
65
66 // Constructors
67
68 //- Construct from patch and internal field
70 (
71 const faPatch&,
73 );
74
75 //- Construct from patch, internal field and dictionary
77 (
78 const faPatch&,
80 const dictionary&
81 );
82
83 //- Construct by mapping the given zeroGradient patch field
84 //- onto a new patch
86 (
88 const faPatch&,
91 );
92
93 //- Construct as copy
95 (
97 );
98
99 //- Construct as copy setting internal field reference
101 (
104 );
105
106 //- Return clone
108 {
109 return faPatchField<Type>::Clone(*this);
110 }
111
112 //- Clone with an internal field reference
114 (
116 ) const
117 {
118 return faPatchField<Type>::Clone(*this, iF);
119 }
120
121
122 // Member Functions
123
124 // Evaluation Functions
125
126 //- Return patch-normal gradient
127 virtual tmp<Field<Type>> snGrad() const
128 {
129 // zero-gradient
130 return tmp<Field<Type>>::New(this->size(), Foam::zero{});
131 }
132
133 //- Retrieve patch-normal gradient [contiguous storage]
134 virtual void snGrad(UList<Type>& result) const
135 {
136 // zero-gradient
137 result = Foam::zero{};
138 }
139
140 //- Evaluate the patch field
141 virtual void evaluate
142 (
143 const Pstream::commsTypes commsType =
145 );
146
147 //- Return the matrix diagonal coefficients corresponding to the
148 //- evaluation of the value of this patchField with given weights
150 (
151 const tmp<scalarField>&
152 ) const;
153
154 //- Return the matrix source coefficients corresponding to the
155 //- evaluation of the value of this patchField with given weights
157 (
158 const tmp<scalarField>&
159 ) const;
160
161 //- Return the matrix diagonal coefficients corresponding to the
162 //- evaluation of the gradient of this patchField
164
165 //- Return the matrix source coefficients corresponding to the
166 //- evaluation of the gradient of this patchField
168};
169
170
171// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
172
173} // End namespace Foam
174
175// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
176
177#ifdef NoRepository
179#endif
180
181// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
182
183#endif
184
185// ************************************************************************* //
Field with dimensions and associated with geometry type GeoMesh which is used to size the field and a...
A 1D vector of objects of type <T>, where the size of the vector is known and can be used for subscri...
Definition UList.H:89
void size(const label n)
Definition UList.H:118
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-area patch fields.
faPatchField(const faPatch &, const DimensionedField< Type, areaMesh > &)
Construct from patch and internal field.
static tmp< faPatchField< Type > > Clone(const DerivedPatchField &pf)
Clone a patch field with its own internal field reference.
static tmp< faPatchField< Type > > New(const word &patchFieldType, const word &actualPatchType, const faPatch &, const DimensionedField< Type, areaMesh > &)
Return a pointer to a new patchField created on freestore given patch and internal field.
Finite area patch class. Used for 2-D non-Euclidian finite area method.
Definition faPatch.H:76
A class for managing temporary objects.
Definition tmp.H:75
virtual tmp< faPatchField< Type > > clone() const
Return clone.
virtual tmp< Field< Type > > gradientInternalCoeffs() const
Return the matrix diagonal coefficients corresponding to the evaluation of the gradient of this patch...
zeroGradientFaPatchField(const zeroGradientFaPatchField< Type > &)
Construct as copy.
zeroGradientFaPatchField(const zeroGradientFaPatchField< Type > &, const DimensionedField< Type, areaMesh > &)
Construct as copy setting internal field reference.
virtual tmp< Field< Type > > valueInternalCoeffs(const tmp< scalarField > &) const
Return the matrix diagonal coefficients corresponding to the evaluation of the value of this patchFie...
TypeName("zeroGradient")
Runtime type information.
virtual tmp< Field< Type > > gradientBoundaryCoeffs() const
Return the matrix source coefficients corresponding to the evaluation of the gradient of this patchFi...
virtual tmp< Field< Type > > snGrad() const
Return patch-normal gradient.
zeroGradientFaPatchField(const faPatch &, const DimensionedField< Type, areaMesh > &)
Construct from patch and internal field.
virtual tmp< Field< Type > > valueBoundaryCoeffs(const tmp< scalarField > &) const
Return the matrix source coefficients corresponding to the evaluation of the value of this patchField...
virtual tmp< faPatchField< Type > > clone(const DimensionedField< Type, areaMesh > &iF) const
Clone with an internal field reference.
virtual void snGrad(UList< Type > &result) const
Retrieve patch-normal gradient [contiguous storage].
virtual void evaluate(const Pstream::commsTypes commsType=Pstream::commsTypes::buffered)
Evaluate the patch field.
A class representing the concept of 0 (zero) that can be used to avoid manipulating objects known to ...
Definition zero.H:58
Namespace for OpenFOAM.
#define TypeName(TypeNameString)
Declare a ClassName() with extra virtual type info.
Definition typeInfo.H:68