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;
81 void set(
const std::string& key,
double value);
83 bool erase(
const std::string& key);
84 bool erase_well_var(
const std::string& well,
const std::string& var);
85 bool erase_group_var(
const std::string& group,
const std::string& var);
87 bool has(
const std::string& key)
const;
88 bool has_well_var(
const std::string& well,
const std::string& var)
const;
89 bool has_well_var(
const std::string& var)
const;
90 bool has_group_var(
const std::string& group,
const std::string& var)
const;
91 bool has_group_var(
const std::string& var)
const;
92 bool has_conn_var(
const std::string& well,
const std::string& var, std::size_t global_index)
const;
95 void update(
const std::string& key,
double value);
96 void update_well_var(
const std::string& well,
const std::string& var,
double value);
97 void update_group_var(
const std::string& group,
const std::string& var,
double value);
98 void update_elapsed(
double delta);
99 void update_udq(
const UDQSet& udq_set,
double undefined_value);
100 void update_conn_var(
const std::string& well,
const std::string& var, std::size_t global_index,
double value);
102 double get(
const std::string&)
const;
103 double get(
const std::string&,
double)
const;
104 double get_elapsed()
const;
105 double get_well_var(
const std::string& well,
const std::string& var)
const;
106 double get_group_var(
const std::string& group,
const std::string& var)
const;
107 double get_conn_var(
const std::string& conn,
const std::string& var, std::size_t global_index)
const;
108 double get_well_var(
const std::string& well,
const std::string& var,
double)
const;
109 double get_group_var(
const std::string& group,
const std::string& var,
double)
const;
110 double get_conn_var(
const std::string& conn,
const std::string& var, std::size_t global_index,
double)
const;
112 const std::vector<std::string>& wells()
const;
113 std::vector<std::string> wells(
const std::string& var)
const;
114 const std::vector<std::string>& groups()
const;
115 std::vector<std::string> groups(
const std::string& var)
const;
116 std::vector<char> serialize()
const;
117 void deserialize(
const std::vector<char>& buffer);
118 const_iterator begin()
const;
119 const_iterator end()
const;
120 std::size_t num_wells()
const;
121 std::size_t size()
const;
124 time_point sim_start;
126 std::unordered_map<std::string,double> values;
129 std::unordered_map<std::string, std::unordered_map<std::string, double>> well_values;
130 std::set<std::string> m_wells;
131 mutable std::optional<std::vector<std::string>> well_names;
134 std::unordered_map<std::string, std::unordered_map<std::string, double>> group_values;
135 std::set<std::string> m_groups;
136 mutable std::optional<std::vector<std::string>> group_names;
140 std::unordered_map<std::string, std::unordered_map<std::string, std::unordered_map<std::size_t, double>>> conn_values;
144 std::ostream& operator<<(std::ostream& stream,
const SummaryState& st);
Definition: SummaryState.hpp:69
Definition: UDQSet.hpp:66
This class implements a small container which holds the transmissibility mulitpliers for all the face...
Definition: Exceptions.hpp:29