OR-Tools  9.3
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"
27#include "ortools/math_opt/model_parameters.pb.h"
28#include "ortools/math_opt/solution.pb.h"
29#include "ortools/math_opt/sparse_containers.pb.h"
30
31namespace operations_research {
32namespace math_opt {
33
34using ::google::protobuf::RepeatedField;
35
38 parameters.dual_values_filter = MakeSkipAllFilter<LinearConstraint>();
39 parameters.reduced_costs_filter = MakeSkipAllFilter<Variable>();
40 return parameters;
41}
42
44 std::initializer_list<Variable> variables) {
45 return OnlySomePrimalVariables<std::initializer_list<Variable>>(variables);
46}
47
50 dual_values_filter.storage(),
51 reduced_costs_filter.storage()});
52}
53
54ModelSolveParametersProto ModelSolveParameters::Proto() const {
55 // We call storage() here for its side effect of asserting that all filters
56 // use variables and linear constraints use the same model.
57 storage();
58
59 ModelSolveParametersProto ret;
60 *ret.mutable_variable_values_filter() = variable_values_filter.Proto();
61 *ret.mutable_dual_values_filter() = dual_values_filter.Proto();
62 *ret.mutable_reduced_costs_filter() = reduced_costs_filter.Proto();
63
64 // TODO(b/183616124): consolidate code. Probably best to add an
65 // export_to_proto to IdMap
66 if (initial_basis) {
67 RepeatedField<int64_t>* const constraint_status_ids =
68 ret.mutable_initial_basis()->mutable_constraint_status()->mutable_ids();
69 RepeatedField<int>* const constraint_status_values =
70 ret.mutable_initial_basis()
71 ->mutable_constraint_status()
72 ->mutable_values();
73 constraint_status_ids->Reserve(initial_basis->constraint_status.size());
74 constraint_status_values->Reserve(initial_basis->constraint_status.size());
75 for (const LinearConstraint& key :
76 initial_basis->constraint_status.SortedKeys()) {
77 constraint_status_ids->Add(key.id());
78 constraint_status_values->Add(
79 EnumToProto(initial_basis->constraint_status.at(key)));
80 }
81 RepeatedField<int64_t>* const variable_status_ids =
82 ret.mutable_initial_basis()->mutable_variable_status()->mutable_ids();
83 RepeatedField<int>* const variable_status_values =
84 ret.mutable_initial_basis()
85 ->mutable_variable_status()
86 ->mutable_values();
87 variable_status_ids->Reserve(initial_basis->variable_status.size());
88 variable_status_values->Reserve(initial_basis->variable_status.size());
89 for (const Variable& key : initial_basis->variable_status.SortedKeys()) {
90 variable_status_ids->Add(key.id());
91 variable_status_values->Add(
92 EnumToProto(initial_basis->variable_status.at(key)));
93 }
94 }
95 for (const SolutionHint& solution_hint : solution_hints) {
96 SolutionHintProto& hint = *ret.add_solution_hints();
97 RepeatedField<int64_t>* const variable_ids =
98 hint.mutable_variable_values()->mutable_ids();
99 RepeatedField<double>* const variable_values =
100 hint.mutable_variable_values()->mutable_values();
101 variable_ids->Reserve(solution_hint.variable_values.size());
102 variable_values->Reserve(solution_hint.variable_values.size());
103 for (const Variable& key : solution_hint.variable_values.SortedKeys()) {
104 variable_ids->Add(key.id());
105 variable_values->Add(solution_hint.variable_values.at(key));
106 }
107 }
108 if (!branching_priorities.empty()) {
109 RepeatedField<int64_t>* const variable_ids =
110 ret.mutable_branching_priorities()->mutable_ids();
111 RepeatedField<int32_t>* const variable_values =
112 ret.mutable_branching_priorities()->mutable_values();
113 variable_ids->Reserve(branching_priorities.size());
114 variable_values->Reserve(branching_priorities.size());
115 for (const Variable& key : branching_priorities.SortedKeys()) {
116 variable_ids->Add(key.id());
117 variable_values->Add(branching_priorities.at(key));
118 }
119 }
120 return ret;
121}
122
123} // namespace math_opt
124} // namespace operations_research
SatParameters parameters
absl::Span< const int64_t > variable_ids
const ModelStorage * ConsistentModelStorage(std::initializer_list< const ModelStorage * > storages)
Definition: key_types.h:61
Enum< E >::Proto EnumToProto(const std::optional< E > value)
Definition: enums.h:264
Collection of objects used to extend the Constraint Solver library.
static ModelSolveParameters OnlySomePrimalVariables(const Collection &variables)