ThermoCombustion.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) 2012-2017 OpenFOAM Foundation
9 -------------------------------------------------------------------------------
10 License
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 
26 Class
27  Foam::ThermoCombustion
28 
29 Description
30  Thermo model wrapper for combustion models
31 
32 SourceFiles
33  ThermoCombustion.C
34 
35 \*---------------------------------------------------------------------------*/
36 
37 #ifndef ThermoCombustion_H
38 #define ThermoCombustion_H
39 
40 #include "autoPtr.H"
41 #include "CombustionModel.H"
42 
43 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
44 
45 namespace Foam
46 {
47 
48 /*---------------------------------------------------------------------------*\
49  class ThermoCombustion Declaration
50 \*---------------------------------------------------------------------------*/
51 
52 template<class ReactionThermo>
53 class ThermoCombustion
54 :
55  public CombustionModel<ReactionThermo>
56 {
57  // Private Member Functions
58 
59  //- Construct as copy (not implemented)
60  ThermoCombustion(const ThermoCombustion&) = delete;
61 
62  //- No copy assignment
63  void operator=(const ThermoCombustion&) = delete;
64 
65 
66 protected:
67 
68  // Protected data
69 
70  //- Thermo
71  ReactionThermo& thermo_;
72 
73 
74 public:
75 
76  // Constructors
77 
78  //- Construct from components
80  (
81  const word& modelType,
82  ReactionThermo& thermo,
84  );
85 
86 
87  //- Destructor
88  virtual ~ThermoCombustion();
89 
90 
91  // Member Functions
92 
93  //- Return access to the thermo package
94  virtual ReactionThermo& thermo();
95 
96  //- Return const access to the thermo package
97  virtual const ReactionThermo& thermo() const;
98 };
99 
100 
101 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
102 
103 } // End namespace Foam
104 
105 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
106 
107 #ifdef NoRepository
108  #include "ThermoCombustion.C"
109 #endif
110 
111 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
112 
113 #endif
114 
115 // ************************************************************************* //
Foam::CombustionModel
Combustion models for templated thermodynamics.
Definition: CombustionModel.H:55
Foam::word
A class for handling words, derived from Foam::string.
Definition: word.H:65
Foam::ThermoCombustion::~ThermoCombustion
virtual ~ThermoCombustion()
Destructor.
Definition: ThermoCombustion.C:54
thermo
Basic thermodynamics type based on the use of fitting functions for cp, h, s obtained from the templa...
Foam::ThermoCombustion
Thermo model wrapper for combustion models.
Definition: ThermoCombustion.H:52
Foam::ThermoCombustion::thermo_
ReactionThermo & thermo_
Thermo.
Definition: ThermoCombustion.H:70
Foam::ThermoCombustion::thermo
virtual ReactionThermo & thermo()
Return access to the thermo package.
Definition: ThermoCombustion.C:62
CombustionModel.H
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
ThermoCombustion.C
turb
compressible::turbulenceModel & turb
Definition: setRegionFluidFields.H:10
Foam::compressibleTurbulenceModel
Abstract base class for turbulence models (RAS, LES and laminar).
Definition: compressibleTurbulenceModel.H:54
autoPtr.H