OR-Tools  9.2
cp_model_loader.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_CP_MODEL_LOADER_H_
15#define OR_TOOLS_SAT_CP_MODEL_LOADER_H_
16
17#include <cstdint>
18#include <functional>
19#include <vector>
20
21#include "absl/container/flat_hash_set.h"
30#include "ortools/sat/integer.h"
33#include "ortools/sat/model.h"
35
36namespace operations_research {
37namespace sat {
38
39// Extracts all the used variables in the CpModelProto and creates a
40// sat::Model representation for them. More precisely
41// - All Boolean variables will be mapped.
42// - All Interval variables will be mapped.
43// - All non-Boolean variable will have a corresponding IntegerVariable, and
44// depending on the view_all_booleans_as_integers, some or all of the
45// BooleanVariable will also have an IntegerVariable corresponding to its
46// "integer view".
47//
48// Note(user): We could create IntegerVariable on the fly as they are needed,
49// but that loose the original variable order which might be useful in
50// heuristics later.
51void LoadVariables(const CpModelProto& model_proto,
52 bool view_all_booleans_as_integers, Model* m);
53
54// Automatically detect optional variables.
55void DetectOptionalVariables(const CpModelProto& model_proto, Model* m);
56
57// Experimental. Loads the symmetry form the proto symmetry field, as long as
58// they only involve Booleans.
59//
60// TODO(user): We currently only have the code for Booleans, it is why we
61// currently ignore symmetries involving integer variables.
62void LoadBooleanSymmetries(const CpModelProto& model_proto, Model* m);
63
64// Extract the encodings (IntegerVariable <-> Booleans) present in the model.
65// This effectively load some linear constraints of size 1 that will be marked
66// as already loaded.
67void ExtractEncoding(const CpModelProto& model_proto, Model* m);
68
69// Extract element encodings from exactly_one constraints and
70// lit => var == value constraints.
71// This function must be called after ExtractEncoding() has been called.
72void ExtractElementEncoding(const CpModelProto& model_proto, Model* m);
73
74// Process all affine relations of the form a*X + b*Y == cte. For each
75// literals associated to (X >= bound) or (X == value) associate it to its
76// corresponding relation on Y. Also do the other side.
77//
78// TODO(user): In an ideal world, all affine relations like this should be
79// removed in the presolve.
81 Model* m);
82
83// Inspect the search strategy stored in the model, and adds a full encoding to
84// variables appearing in a SELECT_MEDIAN_VALUE search strategy if the search
85// branching is set to FIXED_SEARCH.
86void AddFullEncodingFromSearchBranching(const CpModelProto& model_proto,
87 Model* m);
88
89// Calls one of the functions below.
90// Returns false if we do not know how to load the given constraints.
91bool LoadConstraint(const ConstraintProto& ct, Model* m);
92
93void LoadBoolOrConstraint(const ConstraintProto& ct, Model* m);
94void LoadBoolAndConstraint(const ConstraintProto& ct, Model* m);
95void LoadAtMostOneConstraint(const ConstraintProto& ct, Model* m);
96void LoadExactlyOneConstraint(const ConstraintProto& ct, Model* m);
97void LoadBoolXorConstraint(const ConstraintProto& ct, Model* m);
98void LoadLinearConstraint(const ConstraintProto& ct, Model* m);
99void LoadAllDiffConstraint(const ConstraintProto& ct, Model* m);
100void LoadIntProdConstraint(const ConstraintProto& ct, Model* m);
101void LoadIntDivConstraint(const ConstraintProto& ct, Model* m);
111
112} // namespace sat
113} // namespace operations_research
114
115#endif // OR_TOOLS_SAT_CP_MODEL_LOADER_H_
Class that owns everything related to a particular optimization model.
Definition: sat/model.h:38
CpModelProto const * model_proto
const Constraint * ct
void LoadCircuitCoveringConstraint(const ConstraintProto &ct, Model *m)
void LoadExactlyOneConstraint(const ConstraintProto &ct, Model *m)
void LoadVariables(const CpModelProto &model_proto, bool view_all_booleans_as_integers, Model *m)
void LoadIntProdConstraint(const ConstraintProto &ct, Model *m)
bool LoadConstraint(const ConstraintProto &ct, Model *m)
void LoadBoolOrConstraint(const ConstraintProto &ct, Model *m)
void ExtractElementEncoding(const CpModelProto &model_proto, Model *m)
void LoadBooleanSymmetries(const CpModelProto &model_proto, Model *m)
void LoadCumulativeConstraint(const ConstraintProto &ct, Model *m)
void LoadRoutesConstraint(const ConstraintProto &ct, Model *m)
void LoadBoolAndConstraint(const ConstraintProto &ct, Model *m)
void LoadLinMaxConstraint(const ConstraintProto &ct, Model *m)
void LoadBoolXorConstraint(const ConstraintProto &ct, Model *m)
void LoadIntDivConstraint(const ConstraintProto &ct, Model *m)
void LoadLinearConstraint(const ConstraintProto &ct, Model *m)
void LoadIntMinConstraint(const ConstraintProto &ct, Model *m)
void LoadAtMostOneConstraint(const ConstraintProto &ct, Model *m)
void LoadCircuitConstraint(const ConstraintProto &ct, Model *m)
void LoadNoOverlapConstraint(const ConstraintProto &ct, Model *m)
void DetectOptionalVariables(const CpModelProto &model_proto, Model *m)
void LoadAllDiffConstraint(const ConstraintProto &ct, Model *m)
void LoadNoOverlap2dConstraint(const ConstraintProto &ct, Model *m)
void LoadIntMaxConstraint(const ConstraintProto &ct, Model *m)
void AddFullEncodingFromSearchBranching(const CpModelProto &model_proto, Model *m)
void ExtractEncoding(const CpModelProto &model_proto, Model *m)
void PropagateEncodingFromEquivalenceRelations(const CpModelProto &model_proto, Model *m)
Collection of objects used to extend the Constraint Solver library.