greyDiffusiveRadiationMixedFvPatchScalarField.H
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration | Website: https://openfoam.org
5  \\ / A nd | Copyright (C) 2011-2023 OpenFOAM Foundation
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8 License
9  This file is part of OpenFOAM.
10 
11  OpenFOAM is free software: you can redistribute it and/or modify it
12  under the terms of the GNU General Public License as published by
13  the Free Software Foundation, either version 3 of the License, or
14  (at your option) any later version.
15 
16  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
19  for more details.
20 
21  You should have received a copy of the GNU General Public License
22  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
23 
24 Class
25  Foam::greyDiffusiveRadiationMixedFvPatchScalarField
26 
27 Description
28  This boundary condition provides a grey-diffuse condition for radiation
29  intensity, \c I, for use with the finite-volume discrete-ordinates model
30  (fvDOM), in which the radiation temperature is retrieved from the
31  temperature field boundary condition.
32 
33 Usage
34  \table
35  Property | Description | Required | Default value
36  T | temperature field name | no | T
37  emissivityMode | emissivity mode: solidRadiation or lookup | yes |
38  \endtable
39 
40  Example of the boundary condition specification:
41  \verbatim
42  <patchName>
43  {
44  type greyDiffusiveRadiation;
45  T T;
46  emissivityMode solidRadiation;
47  value uniform 0;
48  }
49  \endverbatim
50 
51 See also
52  Foam::radiationCoupledBase
53  Foam::radiationModel
54  Foam::radiationModels::fvDOM
55  Foam::mixedFvPatchField
56 
57 SourceFiles
58  greyDiffusiveRadiationMixedFvPatchScalarField.C
59 
60 \*---------------------------------------------------------------------------*/
61 
62 #ifndef greyDiffusiveRadiationMixedFvPatchScalarField_H
63 #define greyDiffusiveRadiationMixedFvPatchScalarField_H
64 
65 #include "mixedFvPatchFields.H"
66 #include "radiationCoupledBase.H"
67 
68 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
69 
70 namespace Foam
71 {
72 
73 /*---------------------------------------------------------------------------*\
74  Class greyDiffusiveRadiationMixedFvPatchScalarField Declaration
75 \*---------------------------------------------------------------------------*/
76 
77 class greyDiffusiveRadiationMixedFvPatchScalarField
78 :
79  public mixedFvPatchScalarField,
80  public radiationCoupledBase
81 {
82  // Private Data
83 
84  //- Name of temperature field
85  word TName_;
86 
87 
88 public:
89 
90  //- Runtime type information
91  TypeName("greyDiffusiveRadiation");
92 
93 
94  // Constructors
95 
96  //- Construct from patch, internal field and dictionary
98  (
99  const fvPatch&,
101  const dictionary&
102  );
103 
104  //- Construct by mapping given a
105  // greyDiffusiveRadiationMixedFvPatchScalarField onto a new patch
107  (
109  const fvPatch&,
111  const fvPatchFieldMapper&
112  );
113 
114  //- Disallow copy without setting internal field reference
116  (
118  ) = delete;
119 
120  //- Copy constructor setting internal field reference
122  (
125  );
126 
127  //- Construct and return a clone setting internal field reference
129  (
131  ) const
132  {
134  (
136  );
137  }
138 
139 
140  // Member Functions
141 
142  // Access
143 
144  //- Return the temperature field name
145  const word& TName() const
146  {
147  return TName_;
148  }
149 
150  //- Return reference to the temperature field name to allow
151  // adjustment
152  word& TName()
153  {
154  return TName_;
155  }
156 
157 
158  // Mapping functions
159 
160  //- Map the given fvPatchField onto this fvPatchField
161  virtual void map
162  (
163  const fvPatchScalarField&,
164  const fvPatchFieldMapper&
165  );
166 
167  //- Reset the fvPatchField to the given fvPatchField
168  // Used for mesh to mesh mapping
169  virtual void reset(const fvPatchScalarField&);
170 
171 
172  // Evaluation functions
173 
174  //- Update the coefficients associated with the patch field
175  virtual void updateCoeffs();
176 
177 
178  // I-O
179 
180  //- Write
181  virtual void write(Ostream&) const;
182 };
183 
184 
185 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
186 
187 } // End namespace Foam
188 
189 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
190 
191 #endif
192 
193 // ************************************************************************* //
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:57
A list of keyword definitions, which are a keyword followed by any number of values (e....
Definition: dictionary.H:160
Foam::fvPatchFieldMapper.
Abstract base class with a fat-interface to all derived classes covering all possible ways in which t...
Definition: fvPatchField.H:87
A finiteVolume patch using a polyPatch and a fvBoundaryMesh.
Definition: fvPatch.H:64
This boundary condition provides a grey-diffuse condition for radiation intensity,...
greyDiffusiveRadiationMixedFvPatchScalarField(const fvPatch &, const DimensionedField< scalar, volMesh > &, const dictionary &)
Construct from patch, internal field and dictionary.
virtual void reset(const fvPatchScalarField &)
Reset the fvPatchField to the given fvPatchField.
virtual tmp< fvPatchScalarField > clone(const DimensionedField< scalar, volMesh > &iF) const
Construct and return a clone setting internal field reference.
virtual void updateCoeffs()
Update the coefficients associated with the patch field.
virtual void map(const fvPatchScalarField &, const fvPatchFieldMapper &)
Map the given fvPatchField onto this fvPatchField.
TypeName("greyDiffusiveRadiation")
Runtime type information.
A class for managing temporary objects.
Definition: tmp.H:55
A class for handling words, derived from string.
Definition: word.H:62
Namespace for OpenFOAM.