fvModels: Specify source property values in field files
When an fvModel source introduces fluid into a simulation it should also
create a corresponding source term for all properties transported into
the domain by that injection. The source is, effectively, an alternative
form of inlet boundary, on which all transported properties need an
inlet value specified.
These values are now specified in the property field files. The
following is an example of a 0/U file in which the velocity of fluid
introduced by a fvModel source called "injection1" is set to a fixed
value of (-1 0 0):
dimensions [0 1 -1 0 0 0 0];
internalField uniform (0 0 0);
boundaryField
{
#includeEtc "caseDicts/setConstraintTypes"
wall
{
type noSlip;
}
atmosphere
{
type pressureInletOutletVelocity;
value $internalField;
}
}
// *** NEW ***
sources
{
injection1
{
type uniformFixedValue;
uniformValue (-1 0 0);
}
}
And the following entry in the 0/k file specifies the turbulent kinetic
energy introduced as a fraction of the mean flow kinetic energy:
sources
{
injection1
{
type turbulentIntensityKineticEnergy;
intensity 0.05;
}
}
The specification is directly analogous to boundary conditions. The
conditions are run-time selectable and can be concisely implemented.
They can access each other and be inter-dependent (e.g., the above,
where turbulent kinetic energy depends on velocity). The syntax keeps
field data localised and makes the source model (e.g., massSource,
volumeSource, ...) specification independent from what other models and
fields are present in the simulation. The 'fieldValues' entry previously
required by source models is now no longer required.
If source values need specifying and no source condition has been
supplied in the relevant field file then an error will be generated.
This error is similar to that generated for missing boundary conditions.
This replaces the behaviour where sources such as these would introduce
a value of zero, either silently or with a warning. This is now
considered unacceptable. Zero might be a tolerable default for certain
fields (U, k), but is wholly inappropriate for others (T, epsilon, rho).
This change additionally makes it possible to inject fluid into a
multicomponent solver with a specified temperature. Previously, it was
not possible to do this as there was no means of evaluating the energy
of fluid with the injected composition.
This commit is contained in:
@ -20,17 +20,9 @@ internalField uniform 300;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
@ -40,11 +32,6 @@ boundaryField
|
||||
type inletOutlet;
|
||||
inletValue $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,17 +20,9 @@ internalField uniform (0 0 0);
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type noSlip;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type noSlip;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type noSlip;
|
||||
}
|
||||
@ -40,11 +32,6 @@ boundaryField
|
||||
type pressureInletOutletVelocity;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,17 +20,9 @@ internalField uniform 0;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
@ -41,11 +33,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 0.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type epsilonWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type epsilonWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type epsilonWallFunction;
|
||||
value $internalField;
|
||||
@ -44,11 +34,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 0.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type kqRWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type kqRWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type kqRWallFunction;
|
||||
value $internalField;
|
||||
@ -44,11 +34,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,17 +20,9 @@ internalField uniform 0;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
@ -41,11 +33,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 0;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type nutkWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type nutkWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type nutkWallFunction;
|
||||
value $internalField;
|
||||
@ -43,11 +33,6 @@ boundaryField
|
||||
type calculated;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 11.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type omegaWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type omegaWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type omegaWallFunction;
|
||||
value $internalField;
|
||||
@ -44,11 +34,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 1e5;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type calculated;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type calculated;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type calculated;
|
||||
value $internalField;
|
||||
@ -43,11 +33,6 @@ boundaryField
|
||||
type calculated;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 1e5;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type fixedFluxPressure;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type fixedFluxPressure;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type fixedFluxPressure;
|
||||
value $internalField;
|
||||
@ -43,11 +33,6 @@ boundaryField
|
||||
type prghTotalPressure;
|
||||
p0 $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
47
tutorials/compressibleVoF/damBreakInjection/0/T
Normal file
47
tutorials/compressibleVoF/damBreakInjection/0/T
Normal file
@ -0,0 +1,47 @@
|
||||
/*--------------------------------*- C++ -*----------------------------------*\
|
||||
========= |
|
||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||
\\ / O peration | Website: https://openfoam.org
|
||||
\\ / A nd | Version: dev
|
||||
\\/ M anipulation |
|
||||
\*---------------------------------------------------------------------------*/
|
||||
FoamFile
|
||||
{
|
||||
format ascii;
|
||||
class volScalarField;
|
||||
location "0";
|
||||
object T;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
dimensions [0 0 0 1 0 0 0];
|
||||
|
||||
internalField uniform 300;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
wall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
|
||||
atmosphere
|
||||
{
|
||||
type inletOutlet;
|
||||
inletValue $internalField;
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
injection
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue 320;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
47
tutorials/compressibleVoF/damBreakInjection/0/U
Normal file
47
tutorials/compressibleVoF/damBreakInjection/0/U
Normal file
@ -0,0 +1,47 @@
|
||||
/*--------------------------------*- C++ -*----------------------------------*\
|
||||
========= |
|
||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||
\\ / O peration | Website: https://openfoam.org
|
||||
\\ / A nd | Version: dev
|
||||
\\/ M anipulation |
|
||||
\*---------------------------------------------------------------------------*/
|
||||
FoamFile
|
||||
{
|
||||
format ascii;
|
||||
class volVectorField;
|
||||
location "0";
|
||||
object U;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
dimensions [0 1 -1 0 0 0 0];
|
||||
|
||||
internalField uniform (0 0 0);
|
||||
|
||||
boundaryField
|
||||
{
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
wall
|
||||
{
|
||||
type noSlip;
|
||||
}
|
||||
|
||||
atmosphere
|
||||
{
|
||||
type pressureInletOutletVelocity;
|
||||
value $internalField;
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
injection
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue (-1 0 0);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
49
tutorials/compressibleVoF/damBreakInjection/0/epsilon
Normal file
49
tutorials/compressibleVoF/damBreakInjection/0/epsilon
Normal file
@ -0,0 +1,49 @@
|
||||
/*--------------------------------*- C++ -*----------------------------------*\
|
||||
========= |
|
||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||
\\ / O peration | Website: https://openfoam.org
|
||||
\\ / A nd | Version: dev
|
||||
\\/ M anipulation |
|
||||
\*---------------------------------------------------------------------------*/
|
||||
FoamFile
|
||||
{
|
||||
format ascii;
|
||||
class volScalarField;
|
||||
location "0";
|
||||
object epsilon;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
dimensions [0 2 -3 0 0 0 0];
|
||||
|
||||
internalField uniform 0.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
wall
|
||||
{
|
||||
type epsilonWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
atmosphere
|
||||
{
|
||||
type inletOutlet;
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
injection
|
||||
{
|
||||
type turbulentMixingLengthDissipationRate;
|
||||
mixingLength 0.0146;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
49
tutorials/compressibleVoF/damBreakInjection/0/k
Normal file
49
tutorials/compressibleVoF/damBreakInjection/0/k
Normal file
@ -0,0 +1,49 @@
|
||||
/*--------------------------------*- C++ -*----------------------------------*\
|
||||
========= |
|
||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||
\\ / O peration | Website: https://openfoam.org
|
||||
\\ / A nd | Version: dev
|
||||
\\/ M anipulation |
|
||||
\*---------------------------------------------------------------------------*/
|
||||
FoamFile
|
||||
{
|
||||
format ascii;
|
||||
class volScalarField;
|
||||
location "0";
|
||||
object k;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
dimensions [0 2 -2 0 0 0 0];
|
||||
|
||||
internalField uniform 0.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
wall
|
||||
{
|
||||
type kqRWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
atmosphere
|
||||
{
|
||||
type inletOutlet;
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
injection
|
||||
{
|
||||
type turbulentIntensityKineticEnergy;
|
||||
intensity 0.05;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
@ -4,8 +4,14 @@ cd ${0%/*} || exit 1 # Run from this directory
|
||||
# Source tutorial clean functions
|
||||
. $WM_PROJECT_DIR/bin/tools/CleanFunctions
|
||||
|
||||
cleanVoFCase && rm -rf 0 system
|
||||
cleanVoFCase
|
||||
|
||||
find constant -type f -not -name fvModels.injection -delete
|
||||
find 0 -type f -not \( \
|
||||
-name epsilon -or -name k -or -name T -or -name U \
|
||||
\) -delete
|
||||
|
||||
find constant -type f -not -name fvModels -delete
|
||||
|
||||
rm -rf system
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
|
||||
@ -7,8 +7,7 @@ cd ${0%/*} || exit 1 # Run from this directory
|
||||
# Copy the source case and add the mass source model
|
||||
isTest "$@" && path=.. || path=$FOAM_TUTORIALS/compressibleVoF
|
||||
cp -rn $path/damBreak/0 $path/damBreak/constant $path/damBreak/system .
|
||||
runApplication foamDictionary constant/fvModels \
|
||||
-entry injection -dict -merge constant/fvModels.injection
|
||||
rm -rf 0/alpha.water
|
||||
|
||||
# Run
|
||||
runApplication blockMesh
|
||||
|
||||
@ -10,7 +10,7 @@ FoamFile
|
||||
format ascii;
|
||||
class dictionary;
|
||||
location "constant";
|
||||
object fvModels.injection;
|
||||
object fvModels;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
@ -18,19 +18,11 @@ injection
|
||||
{
|
||||
type massSource;
|
||||
|
||||
phase water;
|
||||
|
||||
points ((0.438 0.438 0.0073));
|
||||
|
||||
massFlowRate 0.3;
|
||||
|
||||
phase water;
|
||||
|
||||
fieldValues
|
||||
{
|
||||
T.water 350;
|
||||
U (-1 0 0);
|
||||
k 0.1;
|
||||
epsilon 0.1;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -39,5 +39,14 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
volumeSource
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue (0 0 0);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -39,5 +39,14 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
volumeSource
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue 1;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -27,12 +27,6 @@ volumeSource
|
||||
cellZone volumeSource;
|
||||
|
||||
volumetricFlowRate 0.00064;
|
||||
|
||||
fieldValues
|
||||
{
|
||||
U (0 0 0);
|
||||
tracer 1;
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -20,17 +20,9 @@ internalField uniform (0 0 0);
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type noSlip;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type noSlip;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type noSlip;
|
||||
}
|
||||
@ -40,11 +32,6 @@ boundaryField
|
||||
type pressureInletOutletVelocity;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,17 +20,9 @@ internalField uniform 0;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
@ -41,11 +33,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 0.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type epsilonWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type epsilonWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type epsilonWallFunction;
|
||||
value $internalField;
|
||||
@ -44,11 +34,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 0.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type kqRWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type kqRWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type kqRWallFunction;
|
||||
value $internalField;
|
||||
@ -44,11 +34,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,17 +20,9 @@ internalField uniform 0;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
@ -41,11 +33,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 0;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type nutkWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type nutkWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type nutkWallFunction;
|
||||
value $internalField;
|
||||
@ -43,11 +33,6 @@ boundaryField
|
||||
type calculated;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 11.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type omegaWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type omegaWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type omegaWallFunction;
|
||||
value $internalField;
|
||||
@ -44,11 +34,6 @@ boundaryField
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@ -20,19 +20,9 @@ internalField uniform 0;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
leftWall
|
||||
{
|
||||
type fixedFluxPressure;
|
||||
value $internalField;
|
||||
}
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
rightWall
|
||||
{
|
||||
type fixedFluxPressure;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
lowerWall
|
||||
wall
|
||||
{
|
||||
type fixedFluxPressure;
|
||||
value $internalField;
|
||||
@ -43,11 +33,6 @@ boundaryField
|
||||
type prghTotalPressure;
|
||||
p0 $internalField;
|
||||
}
|
||||
|
||||
defaultFaces
|
||||
{
|
||||
type empty;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
47
tutorials/incompressibleVoF/damBreakInjection/0/U
Normal file
47
tutorials/incompressibleVoF/damBreakInjection/0/U
Normal file
@ -0,0 +1,47 @@
|
||||
/*--------------------------------*- C++ -*----------------------------------*\
|
||||
========= |
|
||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||
\\ / O peration | Website: https://openfoam.org
|
||||
\\ / A nd | Version: dev
|
||||
\\/ M anipulation |
|
||||
\*---------------------------------------------------------------------------*/
|
||||
FoamFile
|
||||
{
|
||||
format ascii;
|
||||
class volVectorField;
|
||||
location "0";
|
||||
object U;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
dimensions [0 1 -1 0 0 0 0];
|
||||
|
||||
internalField uniform (0 0 0);
|
||||
|
||||
boundaryField
|
||||
{
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
wall
|
||||
{
|
||||
type noSlip;
|
||||
}
|
||||
|
||||
atmosphere
|
||||
{
|
||||
type pressureInletOutletVelocity;
|
||||
value $internalField;
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
injection
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue (-1 0 0);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
49
tutorials/incompressibleVoF/damBreakInjection/0/epsilon
Normal file
49
tutorials/incompressibleVoF/damBreakInjection/0/epsilon
Normal file
@ -0,0 +1,49 @@
|
||||
/*--------------------------------*- C++ -*----------------------------------*\
|
||||
========= |
|
||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||
\\ / O peration | Website: https://openfoam.org
|
||||
\\ / A nd | Version: dev
|
||||
\\/ M anipulation |
|
||||
\*---------------------------------------------------------------------------*/
|
||||
FoamFile
|
||||
{
|
||||
format ascii;
|
||||
class volScalarField;
|
||||
location "0";
|
||||
object epsilon;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
dimensions [0 2 -3 0 0 0 0];
|
||||
|
||||
internalField uniform 0.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
wall
|
||||
{
|
||||
type epsilonWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
atmosphere
|
||||
{
|
||||
type inletOutlet;
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
injection
|
||||
{
|
||||
type turbulentMixingLengthDissipationRate;
|
||||
mixingLength 0.0146;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
49
tutorials/incompressibleVoF/damBreakInjection/0/k
Normal file
49
tutorials/incompressibleVoF/damBreakInjection/0/k
Normal file
@ -0,0 +1,49 @@
|
||||
/*--------------------------------*- C++ -*----------------------------------*\
|
||||
========= |
|
||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||
\\ / O peration | Website: https://openfoam.org
|
||||
\\ / A nd | Version: dev
|
||||
\\/ M anipulation |
|
||||
\*---------------------------------------------------------------------------*/
|
||||
FoamFile
|
||||
{
|
||||
format ascii;
|
||||
class volScalarField;
|
||||
location "0";
|
||||
object k;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
dimensions [0 2 -2 0 0 0 0];
|
||||
|
||||
internalField uniform 0.1;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
wall
|
||||
{
|
||||
type kqRWallFunction;
|
||||
value $internalField;
|
||||
}
|
||||
|
||||
atmosphere
|
||||
{
|
||||
type inletOutlet;
|
||||
inletValue $internalField;
|
||||
value $internalField;
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
injection
|
||||
{
|
||||
type turbulentIntensityKineticEnergy;
|
||||
intensity 0.05;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
@ -4,8 +4,14 @@ cd ${0%/*} || exit 1 # Run from this directory
|
||||
# Source tutorial clean functions
|
||||
. $WM_PROJECT_DIR/bin/tools/CleanFunctions
|
||||
|
||||
cleanVoFCase && rm -rf 0 system
|
||||
cleanVoFCase
|
||||
|
||||
find constant -type f -not -name fvModels.injection -delete
|
||||
find 0 -type f -not \( \
|
||||
-name epsilon -or -name k -or -name U \
|
||||
\) -delete
|
||||
|
||||
find constant -type f -not -name fvModels -delete
|
||||
|
||||
rm -rf system
|
||||
|
||||
#------------------------------------------------------------------------------
|
||||
|
||||
@ -4,11 +4,10 @@ cd ${0%/*} || exit 1 # Run from this directory
|
||||
# Source tutorial run functions
|
||||
. $WM_PROJECT_DIR/bin/tools/RunFunctions
|
||||
|
||||
# Copy the source case and add the volume source model
|
||||
# Copy the source case
|
||||
isTest "$@" && path=.. || path=$FOAM_TUTORIALS/incompressibleVoF
|
||||
cp -rn $path/damBreak/0 $path/damBreak/constant $path/damBreak/system .
|
||||
runApplication foamDictionary constant/fvModels \
|
||||
-entry injection -dict -merge constant/fvModels.injection
|
||||
rm -f 0/alpha.water
|
||||
|
||||
# Run
|
||||
runApplication blockMesh
|
||||
|
||||
@ -10,26 +10,26 @@ FoamFile
|
||||
format ascii;
|
||||
class dictionary;
|
||||
location "constant";
|
||||
object fvModels.injection;
|
||||
object fvModels;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
turbulenceDamping
|
||||
{
|
||||
type VoFTurbulenceDamping;
|
||||
|
||||
delta 1e-4;
|
||||
}
|
||||
|
||||
injection
|
||||
{
|
||||
type volumeSource;
|
||||
|
||||
phase water;
|
||||
|
||||
points ((0.438 0.438 0.0073));
|
||||
|
||||
volumetricFlowRate 0.0003;
|
||||
|
||||
phase water;
|
||||
|
||||
fieldValues
|
||||
{
|
||||
U (-1 0 0);
|
||||
k 0.1;
|
||||
epsilon 0.1;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -55,5 +55,14 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformInletOutlet;
|
||||
uniformInletValue 1;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -55,5 +55,14 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformInletOutlet;
|
||||
uniformInletValue 0;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -55,5 +55,14 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformInletOutlet;
|
||||
uniformInletValue 0;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -56,5 +56,14 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformInletOutlet;
|
||||
uniformInletValue 450;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -55,5 +55,14 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformInletOutlet;
|
||||
uniformInletValue (0 50 0);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -56,5 +56,14 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type turbulentMixingLengthDissipationRate;
|
||||
mixingLength 0.01;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -56,5 +56,14 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type turbulentIntensityKineticEnergy;
|
||||
intensity 0.05;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -69,16 +69,6 @@ massSource
|
||||
duration 2;
|
||||
value 1e-4;
|
||||
}
|
||||
|
||||
fieldValues
|
||||
{
|
||||
U (0 50 0);
|
||||
h 100000;
|
||||
O2 0;
|
||||
H2O 1;
|
||||
k 0.0938;
|
||||
epsilon 0.0449;
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -21,9 +21,9 @@ boundaryField
|
||||
{
|
||||
top
|
||||
{
|
||||
type pressureInletOutletVelocity;
|
||||
phi phi.air;
|
||||
value $internalField;
|
||||
type pressureInletOutletVelocity;
|
||||
phi phi.air;
|
||||
value $internalField;
|
||||
}
|
||||
walls
|
||||
{
|
||||
|
||||
@ -21,9 +21,9 @@ boundaryField
|
||||
{
|
||||
top
|
||||
{
|
||||
type pressureInletOutletVelocity;
|
||||
phi phi.water;
|
||||
value $internalField;
|
||||
type pressureInletOutletVelocity;
|
||||
phi phi.water;
|
||||
value $internalField;
|
||||
}
|
||||
walls
|
||||
{
|
||||
@ -31,4 +31,13 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformInletOutlet;
|
||||
uniformInletValue (0 0 0);
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -18,25 +18,21 @@ massSource
|
||||
{
|
||||
type massSource;
|
||||
|
||||
points ((0.075 0.925 0.05));
|
||||
phase water;
|
||||
|
||||
points
|
||||
(
|
||||
(0.075 0.925 0.05)
|
||||
);
|
||||
|
||||
massFlowRate
|
||||
{
|
||||
type square;
|
||||
amplitude 0.5;
|
||||
frequency 0.5;
|
||||
level 0.5;
|
||||
markSpace 0.3333;
|
||||
}
|
||||
|
||||
phase water;
|
||||
rho rho.water;
|
||||
|
||||
fieldValues
|
||||
{
|
||||
U.water (0 0 0);
|
||||
type square;
|
||||
amplitude 0.5;
|
||||
frequency 0.5;
|
||||
level 0.5;
|
||||
markSpace 0.3333;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -41,4 +41,13 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue (0 0 0);
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -38,4 +38,13 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue 0;
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
50
tutorials/multiphaseEuler/bubblePipe/0/f2.air1
Normal file
50
tutorials/multiphaseEuler/bubblePipe/0/f2.air1
Normal file
@ -0,0 +1,50 @@
|
||||
/*--------------------------------*- C++ -*----------------------------------*\
|
||||
========= |
|
||||
\\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
||||
\\ / O peration | Website: https://openfoam.org
|
||||
\\ / A nd | Version: dev
|
||||
\\/ M anipulation |
|
||||
\*---------------------------------------------------------------------------*/
|
||||
FoamFile
|
||||
{
|
||||
format ascii;
|
||||
class volScalarField;
|
||||
object f2.air1;
|
||||
}
|
||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||
|
||||
dimensions [];
|
||||
|
||||
internalField uniform 0;
|
||||
|
||||
boundaryField
|
||||
{
|
||||
#includeEtc "caseDicts/setConstraintTypes"
|
||||
|
||||
inlet
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue 0;
|
||||
}
|
||||
|
||||
outlet
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
|
||||
walls
|
||||
{
|
||||
type zeroGradient;
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue 1;
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
@ -38,4 +38,12 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue 0;
|
||||
}
|
||||
}
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -38,4 +38,13 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue 0;
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -38,4 +38,13 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue 0;
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -18,22 +18,11 @@ massSource
|
||||
{
|
||||
type massSource;
|
||||
|
||||
phase air1;
|
||||
|
||||
cellZone injection;
|
||||
|
||||
massFlowRate 6e-7;
|
||||
|
||||
phase air1;
|
||||
rho rho.air1;
|
||||
|
||||
fieldValues
|
||||
{
|
||||
f0.air1 0;
|
||||
f1.air1 0;
|
||||
f2.air1 1;
|
||||
f3.air1 0;
|
||||
f4.air1 0;
|
||||
U.air1 (0 0 0);
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -32,4 +32,13 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformInletOutlet;
|
||||
uniformInletValue 300;
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -32,4 +32,13 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformInletOutlet;
|
||||
uniformInletValue (0 -10 0);
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -18,14 +18,13 @@ massSource
|
||||
{
|
||||
type massSource;
|
||||
|
||||
phase air;
|
||||
|
||||
points
|
||||
(
|
||||
(0.075 0.2 0.05)
|
||||
);
|
||||
|
||||
phase air;
|
||||
rho rho.air;
|
||||
|
||||
massFlowRate
|
||||
{
|
||||
type scale;
|
||||
@ -34,13 +33,6 @@ massSource
|
||||
duration 5;
|
||||
value 1e-3;
|
||||
}
|
||||
|
||||
fieldValues
|
||||
{
|
||||
U.air (0 -10 0);
|
||||
T.air 300;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -40,4 +40,13 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformFixedEnergyTemperature;
|
||||
uniformHe 3700000;
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -39,4 +39,13 @@ boundaryField
|
||||
}
|
||||
}
|
||||
|
||||
sources
|
||||
{
|
||||
massSource
|
||||
{
|
||||
type uniformFixedValue;
|
||||
uniformValue (0 10 0);
|
||||
}
|
||||
}
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
@ -18,14 +18,13 @@ massSource
|
||||
{
|
||||
type massSource;
|
||||
|
||||
phase steam;
|
||||
|
||||
points
|
||||
(
|
||||
(0.075 0.2 0.05)
|
||||
);
|
||||
|
||||
phase steam;
|
||||
rho rho.steam;
|
||||
|
||||
massFlowRate
|
||||
{
|
||||
type scale;
|
||||
@ -34,13 +33,6 @@ massSource
|
||||
duration 1e6;
|
||||
value 1e-3;
|
||||
}
|
||||
|
||||
fieldValues
|
||||
{
|
||||
U.steam (0 10 0);
|
||||
h.steam 3700000;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// ************************************************************************* //
|
||||
|
||||
Reference in New Issue
Block a user