Renamed the original 'laminar' model to 'Stokes' to indicate it is a linear stress model supporting both Newtonian and non-Newtonian viscosity. This general framework will support linear, non-linear, visco-elastic etc. laminar transport models. For backward compatibility the 'Stokes' laminar stress model can be selected either the original 'laminar' 'simulationType' specification in turbulenceProperties: simulationType laminar; or using the new more general 'laminarModel' specification: simulationType laminar; laminar { laminarModel Stokes; } which allows other laminar stress models to be selected.
96 lines
3.6 KiB
C
96 lines
3.6 KiB
C
/*---------------------------------------------------------------------------*\
|
|
========= |
|
|
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
\\ / O peration |
|
|
\\ / A nd | Copyright (C) 2014-2016 OpenFOAM Foundation
|
|
\\/ M anipulation |
|
|
-------------------------------------------------------------------------------
|
|
License
|
|
This file is part of OpenFOAM.
|
|
|
|
OpenFOAM is free software: you can redistribute it and/or modify it
|
|
under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
\*---------------------------------------------------------------------------*/
|
|
|
|
#include "CompressibleTurbulenceModel.H"
|
|
#include "incompressibleTwoPhaseInteractingMixture.H"
|
|
#include "addToRunTimeSelectionTable.H"
|
|
#include "makeTurbulenceModel.H"
|
|
|
|
#include "laminarModel.H"
|
|
#include "RASModel.H"
|
|
#include "LESModel.H"
|
|
|
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
|
|
|
makeTurbulenceModelTypes
|
|
(
|
|
geometricOneField,
|
|
volScalarField,
|
|
compressibleTurbulenceModel,
|
|
CompressibleTurbulenceModel,
|
|
incompressibleTwoPhaseInteractingMixture
|
|
);
|
|
|
|
makeBaseTurbulenceModel
|
|
(
|
|
geometricOneField,
|
|
volScalarField,
|
|
compressibleTurbulenceModel,
|
|
CompressibleTurbulenceModel,
|
|
incompressibleTwoPhaseInteractingMixture
|
|
);
|
|
|
|
#define makeLaminarModel(Type) \
|
|
makeTemplatedTurbulenceModel \
|
|
( \
|
|
incompressibleTwoPhaseInteractingMixtureCompressibleTurbulenceModel, \
|
|
laminar, \
|
|
Type \
|
|
)
|
|
|
|
#define makeRASModel(Type) \
|
|
makeTemplatedTurbulenceModel \
|
|
( \
|
|
incompressibleTwoPhaseInteractingMixtureCompressibleTurbulenceModel, \
|
|
RAS, \
|
|
Type \
|
|
)
|
|
|
|
#define makeLESModel(Type) \
|
|
makeTemplatedTurbulenceModel \
|
|
( \
|
|
incompressibleTwoPhaseInteractingMixtureCompressibleTurbulenceModel, \
|
|
LES, \
|
|
Type \
|
|
)
|
|
|
|
#include "Stokes.H"
|
|
makeLaminarModel(Stokes);
|
|
|
|
#include "kEpsilon.H"
|
|
makeRASModel(kEpsilon);
|
|
|
|
#include "buoyantKEpsilon.H"
|
|
makeRASModel(buoyantKEpsilon);
|
|
|
|
#include "Smagorinsky.H"
|
|
makeLESModel(Smagorinsky);
|
|
|
|
#include "kEqn.H"
|
|
makeLESModel(kEqn);
|
|
|
|
|
|
// ************************************************************************* //
|