20#ifndef SUMMARY_STATE_H
21#define SUMMARY_STATE_H
23#include <opm/common/utility/TimeService.hpp>
30#include <unordered_map>
70 typedef std::unordered_map<std::string, double>::const_iterator const_iterator;
84 void set(
const std::string& key,
double value);
86 bool erase(
const std::string& key);
87 bool erase_well_var(
const std::string& well,
const std::string& var);
88 bool erase_group_var(
const std::string& group,
const std::string& var);
90 bool has(
const std::string& key)
const;
91 bool has_well_var(
const std::string& well,
const std::string& var)
const;
92 bool has_well_var(
const std::string& var)
const;
93 bool has_group_var(
const std::string& group,
const std::string& var)
const;
94 bool has_group_var(
const std::string& var)
const;
95 bool has_conn_var(
const std::string& well,
const std::string& var, std::size_t global_index)
const;
96 bool has_segment_var(
const std::string& well,
const std::string& var, std::size_t segment)
const;
98 void update(
const std::string& key,
double value);
99 void update_well_var(
const std::string& well,
const std::string& var,
double value);
100 void update_group_var(
const std::string& group,
const std::string& var,
double value);
101 void update_elapsed(
double delta);
102 void update_udq(
const UDQSet& udq_set,
double undefined_value);
103 void update_conn_var(
const std::string& well,
const std::string& var, std::size_t global_index,
double value);
104 void update_segment_var(
const std::string& well,
const std::string& var, std::size_t segment,
double value);
106 double get(
const std::string&)
const;
107 double get(
const std::string&,
double)
const;
108 double get_elapsed()
const;
109 double get_well_var(
const std::string& well,
const std::string& var)
const;
110 double get_group_var(
const std::string& group,
const std::string& var)
const;
111 double get_conn_var(
const std::string& conn,
const std::string& var, std::size_t global_index)
const;
112 double get_segment_var(
const std::string& well,
const std::string& var, std::size_t segment)
const;
113 double get_well_var(
const std::string& well,
const std::string& var,
double)
const;
114 double get_group_var(
const std::string& group,
const std::string& var,
double)
const;
115 double get_conn_var(
const std::string& conn,
const std::string& var, std::size_t global_index,
double)
const;
116 double get_segment_var(
const std::string& well,
const std::string& var, std::size_t segment,
double)
const;
118 const std::vector<std::string>& wells()
const;
119 std::vector<std::string> wells(
const std::string& var)
const;
120 const std::vector<std::string>& groups()
const;
121 std::vector<std::string> groups(
const std::string& var)
const;
123 const_iterator begin()
const;
124 const_iterator end()
const;
125 std::size_t num_wells()
const;
126 std::size_t size()
const;
129 template<
class Serializer>
132 serializer(sim_start);
135 serializer(well_values);
137 serializer(well_names);
138 serializer(group_values);
139 serializer(m_groups);
140 serializer(group_names);
141 serializer(conn_values);
142 serializer(segment_values);
148 time_point sim_start;
150 std::unordered_map<std::string,double> values;
153 std::unordered_map<std::string, std::unordered_map<std::string, double>> well_values;
154 std::set<std::string> m_wells;
155 mutable std::optional<std::vector<std::string>> well_names;
158 std::unordered_map<std::string, std::unordered_map<std::string, double>> group_values;
159 std::set<std::string> m_groups;
160 mutable std::optional<std::vector<std::string>> group_names;
164 std::unordered_map<std::string, std::unordered_map<std::string, std::unordered_map<std::size_t, double>>> conn_values;
168 std::unordered_map<std::string, std::unordered_map<std::string, std::unordered_map<std::size_t, double>>> segment_values;
171std::ostream& operator<<(std::ostream& stream,
const SummaryState& st);
Class for (de-)serializing.
Definition: Serializer.hpp:84
Definition: SummaryState.hpp:68
Definition: UDQSet.hpp:182
This class implements a small container which holds the transmissibility mulitpliers for all the face...
Definition: Exceptions.hpp:30