Loading...
Searching...
No Matches
solidArrheniusReactionRateI.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) 2011-2017 OpenFOAM Foundation
9 Copyright (C) 2022 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
29// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
30
32(
33 const scalar A,
34 const scalar Ta,
35 const scalar Tcrit
36)
38 A_(A),
39 Ta_(Ta),
40 Tcrit_(Tcrit)
41{}
42
43
45(
46 const speciesTable&,
47 const dictionary& dict
48)
49:
50 A_(dict.get<scalar>("A")),
51 Ta_(dict.get<scalar>("Ta")),
52 Tcrit_(dict.get<scalar>("Tcrit"))
53{}
54
55
56// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
57
58inline Foam::scalar Foam::solidArrheniusReactionRate::operator()
59(
60 const scalar,
61 const scalar T,
62 const scalarField&
63) const
64{
65 if (T < Tcrit_)
66 {
67 return 0;
68 }
69
70 return A_*exp(-Ta_/T);
71}
72
73
74inline void Foam::solidArrheniusReactionRate::write(Ostream& os) const
76 os.writeEntry("A", A_);
77 os.writeEntry("Ta", Ta_);
78 os.writeEntry("Tcrit", Tcrit_);
79}
80
81
82inline Foam::Ostream& Foam::operator<<
83(
84 Ostream& os,
85 const solidArrheniusReactionRate& arr
86)
87{
88 arr.write(os);
89 return os;
90}
91
92
93// ************************************************************************* //
static const Foam::dimensionedScalar A("", Foam::dimPressure, 611.21)
An Ostream is an abstract base class for all output systems (streams, files, token lists,...
Definition Ostream.H:59
A list of keyword definitions, which are a keyword followed by a number of values (eg,...
Definition dictionary.H:133
Arrhenius reaction rate for solids.
solidArrheniusReactionRate(const scalar A, const scalar Ta, const scalar Tcrit)
Construct from components.
void write(Ostream &os) const
Write to stream.
OBJstream os(runTime.globalPath()/outputName)
dimensionedScalar exp(const dimensionedScalar &ds)
hashedWordList speciesTable
A table of species as a hashedWordList.
Field< scalar > scalarField
Specialisation of Field<T> for scalar.
void T(FieldField< Field, Type > &f1, const FieldField< Field, Type > &f2)
dictionary dict