RescoupSendSlaveGroupData.hpp
Go to the documentation of this file.
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
28
29namespace Opm {
30
49template<class Scalar, class IndexTraits>
51public:
58
62
65 const Parallel::Communication& comm() const { return this->groupStateHelper_.comm(); }
66
83private:
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: GroupStateHelper.hpp:55
const Parallel::Communication & comm() const
Definition: GroupStateHelper.hpp:223
Definition: GroupState.hpp:41
Definition: GasLiftGroupInfo.hpp:37
Collects and sends group data from slave process to master in reservoir coupling.
Definition: RescoupSendSlaveGroupData.hpp:50
void sendSlaveGroupDataToMaster()
Collect and send group data to the master process.
RescoupSendSlaveGroupData(GroupStateHelperType &groupStateHelper)
Construct a sender for slave group data.
const Parallel::Communication & comm() const
Get the communication object.
Definition: RescoupSendSlaveGroupData.hpp:65
Definition: ReservoirCouplingSlave.hpp:40
Dune::Communication< MPIComm > Communication
Definition: ParallelCommunication.hpp:30
Definition: blackoilbioeffectsmodules.hh:43
Definition: ReservoirCoupling.hpp:177
Definition: ReservoirCoupling.hpp:188
Definition: ReservoirCoupling.hpp:196
Definition: ReservoirCoupling.hpp:230
Definition: ReservoirCoupling.hpp:212