Applies an explicit pressure gradient source in such a way to deflect the flow towards an specific direction (flowDir). Alternatively add an extra pressure drop in the flowDir direction using a model.
More...
#include <directionalPressureGradientExplicitSource.H>


Public Types | |
| enum | pressureDropModel { pVolumetricFlowRateTable , pConstant , pDarcyForchheimer } |
| Modes of pressure drop. More... | |
| Public Types inherited from cellSetOption | |
| enum | selectionModeType : char { smAll , smCellSet , smCellZone , smPoints , smMovingPoints , smGeometric , smCellType } |
| Enumeration for selection mode types. More... | |
Public Member Functions | |
| TypeName ("directionalPressureGradientExplicitSource") | |
| Runtime type information. | |
| directionalPressureGradientExplicitSource (const word &sourceName, const word &modelType, const dictionary &dict, const fvMesh &mesh) | |
| Construct from explicit source name and mesh. | |
| directionalPressureGradientExplicitSource (const directionalPressureGradientExplicitSource &)=delete | |
| No copy construct. | |
| void | operator= (const directionalPressureGradientExplicitSource &)=delete |
| No copy assignment. | |
| virtual | ~directionalPressureGradientExplicitSource ()=default |
| Destructor. | |
| virtual void | correct (volVectorField &U) |
| Correct the pressure gradient. | |
| virtual void | addSup (fvMatrix< vector > &eqn, const label fieldI) |
| Add explicit contribution to momentum equation. | |
| virtual void | addSup (const volScalarField &rho, fvMatrix< vector > &eqn, const label fieldI) |
| Add explicit contribution to compressible momentum equation. | |
| virtual void | constrain (fvMatrix< vector > &eqn, const label fieldI) |
| Set 1/A coefficient. | |
| virtual void | writeData (Ostream &os) const |
| Write the source properties. | |
| virtual bool | read (const dictionary &dict) |
| Read source dictionary. | |
| Public Member Functions inherited from cellSetOption | |
| TypeName ("cellSetOption") | |
| Runtime type information. | |
| cellSetOption (const word &name, const word &modelType, const dictionary &dict, const fvMesh &mesh) | |
| Construct from components. | |
| virtual | ~cellSetOption ()=default |
| Destructor. | |
| scalar | timeStart () const noexcept |
| Return const access to the time start. | |
| scalar | duration () const noexcept |
| Return const access to the duration. | |
| bool | inTimeLimits (const scalar timeValue) const |
| True if within time limits. | |
| bool | useSubMesh () const noexcept |
| True if sub-selection should be used. | |
| selectionModeType | selectionMode () const noexcept |
| Return the cell selection mode. | |
| const wordRes & | selectionNames () const noexcept |
| Return const access to the selection names (set or zone selection). | |
| const wordRe & | zoneName () const |
| Return const access to the first set/zone name. | |
| scalar | V () const noexcept |
| Return const access to the total cell volume. | |
| const labelList & | cells () const noexcept |
| Return const access to the cell selection. | |
| bool | isSelectionUpdated () const noexcept |
| Return flag for selection updates. | |
| scalar | timeStart (scalar val) noexcept |
| Adjust the time start, return the old value. | |
| scalar | duration (scalar val) noexcept |
| Adjust the duration, return the old value. | |
| virtual bool | isActive () |
| Is the source active? | |
| const word & | cellSetName () const |
| The name of the cell set/zone [as a word] for "cellSet" / "cellZone" selection modes). | |
| Public Member Functions inherited from option | |
| TypeName ("option") | |
| Runtime type information. | |
| declareRunTimeSelectionTable (autoPtr, option, dictionary,(const word &name, const word &modelType, const dictionary &dict, const fvMesh &mesh),(name, modelType, dict, mesh)) | |
| option (const word &name, const word &modelType, const dictionary &dict, const fvMesh &mesh) | |
| Construct from components. | |
| autoPtr< option > | clone () const |
| Return clone. | |
| virtual | ~option ()=default |
| Destructor. | |
| const word & | name () const noexcept |
| Return const access to the source name. | |
| const fvMesh & | mesh () const noexcept |
| Return const access to the mesh database. | |
| const dictionary & | coeffs () const noexcept |
| Return dictionary. | |
| bool | active () const noexcept |
| True if source is active. | |
| void | setApplied (const label fieldi) |
| Set the applied flag to true for field index fieldi. | |
| bool | active (const bool on) noexcept |
| Change source active flag, return previous value. | |
| virtual label | applyToField (const word &fieldName) const |
| Return index of field name if found in fieldNames list. | |
| virtual void | checkApplied () const |
| Check that the source has been applied. | |
| virtual void | addSup (fvMatrix< scalar > &eqn, const label fieldi) |
| virtual void | addSup (fvMatrix< symmTensor > &eqn, const label fieldi) |
| virtual void | addSup (fvMatrix< sphericalTensor > &eqn, const label fieldi) |
| virtual void | addSup (fvMatrix< tensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &rho, fvMatrix< scalar > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &rho, fvMatrix< symmTensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &rho, fvMatrix< sphericalTensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &rho, fvMatrix< tensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< scalar > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< vector > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< symmTensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< sphericalTensor > &eqn, const label fieldi) |
| virtual void | addSup (const volScalarField &alpha, const volScalarField &rho, fvMatrix< tensor > &eqn, const label fieldi) |
| virtual void | constrain (fvMatrix< scalar > &eqn, const label fieldi) |
| virtual void | constrain (fvMatrix< sphericalTensor > &eqn, const label fieldi) |
| virtual void | constrain (fvMatrix< symmTensor > &eqn, const label fieldi) |
| virtual void | constrain (fvMatrix< tensor > &eqn, const label fieldi) |
| virtual void | correct (volScalarField &field) |
| virtual void | correct (volTensorField &field) |
| virtual void | correct (surfaceScalarField &field) |
| virtual void | correct (surfaceVectorField &field) |
| virtual void | postProcessSens (scalarField &sensField, const word &fieldName=word::null, const word &designVariablesName=word::null) |
| virtual void | postProcessSens (vectorField &sensField, const word &fieldName=word::null, const word &designVariablesName=word::null) |
| virtual void | postProcessSens (tensorField &sensField, const word &fieldName=word::null, const word &designVariablesName=word::null) |
| virtual void | postProcessAuxSens (const volScalarField &primalField, const volScalarField &adjointField, scalarField &sensField, const word &fieldName=word::null) |
| virtual void | postProcessAuxSens (const volVectorField &primalField, const volVectorField &adjointField, scalarField &sensField, const word &fieldName=word::null) |
| virtual void | postProcessAuxSens (const volTensorField &primalField, const volTensorField &adjointField, scalarField &sensField, const word &fieldName=word::null) |
| virtual void | writeHeader (Ostream &) const |
| Write the source header information. | |
| virtual void | writeFooter (Ostream &) const |
| Write the source footer information. | |
Additional Inherited Members | |
| Static Public Member Functions inherited from option | |
| static autoPtr< option > | New (const word &name, const dictionary &dict, const fvMesh &mesh) |
| Return a reference to the selected fvOption model. | |
| Public Attributes inherited from option | |
| bool | log |
| Switch write log to Info. | |
| Static Public Attributes inherited from cellSetOption | |
| static const Enum< selectionModeType > | selectionModeTypeNames_ |
| List of selection mode type names. | |
| Protected Member Functions inherited from cellSetOption | |
| void | setSelection (const dictionary &dict) |
| Set cell selection name or points selection from dictionary input. | |
| void | setCellSelection () |
| Set the cell selection based on user input selection mode. | |
| void | setVol () |
| Recalculate the volume. | |
| Protected Member Functions inherited from option | |
| void | resetApplied () |
| Resize/reset applied flag list for all fieldNames_ entries. | |
| Protected Attributes inherited from cellSetOption | |
| selectionModeType | selectionMode_ |
| Cell selection mode. | |
| bool | updateSelection_ |
| Flag to enable dictionary-based updates of selections. | |
| scalar | timeStart_ |
| Start time of fvOption. | |
| scalar | duration_ |
| Duration of fvOption execution starting from timeStart. | |
| wordRes | selectionNames_ |
| Face selection names (for set or zone selections). | |
| List< point > | points_ |
| List of points for "points" selectionMode. | |
| PtrList< Function1< point > > | movingPoints_ |
| List of points for "movingPoints" selectionMode. | |
| dictionary | geometricSelection_ |
| Dictionary entries for "geometric" (topoSetCellSource) selection. | |
| labelList | cells_ |
| Set of cells to apply source to. | |
| scalar | V_ |
| Sum of cell volumes. | |
| Protected Attributes inherited from option | |
| const word | name_ |
| Source name. | |
| const word | modelType_ |
| Model type. | |
| const fvMesh & | mesh_ |
| Reference to the mesh database. | |
| dictionary | dict_ |
| Top level source dictionary. | |
| dictionary | coeffs_ |
| Dictionary containing source coefficients. | |
| wordList | fieldNames_ |
| Field names to apply source to - populated by derived models. | |
| List< bool > | applied_ |
| Applied flag list - corresponds to each fieldNames_ entry. | |
| bool | active_ |
| Source active flag. | |
Applies an explicit pressure gradient source in such a way to deflect the flow towards an specific direction (flowDir). Alternatively add an extra pressure drop in the flowDir direction using a model.
constant/fvOptions: directionalPressureGradientExplicitSource1
{
// Mandatory entries (unmodifiable)
type directionalPressureGradientExplicitSource;
// Mandatory entries (unmodifiable)
model <modelName>;
fields (<fieldName>);
// Mandatory entries (runtime modifiable)
flowDir (1 1 0);
faceZone <faceZoneName>;
// Conditional mandatory entries (unmodifiable)
// when <timePath>/uniform/<name>Properties file exists
gradient <vectorField>; // reading from the aforementioned file
// when model=DarcyForchheimer
// deltaP = (D*mu + 0.5*rho*magUn)*magUn*length
D 5e7;
I 0;
length 1e-3;
// when model=constant
pressureDrop 40;
// when model=volumetricFlowRateTable
outOfBounds clamp;
fileName "volFlowRateTable";
// Optional entries (runtime modifiable)
relaxationFactor 0.3;
// Mandatory/Optional (inherited) entries
...
}
where the entries mean:
| Property | Description | Type | Reqd | Dflt |
|---|---|---|---|---|
type | Type name: directionalPressureGradientExplicitSource | word | yes | - |
model | Pressure drop model [Pa] | word | yes | - |
fields | Name of operand field | word | yes | - |
gradient | Initial pressure gradient field | vectorField | cndtnl | - |
flowDir | Deflection flow direction | vector | yes | - |
faceZone | Name of upstream faceZone | word | yes | - |
relaxationFactor | Relaxation factor for flow deflection | scalar | no | 0.3 |
D | Darcy pressure loss coefficient | scalar | cndtnl | - |
I | Inertia pressure lost coefficient | scalar | cndtnl | - |
length | Porous media length | scalar | cndtnl | - |
presssureDrop | Constant pressure drop | scalar | cndtnl | - |
fileName | Interpolation table for volumetric flow rate | interpolationTable | cndtnl | - |
Options for the model entry:
volumetricFlowRateTable | Pressure-gradient file
constant | Constant pressure drop
DarcyForchheimer | Darcy-Forchheimer model
The inherited entries are elaborated in:
Definition at line 218 of file directionalPressureGradientExplicitSource.H.
| enum pressureDropModel |
Modes of pressure drop.
| Enumerator | |
|---|---|
| pVolumetricFlowRateTable | |
| pConstant | |
| pDarcyForchheimer | |
Definition at line 229 of file directionalPressureGradientExplicitSource.H.
| directionalPressureGradientExplicitSource | ( | const word & | sourceName, |
| const word & | modelType, | ||
| const dictionary & | dict, | ||
| const fvMesh & | mesh ) |
Construct from explicit source name and mesh.
Definition at line 156 of file directionalPressureGradientExplicitSource.C.
References cellSetOption::cells_, cellSetOption::cellSetOption(), option::coeffs_, dict, Foam::endl(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, option::fieldNames_, IOstream::good(), if(), Foam::Info, option::mesh(), option::mesh_, option::name(), option::name_, Foam::nl, pConstant, pDarcyForchheimer, propsDict(), pVolumetricFlowRateTable, option::resetApplied(), Foam::type(), and Foam::Zero.
Referenced by directionalPressureGradientExplicitSource(), and operator=().


|
delete |
No copy construct.
References directionalPressureGradientExplicitSource().

|
virtualdefault |
| TypeName | ( | "directionalPressureGradientExplicitSource" | ) |
Runtime type information.
References dict, and option::mesh().

|
delete |
No copy assignment.
References directionalPressureGradientExplicitSource().

|
virtual |
Correct the pressure gradient.
Reimplemented from option.
Definition at line 250 of file directionalPressureGradientExplicitSource.C.
References cellId, cellSetOption::cells_, fvPatchFieldBase::coupled(), D, Foam::dimTime, Foam::dimVolume, Foam::endl(), Foam::exit(), Foam::FatalError, FatalErrorInFunction, faceZone::flipMap(), forAll, Foam::gWeightedAverage(), Foam::Info, Foam::isA(), Foam::mag(), faceZone::masterCells(), mesh, option::mesh_, mu, nu, fvPatchField< Type >::patchNeighbourField(), pbm, pConstant, pDarcyForchheimer, phi, turbulenceModel::propertiesName, pVolumetricFlowRateTable, rAU, Foam::reduce(), rho, Foam::rotationTensor(), PtrList< T >::set(), UList< T >::size(), faceZone::slaveCells(), U, Foam::Zero, and cellSetOption::zoneName().

Add explicit contribution to momentum equation.
Reimplemented from option.
Definition at line 454 of file directionalPressureGradientExplicitSource.C.
References cellSetOption::cells_, fvMatrix< Type >::dimensions(), Foam::dimVolume, option::fieldNames_, option::mesh_, option::name_, DimensionedField< Type, GeoMesh >::New(), IOobjectOption::NO_REGISTER, Foam::Su(), and Foam::Zero.
Referenced by addSup().


|
virtual |
Add explicit contribution to compressible momentum equation.
Reimplemented from option.
Definition at line 475 of file directionalPressureGradientExplicitSource.C.

Set 1/A coefficient.
Reimplemented from option.
Definition at line 486 of file directionalPressureGradientExplicitSource.C.
References fvMatrix< Type >::A(), option::mesh_, option::name_, IOobject::scopedName(), and Foam::Zero.

|
virtual |
Write the source properties.
Reimplemented from option.
Definition at line 513 of file directionalPressureGradientExplicitSource.C.
References NotImplemented, and os().

|
virtual |
Read source dictionary.
Reimplemented from cellSetOption.
Definition at line 522 of file directionalPressureGradientExplicitSource.C.
References option::coeffs(), dict, Foam::GlobalIOList< Tuple2< scalar, vector > >::typeName, pConstant, and pDarcyForchheimer.
