This problem simulates an input file given in the data format used by the commercial ECLiPSE simulator. More...

#include <FlowProblemBlackoil.hpp>

Inheritance diagram for Opm::FlowProblemBlackoil< TypeTag >:
Inheritance graph

Public Types

using FlowProblemType = FlowProblem< TypeTag >
 
using TabulatedTwoDFunction = UniformXTabulated2DFunction< Scalar >
 
using TabulatedFunction = Tabulated1DFunction< Scalar >
 

Public Member Functions

 FlowProblemBlackoil (Simulator &simulator)
 
void beginEpisode () override
 Called by the simulator before an episode begins. More...
 
void beginTimeStep () override
 Called by the simulator before each time integration. More...
 
void finishInit ()
 Called by the Opm::Simulator in order to initialize the problem. More...
 
void endTimeStep () override
 Called by the simulator after each time integration. More...
 
void endStepApplyAction ()
 
void endEpisode () override
 Called by the simulator after the end of an episode. More...
 
void writeReports (const SimulatorTimer &timer)
 
void writeOutput (const bool verbose) override
 Write the requested quantities of the current solution into the output files. More...
 
void finalizeOutput ()
 
void initialSolutionApplied () override
 Callback used by the model to indicate that the initial solution has been determined for all degrees of freedom. More...
 
void addToSourceDense (RateVector &rate, unsigned globalDofIdx, unsigned timeIdx) const override
 
template<class LhsEval >
LhsEval permFactTransMultiplier (const IntensiveQuantities &intQuants, unsigned elementIdx) const
 Calculate the transmissibility multiplier due to porosity reduction. More...
 
const InitialFluidState & initialFluidState (unsigned globalDofIdx) const
 
std::vector< InitialFluidState > & initialFluidStates ()
 
const std::vector< InitialFluidState > & initialFluidStates () const
 
const EclipseIO & eclIO () const
 
void setSubStepReport (const SimulatorReportSingle &report)
 
void setSimulationReport (const SimulatorReport &report)
 
InitialFluidState boundaryFluidState (unsigned globalDofIdx, const int directionId) const
 
const EclWriterTypeeclWriter () const
 
EclWriterTypeeclWriter ()
 
Scalar maxGasDissolutionFactor (unsigned timeIdx, unsigned globalDofIdx) const
 Returns the maximum value of the gas dissolution factor at the current time for a given degree of freedom. More...
 
Scalar maxOilVaporizationFactor (unsigned timeIdx, unsigned globalDofIdx) const
 Returns the maximum value of the oil vaporization factor at the current time for a given degree of freedom. More...
 
bool recycleFirstIterationStorage () const
 Return if the storage term of the first iteration is identical to the storage term for the solution of the previous time step. More...
 
template<class Context >
void initial (PrimaryVariables &values, const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Evaluate the initial value for a control volume. More...
 
Scalar drsdtcon (unsigned elemIdx, int episodeIdx) const
 
bool drsdtconIsActive (unsigned elemIdx, int episodeIdx) const
 
template<class Context >
void boundary (BoundaryRateVector &values, const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Evaluate the boundary conditions for a boundary segment. More...
 
void readSolutionFromOutputModule (const int restart_step, bool fip_init)
 Read simulator solution state from the outputmodule (used with restart) More...
 
Scalar thresholdPressure (unsigned elem1Idx, unsigned elem2Idx) const
 
const FlowThresholdPressure< TypeTag > & thresholdPressure () const
 
FlowThresholdPressure< TypeTag > & thresholdPressure ()
 
const ModuleParams & moduleParams () const
 
template<class Serializer >
void serializeOp (Serializer &serializer)
 
template<class Context >
Scalar porosity (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 
template<class Context >
unsigned pvtRegionIndex (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Returns the index of the relevant region for thermodynmic properties. More...
 
void prefetch (const Element &elem) const
 
template<class Restarter >
void deserialize (Restarter &res)
 This method restores the complete state of the problem and its sub-objects from disk. More...
 
template<class Restarter >
void serialize (Restarter &res)
 This method writes the complete state of the problem and its subobjects to disk. More...
 
int episodeIndex () const
 
void beginIteration ()
 Called by the simulator before each Newton-Raphson iteration. More...
 
void endIteration ()
 Called by the simulator after each Newton-Raphson iteration. More...
 
template<class Context >
const DimMatrixintrinsicPermeability (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 
const DimMatrixintrinsicPermeability (unsigned globalElemIdx) const
 This method returns the intrinsic permeability tensor given a global element index. More...
 
template<class Context >
Scalar transmissibility (const Context &context, unsigned fromDofLocalIdx, unsigned toDofLocalIdx) const
 
Scalar transmissibility (unsigned globalCenterElemIdx, unsigned globalElemIdx) const
 Direct access to the transmissibility between two elements. More...
 
template<class Context >
Scalar diffusivity (const Context &context, unsigned fromDofLocalIdx, unsigned toDofLocalIdx) const
 
Scalar diffusivity (const unsigned globalCellIn, const unsigned globalCellOut) const
 
Scalar dispersivity (const unsigned globalCellIn, const unsigned globalCellOut) const
 
Scalar thermalTransmissibilityBoundary (const unsigned globalSpaceIdx, const unsigned boundaryFaceIdx) const
 Direct access to a boundary transmissibility. More...
 
template<class Context >
Scalar transmissibilityBoundary (const Context &elemCtx, unsigned boundaryFaceIdx) const
 
Scalar transmissibilityBoundary (const unsigned globalSpaceIdx, const unsigned boundaryFaceIdx) const
 Direct access to a boundary transmissibility. More...
 
Scalar thermalHalfTransmissibility (const unsigned globalSpaceIdxIn, const unsigned globalSpaceIdxOut) const
 
template<class Context >
Scalar thermalHalfTransmissibilityIn (const Context &context, unsigned faceIdx, unsigned timeIdx) const
 
template<class Context >
Scalar thermalHalfTransmissibilityOut (const Context &context, unsigned faceIdx, unsigned timeIdx) const
 
template<class Context >
Scalar thermalHalfTransmissibilityBoundary (const Context &elemCtx, unsigned boundaryFaceIdx) const
 
const Vanguard::TransmissibilityType & eclTransmissibilities () const
 Return a reference to the object that handles the "raw" transmissibilities. More...
 
const TracerModeltracerModel () const
 
TracerModeltracerModel ()
 
Scalar porosity (unsigned globalSpaceIdx, unsigned timeIdx) const
 Direct indexed access to the porosity. More...
 
template<class Context >
Scalar dofCenterDepth (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Returns the depth of an degree of freedom [m]. More...
 
Scalar dofCenterDepth (unsigned globalSpaceIdx) const
 Direct indexed acces to the depth of an degree of freedom [m]. More...
 
template<class Context >
Scalar rockCompressibility (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 
Scalar rockCompressibility (unsigned globalSpaceIdx) const
 
template<class Context >
Scalar rockReferencePressure (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 
Scalar rockReferencePressure (unsigned globalSpaceIdx) const
 
template<class Context >
const MaterialLawParamsmaterialLawParams (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 
const MaterialLawParamsmaterialLawParams (unsigned globalDofIdx) const
 
const MaterialLawParamsmaterialLawParams (unsigned globalDofIdx, FaceDir::DirEnum facedir) const
 
template<class Context >
const SolidEnergyLawParamssolidEnergyLawParams (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Return the parameters for the energy storage law of the rock. More...
 
const SolidEnergyLawParamssolidEnergyLawParams (unsigned globalSpaceIdx, unsigned) const
 
template<class Context >
const ThermalConductionLawParamsthermalConductionLawParams (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 
const ThermalConductionLawParamsthermalConductionLawParams (unsigned globalSpaceIdx, unsigned) const
 
std::shared_ptr< const EclMaterialLawManagermaterialLawManager () const
 Returns the ECL material law manager. More...
 
std::shared_ptr< EclMaterialLawManagermaterialLawManager ()
 
template<class FluidState , class ... Args>
void updateRelperms (std::array< Evaluation, numPhases > &mobility, DirectionalMobilityPtr &dirMob, FluidState &fluidState, unsigned globalSpaceIdx) const
 
unsigned pvtRegionIndex (unsigned elemIdx) const
 Returns the index the relevant PVT region given a cell index. More...
 
template<class Context >
unsigned satnumRegionIndex (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Returns the index of the relevant region for thermodynmic properties. More...
 
unsigned satnumRegionIndex (unsigned elemIdx) const
 Returns the index the relevant saturation function region given a cell index. More...
 
template<class Context >
unsigned miscnumRegionIndex (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Returns the index of the relevant region for thermodynmic properties. More...
 
unsigned miscnumRegionIndex (unsigned elemIdx) const
 Returns the index the relevant MISC region given a cell index. More...
 
template<class Context >
unsigned plmixnumRegionIndex (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Returns the index of the relevant region for thermodynmic properties. More...
 
unsigned plmixnumRegionIndex (unsigned elemIdx) const
 Returns the index the relevant PLMIXNUM (for polymer module) region given a cell index. More...
 
template<class Context >
Scalar maxPolymerAdsorption (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Returns the max polymer adsorption value. More...
 
Scalar maxPolymerAdsorption (unsigned elemIdx) const
 Returns the max polymer adsorption value. More...
 
std::string name () const
 The problem name. More...
 
template<class Context >
Scalar temperature (const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 
Scalar temperature (unsigned globalDofIdx, unsigned) const
 
Scalar maxOilSaturation (unsigned globalDofIdx) const
 Returns an element's historic maximum oil phase saturation that was observed during the simulation. More...
 
void setMaxOilSaturation (unsigned globalDofIdx, Scalar value)
 Sets an element's maximum oil phase saturation observed during the simulation. More...
 
template<class Context >
void source (RateVector &rate, const Context &context, unsigned spaceIdx, unsigned timeIdx) const
 Evaluate the source term for all phases within a given sub-control-volume. More...
 
void source (RateVector &rate, unsigned globalDofIdx, unsigned timeIdx) const
 
const WellModelwellModel () const
 Returns a reference to the ECL well manager used by the problem. More...
 
WellModelwellModel ()
 
const AquiferModelaquiferModel () const
 
AquiferModelmutableAquiferModel ()
 
bool nonTrivialBoundaryConditions () const
 
Scalar nextTimeStepSize () const
 Propose the size of the next time step to the simulator. More...
 
template<class LhsEval >
LhsEval rockCompPoroMultiplier (const IntensiveQuantities &intQuants, unsigned elementIdx) const
 Calculate the porosity multiplier due to water induced rock compaction. More...
 
template<class LhsEval >
LhsEval rockCompTransMultiplier (const IntensiveQuantities &intQuants, unsigned elementIdx) const
 Calculate the transmissibility multiplier due to water induced rock compaction. More...
 
template<class LhsEval >
LhsEval wellTransMultiplier (const IntensiveQuantities &intQuants, unsigned elementIdx) const
 Return the well transmissibility multiplier due to rock changes. More...
 
std::pair< BCType, RateVectorboundaryCondition (const unsigned int globalSpaceIdx, const int directionId) const
 
Scalar maxWaterSaturation (unsigned globalDofIdx) const
 Returns an element's historic maximum water phase saturation that was observed during the simulation. More...
 
Scalar minOilPressure (unsigned globalDofIdx) const
 Returns an element's historic minimum pressure of the oil phase that was observed during the simulation. More...
 
Scalar overburdenPressure (unsigned elementIdx) const
 Get the pressure of the overburden. More...
 
Scalar referencePorosity (unsigned elementIdx, unsigned timeIdx) const
 Returns the porosity of an element. More...
 
Scalar rockFraction (unsigned elementIdx, unsigned timeIdx) const
 Returns the rockFraction of an element. More...
 
void setPorosity (Scalar poro, unsigned elementIdx, unsigned timeIdx=0)
 Sets the porosity of an element. More...
 
Scalar solventSaturation (unsigned elemIdx) const
 Returns the initial solvent saturation for a given a cell index. More...
 
Scalar solventRsw (unsigned elemIdx) const
 Returns the initial solvent dissolved in water for a given a cell index. More...
 
Scalar polymerConcentration (unsigned elemIdx) const
 Returns the initial polymer concentration for a given a cell index. More...
 
Scalar polymerMolecularWeight (const unsigned elemIdx) const
 Returns the polymer molecule weight for a given cell index. More...
 
Scalar microbialConcentration (unsigned elemIdx) const
 Returns the initial microbial concentration for a given a cell index. More...
 
Scalar oxygenConcentration (unsigned elemIdx) const
 Returns the initial oxygen concentration for a given a cell index. More...
 
Scalar ureaConcentration (unsigned elemIdx) const
 Returns the initial urea concentration for a given a cell index. More...
 
Scalar biofilmVolumeFraction (unsigned elemIdx) const
 Returns the initial biofilm volume fraction for a given a cell index. More...
 
Scalar calciteVolumeFraction (unsigned elemIdx) const
 Returns the initial calcite volume fraction for a given a cell index. More...
 
bool vapparsActive (int episodeIdx) const
 
int numPressurePointsEquil () const
 
bool operator== (const FlowGenericProblem &rhs) const
 

Static Public Member Functions

static void registerParameters ()
 Registers all available parameters for the problem and the model. More...
 
static int handlePositionalParameter (std::function< void(const std::string &, const std::string &)> addKey, std::set< std::string > &seenParams, std::string &errorMsg, int, const char **argv, int paramIdx, int)
 Handles positional command line parameters. More...
 
static FlowGenericProblem serializationTestObject (const EclipseState &eclState, const Schedule &schedule, const GetPropType< TypeTag, Properties::GridView > &gridView)
 
static std::string helpPreamble (int, const char **argv)
 
static std::string briefDescription ()
 
static void setBriefDescription (const std::string &msg)
 Specifies the string returned by briefDescription() More...
 

Protected Types

enum  { dim = GridView::dimension }
 
enum  { dimWorld = GridView::dimensionworld }
 
enum  { numEq = getPropValue<TypeTag, Properties::NumEq>() }
 
enum  { numPhases = FluidSystem::numPhases }
 
enum  { numComponents = FluidSystem::numComponents }
 
enum  { enableBioeffects = getPropValue<TypeTag, Properties::EnableBioeffects>() }
 
enum  { enableBrine = getPropValue<TypeTag, Properties::EnableBrine>() }
 
enum  { enableConvectiveMixing = getPropValue<TypeTag, Properties::EnableConvectiveMixing>() }
 
enum  { enableDiffusion = getPropValue<TypeTag, Properties::EnableDiffusion>() }
 
enum  { enableDispersion = getPropValue<TypeTag, Properties::EnableDispersion>() }
 
enum  { enableEnergy = getPropValue<TypeTag, Properties::EnableEnergy>() }
 
enum  { enableExperiments = getPropValue<TypeTag, Properties::EnableExperiments>() }
 
enum  { enableExtbo = getPropValue<TypeTag, Properties::EnableExtbo>() }
 
enum  { enableFoam = getPropValue<TypeTag, Properties::EnableFoam>() }
 
enum  { enableMICP = Indices::enableMICP }
 
enum  { enablePolymer = getPropValue<TypeTag, Properties::EnablePolymer>() }
 
enum  { enablePolymerMolarWeight = getPropValue<TypeTag, Properties::EnablePolymerMW>() }
 
enum  { enableSaltPrecipitation = getPropValue<TypeTag, Properties::EnableSaltPrecipitation>() }
 
enum  { enableSolvent = getPropValue<TypeTag, Properties::EnableSolvent>() }
 
enum  { enableTemperature = getPropValue<TypeTag, Properties::EnableTemperature>() }
 
enum  { enableThermalFluxBoundaries = getPropValue<TypeTag, Properties::EnableThermalFluxBoundaries>() }
 
enum  { gasPhaseIdx = FluidSystem::gasPhaseIdx }
 
enum  { oilPhaseIdx = FluidSystem::oilPhaseIdx }
 
enum  { waterPhaseIdx = FluidSystem::waterPhaseIdx }
 
enum  { gasCompIdx = FluidSystem::gasCompIdx }
 
enum  { oilCompIdx = FluidSystem::oilCompIdx }
 
enum  { waterCompIdx = FluidSystem::waterCompIdx }
 
using BaseType = FlowGenericProblem< GetPropType< TypeTag, Properties::GridView >, GetPropType< TypeTag, Properties::FluidSystem > >
 
using ParentType = GetPropType< TypeTag, Properties::BaseProblem >
 
using Implementation = GetPropType< TypeTag, Properties::Problem >
 
using Stencil = GetPropType< TypeTag, Properties::Stencil >
 
using Element = typename GridView::template Codim< 0 >::Entity
 
using EclMaterialLawManager = typename GetProp< TypeTag, Properties::MaterialLaw >::EclMaterialLawManager
 
using EclThermalLawManager = typename GetProp< TypeTag, Properties::SolidEnergyLaw >::EclThermalLawManager
 
using MaterialLawParams = typename EclMaterialLawManager::MaterialLawParams
 
using SolidEnergyLawParams = typename EclThermalLawManager::SolidEnergyLawParams
 
using ThermalConductionLawParams = typename EclThermalLawManager::ThermalConductionLawParams
 
using DofMapper = GetPropType< TypeTag, Properties::DofMapper >
 
using Evaluation = GetPropType< TypeTag, Properties::Evaluation >
 
using WellModel = GetPropType< TypeTag, Properties::WellModel >
 
using AquiferModel = GetPropType< TypeTag, Properties::AquiferModel >
 
using Toolbox = MathToolbox< Evaluation >
 
using TracerModel = GetPropType< TypeTag, Properties::TracerModel >
 
using DirectionalMobilityPtr = Utility::CopyablePtr< DirectionalMobility< TypeTag > >
 
using Grid = std::remove_cv_t< typename std::remove_reference< decltype(gridView_.grid())>::type >
 
using LookUpData = Opm::LookUpData< Grid, GetPropType< TypeTag, Properties::GridView > >
 

Protected Member Functions

void updateExplicitQuantities_ (int episodeIdx, int timeStepSize, const bool first_step_after_restart) override
 
void updateMaxPolymerAdsorption_ ()
 
bool updateMaxPolymerAdsorption_ (unsigned compressedDofIdx, const IntensiveQuantities &iq)
 
void computeAndSetEqWeights_ ()
 
bool updateCompositionChangeLimits_ ()
 
void readEclRestartSolution_ ()
 
void readEquilInitialCondition_ () override
 
void readExplicitInitialCondition_ () override
 
void processRestartSaturations_ (InitialFluidState &elemFluidState, Scalar &solventSaturation)
 
void readInitialCondition_ () override
 
void handleSolventBC (const BCProp::BCFace &bc, RateVector &rate) const override
 
void handlePolymerBC (const BCProp::BCFace &bc, RateVector &rate) const override
 
void handleMicrBC (const BCProp::BCFace &bc, RateVector &rate) const override
 
void handleOxygBC (const BCProp::BCFace &bc, RateVector &rate) const override
 
void handleUreaBC (const BCProp::BCFace &bc, RateVector &rate) const override
 
void updateExplicitQuantities_ (const bool first_step_after_restart)
 
bool satfuncConsistencyRequirementsMet () const
 
template<class UpdateFunc >
void updateProperty_ (const std::string &failureMsg, UpdateFunc func)
 
bool updateMaxOilSaturation_ ()
 
bool updateMaxOilSaturation_ (unsigned compressedDofIdx, const IntensiveQuantities &iq)
 
bool updateMaxWaterSaturation_ ()
 
bool updateMaxWaterSaturation_ (unsigned compressedDofIdx, const IntensiveQuantities &iq)
 
bool updateMinPressure_ ()
 
bool updateMinPressure_ (unsigned compressedDofIdx, const IntensiveQuantities &iq)
 
std::function< std::vector< double >(const FieldPropsManager &, const std::string &)> fieldPropDoubleOnLeafAssigner_ ()
 
template<typename IntType >
std::function< std::vector< IntType >(const FieldPropsManager &, const std::string &, bool)> fieldPropIntTypeOnLeafAssigner_ ()
 
void readMaterialParameters_ ()
 
void readThermalParameters_ ()
 
void updateReferencePorosity_ ()
 
bool updateHysteresis_ ()
 
bool updateHysteresis_ (unsigned compressedDofIdx, const IntensiveQuantities &iq)
 
Scalar getRockCompTransMultVal (std::size_t dofIdx) const
 
void updatePffDofData_ ()
 
void readBoundaryConditions_ ()
 
Scalar limitNextTimeStepSize_ (Scalar dtNext) const
 
int refPressurePhaseIdx_ () const
 
void updateRockCompTransMultVal_ ()
 
template<class LhsEval >
LhsEval computeRockCompTransMultiplier_ (const IntensiveQuantities &intQuants, unsigned elementIdx) const
 Calculate the transmissibility multiplier due to water induced rock compaction. More...
 
void initFluidSystem_ ()
 
bool shouldWriteOutput () const
 Always returns true. The ecl output writer takes care of the rest. More...
 
bool shouldWriteRestartFile () const
 Returns true if an eWoms restart file should be written to disk. More...
 
bool beginEpisode_ (bool enableExperiments, int episodeIdx)
 
void beginTimeStep_ (bool enableExperiments, int episodeIdx, int timeStepIndex, Scalar startTime, Scalar time, Scalar timeStepSize, Scalar endTime)
 
void readRockParameters_ (const std::vector< Scalar > &cellCenterDepths, std::function< std::array< int, 3 >(const unsigned)> ijkIndex)
 
void readRockCompactionParameters_ ()
 
void readBlackoilExtentionsInitialConditions_ (std::size_t numDof, bool enableSolvent, bool enablePolymer, bool enablePolymerMolarWeight, bool enableBioeffects, bool enableMICP)
 
void updatePvtnum_ ()
 
void updateSatnum_ ()
 
void updateMiscnum_ ()
 
void updatePlmixnum_ ()
 
std::function< unsigned(unsigned)> lookupIdxOnLevelZeroAssigner_ ()
 

Protected Attributes

FlowThresholdPressure< TypeTag > thresholdPressures_
 
std::vector< InitialFluidState > initialFluidStates_
 
bool enableEclOutput_
 
std::unique_ptr< EclWriterTypeeclWriter_
 
const Scalar smallSaturationTolerance_ = 1.e-6
 
MixingRateControls< FluidSystemmixControls_
 
ActionHandler< Scalar, IndexTraits > actionHandler_
 
ModuleParams moduleParams_
 
HybridNewton hybridNewton_
 
Vanguard::TransmissibilityType transmissibilities_
 
std::shared_ptr< EclMaterialLawManagermaterialLawManager_
 
std::shared_ptr< EclThermalLawManagerthermalLawManager_
 
GlobalEqVector drift_
 
WellModel wellModel_
 
AquiferModel aquiferModel_
 
PffGridVector< GridView, Stencil, PffDofData_, DofMapperpffDofData_
 
TracerModel tracerModel_
 
BCData< int > bcindex_
 
bool nonTrivialBoundaryConditions_ = false
 
bool first_step_ = true
 
const EclipseState & eclState_
 
const Schedule & schedule_
 
const GetPropType< TypeTag, Properties::GridView > & gridView_
 
std::array< std::vector< Scalar >, 2 > referencePorosity_
 
std::vector< int > pvtnum_
 
std::vector< unsigned short > satnum_
 
std::vector< unsigned short > miscnum_
 
std::vector< unsigned short > plmixnum_
 
std::vector< RockParams > rockParams_
 
std::vector< unsigned short > rockTableIdx_
 
std::vector< TabulatedTwoDFunctionrockCompPoroMultWc_
 
std::vector< TabulatedTwoDFunctionrockCompTransMultWc_
 
std::vector< TabulatedFunctionrockCompPoroMult_
 
std::vector< TabulatedFunctionrockCompTransMult_
 
std::vector< ScalarrockCompTransMultVal_
 
PolymerSolutionContainer< Scalarpolymer_
 
std::vector< ScalarmaxOilSaturation_
 
std::vector< ScalarmaxWaterSaturation_
 
std::vector< ScalarminRefPressure_
 
std::vector< ScalaroverburdenPressure_
 
std::vector< ScalarsolventSaturation_
 
std::vector< ScalarsolventRsw_
 
BioeffectsSolutionContainer< Scalarbioeffects_
 
bool enableTuning_
 
Scalar initialTimeStepSize_
 
Scalar maxTimeStepAfterWellEvent_
 
int numPressurePointsEquil_
 
bool enableDriftCompensation_
 
bool explicitRockCompaction_
 
const LookUpData lookUpData_
 

Static Protected Attributes

static std::string briefDescription_
 

Detailed Description

template<class TypeTag>
class Opm::FlowProblemBlackoil< TypeTag >

This problem simulates an input file given in the data format used by the commercial ECLiPSE simulator.

Member Typedef Documentation

◆ AquiferModel

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::AquiferModel = GetPropType<TypeTag, Properties::AquiferModel>
protectedinherited

◆ BaseType

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::BaseType = FlowGenericProblem<GetPropType<TypeTag, Properties::GridView>, GetPropType<TypeTag, Properties::FluidSystem> >
protectedinherited

◆ DirectionalMobilityPtr

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::DirectionalMobilityPtr = Utility::CopyablePtr<DirectionalMobility<TypeTag> >
protectedinherited

◆ DofMapper

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::DofMapper = GetPropType<TypeTag, Properties::DofMapper>
protectedinherited

◆ EclMaterialLawManager

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::EclMaterialLawManager = typename GetProp<TypeTag, Properties::MaterialLaw>::EclMaterialLawManager
protectedinherited

◆ EclThermalLawManager

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::EclThermalLawManager = typename GetProp<TypeTag, Properties::SolidEnergyLaw>::EclThermalLawManager
protectedinherited

◆ Element

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::Element = typename GridView::template Codim<0>::Entity
protectedinherited

◆ Evaluation

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::Evaluation = GetPropType<TypeTag, Properties::Evaluation>
protectedinherited

◆ FlowProblemType

template<class TypeTag >
using Opm::FlowProblemBlackoil< TypeTag >::FlowProblemType = FlowProblem<TypeTag>

◆ Grid

using Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Grid = std::remove_cv_t< typename std::remove_reference<decltype(gridView_.grid())>::type>
protectedinherited

◆ Implementation

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::Implementation = GetPropType<TypeTag, Properties::Problem>
protectedinherited

◆ LookUpData

using Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::LookUpData = Opm::LookUpData<Grid,GetPropType< TypeTag, Properties::GridView > >
protectedinherited

◆ MaterialLawParams

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::MaterialLawParams = typename EclMaterialLawManager::MaterialLawParams
protectedinherited

◆ ParentType

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::ParentType = GetPropType<TypeTag, Properties::BaseProblem>
protectedinherited

◆ SolidEnergyLawParams

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::SolidEnergyLawParams = typename EclThermalLawManager::SolidEnergyLawParams
protectedinherited

◆ Stencil

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::Stencil = GetPropType<TypeTag, Properties::Stencil>
protectedinherited

◆ TabulatedFunction

using Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::TabulatedFunction = Tabulated1DFunction<Scalar>
inherited

◆ TabulatedTwoDFunction

using Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::TabulatedTwoDFunction = UniformXTabulated2DFunction<Scalar>
inherited

◆ ThermalConductionLawParams

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::ThermalConductionLawParams = typename EclThermalLawManager::ThermalConductionLawParams
protectedinherited

◆ Toolbox

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::Toolbox = MathToolbox<Evaluation>
protectedinherited

◆ TracerModel

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::TracerModel = GetPropType<TypeTag, Properties::TracerModel>
protectedinherited

◆ WellModel

template<class TypeTag >
using Opm::FlowProblem< TypeTag >::WellModel = GetPropType<TypeTag, Properties::WellModel>
protectedinherited

Member Enumeration Documentation

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
dim 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
dimWorld 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
numEq 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
numPhases 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
numComponents 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableBioeffects 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableBrine 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableConvectiveMixing 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableDiffusion 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableDispersion 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableEnergy 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableExperiments 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableExtbo 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableFoam 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableMICP 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enablePolymer 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enablePolymerMolarWeight 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableSaltPrecipitation 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableSolvent 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableTemperature 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
enableThermalFluxBoundaries 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
gasPhaseIdx 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
oilPhaseIdx 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
waterPhaseIdx 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
gasCompIdx 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
oilCompIdx 

◆ anonymous enum

template<class TypeTag >
anonymous enum
protectedinherited
Enumerator
waterCompIdx 

Constructor & Destructor Documentation

◆ FlowProblemBlackoil()

Member Function Documentation

◆ addToSourceDense()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::addToSourceDense ( RateVector rate,
unsigned  globalDofIdx,
unsigned  timeIdx 
) const
inlineoverridevirtual

◆ aquiferModel()

template<class TypeTag >
const AquiferModel & Opm::FlowProblem< TypeTag >::aquiferModel ( ) const
inlineinherited

◆ beginEpisode()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::beginEpisode ( )
inlineoverridevirtual

Called by the simulator before an episode begins.

Reimplemented from Opm::FlowProblem< TypeTag >.

References Opm::FlowProblemBlackoil< TypeTag >::actionHandler_, and Opm::FlowProblem< TypeTag >::beginEpisode().

◆ beginEpisode_()

bool Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::beginEpisode_ ( bool  enableExperiments,
int  episodeIdx 
)
protectedinherited

◆ beginIteration()

template<class TypeTag >
void Opm::FlowProblem< TypeTag >::beginIteration ( )
inlineinherited

◆ beginTimeStep()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::beginTimeStep ( )
inlineoverridevirtual

◆ beginTimeStep_()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::beginTimeStep_ ( bool  enableExperiments,
int  episodeIdx,
int  timeStepIndex,
Scalar  startTime,
Scalar  time,
Scalar  timeStepSize,
Scalar  endTime 
)
protectedinherited

◆ biofilmVolumeFraction()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::biofilmVolumeFraction ( unsigned  elemIdx) const
inherited

Returns the initial biofilm volume fraction for a given a cell index.

◆ boundary()

template<class TypeTag >
template<class Context >
void Opm::FlowProblemBlackoil< TypeTag >::boundary ( BoundaryRateVector &  values,
const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inline

Evaluate the boundary conditions for a boundary segment.

Parameters
valuesStores the fluxes over the boundary segment.
contextThe object representing the execution context from which this method is called.
spaceIdxThe local index of the spatial entity which represents the boundary segment.
timeIdxThe index used for the time discretization

Reservoir simulation uses no-flow conditions as default for all boundaries.

◆ boundaryCondition()

◆ boundaryFluidState()

template<class TypeTag >
InitialFluidState Opm::FlowProblemBlackoil< TypeTag >::boundaryFluidState ( unsigned  globalDofIdx,
const int  directionId 
) const
inline

◆ briefDescription()

std::string Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::briefDescription
staticinherited

Returns a human readable description of the problem for the help message.

The problem description is printed as part of the –help message. It is optional and should not exceed one or two lines of text.

◆ calciteVolumeFraction()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::calciteVolumeFraction ( unsigned  elemIdx) const
inherited

Returns the initial calcite volume fraction for a given a cell index.

◆ computeAndSetEqWeights_()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::computeAndSetEqWeights_ ( )
inlineprotected

◆ computeRockCompTransMultiplier_()

◆ deserialize()

template<class TypeTag >
template<class Restarter >
void Opm::FlowProblem< TypeTag >::deserialize ( Restarter &  res)
inlineinherited

This method restores the complete state of the problem and its sub-objects from disk.

The serialization format used by this method is ad-hoc. It is the inverse of the serialize() method.

Template Parameters
RestarterThe deserializer type
Parameters
resThe deserializer object

References Opm::FlowProblem< TypeTag >::aquiferModel_, Opm::FlowProblem< TypeTag >::beginEpisode(), and Opm::FlowProblem< TypeTag >::wellModel_.

◆ diffusivity() [1/2]

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::diffusivity ( const Context &  context,
unsigned  fromDofLocalIdx,
unsigned  toDofLocalIdx 
) const
inlineinherited

◆ diffusivity() [2/2]

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::diffusivity ( const unsigned  globalCellIn,
const unsigned  globalCellOut 
) const
inlineinherited

give the transmissibility for a face i.e. pair. should be symmetric?

References Opm::FlowProblem< TypeTag >::transmissibilities_.

◆ dispersivity()

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::dispersivity ( const unsigned  globalCellIn,
const unsigned  globalCellOut 
) const
inlineinherited

give the dispersivity for a face i.e. pair.

References Opm::FlowProblem< TypeTag >::transmissibilities_.

◆ dofCenterDepth() [1/2]

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::dofCenterDepth ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

Returns the depth of an degree of freedom [m].

For ECL problems this is defined as the average of the depth of an element and is thus slightly different from the depth of an element's centroid.

References Opm::FlowProblem< TypeTag >::dofCenterDepth().

Referenced by Opm::FlowProblem< TypeTag >::dofCenterDepth().

◆ dofCenterDepth() [2/2]

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::dofCenterDepth ( unsigned  globalSpaceIdx) const
inlineinherited

Direct indexed acces to the depth of an degree of freedom [m].

For ECL problems this is defined as the average of the depth of an element and is thus slightly different from the depth of an element's centroid.

◆ drsdtcon()

template<class TypeTag >
Scalar Opm::FlowProblemBlackoil< TypeTag >::drsdtcon ( unsigned  elemIdx,
int  episodeIdx 
) const
inline

◆ drsdtconIsActive()

template<class TypeTag >
bool Opm::FlowProblemBlackoil< TypeTag >::drsdtconIsActive ( unsigned  elemIdx,
int  episodeIdx 
) const
inline

◆ eclIO()

template<class TypeTag >
const EclipseIO & Opm::FlowProblemBlackoil< TypeTag >::eclIO ( ) const
inline

◆ eclTransmissibilities()

template<class TypeTag >
const Vanguard::TransmissibilityType & Opm::FlowProblem< TypeTag >::eclTransmissibilities ( ) const
inlineinherited

Return a reference to the object that handles the "raw" transmissibilities.

References Opm::FlowProblem< TypeTag >::transmissibilities_.

◆ eclWriter() [1/2]

template<class TypeTag >
EclWriterType & Opm::FlowProblemBlackoil< TypeTag >::eclWriter ( )
inline

◆ eclWriter() [2/2]

template<class TypeTag >
const EclWriterType & Opm::FlowProblemBlackoil< TypeTag >::eclWriter ( ) const
inline

◆ endEpisode()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::endEpisode ( )
inlineoverridevirtual

Called by the simulator after the end of an episode.

Reimplemented from Opm::FlowProblem< TypeTag >.

◆ endIteration()

template<class TypeTag >
void Opm::FlowProblem< TypeTag >::endIteration ( )
inlineinherited

◆ endStepApplyAction()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::endStepApplyAction ( )
inline

◆ endTimeStep()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::endTimeStep ( )
inlineoverridevirtual

Called by the simulator after each time integration.

Reimplemented from Opm::FlowProblem< TypeTag >.

◆ episodeIndex()

◆ fieldPropDoubleOnLeafAssigner_()

template<class TypeTag >
std::function< std::vector< double >(const FieldPropsManager &, const std::string &)> Opm::FlowProblem< TypeTag >::fieldPropDoubleOnLeafAssigner_ ( )
inlineprotectedinherited

◆ fieldPropIntTypeOnLeafAssigner_()

template<class TypeTag >
template<typename IntType >
std::function< std::vector< IntType >(const FieldPropsManager &, const std::string &, bool)> Opm::FlowProblem< TypeTag >::fieldPropIntTypeOnLeafAssigner_ ( )
inlineprotectedinherited

◆ finalizeOutput()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::finalizeOutput ( )
inline

◆ finishInit()

◆ getRockCompTransMultVal()

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::getRockCompTransMultVal ( std::size_t  dofIdx) const
inlineprotectedinherited

◆ handleMicrBC()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::handleMicrBC ( const BCProp::BCFace &  bc,
RateVector rate 
) const
inlineoverrideprotectedvirtual

◆ handleOxygBC()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::handleOxygBC ( const BCProp::BCFace &  bc,
RateVector rate 
) const
inlineoverrideprotectedvirtual

◆ handlePolymerBC()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::handlePolymerBC ( const BCProp::BCFace &  bc,
RateVector rate 
) const
inlineoverrideprotectedvirtual

◆ handlePositionalParameter()

template<class TypeTag >
static int Opm::FlowProblem< TypeTag >::handlePositionalParameter ( std::function< void(const std::string &, const std::string &)>  addKey,
std::set< std::string > &  seenParams,
std::string &  errorMsg,
int  ,
const char **  argv,
int  paramIdx,
int   
)
inlinestaticinherited

Handles positional command line parameters.

Positional parameters are parameters that are not prefixed by any parameter name.

Parameters
seenParamsThe parameters which have already been seen in the current context
errorMsgIf the positional argument cannot be handled, this is the reason why
argcThe total number of command line parameters
argvThe string value of the command line parameters
paramIdxThe index of the positional parameter in the array of all parameters
posParamIdxThe number of the positional parameter encountered so far
Returns
The number of array entries which ought to be skipped before processing the next regular parameter. If this is less than 1, it indicated that the positional parameter was invalid.
Parameters
addKeyCallback for adding a key-value pair
seenParamsAlready seen parameters
errorMsgError message
argvCommand line parameters
paramIdxIndex of parameter to handle

References Opm::detail::eclPositionalParameter().

◆ handleSolventBC()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::handleSolventBC ( const BCProp::BCFace &  bc,
RateVector rate 
) const
inlineoverrideprotectedvirtual

◆ handleUreaBC()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::handleUreaBC ( const BCProp::BCFace &  bc,
RateVector rate 
) const
inlineoverrideprotectedvirtual

◆ helpPreamble()

std::string Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::helpPreamble ( int  ,
const char **  argv 
)
staticinherited

Returns the string that is printed before the list of command line parameters in the help message.

If the returned string is empty, no help message will be generated.

◆ initFluidSystem_()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::initFluidSystem_
protectedinherited

◆ initial()

template<class TypeTag >
template<class Context >
void Opm::FlowProblemBlackoil< TypeTag >::initial ( PrimaryVariables values,
const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inline

Evaluate the initial value for a control volume.

Parameters
valuesStores the primary variables.
contextThe object representing the execution context from which this method is called.
spaceIdxThe local index of the spatial entity which represents the boundary segment.
timeIdxThe index used for the time discretization

The reservoir problem uses a constant boundary condition for the whole domain.

◆ initialFluidState()

template<class TypeTag >
const InitialFluidState & Opm::FlowProblemBlackoil< TypeTag >::initialFluidState ( unsigned  globalDofIdx) const
inline

◆ initialFluidStates() [1/2]

template<class TypeTag >
std::vector< InitialFluidState > & Opm::FlowProblemBlackoil< TypeTag >::initialFluidStates ( )
inline

◆ initialFluidStates() [2/2]

template<class TypeTag >
const std::vector< InitialFluidState > & Opm::FlowProblemBlackoil< TypeTag >::initialFluidStates ( ) const
inline

◆ initialSolutionApplied()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::initialSolutionApplied ( )
inlineoverridevirtual

Callback used by the model to indicate that the initial solution has been determined for all degrees of freedom.

Reimplemented from Opm::FlowProblem< TypeTag >.

◆ intrinsicPermeability() [1/2]

template<class TypeTag >
template<class Context >
const DimMatrix & Opm::FlowProblem< TypeTag >::intrinsicPermeability ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

◆ intrinsicPermeability() [2/2]

template<class TypeTag >
const DimMatrix & Opm::FlowProblem< TypeTag >::intrinsicPermeability ( unsigned  globalElemIdx) const
inlineinherited

This method returns the intrinsic permeability tensor given a global element index.

Its main (only?) usage is the ECL transmissibility calculation code...

References Opm::FlowProblem< TypeTag >::transmissibilities_.

◆ limitNextTimeStepSize_()

◆ lookupIdxOnLevelZeroAssigner_()

std::function< unsigned(unsigned)> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::lookupIdxOnLevelZeroAssigner_ ( )
inlineprotectedinherited

◆ materialLawManager() [1/2]

template<class TypeTag >
std::shared_ptr< EclMaterialLawManager > Opm::FlowProblem< TypeTag >::materialLawManager ( )
inlineinherited

◆ materialLawManager() [2/2]

template<class TypeTag >
std::shared_ptr< const EclMaterialLawManager > Opm::FlowProblem< TypeTag >::materialLawManager ( ) const
inlineinherited

Returns the ECL material law manager.

Note that this method is not part of the generic eWoms problem API because it would force all problens use the ECL material laws.

References Opm::FlowProblem< TypeTag >::materialLawManager_.

◆ materialLawParams() [1/3]

template<class TypeTag >
template<class Context >
const MaterialLawParams & Opm::FlowProblem< TypeTag >::materialLawParams ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

◆ materialLawParams() [2/3]

template<class TypeTag >
const MaterialLawParams & Opm::FlowProblem< TypeTag >::materialLawParams ( unsigned  globalDofIdx) const
inlineinherited

◆ materialLawParams() [3/3]

template<class TypeTag >
const MaterialLawParams & Opm::FlowProblem< TypeTag >::materialLawParams ( unsigned  globalDofIdx,
FaceDir::DirEnum  facedir 
) const
inlineinherited

◆ maxGasDissolutionFactor()

template<class TypeTag >
Scalar Opm::FlowProblemBlackoil< TypeTag >::maxGasDissolutionFactor ( unsigned  timeIdx,
unsigned  globalDofIdx 
) const
inline

Returns the maximum value of the gas dissolution factor at the current time for a given degree of freedom.

◆ maxOilSaturation()

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::maxOilSaturation ( unsigned  globalDofIdx) const
inlineinherited

Returns an element's historic maximum oil phase saturation that was observed during the simulation.

In this context, "historic" means the the time before the current timestep began.

This is a bit of a hack from the conceptional point of view, but it is required to match the results of the 'flow' and ECLIPSE 100 simulators.

References Opm::FlowProblem< TypeTag >::episodeIndex(), Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView >, GetPropType< TypeTag, Properties::FluidSystem > >::maxOilSaturation_, and Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView >, GetPropType< TypeTag, Properties::FluidSystem > >::vapparsActive().

◆ maxOilVaporizationFactor()

template<class TypeTag >
Scalar Opm::FlowProblemBlackoil< TypeTag >::maxOilVaporizationFactor ( unsigned  timeIdx,
unsigned  globalDofIdx 
) const
inline

Returns the maximum value of the oil vaporization factor at the current time for a given degree of freedom.

◆ maxPolymerAdsorption() [1/2]

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::maxPolymerAdsorption ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

Returns the max polymer adsorption value.

References Opm::FlowProblem< TypeTag >::maxPolymerAdsorption().

Referenced by Opm::FlowProblem< TypeTag >::maxPolymerAdsorption().

◆ maxPolymerAdsorption() [2/2]

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::maxPolymerAdsorption ( unsigned  elemIdx) const
inherited

Returns the max polymer adsorption value.

◆ maxWaterSaturation()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::maxWaterSaturation ( unsigned  globalDofIdx) const
inherited

Returns an element's historic maximum water phase saturation that was observed during the simulation.

In this context, "historic" means the the time before the current timestep began.

This is used for output of the maximum water saturation used as input for water induced rock compation ROCK2D/ROCK2DTR.

◆ microbialConcentration()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::microbialConcentration ( unsigned  elemIdx) const
inherited

Returns the initial microbial concentration for a given a cell index.

◆ minOilPressure()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::minOilPressure ( unsigned  globalDofIdx) const
inherited

Returns an element's historic minimum pressure of the oil phase that was observed during the simulation.

In this context, "historic" means the the time before the current timestep began.

This is used for output of the minimum pressure used as input for the irreversible rock compation option.

◆ miscnumRegionIndex() [1/2]

template<class TypeTag >
template<class Context >
unsigned Opm::FlowProblem< TypeTag >::miscnumRegionIndex ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

Returns the index of the relevant region for thermodynmic properties.

References Opm::FlowProblem< TypeTag >::miscnumRegionIndex().

Referenced by Opm::FlowProblem< TypeTag >::miscnumRegionIndex().

◆ miscnumRegionIndex() [2/2]

unsigned Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::miscnumRegionIndex ( unsigned  elemIdx) const
inherited

Returns the index the relevant MISC region given a cell index.

◆ moduleParams()

template<class TypeTag >
const ModuleParams & Opm::FlowProblemBlackoil< TypeTag >::moduleParams ( ) const
inline

◆ mutableAquiferModel()

template<class TypeTag >
AquiferModel & Opm::FlowProblem< TypeTag >::mutableAquiferModel ( )
inlineinherited

◆ name()

template<class TypeTag >
std::string Opm::FlowProblem< TypeTag >::name ( ) const
inlineinherited

The problem name.

This is used as a prefix for files generated by the simulation. It is highly recommend to overwrite this method in the concrete problem which is simulated.

◆ nextTimeStepSize()

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::nextTimeStepSize ( ) const
inlineinherited

Propose the size of the next time step to the simulator.

This method is only called if the Newton solver does converge, the simulator automatically cuts the time step in half without consultating this method again.

References Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView >, GetPropType< TypeTag, Properties::FluidSystem > >::initialTimeStepSize_, and Opm::FlowProblem< TypeTag >::limitNextTimeStepSize_().

◆ nonTrivialBoundaryConditions()

template<class TypeTag >
bool Opm::FlowProblem< TypeTag >::nonTrivialBoundaryConditions ( ) const
inlineinherited

◆ numPressurePointsEquil()

int Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::numPressurePointsEquil ( ) const
inlineinherited

◆ operator==()

bool Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::operator== ( const FlowGenericProblem< GetPropType< TypeTag, Properties::GridView >, GetPropType< TypeTag, Properties::FluidSystem > > &  rhs) const
inherited

◆ overburdenPressure()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::overburdenPressure ( unsigned  elementIdx) const
inherited

Get the pressure of the overburden.

This method is mainly for output.

◆ oxygenConcentration()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::oxygenConcentration ( unsigned  elemIdx) const
inherited

Returns the initial oxygen concentration for a given a cell index.

◆ permFactTransMultiplier()

template<class TypeTag >
template<class LhsEval >
LhsEval Opm::FlowProblemBlackoil< TypeTag >::permFactTransMultiplier ( const IntensiveQuantities intQuants,
unsigned  elementIdx 
) const
inline

Calculate the transmissibility multiplier due to porosity reduction.

TODO: The API of this is a bit ad-hoc, it would be better to use context objects.

◆ plmixnumRegionIndex() [1/2]

template<class TypeTag >
template<class Context >
unsigned Opm::FlowProblem< TypeTag >::plmixnumRegionIndex ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

Returns the index of the relevant region for thermodynmic properties.

References Opm::FlowProblem< TypeTag >::plmixnumRegionIndex().

Referenced by Opm::FlowProblem< TypeTag >::plmixnumRegionIndex().

◆ plmixnumRegionIndex() [2/2]

unsigned Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::plmixnumRegionIndex ( unsigned  elemIdx) const
inherited

Returns the index the relevant PLMIXNUM (for polymer module) region given a cell index.

◆ polymerConcentration()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::polymerConcentration ( unsigned  elemIdx) const
inherited

Returns the initial polymer concentration for a given a cell index.

◆ polymerMolecularWeight()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::polymerMolecularWeight ( const unsigned  elemIdx) const
inherited

Returns the polymer molecule weight for a given cell index.

◆ porosity() [1/2]

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::porosity ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inline

For the FlowProblem, this method is identical to referencePorosity(). The intensive quantities object may apply various multipliers (e.g. ones which model rock compressibility and water induced rock compaction) to it which depend on the current physical conditions.

◆ porosity() [2/2]

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::porosity ( unsigned  globalSpaceIdx,
unsigned  timeIdx 
) const
inherited

Direct indexed access to the porosity.

For the FlowProblem, this method is identical to referencePorosity(). The intensive quantities object may apply various multipliers (e.g. ones which model rock compressibility and water induced rock compaction) to it which depend on the current physical conditions.

◆ prefetch()

template<class TypeTag >
void Opm::FlowProblem< TypeTag >::prefetch ( const Element elem) const
inlineinherited

◆ processRestartSaturations_()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::processRestartSaturations_ ( InitialFluidState &  elemFluidState,
Scalar solventSaturation 
)
inlineprotected

◆ pvtRegionIndex() [1/2]

template<class TypeTag >
template<class Context >
unsigned Opm::FlowProblem< TypeTag >::pvtRegionIndex ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inline

Returns the index of the relevant region for thermodynmic properties.

◆ pvtRegionIndex() [2/2]

unsigned Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::pvtRegionIndex ( unsigned  elemIdx) const
inherited

Returns the index the relevant PVT region given a cell index.

◆ readBlackoilExtentionsInitialConditions_()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::readBlackoilExtentionsInitialConditions_ ( std::size_t  numDof,
bool  enableSolvent,
bool  enablePolymer,
bool  enablePolymerMolarWeight,
bool  enableBioeffects,
bool  enableMICP 
)
protectedinherited

◆ readBoundaryConditions_()

template<class TypeTag >
void Opm::FlowProblem< TypeTag >::readBoundaryConditions_ ( )
inlineprotectedinherited

◆ readEclRestartSolution_()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::readEclRestartSolution_ ( )
inlineprotected

◆ readEquilInitialCondition_()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::readEquilInitialCondition_ ( )
inlineoverrideprotectedvirtual

◆ readExplicitInitialCondition_()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::readExplicitInitialCondition_ ( )
inlineoverrideprotectedvirtual

◆ readInitialCondition_()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::readInitialCondition_ ( )
inlineoverrideprotectedvirtual

Reimplemented from Opm::FlowProblem< TypeTag >.

◆ readMaterialParameters_()

◆ readRockCompactionParameters_()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::readRockCompactionParameters_
protectedinherited

◆ readRockParameters_()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::readRockParameters_ ( const std::vector< Scalar > &  cellCenterDepths,
std::function< std::array< int, 3 >(const unsigned)>  ijkIndex 
)
protectedinherited

◆ readSolutionFromOutputModule()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::readSolutionFromOutputModule ( const int  restart_step,
bool  fip_init 
)
inline

Read simulator solution state from the outputmodule (used with restart)

Parameters
restart_stepStep to read at
fip_initTrue to do limited simulator initialization

fip_init is used when calculating original FIP from restart state

◆ readThermalParameters_()

template<class TypeTag >
void Opm::FlowProblem< TypeTag >::readThermalParameters_ ( )
inlineprotectedinherited

◆ recycleFirstIterationStorage()

template<class TypeTag >
bool Opm::FlowProblemBlackoil< TypeTag >::recycleFirstIterationStorage ( ) const
inline

Return if the storage term of the first iteration is identical to the storage term for the solution of the previous time step.

For quite technical reasons, the storage term cannot be recycled if either DRSDT or DRVDT are active. Nor if the porosity is changes between timesteps using a pore volume multiplier (i.e., poreVolumeMultiplier() != 1.0)

◆ referencePorosity()

Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::referencePorosity ( unsigned  elementIdx,
unsigned  timeIdx 
) const
inlineinherited

Returns the porosity of an element.

The reference porosity of an element is the porosity of the medium before modified by the current solution. Note that this method is not part of the generic eWoms problem API because it would bake the assumption that only the elements are the degrees of freedom into the interface.

◆ refPressurePhaseIdx_()

◆ registerParameters()

template<class TypeTag >
static void Opm::FlowProblemBlackoil< TypeTag >::registerParameters ( )
inlinestatic

◆ rockCompPoroMultiplier()

◆ rockCompressibility() [1/2]

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::rockCompressibility ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

◆ rockCompressibility() [2/2]

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::rockCompressibility ( unsigned  globalSpaceIdx) const
inherited

Direct access to rock compressibility.

While the above overload could be implemented in terms of this method, that would require always looking up the global space index, which is not always needed.

◆ rockCompTransMultiplier()

template<class TypeTag >
template<class LhsEval >
LhsEval Opm::FlowProblem< TypeTag >::rockCompTransMultiplier ( const IntensiveQuantities intQuants,
unsigned  elementIdx 
) const
inlineinherited

Calculate the transmissibility multiplier due to water induced rock compaction.

TODO: The API of this is a bit ad-hoc, it would be better to use context objects.

References Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView >, GetPropType< TypeTag, Properties::FluidSystem > >::explicitRockCompaction_.

◆ rockFraction()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::rockFraction ( unsigned  elementIdx,
unsigned  timeIdx 
) const
inherited

Returns the rockFraction of an element.

Usually 1 - porosity, but if pvmult is used to modify porosity we will apply the same multiplier to the rock fraction i.e. pvmult*(1 - porosity) and thus interpret multpv as a volume multiplier. This is to avoid negative rock volume for pvmult*porosity > 1

◆ rockReferencePressure() [1/2]

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::rockReferencePressure ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

◆ rockReferencePressure() [2/2]

◆ satfuncConsistencyRequirementsMet()

◆ satnumRegionIndex() [1/2]

template<class TypeTag >
template<class Context >
unsigned Opm::FlowProblem< TypeTag >::satnumRegionIndex ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

Returns the index of the relevant region for thermodynmic properties.

References Opm::FlowProblem< TypeTag >::satnumRegionIndex().

Referenced by Opm::FlowProblem< TypeTag >::satnumRegionIndex().

◆ satnumRegionIndex() [2/2]

unsigned Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::satnumRegionIndex ( unsigned  elemIdx) const
inherited

Returns the index the relevant saturation function region given a cell index.

◆ serializationTestObject()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > > Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::serializationTestObject ( const EclipseState &  eclState,
const Schedule &  schedule,
const GetPropType< TypeTag, Properties::GridView > &  gridView 
)
staticinherited

◆ serialize()

template<class TypeTag >
template<class Restarter >
void Opm::FlowProblem< TypeTag >::serialize ( Restarter &  res)
inlineinherited

This method writes the complete state of the problem and its subobjects to disk.

The file format used here is ad-hoc.

References Opm::FlowProblem< TypeTag >::aquiferModel_, and Opm::FlowProblem< TypeTag >::wellModel_.

◆ serializeOp()

template<class TypeTag >
template<class Serializer >
void Opm::FlowProblemBlackoil< TypeTag >::serializeOp ( Serializer &  serializer)
inline

◆ setBriefDescription()

static void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::setBriefDescription ( const std::string &  msg)
inlinestaticinherited

Specifies the string returned by briefDescription()

This string appears in the usage message.

◆ setMaxOilSaturation()

template<class TypeTag >
void Opm::FlowProblem< TypeTag >::setMaxOilSaturation ( unsigned  globalDofIdx,
Scalar  value 
)
inlineinherited

Sets an element's maximum oil phase saturation observed during the simulation.

In this context, "historic" means the the time before the current timestep began.

This a hack on top of the maxOilSaturation() hack but it is currently required to do restart externally. i.e. from the flow code.

References Opm::FlowProblem< TypeTag >::episodeIndex(), Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView >, GetPropType< TypeTag, Properties::FluidSystem > >::maxOilSaturation_, and Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView >, GetPropType< TypeTag, Properties::FluidSystem > >::vapparsActive().

◆ setPorosity()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::setPorosity ( Scalar  poro,
unsigned  elementIdx,
unsigned  timeIdx = 0 
)
inlineinherited

Sets the porosity of an element.

◆ setSimulationReport()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::setSimulationReport ( const SimulatorReport report)
inline

◆ setSubStepReport()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::setSubStepReport ( const SimulatorReportSingle report)
inline

◆ shouldWriteOutput()

bool Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::shouldWriteOutput ( ) const
inlineprotectedinherited

Always returns true. The ecl output writer takes care of the rest.

◆ shouldWriteRestartFile()

bool Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::shouldWriteRestartFile ( ) const
inlineprotectedinherited

Returns true if an eWoms restart file should be written to disk.

The FlowProblem does not write any restart files using the ad-hoc format, only ones using the ECL format.

◆ solidEnergyLawParams() [1/2]

template<class TypeTag >
template<class Context >
const SolidEnergyLawParams & Opm::FlowProblem< TypeTag >::solidEnergyLawParams ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

Return the parameters for the energy storage law of the rock.

References Opm::FlowProblem< TypeTag >::thermalLawManager_.

◆ solidEnergyLawParams() [2/2]

template<class TypeTag >
const SolidEnergyLawParams & Opm::FlowProblem< TypeTag >::solidEnergyLawParams ( unsigned  globalSpaceIdx,
unsigned   
) const
inlineinherited

◆ solventRsw()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::solventRsw ( unsigned  elemIdx) const
inherited

Returns the initial solvent dissolved in water for a given a cell index.

◆ solventSaturation()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::solventSaturation ( unsigned  elemIdx) const
inherited

Returns the initial solvent saturation for a given a cell index.

◆ source() [1/2]

template<class TypeTag >
template<class Context >
void Opm::FlowProblem< TypeTag >::source ( RateVector rate,
const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

Evaluate the source term for all phases within a given sub-control-volume.

Parameters
rateStores the values of the volumetric creation/anihilition rates of the conserved quantities.
contextThe object representing the execution context from which this method is called.
spaceIdxThe local index of the spatial entity which represents the boundary segment.
timeIdxThe index used for the time discretization

For this problem, the source term of all components is 0 everywhere.

References Opm::FlowProblem< TypeTag >::source().

Referenced by Opm::FlowProblem< TypeTag >::source().

◆ source() [2/2]

template<class TypeTag >
void Opm::FlowProblem< TypeTag >::source ( RateVector rate,
unsigned  globalDofIdx,
unsigned  timeIdx 
) const
inlineinherited

◆ temperature() [1/2]

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::temperature ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

◆ temperature() [2/2]

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::temperature ( unsigned  globalDofIdx,
unsigned   
) const
inlineinherited

◆ thermalConductionLawParams() [1/2]

template<class TypeTag >
template<class Context >
const ThermalConductionLawParams & Opm::FlowProblem< TypeTag >::thermalConductionLawParams ( const Context &  context,
unsigned  spaceIdx,
unsigned  timeIdx 
) const
inlineinherited

◆ thermalConductionLawParams() [2/2]

template<class TypeTag >
const ThermalConductionLawParams & Opm::FlowProblem< TypeTag >::thermalConductionLawParams ( unsigned  globalSpaceIdx,
unsigned   
) const
inlineinherited

◆ thermalHalfTransmissibility()

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::thermalHalfTransmissibility ( const unsigned  globalSpaceIdxIn,
const unsigned  globalSpaceIdxOut 
) const
inlineinherited

◆ thermalHalfTransmissibilityBoundary()

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::thermalHalfTransmissibilityBoundary ( const Context &  elemCtx,
unsigned  boundaryFaceIdx 
) const
inlineinherited

◆ thermalHalfTransmissibilityIn()

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::thermalHalfTransmissibilityIn ( const Context &  context,
unsigned  faceIdx,
unsigned  timeIdx 
) const
inlineinherited

◆ thermalHalfTransmissibilityOut()

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::thermalHalfTransmissibilityOut ( const Context &  context,
unsigned  faceIdx,
unsigned  timeIdx 
) const
inlineinherited

◆ thermalTransmissibilityBoundary()

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::thermalTransmissibilityBoundary ( const unsigned  globalSpaceIdx,
const unsigned  boundaryFaceIdx 
) const
inlineinherited

Direct access to a boundary transmissibility.

References Opm::FlowProblem< TypeTag >::transmissibilities_.

◆ thresholdPressure() [1/3]

template<class TypeTag >
FlowThresholdPressure< TypeTag > & Opm::FlowProblemBlackoil< TypeTag >::thresholdPressure ( )
inline

◆ thresholdPressure() [2/3]

template<class TypeTag >
const FlowThresholdPressure< TypeTag > & Opm::FlowProblemBlackoil< TypeTag >::thresholdPressure ( ) const
inline

◆ thresholdPressure() [3/3]

template<class TypeTag >
Scalar Opm::FlowProblemBlackoil< TypeTag >::thresholdPressure ( unsigned  elem1Idx,
unsigned  elem2Idx 
) const
inline

◆ tracerModel() [1/2]

template<class TypeTag >
TracerModel & Opm::FlowProblem< TypeTag >::tracerModel ( )
inlineinherited

◆ tracerModel() [2/2]

template<class TypeTag >
const TracerModel & Opm::FlowProblem< TypeTag >::tracerModel ( ) const
inlineinherited

◆ transmissibility() [1/2]

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::transmissibility ( const Context &  context,
unsigned  fromDofLocalIdx,
unsigned  toDofLocalIdx 
) const
inlineinherited

◆ transmissibility() [2/2]

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::transmissibility ( unsigned  globalCenterElemIdx,
unsigned  globalElemIdx 
) const
inlineinherited

Direct access to the transmissibility between two elements.

References Opm::FlowProblem< TypeTag >::transmissibilities_.

◆ transmissibilityBoundary() [1/2]

template<class TypeTag >
template<class Context >
Scalar Opm::FlowProblem< TypeTag >::transmissibilityBoundary ( const Context &  elemCtx,
unsigned  boundaryFaceIdx 
) const
inlineinherited

◆ transmissibilityBoundary() [2/2]

template<class TypeTag >
Scalar Opm::FlowProblem< TypeTag >::transmissibilityBoundary ( const unsigned  globalSpaceIdx,
const unsigned  boundaryFaceIdx 
) const
inlineinherited

Direct access to a boundary transmissibility.

References Opm::FlowProblem< TypeTag >::transmissibilities_.

◆ updateCompositionChangeLimits_()

template<class TypeTag >
bool Opm::FlowProblemBlackoil< TypeTag >::updateCompositionChangeLimits_ ( )
inlineprotected

References Opm::Properties::dim.

◆ updateExplicitQuantities_() [1/2]

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::updateExplicitQuantities_ ( const bool  first_step_after_restart)
inlineprotected

◆ updateExplicitQuantities_() [2/2]

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::updateExplicitQuantities_ ( int  episodeIdx,
int  timeStepSize,
const bool  first_step_after_restart 
)
inlineoverrideprotectedvirtual

◆ updateHysteresis_() [1/2]

◆ updateHysteresis_() [2/2]

template<class TypeTag >
bool Opm::FlowProblem< TypeTag >::updateHysteresis_ ( unsigned  compressedDofIdx,
const IntensiveQuantities iq 
)
inlineprotectedinherited

◆ updateMaxOilSaturation_() [1/2]

◆ updateMaxOilSaturation_() [2/2]

template<class TypeTag >
bool Opm::FlowProblem< TypeTag >::updateMaxOilSaturation_ ( unsigned  compressedDofIdx,
const IntensiveQuantities iq 
)
inlineprotectedinherited

◆ updateMaxPolymerAdsorption_() [1/2]

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::updateMaxPolymerAdsorption_ ( )
inlineprotected

◆ updateMaxPolymerAdsorption_() [2/2]

template<class TypeTag >
bool Opm::FlowProblemBlackoil< TypeTag >::updateMaxPolymerAdsorption_ ( unsigned  compressedDofIdx,
const IntensiveQuantities iq 
)
inlineprotected

◆ updateMaxWaterSaturation_() [1/2]

◆ updateMaxWaterSaturation_() [2/2]

template<class TypeTag >
bool Opm::FlowProblem< TypeTag >::updateMaxWaterSaturation_ ( unsigned  compressedDofIdx,
const IntensiveQuantities iq 
)
inlineprotectedinherited

◆ updateMinPressure_() [1/2]

◆ updateMinPressure_() [2/2]

template<class TypeTag >
bool Opm::FlowProblem< TypeTag >::updateMinPressure_ ( unsigned  compressedDofIdx,
const IntensiveQuantities iq 
)
inlineprotectedinherited

◆ updateMiscnum_()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::updateMiscnum_
protectedinherited

◆ updatePffDofData_()

◆ updatePlmixnum_()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::updatePlmixnum_
protectedinherited

◆ updateProperty_()

template<class TypeTag >
template<class UpdateFunc >
void Opm::FlowProblem< TypeTag >::updateProperty_ ( const std::string &  failureMsg,
UpdateFunc  func 
)
inlineprotectedinherited

◆ updatePvtnum_()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::updatePvtnum_
protectedinherited

◆ updateReferencePorosity_()

◆ updateRelperms()

template<class TypeTag >
template<class FluidState , class ... Args>
void Opm::FlowProblem< TypeTag >::updateRelperms ( std::array< Evaluation, numPhases > &  mobility,
DirectionalMobilityPtr dirMob,
FluidState &  fluidState,
unsigned  globalSpaceIdx 
) const
inlineinherited

◆ updateRockCompTransMultVal_()

template<class TypeTag >
void Opm::FlowProblem< TypeTag >::updateRockCompTransMultVal_ ( )
inlineprotectedinherited

◆ updateSatnum_()

void Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::updateSatnum_
protectedinherited

◆ ureaConcentration()

FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::ureaConcentration ( unsigned  elemIdx) const
inherited

Returns the initial urea concentration for a given a cell index.

◆ vapparsActive()

bool Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::vapparsActive ( int  episodeIdx) const
inherited

◆ wellModel() [1/2]

template<class TypeTag >
WellModel & Opm::FlowProblem< TypeTag >::wellModel ( )
inlineinherited

◆ wellModel() [2/2]

template<class TypeTag >
const WellModel & Opm::FlowProblem< TypeTag >::wellModel ( ) const
inlineinherited

Returns a reference to the ECL well manager used by the problem.

This can be used for inspecting wells outside of the problem.

References Opm::FlowProblem< TypeTag >::wellModel_.

◆ wellTransMultiplier()

template<class TypeTag >
template<class LhsEval >
LhsEval Opm::FlowProblem< TypeTag >::wellTransMultiplier ( const IntensiveQuantities intQuants,
unsigned  elementIdx 
) const
inlineinherited

◆ writeOutput()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::writeOutput ( const bool  verbose)
inlineoverridevirtual

Write the requested quantities of the current solution into the output files.

Reimplemented from Opm::FlowProblem< TypeTag >.

◆ writeReports()

template<class TypeTag >
void Opm::FlowProblemBlackoil< TypeTag >::writeReports ( const SimulatorTimer timer)
inline

Member Data Documentation

◆ actionHandler_

template<class TypeTag >
ActionHandler<Scalar, IndexTraits> Opm::FlowProblemBlackoil< TypeTag >::actionHandler_
protected

◆ aquiferModel_

◆ bcindex_

template<class TypeTag >
BCData<int> Opm::FlowProblem< TypeTag >::bcindex_
protectedinherited

◆ bioeffects_

◆ briefDescription_

std::string Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::briefDescription_
inlinestaticprotectedinherited

◆ drift_

template<class TypeTag >
GlobalEqVector Opm::FlowProblem< TypeTag >::drift_
protectedinherited

◆ eclState_

const EclipseState& Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::eclState_
protectedinherited

◆ eclWriter_

template<class TypeTag >
std::unique_ptr<EclWriterType> Opm::FlowProblemBlackoil< TypeTag >::eclWriter_
protected

◆ enableDriftCompensation_

bool Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::enableDriftCompensation_
protectedinherited

◆ enableEclOutput_

template<class TypeTag >
bool Opm::FlowProblemBlackoil< TypeTag >::enableEclOutput_
protected

◆ enableTuning_

bool Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::enableTuning_
protectedinherited

◆ explicitRockCompaction_

bool Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::explicitRockCompaction_
protectedinherited

◆ first_step_

template<class TypeTag >
bool Opm::FlowProblem< TypeTag >::first_step_ = true
protectedinherited

◆ gridView_

const GetPropType< TypeTag, Properties::GridView > & Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::gridView_
protectedinherited

◆ hybridNewton_

template<class TypeTag >
HybridNewton Opm::FlowProblemBlackoil< TypeTag >::hybridNewton_
protected

◆ initialFluidStates_

template<class TypeTag >
std::vector<InitialFluidState> Opm::FlowProblemBlackoil< TypeTag >::initialFluidStates_
protected

◆ initialTimeStepSize_

Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::initialTimeStepSize_
protectedinherited

◆ lookUpData_

const LookUpData Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::lookUpData_
protectedinherited

◆ materialLawManager_

◆ maxOilSaturation_

std::vector<Scalar> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::maxOilSaturation_
protectedinherited

◆ maxTimeStepAfterWellEvent_

Scalar Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::maxTimeStepAfterWellEvent_
protectedinherited

◆ maxWaterSaturation_

std::vector<Scalar> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::maxWaterSaturation_
protectedinherited

◆ minRefPressure_

std::vector<Scalar> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::minRefPressure_
protectedinherited

◆ miscnum_

std::vector<unsigned short> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::miscnum_
protectedinherited

◆ mixControls_

template<class TypeTag >
MixingRateControls<FluidSystem> Opm::FlowProblemBlackoil< TypeTag >::mixControls_
protected

◆ moduleParams_

template<class TypeTag >
ModuleParams Opm::FlowProblemBlackoil< TypeTag >::moduleParams_
protected

◆ nonTrivialBoundaryConditions_

template<class TypeTag >
bool Opm::FlowProblem< TypeTag >::nonTrivialBoundaryConditions_ = false
protectedinherited

◆ numPressurePointsEquil_

int Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::numPressurePointsEquil_
protectedinherited

◆ overburdenPressure_

std::vector<Scalar> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::overburdenPressure_
protectedinherited

◆ pffDofData_

◆ plmixnum_

std::vector<unsigned short> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::plmixnum_
protectedinherited

◆ polymer_

◆ pvtnum_

std::vector<int> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::pvtnum_
protectedinherited

◆ referencePorosity_

std::array<std::vector<Scalar>, 2> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::referencePorosity_
protectedinherited

◆ rockCompPoroMult_

std::vector<TabulatedFunction> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::rockCompPoroMult_
protectedinherited

◆ rockCompPoroMultWc_

std::vector<TabulatedTwoDFunction> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::rockCompPoroMultWc_
protectedinherited

◆ rockCompTransMult_

std::vector<TabulatedFunction> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::rockCompTransMult_
protectedinherited

◆ rockCompTransMultVal_

std::vector<Scalar> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::rockCompTransMultVal_
protectedinherited

◆ rockCompTransMultWc_

std::vector<TabulatedTwoDFunction> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::rockCompTransMultWc_
protectedinherited

◆ rockParams_

std::vector<RockParams> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::rockParams_
protectedinherited

◆ rockTableIdx_

std::vector<unsigned short> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::rockTableIdx_
protectedinherited

◆ satnum_

std::vector<unsigned short> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::satnum_
protectedinherited

◆ schedule_

const Schedule& Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::schedule_
protectedinherited

◆ smallSaturationTolerance_

template<class TypeTag >
const Scalar Opm::FlowProblemBlackoil< TypeTag >::smallSaturationTolerance_ = 1.e-6
protected

◆ solventRsw_

std::vector<Scalar> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::solventRsw_
protectedinherited

◆ solventSaturation_

std::vector<Scalar> Opm::FlowGenericProblem< GetPropType< TypeTag, Properties::GridView > , GetPropType< TypeTag, Properties::FluidSystem > >::solventSaturation_
protectedinherited

◆ thermalLawManager_

◆ thresholdPressures_

template<class TypeTag >
FlowThresholdPressure<TypeTag> Opm::FlowProblemBlackoil< TypeTag >::thresholdPressures_
protected

◆ tracerModel_

◆ transmissibilities_

◆ wellModel_


The documentation for this class was generated from the following file: