Computes various turbulence-related quantities that are not typically output during calculations, and stores/writes them on the mesh database for further manipulation. More...
Public Types | |
enum | compressibleField { cfK, cfEpsilon, cfOmega, cfNuTilda, cfMut, cfMuEff, cfAlphat, cfAlphaEff, cfR, cfDevRhoReff, cfL, cfI } |
enum | incompressibleField { ifK, ifEpsilon, ifOmega, ifNuTilda, ifNut, ifNuEff, ifR, ifDevReff, ifL, ifI } |
Public Member Functions | |
TypeName ("turbulenceFields") | |
turbulenceFields (const word &name, const Time &runTime, const dictionary &dict) | |
turbulenceFields (const turbulenceFields &)=delete | |
void | operator= (const turbulenceFields &)=delete |
virtual | ~turbulenceFields ()=default |
virtual bool | read (const dictionary &) |
virtual bool | execute () |
virtual bool | write () |
template<class Model > | |
Foam::tmp< Foam::volScalarField > | nuTilda (const Model &model) const |
template<class Model > | |
Foam::tmp< Foam::volScalarField > | L (const Model &model) const |
template<class Model > | |
Foam::tmp< Foam::volScalarField > | I (const Model &model) const |
![]() | |
TypeName ("fvMeshFunctionObject") | |
fvMeshFunctionObject (const word &name, const Time &runTime, const dictionary &dict) | |
fvMeshFunctionObject (const word &name, const objectRegistry &obr, const dictionary &dict) | |
virtual | ~fvMeshFunctionObject ()=default |
![]() | |
TypeName ("regionFunctionObject") | |
regionFunctionObject (const word &name, const Time &runTime, const dictionary &dict) | |
regionFunctionObject (const word &name, const objectRegistry &obr, const dictionary &dict) | |
virtual | ~regionFunctionObject ()=default |
template<class ObjectType > | |
const ObjectType * | lookupObjectPtr (const word &fieldName) const |
template<class ObjectType > | |
ObjectType * | lookupObjectRefPtr (const word &fieldName) const |
![]() | |
stateFunctionObject (const word &name, const Time &runTime) | |
virtual | ~stateFunctionObject ()=default |
dictionary & | propertyDict () |
bool | foundProperty (const word &entryName) const |
void | clearTrigger () |
label | getTrigger () const |
bool | setTrigger (const label triggeri, bool increaseOnly=true) |
bool | getDict (const word &entryName, dictionary &dict) const |
bool | getObjectDict (const word &objectName, const word &entryName, dictionary &dict) const |
template<class Type > | |
Type | getProperty (const word &entryName, const Type &defaultValue=Type(Zero)) const |
template<class Type > | |
bool | getProperty (const word &entryName, Type &value) const |
template<class Type > | |
void | setProperty (const word &entryName, const Type &value) |
template<class Type > | |
Type | getObjectProperty (const word &objectName, const word &entryName, const Type &defaultValue=Type(Zero)) const |
template<class Type > | |
bool | getObjectProperty (const word &objectName, const word &entryName, Type &value) const |
template<class Type > | |
void | setObjectProperty (const word &objectName, const word &entryName, const Type &value) |
template<class Type > | |
void | setResult (const word &entryName, const Type &value) |
template<class Type > | |
void | setObjectResult (const word &objectName, const word &entryName, const Type &value) |
template<class Type > | |
Type | getResult (const word &entryName, const Type &defaultValue=Type(Zero)) const |
template<class Type > | |
Type | getObjectResult (const word &objectName, const word &entryName, const Type &defaultValue=Type(Zero)) const |
template<class Type > | |
bool | getObjectResult (const word &objectName, const word &entryName, Type &value) const |
word | resultType (const word &entryName) const |
word | objectResultType (const word &objectName, const word &entryName) const |
wordList | objectResultEntries () const |
wordList | objectResultEntries (const word &objectName) const |
void | writeResultEntries (Ostream &os) const |
void | writeResultEntries (const word &objectName, Ostream &os) const |
void | writeAllResultEntries (Ostream &os) const |
![]() | |
timeFunctionObject (const word &name, const Time &runTime) | |
virtual | ~timeFunctionObject ()=default |
const Time & | time () const |
objectRegistry & | storedObjects () |
const objectRegistry & | storedObjects () const |
![]() | |
declareRunTimeSelectionTable (autoPtr, functionObject, dictionary,(const word &name, const Time &runTime, const dictionary &dict),(name, runTime, dict)) | |
functionObject (const word &name, const bool withNamePrefix=defaultUseNamePrefix) | |
autoPtr< functionObject > | clone () const |
virtual | ~functionObject ()=default |
virtual const word & | type () const =0 |
const word & | name () const noexcept |
bool | useNamePrefix () const noexcept |
bool | useNamePrefix (bool on) noexcept |
virtual bool | execute (const label subIndex) |
virtual bool | end () |
virtual bool | adjustTimeStep () |
virtual bool | filesModified () const |
virtual void | updateMesh (const mapPolyMesh &mpm) |
virtual void | movePoints (const polyMesh &mesh) |
Static Public Attributes | |
static const Enum< compressibleField > | compressibleFieldNames_ |
static const Enum< incompressibleField > | incompressibleFieldNames_ |
static const word | modelName_ |
![]() | |
static int | debug |
static bool | postProcess |
static bool | defaultUseNamePrefix |
static word | outputPrefix |
Protected Member Functions | |
void | initialise () |
bool | compressible () |
template<class Type > | |
void | processField (const word &fieldName, const tmp< GeometricField< Type, fvPatchField, volMesh >> &tvalue) |
template<class Model > | |
tmp< volScalarField > | nuTilda (const Model &model) const |
template<class Model > | |
tmp< volScalarField > | L (const Model &model) const |
template<class Model > | |
tmp< volScalarField > | I (const Model &model) const |
![]() | |
fvMeshFunctionObject (const fvMeshFunctionObject &)=delete | |
void | operator= (const fvMeshFunctionObject &)=delete |
![]() | |
virtual const objectRegistry & | obr () const |
template<class ObjectType > | |
bool | foundObject (const word &fieldName) const |
template<class ObjectType > | |
const ObjectType * | cfindObject (const word &fieldName) const |
template<class ObjectType > | |
const ObjectType * | findObject (const word &fieldName) const |
template<class ObjectType > | |
ObjectType * | findObject (const word &fieldName) |
template<class ObjectType > | |
ObjectType * | getObjectPtr (const word &fieldName) const |
template<class ObjectType > | |
const ObjectType & | lookupObject (const word &fieldName) const |
template<class ObjectType > | |
ObjectType & | lookupObjectRef (const word &fieldName) const |
template<class ObjectType > | |
bool | store (word &fieldName, const tmp< ObjectType > &tfield, bool cacheable=false) |
template<class ObjectType > | |
bool | storeInDb (const word &fieldName, const tmp< ObjectType > &tfield, const objectRegistry &obr) |
bool | writeObject (const word &fieldName) |
bool | clearObject (const word &fieldName) |
void | clearObjects (const wordList &objNames) |
regionFunctionObject (const regionFunctionObject &)=delete | |
void | operator= (const regionFunctionObject &)=delete |
![]() | |
const functionObjects::properties & | stateDict () const |
functionObjects::properties & | stateDict () |
stateFunctionObject (const stateFunctionObject &)=delete | |
void | operator= (const stateFunctionObject &)=delete |
![]() | |
void | clearOutputObjects (const wordList &objNames) |
timeFunctionObject (const timeFunctionObject &)=delete | |
void | operator= (const timeFunctionObject &)=delete |
![]() | |
word | scopedName (const word &name) const |
Protected Attributes | |
bool | initialised_ |
word | prefix_ |
wordHashSet | fieldSet_ |
![]() | |
const fvMesh & | mesh_ |
![]() | |
word | subRegistryName_ |
const objectRegistry & | obr_ |
const objectRegistry * | obrPtr_ |
![]() | |
const Time & | time_ |
Additional Inherited Members | |
![]() | |
static autoPtr< functionObject > | New (const word &name, const Time &runTime, const dictionary &dict) |
![]() | |
bool | log |
Computes various turbulence-related quantities that are not typically output during calculations, and stores/writes them on the mesh database for further manipulation.
Fields are stored as copies of the original with a user-defined prefix e.g. a prefix of turbulenceModel
yields the following for field R:
turbulenceModel:R
Operands:
Operand | Type | Location |
---|---|---|
input | - | - |
output file | - | - |
output field | vol<Type>Field | $FOAM_CASE/<time>/<outField> |
where <Type>=Scalar/SymmTensor
.
References:
Estimation expressions for L (tag:P), Eq. 10.37: Pope, S. B. (2000). Turbulent flows. Cambridge, UK: Cambridge Univ. Press DOI:10.1017/CBO9780511840531
system/controlDict.functions
: turbulenceFields1 { // Mandatory entries (unmodifiable) type turbulenceFields; libs (fieldFunctionObjects); // Mandatory entries (runtime modifiable) // Either of the below // Option-1 fields (R devRhoReff); // Option-2 field R; // Optional entries (runtime modifiable) prefix <word>; // Inherited entries ... }
where the entries mean:
Property | Description | Type | Reqd | Deflt |
---|---|---|---|---|
type | Type name: turbulenceFields | word | yes | - |
libs | Library name: fieldFunctionObjects | word | yes | - |
fields | Names of fields to store (see below) | wordList | yes | - |
field | Name of a field to store (see below) | word | yes | - |
prefix | Name of output-field prefix | word | no | turbulenceProperties |
where fields
can include:
k | turbulent kinetic energy epsilon | turbulent kinetic energy dissipation rate omega | specific dissipation rate nuTilda | modified turbulent viscosity nut | turbulent viscosity (incompressible) nuEff | effective turbulent viscosity (incompressible) mut | turbulent viscosity (compressible) muEff | effective turbulent viscosity (compressible) alphat | turbulence thermal diffusivity (compressible) alphaEff | effective turbulence thermal diffusivity (compressible) R | Reynolds stress tensor devReff | deviatoric part of the effective Reynolds stress devRhoReff | divergence of the Reynolds stress L | integral-length scale / mixing-length scale I | turbulence intensity
The inherited entries are elaborated in:
Minimal example by using the postProcess
utility:
<solver> -postProcess -func turbulenceFields
nuTilda
is an approximation based on a dimensional analysis.Definition at line 210 of file turbulenceFields.H.
enum compressibleField |
Definition at line 219 of file turbulenceFields.H.
enum incompressibleField |
Definition at line 239 of file turbulenceFields.H.
turbulenceFields | ( | const word & | name, |
const Time & | runTime, | ||
const dictionary & | dict | ||
) |
Definition at line 129 of file turbulenceFields.C.
References dict, and Foam::read().
|
delete |
|
virtualdefault |
|
protected |
Definition at line 86 of file turbulenceFields.C.
References Foam::endl(), f(), turbulenceFields::fieldSet_, objectRegistry::found(), turbulenceFields::initialised_, Foam::nl, regionFunctionObject::obr_, turbulenceFields::prefix_, IOobject::scopedName(), HashSet::unset(), and WarningInFunction.
|
protected |
Definition at line 107 of file turbulenceFields.C.
References Foam::exit(), Foam::FatalError, and FatalErrorInFunction.
|
protected |
Definition at line 28 of file turbulenceFieldsTemplates.C.
|
protected |
|
protected |
|
protected |
TypeName | ( | "turbulenceFields" | ) |
|
delete |
|
virtual |
Reimplemented from regionFunctionObject.
Definition at line 146 of file turbulenceFields.C.
References dict, Foam::endl(), f(), Foam::Info, Foam::name(), Foam::nl, regionFunctionObject::read(), IOobject::scopedName(), and Foam::type().
|
virtual |
Implements functionObject.
Definition at line 185 of file turbulenceFields.C.
References Foam::abort(), compressible, f(), Foam::FatalError, FatalErrorInFunction, Foam::I, and L().
|
virtual |
Implements functionObject.
Definition at line 343 of file turbulenceFields.C.
References Foam::endl(), f(), Foam::Info, and IOobject::scopedName().
Foam::tmp<Foam::volScalarField> nuTilda | ( | const Model & | model | ) | const |
Definition at line 67 of file turbulenceFieldsTemplates.C.
References Foam::dimless, Foam::dimTime, and Foam::New().
Foam::tmp<Foam::volScalarField> L | ( | const Model & | model | ) | const |
Definition at line 84 of file turbulenceFieldsTemplates.C.
References Foam::dimTime, Foam::dimVelocity, Foam::New(), Foam::pow(), and Foam::sqr().
Foam::tmp<Foam::volScalarField> I | ( | const Model & | model | ) | const |
Definition at line 103 of file turbulenceFieldsTemplates.C.
References Foam::dimVelocity, Foam::mag(), Foam::max(), Foam::New(), and Foam::sqrt().
|
static |
Definition at line 236 of file turbulenceFields.H.
|
static |
Definition at line 254 of file turbulenceFields.H.
|
static |
Definition at line 257 of file turbulenceFields.H.
|
protected |
Definition at line 265 of file turbulenceFields.H.
Referenced by turbulenceFields::initialise().
|
protected |
Definition at line 268 of file turbulenceFields.H.
Referenced by turbulenceFields::initialise().
|
protected |
Definition at line 271 of file turbulenceFields.H.
Referenced by turbulenceFields::initialise().
Copyright © 2011-2018 OpenFOAM | OPENFOAM® is a registered trademark of OpenCFD Ltd.