Newer
Older
/*---------------------------------------------------------------------------*\
========= |
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
\\ / O peration |
\\/ M anipulation |
-------------------------------------------------------------------------------
Copyright (C) 2019,2021 OpenCFD Ltd.
-------------------------------------------------------------------------------
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/>.
Henry
committed
Foam::temperatureCoupledBase
Henry Weller
committed
Common functions used in temperature coupled boundaries.
The thermal conductivity \c kappa may be obtained by the following methods:
- 'lookup' : lookup volScalarField (or volSymmTensorField) with name
defined by 'kappa'
- 'fluidThermo' : use fluidThermo and default
compressible::turbulenceModel to calculate kappa
- 'solidThermo' : use solidThermo kappa()
- 'directionalSolidThermo': uses look up for volSymmTensorField for
transformed kappa vector. Field name definable in 'alphaAni',
named 'Anialpha' in solid solver by default
- 'function' : kappa, alpha directly specified as Function1
- 'phaseSystem' : used for multiphase thermos
Henry Weller
committed
Henry Weller
committed
\par Keywords provided by this class:
\table
Property | Description | Required | Default
kappaMethod | Thermal conductivity method | yes |
kappa | Name of thermal conductivity field | no |
alpha | Name of thermal diffusivity field | no |
alphaAni | Name of non-isotropic alpha | no |
kappaValue | Function1 supplying kappa | no |
alphaValue | Function1 supplying alpha | no |
Henry Weller
committed
\endtable
Henry Weller
committed
Henry Weller
committed
Usage
Henry Weller
committed
\verbatim
nonIsotropicWall
{
...
Henry Weller
committed
kappaMethod directionalSolidThermo;
alphaAni Anialpha;
Henry Weller
committed
...
}
\endverbatim
\verbatim
specifiedWall
{
...
kappaMethod function;
kappaFunction constant 1.0;
alphaFunction constant 100.0;
...
}
\endverbatim
SourceFiles
temperatureCoupledBase.C
\*---------------------------------------------------------------------------*/
#ifndef temperatureCoupledBase_H
#define temperatureCoupledBase_H
#include "scalarField.H"
#include "fvPatch.H"
#include "PatchFunction1.H"
#include "fvPatchFieldMapper.H"
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
namespace Foam
{
/*---------------------------------------------------------------------------*\
andy
committed
Class temperatureCoupledBase Declaration
\*---------------------------------------------------------------------------*/
class temperatureCoupledBase
{
public:
andy
committed
// Public Enumerations
andy
committed
//- Type of supplied Kappa
enum KMethodType
{
andy
committed
mtFluidThermo,
mtSolidThermo,
mtDirectionalSolidThermo,
mtLookup,
mtFunction
andy
committed
static const Enum<KMethodType> KMethodTypeNames_;
//- Underlying patch
const fvPatch& patch_;
//- How to get K
const KMethodType method_;
//- Name of thermal conductivity field (if looked up from database)
const word kappaName_;
//- Name of the non-Isotropic alpha (default: Anialpha)
const word alphaAniName_;
//- Name of thermal diffusivity
const word alphaName_;
//- Function1 for kappa
autoPtr<PatchFunction1<scalar>> kappaFunction1_;
//- Function1 for alpha
autoPtr<PatchFunction1<scalar>> alphaFunction1_;
public:
// Constructors
//- Construct from patch and K name
temperatureCoupledBase
(
const fvPatch& patch,
const word& calculationMethod,
const word& kappaName,
const word& alphaAniName,
const word& alphaName
);
//- Construct from patch and dictionary
temperatureCoupledBase
(
const fvPatch& patch,
const dictionary& dict
);
//- Construct from patch and temperatureCoupledBase
temperatureCoupledBase
(
const fvPatch& patch,
const temperatureCoupledBase& base
);
//- Construct as copy
temperatureCoupledBase
(
const temperatureCoupledBase&
);
//- Destructor
virtual ~temperatureCoupledBase() = default;
// Member functions
//- Method to obtain K
word KMethod() const
{
return KMethodTypeNames_[method_];
}
//- Name of thermal conductivity field
const word& kappaName() const
return kappaName_;
//- Name of thermal diffusivity field
const word& alphaName() const
{
return alphaName_;
}
//- Map (and resize as needed) from self given a mapping object
virtual void autoMap
(
const fvPatchFieldMapper&
) = 0;
//- Reverse map the given fvPatchField onto this fvPatchField
virtual void rmap
(
const fvPatchField<scalar>&,
//- Given patch temperature calculate corresponding K field
virtual tmp<scalarField> kappa(const scalarField& Tp) const;
//- Given patch temperature calculate corresponding alphaEff field
virtual tmp<scalarField> alpha(const scalarField& Tp) const;
void write(Ostream& os) const;
};
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
} // End namespace Foam
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
#endif
// ************************************************************************* //