opm-simulators
Loading...
Searching...
No Matches
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
29namespace Opm {
30
49template<class Scalar, class IndexTraits>
51public:
52 using SlaveGroupProductionData = ReservoirCoupling::SlaveGroupProductionData<Scalar>;
53 using SlaveGroupInjectionData = ReservoirCoupling::SlaveGroupInjectionData<Scalar>;
55 using ProductionRates = ReservoirCoupling::ProductionRates<Scalar>;
56 using InjectionRates = ReservoirCoupling::InjectionRates<Scalar>;
57 using GroupStateHelperType = GroupStateHelper<Scalar, IndexTraits>;
58
61 RescoupSendSlaveGroupData(GroupStateHelperType& groupStateHelper);
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:57
Definition GroupState.hpp:41
Definition GasLiftGroupInfo.hpp:38
void sendSlaveGroupDataToMaster()
Collect and send group data to the master process.
Definition RescoupSendSlaveGroupData.cpp:119
RescoupSendSlaveGroupData(GroupStateHelperType &groupStateHelper)
Construct a sender for slave group data.
Definition RescoupSendSlaveGroupData.cpp:39
const Parallel::Communication & comm() const
Get the communication object.
Definition RescoupSendSlaveGroupData.hpp:65
Definition ReservoirCouplingSlave.hpp:40
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition blackoilbioeffectsmodules.hh:45
Definition ReservoirCoupling.hpp:177
Definition ReservoirCoupling.hpp:187
Definition ReservoirCoupling.hpp:195
Definition ReservoirCoupling.hpp:229
Definition ReservoirCoupling.hpp:211