14 #ifndef OR_TOOLS_MATH_OPT_MATH_OPT_PROTO_UTILS_H_
15 #define OR_TOOLS_MATH_OPT_MATH_OPT_PROTO_UTILS_H_
19 #include "absl/container/flat_hash_set.h"
22 #include "ortools/math_opt/callback.pb.h"
23 #include "ortools/math_opt/model.pb.h"
24 #include "ortools/math_opt/sparse_containers.pb.h"
30 return variables.ids_size();
33 inline int NumConstraints(
const LinearConstraintsProto& linear_constraints) {
34 return linear_constraints.ids_size();
38 return matrix.row_ids_size();
70 template <
typename Value>
74 const SparseVectorFilterProto& filter_;
77 int next_filtered_id_index_ = 0;
83 int next_input_id_lower_bound_ = 0;
88 absl::flat_hash_set<CallbackEventProto>
EventSet(
89 const CallbackRegistrationProto& callback_registration);
95 template <
typename Value>
99 CHECK_GE(
id, next_input_id_lower_bound_)
100 <<
"This function must be called with strictly increasing ids.";
104 next_input_id_lower_bound_ =
id + 1;
111 if (filter_.skip_zero_values() &&
value == 0) {
115 if (!filter_.filter_by_ids()) {
120 while (next_filtered_id_index_ < filter_.filtered_ids_size() &&
121 filter_.filtered_ids(next_filtered_id_index_) <
id) {
122 ++next_filtered_id_index_;
125 if (next_filtered_id_index_ == filter_.filtered_ids_size()) {
132 return id == filter_.filtered_ids(next_filtered_id_index_);
#define CHECK_GE(val1, val2)
SparseVectorFilterPredicate(const SparseVectorFilterProto &filter)
bool AcceptsAndUpdate(const int64_t id, const Value &value)
int NumMatrixNonzeros(const SparseDoubleMatrixProto &matrix)
int NumVariables(const VariablesProto &variables)
int NumConstraints(const LinearConstraintsProto &linear_constraints)
absl::flat_hash_set< CallbackEventProto > EventSet(const CallbackRegistrationProto &callback_registration)
void RemoveSparseDoubleVectorZeros(SparseDoubleVectorProto &sparse_vector)
std::function< int64_t(const Model &)> Value(IntegerVariable v)
Collection of objects used to extend the Constraint Solver library.