opm-simulators
RescoupSendSlaveGroupData.hpp
1 /*
2  Copyright 2025 Equinor ASA
3 
4  This file is part of the Open Porous Media project (OPM).
5 
6  OPM is free software: you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  OPM is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with OPM. If not, see <http://www.gnu.org/licenses/>.
18 */
19 
20 #ifndef OPM_RESCOUP_SEND_SLAVE_GROUP_DATA_HPP
21 #define OPM_RESCOUP_SEND_SLAVE_GROUP_DATA_HPP
22 
23 #include <opm/simulators/flow/rescoup/ReservoirCoupling.hpp>
24 #include <opm/simulators/wells/GuideRateHandler.hpp>
25 #include <opm/simulators/wells/GroupState.hpp>
26 #include <opm/simulators/wells/GroupStateHelper.hpp>
27 #include <opm/simulators/utils/DeferredLogger.hpp>
28 
29 namespace Opm {
30 
49 template<class Scalar, class IndexTraits>
51 public:
58 
62 
65  const Parallel::Communication& comm() const { return this->groupStateHelper_.comm(); }
66 
83 private:
87  Potentials collectSlaveGroupPotentials_(std::size_t group_idx) const;
88 
92  SlaveGroupInjectionData collectSlaveGroupInjectionData_(std::size_t group_idx) const;
93 
97  SlaveGroupProductionData collectSlaveGroupProductionData_(std::size_t group_idx) const;
98 
102  Scalar collectSlaveGroupReinjectionRateForGasPhase_(std::size_t group_idx) const;
103 
109  ProductionRates collectSlaveGroupSurfaceProductionRates_(std::size_t group_idx) const;
110 
116  ProductionRates collectSlaveGroupNetworkSurfaceProductionRates_(std::size_t group_idx) const;
117 
123  ProductionRates collectSlaveGroupReservoirProductionRates_(std::size_t group_idx) const;
124 
128  Scalar collectSlaveGroupVoidageRate_(std::size_t group_idx) const;
129 
133  InjectionRates createInjectionRatesFromRateVector_(const std::vector<Scalar>& rate_vector) const;
134 
139  void sendSlaveGroupProductionDataToMaster_() const;
140 
145  void sendSlaveGroupInjectionDataToMaster_() const;
146 
148  const GroupStateHelperType& groupStateHelper_;
149 
151  ReservoirCouplingSlave<Scalar>& reservoir_coupling_slave_;
152 
154  const Schedule& schedule_;
155 
157  const GroupState<Scalar>& group_state_;
158 
160  const PhaseUsageInfo<IndexTraits>& phase_usage_;
161 
163  const int report_step_idx_;
164 };
165 
166 } // namespace Opm
167 
168 #endif // OPM_RESCOUP_SEND_SLAVE_GROUP_DATA_HPP
Definition: ReservoirCoupling.hpp:177
void sendSlaveGroupDataToMaster()
Collect and send group data to the master process.
Definition: RescoupSendSlaveGroupData.cpp:119
Definition: BlackoilWellModelConstraints.hpp:34
Definition: ReservoirCoupling.hpp:229
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition: blackoilbioeffectsmodules.hh:45
Definition: BlackoilWellModelConstraints.hpp:37
Definition: ReservoirCoupling.hpp:195
Definition: ReservoirCoupling.hpp:187
Definition: GasLiftGroupInfo.hpp:38
Definition: ReservoirCouplingSlave.hpp:40
RescoupSendSlaveGroupData(GroupStateHelperType &groupStateHelper)
Construct a sender for slave group data.
Definition: RescoupSendSlaveGroupData.cpp:39
Collects and sends group data from slave process to master in reservoir coupling. ...
Definition: RescoupSendSlaveGroupData.hpp:50
const Parallel::Communication & comm() const
Get the communication object.
Definition: RescoupSendSlaveGroupData.hpp:65
Definition: ReservoirCoupling.hpp:211