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