2010-05-12 13:27:55 +00:00
|
|
|
Info<< "Reading transportProperties\n" << endl;
|
|
|
|
|
|
|
|
IOdictionary transportProperties
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"transportProperties",
|
|
|
|
runTime.constant(),
|
|
|
|
mesh,
|
|
|
|
IOobject::MUST_READ,
|
|
|
|
IOobject::NO_WRITE
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
autoPtr<phaseModel> phasea = phaseModel::New
|
|
|
|
(
|
|
|
|
mesh,
|
|
|
|
transportProperties,
|
|
|
|
"a"
|
|
|
|
);
|
|
|
|
|
|
|
|
autoPtr<phaseModel> phaseb = phaseModel::New
|
|
|
|
(
|
|
|
|
mesh,
|
|
|
|
transportProperties,
|
|
|
|
"b"
|
|
|
|
);
|
|
|
|
|
|
|
|
volVectorField& Ua = phasea->U();
|
|
|
|
surfaceScalarField& phia = phasea->phi();
|
|
|
|
const dimensionedScalar& rhoa = phasea->rho();
|
|
|
|
const dimensionedScalar& nua = phasea->nu();
|
|
|
|
|
|
|
|
volVectorField& Ub = phaseb->U();
|
|
|
|
surfaceScalarField& phib = phaseb->phi();
|
|
|
|
const dimensionedScalar& rhob = phaseb->rho();
|
|
|
|
const dimensionedScalar& nub = phaseb->nu();
|
|
|
|
|
|
|
|
Info<< "Reading field alpha\n" << endl;
|
|
|
|
volScalarField alpha
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"alpha",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::MUST_READ,
|
|
|
|
IOobject::AUTO_WRITE
|
|
|
|
),
|
|
|
|
mesh
|
|
|
|
);
|
|
|
|
|
|
|
|
volScalarField beta
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"beta",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::NO_READ,
|
|
|
|
IOobject::NO_WRITE
|
|
|
|
),
|
|
|
|
scalar(1) - alpha
|
|
|
|
//,alpha.boundaryField().types()
|
|
|
|
);
|
|
|
|
|
|
|
|
Info<< "Reading field p\n" << endl;
|
|
|
|
volScalarField p
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"p",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::MUST_READ,
|
|
|
|
IOobject::AUTO_WRITE
|
|
|
|
),
|
|
|
|
mesh
|
|
|
|
);
|
|
|
|
|
|
|
|
volVectorField U
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"U",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::NO_READ,
|
|
|
|
IOobject::AUTO_WRITE
|
|
|
|
),
|
|
|
|
alpha*Ua + beta*Ub
|
|
|
|
);
|
|
|
|
|
|
|
|
Info<< "Reading field k\n" << endl;
|
|
|
|
volScalarField k
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"k",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::MUST_READ,
|
|
|
|
IOobject::AUTO_WRITE
|
|
|
|
),
|
|
|
|
mesh
|
|
|
|
);
|
|
|
|
|
|
|
|
Info<< "Reading field epsilon\n" << endl;
|
|
|
|
volScalarField epsilon
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"epsilon",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::MUST_READ,
|
|
|
|
IOobject::AUTO_WRITE
|
|
|
|
),
|
|
|
|
mesh
|
|
|
|
);
|
|
|
|
|
|
|
|
dimensionedScalar Cvm
|
|
|
|
(
|
|
|
|
transportProperties.lookup("Cvm")
|
|
|
|
);
|
|
|
|
|
|
|
|
dimensionedScalar Cl
|
|
|
|
(
|
|
|
|
transportProperties.lookup("Cl")
|
|
|
|
);
|
|
|
|
|
|
|
|
dimensionedScalar Ct
|
|
|
|
(
|
|
|
|
transportProperties.lookup("Ct")
|
|
|
|
);
|
|
|
|
|
|
|
|
surfaceScalarField phi
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"phi",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh
|
|
|
|
),
|
|
|
|
fvc::interpolate(alpha)*phia + fvc::interpolate(beta)*phib
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
IOdictionary RASProperties
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"RASProperties",
|
|
|
|
runTime.constant(),
|
|
|
|
mesh,
|
|
|
|
IOobject::MUST_READ,
|
|
|
|
IOobject::NO_WRITE
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
Switch turbulence
|
|
|
|
(
|
|
|
|
RASProperties.lookup("turbulence")
|
|
|
|
);
|
|
|
|
|
|
|
|
dictionary kEpsilonCoeffs
|
|
|
|
(
|
|
|
|
RASProperties.subDict("kEpsilonCoeffs")
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
scalar Cmu
|
|
|
|
(
|
|
|
|
readScalar(kEpsilonCoeffs.lookup("Cmu"))
|
|
|
|
);
|
|
|
|
|
|
|
|
scalar C1
|
|
|
|
(
|
|
|
|
readScalar(kEpsilonCoeffs.lookup("C1"))
|
|
|
|
);
|
|
|
|
|
|
|
|
scalar C2
|
|
|
|
(
|
|
|
|
readScalar(kEpsilonCoeffs.lookup("C2"))
|
|
|
|
);
|
|
|
|
|
|
|
|
scalar alphak
|
|
|
|
(
|
|
|
|
readScalar(kEpsilonCoeffs.lookup("alphak"))
|
|
|
|
);
|
|
|
|
|
|
|
|
scalar alphaEps
|
|
|
|
(
|
|
|
|
readScalar(kEpsilonCoeffs.lookup("alphaEps"))
|
|
|
|
);
|
|
|
|
|
|
|
|
dictionary wallFunctionCoeffs
|
|
|
|
(
|
|
|
|
RASProperties.subDict("wallFunctionCoeffs")
|
|
|
|
);
|
|
|
|
|
|
|
|
scalar kappa
|
|
|
|
(
|
|
|
|
readScalar(wallFunctionCoeffs.lookup("kappa"))
|
|
|
|
);
|
|
|
|
|
|
|
|
scalar E
|
|
|
|
(
|
|
|
|
readScalar(wallFunctionCoeffs.lookup("E"))
|
|
|
|
);
|
|
|
|
|
|
|
|
nearWallDist y(mesh);
|
|
|
|
|
|
|
|
Info<< "Calculating field nutb\n" << endl;
|
|
|
|
volScalarField nutb
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"nutb",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::NO_READ,
|
|
|
|
IOobject::AUTO_WRITE
|
|
|
|
),
|
|
|
|
Cmu*sqr(k)/epsilon
|
|
|
|
);
|
|
|
|
|
|
|
|
Info<< "Calculating field nuEffa\n" << endl;
|
|
|
|
volScalarField nuEffa
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"nuEffa",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::NO_READ,
|
|
|
|
IOobject::NO_WRITE
|
|
|
|
),
|
|
|
|
sqr(Ct)*nutb + nua
|
|
|
|
);
|
|
|
|
|
|
|
|
Info<< "Calculating field nuEffb\n" << endl;
|
|
|
|
volScalarField nuEffb
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"nuEffb",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::NO_READ,
|
|
|
|
IOobject::NO_WRITE
|
|
|
|
),
|
|
|
|
nutb + nub
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
Info<< "Calculating field DDtUa and DDtUb\n" << endl;
|
|
|
|
|
|
|
|
volVectorField DDtUa =
|
|
|
|
fvc::ddt(Ua)
|
|
|
|
+ fvc::div(phia, Ua)
|
|
|
|
- fvc::div(phia)*Ua;
|
|
|
|
|
|
|
|
volVectorField DDtUb =
|
|
|
|
fvc::ddt(Ub)
|
|
|
|
+ fvc::div(phib, Ub)
|
|
|
|
- fvc::div(phib)*Ub;
|
|
|
|
|
|
|
|
|
|
|
|
Info<< "Calculating field g.h\n" << endl;
|
|
|
|
volScalarField gh("gh", g & mesh.C());
|
|
|
|
|
|
|
|
IOdictionary interfacialProperties
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"interfacialProperties",
|
|
|
|
runTime.constant(),
|
|
|
|
mesh,
|
|
|
|
IOobject::MUST_READ,
|
|
|
|
IOobject::NO_WRITE
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
autoPtr<dragModel> draga = dragModel::New
|
|
|
|
(
|
|
|
|
interfacialProperties,
|
|
|
|
alpha,
|
|
|
|
phasea,
|
|
|
|
phaseb
|
|
|
|
);
|
|
|
|
|
|
|
|
autoPtr<dragModel> dragb = dragModel::New
|
|
|
|
(
|
|
|
|
interfacialProperties,
|
|
|
|
beta,
|
|
|
|
phaseb,
|
|
|
|
phasea
|
|
|
|
);
|
|
|
|
|
|
|
|
word dragPhase("blended");
|
|
|
|
if (interfacialProperties.found("dragPhase"))
|
|
|
|
{
|
|
|
|
dragPhase = word(interfacialProperties.lookup("dragPhase"));
|
|
|
|
|
|
|
|
bool validDrag =
|
|
|
|
dragPhase == "a" || dragPhase == "b" || dragPhase == "blended";
|
|
|
|
|
|
|
|
if (!validDrag)
|
|
|
|
{
|
|
|
|
FatalErrorIn(args.executable())
|
|
|
|
<< "invalid dragPhase " << dragPhase
|
|
|
|
<< exit(FatalError);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Info << "dragPhase is " << dragPhase << endl;
|
|
|
|
kineticTheoryModel kineticTheory
|
|
|
|
(
|
|
|
|
phasea,
|
|
|
|
Ub,
|
|
|
|
alpha,
|
|
|
|
draga
|
|
|
|
);
|
|
|
|
|
|
|
|
surfaceScalarField rUaAf
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"rUaAf",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::NO_READ,
|
|
|
|
IOobject::NO_WRITE
|
|
|
|
),
|
|
|
|
mesh,
|
|
|
|
dimensionedScalar("zero", dimensionSet(0, 0, 1, 0, 0), 0.0)
|
|
|
|
);
|
|
|
|
|
|
|
|
surfaceScalarField ppMagf
|
|
|
|
(
|
|
|
|
IOobject
|
|
|
|
(
|
|
|
|
"ppMagf",
|
|
|
|
runTime.timeName(),
|
|
|
|
mesh,
|
|
|
|
IOobject::NO_READ,
|
|
|
|
IOobject::NO_WRITE
|
|
|
|
),
|
|
|
|
mesh,
|
|
|
|
dimensionedScalar("zero", dimensionSet(0, 2, -1, 0, 0), 0.0)
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
label pRefCell = 0;
|
|
|
|
scalar pRefValue = 0.0;
|
2016-05-28 02:11:10 +00:00
|
|
|
setRefCell(p, piso.dict(), pRefCell, pRefValue);
|
|
|
|
mesh.schemesDict().setFluxRequired(p.name());
|