kEpsilon::kEpsilon ( const volVectorField& U, const surfaceScalarField& phi, transportModel& lamTransportModel ) : RASModel(typeName, U, phi, lamTransportModel), Cmu_ ( dimensioned<scalar>::lookupOrAddToDict ( "Cmu", coeffDict_, 0.09 ) ), C1_ ( dimensioned<scalar>::lookupOrAddToDict ( "C1", coeffDict_, 1.44 ) ), C2_ ( dimensioned<scalar>::lookupOrAddToDict ( "C2", coeffDict_, 1.92 ) ), sigmaEps_ ( dimensioned<scalar>::lookupOrAddToDict ( "sigmaEps", coeffDict_, 1.3 ) ), k_ ( IOobject ( "k", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateK("k", mesh_) ), epsilon_ ( IOobject ( "epsilon", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateEpsilon("epsilon", mesh_) ), nut_ ( IOobject ( "nut", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateNut("nut", mesh_) ) { nut_ = Cmu_*sqr(k_)/(epsilon_ + epsilonSmall_); nut_.correctBoundaryConditions(); printCoeffs(); }
qZeta::qZeta ( const volVectorField& U, const surfaceScalarField& phi, transportModel& lamTransportModel ) : RASModel(typeName, U, phi, lamTransportModel), Cmu_ ( dimensioned<scalar>::lookupOrAddToDict ( "Cmu", coeffDict_, 0.09 ) ), C1_ ( dimensioned<scalar>::lookupOrAddToDict ( "C1", coeffDict_, 1.44 ) ), C2_ ( dimensioned<scalar>::lookupOrAddToDict ( "C2", coeffDict_, 1.92 ) ), sigmaZeta_ ( dimensioned<scalar>::lookupOrAddToDict ( "sigmaZeta", coeffDict_, 1.3 ) ), anisotropic_ ( Switch::lookupOrAddToDict ( "anisotropic", coeffDict_, false ) ), k_ ( IOobject ( "k", runTime_.timeName(), mesh_, IOobject::MUST_READ, IOobject::AUTO_WRITE ), mesh_ ), epsilon_ ( IOobject ( "epsilon", runTime_.timeName(), mesh_, IOobject::MUST_READ, IOobject::AUTO_WRITE ), mesh_ ), q_ ( IOobject ( "q", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), sqrt(k_), k_.boundaryField().types() ), zeta_ ( IOobject ( "zeta", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), epsilon_/(2.0*q_), epsilon_.boundaryField().types() ), nut_ ( IOobject ( "nut", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateNut("nut", mesh_) ) { nut_ = Cmu_*fMu()*sqr(k_)/(epsilon_ + epsilonSmall_); nut_.correctBoundaryConditions(); printCoeffs(); }
kEpsilon::kEpsilon ( const volVectorField& U, const surfaceScalarField& phi, transportModel& transport, const word& turbulenceModelName, const word& modelName ) : RASModel(modelName, U, phi, transport, turbulenceModelName), Cmu_ ( dimensioned<scalar>::lookupOrAddToDict ( "Cmu", coeffDict_, 0.09 ) ), C1_ ( dimensioned<scalar>::lookupOrAddToDict ( "C1", coeffDict_, 1.44 ) ), C2_ ( dimensioned<scalar>::lookupOrAddToDict ( "C2", coeffDict_, 1.92 ) ), sigmaEps_ ( dimensioned<scalar>::lookupOrAddToDict ( "sigmaEps", coeffDict_, 1.3 ) ), k_ ( IOobject ( "k", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateK("k", mesh_) ), epsilon_ ( IOobject ( "epsilon", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateEpsilon("epsilon", mesh_) ), nut_ ( IOobject ( "nut", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateNut("nut", mesh_) ) { bound(k_, kMin_); bound(epsilon_, epsilonMin_); nut_ = Cmu_*sqr(k_)/epsilon_; nut_.correctBoundaryConditions(); printCoeffs(); }
kOmega::kOmega ( const volVectorField& U, const surfaceScalarField& phi, transportModel& lamTransportModel ) : RASModel(typeName, U, phi, lamTransportModel), Cmu_ ( dimensioned<scalar>::lookupOrAddToDict ( "betaStar", coeffDict_, 0.09 ) ), beta_ ( dimensioned<scalar>::lookupOrAddToDict ( "beta", coeffDict_, 0.072 ) ), alpha_ ( dimensioned<scalar>::lookupOrAddToDict ( "alpha", coeffDict_, 0.52 ) ), alphaK_ ( dimensioned<scalar>::lookupOrAddToDict ( "alphaK", coeffDict_, 0.5 ) ), alphaOmega_ ( dimensioned<scalar>::lookupOrAddToDict ( "alphaOmega", coeffDict_, 0.5 ) ), k_ ( IOobject ( "k", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateK("k", mesh_) ), omega_ ( IOobject ( "omega", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateOmega("omega", mesh_) ), nut_ ( IOobject ( "nut", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateNut("nut", mesh_) ) { nut_ = k_/(omega_ + omegaSmall_); nut_.correctBoundaryConditions(); printCoeffs(); }
realizableKE::realizableKE ( const volVectorField& U, const surfaceScalarField& phi, transportModel& lamTransportModel ) : RASModel(typeName, U, phi, lamTransportModel), Cmu_ ( dimensioned<scalar>::lookupOrAddToDict ( "Cmu", coeffDict_, 0.09 ) ), A0_ ( dimensioned<scalar>::lookupOrAddToDict ( "A0", coeffDict_, 4.0 ) ), C2_ ( dimensioned<scalar>::lookupOrAddToDict ( "C2", coeffDict_, 1.9 ) ), sigmak_ ( dimensioned<scalar>::lookupOrAddToDict ( "sigmak", coeffDict_, 1.0 ) ), sigmaEps_ ( dimensioned<scalar>::lookupOrAddToDict ( "sigmaEps", coeffDict_, 1.2 ) ), k_ ( IOobject ( "k", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateK("k", mesh_) ), epsilon_ ( IOobject ( "epsilon", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateEpsilon("epsilon", mesh_) ), nut_ ( IOobject ( "nut", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateNut("nut", mesh_) ) { bound(k_, k0_); bound(epsilon_, epsilon0_); nut_ = rCmu(fvc::grad(U_))*sqr(k_)/(epsilon_ + epsilonSmall_); nut_.correctBoundaryConditions(); printCoeffs(); }
realizableKE_Veh::realizableKE_Veh ( const volVectorField& U, const surfaceScalarField& phi, transportModel& transport, const word& turbulenceModelName, const word& modelName ) : RASModel(modelName, U, phi, transport, turbulenceModelName), Cfcar_ ( dimensioned<scalar>::lookupOrAddToDict ( "Cfcar", coeffDict_, 0.64 ) ), L_ ( dimensioned<scalar>::lookupOrAddToDict ( "L", coeffDict_, 10, dimensionSet(0,1,0,0,0,0,0) ) ), Cecar_ ( dimensioned<scalar>::lookupOrAddToDict ( "Cecar", coeffDict_, 2.47 ) ), Cmu_ ( dimensioned<scalar>::lookupOrAddToDict ( "Cmu", coeffDict_, 0.09 ) ), A0_ ( dimensioned<scalar>::lookupOrAddToDict ( "A0", coeffDict_, 4.0 ) ), C2_ ( dimensioned<scalar>::lookupOrAddToDict ( "C2", coeffDict_, 1.9 ) ), sigmak_ ( dimensioned<scalar>::lookupOrAddToDict ( "sigmak", coeffDict_, 1.0 ) ), sigmaEps_ ( dimensioned<scalar>::lookupOrAddToDict ( "sigmaEps", coeffDict_, 1.2 ) ), k_ ( IOobject ( "k", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateK("k", mesh_) ), epsilon_ ( IOobject ( "epsilon", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateEpsilon("epsilon", mesh_) ), nut_ ( IOobject ( "nut", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateNut("nut", mesh_) ), Ucar_ ( IOobject ( "Ucar", runTime_.timeName(), mesh_, IOobject::MUST_READ, IOobject::AUTO_WRITE ), mesh_ ), VAD_ ( IOobject ( "VAD", runTime_.timeName(), mesh_, IOobject::MUST_READ, IOobject::AUTO_WRITE ), mesh_ ) { bound(k_, kMin_); bound(epsilon_, epsilonMin_); nut_ = rCmu(fvc::grad(U_))*sqr(k_)/epsilon_; nut_.correctBoundaryConditions(); printCoeffs(); }
LienCubicKE::LienCubicKE ( const volVectorField& U, const surfaceScalarField& phi, transportModel& transport, const word& turbulenceModelName, const word& modelName ) : RASModel(modelName, U, phi, transport, turbulenceModelName), C1_ ( dimensioned<scalar>::lookupOrAddToDict ( "C1", coeffDict_, 1.44 ) ), C2_ ( dimensioned<scalar>::lookupOrAddToDict ( "C2", coeffDict_, 1.92 ) ), sigmak_ ( dimensioned<scalar>::lookupOrAddToDict ( "sigmak", coeffDict_, 1.0 ) ), sigmaEps_ ( dimensioned<scalar>::lookupOrAddToDict ( "sigmaEps", coeffDict_, 1.3 ) ), A1_ ( dimensioned<scalar>::lookupOrAddToDict ( "A1", coeffDict_, 1.25 ) ), A2_ ( dimensioned<scalar>::lookupOrAddToDict ( "A2", coeffDict_, 1000.0 ) ), Ctau1_ ( dimensioned<scalar>::lookupOrAddToDict ( "Ctau1", coeffDict_, -4.0 ) ), Ctau2_ ( dimensioned<scalar>::lookupOrAddToDict ( "Ctau2", coeffDict_, 13.0 ) ), Ctau3_ ( dimensioned<scalar>::lookupOrAddToDict ( "Ctau3", coeffDict_, -2.0 ) ), alphaKsi_ ( dimensioned<scalar>::lookupOrAddToDict ( "alphaKsi", coeffDict_, 0.9 ) ), k_ ( IOobject ( "k", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateK("k", mesh_) ), epsilon_ ( IOobject ( "epsilon", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateEpsilon("epsilon", mesh_) ), gradU_(fvc::grad(U)), eta_ ( k_/bound(epsilon_, epsilonMin_) *sqrt(2.0*magSqr(0.5*(gradU_ + gradU_.T()))) ), ksi_ ( k_/epsilon_ *sqrt(2.0*magSqr(0.5*(gradU_ - gradU_.T()))) ), Cmu_(2.0/(3.0*(A1_ + eta_ + alphaKsi_*ksi_))), fEta_(A2_ + pow(eta_, 3.0)), C5viscosity_ ( - 2.0*pow3(Cmu_)*pow4(k_)/pow3(epsilon_) *( magSqr(gradU_ + gradU_.T()) - magSqr(gradU_ - gradU_.T()) ) ), nut_ ( IOobject ( "nut", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateNut("nut", mesh_) ), nonlinearStress_ ( "nonlinearStress", // quadratic terms symm ( pow(k_, 3.0)/sqr(epsilon_) *( Ctau1_/fEta_ *( (gradU_ & gradU_) + (gradU_ & gradU_)().T() ) + Ctau2_/fEta_*(gradU_ & gradU_.T()) + Ctau3_/fEta_*(gradU_.T() & gradU_) ) // cubic term C4 - 20.0*pow(k_, 4.0)/pow(epsilon_, 3.0) *pow(Cmu_, 3.0) *( ((gradU_ & gradU_) & gradU_.T()) + ((gradU_ & gradU_.T()) & gradU_.T()) - ((gradU_.T() & gradU_) & gradU_) - ((gradU_.T() & gradU_.T()) & gradU_) ) ) ) { bound(k_, kMin_); // already bounded: bound(epsilon_, epsilonMin_); nut_ = Cmu_*sqr(k_)/epsilon_ + C5viscosity_; nut_.correctBoundaryConditions(); printCoeffs(); }
kOmega::kOmega ( const volVectorField& U, const surfaceScalarField& phi, transportModel& transport, const word& turbulenceModelName, const word& modelName ) : RASModel(modelName, U, phi, transport, turbulenceModelName), Cmu_ ( dimensioned<scalar>::lookupOrAddToDict ( "betaStar", coeffDict_, 0.09 ) ), beta_ ( dimensioned<scalar>::lookupOrAddToDict ( "beta", coeffDict_, 0.072 ) ), alpha_ ( dimensioned<scalar>::lookupOrAddToDict ( "alpha", coeffDict_, 0.52 ) ), alphaK_ ( dimensioned<scalar>::lookupOrAddToDict ( "alphaK", coeffDict_, 0.5 ) ), alphaOmega_ ( dimensioned<scalar>::lookupOrAddToDict ( "alphaOmega", coeffDict_, 0.5 ) ), k_ ( IOobject ( "k", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateK("k", mesh_) ), omega_ ( IOobject ( "omega", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateOmega("omega", mesh_) ), nut_ ( IOobject ( "nut", runTime_.timeName(), mesh_, IOobject::NO_READ, IOobject::AUTO_WRITE ), autoCreateNut("nut", mesh_) ) { bound(k_, kMin_); bound(omega_, omegaMin_); nut_ = k_/omega_; nut_.correctBoundaryConditions(); printCoeffs(); }