All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
multiphaseMixtureThermo.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) 2013-2019 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::multiphaseMixtureThermo
26 
27 Description
28 
29 SourceFiles
30  multiphaseMixtureThermo.C
31 
32 \*---------------------------------------------------------------------------*/
33 
34 #ifndef multiphaseMixtureThermo_H
35 #define multiphaseMixtureThermo_H
36 
37 #include "phaseModel.H"
38 #include "PtrDictionary.H"
39 #include "volFields.H"
40 #include "surfaceFields.H"
41 #include "rhoThermo.H"
42 #include "psiThermo.H"
43 
44 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
45 
46 namespace Foam
47 {
48 
49 /*---------------------------------------------------------------------------*\
50  Class multiphaseMixtureThermo Declaration
51 \*---------------------------------------------------------------------------*/
52 
54 :
55  public psiThermo
56 {
57 public:
58 
59  class interfacePair
60  :
61  public Pair<word>
62  {
63  public:
64 
65  class hash
66  :
67  public Hash<interfacePair>
68  {
69  public:
70 
71  hash()
72  {}
73 
74  label operator()(const interfacePair& key) const
75  {
76  return word::hash()(key.first()) + word::hash()(key.second());
77  }
78  };
79 
80 
81  // Constructors
82 
84  {}
85 
86  interfacePair(const word& alpha1Name, const word& alpha2Name)
87  :
88  Pair<word>(alpha1Name, alpha2Name)
89  {}
90 
92  :
93  Pair<word>(alpha1.name(), alpha2.name())
94  {}
95 
96 
97  // Friend Operators
98 
99  friend bool operator==
100  (
101  const interfacePair& a,
102  const interfacePair& b
103  )
104  {
105  return
106  (
107  ((a.first() == b.first()) && (a.second() == b.second()))
108  || ((a.first() == b.second()) && (a.second() == b.first()))
109  );
110  }
111 
112  friend bool operator!=
113  (
114  const interfacePair& a,
115  const interfacePair& b
116  )
117  {
118  return (!(a == b));
119  }
120  };
121 
122 
123 private:
124 
125  // Private Data
126 
127  //- Dictionary of phases
129 
130  const fvMesh& mesh_;
131  const volVectorField& U_;
132  const surfaceScalarField& phi_;
133 
134  surfaceScalarField rhoPhi_;
135 
136  volScalarField alphas_;
137 
139  sigmaTable;
140 
141  sigmaTable sigmas_;
142  dimensionSet dimSigma_;
143 
144  //- Stabilisation for normalisation of the interface normal
145  const dimensionedScalar deltaN_;
146 
147  //- Conversion factor for degrees into radians
148  static const scalar convertToRad;
149 
150 
151  // Private Member Functions
152 
153  void calcAlphas();
154 
155  void solveAlphas(const scalar cAlpha);
156 
158  (
159  const volScalarField& alpha1,
160  const volScalarField& alpha2
161  ) const;
162 
164  (
165  const volScalarField& alpha1,
166  const volScalarField& alpha2
167  ) const;
168 
169  void correctContactAngle
170  (
171  const phaseModel& alpha1,
172  const phaseModel& alpha2,
173  surfaceVectorField::Boundary& nHatb
174  ) const;
175 
177  (
178  const phaseModel& alpha1,
179  const phaseModel& alpha2
180  ) const;
181 
182 
183 public:
184 
185  //- Runtime type information
186  TypeName("multiphaseMixtureThermo");
187 
188 
189  // Constructors
190 
191  //- Construct from components
193  (
194  const volVectorField& U,
195  const surfaceScalarField& phi
196  );
197 
198 
199  //- Destructor
200  virtual ~multiphaseMixtureThermo()
201  {}
202 
203 
204  // Member Functions
205 
206  //- Return the phases
207  const PtrDictionary<phaseModel>& phases() const
208  {
209  return phases_;
210  }
211 
212  //- Return non-const access to the phases
214  {
215  return phases_;
216  }
217 
218  //- Return the velocity
219  const volVectorField& U() const
220  {
221  return U_;
222  }
223 
224  //- Return the volumetric flux
225  const surfaceScalarField& phi() const
226  {
227  return phi_;
228  }
230  const surfaceScalarField& rhoPhi() const
231  {
232  return rhoPhi_;
233  }
234 
235  //- Update properties
236  virtual void correct();
237 
238  //- Update densities for given pressure change
239  void correctRho(const volScalarField& dp);
240 
241  //- Return the name of the thermo physics
242  virtual word thermoName() const;
243 
244  //- Return true if the equation of state is incompressible
245  // i.e. rho != f(p)
246  virtual bool incompressible() const;
247 
248  //- Return true if the equation of state is isochoric
249  // i.e. rho = const
250  virtual bool isochoric() const;
251 
252 
253  // Access to thermodynamic state variables
254 
255  //- Enthalpy/Internal energy [J/kg]
256  // Non-const access allowed for transport equations
257  virtual volScalarField& he()
258  {
260  return phases_[0].thermo().he();
261  }
262 
263  //- Enthalpy/Internal energy [J/kg]
264  virtual const volScalarField& he() const
265  {
267  return phases_[0].thermo().he();
268  }
269 
270  //- Enthalpy/Internal energy
271  // for given pressure and temperature [J/kg]
272  virtual tmp<volScalarField> he
273  (
274  const volScalarField& p,
275  const volScalarField& T
276  ) const;
277 
278  //- Enthalpy/Internal energy for cell-set [J/kg]
279  virtual tmp<scalarField> he
280  (
281  const scalarField& p,
282  const scalarField& T,
283  const labelList& cells
284  ) const;
285 
286  //- Enthalpy/Internal energy for patch [J/kg]
287  virtual tmp<scalarField> he
288  (
289  const scalarField& p,
290  const scalarField& T,
291  const label patchi
292  ) const;
293 
294  //- Chemical enthalpy [J/kg]
295  virtual tmp<volScalarField> hc() const;
296 
297  //- Temperature from enthalpy/internal energy for cell-set
298  virtual tmp<scalarField> THE
299  (
300  const scalarField& h,
301  const scalarField& p,
302  const scalarField& T0, // starting temperature
303  const labelList& cells
304  ) const;
305 
306  //- Temperature from enthalpy/internal energy for patch
307  virtual tmp<scalarField> THE
308  (
309  const scalarField& h,
310  const scalarField& p,
311  const scalarField& T0, // starting temperature
312  const label patchi
313  ) const;
314 
315 
316  // Fields derived from thermodynamic state variables
317 
318  //- Density [kg/m^3]
319  virtual tmp<volScalarField> rho() const;
320 
321  //- Density for patch [kg/m^3]
322  virtual tmp<scalarField> rho(const label patchi) const;
323 
324  //- Heat capacity at constant pressure [J/kg/K]
325  virtual tmp<volScalarField> Cp() const;
326 
327  //- Heat capacity at constant pressure for patch [J/kg/K]
328  virtual tmp<scalarField> Cp
329  (
330  const scalarField& p,
331  const scalarField& T,
332  const label patchi
333  ) const;
334 
335  //- Heat capacity at constant volume [J/kg/K]
336  virtual tmp<volScalarField> Cv() const;
337 
338  //- Heat capacity at constant volume for patch [J/kg/K]
339  virtual tmp<scalarField> Cv
340  (
341  const scalarField& p,
342  const scalarField& T,
343  const label patchi
344  ) const;
345 
346  //- Gamma = Cp/Cv []
347  virtual tmp<volScalarField> gamma() const;
348 
349  //- Gamma = Cp/Cv for patch []
350  virtual tmp<scalarField> gamma
351  (
352  const scalarField& p,
353  const scalarField& T,
354  const label patchi
355  ) const;
356 
357  //- Heat capacity at constant pressure/volume [J/kg/K]
358  virtual tmp<volScalarField> Cpv() const;
359 
360  //- Heat capacity at constant pressure/volume for patch [J/kg/K]
361  virtual tmp<scalarField> Cpv
362  (
363  const scalarField& p,
364  const scalarField& T,
365  const label patchi
366  ) const;
367 
368  //- Heat capacity ratio []
369  virtual tmp<volScalarField> CpByCpv() const;
370 
371  //- Heat capacity ratio for patch []
372  virtual tmp<scalarField> CpByCpv
373  (
374  const scalarField& p,
375  const scalarField& T,
376  const label patchi
377  ) const;
378 
379  //- Molecular weight [kg/kmol]
380  virtual tmp<volScalarField> W() const;
381 
382  //- Molecular weight for patch [kg/kmol]
383  virtual tmp<scalarField> W(const label patchi) const;
384 
385 
386  // Fields derived from transport state variables
387 
388  //- Kinematic viscosity of mixture [m^2/s]
389  virtual tmp<volScalarField> nu() const;
390 
391  //- Kinematic viscosity of mixture for patch [m^2/s]
392  virtual tmp<scalarField> nu(const label patchi) const;
393 
394  //- Thermal diffusivity for temperature of mixture [W/m/K]
395  virtual tmp<volScalarField> kappa() const;
396 
397  //- Thermal diffusivity of mixture for patch [W/m/K]
398  virtual tmp<scalarField> kappa
399  (
400  const label patchi
401  ) const;
402 
403  //- Thermal diffusivity for energy of mixture [kg/m/s]
404  virtual tmp<volScalarField> alphahe() const;
405 
406  //- Thermal diffusivity for energy of mixture for patch [kg/m/s]
407  virtual tmp<scalarField> alphahe(const label patchi) const;
408 
409  //- Effective thermal diffusivity of mixture [W/m/K]
411  (
412  const volScalarField& alphat
413  ) const;
414 
415  //- Effective thermal diffusivity of mixture for patch [W/m/K]
416  virtual tmp<scalarField> kappaEff
417  (
418  const scalarField& alphat,
419  const label patchi
420  ) const;
421 
422  //- Effective thermal diffusivity of mixture [W/m/K]
424  (
425  const volScalarField& alphat
426  ) const;
427 
428  //- Effective thermal diffusivity of mixture for patch [W/m/K]
429  virtual tmp<scalarField> alphaEff
430  (
431  const scalarField& alphat,
432  const label patchi
433  ) const;
434 
435 
436  //- Return the phase-averaged reciprocal Cv
437  tmp<volScalarField> rCv() const;
438 
440 
441  //- Indicator of the proximity of the interface
442  // Field values are 1 near and 0 away for the interface.
444 
445  //- Solve for the mixture phase-fractions
446  void solve();
447 };
448 
449 
450 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
451 
452 } // End namespace Foam
453 
454 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
455 
456 #endif
457 
458 // ************************************************************************* //
Template dictionary class which manages the storage associated with it.
Definition: PtrDictionary.H:53
Foam::surfaceFields.
const volVectorField & U() const
Return the velocity.
Hashing function class, shared by all the derived classes.
Definition: string.H:90
intWM_LABEL_SIZE_t label
A label is an int32_t or int64_t as specified by the pre-processor macro WM_LABEL_SIZE.
Definition: label.H:59
const surfaceScalarField & phi() const
Return the volumetric flux.
virtual tmp< volScalarField > gamma() const
Gamma = Cp/Cv [].
virtual tmp< volScalarField > hc() const
Chemical enthalpy [J/kg].
virtual const volScalarField & T() const
Temperature [K].
Definition: basicThermo.C:489
virtual ~multiphaseMixtureThermo()
Destructor.
CGAL::Exact_predicates_exact_constructions_kernel K
virtual tmp< volScalarField > Cp() const
Heat capacity at constant pressure [J/kg/K].
virtual tmp< volScalarField > CpByCpv() const
Heat capacity ratio [].
virtual volScalarField & p()
Pressure [Pa].
Definition: basicThermo.C:477
void correctRho(const volScalarField &dp)
Update densities for given pressure change.
void solve()
Solve for the mixture phase-fractions.
Dimension set for the base types.
Definition: dimensionSet.H:120
An ordered pair of two objects of type <T> with first() and second() elements.
Definition: contiguous.H:49
const cellShapeList & cells
virtual tmp< volScalarField > alphahe() const
Thermal diffusivity for energy of mixture [kg/m/s].
virtual tmp< volScalarField > rho() const
Density [kg/m^3].
const dimensionedScalar b
Wien displacement law constant: default SI units: [m K].
Definition: createFields.H:27
tmp< volScalarField > rCv() const
Return the phase-averaged reciprocal Cv.
const PtrDictionary< phaseModel > & phases() const
Return the phases.
A class for handling words, derived from string.
Definition: word.H:59
const volScalarField & alpha1
const word & name() const
Name function is needed to disambiguate those inherited.
alpha2
Definition: alphaEqn.H:115
virtual tmp< volScalarField > nu() const
Kinematic viscosity of mixture [m^2/s].
label operator()(const interfacePair &key) const
const Type & second() const
Return second.
Definition: Pair.H:99
TypeName("multiphaseMixtureThermo")
Runtime type information.
virtual tmp< volScalarField > kappaEff(const volScalarField &alphat) const
Effective thermal diffusivity of mixture [W/m/K].
multiphaseMixtureThermo(const volVectorField &U, const surfaceScalarField &phi)
Construct from components.
label patchi
volScalarField & h
Planck constant.
virtual tmp< volScalarField > W() const
Molecular weight [kg/kmol].
const surfaceScalarField & rhoPhi() const
Mesh data needed to do the Finite Volume discretisation.
Definition: fvMesh.H:78
Hash function class for primitives. All non-primitives used to hash entries on hash tables likely nee...
Definition: Hash.H:54
tmp< volScalarField > nearInterface() const
Indicator of the proximity of the interface.
virtual tmp< scalarField > THE(const scalarField &h, const scalarField &p, const scalarField &T0, const labelList &cells) const
Temperature from enthalpy/internal energy for cell-set.
virtual tmp< volScalarField > Cv() const
Heat capacity at constant volume [J/kg/K].
A class for managing temporary objects.
Definition: PtrList.H:53
tmp< surfaceScalarField > surfaceTensionForce() const
virtual tmp< volScalarField > alphaEff(const volScalarField &alphat) const
Effective thermal diffusivity of mixture [W/m/K].
virtual tmp< volScalarField > Cpv() const
Heat capacity at constant pressure/volume [J/kg/K].
#define NotImplemented
Issue a FatalErrorIn for a function not currently implemented.
Definition: error.H:366
virtual tmp< volScalarField > kappa() const
Thermal diffusivity for temperature of mixture [W/m/K].
Single incompressible phase derived from the phase-fraction. Used as part of the multiPhaseMixture fo...
Definition: phaseModel.H:53
const Type & first() const
Return first.
Definition: Pair.H:87
Basic thermodynamic properties based on compressibility.
Definition: psiThermo.H:49
virtual bool isochoric() const
Return true if the equation of state is isochoric.
virtual word thermoName() const
Return the name of the thermo physics.
virtual volScalarField & he()
Enthalpy/Internal energy [J/kg].
Namespace for OpenFOAM.
virtual bool incompressible() const
Return true if the equation of state is incompressible.
virtual void correct()
Update properties.