opm-common
EclipseIO.hpp
1 /*
2  Copyright (c) 2013 Andreas Lauser
3  Copyright (c) 2013 Uni Research AS
4  Copyright (c) 2014 IRIS AS
5 
6  This file is part of the Open Porous Media project (OPM).
7 
8  OPM is free software: you can redistribute it and/or modify
9  it under the terms of the GNU General Public License as published by
10  the Free Software Foundation, either version 3 of the License, or
11  (at your option) any later version.
12 
13  OPM is distributed in the hope that it will be useful,
14  but WITHOUT ANY WARRANTY; without even the implied warranty of
15  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  GNU General Public License for more details.
17 
18  You should have received a copy of the GNU General Public License
19  along with OPM. If not, see <http://www.gnu.org/licenses/>.
20 */
21 
22 #ifndef OPM_ECLIPSE_WRITER_HPP
23 #define OPM_ECLIPSE_WRITER_HPP
24 
25 #include <opm/input/eclipse/EclipseState/Grid/NNC.hpp>
26 
27 #include <opm/output/data/Solution.hpp>
28 #include <opm/output/eclipse/RestartValue.hpp>
29 
30 #include <map>
31 #include <memory>
32 #include <optional>
33 #include <string>
34 #include <vector>
35 
36 namespace Opm {
37 
38 class EclipseGrid;
39 class EclipseState;
40 class RestartKey;
41 class Schedule;
42 class SummaryConfig;
43 class SummaryState;
44 class UDQState;
45 class WellTestState;
46 
47 } // namespace Opm
48 
49 namespace Opm::Action {
50  class State;
51 } // namespace Opm::Action
52 
53 namespace Opm::out {
54  class Summary;
55 } // namespace Opm::out
56 
57 namespace Opm {
58 
60 class EclipseIO
61 {
62 public:
92  EclipseIO(const EclipseState& es,
93  EclipseGrid grid,
94  const Schedule& schedule,
95  const SummaryConfig& summary_config,
96  const std::string& basename = std::string{},
97  const bool writeEsmry = false);
98 
103  EclipseIO(const EclipseIO&) = delete;
104 
109  EclipseIO& operator=(const EclipseIO&) = delete;
110 
114  ~EclipseIO();
115 
160  void writeInitial(data::Solution simProps = data::Solution(),
161  std::map<std::string, std::vector<int>> int_data = {},
162  const std::vector<NNCdata>& nnc = {});
163 
164 
181  void writeInitial(std::vector<data::Solution>,
182  std::map<std::string, std::vector<int>> int_data = {},
183  const std::vector<NNCdata>& nnc = {});
184 
185 
186  void writeInitial(std::vector<data::Solution>,
187  std::map<std::string, std::vector<int>> int_data = {},
188  const NNCCollection& nnc_col = {});
189 
190 
249  void writeTimeStep(const Action::State& action_state,
250  const WellTestState& wtest_state,
251  const SummaryState& st,
252  const UDQState& udq_state,
253  int report_step,
254  bool isSubstep,
255  double seconds_elapsed,
257  const bool write_double = false,
258  std::optional<int> time_step = std::nullopt,
259  const bool isFinalWriteOut = false);
260 
322  void writeTimeStep(const Action::State& action_state,
323  const WellTestState& wtest_state,
324  const SummaryState& st,
325  const UDQState& udq_state,
326  int report_step,
327  bool isSubstep,
328  double seconds_elapsed,
329  std::vector<RestartValue> value,
330  const bool write_double = false,
331  std::optional<int> time_step = std::nullopt,
332  const bool isFinalWriteOut = false);
333 
334 
381  RestartValue loadRestart(Action::State& action_state,
382  SummaryState& summary_state,
383  const std::vector<RestartKey>& solution_keys,
384  const std::vector<RestartKey>& extra_keys = {}) const;
385 
415  data::Solution loadRestartSolution(const std::vector<RestartKey>& solution_keys,
416  const int report_step) const;
417 
424  const out::Summary& summary() const;
425 
432  const SummaryConfig& finalSummaryConfig() const;
433 
434 private:
436  class Impl;
437 
439  std::unique_ptr<Impl> impl;
440 };
441 
442 } // namespace Opm
443 
444 #endif // OPM_ECLIPSE_WRITER_HPP
Definition: Python.hpp:35
Definition: Solution.hpp:34
File I/O management for reservoir description and dynamic results.
Definition: EclipseIO.hpp:60
Definition: EclipseIO.hpp:53
Definition: Schedule.hpp:100
EclipseIO & operator=(const EclipseIO &)=delete
Deleted assignment operator.
Collection of run&#39;s summary vectors.
Definition: SummaryConfig.hpp:298
EclipseIO(const EclipseState &es, EclipseGrid grid, const Schedule &schedule, const SummaryConfig &summary_config, const std::string &basename=std::string{}, const bool writeEsmry=false)
Constructor.
Definition: EclipseIO.cpp:1102
About cell information and dimension: The actual grid information is held in a pointer to an ERT ecl_...
Definition: EclipseGrid.hpp:62
void writeInitial(data::Solution simProps=data::Solution(), std::map< std::string, std::vector< int >> int_data={}, const std::vector< NNCdata > &nnc={})
Output static properties to EGRID and INIT files.
Definition: EclipseIO.cpp:1121
const SummaryConfig & finalSummaryConfig() const
Access finalised summary configuration object.
Definition: EclipseIO.cpp:1270
Management information about the current run&#39;s ACTION system, especially concerning the number of tim...
Definition: State.hpp:50
This class implements a small container which holds the transmissibility mulitpliers for all the face...
Definition: Exceptions.hpp:30
Computational engine for calculating summary vectors (2D curves as a function of time) and writing th...
Definition: Summary.hpp:56
Definition: NNC.hpp:199
Definition: RestartValue.hpp:72
Definition: EclipseState.hpp:66
Definition: UDQState.hpp:39
Internal implementation class for EclipseIO public interface.
Definition: EclipseIO.cpp:133
void writeTimeStep(const Action::State &action_state, const WellTestState &wtest_state, const SummaryState &st, const UDQState &udq_state, int report_step, bool isSubstep, double seconds_elapsed, RestartValue value, const bool write_double=false, std::optional< int > time_step=std::nullopt, const bool isFinalWriteOut=false)
Write reservoir state and summary information to disk.
Definition: EclipseIO.cpp:1155
Definition: SummaryState.hpp:72
data::Solution loadRestartSolution(const std::vector< RestartKey > &solution_keys, const int report_step) const
Load per-cell solution data from restart file at specific time.
Definition: EclipseIO.cpp:1259
const out::Summary & summary() const
Access internal summary vector calculation engine.
Definition: EclipseIO.cpp:1265
Definition: WellTestState.hpp:65
RestartValue loadRestart(Action::State &action_state, SummaryState &summary_state, const std::vector< RestartKey > &solution_keys, const std::vector< RestartKey > &extra_keys={}) const
Load per-cell solution data and wellstate from restart file.
Definition: EclipseIO.cpp:1249
~EclipseIO()
Destructor.