Google OR-Tools v9.11
a fast and portable software suite for combinatorial optimization
Loading...
Searching...
No Matches
result_validator.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_VALIDATORS_RESULT_VALIDATOR_H_
15#define OR_TOOLS_MATH_OPT_VALIDATORS_RESULT_VALIDATOR_H_
16
17#include "absl/status/status.h"
18#include "google/protobuf/repeated_ptr_field.h"
20#include "ortools/math_opt/model_parameters.pb.h"
21#include "ortools/math_opt/result.pb.h"
22
23namespace operations_research {
24namespace math_opt {
25
26absl::Status ValidateSolutions(
27 const google::protobuf::RepeatedPtrField<SolutionProto>& solutions,
28 const ModelSolveParametersProto& parameters,
29 const ModelSummary& model_summary);
30
31// Validates the input result.
32absl::Status ValidateResult(const SolveResultProto& result,
33 const ModelSolveParametersProto& parameters,
34 const ModelSummary& model_summary);
35
36// Returns absl::Ok only if a primal feasible solution is available.
37absl::Status CheckHasPrimalSolution(const SolveResultProto& result);
39 const TerminationProto& termination,
40 const google::protobuf::RepeatedPtrField<SolutionProto>& solutions,
41 bool maximize);
43 const TerminationProto& termination,
44 const google::protobuf::RepeatedPtrField<SolutionProto>& solutions,
45 bool maximize);
46
47} // namespace math_opt
48} // namespace operations_research
49
50#endif // OR_TOOLS_MATH_OPT_VALIDATORS_RESULT_VALIDATOR_H_
SatParameters parameters
TerminationReason termination
absl::Status CheckDualSolutionAndStatusConsistency(const TerminationProto &termination, const google::protobuf::RepeatedPtrField< SolutionProto > &solutions, const bool maximize)
absl::Status CheckHasPrimalSolution(const SolveResultProto &result)
Returns absl::Ok only if a primal feasible solution is available.
absl::Status CheckPrimalSolutionAndTerminationConsistency(const TerminationProto &termination, const google::protobuf::RepeatedPtrField< SolutionProto > &solutions, const bool maximize)
absl::Status ValidateResult(const SolveResultProto &result, const ModelSolveParametersProto &parameters, const ModelSummary &model_summary)
Validates the input result.
absl::Status ValidateSolutions(const google::protobuf::RepeatedPtrField< SolutionProto > &solutions, const ModelSolveParametersProto &parameters, const ModelSummary &model_summary)
In SWIG mode, we don't want anything besides these top-level includes.