コード例 #1
0
ファイル: KEStencilF.cpp プロジェクト: cqql/turbulence
void KEStencilF::apply(FlowField& flowField, int i, int j, int k) {
  // turbulent kinetic energy
  wip.tke = flowField.getTke(i, j, k);
  wip.tkes = (wip.tke > 0) - (wip.tke < 0);
  wip.tke = fabs(wip.tke);

  // dissipation rate
  wip.epsilon = flowField.getEpsilon(i, j, k);
  wip.epsilons = (wip.epsilon > 0) - (wip.epsilon < 0);
  wip.epsilon = fabs(wip.epsilon);

  // closest wall distance
  wip.delta = flowField.getH(i, j, k);

  // turbulent Reynolds numbers
  wip.Rt = wip.tke * wip.tke * wip.Re / max(wip.epsilon, err);
  wip.Rd = sqrt(wip.tke) * wip.delta * wip.Re;

  // dimensionless wall distance
  FLOAT uTau = pow(cmu, 0.25) * sqrt(wip.tke);
  wip.yplus = uTau * wip.delta * wip.Re;

  // calculate factors
  calc();

  // limitation for diffusion and reaction terms
//   FLOAT gamma = flowField.getEpsilon(i,j,k)/max(1e-8, flowField.getTke(i,j,k));
//   wop.f2 *= (wop.f2*gamma> 0.0) ? 1.0 : 0.0;
//   wop.f3  = (       gamma> 0.0) ? 1.0 : 0.0; 

  // write factors
  flowField.getFmu(i, j, k) = wop.fmu;
  flowField.getF1(i, j, k) = wop.f1;
  flowField.getF2(i, j, k) = wop.f2;
  flowField.getF3(i, j, k) = wop.f3;
  flowField.getD(i, j, k) = wop.D;
  flowField.getE(i, j, k) = wop.E;
}