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

This boundary condition provides a jump condition, using the cyclic condition as a base. More...

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

Public Member Functions

 TypeName ("porousBafflePressure")
 Runtime type information. More...
 
 porousBafflePressureFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &)
 Construct from patch and internal field. More...
 
 porousBafflePressureFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &, const dictionary &)
 Construct from patch, internal field and dictionary. More...
 
 porousBafflePressureFvPatchField (const porousBafflePressureFvPatchField &, const fvPatch &, const DimensionedField< scalar, volMesh > &, const fvPatchFieldMapper &)
 Construct by mapping given porousBafflePressureFvPatchField. More...
 
 porousBafflePressureFvPatchField (const porousBafflePressureFvPatchField &)
 Construct as copy. More...
 
virtual tmp< fvPatchField< scalar > > clone () const
 Construct and return a clone. More...
 
 porousBafflePressureFvPatchField (const porousBafflePressureFvPatchField &, const DimensionedField< scalar, volMesh > &)
 Construct as copy setting internal field reference. More...
 
virtual tmp< fvPatchField< scalar > > clone (const DimensionedField< scalar, volMesh > &iF) const
 Construct and return a clone setting internal field reference. More...
 
virtual void updateCoeffs ()
 Update the coefficients associated with the patch field. More...
 
virtual void write (Ostream &) const
 Write. More...
 
- Public Member Functions inherited from fixedJumpFvPatchField< scalar >
 TypeName ("fixedJump")
 Runtime type information. More...
 
 fixedJumpFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &)
 Construct from patch and internal field. More...
 
 fixedJumpFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &, const dictionary &)
 Construct from patch, internal field and dictionary. More...
 
 fixedJumpFvPatchField (const fixedJumpFvPatchField< scalar > &, const fvPatch &, const DimensionedField< scalar, volMesh > &, const fvPatchFieldMapper &)
 Construct by mapping given fixedJumpFvPatchField onto a. More...
 
 fixedJumpFvPatchField (const fixedJumpFvPatchField< scalar > &)
 Construct as copy. More...
 
 fixedJumpFvPatchField (const fixedJumpFvPatchField< scalar > &, const DimensionedField< scalar, volMesh > &)
 Construct as copy setting internal field reference. More...
 
virtual tmp< fvPatchField< scalar > > clone () const
 Construct and return a clone. More...
 
virtual tmp< Field< scalar > > jump () const
 Return the "jump" across the patch. More...
 
virtual void autoMap (const fvPatchFieldMapper &)
 Map (and resize as needed) from self given a mapping object. More...
 
virtual void rmap (const fvPatchField< scalar > &, const labelList &)
 Reverse map the given fvPatchField onto this fvPatchField. More...
 
- Public Member Functions inherited from jumpCyclicFvPatchField< scalar >
 TypeName ("jumpCyclic")
 Runtime type information. More...
 
 jumpCyclicFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &)
 Construct from patch and internal field. More...
 
 jumpCyclicFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &, const dictionary &)
 Construct from patch, internal field and dictionary. More...
 
 jumpCyclicFvPatchField (const jumpCyclicFvPatchField< scalar > &, const fvPatch &, const DimensionedField< scalar, volMesh > &, const fvPatchFieldMapper &)
 Construct by mapping given jumpCyclicFvPatchField onto a new patch. More...
 
 jumpCyclicFvPatchField (const jumpCyclicFvPatchField< scalar > &)
 Construct as copy. More...
 
 jumpCyclicFvPatchField (const jumpCyclicFvPatchField< scalar > &, const DimensionedField< scalar, volMesh > &)
 Construct as copy setting internal field reference. More...
 
virtual const wordinterfaceFieldType () const
 Return the interface type. More...
 
tmp< Field< scalar > > patchNeighbourField () const
 Return neighbour coupled given internal cell data. More...
 
virtual void updateInterfaceMatrix (scalarField &result, const scalarField &psiInternal, const scalarField &coeffs, const direction cmpt, const Pstream::commsTypes commsType) const
 Update result field based on interface functionality. More...
 
virtual void updateInterfaceMatrix (Field< scalar > &, const Field< scalar > &, const scalarField &, const Pstream::commsTypes commsType) const
 Update result field based on interface functionality. More...
 
void updateInterfaceMatrix (scalarField &result, const scalarField &psiInternal, const scalarField &coeffs, const direction cmpt, const Pstream::commsTypes commsType) const
 Update result field based on interface functionality. More...
 
void updateInterfaceMatrix (scalarField &result, const scalarField &psiInternal, const scalarField &coeffs, const direction cmpt, const Pstream::commsTypes) const
 Update result field based on interface functionality. More...
 
- Public Member Functions inherited from cyclicFvPatchField< scalar >
 TypeName (cyclicFvPatch::typeName_())
 Runtime type information. More...
 
 cyclicFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &)
 Construct from patch and internal field. More...
 
 cyclicFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &, const dictionary &)
 Construct from patch, internal field and dictionary. More...
 
 cyclicFvPatchField (const cyclicFvPatchField< scalar > &, const fvPatch &, const DimensionedField< scalar, volMesh > &, const fvPatchFieldMapper &)
 Construct by mapping given cyclicFvPatchField onto a new patch. More...
 
 cyclicFvPatchField (const cyclicFvPatchField< scalar > &)
 Construct as copy. More...
 
 cyclicFvPatchField (const cyclicFvPatchField< scalar > &, const DimensionedField< scalar, volMesh > &)
 Construct as copy setting internal field reference. More...
 
const cyclicFvPatchcyclicPatch () const
 Return local reference cast into the cyclic patch. More...
 
const cyclicFvPatchField< scalar > & neighbourPatchField () const
 Return reference to neighbour patchField. More...
 
virtual bool doTransform () const
 Does the patch field perform the transformation. More...
 
virtual const tensorFieldforwardT () const
 Return face transformation tensor. More...
 
virtual const tensorFieldreverseT () const
 Return neighbour-cell transformation tensor. More...
 
virtual int rank () const
 Return rank of component for transform. More...
 
- Public Member Functions inherited from cyclicLduInterfaceField
 TypeName ("cyclicLduInterfaceField")
 Runtime type information. More...
 
 cyclicLduInterfaceField ()
 Construct given coupled patch. More...
 
virtual ~cyclicLduInterfaceField ()
 Destructor. More...
 
virtual bool doTransform () const =0
 Is the transform required. More...
 
virtual const tensorFieldforwardT () const =0
 Return face transformation tensor. More...
 
virtual const tensorFieldreverseT () const =0
 Return neighbour-cell transformation tensor. More...
 
virtual int rank () const =0
 Return rank of component for transform. More...
 
template<class Type >
void transformCoupleField (Field< Type > &f) const
 Transform given patch field. More...
 
void transformCoupleField (scalarField &f, const direction cmpt) const
 Transform given patch component field. More...
 
- Public Member Functions inherited from coupledFvPatchField< scalar >
 TypeName (coupledFvPatch::typeName_())
 Runtime type information. More...
 
 coupledFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &)
 Construct from patch and internal field. More...
 
 coupledFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &, const Field< scalar > &)
 Construct from patch and internal field and patch field. More...
 
 coupledFvPatchField (const fvPatch &, const DimensionedField< scalar, volMesh > &, const dictionary &)
 Construct from patch, internal field and dictionary. More...
 
 coupledFvPatchField (const coupledFvPatchField< scalar > &, const fvPatch &, const DimensionedField< scalar, volMesh > &, const fvPatchFieldMapper &)
 Construct by mapping the given coupledFvPatchField onto a new patch. More...
 
 coupledFvPatchField (const coupledFvPatchField< scalar > &)
 Construct as copy. More...
 
 coupledFvPatchField (const coupledFvPatchField< scalar > &, const DimensionedField< scalar, volMesh > &)
 Construct as copy setting internal field reference. More...
 
virtual bool coupled () const
 Return true if this patch field is derived from. More...
 
virtual tmp< Field< scalar > > snGrad (const scalarField &deltaCoeffs) const
 Return patch-normal gradient. More...
 
virtual tmp< Field< scalar > > snGrad () const
 Return patch-normal gradient. More...
 
virtual void initEvaluate (const Pstream::commsTypes commsType)
 Initialise the evaluation of the patch field. More...
 
virtual void evaluate (const Pstream::commsTypes commsType)
 Evaluate the patch field. More...
 
virtual tmp< Field< scalar > > valueInternalCoeffs (const tmp< scalarField > &) const
 Return the matrix diagonal coefficients corresponding to the. More...
 
virtual tmp< Field< scalar > > valueBoundaryCoeffs (const tmp< scalarField > &) const
 Return the matrix source coefficients corresponding to the. More...
 
virtual tmp< Field< scalar > > gradientInternalCoeffs (const scalarField &deltaCoeffs) const
 Return the matrix diagonal coefficients corresponding to the. More...
 
virtual tmp< Field< scalar > > gradientInternalCoeffs () const
 Return the matrix diagonal coefficients corresponding to the. More...
 
virtual tmp< Field< scalar > > gradientBoundaryCoeffs (const scalarField &deltaCoeffs) const
 Return the matrix source coefficients corresponding to the. More...
 
virtual tmp< Field< scalar > > gradientBoundaryCoeffs () const
 Return the matrix source coefficients corresponding to the. More...
 
- Public Member Functions inherited from LduInterfaceField< scalar >
 LduInterfaceField (const lduInterface &patch)
 Construct given coupled patch. More...
 
 TypeName ("LduInterfaceField")
 Runtime type information. More...
 
virtual ~LduInterfaceField ()
 Destructor. More...
 
virtual void initInterfaceMatrixUpdate (Field< scalar > &, const Field< scalar > &, const scalarField &, const Pstream::commsTypes commsType) const
 Initialise neighbour matrix update. More...
 
virtual void initInterfaceMatrixUpdate (scalarField &, const scalarField &, const scalarField &, const direction, const Pstream::commsTypes commsType) const
 Inherit initInterfaceMatrixUpdate from lduInterfaceField. More...
 
virtual void updateInterfaceMatrix (scalarField &, const scalarField &, const scalarField &, const direction, const Pstream::commsTypes commsType) const =0
 Inherit updateInterfaceMatrix from lduInterfaceField. More...
 
- Public Member Functions inherited from lduInterfaceField
 TypeName ("lduInterfaceField")
 Runtime type information. More...
 
 lduInterfaceField (const lduInterface &patch)
 Construct given coupled patch. More...
 
virtual ~lduInterfaceField ()
 Destructor. More...
 
const lduInterfaceinterface () const
 Return the interface. More...
 
virtual const wordinterfaceFieldType () const
 Return the interface type. More...
 
bool updatedMatrix () const
 Whether matrix has been updated. More...
 
bool & updatedMatrix ()
 Whether matrix has been updated. More...
 
virtual bool ready () const
 Is all data available. More...
 
virtual void initInterfaceMatrixUpdate (scalarField &, const scalarField &, const scalarField &, const direction, const Pstream::commsTypes commsType) const
 Initialise neighbour matrix update. More...
 
- Public Member Functions inherited from fvPatchField< scalar >
 TypeName ("fvPatchField")
 Runtime type information. More...
 
 declareRunTimeSelectionTable (tmp, fvPatchField, patch,(const fvPatch &p, const DimensionedField< Type, volMesh > &iF),(p, iF))
 
 declareRunTimeSelectionTable (tmp, fvPatchField, patchMapper,(const fvPatchField< Type > &ptf, const fvPatch &p, const DimensionedField< Type, volMesh > &iF, const fvPatchFieldMapper &m),(dynamic_cast< const fvPatchFieldType & >(ptf), p, iF, m))
 
 declareRunTimeSelectionTable (tmp, fvPatchField, dictionary,(const fvPatch &p, const DimensionedField< Type, volMesh > &iF, const dictionary &dict),(p, iF, dict))
 
 fvPatchField (const fvPatch &, const DimensionedField< Type, volMesh > &)
 Construct from patch and internal field. More...
 
 fvPatchField (const fvPatch &, const DimensionedField< Type, volMesh > &, const word &patchType)
 Construct from patch and internal field and patch type. More...
 
 fvPatchField (const fvPatch &, const DimensionedField< Type, volMesh > &, const Field< Type > &)
 Construct from patch and internal field and patch field. More...
 
 fvPatchField (const fvPatch &, const DimensionedField< Type, volMesh > &, const dictionary &, const bool valueRequired=false)
 Construct from patch, internal field and dictionary. More...
 
 fvPatchField (const fvPatchField< Type > &, const fvPatch &, const DimensionedField< Type, volMesh > &, const fvPatchFieldMapper &)
 Construct by mapping the given fvPatchField onto a new patch. More...
 
 fvPatchField (const fvPatchField< Type > &)
 Construct as copy. More...
 
 fvPatchField (const fvPatchField< Type > &, const DimensionedField< Type, volMesh > &)
 Construct as copy setting internal field reference. More...
 
virtual tmp< fvPatchField< Type > > clone (const DimensionedField< Type, volMesh > &iF) const
 Construct and return a clone setting internal field reference. More...
 
Foam::tmp< Foam::fvPatchField< Type > > NewCalculatedType (const fvPatch &p)
 
Foam::tmp< Foam::fvPatchField< Type > > NewCalculatedType (const fvPatchField< Type2 > &pf)
 
virtual ~fvPatchField ()
 Destructor. More...
 
const objectRegistrydb () const
 Return local objectRegistry. More...
 
const fvPatchpatch () const
 Return patch. More...
 
const DimensionedField< Type, volMesh > & dimensionedInternalField () const
 Return dimensioned internal field reference. More...
 
const Field< Type > & internalField () const
 Return internal field reference. More...
 
const wordpatchType () const
 Optional patch type. More...
 
wordpatchType ()
 Optional patch type. More...
 
virtual bool fixesValue () const
 Return true if this patch field fixes a value. More...
 
bool updated () const
 Return true if the boundary condition has already been updated. More...
 
bool manipulatedMatrix () const
 Return true if the matrix has already been manipulated. More...
 
virtual void rmap (const fvPatchField< Type > &, const labelList &)
 Reverse map the given fvPatchField onto this fvPatchField. More...
 
virtual void updateCoeffs (const scalarField &weights)
 Update the coefficients associated with the patch field. More...
 
virtual tmp< Field< Type > > patchInternalField () const
 Return internal field next to patch as patch field. More...
 
virtual void patchInternalField (Field< Type > &) const
 Return internal field next to patch as patch field. More...
 
virtual void manipulateMatrix (fvMatrix< Type > &matrix)
 Manipulate matrix. More...
 
virtual void manipulateMatrix (fvMatrix< Type > &matrix, const scalarField &weights)
 Manipulate matrix with given weights. More...
 
void writeEntryIfDifferent (Ostream &os, const word &entryName, const EntryType &value1, const EntryType &value2) const
 Helper function to write the keyword and entry only if the. More...
 
void check (const fvPatchField< Type > &) const
 Check fvPatchField<Type> against given fvPatchField<Type> More...
 
virtual void operator= (const UList< Type > &)
 
virtual void operator= (const fvPatchField< Type > &)
 
virtual void operator= (const Type &)
 
virtual void operator+= (const fvPatchField< Type > &)
 
virtual void operator+= (const Field< Type > &)
 
virtual void operator+= (const Type &)
 
virtual void operator-= (const fvPatchField< Type > &)
 
virtual void operator-= (const Field< Type > &)
 
virtual void operator-= (const Type &)
 
virtual void operator*= (const fvPatchField< scalar > &)
 
virtual void operator*= (const Field< scalar > &)
 
virtual void operator*= (const scalar)
 
virtual void operator/= (const fvPatchField< scalar > &)
 
virtual void operator/= (const Field< scalar > &)
 
virtual void operator/= (const scalar)
 
virtual void operator== (const fvPatchField< Type > &)
 
virtual void operator== (const Field< Type > &)
 
virtual void operator== (const Type &)
 

Private Attributes

const word phiName_
 Name of flux field (default = phi) More...
 
const word rhoName_
 Name of density field (default = rho) More...
 
autoPtr< DataEntry< scalar > > D_
 Darcy pressure loss coefficient. More...
 
autoPtr< DataEntry< scalar > > I_
 Inertia pressure lost coefficient. More...
 
scalar length_
 Porous media length. More...
 
bool uniformJump_
 Aplies uniform pressure drop. More...
 

Additional Inherited Members

- Public Types inherited from fvPatchField< scalar >
typedef fvPatch Patch
 
- Static Public Member Functions inherited from fvPatchField< scalar >
static tmp< fvPatchField< Type > > New (const word &, const fvPatch &, const DimensionedField< Type, volMesh > &)
 Return a pointer to a new patchField created on freestore given. More...
 
static tmp< fvPatchField< Type > > New (const word &, const word &actualPatchType, const fvPatch &, const DimensionedField< Type, volMesh > &)
 Return a pointer to a new patchField created on freestore given. More...
 
static tmp< fvPatchField< Type > > New (const fvPatchField< Type > &, const fvPatch &, const DimensionedField< Type, volMesh > &, const fvPatchFieldMapper &)
 Return a pointer to a new patchField created on freestore from. More...
 
static tmp< fvPatchField< Type > > New (const fvPatch &, const DimensionedField< Type, volMesh > &, const dictionary &)
 Return a pointer to a new patchField created on freestore. More...
 
static tmp< fvPatchField< Type > > NewCalculatedType (const fvPatch &)
 Return a pointer to a new calculatedFvPatchField created on. More...
 
static tmp< fvPatchField< Type > > NewCalculatedType (const fvPatchField< Type2 > &)
 Return a pointer to a new calculatedFvPatchField created on. More...
 
static const wordcalculatedType ()
 Return the type of the calculated for of fvPatchField. More...
 
- Static Public Attributes inherited from fvPatchField< scalar >
static int disallowGenericFvPatchField
 Debug switch to disallow the use of genericFvPatchField. More...
 
- Protected Attributes inherited from fixedJumpFvPatchField< scalar >
Field< scalar > jump_
 "jump" field More...
 

Detailed Description

template<class Type>
class Foam::porousBafflePressureFvPatchField< Type >

This boundary condition provides a jump condition, using the cyclic condition as a base.

The porous baffle introduces a pressure jump defined by:

\[ \Delta p = -(D \mu U + 0.5 I \rho |U|^2 )L \]

where

$ p $ = pressure [Pa]
$ \rho $ = density [kg/m3]
$ \mu $ = laminar viscosity [Pa s]
$ D $ = Darcy coefficient
$ I $ = inertial coefficient
$ L $ = porous media length in the flow direction


Patch usage

Property Description Required Default value
patchType underlying patch type should be cyclic yes
phi flux field name no phi
rho density field name no rho
D Darcy coefficient yes
I inertial coefficient yes
length porous media length in the flow direction yes
uniformJump applies a uniform pressure drop on the patch based on the

Example of the boundary condition specification:

    myPatch
    {
        type            porousBafflePressure;
        patchType       cyclic;
        jump            uniform 0;
        D               0.001;
        I               1000000;
        length          0.1;
        uniformJump     false;
        value           uniform 0;
    }
Note
The underlying patchType should be set to cyclic
Source files

Definition at line 164 of file porousBafflePressureFvPatchField.H.

Constructor & Destructor Documentation

◆ porousBafflePressureFvPatchField() [1/5]

porousBafflePressureFvPatchField ( const fvPatch p,
const DimensionedField< scalar, volMesh > &  iF 
)

Construct from patch and internal field.

Definition at line 34 of file porousBafflePressureFvPatchField.C.

Referenced by porousBafflePressureFvPatchField< Type >::clone().

Here is the caller graph for this function:

◆ porousBafflePressureFvPatchField() [2/5]

porousBafflePressureFvPatchField ( const fvPatch p,
const DimensionedField< scalar, volMesh > &  iF,
const dictionary dict 
)

Construct from patch, internal field and dictionary.

Definition at line 50 of file porousBafflePressureFvPatchField.C.

References dict, and p.

◆ porousBafflePressureFvPatchField() [3/5]

porousBafflePressureFvPatchField ( const porousBafflePressureFvPatchField< Type > &  ptf,
const fvPatch p,
const DimensionedField< scalar, volMesh > &  iF,
const fvPatchFieldMapper mapper 
)

Construct by mapping given porousBafflePressureFvPatchField.

onto a new patch

Definition at line 72 of file porousBafflePressureFvPatchField.C.

◆ porousBafflePressureFvPatchField() [4/5]

Construct as copy.

Definition at line 90 of file porousBafflePressureFvPatchField.C.

◆ porousBafflePressureFvPatchField() [5/5]

porousBafflePressureFvPatchField ( const porousBafflePressureFvPatchField< Type > &  ptf,
const DimensionedField< scalar, volMesh > &  iF 
)

Construct as copy setting internal field reference.

Definition at line 106 of file porousBafflePressureFvPatchField.C.

Member Function Documentation

◆ TypeName()

TypeName ( "porousBafflePressure"  )

Runtime type information.

◆ clone() [1/2]

virtual tmp<fvPatchField<scalar> > clone ( ) const
inlinevirtual

Construct and return a clone.

Definition at line 229 of file porousBafflePressureFvPatchField.H.

References porousBafflePressureFvPatchField< Type >::porousBafflePressureFvPatchField().

Here is the call graph for this function:

◆ clone() [2/2]

virtual tmp<fvPatchField<scalar> > clone ( const DimensionedField< scalar, volMesh > &  iF) const
inlinevirtual

Construct and return a clone setting internal field reference.

Reimplemented from fixedJumpFvPatchField< scalar >.

Definition at line 246 of file porousBafflePressureFvPatchField.H.

References porousBafflePressureFvPatchField< Type >::porousBafflePressureFvPatchField().

Here is the call graph for this function:

◆ updateCoeffs()

void updateCoeffs ( )
virtual

◆ write()

void write ( Ostream os) const
virtual

Write.

Reimplemented from fixedJumpFvPatchField< scalar >.

Definition at line 190 of file porousBafflePressureFvPatchField.C.

References token::END_STATEMENT, Foam::nl, fixedJumpFvPatchField< Type >::write(), and Ostream::writeKeyword().

Here is the call graph for this function:

Field Documentation

◆ phiName_

const word phiName_
private

Name of flux field (default = phi)

Definition at line 171 of file porousBafflePressureFvPatchField.H.

Referenced by porousBafflePressureFvPatchField< Type >::updateCoeffs().

◆ rhoName_

const word rhoName_
private

Name of density field (default = rho)

Definition at line 174 of file porousBafflePressureFvPatchField.H.

Referenced by porousBafflePressureFvPatchField< Type >::updateCoeffs().

◆ D_

autoPtr<DataEntry<scalar> > D_
private

Darcy pressure loss coefficient.

Definition at line 177 of file porousBafflePressureFvPatchField.H.

Referenced by porousBafflePressureFvPatchField< Type >::updateCoeffs().

◆ I_

autoPtr<DataEntry<scalar> > I_
private

Inertia pressure lost coefficient.

Definition at line 180 of file porousBafflePressureFvPatchField.H.

Referenced by porousBafflePressureFvPatchField< Type >::updateCoeffs().

◆ length_

scalar length_
private

Porous media length.

Definition at line 183 of file porousBafflePressureFvPatchField.H.

Referenced by porousBafflePressureFvPatchField< Type >::updateCoeffs().

◆ uniformJump_

bool uniformJump_
private

Aplies uniform pressure drop.

Definition at line 186 of file porousBafflePressureFvPatchField.H.

Referenced by porousBafflePressureFvPatchField< Type >::updateCoeffs().


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