14#ifndef OR_TOOLS_MATH_OPT_CORE_MATH_OPT_PROTO_UTILS_H_
15#define OR_TOOLS_MATH_OPT_CORE_MATH_OPT_PROTO_UTILS_H_
20#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();
47 return variables.ids().empty() ? std::nullopt
48 : std::make_optional(variables.ids()[0]);
54 const LinearConstraintsProto& linear_constraints) {
55 return linear_constraints.ids().empty()
57 : std::make_optional(linear_constraints.ids()[0]);
89 template <
typename Value>
93 const SparseVectorFilterProto& filter_;
96 int next_filtered_id_index_ = 0;
102 int64_t next_input_id_lower_bound_ = 0;
107absl::flat_hash_set<CallbackEventProto>
EventSet(
108 const CallbackRegistrationProto& callback_registration);
113 absl::string_view detail = {});
116 absl::string_view detail = {});
119 absl::string_view detail = {});
122 absl::string_view detail = {});
128template <
typename Value>
132 CHECK_GE(
id, next_input_id_lower_bound_)
133 <<
"This function must be called with strictly increasing ids.";
137 next_input_id_lower_bound_ =
id + 1;
144 if (filter_.skip_zero_values() &&
value == 0) {
148 if (!filter_.filter_by_ids()) {
153 while (next_filtered_id_index_ < filter_.filtered_ids_size() &&
154 filter_.filtered_ids(next_filtered_id_index_) <
id) {
155 ++next_filtered_id_index_;
158 if (next_filtered_id_index_ == filter_.filtered_ids_size()) {
165 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)
std::optional< int64_t > FirstLinearConstraintId(const LinearConstraintsProto &linear_constraints)
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)
std::optional< int64_t > FirstVariableId(const VariablesProto &variables)
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.