| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |   Copyright 2016 SINTEF ICT, Applied Mathematics. | 
					
						
							| 
									
										
										
										
											2017-03-24 12:19:11 +01:00
										 |  |  |   Copyright 2016 - 2017 Statoil ASA. | 
					
						
							|  |  |  |   Copyright 2017 Dr. Blatt - HPC-Simulation-Software & Services | 
					
						
							| 
									
										
										
										
											2018-06-06 15:17:59 +02:00
										 |  |  |   Copyright 2016 - 2018 IRIS AS | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   This file is part of the Open Porous Media project (OPM). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OPM is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |   it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |   the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |   (at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   OPM is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |   but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |   GNU General Public License for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |   along with OPM.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-26 10:52:05 +02:00
										 |  |  | #ifndef OPM_BLACKOILWELLMODEL_HEADER_INCLUDED
 | 
					
						
							|  |  |  | #define OPM_BLACKOILWELLMODEL_HEADER_INCLUDED
 | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  | #include <ebos/eclproblem.hh>
 | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | #include <opm/common/OpmLog/OpmLog.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <cassert>
 | 
					
						
							| 
									
										
										
										
											2023-01-05 12:36:46 +01:00
										 |  |  | #include <cstddef>
 | 
					
						
							| 
									
										
										
										
											2020-12-01 18:04:46 +01:00
										 |  |  | #include <map>
 | 
					
						
							|  |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2020-10-29 23:30:09 +01:00
										 |  |  | #include <optional>
 | 
					
						
							| 
									
										
										
										
											2021-05-27 08:31:49 +02:00
										 |  |  | #include <set>
 | 
					
						
							| 
									
										
										
										
											2020-12-01 18:04:46 +01:00
										 |  |  | #include <string>
 | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | #include <tuple>
 | 
					
						
							| 
									
										
										
										
											2020-12-01 18:04:46 +01:00
										 |  |  | #include <unordered_map>
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-14 08:30:15 +01:00
										 |  |  | #include <opm/input/eclipse/Schedule/Schedule.hpp>
 | 
					
						
							|  |  |  | #include <opm/input/eclipse/Schedule/Well/WellTestState.hpp>
 | 
					
						
							|  |  |  | #include <opm/input/eclipse/Schedule/Group/GuideRate.hpp>
 | 
					
						
							|  |  |  | #include <opm/input/eclipse/Schedule/Group/Group.hpp>
 | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-20 10:30:16 +02:00
										 |  |  | #include <opm/simulators/timestepping/SimulatorReport.hpp>
 | 
					
						
							| 
									
										
										
										
											2021-03-03 13:59:26 +01:00
										 |  |  | #include <opm/simulators/flow/countGlobalCells.hpp>
 | 
					
						
							| 
									
										
										
										
											2021-06-07 13:04:29 +02:00
										 |  |  | #include <opm/simulators/wells/BlackoilWellModelGeneric.hpp>
 | 
					
						
							| 
									
										
										
										
											2022-10-24 09:36:05 +02:00
										 |  |  | #include <opm/simulators/wells/BlackoilWellModelGuideRates.hpp>
 | 
					
						
							| 
									
										
										
										
											2021-03-03 13:59:26 +01:00
										 |  |  | #include <opm/simulators/wells/GasLiftSingleWell.hpp>
 | 
					
						
							|  |  |  | #include <opm/simulators/wells/GasLiftWellState.hpp>
 | 
					
						
							| 
									
										
										
										
											2021-05-27 08:31:49 +02:00
										 |  |  | #include <opm/simulators/wells/GasLiftSingleWellGeneric.hpp>
 | 
					
						
							|  |  |  | #include <opm/simulators/wells/GasLiftStage2.hpp>
 | 
					
						
							|  |  |  | #include <opm/simulators/wells/GasLiftGroupInfo.hpp>
 | 
					
						
							| 
									
										
										
										
											2019-10-23 09:09:45 +02:00
										 |  |  | #include <opm/simulators/wells/PerforationData.hpp>
 | 
					
						
							| 
									
										
										
										
											2019-05-07 13:06:02 +02:00
										 |  |  | #include <opm/simulators/wells/VFPInjProperties.hpp>
 | 
					
						
							|  |  |  | #include <opm/simulators/wells/VFPProdProperties.hpp>
 | 
					
						
							| 
									
										
										
										
											2021-05-20 13:32:18 +02:00
										 |  |  | #include <opm/simulators/wells/WellState.hpp>
 | 
					
						
							| 
									
										
										
										
											2021-04-22 17:31:21 +02:00
										 |  |  | #include <opm/simulators/wells/WGState.hpp>
 | 
					
						
							| 
									
										
										
										
											2019-06-20 09:09:19 +02:00
										 |  |  | #include <opm/simulators/wells/RateConverter.hpp>
 | 
					
						
							| 
									
										
										
										
											2021-09-06 14:20:40 +02:00
										 |  |  | #include <opm/simulators/wells/RegionAverageCalculator.hpp>
 | 
					
						
							| 
									
										
										
										
											2019-05-07 13:06:02 +02:00
										 |  |  | #include <opm/simulators/wells/WellInterface.hpp>
 | 
					
						
							|  |  |  | #include <opm/simulators/wells/StandardWell.hpp>
 | 
					
						
							|  |  |  | #include <opm/simulators/wells/MultisegmentWell.hpp>
 | 
					
						
							| 
									
										
										
										
											2019-08-07 14:13:11 +02:00
										 |  |  | #include <opm/simulators/wells/WellGroupHelpers.hpp>
 | 
					
						
							| 
									
										
										
										
											2020-10-09 13:38:33 +02:00
										 |  |  | #include <opm/simulators/wells/WellProdIndexCalculator.hpp>
 | 
					
						
							| 
									
										
										
										
											2020-10-06 14:52:44 +02:00
										 |  |  | #include <opm/simulators/wells/ParallelWellInfo.hpp>
 | 
					
						
							| 
									
										
										
										
											2018-11-13 14:02:55 +01:00
										 |  |  | #include <opm/simulators/timestepping/gatherConvergenceReport.hpp>
 | 
					
						
							| 
									
										
										
										
											2019-05-07 13:06:02 +02:00
										 |  |  | #include <dune/common/fmatrix.hh>
 | 
					
						
							|  |  |  | #include <dune/istl/bcrsmatrix.hh>
 | 
					
						
							|  |  |  | #include <dune/istl/matrixmatrix.hh>
 | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <opm/material/densead/Math.hpp>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-07 13:06:02 +02:00
										 |  |  | #include <opm/simulators/utils/DeferredLogger.hpp>
 | 
					
						
							| 
									
										
										
										
											2017-01-24 15:59:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-21 13:42:08 +02:00
										 |  |  | namespace Opm::Properties { | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-27 11:38:38 +02:00
										 |  |  | template<class TypeTag, class MyTypeTag> | 
					
						
							|  |  |  | struct EnableTerminalOutput { | 
					
						
							|  |  |  |     using type = UndefinedProperty; | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-21 13:42:08 +02:00
										 |  |  | } // namespace Opm::Properties
 | 
					
						
							| 
									
										
										
										
											2017-06-15 17:19:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | namespace Opm { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-26 10:52:05 +02:00
										 |  |  |         /// Class for handling the blackoil well model.
 | 
					
						
							| 
									
										
										
										
											2017-05-03 13:34:15 +02:00
										 |  |  |         template<typename TypeTag> | 
					
						
							| 
									
										
										
										
											2021-05-05 11:22:44 +02:00
										 |  |  |         class BlackoilWellModel : public BaseAuxiliaryModule<TypeTag> | 
					
						
							| 
									
										
										
										
											2021-05-19 14:51:14 +02:00
										 |  |  |                                 , public BlackoilWellModelGeneric | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  |         public: | 
					
						
							|  |  |  |             // ---------      Types      ---------
 | 
					
						
							| 
									
										
										
										
											2018-06-21 12:14:17 +02:00
										 |  |  |             typedef BlackoilModelParametersEbos<TypeTag> ModelParameters; | 
					
						
							| 
									
										
										
										
											2016-08-23 09:45:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-26 10:49:52 +02:00
										 |  |  |             using Grid = GetPropType<TypeTag, Properties::Grid>; | 
					
						
							| 
									
										
										
										
											2021-12-01 14:00:21 +01:00
										 |  |  |             using EquilGrid = GetPropType<TypeTag, Properties::EquilGrid>; | 
					
						
							| 
									
										
										
										
											2020-08-26 10:49:52 +02:00
										 |  |  |             using FluidSystem = GetPropType<TypeTag, Properties::FluidSystem>; | 
					
						
							|  |  |  |             using ElementContext = GetPropType<TypeTag, Properties::ElementContext>; | 
					
						
							|  |  |  |             using Indices = GetPropType<TypeTag, Properties::Indices>; | 
					
						
							|  |  |  |             using Simulator = GetPropType<TypeTag, Properties::Simulator>; | 
					
						
							|  |  |  |             using Scalar = GetPropType<TypeTag, Properties::Scalar>; | 
					
						
							|  |  |  |             using RateVector = GetPropType<TypeTag, Properties::RateVector>; | 
					
						
							|  |  |  |             using GlobalEqVector = GetPropType<TypeTag, Properties::GlobalEqVector>; | 
					
						
							|  |  |  |             using SparseMatrixAdapter = GetPropType<TypeTag, Properties::SparseMatrixAdapter>; | 
					
						
							| 
									
										
										
										
											2022-02-07 11:28:35 +01:00
										 |  |  |             using GasLiftSingleWell = typename WellInterface<TypeTag>::GasLiftSingleWell; | 
					
						
							| 
									
										
										
										
											2021-05-27 08:31:49 +02:00
										 |  |  |             using GLiftOptWells = typename BlackoilWellModelGeneric::GLiftOptWells; | 
					
						
							|  |  |  |             using GLiftProdWells = typename BlackoilWellModelGeneric::GLiftProdWells; | 
					
						
							|  |  |  |             using GLiftWellStateMap = | 
					
						
							|  |  |  |                 typename BlackoilWellModelGeneric::GLiftWellStateMap; | 
					
						
							|  |  |  |             using GLiftEclWells = typename GasLiftGroupInfo::GLiftEclWells; | 
					
						
							|  |  |  |             using GLiftSyncGroups = typename GasLiftSingleWellGeneric::GLiftSyncGroups; | 
					
						
							| 
									
										
										
										
											2022-04-01 10:35:30 +02:00
										 |  |  |             constexpr static std::size_t pressureVarIndex = GetPropType<TypeTag, Properties::Indices>::pressureSwitchIdx; | 
					
						
							| 
									
										
										
										
											2021-05-05 11:22:44 +02:00
										 |  |  |             typedef typename BaseAuxiliaryModule<TypeTag>::NeighborSet NeighborSet; | 
					
						
							| 
									
										
										
										
											2017-05-03 13:34:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-04 09:14:08 +01:00
										 |  |  |             static const int numEq = Indices::numEq; | 
					
						
							|  |  |  |             static const int solventSaturationIdx = Indices::solventSaturationIdx; | 
					
						
							| 
									
										
										
										
											2021-01-28 14:33:21 +01:00
										 |  |  |             static constexpr bool has_solvent_ = getPropValue<TypeTag, Properties::EnableSolvent>(); | 
					
						
							|  |  |  |             static constexpr bool has_polymer_ = getPropValue<TypeTag, Properties::EnablePolymer>(); | 
					
						
							| 
									
										
										
										
											2021-03-08 15:11:50 +01:00
										 |  |  |             static constexpr bool has_energy_ = getPropValue<TypeTag, Properties::EnableEnergy>(); | 
					
						
							| 
									
										
										
										
											2021-10-06 19:32:35 +02:00
										 |  |  |             static constexpr bool has_micp_ = getPropValue<TypeTag, Properties::EnableMICP>(); | 
					
						
							| 
									
										
										
										
											2017-06-27 14:04:59 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-21 15:30:34 +02:00
										 |  |  |             // TODO: where we should put these types, WellInterface or Well Model?
 | 
					
						
							|  |  |  |             // or there is some other strategy, like TypeTag
 | 
					
						
							| 
									
										
										
										
											2017-05-03 13:34:15 +02:00
										 |  |  |             typedef Dune::FieldVector<Scalar, numEq    > VectorBlockType; | 
					
						
							| 
									
										
										
										
											2016-11-01 13:41:00 +01:00
										 |  |  |             typedef Dune::BlockVector<VectorBlockType> BVector; | 
					
						
							| 
									
										
										
										
											2017-05-03 13:34:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-05 11:22:44 +02:00
										 |  |  |             typedef BlackOilPolymerModule<TypeTag> PolymerModule; | 
					
						
							| 
									
										
										
										
											2021-10-06 19:32:35 +02:00
										 |  |  |             typedef BlackOilMICPModule<TypeTag> MICPModule; | 
					
						
							| 
									
										
										
										
											2016-11-18 12:43:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-17 13:14:32 +01:00
										 |  |  |             // For the conversion between the surface volume rate and resrevoir voidage rate
 | 
					
						
							|  |  |  |             using RateConverterType = RateConverter:: | 
					
						
							| 
									
										
										
										
											2017-11-08 13:57:36 +01:00
										 |  |  |                 SurfaceToReservoirVoidage<FluidSystem, std::vector<int> >; | 
					
						
							| 
									
										
										
										
											2016-11-01 13:41:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-01 15:04:54 +02:00
										 |  |  |             // For computing average pressured used by gpmaint
 | 
					
						
							| 
									
										
										
										
											2021-09-06 14:20:40 +02:00
										 |  |  |             using AverageRegionalPressureType = RegionAverageCalculator:: | 
					
						
							| 
									
										
										
										
											2021-09-01 15:04:54 +02:00
										 |  |  |                 AverageRegionalPressure<FluidSystem, std::vector<int> >; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             BlackoilWellModel(Simulator& ebosSimulator); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-03 17:26:57 +02:00
										 |  |  |             void init(); | 
					
						
							| 
									
										
										
										
											2022-04-12 08:44:52 +02:00
										 |  |  |             void initWellContainer(const int reportStepIdx) override; | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /////////////
 | 
					
						
							|  |  |  |             // <eWoms auxiliary module stuff>
 | 
					
						
							|  |  |  |             /////////////
 | 
					
						
							| 
									
										
										
										
											2021-06-14 09:09:33 +02:00
										 |  |  |             unsigned numDofs() const override | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             // No extra dofs are inserted for wells. (we use a Schur complement.)
 | 
					
						
							|  |  |  |             { return 0; } | 
					
						
							| 
									
										
										
										
											2017-05-03 13:34:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-14 09:09:33 +02:00
										 |  |  |             void addNeighbors(std::vector<NeighborSet>& neighbors) const override; | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-14 09:09:33 +02:00
										 |  |  |             void applyInitial() override | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-14 09:09:33 +02:00
										 |  |  |             void linearize(SparseMatrixAdapter& jacobian, GlobalEqVector& res) override; | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-14 09:09:33 +02:00
										 |  |  |             void postSolve(GlobalEqVector& deltaX) override | 
					
						
							| 
									
										
										
										
											2018-06-06 10:59:41 +02:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |                 recoverWellSolutionAndUpdateWellState(deltaX); | 
					
						
							| 
									
										
										
										
											2018-06-06 10:59:41 +02:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             /////////////
 | 
					
						
							|  |  |  |             // </ eWoms auxiliary module stuff>
 | 
					
						
							|  |  |  |             /////////////
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             template <class Restarter> | 
					
						
							| 
									
										
										
										
											2019-04-24 17:18:44 +02:00
										 |  |  |             void deserialize(Restarter& /* res */) | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             { | 
					
						
							|  |  |  |                 // TODO (?)
 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /*!
 | 
					
						
							|  |  |  |              * \brief This method writes the complete state of the well | 
					
						
							|  |  |  |              *        to the harddisk. | 
					
						
							|  |  |  |              */ | 
					
						
							|  |  |  |             template <class Restarter> | 
					
						
							| 
									
										
										
										
											2019-04-24 17:18:44 +02:00
										 |  |  |             void serialize(Restarter& /* res*/) | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             { | 
					
						
							|  |  |  |                 // TODO (?)
 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-03 17:26:57 +02:00
										 |  |  |             void beginEpisode() | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2023-03-21 22:44:14 +01:00
										 |  |  |                 OPM_TIMEBLOCK(beginEpsiode); | 
					
						
							| 
									
										
										
										
											2019-04-03 17:26:57 +02:00
										 |  |  |                 beginReportStep(ebosSimulator_.episodeIndex()); | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             void beginTimeStep(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             void beginIteration() | 
					
						
							|  |  |  |             { | 
					
						
							| 
									
										
										
										
											2023-03-21 22:44:14 +01:00
										 |  |  |                 OPM_TIMEBLOCK(beginIteration); | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |                 assemble(ebosSimulator_.model().newtonMethod().numIterations(), | 
					
						
							|  |  |  |                          ebosSimulator_.timeStepSize()); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             void endIteration() | 
					
						
							|  |  |  |             { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             void endTimeStep() | 
					
						
							|  |  |  |             { | 
					
						
							| 
									
										
										
										
											2023-03-21 22:44:14 +01:00
										 |  |  |                 OPM_TIMEBLOCK(endTimeStep); | 
					
						
							| 
									
										
										
										
											2018-11-30 12:15:51 +01:00
										 |  |  |                 timeStepSucceeded(ebosSimulator_.time(), ebosSimulator_.timeStepSize()); | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             void endEpisode() | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 endReportStep(); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2022-08-03 10:05:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-17 11:15:15 +02:00
										 |  |  |             void computeTotalRatesForDof(RateVector& rate, | 
					
						
							| 
									
										
										
										
											2022-08-10 10:01:54 +02:00
										 |  |  |                                          unsigned globalIdx) const; | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             template <class Context> | 
					
						
							|  |  |  |             void computeTotalRatesForDof(RateVector& rate, | 
					
						
							|  |  |  |                                          const Context& context, | 
					
						
							|  |  |  |                                          unsigned spaceIdx, | 
					
						
							|  |  |  |                                          unsigned timeIdx) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-14 13:18:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             using WellInterfacePtr = std::shared_ptr<WellInterface<TypeTag> >; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-19 14:51:14 +02:00
										 |  |  |             using BlackoilWellModelGeneric::initFromRestartFile; | 
					
						
							|  |  |  |             void initFromRestartFile(const RestartValue& restartValues) | 
					
						
							| 
									
										
										
										
											2021-03-26 22:10:16 +01:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2021-05-19 14:51:14 +02:00
										 |  |  |                 initFromRestartFile(restartValues, | 
					
						
							| 
									
										
										
										
											2021-10-11 14:38:41 +02:00
										 |  |  |                                     this->ebosSimulator_.vanguard().transferWTestState(), | 
					
						
							| 
									
										
										
										
											2021-12-01 14:00:21 +01:00
										 |  |  |                                     grid().size(0), | 
					
						
							| 
									
										
										
										
											2021-05-19 14:51:14 +02:00
										 |  |  |                                     param_.use_multisegment_well_); | 
					
						
							| 
									
										
										
										
											2021-03-26 22:10:16 +01:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-09 12:50:46 +01:00
										 |  |  |             using BlackoilWellModelGeneric::prepareDeserialize; | 
					
						
							|  |  |  |             void prepareDeserialize(const int report_step) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 prepareDeserialize(report_step, grid().size(0), | 
					
						
							|  |  |  |                                    param_.use_multisegment_well_); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-05 11:22:44 +02:00
										 |  |  |             data::Wells wellData() const | 
					
						
							| 
									
										
										
										
											2020-02-07 19:08:14 +01:00
										 |  |  |             { | 
					
						
							| 
									
										
										
										
											2021-06-21 16:15:10 +02:00
										 |  |  |                 auto wsrpt = this->wellState() | 
					
						
							| 
									
										
										
										
											2021-12-01 14:00:21 +01:00
										 |  |  |                     .report(ebosSimulator_.vanguard().globalCell().data(), | 
					
						
							| 
									
										
										
										
											2021-10-25 13:06:02 +02:00
										 |  |  |                             [this](const int well_index) -> bool | 
					
						
							| 
									
										
										
										
											2021-06-21 16:15:10 +02:00
										 |  |  |                 { | 
					
						
							| 
									
										
										
										
											2021-10-25 13:06:02 +02:00
										 |  |  |                     return this->wasDynamicallyShutThisTimeStep(well_index); | 
					
						
							| 
									
										
										
										
											2021-06-21 16:15:10 +02:00
										 |  |  |                 }); | 
					
						
							| 
									
										
										
										
											2020-02-07 19:08:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-11 14:58:38 +02:00
										 |  |  |                 this->assignWellTracerRates(wsrpt); | 
					
						
							| 
									
										
										
										
											2021-06-03 12:58:39 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-24 09:36:05 +02:00
										 |  |  |                 BlackoilWellModelGuideRates(*this).assignWellGuideRates(wsrpt, this->reportStepIndex()); | 
					
						
							| 
									
										
										
										
											2021-05-19 14:51:14 +02:00
										 |  |  |                 this->assignShutConnections(wsrpt, this->reportStepIndex()); | 
					
						
							| 
									
										
										
										
											2020-02-07 19:08:14 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 return wsrpt; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2016-08-25 15:25:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-02 14:56:19 +02:00
										 |  |  |             // subtract Binv(D)rw from r;
 | 
					
						
							| 
									
										
										
										
											2018-11-05 15:54:48 +01:00
										 |  |  |             void apply( BVector& r) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-07 13:23:52 +02:00
										 |  |  |             // subtract B*inv(D)*C * x from A*x
 | 
					
						
							| 
									
										
										
										
											2017-06-07 14:23:43 +02:00
										 |  |  |             void apply(const BVector& x, BVector& Ax) const; | 
					
						
							| 
									
										
										
										
											2016-08-25 15:25:01 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-13 14:21:59 +01:00
										 |  |  |             // accumulate the contributions of all Wells in the WellContributions object
 | 
					
						
							|  |  |  |             void getWellContributions(WellContributions& x) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-17 13:43:39 +01:00
										 |  |  |             // apply well model with scaling of alpha
 | 
					
						
							| 
									
										
										
										
											2017-06-07 14:23:43 +02:00
										 |  |  |             void applyScaleAdd(const Scalar alpha, const BVector& x, BVector& Ax) const; | 
					
						
							| 
									
										
										
										
											2016-11-17 13:43:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-08 13:57:36 +01:00
										 |  |  |             // Check if well equations is converged.
 | 
					
						
							| 
									
										
										
										
											2022-10-17 15:22:04 +02:00
										 |  |  |             ConvergenceReport getWellConvergence(const std::vector<Scalar>& B_avg, const bool checkWellGroupControls = false) const; | 
					
						
							| 
									
										
										
										
											2016-08-19 13:50:27 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-07 16:13:39 +02:00
										 |  |  |             const SimulatorReportSingle& lastReport() const; | 
					
						
							| 
									
										
										
										
											2017-08-08 10:44:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-05 14:21:28 +02:00
										 |  |  |             void addWellContributions(SparseMatrixAdapter& jacobian) const; | 
					
						
							| 
									
										
										
										
											2022-06-10 11:08:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-11 16:10:00 +02:00
										 |  |  |             // add source from wells to the reservoir matrix
 | 
					
						
							|  |  |  |             void addReservoirSourceTerms(GlobalEqVector& residual, | 
					
						
							| 
									
										
										
										
											2023-01-03 10:48:19 +01:00
										 |  |  |                                          std::vector<typename SparseMatrixAdapter::MatrixBlock*>& diagMatAddress) const; | 
					
						
							| 
									
										
										
										
											2022-10-11 16:10:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-08 13:57:36 +01:00
										 |  |  |             // called at the beginning of a report step
 | 
					
						
							|  |  |  |             void beginReportStep(const int time_step); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-01 16:41:46 +02:00
										 |  |  |             void updatePerforationIntensiveQuantities(); | 
					
						
							|  |  |  |             // it should be able to go to prepareTimeStep(), however, the updateWellControls() and initPrimaryVariablesEvaluation()
 | 
					
						
							|  |  |  |             // makes it a little more difficult. unless we introduce if (iterationIdx != 0) to avoid doing the above functions
 | 
					
						
							|  |  |  |             // twice at the beginning of the time step
 | 
					
						
							|  |  |  |             /// Calculating the explict quantities used in the well calculation. By explicit, we mean they are cacluated
 | 
					
						
							|  |  |  |             /// at the beginning of the time step and no derivatives are included in these quantities
 | 
					
						
							| 
									
										
										
										
											2021-05-05 11:22:44 +02:00
										 |  |  |             void calculateExplicitQuantities(DeferredLogger& deferred_logger) const; | 
					
						
							| 
									
										
										
										
											2021-04-01 16:41:46 +02:00
										 |  |  |             // some preparation work, mostly related to group control and RESV,
 | 
					
						
							|  |  |  |             // at the beginning of each time step (Not report step)
 | 
					
						
							| 
									
										
										
										
											2021-05-05 11:22:44 +02:00
										 |  |  |             void prepareTimeStep(DeferredLogger& deferred_logger); | 
					
						
							| 
									
										
										
										
											2021-04-01 16:41:46 +02:00
										 |  |  |             void initPrimaryVariablesEvaluation() const; | 
					
						
							| 
									
										
										
										
											2022-10-20 11:03:29 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-21 13:37:28 +02:00
										 |  |  |             std::pair<bool, bool> | 
					
						
							|  |  |  |             updateWellControls(const bool mandatory_network_balance, DeferredLogger& deferred_logger, | 
					
						
							|  |  |  |                                const std::size_t network_update_it); | 
					
						
							| 
									
										
										
										
											2021-08-25 14:06:56 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             void updateAndCommunicate(const int reportStepIdx, | 
					
						
							|  |  |  |                                       const int iterationIdx, | 
					
						
							|  |  |  |                                       DeferredLogger& deferred_logger); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-29 09:22:56 +02:00
										 |  |  |             bool updateGroupControls(const Group& group, | 
					
						
							|  |  |  |                                     DeferredLogger& deferred_logger, | 
					
						
							|  |  |  |                                     const int reportStepIdx, | 
					
						
							|  |  |  |                                     const int iterationIdx); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-01 16:41:46 +02:00
										 |  |  |             WellInterfacePtr getWell(const std::string& well_name) const; | 
					
						
							| 
									
										
										
										
											2021-08-19 12:15:35 +02:00
										 |  |  |             bool hasWell(const std::string& well_name) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-10 11:08:24 +02:00
										 |  |  |             using PressureMatrix = Dune::BCRSMatrix<Opm::MatrixBlock<double, 1, 1>>; | 
					
						
							| 
									
										
										
										
											2021-01-04 15:18:23 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-05 14:21:28 +02:00
										 |  |  |             int numLocalWellsEnd() const; | 
					
						
							| 
									
										
										
										
											2022-06-10 11:08:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-05 14:21:28 +02:00
										 |  |  |             void addWellPressureEquations(PressureMatrix& jacobian, const BVector& weights,const bool use_well_weights) const; | 
					
						
							| 
									
										
										
										
											2022-04-19 11:53:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-05 14:21:28 +02:00
										 |  |  |             std::vector<std::vector<int>> getMaxWellConnections() const; | 
					
						
							| 
									
										
										
										
											2022-06-10 11:08:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-05 14:21:28 +02:00
										 |  |  |             void addWellPressureEquationsStruct(PressureMatrix& jacobian) const; | 
					
						
							| 
									
										
										
										
											2022-04-19 11:53:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-27 08:31:49 +02:00
										 |  |  |             void initGliftEclWellMap(GLiftEclWells &ecl_well_map); | 
					
						
							| 
									
										
										
										
											2021-05-19 14:51:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-07 21:09:25 +02:00
										 |  |  |             /// \brief Get list of local nonshut wells
 | 
					
						
							| 
									
										
										
										
											2022-05-09 11:22:59 +02:00
										 |  |  |             const std::vector<WellInterfacePtr>& localNonshutWells() const | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 return well_container_; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-10-07 21:09:25 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-09 11:22:59 +02:00
										 |  |  |             int numLocalNonshutWells() const; | 
					
						
							| 
									
										
										
										
											2022-04-01 22:34:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-08 13:57:36 +01:00
										 |  |  |         protected: | 
					
						
							|  |  |  |             Simulator& ebosSimulator_; | 
					
						
							| 
									
										
										
										
											2019-10-23 09:09:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-15 17:19:49 +02:00
										 |  |  |             // a vector of all the wells.
 | 
					
						
							| 
									
										
										
										
											2022-11-11 21:41:24 +01:00
										 |  |  |             std::vector<WellInterfacePtr> well_container_{}; | 
					
						
							| 
									
										
										
										
											2017-06-15 17:19:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-02 00:14:34 +01:00
										 |  |  |             std::vector<bool> is_cell_perforated_{}; | 
					
						
							| 
									
										
										
										
											2018-11-15 14:37:01 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-20 00:16:52 +02:00
										 |  |  |             void initializeWellState(const int           timeStepIdx, | 
					
						
							|  |  |  |                                      const SummaryState& summaryState); | 
					
						
							| 
									
										
										
										
											2019-10-23 09:09:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 10:23:42 +02:00
										 |  |  |             // create the well container
 | 
					
						
							| 
									
										
										
										
											2021-06-07 15:01:10 +02:00
										 |  |  |             void createWellContainer(const int time_step) override; | 
					
						
							| 
									
										
										
										
											2017-06-15 17:19:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-01 18:04:46 +01:00
										 |  |  |             WellInterfacePtr | 
					
						
							|  |  |  |             createWellPointer(const int wellID, | 
					
						
							|  |  |  |                               const int time_step) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             template <typename WellType> | 
					
						
							|  |  |  |             std::unique_ptr<WellType> | 
					
						
							|  |  |  |             createTypedWellPointer(const int wellID, | 
					
						
							|  |  |  |                                    const int time_step) const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-05 11:22:44 +02:00
										 |  |  |             WellInterfacePtr createWellForWellTest(const std::string& well_name, const int report_step, DeferredLogger& deferred_logger) const; | 
					
						
							| 
									
										
										
										
											2018-10-31 14:56:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-09 10:36:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-08 13:57:36 +01:00
										 |  |  |             const ModelParameters param_; | 
					
						
							| 
									
										
										
										
											2023-01-05 12:36:46 +01:00
										 |  |  |             std::size_t global_num_cells_{}; | 
					
						
							| 
									
										
										
										
											2017-08-11 14:51:29 +02:00
										 |  |  |             // the number of the cells in the local grid
 | 
					
						
							| 
									
										
										
										
											2023-01-05 12:36:46 +01:00
										 |  |  |             std::size_t local_num_cells_{}; | 
					
						
							| 
									
										
										
										
											2021-03-02 00:14:34 +01:00
										 |  |  |             double gravity_{}; | 
					
						
							|  |  |  |             std::vector<double> depth_{}; | 
					
						
							|  |  |  |             bool alternative_well_rate_init_{}; | 
					
						
							| 
									
										
										
										
											2020-10-29 23:30:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-02 00:14:34 +01:00
										 |  |  |             std::unique_ptr<RateConverterType> rateConverter_{}; | 
					
						
							| 
									
										
										
										
											2023-01-11 10:49:51 +01:00
										 |  |  |             std::map<std::string, std::unique_ptr<AverageRegionalPressureType>> regionalAveragePressureCalculator_{}; | 
					
						
							| 
									
										
										
										
											2021-09-01 15:04:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-02 00:14:34 +01:00
										 |  |  |             SimulatorReportSingle last_report_{}; | 
					
						
							| 
									
										
										
										
											2017-03-24 15:12:42 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-21 00:04:28 +02:00
										 |  |  |             // solve to get a good network solution, group and well states might be updated during the process.
 | 
					
						
							|  |  |  |             // the reservoir should stay static during this solution procedure.
 | 
					
						
							|  |  |  |             void balanceNetwork(DeferredLogger& deferred_logger); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // TODO: funciton can go to BlackoilWellModelGeneric?
 | 
					
						
							|  |  |  |             bool needRebalanceNetwork() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 10:23:42 +02:00
										 |  |  |             // used to better efficiency of calcuation
 | 
					
						
							| 
									
										
										
										
											2021-03-02 00:14:34 +01:00
										 |  |  |             mutable BVector scaleAddRes_{}; | 
					
						
							| 
									
										
										
										
											2016-11-02 10:43:55 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-02 00:14:34 +01:00
										 |  |  |             std::vector<Scalar> B_avg_{}; | 
					
						
							| 
									
										
										
										
											2021-03-18 14:49:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-06 10:59:41 +02:00
										 |  |  |             const Grid& grid() const | 
					
						
							|  |  |  |             { return ebosSimulator_.vanguard().grid(); } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-01 14:00:21 +01:00
										 |  |  |             const EquilGrid& equilGrid() const | 
					
						
							|  |  |  |             { return ebosSimulator_.vanguard().equilGrid(); } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-06 10:59:41 +02:00
										 |  |  |             const EclipseState& eclState() const | 
					
						
							|  |  |  |             { return ebosSimulator_.vanguard().eclState(); } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  |             // compute the well fluxes and assemble them in to the reservoir equations as source terms
 | 
					
						
							|  |  |  |             // and in the well equations.
 | 
					
						
							|  |  |  |             void assemble(const int iterationIdx, | 
					
						
							|  |  |  |                           const double dt); | 
					
						
							| 
									
										
										
										
											2022-10-20 11:03:29 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-20 15:47:31 +02:00
										 |  |  |             // well controls and network pressures affect each other and are solved in an iterative manner.
 | 
					
						
							|  |  |  |             // the function handles one iteration of updating well controls and network pressures.
 | 
					
						
							|  |  |  |             // it is possible to decouple the update of well controls and network pressures further.
 | 
					
						
							| 
									
										
										
										
											2022-10-20 11:03:29 +02:00
										 |  |  |             // the returned two booleans are {continue_due_to_network, well_group_control_changed}, respectively
 | 
					
						
							| 
									
										
										
										
											2023-04-21 13:37:28 +02:00
										 |  |  |             std::pair<bool, bool> updateWellControlsAndNetworkIteration(const bool mandatory_network_balance, | 
					
						
							|  |  |  |                                                                         const double dt, | 
					
						
							| 
									
										
										
										
											2022-10-20 11:03:29 +02:00
										 |  |  |                                                                         const std::size_t network_update_iteration, | 
					
						
							|  |  |  |                                                                         DeferredLogger& local_deferredLogger); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-21 13:37:28 +02:00
										 |  |  |             bool updateWellControlsAndNetwork(const bool mandatory_network_balance, | 
					
						
							|  |  |  |                                               const double dt, | 
					
						
							|  |  |  |                                               DeferredLogger& local_deferredLogger); | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // called at the end of a time step
 | 
					
						
							| 
									
										
										
										
											2018-11-30 12:15:51 +01:00
										 |  |  |             void timeStepSucceeded(const double& simulationTime, const double dt); | 
					
						
							| 
									
										
										
										
											2018-08-16 11:51:36 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // called at the end of a report step
 | 
					
						
							|  |  |  |             void endReportStep(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // using the solution x to recover the solution xw for wells and applying
 | 
					
						
							|  |  |  |             // xw to update Well State
 | 
					
						
							|  |  |  |             void recoverWellSolutionAndUpdateWellState(const BVector& x); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-10 15:27:05 +02:00
										 |  |  |             // setting the well_solutions_ based on well_state.
 | 
					
						
							| 
									
										
										
										
											2021-05-05 11:22:44 +02:00
										 |  |  |             void updatePrimaryVariables(DeferredLogger& deferred_logger); | 
					
						
							| 
									
										
										
										
											2017-08-10 15:27:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-18 14:49:52 +01:00
										 |  |  |             void updateAverageFormationFactor(); | 
					
						
							| 
									
										
										
										
											2017-08-10 15:27:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-07 14:09:36 +02:00
										 |  |  |             void computePotentials(const std::size_t widx, | 
					
						
							|  |  |  |                                    const WellState& well_state_copy, | 
					
						
							|  |  |  |                                    std::string& exc_msg, | 
					
						
							|  |  |  |                                    ExceptionType::ExcEnum& exc_type, | 
					
						
							| 
									
										
										
										
											2021-06-07 13:04:29 +02:00
										 |  |  |                                    DeferredLogger& deferred_logger) override; | 
					
						
							| 
									
										
										
										
											2021-06-07 14:09:36 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-10 15:27:05 +02:00
										 |  |  |             const std::vector<double>& wellPerfEfficiencyFactors() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-07 15:01:10 +02:00
										 |  |  |             void calculateProductivityIndexValuesShutWells(const int reportStepIdx, DeferredLogger& deferred_logger) override; | 
					
						
							|  |  |  |             void calculateProductivityIndexValues(DeferredLogger& deferred_logger) override; | 
					
						
							| 
									
										
										
										
											2021-03-02 01:11:19 +01:00
										 |  |  |             void calculateProductivityIndexValues(const WellInterface<TypeTag>* wellPtr, | 
					
						
							|  |  |  |                                                   DeferredLogger& deferred_logger); | 
					
						
							| 
									
										
										
										
											2020-10-09 13:38:33 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-03-28 16:14:14 +02:00
										 |  |  |             // The number of components in the model.
 | 
					
						
							|  |  |  |             int numComponents() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             int reportStepIndex() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-02 13:33:23 +02:00
										 |  |  |             void assembleWellEq(const double dt, DeferredLogger& deferred_logger); | 
					
						
							| 
									
										
										
										
											2017-08-14 14:11:58 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-10-20 11:03:29 +02:00
										 |  |  |             void prepareWellsBeforeAssembling(const double dt, DeferredLogger& deferred_logger); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // TODO: finding a better naming
 | 
					
						
							|  |  |  |             void assembleWellEqWithoutIteration(const double dt, DeferredLogger& deferred_logger); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-08 15:46:08 +01:00
										 |  |  |             bool maybeDoGasLiftOptimize(DeferredLogger& deferred_logger); | 
					
						
							| 
									
										
										
										
											2021-03-03 13:59:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-27 08:31:49 +02:00
										 |  |  |             void gasLiftOptimizationStage1(DeferredLogger& deferred_logger, | 
					
						
							|  |  |  |                 GLiftProdWells &prod_wells, GLiftOptWells &glift_wells, | 
					
						
							|  |  |  |                 GasLiftGroupInfo &group_info, GLiftWellStateMap &state_map); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-07 11:28:35 +01:00
										 |  |  |             // cannot be const since it accesses the non-const WellState
 | 
					
						
							|  |  |  |             void gasLiftOptimizationStage1SingleWell(WellInterface<TypeTag> *well, | 
					
						
							|  |  |  |                 DeferredLogger& deferred_logger, | 
					
						
							|  |  |  |                 GLiftProdWells &prod_wells, GLiftOptWells &glift_wells, | 
					
						
							|  |  |  |                 GasLiftGroupInfo &group_info, GLiftWellStateMap &state_map, | 
					
						
							|  |  |  |                 GLiftSyncGroups& groups_to_sync); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-08 15:48:30 +01:00
										 |  |  |             void extractLegacyCellPvtRegionIndex_(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             void extractLegacyDepth_(); | 
					
						
							| 
									
										
										
										
											2017-11-08 13:57:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-28 13:47:10 +02:00
										 |  |  |             /// upate the wellTestState related to economic limits
 | 
					
						
							|  |  |  |             void updateWellTestState(const double& simulationTime, WellTestState& wellTestState) const; | 
					
						
							| 
									
										
										
										
											2017-11-08 13:57:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-05 11:22:44 +02:00
										 |  |  |             void wellTesting(const int timeStepIdx, const double simulationTime, DeferredLogger& deferred_logger); | 
					
						
							| 
									
										
										
										
											2018-06-06 15:17:59 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-19 14:51:14 +02:00
										 |  |  |             void calcRates(const int fipnum, | 
					
						
							|  |  |  |                            const int pvtreg, | 
					
						
							| 
									
										
										
										
											2023-03-24 14:59:52 +01:00
										 |  |  |                            const std::vector<double>& production_rates, | 
					
						
							| 
									
										
										
										
											2021-05-19 14:51:14 +02:00
										 |  |  |                            std::vector<double>& resv_coeff) override; | 
					
						
							| 
									
										
										
										
											2019-09-23 15:15:55 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-08 15:29:15 +02:00
										 |  |  |             void calcInjRates(const int fipnum, | 
					
						
							|  |  |  |                            const int pvtreg, | 
					
						
							|  |  |  |                            std::vector<double>& resv_coeff) override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-03 12:58:39 +02:00
										 |  |  |             void computeWellTemperature(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-11 14:58:38 +02:00
										 |  |  |             void assignWellTracerRates(data::Wells& wsrpt) const; | 
					
						
							| 
									
										
										
										
											2020-05-15 11:21:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-19 16:50:42 +02:00
										 |  |  |             int compressedIndexForInterior(int cartesian_cell_idx) const override { | 
					
						
							|  |  |  |                 return ebosSimulator_.vanguard().compressedIndexForInterior(cartesian_cell_idx); | 
					
						
							| 
									
										
										
										
											2021-09-27 11:28:27 +02:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-26 22:10:16 +01:00
										 |  |  |         private: | 
					
						
							| 
									
										
										
										
											2021-04-25 20:47:31 +02:00
										 |  |  |             BlackoilWellModel(Simulator& ebosSimulator, const PhaseUsage& pu); | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  |         }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace Opm
 | 
					
						
							| 
									
										
										
										
											2017-02-13 16:45:06 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-26 10:52:05 +02:00
										 |  |  | #include "BlackoilWellModel_impl.hpp"
 | 
					
						
							| 
									
										
										
										
											2016-08-11 13:31:52 +02:00
										 |  |  | #endif
 |