tmp> mvConvection ( fv::gpuconvectionScheme::New ( devicemesh, fields, phi, devicemesh.hostmesh().divScheme("div(phi,Yi_h)") ) ); { reaction->correct(); Qdot = reaction->Qdot(); volScalargpuField Yt(0.0*Y[0]); forAll(Y, i) { if (i != inertIndex && composition.active(i)) { volScalargpuField& Yi = Y[i]; gpufvScalarMatrix YiEqn ( fvm::ddt(rho, Yi) + mvConvection->fvmDiv(phi, Yi) - fvm::laplacian(turbulence->muEff(), Yi) == reaction->R(Yi) + fvOptions(rho, Yi) ); YiEqn.relax(); fvOptions.constrain(YiEqn); YiEqn.solve(mesh.solver("Yi")); fvOptions.correct(Yi); Yi.max(0.0); Yt += Yi; } } Y[inertIndex] = scalar(1) - Yt; Y[inertIndex].max(0.0); //thermo.updateCellMixture(); }