74 using const_iterator = std::unordered_map<std::string, double>::const_iterator;
76 explicit SummaryState(time_point sim_start_arg,
double udqUndefined);
90 void set(
const std::string& key,
double value);
92 bool erase(
const std::string& key);
93 bool erase_well_var(
const std::string& well,
const std::string& var);
94 bool erase_group_var(
const std::string& group,
const std::string& var);
96 bool has(
const std::string& key)
const;
97 bool has_well_var(
const std::string& well,
const std::string& var)
const;
98 bool has_well_var(
const std::string& var)
const;
99 bool has_group_var(
const std::string& group,
const std::string& var)
const;
100 bool has_group_var(
const std::string& var)
const;
101 bool has_conn_var(
const std::string& well,
const std::string& var, std::size_t global_index)
const;
102 bool has_segment_var(
const std::string& well,
const std::string& var, std::size_t segment)
const;
103 bool has_region_var(
const std::string& regSet,
const std::string& var, std::size_t region)
const;
105 void update(
const std::string& key,
double value);
106 void update_well_var(
const std::string& well,
const std::string& var,
double value);
107 void update_group_var(
const std::string& group,
const std::string& var,
double value);
108 void update_elapsed(
double delta);
109 void update_udq(
const UDQSet& udq_set);
110 void update_conn_var(
const std::string& well,
const std::string& var, std::size_t global_index,
double value);
111 void update_segment_var(
const std::string& well,
const std::string& var, std::size_t segment,
double value);
112 void update_region_var(
const std::string& regSet,
const std::string& var, std::size_t region,
double value);
114 double get(
const std::string&)
const;
115 double get(
const std::string&,
double)
const;
116 double get_elapsed()
const;
117 double get_well_var(
const std::string& well,
const std::string& var)
const;
118 double get_group_var(
const std::string& group,
const std::string& var)
const;
119 double get_conn_var(
const std::string& conn,
const std::string& var, std::size_t global_index)
const;
120 double get_segment_var(
const std::string& well,
const std::string& var, std::size_t segment)
const;
121 double get_region_var(
const std::string& regSet,
const std::string& var, std::size_t region)
const;
122 double get_well_var(
const std::string& well,
const std::string& var,
double)
const;
123 double get_group_var(
const std::string& group,
const std::string& var,
double)
const;
124 double get_conn_var(
const std::string& conn,
const std::string& var, std::size_t global_index,
double)
const;
125 double get_segment_var(
const std::string& well,
const std::string& var, std::size_t segment,
double)
const;
126 double get_region_var(
const std::string& regSet,
const std::string& var, std::size_t region,
double)
const;
128 bool is_undefined_value(
const double val)
const {
return val == udq_undefined; }
130 const std::vector<std::string>& wells()
const;
131 std::vector<std::string> wells(
const std::string& var)
const;
132 const std::vector<std::string>& groups()
const;
133 std::vector<std::string> groups(
const std::string& var)
const;
135 const_iterator begin()
const;
136 const_iterator end()
const;
137 std::size_t num_wells()
const;
138 std::size_t size()
const;
141 template<
class Serializer>
144 serializer(sim_start);
145 serializer(this->udq_undefined);
148 serializer(well_values);
150 serializer(well_names);
151 serializer(group_values);
152 serializer(m_groups);
153 serializer(group_names);
154 serializer(conn_values);
155 serializer(segment_values);
156 serializer(this->region_values);
162 time_point sim_start;
163 double udq_undefined{};
165 std::unordered_map<std::string,double> values;
168 std::unordered_map<std::string, std::unordered_map<std::string, double>> well_values;
169 std::set<std::string> m_wells;
170 mutable std::optional<std::vector<std::string>> well_names;
173 std::unordered_map<std::string, std::unordered_map<std::string, double>> group_values;
174 std::set<std::string> m_groups;
175 mutable std::optional<std::vector<std::string>> group_names;
179 std::unordered_map<std::string, std::unordered_map<std::string, std::unordered_map<std::size_t, double>>> conn_values;
183 std::unordered_map<std::string, std::unordered_map<std::string, std::unordered_map<std::size_t, double>>> segment_values;
187 std::unordered_map<std::string, std::unordered_map<std::string, std::unordered_map<std::size_t, double>>> region_values;