calculatedFaPatchField.C
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) 2021 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
27\*---------------------------------------------------------------------------*/
28
30#include "faPatchFieldMapper.H"
31
32// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
33
34template<class Type>
36{
38}
39
40
41// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
42
43template<class Type>
45(
46 const faPatch& p,
48)
49:
50 faPatchField<Type>(p, iF)
51{}
52
53
54template<class Type>
56(
58 const faPatch& p,
60 const faPatchFieldMapper& mapper
61)
62:
63 faPatchField<Type>(ptf, p, iF, mapper)
64{}
65
66
67template<class Type>
69(
70 const faPatch& p,
72 const dictionary& dict
73)
74:
75 faPatchField<Type>(p, iF, Field<Type>("value", dict, p.size()))
76{}
77
78
79template<class Type>
81(
83)
84:
85 faPatchField<Type>(ptf)
86{}
87
88
89template<class Type>
91(
94)
95:
96 faPatchField<Type>(ptf, iF)
97{}
98
99
100template<class Type>
101template<class Type2>
103(
104 const faPatchField<Type2>& pf
105)
106{
107 auto* patchTypeCtor = patchConstructorTable(pf.patch().type());
108
109 if (patchTypeCtor)
110 {
111 return patchTypeCtor
112 (
113 pf.patch(),
115 );
116 }
117 else
118 {
120 (
122 (
123 pf.patch(),
125 )
126 );
127 }
128}
129
130
131// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
132
133template<class Type>
136(
137 const tmp<scalarField>&
138) const
139{
141 << "valueInternalCoeffs cannot be called for a calculatedFaPatchField"
142 << "\n on patch " << this->patch().name()
143 << " of field " << this->internalField().name()
144 << " in file " << this->internalField().objectPath()
145 << "\n You are probably trying to solve for a field with a "
146 "default boundary condition."
147 << exit(FatalError);
148
149 return *this;
150}
151
152
153template<class Type>
156(
157 const tmp<scalarField>&
158) const
159{
161 << "valueBoundaryCoeffs cannot be called for a calculatedFaPatchField"
162 << "\n on patch " << this->patch().name()
163 << " of field " << this->internalField().name()
164 << " in file " << this->internalField().objectPath()
165 << "\n You are probably trying to solve for a field with a "
166 "default boundary condition."
167 << exit(FatalError);
168
169 return *this;
170}
171
172
173template<class Type>
176{
178 << "gradientInternalCoeffs cannot be called for a "
179 "calculatedFaPatchField"
180 << "\n on patch " << this->patch().name()
181 << " of field " << this->internalField().name()
182 << " in file " << this->internalField().objectPath()
183 << "\n You are probably trying to solve for a field with a "
184 "default boundary condition."
185 << exit(FatalError);
186
187 return *this;
188}
189
190
191template<class Type>
194{
196 << "\n "
197 "gradientBoundaryCoeffs cannot be called for a "
198 "calculatedFaPatchField"
199 << "\n on patch " << this->patch().name()
200 << " of field " << this->internalField().name()
201 << " in file " << this->internalField().objectPath()
202 << "\n You are probably trying to solve for a field with a "
203 "default boundary condition."
204 << exit(FatalError);
205
206 return *this;
207}
208
209
210template<class Type>
212{
214 this->writeEntry("value", os);
215}
216
217
218// ************************************************************************* //
Field with dimensions and associated with geometry type GeoMesh which is used to size the field and a...
Generic templated field type.
Definition: Field.H:82
An Ostream is an abstract base class for all output systems (streams, files, token lists,...
Definition: Ostream.H:62
Author Zeljko Tukovic, FMENA Hrvoje Jasak, Wikki Ltd.
tmp< Field< Type > > gradientInternalCoeffs() const
Return the matrix diagonal coefficients corresponding to the.
virtual tmp< Field< Type > > valueInternalCoeffs(const tmp< scalarField > &) const
Return the matrix diagonal coefficients corresponding to the.
tmp< Field< Type > > gradientBoundaryCoeffs() const
Return the matrix source coefficients corresponding to the.
virtual tmp< Field< Type > > valueBoundaryCoeffs(const tmp< scalarField > &) const
Return the matrix source coefficients corresponding to the.
A list of keyword definitions, which are a keyword followed by a number of values (eg,...
Definition: dictionary.H:126
A FieldMapper for finite-area patch fields.
faPatchField<Type> abstract base class. This class gives a fat-interface to all derived classes cover...
Definition: faPatchField.H:82
const faPatch & patch() const
Return patch.
Definition: faPatchField.H:286
static tmp< faPatchField< Type > > NewCalculatedType(const faPatchField< Type2 > &)
static const word & calculatedType()
Return the type of the calculated for of faPatchField.
Finite area patch class. Used for 2-D non-Euclidian finite area method.
Definition: faPatch.H:78
virtual bool write()
Write the output fields.
A class for managing temporary objects.
Definition: tmp.H:65
A class for handling words, derived from Foam::string.
Definition: word.H:68
volScalarField & p
#define FatalErrorInFunction
Report an error message using Foam::FatalError.
Definition: error.H:453
OBJstream os(runTime.globalPath()/outputName)
error FatalError
errorManipArg< error, int > exit(error &err, const int errNo=1)
Definition: errorManip.H:130
dictionary dict