20 #ifndef SUMMARY_STATE_H
21 #define SUMMARY_STATE_H
27 #include <unordered_map>
31 #include <opm/common/utility/TimeService.hpp>
71 typedef std::unordered_map<std::string, double>::const_iterator const_iterator;
86 void set(
const std::string& key,
double value);
88 bool erase(
const std::string& key);
89 bool erase_well_var(
const std::string& well,
const std::string& var);
90 bool erase_group_var(
const std::string& group,
const std::string& var);
92 bool has(
const std::string& key)
const;
93 bool has_well_var(
const std::string& well,
const std::string& var)
const;
94 bool has_well_var(
const std::string& var)
const;
95 bool has_group_var(
const std::string& group,
const std::string& var)
const;
96 bool has_group_var(
const std::string& var)
const;
97 bool has_conn_var(
const std::string& well,
const std::string& var, std::size_t global_index)
const;
100 void update(
const std::string& key,
double value);
101 void update_well_var(
const std::string& well,
const std::string& var,
double value);
102 void update_group_var(
const std::string& group,
const std::string& var,
double value);
103 void update_elapsed(
double delta);
104 void update_udq(
const UDQSet& udq_set,
double undefined_value);
105 void update_conn_var(
const std::string& well,
const std::string& var, std::size_t global_index,
double value);
107 double get(
const std::string&)
const;
108 double get(
const std::string&,
double)
const;
109 double get_elapsed()
const;
110 double get_well_var(
const std::string& well,
const std::string& var)
const;
111 double get_group_var(
const std::string& group,
const std::string& var)
const;
112 double get_conn_var(
const std::string& conn,
const std::string& var, std::size_t global_index)
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;
117 const std::vector<std::string>& wells()
const;
118 std::vector<std::string> wells(
const std::string& var)
const;
119 const std::vector<std::string>& groups()
const;
120 std::vector<std::string> groups(
const std::string& var)
const;
122 const_iterator begin()
const;
123 const_iterator end()
const;
124 std::size_t num_wells()
const;
125 std::size_t size()
const;
128 template<
class Serializer>
131 serializer(sim_start);
134 serializer(well_values);
136 serializer(well_names);
137 serializer(group_values);
138 serializer(m_groups);
139 serializer(group_names);
140 serializer(conn_values);
148 st.values = {{
"test1", 2.0}};
149 st.well_values = {{
"test2", {{
"test3", 3.0}}}};
150 st.m_wells = {
"test4"};
151 st.well_names = {
"test5"};
152 st.group_values = {{
"test6", {{
"test7", 4.0}}}},
153 st.m_groups = {
"test7"};
154 st.group_names = {
"test8"},
155 st.conn_values = {{
"test9", {{
"test10", {{5, 6.0}}}}}};
161 time_point sim_start;
163 std::unordered_map<std::string,double> values;
166 std::unordered_map<std::string, std::unordered_map<std::string, double>> well_values;
167 std::set<std::string> m_wells;
168 mutable std::optional<std::vector<std::string>> well_names;
171 std::unordered_map<std::string, std::unordered_map<std::string, double>> group_values;
172 std::set<std::string> m_groups;
173 mutable std::optional<std::vector<std::string>> group_names;
177 std::unordered_map<std::string, std::unordered_map<std::string, std::unordered_map<std::size_t, double>>> conn_values;
181 std::ostream& operator<<(std::ostream& stream,
const SummaryState& st);
Class for (de-)serializing.
Definition: Serializer.hpp:75
Definition: SummaryState.hpp:69
Definition: UDQSet.hpp:63
This class implements a small container which holds the transmissibility mulitpliers for all the face...
Definition: Exceptions.hpp:29