LandauTellerReactionRate.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-2021 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::LandauTellerReactionRate
26 
27 Description
28  Landau-Teller reaction rate.
29 
30 SourceFiles
31  LandauTellerReactionRateI.H
32 
33 \*---------------------------------------------------------------------------*/
34 
35 #ifndef LandauTellerReactionRate_H
36 #define LandauTellerReactionRate_H
37 
38 #include "scalarField.H"
39 #include "typeInfo.H"
40 
41 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
42 
43 namespace Foam
44 {
45 
46 // Forward declaration of friend functions and operators
47 
48 class LandauTellerReactionRate;
49 
50 Ostream& operator<<(Ostream&, const LandauTellerReactionRate&);
51 
52 
53 /*---------------------------------------------------------------------------*\
54  Class LandauTellerReactionRate Declaration
55 \*---------------------------------------------------------------------------*/
56 
58 {
59  // Private Data
60 
61  scalar A_;
62  scalar beta_;
63  scalar Ta_;
64  scalar B_;
65  scalar C_;
66 
67 
68 public:
69 
70  // Constructors
71 
72  //- Construct from components
74  (
75  const scalar A,
76  const scalar beta,
77  const scalar Ta,
78  const scalar B,
79  const scalar C
80  );
81 
82  //- Construct from dictionary
84  (
85  const speciesTable& species,
86  const dictionary& dict
87  );
88 
89 
90  // Member Functions
91 
92  //- Return the type name
93  static word type()
94  {
95  return "LandauTeller";
96  }
97 
98  //- Pre-evaluation hook
99  inline void preEvaluate() const;
100 
101  //- Post-evaluation hook
102  inline void postEvaluate() const;
103 
104  //- Return the rate
105  inline scalar operator()
106  (
107  const scalar p,
108  const scalar T,
109  const scalarField& c,
110  const label li
111  ) const;
112 
113  //- The derivative of the rate w.r.t. temperature
114  inline scalar ddT
115  (
116  const scalar p,
117  const scalar T,
118  const scalarField& c,
119  const label li
120  ) const;
121 
122  //- Is the rate a function of concentration?
123  inline bool hasDdc() const;
124 
125  //- The derivative of the rate w.r.t. concentration
126  inline void ddc
127  (
128  const scalar p,
129  const scalar T,
130  const scalarField& c,
131  const label li,
133  ) const;
134 
135  //- Write to stream
136  inline void write(Ostream& os) const;
137 
138 
139  // Ostream Operator
140 
141  inline friend Ostream& operator<<
142  (
143  Ostream&,
145  );
146 };
147 
148 
149 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
150 
151 } // End namespace Foam
152 
153 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
154 
156 
157 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
158 
159 #endif
160 
161 // ************************************************************************* //
static const Foam::dimensionedScalar A("A", Foam::dimPressure, 611.21)
static const Foam::dimensionedScalar B("B", Foam::dimless, 18.678)
Graphite solid properties.
Definition: C.H:51
Landau-Teller reaction rate.
void preEvaluate() const
Pre-evaluation hook.
void postEvaluate() const
Post-evaluation hook.
static word type()
Return the type name.
void write(Ostream &os) const
Write to stream.
void ddc(const scalar p, const scalar T, const scalarField &c, const label li, scalarField &ddc) const
The derivative of the rate w.r.t. concentration.
LandauTellerReactionRate(const scalar A, const scalar beta, const scalar Ta, const scalar B, const scalar C)
Construct from components.
scalar ddT(const scalar p, const scalar T, const scalarField &c, const label li) const
The derivative of the rate w.r.t. temperature.
bool hasDdc() const
Is the rate a function of concentration?
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
A wordList with hashed indices for faster lookup by name.
A class for handling words, derived from string.
Definition: word.H:62
const dimensionedScalar c
Speed of light in a vacuum.
Namespace for OpenFOAM.
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
Ostream & operator<<(Ostream &, const ensightPart &)
void T(FieldField< Field, Type > &f1, const FieldField< Field, Type > &f2)
dictionary dict
volScalarField & p