14#ifndef OR_TOOLS_MATH_OPT_CORE_MATH_OPT_PROTO_UTILS_H_
15#define OR_TOOLS_MATH_OPT_CORE_MATH_OPT_PROTO_UTILS_H_
22#include "absl/container/flat_hash_set.h"
23#include "ortools/math_opt/callback.pb.h"
24#include "ortools/math_opt/model.pb.h"
25#include "ortools/math_opt/model_update.pb.h"
26#include "ortools/math_opt/result.pb.h"
27#include "ortools/math_opt/sparse_containers.pb.h"
33 return variables.ids_size();
37 return linear_constraints.ids_size();
41 return matrix.row_ids_size();
73 template <
typename Value>
77 const SparseVectorFilterProto& filter_;
80 int next_filtered_id_index_ = 0;
86 int next_input_id_lower_bound_ = 0;
91absl::flat_hash_set<CallbackEventProto>
EventSet(
92 const CallbackRegistrationProto& callback_registration);
97 absl::string_view detail = {});
100 absl::string_view detail = {});
103 absl::string_view detail = {});
106 absl::string_view detail = {});
112template <
typename Value>
116 CHECK_GE(
id, next_input_id_lower_bound_)
117 <<
"This function must be called with strictly increasing ids.";
121 next_input_id_lower_bound_ =
id + 1;
128 if (filter_.skip_zero_values() &&
value == 0) {
132 if (!filter_.filter_by_ids()) {
137 while (next_filtered_id_index_ < filter_.filtered_ids_size() &&
138 filter_.filtered_ids(next_filtered_id_index_) <
id) {
139 ++next_filtered_id_index_;
142 if (next_filtered_id_index_ == filter_.filtered_ids_size()) {
149 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)
TerminationProto FeasibleTermination(const LimitProto limit, const absl::string_view detail)
int NumMatrixNonzeros(const SparseDoubleMatrixProto &matrix)
int NumVariables(const VariablesProto &variables)
TerminationProto TerminateForLimit(const LimitProto limit, const bool feasible, const absl::string_view detail)
TerminationProto NoSolutionFoundTermination(const LimitProto limit, const absl::string_view detail)
int NumConstraints(const LinearConstraintsProto &linear_constraints)
TerminationProto TerminateForReason(const TerminationReasonProto reason, const absl::string_view detail)
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.