opm-simulators
BlackoilWellModelConstraints.hpp
1 /*
2  Copyright 2016 SINTEF ICT, Applied Mathematics.
3  Copyright 2016 - 2017 Statoil ASA.
4  Copyright 2017 Dr. Blatt - HPC-Simulation-Software & Services
5  Copyright 2016 - 2018 IRIS AS
6 
7  This file is part of the Open Porous Media project (OPM).
8 
9  OPM is free software: you can redistribute it and/or modify
10  it under the terms of the GNU General Public License as published by
11  the Free Software Foundation, either version 3 of the License, or
12  (at your option) any later version.
13 
14  OPM is distributed in the hope that it will be useful,
15  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  GNU General Public License for more details.
18 
19  You should have received a copy of the GNU General Public License
20  along with OPM. If not, see <http://www.gnu.org/licenses/>.
21 */
22 
23 #ifndef OPM_BLACKOILWELLMODEL_CONSTRAINTS_HEADER_INCLUDED
24 #define OPM_BLACKOILWELLMODEL_CONSTRAINTS_HEADER_INCLUDED
25 
26 #include <opm/input/eclipse/Schedule/Group/Group.hpp>
27 #include <optional>
28 #include <utility>
29 
30 namespace Opm {
31 
32 template<typename Scalar, typename IndexTraits> class BlackoilWellModelGeneric;
33 class DeferredLogger;
34 template<class Scalar> class GroupState;
35 class SummaryState;
36 template<typename Scalar, typename IndexTraits> class WellState;
37 template<typename Scalar, typename IndexTraits> class GroupStateHelper;
38 
40 template<typename Scalar, typename IndexTraits>
42 {
43 public:
44 
45  constexpr static int waterPhaseIdx = IndexTraits::waterPhaseIdx;
46  constexpr static int oilPhaseIdx = IndexTraits::oilPhaseIdx;
47  constexpr static int gasPhaseIdx = IndexTraits::gasPhaseIdx;
48 
50 
53  : wellModel_(wellModel)
54  {}
55 
57  void actionOnBrokenConstraints(const Group& group,
58  const Group::InjectionCMode& newControl,
59  const Phase& controlPhase,
60  GroupState<Scalar>& group_state,
61  DeferredLogger& deferred_logger) const;
62 
64  bool actionOnBrokenConstraints(const Group& group,
65  const Group::GroupLimitAction group_limit_action,
66  const Group::ProductionCMode& newControl,
67  std::optional<std::string>& worst_offending_well,
68  GroupState<Scalar>& group_state,
69  DeferredLogger& deferred_logger) const;
70 
72  bool updateGroupIndividualControl(const Group& group,
73  const int reportStepIdx,
74  const int max_number_of_group_switch,
75  const bool update_group_switching_log,
76  std::map<std::string, std::array<std::vector<Group::InjectionCMode>, 3>>& switched_inj,
77  std::map<std::string, std::vector<Group::ProductionCMode>>& switched_prod,
78  std::map<std::string, std::pair<std::string, std::string>>& closed_offending_wells,
79  GroupState<Scalar>& group_state,
81  DeferredLogger& deferred_logger) const;
82 
83 private:
85  std::pair<Group::InjectionCMode, Scalar>
86  checkGroupInjectionConstraints(const Group& group,
87  const int reportStepIdx,
88  const Phase& phase) const;
89 
91  std::pair<Group::ProductionCMode, Scalar>
92  checkGroupProductionConstraints(const Group& group) const;
93 
94  const GroupStateHelperType& groupStateHelper() const { return wellModel_.groupStateHelper(); }
95  const BlackoilWellModelGeneric<Scalar, IndexTraits>& wellModel_;
96 };
97 
98 } // namespace Opm
99 
100 #endif
Class for handling the blackoil well model.
Definition: ActionHandler.hpp:39
Definition: BlackoilWellModelConstraints.hpp:34
Class for handling constraints for the blackoil well model.
Definition: BlackoilWellModelConstraints.hpp:41
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition: blackoilbioeffectsmodules.hh:45
Definition: BlackoilWellModelConstraints.hpp:37
Definition: DeferredLogger.hpp:56
BlackoilWellModelConstraints(const BlackoilWellModelGeneric< Scalar, IndexTraits > &wellModel)
Constructor initializes reference to the well model.
Definition: BlackoilWellModelConstraints.hpp:52
void actionOnBrokenConstraints(const Group &group, const Group::InjectionCMode &newControl, const Phase &controlPhase, GroupState< Scalar > &group_state, DeferredLogger &deferred_logger) const
Execute action for broken constraint for an injection well group.
Definition: BlackoilWellModelConstraints.cpp:189
bool updateGroupIndividualControl(const Group &group, const int reportStepIdx, const int max_number_of_group_switch, const bool update_group_switching_log, std::map< std::string, std::array< std::vector< Group::InjectionCMode >, 3 >> &switched_inj, std::map< std::string, std::vector< Group::ProductionCMode >> &switched_prod, std::map< std::string, std::pair< std::string, std::string >> &closed_offending_wells, GroupState< Scalar > &group_state, WellState< Scalar, IndexTraits > &well_state, DeferredLogger &deferred_logger) const
Update the individual controls for wells in a group. Return true if a group control is changed...
Definition: BlackoilWellModelConstraints.cpp:315
The state of a set of wells, tailored for use by the fully implicit blackoil simulator.
Definition: TemperatureModel.hpp:61