Google OR-Tools v9.11
a fast and portable software suite for combinatorial optimization
Loading...
Searching...
No Matches
pdlp_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_MATH_OPT_SOLVERS_PDLP_SOLVER_H_
15#define OR_TOOLS_MATH_OPT_SOLVERS_PDLP_SOLVER_H_
16
17#include <memory>
18
19#include "absl/status/statusor.h"
20#include "ortools/math_opt/callback.pb.h"
22#include "ortools/math_opt/infeasible_subsystem.pb.h"
23#include "ortools/math_opt/model.pb.h"
24#include "ortools/math_opt/model_parameters.pb.h"
25#include "ortools/math_opt/model_update.pb.h"
26#include "ortools/math_opt/parameters.pb.h"
27#include "ortools/math_opt/result.pb.h"
30#include "ortools/pdlp/solvers.pb.h"
32
33namespace operations_research {
34namespace math_opt {
35
37 public:
38 static absl::StatusOr<std::unique_ptr<SolverInterface>> New(
39 const ModelProto& model, const InitArgs& init_args);
40
41 absl::StatusOr<SolveResultProto> Solve(
42 const SolveParametersProto& parameters,
43 const ModelSolveParametersProto& model_parameters,
44 MessageCallback message_cb,
45 const CallbackRegistrationProto& callback_registration, Callback cb,
46 const SolveInterrupter* interrupter) override;
47 absl::StatusOr<bool> Update(const ModelUpdateProto& model_update) override;
48 absl::StatusOr<ComputeInfeasibleSubsystemResultProto>
49 ComputeInfeasibleSubsystem(const SolveParametersProto& parameters,
50 MessageCallback message_cb,
51 const SolveInterrupter* interrupter) override;
52
53 // Returns the merged parameters and a list of warnings.
54 static absl::StatusOr<pdlp::PrimalDualHybridGradientParams> MergeParameters(
55 const SolveParametersProto& parameters, bool has_message_callback);
56
57 private:
58 PdlpSolver() = default;
59
60 absl::StatusOr<SolveResultProto> MakeSolveResult(
61 const pdlp::SolverResult& pdlp_result,
62 const ModelSolveParametersProto& model_params);
63
64 PdlpBridge pdlp_bridge_;
65};
66
67} // namespace math_opt
68} // namespace operations_research
69
70#endif // OR_TOOLS_MATH_OPT_SOLVERS_PDLP_SOLVER_H_
static absl::StatusOr< std::unique_ptr< SolverInterface > > New(const ModelProto &model, const InitArgs &init_args)
absl::StatusOr< ComputeInfeasibleSubsystemResultProto > ComputeInfeasibleSubsystem(const SolveParametersProto &parameters, MessageCallback message_cb, const SolveInterrupter *interrupter) override
absl::StatusOr< SolveResultProto > Solve(const SolveParametersProto &parameters, const ModelSolveParametersProto &model_parameters, MessageCallback message_cb, const CallbackRegistrationProto &callback_registration, Callback cb, const SolveInterrupter *interrupter) override
static absl::StatusOr< pdlp::PrimalDualHybridGradientParams > MergeParameters(const SolveParametersProto &parameters, bool has_message_callback)
Returns the merged parameters and a list of warnings.
absl::StatusOr< bool > Update(const ModelUpdateProto &model_update) override
std::function< void(const std::vector< std::string > &)> MessageCallback
std::function< absl::StatusOr< CallbackResultProto >( const CallbackDataProto &)> Callback
SatParameters parameters
GRBmodel * model
In SWIG mode, we don't want anything besides these top-level includes.