Google OR-Tools v9.11
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-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_LINEAR_SOLVER_PROTO_SOLVER_PDLP_PROTO_SOLVER_H_
15#define OR_TOOLS_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"
22
23namespace 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.
43absl::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 // OR_TOOLS_LINEAR_SOLVER_PROTO_SOLVER_PDLP_PROTO_SOLVER_H_
In SWIG mode, we don't want anything besides these top-level includes.
absl::StatusOr< MPSolutionResponse > PdlpSolveProto(LazyMutableCopy< MPModelRequest > request, const bool relax_integer_variables, const std::atomic< bool > *interrupt_solve)