Info<< "Reading transportProperties\n" << endl; IOdictionary transportProperties ( IOobject ( "transportProperties", runTime.constant(), mesh, IOobject::MUST_READ, IOobject::NO_WRITE ) ); autoPtr phasea = phaseModel::New ( mesh, transportProperties, "a" ); autoPtr 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 draga = dragModel::New ( interfacialProperties, alpha, phasea, phaseb ); autoPtr 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; setRefCell(p, mesh.solutionDict().subDict("PISO"), pRefCell, pRefValue);