opm-simulators
ParallelSerialization.hpp
1 /*
2  Copyright 2020 Equinor AS.
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 #ifndef PARALLEL_SERIALIZATION_HPP
20 #define PARALLEL_SERIALIZATION_HPP
21 
22 #include <opm/simulators/utils/ParallelCommunication.hpp>
23 
24 namespace Opm {
25 
26 class EclipseState;
27 class Schedule;
28 class SummaryConfig;
29 class UDQState;
30 class WellTestState;
31 class TransMult;
32 
33 namespace Action {
34 class State;
35 }
36 
46 void eclStateBroadcast(Parallel::Communication comm,
47  EclipseState& eclState,
48  Schedule& schedule,
49  SummaryConfig& summaryConfig,
50  UDQState& udqState,
51  Action::State& actionState,
52  WellTestState& wtestState);
53 
54 
55 template <class T>
56 void eclBroadcast(Parallel::Communication, T& )
57 #if HAVE_MPI
58 ;
59 #else
60 {}
61 #endif
62 
63 
64 } // end namespace Opm
65 
66 #endif // PARALLEL_SERIALIZATION_HPP
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition: blackoilbioeffectsmodules.hh:45
void eclStateBroadcast(Parallel::Communication comm, EclipseState &eclState, Schedule &schedule, SummaryConfig &summaryConfig, UDQState &udqState, Action::State &actionState, WellTestState &wtestState)
Broadcasts an eclipse state from root node in parallel runs.
Definition: ParallelSerialization.cpp:75