int main() { typedef double Scalar; typedef Opm::FluidSystems::H2ON2<Scalar> FluidSystem; typedef Opm::ImmiscibleFluidState<Scalar, FluidSystem> ImmiscibleFluidState; enum { numPhases = FluidSystem::numPhases }; enum { numComponents = FluidSystem::numComponents }; enum { liquidPhaseIdx = FluidSystem::liquidPhaseIdx }; enum { gasPhaseIdx = FluidSystem::gasPhaseIdx }; enum { H2OIdx = FluidSystem::H2OIdx }; enum { N2Idx = FluidSystem::N2Idx }; typedef Opm::TwoPhaseMaterialTraits<Scalar, liquidPhaseIdx, gasPhaseIdx> MaterialLawTraits; typedef Opm::RegularizedBrooksCorey<MaterialLawTraits> EffMaterialLaw; typedef Opm::EffToAbsLaw<EffMaterialLaw> MaterialLaw; typedef MaterialLaw::Params MaterialLawParams; Scalar T = 273.15 + 25; // initialize the tables of the fluid system Scalar Tmin = T - 1.0; Scalar Tmax = T + 1.0; int nT = 3; Scalar pmin = 0.0; Scalar pmax = 1.25 * 2e6; int np = 100; FluidSystem::init(Tmin, Tmax, nT, pmin, pmax, np); // set the parameters for the capillary pressure law MaterialLawParams matParams; matParams.setResidualSaturation(MaterialLaw::wettingPhaseIdx, 0.0); matParams.setResidualSaturation(MaterialLaw::nonWettingPhaseIdx, 0.0); matParams.setEntryPressure(0); matParams.setLambda(2.0); matParams.finalize(); ImmiscibleFluidState fsRef; // create an fluid state which is consistent // set the fluid temperatures fsRef.setTemperature(T); //////////////// // only liquid //////////////// std::cout << "testing single-phase liquid\n"; // set liquid saturation and pressure fsRef.setSaturation(liquidPhaseIdx, 1.0); fsRef.setPressure(liquidPhaseIdx, 1e6); // set the remaining parameters of the reference fluid state completeReferenceFluidState<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams, liquidPhaseIdx); // check the flash calculation checkImmiscibleFlash<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams); //////////////// // only gas //////////////// std::cout << "testing single-phase gas\n"; // set gas saturation and pressure fsRef.setSaturation(gasPhaseIdx, 1.0); fsRef.setPressure(gasPhaseIdx, 1e6); // set the remaining parameters of the reference fluid state completeReferenceFluidState<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams, gasPhaseIdx); // check the flash calculation checkImmiscibleFlash<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams); //////////////// // both phases //////////////// std::cout << "testing two-phase\n"; // set liquid saturation and pressure fsRef.setSaturation(liquidPhaseIdx, 0.5); fsRef.setPressure(liquidPhaseIdx, 1e6); // set the remaining parameters of the reference fluid state completeReferenceFluidState<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams, liquidPhaseIdx); // check the flash calculation checkImmiscibleFlash<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams); //////////////// // with capillary pressure //////////////// std::cout << "testing two-phase with capillary pressure\n"; MaterialLawParams matParams2; matParams2.setResidualSaturation(MaterialLaw::wettingPhaseIdx, 0.0); matParams2.setResidualSaturation(MaterialLaw::nonWettingPhaseIdx, 0.0); matParams2.setEntryPressure(1e3); matParams2.setLambda(2.0); matParams2.finalize(); // set liquid saturation fsRef.setSaturation(liquidPhaseIdx, 0.5); // set pressure of the liquid phase fsRef.setPressure(liquidPhaseIdx, 1e6); // set the remaining parameters of the reference fluid state completeReferenceFluidState<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams2, liquidPhaseIdx); // check the flash calculation checkImmiscibleFlash<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams2); return 0; }
int main() { typedef double Scalar; typedef Opm::FluidSystems::H2ON2<Scalar, false> FluidSystem; typedef Opm::CompositionalFluidState<Scalar, FluidSystem> CompositionalFluidState; enum { numPhases = FluidSystem::numPhases }; enum { numComponents = FluidSystem::numComponents }; enum { lPhaseIdx = FluidSystem::lPhaseIdx }; enum { gPhaseIdx = FluidSystem::gPhaseIdx }; enum { H2OIdx = FluidSystem::H2OIdx }; enum { N2Idx = FluidSystem::N2Idx }; typedef Opm::TwoPhaseMaterialTraits<Scalar, lPhaseIdx, gPhaseIdx> MaterialTraits; typedef Opm::RegularizedBrooksCorey<MaterialTraits> EffMaterialLaw; typedef Opm::EffToAbsLaw<EffMaterialLaw> MaterialLaw; typedef MaterialLaw::Params MaterialLawParams; Scalar T = 273.15 + 25; // initialize the tables of the fluid system Scalar Tmin = T - 1.0; Scalar Tmax = T + 1.0; int nT = 3; Scalar pmin = 0.0; Scalar pmax = 1.25 * 2e6; int np = 100; FluidSystem::init(Tmin, Tmax, nT, pmin, pmax, np); // set the parameters for the capillary pressure law MaterialLawParams matParams; matParams.setResidualSaturation(MaterialLaw::wPhaseIdx, 0.0); matParams.setResidualSaturation(MaterialLaw::nPhaseIdx, 0.0); matParams.setEntryPressure(0); matParams.setLambda(2.0); matParams.finalize(); CompositionalFluidState fsRef; // create an fluid state which is consistent // set the fluid temperatures fsRef.setTemperature(T); //////////////// // only liquid //////////////// std::cout << "testing single-phase liquid\n"; // set liquid saturation fsRef.setSaturation(lPhaseIdx, 1.0); // set pressure of the liquid phase fsRef.setPressure(lPhaseIdx, 2e5); // set the liquid composition to pure water fsRef.setMoleFraction(lPhaseIdx, N2Idx, 0.0); fsRef.setMoleFraction(lPhaseIdx, H2OIdx, 1.0 - fsRef.moleFraction(lPhaseIdx, N2Idx)); // "complete" the fluid state completeReferenceFluidState<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams, lPhaseIdx); // check the flash calculation checkNcpFlash<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams); //////////////// // only gas //////////////// std::cout << "testing single-phase gas\n"; // set gas saturation fsRef.setSaturation(gPhaseIdx, 1.0); // set pressure of the gas phase fsRef.setPressure(gPhaseIdx, 1e6); // set the gas composition to 99.9% nitrogen and 0.1% water fsRef.setMoleFraction(gPhaseIdx, N2Idx, 0.999); fsRef.setMoleFraction(gPhaseIdx, H2OIdx, 0.001); // "complete" the fluid state completeReferenceFluidState<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams, gPhaseIdx); // check the flash calculation checkNcpFlash<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams); //////////////// // both phases //////////////// std::cout << "testing two-phase\n"; // set saturations fsRef.setSaturation(lPhaseIdx, 0.5); fsRef.setSaturation(gPhaseIdx, 0.5); // set pressures fsRef.setPressure(lPhaseIdx, 1e6); fsRef.setPressure(gPhaseIdx, 1e6); FluidSystem::ParameterCache paramCache; typedef Opm::MiscibleMultiPhaseComposition<Scalar, FluidSystem> MiscibleMultiPhaseComposition; MiscibleMultiPhaseComposition::solve(fsRef, paramCache, /*setViscosity=*/false, /*setEnthalpy=*/false); // check the flash calculation checkNcpFlash<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams); //////////////// // with capillary pressure //////////////// MaterialLawParams matParams2; matParams2.setResidualSaturation(MaterialLaw::wPhaseIdx, 0.0); matParams2.setResidualSaturation(MaterialLaw::nPhaseIdx, 0.0); matParams2.setEntryPressure(1e3); matParams2.setLambda(2.0); matParams2.finalize(); // set gas saturation fsRef.setSaturation(gPhaseIdx, 0.5); fsRef.setSaturation(lPhaseIdx, 0.5); // set pressure of the liquid phase fsRef.setPressure(lPhaseIdx, 1e6); // calulate the capillary pressure typedef Dune::FieldVector<Scalar, numPhases> PhaseVector; PhaseVector pC; MaterialLaw::capillaryPressures(pC, matParams2, fsRef); fsRef.setPressure(gPhaseIdx, fsRef.pressure(lPhaseIdx) + (pC[gPhaseIdx] - pC[lPhaseIdx])); typedef Opm::MiscibleMultiPhaseComposition<Scalar, FluidSystem> MiscibleMultiPhaseComposition; MiscibleMultiPhaseComposition::solve(fsRef, paramCache, /*setViscosity=*/false, /*setEnthalpy=*/false); // check the flash calculation checkNcpFlash<Scalar, FluidSystem, MaterialLaw>(fsRef, matParams2); return 0; }