analytical.C
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-------------------------------------------------------------------------------
10License
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\*---------------------------------------------------------------------------*/
27
28#include "analytical.H"
30
31// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
32
33namespace Foam
34{
35namespace integrationSchemes
36{
39}
40}
41
42// * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * //
43
45{}
46
47
48// * * * * * * * * * * * * * * * * Destructor * * * * * * * * * * * * * * * //
49
51{}
52
53
54// * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * //
55
57(
58 const scalar dt,
59 const scalar Beta
60) const
61{
62 return
63 mag(Beta*dt) > SMALL
64 ? (1 - exp(- Beta*dt))/Beta
65 : dt;
66}
67
68
70(
71 const scalar dt,
72 const scalar Beta
73) const
74{
75 return
76 mag(Beta*dt) > SMALL
77 ? dt/Beta - (1 - exp(- Beta*dt))/sqr(Beta)
78 : sqr(dt);
79}
80
81
82// ************************************************************************* //
Macros for easy insertion into run-time selection tables.
#define addToRunTimeSelectionTable(baseType, thisType, argNames)
Add to construction table with typeName as the key.
Base for a set of schemes which integrate simple ODEs which arise from semi-implcit rate expressions.
Analytical integration scheme.
Definition: analytical.H:56
virtual ~analytical()
Destructor.
Definition: analytical.C:50
virtual scalar sumDtEff(const scalar dt, const scalar Beta) const
Return the integral of the effective time step.
Definition: analytical.C:70
virtual scalar dtEff(const scalar dt, const scalar Beta) const
Return the integration effective time step.
Definition: analytical.C:57
A class for handling words, derived from Foam::string.
Definition: word.H:68
#define defineTypeNameAndDebug(Type, DebugSwitch)
Define the typeName and debug information.
Definition: className.H:121
Namespace for OpenFOAM.
dimensionedScalar exp(const dimensionedScalar &ds)
dimensionedSymmTensor sqr(const dimensionedVector &dv)
dimensioned< typename typeOfMag< Type >::type > mag(const dimensioned< Type > &dt)