Google OR-Tools v9.12
a fast and portable software suite for combinatorial optimization
Loading...
Searching...
No Matches
visitor.cc
Go to the documentation of this file.
1// Copyright 2010-2025 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#include <cstddef>
15#include <cstdint>
16#include <string>
17#include <utility>
18#include <vector>
19
20#include "absl/container/flat_hash_map.h"
21#include "absl/log/check.h"
26
27namespace operations_research {
28// ---------- ArgumentHolder ----------
29
30const std::string& ArgumentHolder::TypeName() const { return type_name_; }
31
32void ArgumentHolder::SetTypeName(const std::string& type_name) {
33 type_name_ = type_name;
34}
35
36void ArgumentHolder::SetIntegerArgument(const std::string& arg_name,
37 int64_t value) {
38 integer_argument_[arg_name] = value;
39}
40
42 const std::string& arg_name, const std::vector<int64_t>& values) {
43 integer_array_argument_[arg_name] = values;
44}
45
46void ArgumentHolder::SetIntegerMatrixArgument(const std::string& arg_name,
47 const IntTupleSet& values) {
48 matrix_argument_.insert(std::make_pair(arg_name, values));
49}
50
51void ArgumentHolder::SetIntegerExpressionArgument(const std::string& arg_name,
52 IntExpr* const expr) {
53 integer_expression_argument_[arg_name] = expr;
54}
55
57 const std::string& arg_name, const std::vector<IntVar*>& vars) {
58 integer_variable_array_argument_[arg_name] = vars;
59}
60
61void ArgumentHolder::SetIntervalArgument(const std::string& arg_name,
62 IntervalVar* const var) {
63 interval_argument_[arg_name] = var;
64}
65
67 const std::string& arg_name, const std::vector<IntervalVar*>& vars) {
68 interval_array_argument_[arg_name] = vars;
69}
70
71void ArgumentHolder::SetSequenceArgument(const std::string& arg_name,
72 SequenceVar* const var) {
73 sequence_argument_[arg_name] = var;
74}
75
77 const std::string& arg_name, const std::vector<SequenceVar*>& vars) {
78 sequence_array_argument_[arg_name] = vars;
79}
80
82 const std::string& arg_name) const {
83 return integer_expression_argument_.contains(arg_name);
84}
85
87 const std::string& arg_name) const {
88 return integer_variable_array_argument_.contains(arg_name);
89}
90
92 const std::string& arg_name, int64_t def) const {
93 return gtl::FindWithDefault(integer_argument_, arg_name, def);
94}
95
97 const std::string& arg_name) const {
98 return gtl::FindOrDie(integer_argument_, arg_name);
99}
100
102 const std::string& arg_name) const {
103 return gtl::FindOrDie(integer_array_argument_, arg_name);
104}
105
107 const std::string& arg_name) const {
108 return gtl::FindOrDie(integer_expression_argument_, arg_name);
109}
110
111const std::vector<IntVar*>&
113 const std::string& arg_name) const {
114 return gtl::FindOrDie(integer_variable_array_argument_, arg_name);
115}
116
118 const std::string& arg_name) const {
119 return gtl::FindOrDie(matrix_argument_, arg_name);
120}
121
122// ---------- ModelParser ---------
123
125
126ModelParser::~ModelParser() { CHECK(holders_.empty()); }
127
128void ModelParser::BeginVisitModel(const std::string& solver_name) {
130}
131
132void ModelParser::EndVisitModel(const std::string& solver_name) {
134}
135
136void ModelParser::BeginVisitConstraint(const std::string& type_name,
137 const Constraint* const constraint) {
139}
140
141void ModelParser::EndVisitConstraint(const std::string& type_name,
142 const Constraint* const constraint) {
143 // Constraint parsing is usually done here.
145}
146
147void ModelParser::BeginVisitIntegerExpression(const std::string& type_name,
148 const IntExpr* const expr) {
150}
151
152void ModelParser::EndVisitIntegerExpression(const std::string& type_name,
153 const IntExpr* const expr) {
154 // Expression parsing is usually done here.
156}
157
158void ModelParser::VisitIntegerVariable(const IntVar* const variable,
159 IntExpr* const delegate) {
160 // Usual place for parsing.
161}
162
163void ModelParser::VisitIntegerVariable(const IntVar* const variable,
164 const std::string& operation,
165 int64_t value, IntVar* const delegate) {
166 delegate->Accept(this);
167 // Usual place for parsing.
168}
169
171 const std::string& operation,
172 int64_t value,
173 IntervalVar* const delegate) {
174 if (delegate != nullptr) {
175 delegate->Accept(this);
176 }
177 // Usual place for parsing.
178}
179
181 // Usual place for parsing.
182}
183
184// Integer arguments
185void ModelParser::VisitIntegerArgument(const std::string& arg_name,
186 int64_t value) {
187 Top()->SetIntegerArgument(arg_name, value);
188}
189
191 const std::string& arg_name, const std::vector<int64_t>& values) {
192 Top()->SetIntegerArrayArgument(arg_name, values);
193}
194
195void ModelParser::VisitIntegerMatrixArgument(const std::string& arg_name,
196 const IntTupleSet& values) {
197 Top()->SetIntegerMatrixArgument(arg_name, values);
198}
199
200// Variables.
201void ModelParser::VisitIntegerExpressionArgument(const std::string& arg_name,
202 IntExpr* const argument) {
203 Top()->SetIntegerExpressionArgument(arg_name, argument);
204 argument->Accept(this);
205}
206
208 const std::string& arg_name, const std::vector<IntVar*>& arguments) {
209 Top()->SetIntegerVariableArrayArgument(arg_name, arguments);
210 for (int i = 0; i < arguments.size(); ++i) {
211 arguments[i]->Accept(this);
212 }
213}
214
215// Visit interval argument.
216void ModelParser::VisitIntervalArgument(const std::string& arg_name,
217 IntervalVar* const argument) {
218 Top()->SetIntervalArgument(arg_name, argument);
219 argument->Accept(this);
220}
221
223 const std::string& arg_name, const std::vector<IntervalVar*>& arguments) {
224 Top()->SetIntervalArrayArgument(arg_name, arguments);
225 for (int i = 0; i < arguments.size(); ++i) {
226 arguments[i]->Accept(this);
227 }
228}
229
230// Visit sequence argument.
231void ModelParser::VisitSequenceArgument(const std::string& arg_name,
232 SequenceVar* const argument) {
233 Top()->SetSequenceArgument(arg_name, argument);
234 argument->Accept(this);
235}
236
238 const std::string& arg_name, const std::vector<SequenceVar*>& arguments) {
239 Top()->SetSequenceArrayArgument(arg_name, arguments);
240 for (int i = 0; i < arguments.size(); ++i) {
241 arguments[i]->Accept(this);
242 }
243}
244
246 holders_.push_back(new ArgumentHolder);
247}
248
250 CHECK(!holders_.empty());
251 delete holders_.back();
252 holders_.pop_back();
253}
254
256 CHECK(!holders_.empty());
257 return holders_.back();
258}
259} // namespace operations_research
Argument Holder: useful when visiting a model.
const IntTupleSet & FindIntegerMatrixArgumentOrDie(const std::string &arg_name) const
Definition visitor.cc:117
void SetIntegerVariableArrayArgument(const std::string &arg_name, const std::vector< IntVar * > &vars)
Definition visitor.cc:56
void SetIntervalArgument(const std::string &arg_name, IntervalVar *var)
Definition visitor.cc:61
void SetIntervalArrayArgument(const std::string &arg_name, const std::vector< IntervalVar * > &vars)
Definition visitor.cc:66
IntExpr * FindIntegerExpressionArgumentOrDie(const std::string &arg_name) const
Definition visitor.cc:106
void SetTypeName(const std::string &type_name)
Definition visitor.cc:32
bool HasIntegerExpressionArgument(const std::string &arg_name) const
Checks if arguments exist.
Definition visitor.cc:81
void SetIntegerArrayArgument(const std::string &arg_name, const std::vector< int64_t > &values)
Definition visitor.cc:41
const std::vector< IntVar * > & FindIntegerVariableArrayArgumentOrDie(const std::string &arg_name) const
Definition visitor.cc:112
void SetSequenceArgument(const std::string &arg_name, SequenceVar *var)
Definition visitor.cc:71
const std::string & TypeName() const
Type of the argument.
Definition visitor.cc:30
void SetIntegerMatrixArgument(const std::string &arg_name, const IntTupleSet &values)
Definition visitor.cc:46
bool HasIntegerVariableArrayArgument(const std::string &arg_name) const
Definition visitor.cc:86
const std::vector< int64_t > & FindIntegerArrayArgumentOrDie(const std::string &arg_name) const
Definition visitor.cc:101
int64_t FindIntegerArgumentOrDie(const std::string &arg_name) const
Definition visitor.cc:96
void SetIntegerArgument(const std::string &arg_name, int64_t value)
Setters.
Definition visitor.cc:36
void SetIntegerExpressionArgument(const std::string &arg_name, IntExpr *expr)
Definition visitor.cc:51
void SetSequenceArrayArgument(const std::string &arg_name, const std::vector< SequenceVar * > &vars)
Definition visitor.cc:76
int64_t FindIntegerArgumentWithDefault(const std::string &arg_name, int64_t def) const
Getters.
Definition visitor.cc:91
virtual void Accept(ModelVisitor *visitor) const
Accepts the given visitor.
--— Main IntTupleSet class --—
Definition tuple_set.h:47
void Accept(ModelVisitor *visitor) const override
Accepts the given visitor.
virtual void Accept(ModelVisitor *visitor) const =0
Accepts the given visitor.
void VisitIntervalArgument(const std::string &arg_name, IntervalVar *argument) override
Visit interval argument.
Definition visitor.cc:216
void VisitIntervalArrayArgument(const std::string &arg_name, const std::vector< IntervalVar * > &arguments) override
Definition visitor.cc:222
void VisitIntervalVariable(const IntervalVar *variable, const std::string &operation, int64_t value, IntervalVar *delegate) override
Definition visitor.cc:170
void VisitIntegerArgument(const std::string &arg_name, int64_t value) override
Integer arguments.
Definition visitor.cc:185
void VisitIntegerArrayArgument(const std::string &arg_name, const std::vector< int64_t > &values) override
Definition visitor.cc:190
void VisitSequenceVariable(const SequenceVar *variable) override
Definition visitor.cc:180
void BeginVisitIntegerExpression(const std::string &type_name, const IntExpr *expr) override
Definition visitor.cc:147
void VisitSequenceArgument(const std::string &arg_name, SequenceVar *argument) override
Visit sequence argument.
Definition visitor.cc:231
void VisitSequenceArrayArgument(const std::string &arg_name, const std::vector< SequenceVar * > &arguments) override
Definition visitor.cc:237
void VisitIntegerVariable(const IntVar *variable, IntExpr *delegate) override
Definition visitor.cc:158
void VisitIntegerVariableArrayArgument(const std::string &arg_name, const std::vector< IntVar * > &arguments) override
Definition visitor.cc:207
ModelParser()
-------— ModelParser ------—
Definition visitor.cc:124
void BeginVisitModel(const std::string &solver_name) override
Header/footers.
Definition visitor.cc:128
void BeginVisitConstraint(const std::string &type_name, const Constraint *constraint) override
Definition visitor.cc:136
void EndVisitConstraint(const std::string &type_name, const Constraint *constraint) override
Definition visitor.cc:141
ArgumentHolder * Top() const
Definition visitor.cc:255
void VisitIntegerMatrixArgument(const std::string &arg_name, const IntTupleSet &values) override
Definition visitor.cc:195
void EndVisitIntegerExpression(const std::string &type_name, const IntExpr *expr) override
Definition visitor.cc:152
void EndVisitModel(const std::string &solver_name) override
Definition visitor.cc:132
void VisitIntegerExpressionArgument(const std::string &arg_name, IntExpr *argument) override
Variables.
Definition visitor.cc:201
virtual void Accept(ModelVisitor *visitor) const
Accepts the given visitor.
const Collection::value_type::second_type & FindOrDie(const Collection &collection, const typename Collection::value_type::first_type &key)
Definition map_util.h:211
const MapUtilMappedT< Collection > & FindWithDefault(const Collection &collection, const KeyType &key, const MapUtilMappedT< Collection > &value)
Definition map_util.h:36
In SWIG mode, we don't want anything besides these top-level includes.