OR-Tools  9.1
model_solve_parameters.cc
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 
15 
16 #include <stdint.h>
17 
18 #include <initializer_list>
19 #include <optional>
20 #include <utility>
21 
22 #include "google/protobuf/message.h"
28 #include "ortools/math_opt/model_parameters.pb.h"
29 #include "ortools/math_opt/solution.pb.h"
30 #include "ortools/math_opt/sparse_containers.pb.h"
31 
32 namespace operations_research {
33 namespace math_opt {
34 
35 using ::google::protobuf::RepeatedField;
36 
39  parameters.dual_linear_constraints_filter =
40  MakeSkipAllFilter<LinearConstraint>();
41  parameters.dual_variables_filter = MakeSkipAllFilter<Variable>();
42  return parameters;
43 }
44 
46  std::initializer_list<Variable> variables) {
47  return OnlySomePrimalVariables<std::initializer_list<Variable>>(variables);
48 }
49 
53  dual_variables_filter.model()});
54 }
55 
56 ModelSolveParametersProto ModelSolveParameters::Proto() const {
57  // We call model() here for its side effect of asserting that all filters use
58  // variables and linear constraints use the same model.
59  model();
60 
61  ModelSolveParametersProto ret;
62  *ret.mutable_primal_variables_filter() = primal_variables_filter.Proto();
63  *ret.mutable_dual_linear_constraints_filter() =
65  *ret.mutable_dual_variables_filter() = dual_variables_filter.Proto();
66 
67  // TODO(user): consolidate code. Probably best to add an export_to_proto
68  // to IdMap
69  if (initial_basis) {
70  RepeatedField<int64_t>* const constraint_status_ids =
71  ret.mutable_initial_basis()->mutable_constraint_status()->mutable_ids();
72  RepeatedField<int>* const constraint_status_values =
73  ret.mutable_initial_basis()
74  ->mutable_constraint_status()
75  ->mutable_values();
76  constraint_status_ids->Reserve(initial_basis->constraint_status.size());
77  constraint_status_values->Reserve(initial_basis->constraint_status.size());
78  for (const LinearConstraint& key :
79  initial_basis->constraint_status.SortedKeys()) {
80  constraint_status_ids->Add(key.id());
81  constraint_status_values->Add(initial_basis->constraint_status.at(key));
82  }
83  RepeatedField<int64_t>* const variable_status_ids =
84  ret.mutable_initial_basis()->mutable_variable_status()->mutable_ids();
85  RepeatedField<int>* const variable_status_values =
86  ret.mutable_initial_basis()
87  ->mutable_variable_status()
88  ->mutable_values();
89  variable_status_ids->Reserve(initial_basis->variable_status.size());
90  variable_status_values->Reserve(initial_basis->variable_status.size());
91  for (const Variable& key : initial_basis->variable_status.SortedKeys()) {
92  variable_status_ids->Add(key.id());
93  variable_status_values->Add(initial_basis->variable_status.at(key));
94  }
95  }
96  return ret;
97 }
98 
99 } // namespace math_opt
100 } // namespace operations_research
IndexedModel * ConsistentModel(std::initializer_list< IndexedModel * > models)
Definition: key_types.h:61
static ModelSolveParameters OnlySomePrimalVariables(const Collection &variables)
Collection of objects used to extend the Constraint Solver library.
SatParameters parameters