Google OR-Tools
v9.15
a fast and portable software suite for combinatorial optimization
Loading...
Searching...
No Matches
pdlp_proto_solver.h
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
#ifndef ORTOOLS_LINEAR_SOLVER_PROTO_SOLVER_PDLP_PROTO_SOLVER_H_
15
#define ORTOOLS_LINEAR_SOLVER_PROTO_SOLVER_PDLP_PROTO_SOLVER_H_
16
17
#include <atomic>
18
19
#include "absl/status/statusor.h"
20
#include "
ortools/linear_solver/linear_solver.pb.h
"
21
#include "
ortools/util/lazy_mutable_copy.h
"
22
23
namespace
operations_research
{
24
25
// Uses pdlp::PrimalDualHybridGradient to solve the problem specified by the
26
// MPModelRequest. Users of this interface should be aware of the size
27
// limitations of MPModelProto (see, e.g., large_linear_program.proto).
28
//
29
// If possible, std::move the request into this function call so that its
30
// memory can be reclaimed early.
31
//
32
// The optional interrupt_solve can be used to interrupt the solve early. The
33
// solver will periodically check its value and stop if it holds true.
34
//
35
// If relax_integer_variables is true, integrality constraints are relaxed
36
// before solving. If false, integrality constraints result in an error. The
37
// solver_specific_info field in the MPSolutionResponse contains a serialized
38
// SolveLog.
39
//
40
// Returns an error if the conversion from MPModelProto to
41
// pdlp::QuadraticProgram fails. The lack of an error does not imply success.
42
// Check the SolveLog's termination_reason for more refined status details.
43
absl::StatusOr<MPSolutionResponse>
PdlpSolveProto
(
44
LazyMutableCopy<MPModelRequest>
request,
45
bool
relax_integer_variables =
false
,
46
const
std::atomic<bool>* interrupt_solve =
nullptr
);
47
48
}
// namespace operations_research
49
50
#endif
// ORTOOLS_LINEAR_SOLVER_PROTO_SOLVER_PDLP_PROTO_SOLVER_H_
operations_research::LazyMutableCopy
Definition
lazy_mutable_copy.h:44
lazy_mutable_copy.h
linear_solver.pb.h
operations_research
OR-Tools root namespace.
Definition
binary_indexed_tree.h:21
operations_research::PdlpSolveProto
absl::StatusOr< MPSolutionResponse > PdlpSolveProto(LazyMutableCopy< MPModelRequest > request, const bool relax_integer_variables, const std::atomic< bool > *interrupt_solve)
Definition
pdlp_proto_solver.cc:36
ortools
linear_solver
proto_solver
pdlp_proto_solver.h
Generated by
1.15.0