Google OR-Tools v9.11
a fast and portable software suite for combinatorial optimization
Loading...
Searching...
No Matches
proto_converter.h
Go to the documentation of this file.
1// Copyright 2010-2024 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_MATH_OPT_IO_PROTO_CONVERTER_H_
15#define OR_TOOLS_MATH_OPT_IO_PROTO_CONVERTER_H_
16
17#include <optional>
18
19#include "absl/status/statusor.h"
20#include "ortools/linear_solver/linear_solver.pb.h"
21#include "ortools/math_opt/model.pb.h"
22#include "ortools/math_opt/model_parameters.pb.h"
23
25
26// Returns a ModelProto equivalent to the input linear_solver Model. The input
27// MPModelProto must be valid, as checked by `FindErrorInMPModelProto()`.
28//
29// The linear_solver Model stores all general constraints (e.g., quadratic, SOS)
30// in a single repeated field, while ModelProto stores then in separate maps.
31// The output constraint maps will each be populated with consecutive indices
32// starting from 0 (hence the indices may change).
33//
34// MPModelProto can contain an optional `solution_hint` which is ignored by this
35// function. In MathOpt the hints are parameters passed to the solve functions
36// instead of being in the model. The `MPModelProtoSolutionHintToMathOptHint()`
37// function can be used to extract it.
38absl::StatusOr<ModelProto> MPModelProtoToMathOptModel(
39 const MPModelProto& model);
40
41// Returns the optional `model.solution_hint` as a MathOpt hint. Returns nullopt
42// if no hint is set on the input model or if the hint is empty.
43//
44// The input MPModelProto must be valid, as checked by
45// `FindErrorInMPModelProto()`.
46absl::StatusOr<std::optional<SolutionHintProto>>
48
49// Returns a linear_solver MPModelProto equivalent to the input math_opt Model.
50// The input Model must be in a valid state, as checked by `ValidateModel`.
51//
52// Variables are created in the same order as they appear in
53// `model.variables`. Hence the returned `.variable(i)` corresponds to input
54// `model.variables.ids(i)`.
55//
56// The linear_solver Model stores all general constraints (e.g., quadratic, SOS)
57// in a single repeated field, while ModelProto stores then in separate maps.
58// Therefore neither the relative ordering, nor the raw IDs, of general
59// constraints are preserved in the resulting Model.
60absl::StatusOr<MPModelProto> MathOptModelToMPModelProto(
61 const ModelProto& model);
62
63} // namespace operations_research::math_opt
64
65#endif // OR_TOOLS_MATH_OPT_IO_PROTO_CONVERTER_H_
GRBmodel * model
An object oriented wrapper for quadratic constraints in ModelStorage.
Definition gurobi_isv.cc:28
absl::StatusOr< std::optional< SolutionHintProto > > MPModelProtoSolutionHintToMathOptHint(const MPModelProto &model)
absl::StatusOr<::operations_research::MPModelProto > MathOptModelToMPModelProto(const ::operations_research::math_opt::ModelProto &model)
absl::StatusOr<::operations_research::math_opt::ModelProto > MPModelProtoToMathOptModel(const ::operations_research::MPModelProto &model)