Two-scheme cell-based Courant number based blending differencing scheme. More...
Public Member Functions | |
TypeName ("cellCoBlended") | |
Runtime type information. More... | |
cellCoBlended (const fvMesh &mesh, Istream &is) | |
Construct from mesh and Istream. More... | |
cellCoBlended (const fvMesh &mesh, const surfaceScalarField &faceFlux, Istream &is) | |
Construct from mesh, faceFlux and Istream. More... | |
virtual tmp< surfaceScalarField > | blendingFactor (const GeometricField< Type, fvPatchField, volMesh > &vf) const |
Return the face-based blending factor. More... | |
tmp< surfaceScalarField > | weights (const GeometricField< Type, fvPatchField, volMesh > &vf) const |
Return the interpolation weighting factors. More... | |
tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > | interpolate (const GeometricField< Type, fvPatchField, volMesh > &vf) const |
Return the face-interpolate of the given cell field. More... | |
virtual bool | corrected () const |
Return true if this scheme uses an explicit correction. More... | |
virtual tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > | correction (const GeometricField< Type, fvPatchField, volMesh > &vf) const |
Return the explicit correction to the face-interpolate. More... | |
![]() | |
TypeName ("surfaceInterpolationScheme") | |
Runtime type information. More... | |
declareRunTimeSelectionTable (tmp, surfaceInterpolationScheme, Mesh,(const fvMesh &mesh, Istream &schemeData),(mesh, schemeData)) | |
declareRunTimeSelectionTable (tmp, surfaceInterpolationScheme, MeshFlux,(const fvMesh &mesh, const surfaceScalarField &faceFlux, Istream &schemeData),(mesh, faceFlux, schemeData)) | |
surfaceInterpolationScheme (const fvMesh &mesh) | |
Construct from mesh. More... | |
virtual | ~surfaceInterpolationScheme () |
Destructor. More... | |
const fvMesh & | mesh () const |
Return mesh reference. More... | |
tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > | interpolate (const tmp< GeometricField< Type, fvPatchField, volMesh > > &) const |
Return the face-interpolate of the given tmp cell field. More... | |
![]() | |
refCount () | |
Construct null with zero count. More... | |
int | count () const |
Return the reference count. More... | |
bool | okToDelete () const |
Return true if the reference count is zero. More... | |
void | resetRefCount () |
Reset the reference count to zero. More... | |
void | operator++ () |
Increment the reference count. More... | |
void | operator++ (int) |
Increment the reference count. More... | |
void | operator-- () |
Decrement the reference count. More... | |
void | operator-- (int) |
Decrement the reference count. More... | |
![]() | |
blendedSchemeBase () | |
Constructor. More... | |
virtual | ~blendedSchemeBase () |
Destructor. More... | |
Private Member Functions | |
cellCoBlended (const cellCoBlended &) | |
Disallow default bitwise copy construct. More... | |
void | operator= (const cellCoBlended &) |
Disallow default bitwise assignment. More... | |
Private Attributes | |
const scalar | Co1_ |
Courant number below which scheme1 is used. More... | |
tmp< surfaceInterpolationScheme< Type > > | tScheme1_ |
Scheme 1. More... | |
const scalar | Co2_ |
Courant number above which scheme2 is used. More... | |
tmp< surfaceInterpolationScheme< Type > > | tScheme2_ |
Scheme 2. More... | |
const surfaceScalarField & | faceFlux_ |
The face-flux used to compute the face Courant number. More... | |
Additional Inherited Members | |
![]() | |
static tmp< surfaceInterpolationScheme< Type > > | New (const fvMesh &mesh, Istream &schemeData) |
Return new tmp interpolation scheme. More... | |
static tmp< surfaceInterpolationScheme< Type > > | New (const fvMesh &mesh, const surfaceScalarField &faceFlux, Istream &schemeData) |
Return new tmp interpolation scheme. More... | |
static tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > | interpolate (const GeometricField< Type, fvPatchField, volMesh > &, const tmp< surfaceScalarField > &, const tmp< surfaceScalarField > &) |
Return the face-interpolate of the given cell field. More... | |
static tmp< GeometricField< Type, fvsPatchField, surfaceMesh > > | interpolate (const GeometricField< Type, fvPatchField, volMesh > &, const tmp< surfaceScalarField > &) |
Return the face-interpolate of the given cell field. More... | |
Two-scheme cell-based Courant number based blending differencing scheme.
This scheme is equivalent to the CoBlended scheme except that the Courant number is evaluated for cells using the same approach as use in the finite-volume solvers and then interpolated to the faces rather than being estimated directly at the faces based on the flux. This is a more consistent method for evaluating the Courant number but suffers from the need to interpolate which introduces a degree of freedom. However, the interpolation scheme for "Co" is run-time selected and may be specified in "interpolationSchemes" and "localMax" might be most appropriate.
Example of the cellCoBlended scheme specification using LUST for Courant numbers less than 1 and linearUpwind for Courant numbers greater than 10:
divSchemes { . . div(phi,U) Gauss cellCoBlended 1 LUST grad(U) 10 linearUpwind grad(U); . . } interpolationSchemes { . . interpolate(Co) localMax; . . }
Definition at line 88 of file cellCoBlended.H.
|
private |
Disallow default bitwise copy construct.
|
inline |
Construct from mesh and Istream.
The name of the flux field is read from the Istream and looked-up from the mesh objectRegistry
Definition at line 132 of file cellCoBlended.H.
References cellCoBlended< Type >::Co1_, cellCoBlended< Type >::Co2_, Foam::exit(), Foam::FatalIOError, and FatalIOErrorInFunction.
|
inline |
Construct from mesh, faceFlux and Istream.
Definition at line 165 of file cellCoBlended.H.
References cellCoBlended< Type >::Co1_, cellCoBlended< Type >::Co2_, Foam::exit(), Foam::FatalIOError, and FatalIOErrorInFunction.
|
private |
Disallow default bitwise assignment.
TypeName | ( | "cellCoBlended< Type >" | ) |
Runtime type information.
|
inlinevirtual |
Return the face-based blending factor.
Implements blendedSchemeBase< Type >.
Definition at line 198 of file cellCoBlended.H.
References cellCoBlended< Type >::Co1_, cellCoBlended< Type >::Co2_, GeometricField::correctBoundaryConditions(), TimeState::deltaTValue(), Foam::dimArea, Foam::dimDensity, Foam::dimless, Foam::dimVelocity, Foam::exit(), cellCoBlended< Type >::faceFlux_, Foam::FatalError, FatalErrorInFunction, internalField(), GeometricField::internalField(), Foam::fvc::interpolate(), Foam::mag(), Foam::max(), surfaceInterpolationScheme< Type >::mesh(), Foam::min(), rho, Foam::fvc::surfaceSum(), fvMesh::time(), Time::timeName(), and fvMesh::V().
Referenced by cellCoBlended< Type >::correction(), cellCoBlended< Type >::interpolate(), and cellCoBlended< Type >::weights().
|
inlinevirtual |
Return the interpolation weighting factors.
Implements surfaceInterpolationScheme< Type >.
Definition at line 267 of file cellCoBlended.H.
References cellCoBlended< Type >::blendingFactor(), cellCoBlended< Type >::tScheme1_, and cellCoBlended< Type >::tScheme2_.
|
inlinevirtual |
Return the face-interpolate of the given cell field.
with explicit correction
Reimplemented from surfaceInterpolationScheme< Type >.
Definition at line 283 of file cellCoBlended.H.
References cellCoBlended< Type >::blendingFactor(), cellCoBlended< Type >::tScheme1_, and cellCoBlended< Type >::tScheme2_.
|
inlinevirtual |
Return true if this scheme uses an explicit correction.
Reimplemented from surfaceInterpolationScheme< Type >.
Definition at line 296 of file cellCoBlended.H.
References cellCoBlended< Type >::tScheme1_, and cellCoBlended< Type >::tScheme2_.
Referenced by cellCoBlended< Type >::correction().
|
inlinevirtual |
Return the explicit correction to the face-interpolate.
for the given field
Reimplemented from surfaceInterpolationScheme< Type >.
Definition at line 306 of file cellCoBlended.H.
References cellCoBlended< Type >::blendingFactor(), cellCoBlended< Type >::corrected(), cellCoBlended< Type >::tScheme1_, and cellCoBlended< Type >::tScheme2_.
|
private |
Courant number below which scheme1 is used.
Definition at line 96 of file cellCoBlended.H.
Referenced by cellCoBlended< Type >::blendingFactor(), and cellCoBlended< Type >::cellCoBlended().
|
private |
Scheme 1.
Definition at line 99 of file cellCoBlended.H.
Referenced by cellCoBlended< Type >::corrected(), cellCoBlended< Type >::correction(), cellCoBlended< Type >::interpolate(), and cellCoBlended< Type >::weights().
|
private |
Courant number above which scheme2 is used.
Definition at line 102 of file cellCoBlended.H.
Referenced by cellCoBlended< Type >::blendingFactor(), and cellCoBlended< Type >::cellCoBlended().
|
private |
Scheme 2.
Definition at line 105 of file cellCoBlended.H.
Referenced by cellCoBlended< Type >::corrected(), cellCoBlended< Type >::correction(), cellCoBlended< Type >::interpolate(), and cellCoBlended< Type >::weights().
|
private |
The face-flux used to compute the face Courant number.
Definition at line 108 of file cellCoBlended.H.
Referenced by cellCoBlended< Type >::blendingFactor().
Copyright © 2011-2018 OpenFOAM | OPENFOAM® is a registered trademark of OpenCFD Ltd.