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
107 ProductionRates collectSlaveGroupSurfaceProductionRates_(std::size_t group_idx) const;
108
114 ProductionRates collectSlaveGroupReservoirProductionRates_(std::size_t group_idx) const;
115
119 Scalar collectSlaveGroupVoidageRate_(std::size_t group_idx) const;
120
124 InjectionRates createInjectionRatesFromRateVector_(const std::vector<Scalar>& rate_vector) const;
125
130 void sendSlaveGroupProductionDataToMaster_() const;
131
136 void sendSlaveGroupInjectionDataToMaster_() const;
137
139 const GroupStateHelperType& groupStateHelper_;
140
142 ReservoirCouplingSlave<Scalar>& reservoir_coupling_slave_;
143
145 const Schedule& schedule_;
146
148 const GroupState<Scalar>& group_state_;
149
151 const PhaseUsageInfo<IndexTraits>& phase_usage_;
152
154 const int report_step_idx_;
155};
156
157} // namespace Opm
158
159#endif // OPM_RESCOUP_SEND_SLAVE_GROUP_DATA_HPP
Definition: GroupStateHelper.hpp:53
const Parallel::Communication & comm() const
Definition: GroupStateHelper.hpp:142
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:155
Definition: ReservoirCoupling.hpp:166
Definition: ReservoirCoupling.hpp:174
Definition: ReservoirCoupling.hpp:205
Definition: ReservoirCoupling.hpp:190