/*---------------------------------------------------------------------------*\ ========= | \\ / F ield | OpenFOAM: The Open Source CFD Toolbox \\ / O peration | \\ / A nd | Copyright (C) 2012-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 . Class Foam::RASModels::v2WallFunctionFvPatchScalarField Group grpWallFunctions Description This boundary condition provides a turbulence stress normal to streamlines wall function condition for low- and high-Reynolds number, turbulent flow cases. The model operates in two modes, based on the computed laminar-to-turbulent switch-over y+ value derived from kappa and E. Usage \table Property | Description | Required | Default value Cmu | model coefficient | no | 0.09 kappa | Von Karman constant | no | 0.41 E | model coefficient | no | 9.8 \endtable Example of the boundary condition specification: \verbatim myPatch { type v2WallFunction; } \endverbatim SeeAlso Foam::fixedValueFvPatchField SourceFiles v2WallFunctionFvPatchScalarField.C \*---------------------------------------------------------------------------*/ #ifndef v2WallFunctionFvPatchScalarField_H #define v2WallFunctionFvPatchScalarField_H #include "fixedValueFvPatchField.H" // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // namespace Foam { namespace RASModels { /*---------------------------------------------------------------------------*\ Class v2WallFunctionFvPatchScalarField Declaration \*---------------------------------------------------------------------------*/ class v2WallFunctionFvPatchScalarField : public fixedValueFvPatchField { protected: // Protected data //- Cmu coefficient scalar Cmu_; //- Von Karman constant scalar kappa_; //- E coefficient scalar E_; //- Y+ at the edge of the laminar sublayer scalar yPlusLam_; // Protected Member Functions //- Check the type of the patch virtual void checkType(); //- Write local wall function variables virtual void writeLocalEntries(Ostream&) const; //- Calculate the Y+ at the edge of the laminar sublayer scalar yPlusLam(const scalar kappa, const scalar E); public: //- Runtime type information TypeName("v2WallFunction"); // Constructors //- Construct from patch and internal field v2WallFunctionFvPatchScalarField ( const fvPatch&, const DimensionedField& ); //- Construct from patch, internal field and dictionary v2WallFunctionFvPatchScalarField ( const fvPatch&, const DimensionedField&, const dictionary& ); //- Construct by mapping given v2WallFunctionFvPatchScalarField // onto a new patch v2WallFunctionFvPatchScalarField ( const v2WallFunctionFvPatchScalarField&, const fvPatch&, const DimensionedField&, const fvPatchFieldMapper& ); //- Construct as copy v2WallFunctionFvPatchScalarField ( const v2WallFunctionFvPatchScalarField& ); //- Construct and return a clone virtual tmp clone() const { return tmp ( new v2WallFunctionFvPatchScalarField(*this) ); } //- Construct as copy setting internal field reference v2WallFunctionFvPatchScalarField ( const v2WallFunctionFvPatchScalarField&, const DimensionedField& ); //- Construct and return a clone setting internal field reference virtual tmp clone ( const DimensionedField& iF ) const { return tmp ( new v2WallFunctionFvPatchScalarField(*this, iF) ); } // Member functions // Evaluation functions //- Update the coefficients associated with the patch field virtual void updateCoeffs(); //- Evaluate the patchField virtual void evaluate(const Pstream::commsTypes); // I-O //- Write virtual void write(Ostream&) const; }; // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // } // End namespace RASModels } // End namespace Foam // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // #endif // ************************************************************************* //