23 std::string MaybeExtendName(
const std::string& base_name,
24 const std::string& extension) {
25 if (base_name.empty()) {
28 return absl::StrCat(base_name,
"/", extension);
40 for (
const auto& term : right.
terms) {
41 left.
terms[term.first] -= term.second;
48 for (
auto& term : expr.
terms) {
49 term.second = -term.second;
60 result.
lower_bound = -std::numeric_limits<double>::infinity();
62 for (
const auto& term : diff.
terms) {
70 const std::string&
name) {
77 const std::vector<GScipLinearExpr>& terms,
78 const std::string&
name) {
87 std::vector<SCIP_VAR*> indicators;
88 for (
int i = 0; i < terms.size(); ++i) {
89 auto z = gscip->
AddVariable(0.0, 1.0, 0.0, GScipVarType::kInteger,
90 MaybeExtendName(
name, absl::StrCat(
"z_", i)));
92 indicators.push_back(*z);
95 for (
int i = 0; i < terms.size(); ++i) {
99 ->AddLinearConstraint(
100 GScipLe(terms.at(i), resultant),
101 MaybeExtendName(
name, absl::StrCat(
"x_", i,
"_le_y")))
114 ->AddIndicatorConstraint(
115 ind, MaybeExtendName(
116 name, absl::StrCat(
"y_le__x_", i,
"_if_z_", i)))
126 z_use.
coefficients = std::vector<double>(indicators.size(), 1.0);
133 const std::vector<GScipLinearExpr>& terms,
134 const std::string&
name) {
135 std::vector<GScipLinearExpr> negated_terms;
136 negated_terms.reserve(terms.size());
144 GScip* gscip, std::vector<SCIP_Var*> quadratic_variables1,
145 std::vector<SCIP_Var*> quadratic_variables2,
146 std::vector<double> quadratic_coefficients,
const std::string&
name) {
147 constexpr
double kInf = std::numeric_limits<double>::infinity();
149 gscip->
AddVariable(-kInf, kInf, 1.0, GScipVarType::kContinuous,
150 MaybeExtendName(
name,
"obj"));
184 ->AddIndicatorConstraint(
185 ub_constraint, MaybeExtendName(
name,
"ub"), options)
200 ->AddIndicatorConstraint(
201 lb_constraint, MaybeExtendName(
name,
"lb"), options)
204 return absl::OkStatus();