|
BlackoilWellModel.hpp
Go to the documentation of this file.
98 class BlackoilWellModel : public WellConnectionAuxiliaryModule<TypeTag, BlackoilWellModel<TypeTag>>
116 using WellConnectionModule = WellConnectionAuxiliaryModule<TypeTag, BlackoilWellModel<TypeTag>>;
120 constexpr static std::size_t pressureVarIndex = GetPropType<TypeTag, Properties::Indices>::pressureSwitchIdx;
126 static constexpr EnergyModules energyModuleType_ = getPropValue<TypeTag, Properties::EnergyModuleType>();
258 ConvergenceReport getWellConvergence(const std::vector<Scalar>& B_avg, const bool checkWellGroupControlsAndNetwork = false) const;
361 int compressedIndexForInteriorLGR(const std::string& lgr_tag, const Connection& conn) const override
501 static Scalar computeTemperatureWeightFactor(const int perf_index, const int np, const FluidState& fs, const SingleWellState& ws)
516 weight_factor += cellDensity * (perfPhaseRate / cellBinv) * (cellInternalEnergy / cellTemperatures);
555 std::map<std::string, std::unique_ptr<AverageRegionalPressureType>> regionalAveragePressureCalculator_{};
579 // the returned two booleans are {continue_due_to_network, well_group_control_changed}, respectively
580 std::tuple<bool, bool, Scalar> updateWellControlsAndNetworkIteration(const bool mandatory_network_balance,
620 void calculateProductivityIndexValuesShutWells(const int reportStepIdx, DeferredLogger& deferred_logger) override;
641 void wellTesting(const int timeStepIdx, const double simulationTime, DeferredLogger& deferred_logger);
741 // Store cell rates after assembling to avoid iterating all wells and connections for every element
Class for handling the gaslift in the blackoil well model. Definition: BlackoilWellModelGasLift.hpp:96 Class for handling the blackoil well model. Definition: BlackoilWellModelGeneric.hpp:98 BlackoilWellModelWBP< Scalar, IndexTraits > wbp_ Definition: BlackoilWellModelGeneric.hpp:523 GroupStateHelperType & groupStateHelper() Definition: BlackoilWellModelGeneric.hpp:293 const GroupState< Scalar > & groupState() const Definition: BlackoilWellModelGeneric.hpp:147 void assignWellTargets(data::Wells &wsrpt) const void assignDynamicWellStatus(data::Wells &wsrpt) const WellTestState & wellTestState() Definition: BlackoilWellModelGeneric.hpp:188 void assignMassGasRate(data::Wells &wsrpt, const Scalar gasDensity) const const WellState< Scalar, IndexTraits > & wellState() const Definition: BlackoilWellModelGeneric.hpp:157 void assignShutConnections(data::Wells &wsrpt, const int reportStepIndex) const Class for handling the guide rates in the blackoil well model. Definition: BlackoilWellModelGuideRates.hpp:47 void assignWellGuideRates(data::Wells &wsrpt, const int reportStepIdx) const Assign well guide rates. Class for handling the blackoil well network model. Definition: BlackoilWellModelNetwork.hpp:47 Class for handling the blackoil well model in a NLDD solver. Definition: BlackoilWellModelNldd.hpp:80 Class for handling the blackoil well model. Definition: BlackoilWellModel.hpp:101 ReservoirCoupling::Proxy< Scalar > & rescoup() Get the reservoir coupling proxy. Definition: BlackoilWellModel.hpp:407 void initializeGroupStructure(const int reportStepIdx) Definition: BlackoilWellModel_impl.hpp:294 bool network_needs_more_balancing_force_another_newton_iteration_ Definition: BlackoilWellModel.hpp:562 Dune::BCRSMatrix< Dune::FieldMatrix< Scalar, numWellDofs, numWellDofs > > DMatrix Definition: BlackoilWellModel.hpp:293 void calcResvCoeff(const int fipnum, const int pvtreg, const std::vector< Scalar > &production_rates, std::vector< Scalar > &resv_coeff) const override Definition: BlackoilWellModel_impl.hpp:2162 ReservoirCouplingMaster< Scalar > & reservoirCouplingMaster() Get reference to reservoir coupling master. Definition: BlackoilWellModel.hpp:442 void prepareTimeStep(DeferredLogger &deferred_logger) Definition: BlackoilWellModel_impl.hpp:1985 std::tuple< bool, bool, Scalar > updateWellControlsAndNetworkIteration(const bool mandatory_network_balance, const bool relax_network_tolerance, const bool optimize_gas_lift, const double dt, DeferredLogger &local_deferredLogger) Definition: BlackoilWellModel_impl.hpp:1264 static constexpr bool has_bioeffects_ Definition: BlackoilWellModel.hpp:130 Dune::BCRSMatrix< Dune::FieldMatrix< Scalar, numWellDofs, numResDofs > > BMatrix Definition: BlackoilWellModel.hpp:291 WellInterfacePtr createWellPointer(const int wellID, const int report_step) const Definition: BlackoilWellModel_impl.hpp:1051 GuideRateHandler< Scalar, IndexTraits > guide_rate_handler_ Definition: BlackoilWellModel.hpp:558 const EclipseState & eclState() const Definition: BlackoilWellModel.hpp:569 void prepareWellsBeforeAssembling(const double dt) Definition: BlackoilWellModel_impl.hpp:1363 const std::vector< WellInterfacePtr > & localNonshutWells() const Get list of local nonshut wells. Definition: BlackoilWellModel.hpp:324 void prepareDeserialize(const int report_step) Definition: BlackoilWellModel.hpp:203 void setNlddAdapter(BlackoilWellModelNldd< TypeTag > *mod) Definition: BlackoilWellModel.hpp:395 const Simulator & simulator() const Definition: BlackoilWellModel.hpp:384 static constexpr bool has_geochem_ Definition: BlackoilWellModel.hpp:129 static constexpr EnergyModules energyModuleType_ Definition: BlackoilWellModel.hpp:126 std::size_t global_num_cells_ Definition: BlackoilWellModel.hpp:548 GetPropType< TypeTag, Properties::Scalar > Scalar Definition: BlackoilWellModel.hpp:110 const std::vector< Scalar > & B_avg() const Definition: BlackoilWellModel.hpp:480 SimulatorReportSingle last_report_ Definition: BlackoilWellModel.hpp:557 static const int solventSaturationIdx Definition: BlackoilWellModel.hpp:123 void initWellContainer(const int reportStepIdx) override Definition: BlackoilWellModel_impl.hpp:182 void beginReportStep(const int time_step) Definition: BlackoilWellModel_impl.hpp:199 static constexpr int numResDofs Definition: BlackoilWellModel.hpp:289 const WellInterface< TypeTag > & getWell(const std::string &well_name) const Definition: BlackoilWellModel_impl.hpp:2134 bool useTightRcNetworkCoupling() const True when tight (per-sub-iteration) reservoir-coupling network coupling is in effect.... Definition: BlackoilWellModel.hpp:489 GetPropType< TypeTag, Properties::FluidSystem > FluidSystem Definition: BlackoilWellModel.hpp:106 bool isReservoirCouplingMaster() const Check if this process is a reservoir coupling master. Definition: BlackoilWellModel.hpp:426 Dune::FieldVector< Scalar, numEq > VectorBlockType Definition: BlackoilWellModel.hpp:134 const BlackoilWellModelNetwork< TypeTag > & network() const Definition: BlackoilWellModel.hpp:390 void initFromRestartFile(const RestartValue &restartValues) Definition: BlackoilWellModel.hpp:194 GetPropType< TypeTag, Properties::ElementContext > ElementContext Definition: BlackoilWellModel.hpp:107 GetPropType< TypeTag, Properties::Grid > Grid Definition: BlackoilWellModel.hpp:104 GetPropType< TypeTag, Properties::EquilGrid > EquilGrid Definition: BlackoilWellModel.hpp:105 static constexpr int numWellDofs Definition: BlackoilWellModel.hpp:290 int numConservationQuantities() const Definition: BlackoilWellModel_impl.hpp:2106 const std::map< std::string, int > & well_domain() const Definition: BlackoilWellModel.hpp:337 const ReservoirCouplingSlave< Scalar > & reservoirCouplingSlave() const Definition: BlackoilWellModel.hpp:454 bool updateWellControls(DeferredLogger &deferred_logger) Definition: BlackoilWellModel_impl.hpp:1660 static constexpr bool has_polymer_ Definition: BlackoilWellModel.hpp:125 int reportStepIndex() const Definition: BlackoilWellModel_impl.hpp:2150 void calculateProductivityIndexValues(DeferredLogger &deferred_logger) override Definition: BlackoilWellModel_impl.hpp:1927 void extractLegacyDepth_() Definition: BlackoilWellModel_impl.hpp:2122 void extractLegacyCellPvtRegionIndex_() Definition: BlackoilWellModel_impl.hpp:2090 std::vector< WellInterfacePtr > & wellContainer() Definition: BlackoilWellModel.hpp:392 void recoverWellSolutionAndUpdateWellStateDomain(const BVector &x, const int domainIdx) Definition: BlackoilWellModel_impl.hpp:1581 void updateAverageFormationFactor() Definition: BlackoilWellModel_impl.hpp:2033 GetPropType< TypeTag, Properties::Simulator > Simulator Definition: BlackoilWellModel.hpp:109 BlackoilWellModel(Simulator &simulator, const NewtonIterationContext &iter_ctx) Definition: BlackoilWellModel_impl.hpp:72 bool isReservoirCouplingSlave() const Check if this process is a reservoir coupling slave. Definition: BlackoilWellModel.hpp:429 const ReservoirCouplingMaster< Scalar > & reservoirCouplingMaster() const Definition: BlackoilWellModel.hpp:445 void initializeWellState(const int timeStepIdx) Definition: BlackoilWellModel_impl.hpp:761 void updatePrimaryVariables() Definition: BlackoilWellModel_impl.hpp:2081 const ReservoirCoupling::Proxy< Scalar > & rescoup() const Definition: BlackoilWellModel.hpp:408 BlackOilPolymerModule< TypeTag, has_polymer_ > PolymerModule Definition: BlackoilWellModel.hpp:137 void computeWellTemperature() Definition: BlackoilWellModel_impl.hpp:2184 void addWellPressureEquations(PressureMatrix &jacobian, const BVector &weights, const bool use_well_weights) const Definition: BlackoilWellModel_impl.hpp:1485 const SimulatorReportSingle & lastReport() const Definition: BlackoilWellModel_impl.hpp:637 bool updateWellControlsAndNetwork(const bool mandatory_network_balance, const double dt, DeferredLogger &local_deferredLogger) Definition: BlackoilWellModel_impl.hpp:1202 GetPropType< TypeTag, Properties::SparseMatrixAdapter > SparseMatrixAdapter Definition: BlackoilWellModel.hpp:113 void addWellContributions(SparseMatrixAdapter &jacobian) const Definition: BlackoilWellModel_impl.hpp:1462 const EquilGrid & equilGrid() const Definition: BlackoilWellModel.hpp:566 void assembleWellEq(const double dt) Definition: BlackoilWellModel_impl.hpp:1351 WellInterfacePtr createWellForWellTest(const std::string &well_name, const int report_step, DeferredLogger &deferred_logger) const Definition: BlackoilWellModel_impl.hpp:1102 GetPropType< TypeTag, Properties::Indices > Indices Definition: BlackoilWellModel.hpp:108 int compressedIndexForInteriorLGR(const std::string &lgr_tag, const Connection &conn) const override Definition: BlackoilWellModel.hpp:361 void calculateExplicitQuantities() const Definition: BlackoilWellModel_impl.hpp:1645 BlackoilWellModelNetwork< TypeTag > & network() Definition: BlackoilWellModel.hpp:389 Dune::BlockVector< Dune::FieldVector< Scalar, numWellDofs > > WVector Definition: BlackoilWellModel.hpp:294 std::vector< WellInterfacePtr > well_container_ Definition: BlackoilWellModel.hpp:525 static constexpr std::size_t pressureVarIndex Definition: BlackoilWellModel.hpp:120 void updateAndCommunicate(const int reportStepIdx) Definition: BlackoilWellModel_impl.hpp:1740 Dune::BCRSMatrix< Opm::MatrixBlock< Scalar, 1, 1 > > PressureMatrix Definition: BlackoilWellModel.hpp:303 void computeTotalRatesForDof(RateVector &rate, unsigned globalIdx) const Definition: BlackoilWellModel_impl.hpp:724 bool addMatrixContributions() const Definition: BlackoilWellModel.hpp:350 const std::vector< Scalar > & wellPerfEfficiencyFactors() const GetPropType< TypeTag, Properties::RateVector > RateVector Definition: BlackoilWellModel.hpp:111 bool updateGroupControls(const Group &group, DeferredLogger &deferred_logger, const int reportStepIdx) Definition: BlackoilWellModel_impl.hpp:1767 std::map< std::string, std::unique_ptr< AverageRegionalPressureType > > regionalAveragePressureCalculator_ Definition: BlackoilWellModel.hpp:555 void calcInjResvCoeff(const int fipnum, const int pvtreg, std::vector< Scalar > &resv_coeff) const override Definition: BlackoilWellModel_impl.hpp:2173 static Scalar computeTemperatureWeightFactor(const int perf_index, const int np, const FluidState &fs, const SingleWellState &ws) Definition: BlackoilWellModel.hpp:501 GetPropType< TypeTag, Properties::GlobalEqVector > GlobalEqVector Definition: BlackoilWellModel.hpp:112 void initializeLocalWellStructure(const int reportStepIdx, const bool enableWellPIScaling) Definition: BlackoilWellModel_impl.hpp:248 GuideRateHandler< Scalar, IndexTraits > & guideRateHandler() Definition: BlackoilWellModel.hpp:398 static constexpr bool has_solvent_ Definition: BlackoilWellModel.hpp:124 Dune::BlockVector< VectorBlockType > BVector Definition: BlackoilWellModel.hpp:135 static constexpr bool has_micp_ Definition: BlackoilWellModel.hpp:128 std::unique_ptr< RateConverterType > rateConverter_ Definition: BlackoilWellModel.hpp:554 const SparseTable< int > & well_local_cells() const Definition: BlackoilWellModel.hpp:329 void wellTesting(const int timeStepIdx, const double simulationTime, DeferredLogger &deferred_logger) Definition: BlackoilWellModel_impl.hpp:560 std::vector< bool > is_cell_perforated_ Definition: BlackoilWellModel.hpp:527 ConvergenceReport getWellConvergence(const std::vector< Scalar > &B_avg, const bool checkWellGroupControlsAndNetwork=false) const Definition: BlackoilWellModel_impl.hpp:1594 int numStrictIterations() const Definition: BlackoilWellModel.hpp:353 typename FluidSystem::IndexTraitsType IndexTraits Definition: BlackoilWellModel.hpp:117 void updateCellRatesForDomain(int domainIndex, const std::map< std::string, int > &well_domain_map) Definition: BlackoilWellModel_impl.hpp:1409 data::WellBlockAveragePressures wellBlockAveragePressures() const Definition: BlackoilWellModel.hpp:247 void assembleWellEqWithoutIteration(const double dt) Definition: BlackoilWellModel_impl.hpp:1377 void updateCellRates() Definition: BlackoilWellModel_impl.hpp:1397 void assemble(const double dt) Definition: BlackoilWellModel_impl.hpp:1127 std::size_t local_num_cells_ Definition: BlackoilWellModel.hpp:550 BlackOilBioeffectsModule< TypeTag, has_bioeffects_ > BioeffectsModule Definition: BlackoilWellModel.hpp:138 bool alternative_well_rate_init_ Definition: BlackoilWellModel.hpp:553 void timeStepSucceeded(const double simulationTime, const double dt) Definition: BlackoilWellModel_impl.hpp:647 std::unique_ptr< WellType > createTypedWellPointer(const int wellID, const int time_step) const Definition: BlackoilWellModel_impl.hpp:1071 void computePotentials(const std::size_t widx, const WellState< Scalar, IndexTraits > &well_state_copy, std::string &exc_msg, ExceptionType::ExcEnum &exc_type) override Definition: BlackoilWellModel_impl.hpp:1892 void updateGuideRates(const int report_step_idx, const double sim_time) Update guide rates for all wells and groups. Definition: BlackoilWellModel.hpp:417 ReservoirCoupling::Proxy< Scalar > rescoup_ Definition: BlackoilWellModel.hpp:559 void createWellContainer(const int report_step) override Definition: BlackoilWellModel_impl.hpp:804 std::unique_ptr< WellInterface< TypeTag > > WellInterfacePtr Definition: BlackoilWellModel.hpp:191 ReservoirCouplingSlave< Scalar > & reservoirCouplingSlave() Get reference to reservoir coupling slave. Definition: BlackoilWellModel.hpp:451 const ModelParameters & param() const Definition: BlackoilWellModel.hpp:483 void updateWellTestState(const double simulationTime, WellTestState &wellTestState) upate the wellTestState related to economic limits Definition: BlackoilWellModel_impl.hpp:1821 void addWellPressureEquationsDomain(PressureMatrix &jacobian, const BVector &weights, const bool use_well_weights, const int domainIndex) const Definition: BlackoilWellModel.hpp:309 bool isReservoirCouplingMasterGroup(const std::string &group_name) const Check if a group is a reservoir coupling master group. Definition: BlackoilWellModel.hpp:436 void addBCDMatrix(std::vector< BMatrix > &b_matrices, std::vector< CMatrix > &c_matrices, std::vector< DMatrix > &d_matrices, Opm::SparseTable< int > &wcells) const Definition: BlackoilWellModel_impl.hpp:1471 const GuideRateHandler< Scalar, IndexTraits > & guideRateHandler() const Definition: BlackoilWellModel.hpp:401 void addReservoirSourceTerms(GlobalEqVector &residual, const std::vector< typename SparseMatrixAdapter::MatrixBlock * > &diagMatAddress) const Definition: BlackoilWellModel_impl.hpp:1507 int compressedIndexForInterior(int cartesian_cell_idx) const override get compressed index for interior cells (-1, otherwise Definition: BlackoilWellModel.hpp:356 Dune::BCRSMatrix< Dune::FieldMatrix< Scalar, numResDofs, numWellDofs > > CMatrix Definition: BlackoilWellModel.hpp:292 static constexpr bool has_energy_ Definition: BlackoilWellModel.hpp:127 void recoverWellSolutionAndUpdateWellState(const BVector &x) Definition: BlackoilWellModel_impl.hpp:1557 void addWellPressureEquationsStruct(PressureMatrix &jacobian) const Definition: BlackoilWellModel_impl.hpp:1537 void calculateProductivityIndexValuesShutWells(const int reportStepIdx, DeferredLogger &deferred_logger) override Definition: BlackoilWellModel_impl.hpp:1941 const std::vector< WellInterfacePtr > & wellContainer() const Definition: BlackoilWellModel.hpp:393 Definition: ConvergenceReport.hpp:38 Definition: DeferredLogger.hpp:57 Definition: GroupStateHelper.hpp:56 Handles computation and reporting of guide rates for wells and groups. Definition: GuideRateHandler.hpp:46 Definition: RateConverter.hpp:70 Definition: RegionAverageCalculator.hpp:60 Thin proxy for reservoir coupling master/slave pointers. Definition: RescoupProxy.hpp:54 Definition: ReservoirCouplingMaster.hpp:38 Definition: ReservoirCouplingSlave.hpp:40 Definition: SingleWellState.hpp:44 Definition: BlackoilWellModel.hpp:90 Definition: WellConnectionAuxiliaryModule.hpp:39 Definition: WellContributions.hpp:51 Definition: WellInterface.hpp:78 Definition: WellState.hpp:66 Definition: blackoilbioeffectsmodules.hh:45 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 Solver parameters for the NonlinearSystemBlackOilReservoir. Definition: BlackoilModelParameters.hpp:201 bool matrix_add_well_contributions_ Whether to add influences of wells between cells to the matrix and preconditioner matrix. Definition: BlackoilModelParameters.hpp:315 int strict_outer_iter_wells_ Newton iteration where wells are stricly convergent. Definition: BlackoilModelParameters.hpp:265 bool rc_network_loose_coupling_ Definition: BlackoilModelParameters.hpp:357 Context for iteration-dependent decisions in the Newton solver. Definition: NewtonIterationContext.hpp:43 A struct for returning timing data from a simulator to its caller. Definition: SimulatorReport.hpp:34 |