27 #include "absl/container/flat_hash_map.h"
28 #include "absl/container/flat_hash_set.h"
29 #include "absl/memory/memory.h"
30 #include "absl/status/status.h"
31 #include "absl/status/statusor.h"
32 #include "absl/strings/str_cat.h"
33 #include "absl/strings/str_format.h"
34 #include "absl/strings/string_view.h"
35 #include "absl/types/span.h"
43 #include "scip/cons_linear.h"
44 #include "scip/scip.h"
45 #include "scip/scip_general.h"
46 #include "scip/scip_param.h"
47 #include "scip/scip_prob.h"
48 #include "scip/scip_solvingstats.h"
49 #include "scip/scipdefplugins.h"
50 #include "scip/type_cons.h"
51 #include "scip/type_scip.h"
52 #include "scip/type_var.h"
56 #define RETURN_ERROR_UNLESS(x) \
58 return util::StatusBuilder(absl::InvalidArgumentError(absl::StrFormat( \
59 "Condition violated at %s:%d: %s", __FILE__, __LINE__, #x)))
63 constexpr absl::string_view kLinearConstraintHandlerName =
"linear";
65 SCIP_VARTYPE ConvertVarType(
const GScipVarType var_type) {
68 return SCIP_VARTYPE_CONTINUOUS;
70 return SCIP_VARTYPE_IMPLINT;
72 return SCIP_VARTYPE_INTEGER;
76 GScipVarType ConvertVarType(
const SCIP_VARTYPE var_type) {
78 case SCIP_VARTYPE_CONTINUOUS:
80 case SCIP_VARTYPE_IMPLINT:
82 case SCIP_VARTYPE_INTEGER:
83 case SCIP_VARTYPE_BINARY:
88 GScipOutput::Status ConvertStatus(
const SCIP_STATUS scip_status) {
89 switch (scip_status) {
90 case SCIP_STATUS_UNKNOWN:
92 case SCIP_STATUS_USERINTERRUPT:
93 return GScipOutput::USER_INTERRUPT;
94 case SCIP_STATUS_BESTSOLLIMIT:
95 return GScipOutput::BEST_SOL_LIMIT;
96 case SCIP_STATUS_MEMLIMIT:
97 return GScipOutput::MEM_LIMIT;
98 case SCIP_STATUS_NODELIMIT:
99 return GScipOutput::NODE_LIMIT;
100 case SCIP_STATUS_RESTARTLIMIT:
101 return GScipOutput::RESTART_LIMIT;
102 case SCIP_STATUS_SOLLIMIT:
103 return GScipOutput::SOL_LIMIT;
104 case SCIP_STATUS_STALLNODELIMIT:
105 return GScipOutput::STALL_NODE_LIMIT;
106 case SCIP_STATUS_TIMELIMIT:
107 return GScipOutput::TIME_LIMIT;
108 case SCIP_STATUS_TOTALNODELIMIT:
109 return GScipOutput::TOTAL_NODE_LIMIT;
110 case SCIP_STATUS_OPTIMAL:
112 case SCIP_STATUS_GAPLIMIT:
113 return GScipOutput::GAP_LIMIT;
114 case SCIP_STATUS_INFEASIBLE:
116 case SCIP_STATUS_UNBOUNDED:
117 return GScipOutput::UNBOUNDED;
118 case SCIP_STATUS_INFORUNBD:
119 return GScipOutput::INF_OR_UNBD;
120 case SCIP_STATUS_TERMINATE:
121 return GScipOutput::TERMINATE;
123 LOG(
FATAL) <<
"Unrecognized scip status: " << scip_status;
127 SCIP_PARAMEMPHASIS ConvertEmphasis(
128 const GScipParameters::Emphasis gscip_emphasis) {
129 switch (gscip_emphasis) {
130 case GScipParameters::DEFAULT_EMPHASIS:
131 return SCIP_PARAMEMPHASIS_DEFAULT;
132 case GScipParameters::CP_SOLVER:
133 return SCIP_PARAMEMPHASIS_CPSOLVER;
134 case GScipParameters::EASY_CIP:
135 return SCIP_PARAMEMPHASIS_EASYCIP;
136 case GScipParameters::FEASIBILITY:
137 return SCIP_PARAMEMPHASIS_FEASIBILITY;
138 case GScipParameters::HARD_LP:
139 return SCIP_PARAMEMPHASIS_HARDLP;
140 case GScipParameters::OPTIMALITY:
141 return SCIP_PARAMEMPHASIS_OPTIMALITY;
143 return SCIP_PARAMEMPHASIS_COUNTER;
144 case GScipParameters::PHASE_FEAS:
145 return SCIP_PARAMEMPHASIS_PHASEFEAS;
146 case GScipParameters::PHASE_IMPROVE:
147 return SCIP_PARAMEMPHASIS_PHASEIMPROVE;
148 case GScipParameters::PHASE_PROOF:
149 return SCIP_PARAMEMPHASIS_PHASEPROOF;
151 LOG(
FATAL) <<
"Unrecognized gscip_emphasis: "
156 SCIP_PARAMSETTING ConvertMetaParamValue(
157 const GScipParameters::MetaParamValue gscip_meta_param_value) {
158 switch (gscip_meta_param_value) {
159 case GScipParameters::DEFAULT_META_PARAM_VALUE:
160 return SCIP_PARAMSETTING_DEFAULT;
161 case GScipParameters::AGGRESSIVE:
162 return SCIP_PARAMSETTING_AGGRESSIVE;
163 case GScipParameters::FAST:
164 return SCIP_PARAMSETTING_FAST;
165 case GScipParameters::OFF:
166 return SCIP_PARAMSETTING_OFF;
168 LOG(
FATAL) <<
"Unrecognized gscip_meta_param_value: "
182 return constraint_options;
185 absl::Status GScip::SetParams(
const GScipParameters& params,
186 const std::string& legacy_params) {
187 if (params.has_silence_output()) {
188 SCIPsetMessagehdlrQuiet(scip_, params.silence_output());
190 if (!params.search_logs_filename().empty()) {
191 SCIPsetMessagehdlrLogfile(scip_, params.search_logs_filename().c_str());
194 const SCIP_Bool set_param_quiet =
195 static_cast<SCIP_Bool
>(!params.silence_output());
198 scip_, ConvertEmphasis(params.emphasis()), set_param_quiet));
199 if (params.has_heuristics()) {
201 scip_, ConvertMetaParamValue(params.heuristics()), set_param_quiet));
203 if (params.has_presolve()) {
205 scip_, ConvertMetaParamValue(params.presolve()), set_param_quiet));
207 if (params.has_separating()) {
209 scip_, ConvertMetaParamValue(params.separating()), set_param_quiet));
211 for (
const auto& bool_param : params.bool_params()) {
213 (SCIPsetBoolParam(scip_, bool_param.first.c_str(), bool_param.second)));
215 for (
const auto& int_param : params.int_params()) {
217 (SCIPsetIntParam(scip_, int_param.first.c_str(), int_param.second)));
219 for (
const auto& long_param : params.long_params()) {
221 long_param.second)));
223 for (
const auto& char_param : params.char_params()) {
224 if (char_param.second.size() != 1) {
225 return absl::InvalidArgumentError(
226 absl::StrCat(
"Character parameters must be single character strings, "
228 char_param.first,
" was: ", char_param.second));
231 char_param.second[0])));
233 for (
const auto& string_param : params.string_params()) {
235 string_param.second.c_str())));
237 for (
const auto& real_param : params.real_params()) {
239 (SCIPsetRealParam(scip_, real_param.first.c_str(), real_param.second)));
241 if (!legacy_params.empty()) {
245 return absl::OkStatus();
249 const std::string& problem_name) {
250 SCIP*
scip =
nullptr;
255 return absl::WrapUnique(
new GScip(
scip));
258 GScip::GScip(SCIP* scip) : scip_(scip) {}
262 absl::Status GScip::FreeTransform() {
267 return absl::StrFormat(
"SCIP %d.%d.%d [LP solver: %s]", SCIPmajorVersion(),
268 SCIPminorVersion(), SCIPtechVersion(),
273 if (scip_ ==
nullptr) {
276 return SCIPinterruptSolve(scip_) == SCIP_OKAY;
279 absl::Status GScip::CleanUp() {
280 if (scip_ !=
nullptr) {
281 for (SCIP_VAR* variable : variables_) {
282 if (variable !=
nullptr) {
286 for (SCIP_CONS* constraint : constraints_) {
287 if (constraint !=
nullptr) {
293 return absl::OkStatus();
297 const absl::Status clean_up_status = CleanUp();
298 LOG_IF(DFATAL, !clean_up_status.ok()) << clean_up_status;
302 double lb,
double ub,
double obj_coef,
GScipVarType var_type,
304 SCIP_VAR*
var =
nullptr;
305 lb = ScipInfClamp(lb);
306 ub = ScipInfClamp(ub);
311 ConvertVarType(var_type)));
316 variables_.insert(
var);
323 absl::Status GScip::MaybeKeepConstraintAlive(
326 constraints_.insert(constraint);
330 return absl::OkStatus();
336 SCIP_CONS* constraint =
nullptr;
338 <<
"Error adding constraint: " <<
name <<
".";
341 const_cast<SCIP_VAR**
>(range.
variables.data()),
362 SCIP_CONS* constraint =
nullptr;
365 <<
"Error adding quadratic constraint: " <<
name <<
" in linear term.";
368 <<
"Error adding quadratic constraint: " <<
name <<
" in quadratic term.";
370 <<
"Error adding quadratic constraint: " <<
name <<
" in quadratic term.";
372 scip_, &constraint,
name.c_str(), num_lin_vars,
398 <<
"Error adding indicator constraint: " <<
name <<
".";
403 SCIP_CONS* constraint =
nullptr;
406 <<
"Error adding indicator constraint: " <<
name <<
".";
408 scip_, &constraint,
name.c_str(), indicator,
410 const_cast<SCIP_Var**
>(indicator_constraint.
variables.data()),
411 const_cast<double*
>(indicator_constraint.
coefficients.data()),
431 <<
"Error adding and constraint: " <<
name <<
".";
432 SCIP_CONS* constraint =
nullptr;
434 SCIPcreateConsAnd(scip_, &constraint,
name.c_str(),
436 const_cast<SCIP_VAR**
>(logical_data.
operators.data()),
456 <<
"Error adding or constraint: " <<
name <<
".";
457 SCIP_CONS* constraint =
nullptr;
459 SCIPcreateConsOr(scip_, &constraint,
name.c_str(), logical_data.
resultant,
461 const_cast<SCIP_Var**
>(logical_data.
operators.data()),
479 absl::Status ValidateSOSData(
const GScipSOSData& sos_data,
480 const std::string&
name) {
482 <<
"Error adding SOS constraint: " <<
name <<
".";
483 if (!sos_data.
weights.empty()) {
485 <<
" Error adding SOS constraint: " <<
name <<
".";
487 absl::flat_hash_set<double> distinct_weights;
488 for (
const double w : sos_data.
weights) {
490 <<
"Error adding SOS constraint: " <<
name
491 <<
", weights must be distinct, but found value " << w <<
" twice.";
492 distinct_weights.insert(w);
494 return absl::OkStatus();
503 SCIP_CONS* constraint =
nullptr;
504 double* weights =
nullptr;
505 if (!sos_data.
weights.empty()) {
506 weights =
const_cast<double*
>(sos_data.
weights.data());
511 const_cast<SCIP_Var**
>(sos_data.
variables.data()), weights,
530 SCIP_CONS* constraint =
nullptr;
531 double* weights =
nullptr;
532 if (!sos_data.
weights.empty()) {
533 weights =
const_cast<double*
>(sos_data.
weights.data());
537 const_cast<SCIP_Var**
>(sos_data.
variables.data()), weights,
554 scip_, is_maximize ? SCIP_OBJSENSE_MAXIMIZE : SCIP_OBJSENSE_MINIMIZE));
555 return absl::OkStatus();
559 double old_offset = SCIPgetOrigObjoffset(scip_);
560 double delta_offset = offset - old_offset;
562 return absl::OkStatus();
566 return SCIPgetObjsense(scip_) == SCIP_OBJSENSE_MAXIMIZE;
573 return absl::OkStatus();
577 lb = ScipInfClamp(lb);
579 return absl::OkStatus();
583 ub = ScipInfClamp(ub);
585 return absl::OkStatus();
590 return absl::OkStatus();
594 SCIP_Bool infeasible;
596 SCIPchgVarType(scip_,
var, ConvertVarType(var_type), &infeasible));
597 return absl::OkStatus();
601 SCIP_Bool did_delete;
604 <<
"Failed to delete variable named: " <<
Name(
var);
605 variables_.erase(
var);
607 return absl::OkStatus();
611 const absl::flat_hash_set<SCIP_VAR*>& vars) {
612 for (SCIP_CONS* constraint : constraints_) {
614 return absl::InvalidArgumentError(absl::StrCat(
615 "Model contains nonlinear constraint: ",
Name(constraint)));
618 return absl::OkStatus();
624 for (SCIP_CONS* constraint : constraints_) {
625 const absl::Span<SCIP_VAR* const> nonzeros =
627 const std::vector<SCIP_VAR*> nonzeros_copy(nonzeros.begin(),
629 for (SCIP_VAR*
var : nonzeros_copy) {
630 if (vars.contains(
var)) {
635 for (SCIP_VAR*
const var : vars) {
638 return absl::OkStatus();
642 return ScipInfUnclamp(SCIPvarGetLbOriginal(
var));
646 return ScipInfUnclamp(SCIPvarGetUbOriginal(
var));
652 return ConvertVarType(SCIPvarGetType(
var));
658 return absl::string_view(SCIPconshdlrGetName(SCIPconsGetHdlr(constraint)));
662 return ConstraintType(constraint) == kLinearConstraintHandlerName;
666 SCIP_CONS* constraint) {
667 int num_vars = SCIPgetNVarsLinear(scip_, constraint);
668 return absl::MakeConstSpan(SCIPgetValsLinear(scip_, constraint), num_vars);
672 SCIP_CONS* constraint) {
673 int num_vars = SCIPgetNVarsLinear(scip_, constraint);
674 return absl::MakeConstSpan(SCIPgetVarsLinear(scip_, constraint), num_vars);
678 return ScipInfUnclamp(SCIPgetLhsLinear(scip_, constraint));
682 return ScipInfUnclamp(SCIPgetRhsLinear(scip_, constraint));
686 return SCIPconsGetName(constraint);
690 lb = ScipInfClamp(lb);
692 return absl::OkStatus();
696 ub = ScipInfClamp(ub);
698 return absl::OkStatus();
703 constraints_.erase(constraint);
705 return absl::OkStatus();
714 return absl::OkStatus();
720 const int scip_num_vars = SCIPgetNOrigVars(scip_);
721 const bool is_solution_partial = partial_solution.size() < scip_num_vars;
722 if (is_solution_partial) {
727 <<
"Error suggesting hint.";
730 for (
const auto& var_value_pair : partial_solution) {
732 var_value_pair.second));
734 if (!is_solution_partial) {
735 SCIP_Bool is_feasible;
737 scip_, solution,
false,
true,
740 if (!
static_cast<bool>(is_feasible)) {
747 if (
static_cast<bool>(is_stored)) {
755 const GScipParameters& params,
const std::string& legacy_params,
766 const absl::Status param_status = SetParams(params, legacy_params);
767 if (!param_status.ok()) {
768 result.
gscip_output.set_status(GScipOutput::INVALID_SOLVER_PARAMETERS);
771 std::string(param_status.message()));
774 if (params.print_scip_model()) {
777 if (!params.scip_model_filename().empty()) {
779 scip_, params.scip_model_filename().c_str(),
"cip", FALSE));
790 if (message_handler !=
nullptr) {
794 SCIPsetMessagehdlr(scip_, new_handler.get());
809 const SCIP_STAGE stage = SCIPgetStage(scip_);
810 if (stage != SCIP_STAGE_PRESOLVING && stage != SCIP_STAGE_SOLVING &&
811 stage != SCIP_STAGE_SOLVED) {
814 absl::StrCat(
"Unpexpected SCIP final stage= ", stage,
815 " was expected to be either SCIP_STAGE_PRESOLVING, "
816 "SCIP_STAGE_SOLVING, or SCIP_STAGE_SOLVED"));
819 if (params.print_detailed_solving_stats()) {
822 if (!params.detailed_solving_stats_filename().empty()) {
823 FILE*
file = fopen(params.detailed_solving_stats_filename().c_str(),
"w");
824 if (
file ==
nullptr) {
825 return absl::InvalidArgumentError(absl::StrCat(
826 "Could not open file: ", params.detailed_solving_stats_filename(),
827 " to write SCIP solve stats."));
830 int close_result = fclose(
file);
831 if (close_result != 0) {
832 return absl::InvalidArgumentError(absl::StrCat(
833 "Error: ", close_result,
834 " closing file: ", params.detailed_solving_stats_filename(),
835 " when writing solve stats."));
841 GScipSolvingStats* stats = result.
gscip_output.mutable_stats();
842 const int num_scip_solutions = SCIPgetNSols(scip_);
843 const int num_returned_solutions =
845 SCIP_SOL** all_solutions = SCIPgetSols(scip_);
846 stats->set_best_objective(ScipInfUnclamp(SCIPgetPrimalbound(scip_)));
847 for (
int i = 0; i < num_returned_solutions; ++i) {
848 SCIP_SOL* scip_sol = all_solutions[i];
849 const double obj_value = ScipInfUnclamp(SCIPgetSolOrigObj(scip_, scip_sol));
851 for (SCIP_VAR* v : variables_) {
852 solution[v] = SCIPgetSolVal(scip_, scip_sol, v);
858 if (stage != SCIP_STAGE_PRESOLVING && SCIPhasPrimalRay(scip_)) {
859 for (SCIP_VAR* v : variables_) {
860 result.
primal_ray[v] = SCIPgetPrimalRayVal(scip_, v);
864 stats->set_best_bound(ScipInfUnclamp(SCIPgetDualbound(scip_)));
865 stats->set_node_count(SCIPgetNTotalNodes(scip_));
866 stats->set_first_lp_relaxation_bound(SCIPgetFirstLPDualboundRoot(scip_));
867 stats->set_root_node_bound(SCIPgetDualboundRoot(scip_));
868 if (stage != SCIP_STAGE_PRESOLVING) {
869 stats->set_total_lp_iterations(SCIPgetNLPIterations(scip_));
870 stats->set_primal_simplex_iterations(SCIPgetNPrimalLPIterations(scip_));
871 stats->set_dual_simplex_iterations(SCIPgetNDualLPIterations(scip_));
872 stats->set_deterministic_time(SCIPgetDeterministicTime(scip_));
874 result.
gscip_output.set_status(ConvertStatus(SCIPgetStatus(scip_)));
882 if (message_handler !=
nullptr) {
896 SCIPsetMessagehdlrQuiet(scip_,
false);
897 SCIPsetMessagehdlrLogfile(scip_,
nullptr);
903 const std::string& parameter_name) {
904 SCIP_Bool default_value;
906 SCIPgetBoolParam(scip_, parameter_name.c_str(), &default_value));
907 return static_cast<bool>(default_value);
911 const std::string& parameter_name) {
914 SCIPgetIntParam(scip_, parameter_name.c_str(), &default_value));
915 return default_value;
919 const std::string& parameter_name) {
922 SCIPgetLongintParam(scip_, parameter_name.c_str(), &result));
923 return static_cast<int64_t
>(result);
927 const std::string& parameter_name) {
930 SCIPgetRealParam(scip_, parameter_name.c_str(), &result));
935 const std::string& parameter_name) {
938 SCIPgetCharParam(scip_, parameter_name.c_str(), &result));
943 const std::string& parameter_name) {
946 SCIPgetStringParam(scip_, parameter_name.c_str(), &result));
947 return std::string(result);
950 double GScip::ScipInfClamp(
double d) {
951 const double kScipInf =
ScipInf();
952 if (d > kScipInf)
return kScipInf;
953 if (d < -kScipInf)
return -kScipInf;
957 double GScip::ScipInfUnclamp(
double d) {
958 const double kScipInf =
ScipInf();
959 if (d >= kScipInf)
return std::numeric_limits<double>::infinity();
960 if (d <= -kScipInf)
return -std::numeric_limits<double>::infinity();
964 #undef RETURN_ERROR_UNLESS
#define LOG_IF(severity, condition)
double LinearConstraintUb(SCIP_CONS *constraint)
absl::Status SetObjectiveOffset(double offset)
absl::StatusOr< SCIP_VAR * > AddVariable(double lb, double ub, double obj_coef, GScipVarType var_type, const std::string &var_name="", const GScipVariableOptions &options=DefaultGScipVariableOptions())
absl::Status DeleteVariable(SCIP_VAR *var)
absl::StatusOr< SCIP_CONS * > AddOrConstraint(const GScipLogicalConstraintData &logical_data, const std::string &name="", const GScipConstraintOptions &options=DefaultGScipConstraintOptions())
absl::StatusOr< double > DefaultRealParamValue(const std::string ¶meter_name)
absl::Status CanSafeBulkDelete(const absl::flat_hash_set< SCIP_VAR * > &vars)
absl::StatusOr< SCIP_CONS * > AddAndConstraint(const GScipLogicalConstraintData &logical_data, const std::string &name="", const GScipConstraintOptions &options=DefaultGScipConstraintOptions())
absl::StatusOr< SCIP_CONS * > AddLinearConstraint(const GScipLinearRange &range, const std::string &name="", const GScipConstraintOptions &options=DefaultGScipConstraintOptions())
bool IsConstraintLinear(SCIP_CONS *constraint)
absl::string_view ConstraintType(SCIP_CONS *constraint)
absl::StatusOr< int64_t > DefaultLongParamValue(const std::string ¶meter_name)
absl::StatusOr< int > DefaultIntParamValue(const std::string ¶meter_name)
absl::Status DeleteConstraint(SCIP_CONS *constraint)
absl::Status SetLinearConstraintUb(SCIP_CONS *constraint, double ub)
absl::Status SafeBulkDelete(const absl::flat_hash_set< SCIP_VAR * > &vars)
static absl::StatusOr< std::unique_ptr< GScip > > Create(const std::string &problem_name)
double ObjCoef(SCIP_VAR *var)
absl::Status SetMaximize(bool is_maximize)
absl::Span< SCIP_VAR *const > LinearConstraintVariables(SCIP_CONS *constraint)
absl::StatusOr< std::string > DefaultStringParamValue(const std::string ¶meter_name)
absl::StatusOr< bool > DefaultBoolParamValue(const std::string ¶meter_name)
absl::StatusOr< SCIP_CONS * > AddIndicatorConstraint(const GScipIndicatorConstraint &indicator_constraint, const std::string &name="", const GScipConstraintOptions &options=DefaultGScipConstraintOptions())
absl::Status SetLb(SCIP_VAR *var, double lb)
double LinearConstraintLb(SCIP_CONS *constraint)
absl::Status SetLinearConstraintCoef(SCIP_CONS *constraint, SCIP_VAR *var, double value)
absl::Status SetLinearConstraintLb(SCIP_CONS *constraint, double lb)
absl::StatusOr< GScipHintResult > SuggestHint(const GScipSolution &partial_solution)
absl::StatusOr< GScipResult > Solve(const GScipParameters ¶ms=GScipParameters(), const std::string &legacy_params="", GScipMessageHandler message_handler=nullptr)
GScipVarType VarType(SCIP_VAR *var)
absl::Status SetVarType(SCIP_VAR *var, GScipVarType var_type)
absl::Status SetBranchingPriority(SCIP_VAR *var, int priority)
absl::StatusOr< char > DefaultCharParamValue(const std::string ¶meter_name)
absl::Span< const double > LinearConstraintCoefficients(SCIP_CONS *constraint)
absl::Status SetUb(SCIP_VAR *var, double ub)
absl::Status SetObjCoef(SCIP_VAR *var, double obj_coef)
absl::StatusOr< SCIP_CONS * > AddSOS2Constraint(const GScipSOSData &sos_data, const std::string &name="", const GScipConstraintOptions &options=DefaultGScipConstraintOptions())
static std::string ScipVersion()
absl::StatusOr< SCIP_CONS * > AddQuadraticConstraint(const GScipQuadraticRange &range, const std::string &name="", const GScipConstraintOptions &options=DefaultGScipConstraintOptions())
absl::string_view Name(SCIP_VAR *var)
absl::StatusOr< SCIP_CONS * > AddSOS1Constraint(const GScipSOSData &sos_data, const std::string &name="", const GScipConstraintOptions &options=DefaultGScipConstraintOptions())
bool ObjectiveIsMaximize()
#define RETURN_ERROR_UNLESS(x)
const char * SCIPlpiGetSolverName(void)
gets name and version of LP solver
absl::StatusOr< MessageHandlerPtr > MakeSCIPMessageHandler(const GScipMessageHandler gscip_message_handler)
MessageHandlerPtr CaptureMessageHandlerPtr(SCIP_MESSAGEHDLR *const handler)
std::unique_ptr< SCIP_MESSAGEHDLR, void(*)(SCIP_MESSAGEHDLR *)> MessageHandlerPtr
Collection of objects used to extend the Constraint Solver library.
const GScipConstraintOptions & DefaultGScipConstraintOptions()
std::function< void(GScipMessageType type, absl::string_view message)> GScipMessageHandler
int GScipMaxNumThreads(const GScipParameters ¶meters)
absl::Status LegacyScipSetSolverSpecificParameters(const std::string ¶meters, SCIP *scip)
std::string ProtoEnumToString(ProtoEnumType enum_value)
const GScipVariableOptions & DefaultGScipVariableOptions()
absl::flat_hash_map< SCIP_VAR *, double > GScipSolution
#define SCIP_TO_STATUS(x)
#define RETURN_IF_SCIP_ERROR(x)
#define ASSIGN_OR_RETURN(lhs, rexpr)
#define RETURN_IF_ERROR(expr)
std::vector< double > coefficients
std::vector< SCIP_Var * > variables
SCIP_VAR * indicator_variable
std::vector< SCIP_VAR * > variables
std::vector< double > coefficients
std::vector< SCIP_VAR * > operators
std::vector< SCIP_Var * > quadratic_variables1
std::vector< SCIP_Var * > quadratic_variables2
std::vector< SCIP_Var * > linear_variables
std::vector< double > linear_coefficients
std::vector< double > quadratic_coefficients
absl::flat_hash_map< SCIP_VAR *, double > primal_ray
std::vector< double > objective_values
std::vector< GScipSolution > solutions
std::vector< SCIP_VAR * > variables
std::vector< double > weights