OR-Tools  9.1
linear_relaxation.h
Go to the documentation of this file.
1 // Copyright 2010-2021 Google LLC
2 // Licensed under the Apache License, Version 2.0 (the "License");
3 // you may not use this file except in compliance with the License.
4 // You may obtain a copy of the License at
5 //
6 // http://www.apache.org/licenses/LICENSE-2.0
7 //
8 // Unless required by applicable law or agreed to in writing, software
9 // distributed under the License is distributed on an "AS IS" BASIS,
10 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
11 // See the License for the specific language governing permissions and
12 // limitations under the License.
13 
14 #ifndef OR_TOOLS_SAT_LINEAR_RELAXATION_H_
15 #define OR_TOOLS_SAT_LINEAR_RELAXATION_H_
16 
17 #include <vector>
18 
20 #include "ortools/sat/integer.h"
23 #include "ortools/sat/model.h"
24 
25 namespace operations_research {
26 namespace sat {
27 
29  std::vector<LinearConstraint> linear_constraints;
30  std::vector<std::vector<Literal>> at_most_ones;
31  std::vector<CutGenerator> cut_generators;
32 };
33 
34 // If the given IntegerVariable is fully encoded (li <=> var == xi), adds to the
35 // constraints vector the following linear relaxation of its encoding:
36 // - Sum li == 1
37 // - Sum li * xi == var
38 // Note that all the literal (li) of the encoding must have an IntegerView,
39 // otherwise this function just does nothing.
40 //
41 // Returns false, if the relaxation couldn't be added because this variable
42 // was not fully encoded or not all its associated literal had a view.
43 bool AppendFullEncodingRelaxation(IntegerVariable var, const Model& model,
44  LinearRelaxation* relaxation);
45 
46 // When the set of (li <=> var == xi) do not cover the full domain of xi, we
47 // do something a bit more involved. Let min/max the min and max value of the
48 // domain of var that is NOT part of the encoding. We add:
49 // - Sum li <= 1
50 // - (Sum li * xi) + (1 - Sum li) * min <= var
51 // - var <= (Sum li * xi) + (1 - Sum li) * max
52 //
53 // Note that if it turns out that the partial encoding is full, this will just
54 // use the same encoding as AppendFullEncodingRelaxation(). Any literal that
55 // do not have an IntegerView will be skipped, there is no point adding them
56 // to the LP if they are not used in any other constraint, the relaxation will
57 // have the same "power" without them.
58 void AppendPartialEncodingRelaxation(IntegerVariable var, const Model& model,
59  LinearRelaxation* relaxation);
60 
61 // This is a different relaxation that use a partial set of literal li such that
62 // (li <=> var >= xi). In which case we use the following encoding:
63 // - li >= l_{i+1} for all possible i. Note that the xi need to be sorted.
64 // - var >= min + l0 * (x0 - min) + Sum_{i>0} li * (xi - x_{i-1})
65 // - and same as above for NegationOf(var) for the upper bound.
66 //
67 // Like for AppendPartialEncodingRelaxation() we skip any li that do not have
68 // an integer view.
70  const Model& model,
71  LinearRelaxation* relaxation);
72 
73 // Returns a vector of new literals in exactly one relationship.
74 // In addition, this create an IntegerView for all these literals and also add
75 // the exactly one to the LinearRelaxation.
76 std::vector<Literal> CreateAlternativeLiteralsWithView(
77  int num_literals, Model* model, LinearRelaxation* relaxation);
78 
79 // Adds linearization of int max constraints. Returns a vector of z vars such
80 // that: z_vars[l] == 1 <=> target = exprs[l].
81 //
82 // Consider the Lin Max constraint with d expressions and n variables in the
83 // form: target = max {exprs[l] = Sum (wli * xi + bl)}. l in {1,..,d}.
84 // Li = lower bound of xi
85 // Ui = upper bound of xi.
86 // Let zl be in {0,1} for all l in {1,..,d}.
87 // The target = exprs[l] when zl = 1.
88 //
89 // The following is a valid linearization for Lin Max.
90 // target >= exprs[l], for all l in {1,..,d}
91 // target <= Sum_i(wki * xi) + Sum_l((Nkl + bl) * zl), for all k in {1,..,d}
92 // Where Nkl is a large number defined as:
93 // Nkl = Sum_i(max((wli - wki)*Li, (wli - wki)*Ui))
94 // = Sum (max corner difference for variable i, target expr k, max expr l)
95 // Reference: "Strong mixed-integer programming formulations for trained neural
96 // networks" by Ross Anderson et. (https://arxiv.org/pdf/1811.01988.pdf).
97 // TODO(user): Support linear expression as target.
99  LinearRelaxation* relaxation);
101  IntegerVariable target, const std::vector<Literal>& alternative_literals,
102  const std::vector<LinearExpression>& exprs, Model* model,
103  LinearRelaxation* relaxation);
104 
106  LinearRelaxation* relaxation);
107 
109  LinearRelaxation* relaxation);
110 
112  LinearRelaxation* relaxation);
113 
115  LinearRelaxation* relaxation);
116 
118  bool encode_other_direction, Model* model,
119  LinearRelaxation* relaxation);
120 
122  bool encode_other_direction, Model* model,
123  LinearRelaxation* relaxation);
124 
125 // Appends linear constraints to the relaxation. This also handles the
126 // relaxation of linear constraints with enforcement literals.
127 // A linear constraint lb <= ax <= ub with enforcement literals {ei} is relaxed
128 // as following.
129 // lb <= (Sum Negated(ei) * (lb - implied_lb)) + ax <= inf
130 // -inf <= (Sum Negated(ei) * (ub - implied_ub)) + ax <= ub
131 // Where implied_lb and implied_ub are trivial lower and upper bounds of the
132 // constraint.
134  bool linearize_enforced_constraints,
135  Model* model,
136  LinearRelaxation* relaxation);
137 
139  LinearRelaxation* relaxation);
140 
142  LinearRelaxation* relaxation);
143 
145  LinearRelaxation* relaxation);
146 
147 // Adds linearization of no overlap constraints.
148 // It adds an energetic equation linking the duration of all potential tasks to
149 // the actual span of the no overlap constraint.
151  const ConstraintProto& ct, Model* model,
152  LinearRelaxation* relaxation);
153 
154 // Adds linearization of cumulative constraints.The second part adds an
155 // energetic equation linking the duration of all potential tasks to the actual
156 // max span * capacity of the cumulative constraint.
158  const ConstraintProto& ct, Model* model,
159  LinearRelaxation* relaxation);
160 
161 // Adds linearization of different types of constraints.
163  const ConstraintProto& ct,
164  int linearization_level, Model* model,
165  LinearRelaxation* relaxation);
166 
167 // Cut generators.
169  LinearRelaxation* relaxation);
170 
172  LinearRelaxation* relaxation);
173 
175  LinearRelaxation* relaxation);
176 
178  LinearRelaxation* relaxation);
179 
181  LinearRelaxation* relaxation);
182 
184  LinearRelaxation* relaxation);
185 
187  LinearRelaxation* relaxation);
188 
190  LinearRelaxation* relaxation);
191 
192 // Note: This only work if all affine expressions share the same variable.
194  LinearRelaxation* relaxation);
195 
196 // Scan the model and add cut generators.
197 void TryToAddCutGenerators(const ConstraintProto& ct, int linearization_level,
198  Model* m, LinearRelaxation* relaxation);
199 
200 // Builds the linear relaxaton of a CpModelProto and stores it in the
201 // LinearRelaxation container.
203  int linearization_level, Model* m,
204  LinearRelaxation* relaxation);
205 
206 } // namespace sat
207 } // namespace operations_research
208 
209 #endif // OR_TOOLS_SAT_LINEAR_RELAXATION_H_
void AddAllDiffCutGenerator(const ConstraintProto &ct, Model *m, LinearRelaxation *relaxation)
void AppendLinMaxRelaxationPart1(const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
bool AppendFullEncodingRelaxation(IntegerVariable var, const Model &model, LinearRelaxation *relaxation)
void ComputeLinearRelaxation(const CpModelProto &model_proto, int linearization_level, Model *m, LinearRelaxation *relaxation)
Class that owns everything related to a particular optimization model.
Definition: sat/model.h:38
void AppendCircuitRelaxation(const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
void AppendIntervalRelaxation(const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
void AppendIntMaxRelaxation(const ConstraintProto &ct, int linearization_level, Model *model, LinearRelaxation *relaxation)
GRBmodel * model
std::vector< Literal > CreateAlternativeLiteralsWithView(int num_literals, Model *model, LinearRelaxation *relaxation)
void AppendAtMostOneRelaxation(const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
void AddCumulativeCutGenerator(const ConstraintProto &ct, Model *m, LinearRelaxation *relaxation)
std::vector< std::vector< Literal > > at_most_ones
void AddRoutesCutGenerator(const ConstraintProto &ct, Model *m, LinearRelaxation *relaxation)
void AddNoOverlap2dCutGenerator(const ConstraintProto &ct, Model *m, LinearRelaxation *relaxation)
void AppendPartialGreaterThanEncodingRelaxation(IntegerVariable var, const Model &model, LinearRelaxation *relaxation)
void AppendLinearConstraintRelaxation(const ConstraintProto &ct, bool linearize_enforced_constraints, Model *model, LinearRelaxation *relaxation)
void AppendBoolAndRelaxation(const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
void TryToLinearizeConstraint(const CpModelProto &model_proto, const ConstraintProto &ct, int linearization_level, Model *model, LinearRelaxation *relaxation)
void AddNoOverlapCutGenerator(const ConstraintProto &ct, Model *m, LinearRelaxation *relaxation)
void AppendExactlyOneRelaxation(const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
void AppendMaxAffineRelaxation(const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
void AppendBoolOrRelaxation(const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
CpModelProto const * model_proto
void TryToAddCutGenerators(const ConstraintProto &ct, int linearization_level, Model *m, LinearRelaxation *relaxation)
void AppendNoOverlapRelaxation(const CpModelProto &model_proto, const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
void AddCircuitCutGenerator(const ConstraintProto &ct, Model *m, LinearRelaxation *relaxation)
void AppendPartialEncodingRelaxation(IntegerVariable var, const Model &model, LinearRelaxation *relaxation)
std::vector< CutGenerator > cut_generators
Collection of objects used to extend the Constraint Solver library.
void AppendRoutesRelaxation(const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)
void AddIntProdCutGenerator(const ConstraintProto &ct, int linearization_level, Model *m, LinearRelaxation *relaxation)
IntVar * var
Definition: expr_array.cc:1874
void AppendLinMaxRelaxationPart2(IntegerVariable target, const std::vector< Literal > &alternative_literals, const std::vector< LinearExpression > &exprs, Model *model, LinearRelaxation *relaxation)
std::vector< LinearConstraint > linear_constraints
void AddLinMaxCutGenerator(const ConstraintProto &ct, Model *m, LinearRelaxation *relaxation)
const Constraint * ct
void AppendIntMinRelaxation(const ConstraintProto &ct, bool encode_other_direction, Model *model, LinearRelaxation *relaxation)
void AppendCumulativeRelaxation(const CpModelProto &model_proto, const ConstraintProto &ct, Model *model, LinearRelaxation *relaxation)