My Project
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 
37 
43 void eclStateBroadcast(Parallel::Communication comm, EclipseState& eclState, Schedule& schedule,
44  SummaryConfig& summaryConfig,
45  UDQState& udqState,
46  Action::State& actionState,
47  WellTestState& wtestState);
48 
49 
50 template <class T>
51 void eclBroadcast(Parallel::Communication, T& )
52 #if HAVE_MPI
53 ;
54 #else
55 {}
56 #endif
57 
58 
59 } // end namespace Opm
60 
61 #endif // PARALLEL_SERIALIZATION_HPP
This file contains a set of helper functions used by VFPProd / VFPInj.
Definition: BlackoilPhases.hpp:27
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:46