opm-simulators
WellGroupControls.hpp
1 /*
2  Copyright 2017 SINTEF Digital, Mathematics and Cybernetics.
3  Copyright 2017 Statoil ASA.
4  Copyright 2017 IRIS
5  Copyright 2019 Norce
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 
24 #ifndef OPM_WELL_GROUP_CONTROLS_HEADER_INCLUDED
25 #define OPM_WELL_GROUP_CONTROLS_HEADER_INCLUDED
26 
27 #include <opm/input/eclipse/Schedule/Group/GuideRate.hpp>
28 #include <string>
29 #include <functional>
30 #include <optional>
31 #include <vector>
32 
33 namespace Opm
34 {
35 
36 class DeferredLogger;
37 class Group;
38 template<class Scalar> class GroupState;
39 enum class InjectorType;
40 using RegionId = int;
41 class Schedule;
42 class SummaryState;
43 template<typename Scalar, typename IndexTraits> class GroupStateHelper;
44 template<typename Scalar, typename IndexTraits> class WellInterfaceGeneric;
45 template<typename Scalar, typename IndexTraits> class WellState;
46 
48 template<typename Scalar, typename IndexTraits>
50 public:
52  explicit WellGroupControls(const WellInterfaceGeneric<Scalar, IndexTraits>& well) : well_(well) {}
53 
54  using RateConvFunc = std::function<void(const RegionId, const int,
55  const std::optional<std::string>&, std::vector<Scalar>&)>;
56  using GroupStateHelperType = GroupStateHelper<Scalar, IndexTraits>;
57 
58  template<class EvalWell>
59  void getGroupInjectionControl(const Group& group,
60  const GroupStateHelperType& groupStateHelper,
61  const InjectorType& injectorType,
62  const EvalWell& bhp,
63  const EvalWell& injection_rate,
64  const RateConvFunc& rateConverter,
65  Scalar efficiencyFactor,
66  EvalWell& control_eq) const;
67 
68  std::optional<Scalar>
69  getGroupInjectionTargetRate(const Group& group,
70  const GroupStateHelperType& groupStateHelper,
71  const InjectorType& injectorType,
72  const RateConvFunc& rateConverter,
73  Scalar efficiencyFactor) const;
74 
75  template<class EvalWell>
76  void getGroupProductionControl(const Group& group,
77  const GroupStateHelperType& groupStateHelper,
78  const EvalWell& bhp,
79  const std::vector<EvalWell>& rates,
80  const RateConvFunc& rateConverter,
81  Scalar efficiencyFactor,
82  EvalWell& control_eq) const;
83 
84  Scalar getGroupProductionTargetRate(const Group& group,
85  const GroupStateHelperType& groupStateHelper,
86  const RateConvFunc& rateConverter,
87  Scalar efficiencyFactor) const;
88 
89 private:
91 };
92 
93 }
94 
95 #endif // OPM_WELL_GROUP_CONTROLS_HEADER_INCLUDED
WellGroupControls(const WellInterfaceGeneric< Scalar, IndexTraits > &well)
Constructor sets reference to well.
Definition: WellGroupControls.hpp:52
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition: blackoilbioeffectsmodules.hh:45
Definition: BlackoilWellModelConstraints.hpp:37
Class for computing well group controls.
Definition: WellGroupControls.hpp:49
Definition: BlackoilWellModelGeneric.hpp:75