Public Member Functions | Private Member Functions | Private Attributes
cellCoBlended< Type > Class Template Reference

Two-scheme cell-based Courant number based blending differencing scheme. More...

Inheritance diagram for cellCoBlended< Type >:
Inheritance graph
[legend]
Collaboration diagram for cellCoBlended< Type >:
Collaboration graph
[legend]

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< surfaceScalarFieldblendingFactor (const GeometricField< Type, fvPatchField, volMesh > &vf) const
 Return the face-based blending factor. More...
 
tmp< surfaceScalarFieldweights (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...
 
- Public Member Functions inherited from surfaceInterpolationScheme< Type >
 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 fvMeshmesh () 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...
 
- Public Member Functions inherited from refCount
 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...
 
- Public Member Functions inherited from blendedSchemeBase< Type >
 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 surfaceScalarFieldfaceFlux_
 The face-flux used to compute the face Courant number. More...
 

Additional Inherited Members

- Static Public Member Functions inherited from surfaceInterpolationScheme< Type >
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...
 

Detailed Description

template<class Type>
class Foam::cellCoBlended< Type >

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;
    .
    .
}
See also
Foam::CoBlended Foam::localBlended
Source files

Definition at line 88 of file cellCoBlended.H.

Constructor & Destructor Documentation

◆ cellCoBlended() [1/3]

cellCoBlended ( const cellCoBlended< Type > &  )
private

Disallow default bitwise copy construct.

◆ cellCoBlended() [2/3]

cellCoBlended ( const fvMesh mesh,
Istream is 
)
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.

Here is the call graph for this function:

◆ cellCoBlended() [3/3]

cellCoBlended ( const fvMesh mesh,
const surfaceScalarField faceFlux,
Istream is 
)
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.

Here is the call graph for this function:

Member Function Documentation

◆ operator=()

void operator= ( const cellCoBlended< Type > &  )
private

Disallow default bitwise assignment.

◆ TypeName()

TypeName ( "cellCoBlended< Type >"  )

Runtime type information.

◆ blendingFactor()

virtual tmp<surfaceScalarField> blendingFactor ( const GeometricField< Type, fvPatchField, volMesh > &  vf) const
inlinevirtual

◆ weights()

tmp<surfaceScalarField> weights ( const GeometricField< Type, fvPatchField, volMesh > &  vf) const
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_.

Here is the call graph for this function:

◆ interpolate()

tmp<GeometricField<Type, fvsPatchField, surfaceMesh> > interpolate ( const GeometricField< Type, fvPatchField, volMesh > &  vf) const
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_.

Here is the call graph for this function:

◆ corrected()

virtual bool corrected ( ) const
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().

Here is the caller graph for this function:

◆ correction()

virtual tmp<GeometricField<Type, fvsPatchField, surfaceMesh> > correction ( const GeometricField< Type, fvPatchField, volMesh > &  vf) const
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_.

Here is the call graph for this function:

Field Documentation

◆ Co1_

const scalar Co1_
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().

◆ tScheme1_

tmp<surfaceInterpolationScheme<Type> > tScheme1_
private

◆ Co2_

const scalar Co2_
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().

◆ tScheme2_

tmp<surfaceInterpolationScheme<Type> > tScheme2_
private

◆ faceFlux_

const surfaceScalarField& faceFlux_
private

The face-flux used to compute the face Courant number.

Definition at line 108 of file cellCoBlended.H.

Referenced by cellCoBlended< Type >::blendingFactor().


The documentation for this class was generated from the following file: