28#ifndef EWOMS_RICHARDS_NEWTON_METHOD_HH
29#define EWOMS_RICHARDS_NEWTON_METHOD_HH
31#include <dune/common/fvector.hh>
33#include <opm/material/fluidstates/ImmiscibleFluidState.hpp>
48template <
class TypeTag>
63 enum { pressureWIdx = Indices::pressureWIdx };
64 enum { numPhases = FluidSystem::numPhases };
65 enum { liquidPhaseIdx = getPropValue<TypeTag, Properties::LiquidPhaseIndex>() };
66 enum { gasPhaseIdx = getPropValue<TypeTag, Properties::GasPhaseIndex>() };
68 using PhaseVector = Dune::FieldVector<Scalar, numPhases>;
72 : ParentType(simulator)
83 PrimaryVariables& nextValue,
84 const PrimaryVariables& currentValue,
85 const EqVector& update,
89 nextValue = currentValue;
93 if (this->numIterations_ > 4) {
97 const auto& problem = this->simulator_.problem();
100 const MaterialLawParams& matParams =
101 problem.materialLawParams(globalDofIdx, 0);
103 ImmiscibleFluidState<Scalar, FluidSystem> fs;
106 const Scalar T = problem.temperature(globalDofIdx, 0);
107 fs.setTemperature(T);
115 fs.setSaturation(liquidPhaseIdx, 1.0);
116 fs.setSaturation(gasPhaseIdx, 0.0);
118 MaterialLaw::capillaryPressures(pC, matParams, fs);
123 const Scalar pWOld = currentValue[pressureWIdx];
125 std::max(problem.referencePressure(globalDofIdx, 0),
126 pWOld + (pC[gasPhaseIdx] - pC[liquidPhaseIdx]));
131 fs.setPressure(liquidPhaseIdx, pWOld);
132 fs.setPressure(gasPhaseIdx, pNOld);
135 MaterialLaw::saturations(satOld, matParams, fs);
136 satOld[liquidPhaseIdx] = std::max(Scalar{0.0}, satOld[liquidPhaseIdx]);
143 fs.setSaturation(liquidPhaseIdx, satOld[liquidPhaseIdx] - 0.2);
144 fs.setSaturation(gasPhaseIdx, 1.0 - (satOld[liquidPhaseIdx] - 0.2));
145 MaterialLaw::capillaryPressures(pC, matParams, fs);
146 const Scalar pwMin = pNOld - (pC[gasPhaseIdx] - pC[liquidPhaseIdx]);
148 fs.setSaturation(liquidPhaseIdx, satOld[liquidPhaseIdx] + 0.2);
149 fs.setSaturation(gasPhaseIdx, 1.0 - (satOld[liquidPhaseIdx] + 0.2));
150 MaterialLaw::capillaryPressures(pC, matParams, fs);
151 const Scalar pwMax = pNOld - (pC[gasPhaseIdx] - pC[liquidPhaseIdx]);
157 const Scalar pW = std::clamp(nextValue[pressureWIdx], pwMin, pwMax);
158 nextValue[pressureWIdx] = pW;
The multi-dimensional Newton method.
Definition: newtonmethod.hh:100
A Richards model specific Newton method.
Definition: richardsnewtonmethod.hh:50
RichardsNewtonMethod(Simulator &simulator)
Definition: richardsnewtonmethod.hh:71
void updatePrimaryVariables_(unsigned globalDofIdx, PrimaryVariables &nextValue, const PrimaryVariables ¤tValue, const EqVector &update, const EqVector &)
Update a single primary variables object.
Definition: richardsnewtonmethod.hh:82
friend ParentType
Definition: richardsnewtonmethod.hh:77
Defines the common properties required by the porous medium multi-phase models.
Definition: blackoilboundaryratevector.hh:39
typename Properties::Detail::GetPropImpl< TypeTag, Property >::type::type GetPropType
get the type alias defined in the property (equivalent to old macro GET_PROP_TYPE(....
Definition: propertysystem.hh:233
Contains the property declarations for the Richards model.