2021-04-01 21:00:53 +02:00
|
|
|
// Copyright 2010-2021 Google LLC
|
2015-06-18 14:08:50 +02:00
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
|
//
|
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
//
|
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
|
|
#ifndef OR_TOOLS_LINEAR_SOLVER_MODEL_VALIDATOR_H_
|
|
|
|
|
#define OR_TOOLS_LINEAR_SOLVER_MODEL_VALIDATOR_H_
|
|
|
|
|
|
2022-05-18 16:36:05 +02:00
|
|
|
#include <optional>
|
2015-06-18 14:08:50 +02:00
|
|
|
#include <string>
|
2019-04-18 16:44:47 +02:00
|
|
|
|
2019-09-02 11:32:05 +02:00
|
|
|
#include "absl/types/optional.h"
|
2017-04-26 17:30:25 +02:00
|
|
|
#include "ortools/linear_solver/linear_solver.pb.h"
|
2019-09-02 11:32:05 +02:00
|
|
|
#include "ortools/util/lazy_mutable_copy.h"
|
2015-06-18 14:08:50 +02:00
|
|
|
|
|
|
|
|
namespace operations_research {
|
2019-07-17 07:08:02 -07:00
|
|
|
/**
|
2019-11-20 14:28:11 -08:00
|
|
|
* Returns an empty string iff the model is valid and not trivially infeasible.
|
|
|
|
|
* Otherwise, returns a description of the first error or trivial infeasibility
|
2021-08-23 16:52:06 +02:00
|
|
|
* variable or constraint bound encountered.
|
2019-07-17 07:08:02 -07:00
|
|
|
*
|
2020-11-19 00:17:26 +01:00
|
|
|
* abs_value_threshold is the (exclusive) limit for the abs value of constraint
|
|
|
|
|
* coefficients, objective coefficients, etc. If unspecified, or 0, it defaults
|
|
|
|
|
* to FLAGS_model_validator_infinity.
|
|
|
|
|
*
|
2019-07-17 07:08:02 -07:00
|
|
|
* NOTE(user): the code of this method (and the client code too!) is
|
2019-11-20 14:28:11 -08:00
|
|
|
* considerably simplified by this string-based, simple API. If clients
|
2019-07-17 07:08:02 -07:00
|
|
|
* require it, we could add a formal error status enum.
|
|
|
|
|
*/
|
2021-08-23 16:52:06 +02:00
|
|
|
std::string FindErrorInMPModelProto(
|
|
|
|
|
const MPModelProto& model, double abs_value_threshold = 0.0,
|
|
|
|
|
// If false, variable and constraint bounds like [lb=1.2, ub=0.7] yield an
|
|
|
|
|
// error, and also integer variable bounds like [0.7, 0.8].
|
|
|
|
|
bool accept_trivially_infeasible_bounds = false);
|
2015-10-23 13:45:43 +02:00
|
|
|
|
2019-07-18 05:53:45 -07:00
|
|
|
/**
|
2019-09-02 11:32:05 +02:00
|
|
|
* Like FindErrorInMPModelProto, but for a MPModelDeltaProto applied to a given
|
2019-07-18 05:53:45 -07:00
|
|
|
* baseline model (assumed valid, eg. FindErrorInMPModelProto(model)="").
|
|
|
|
|
* Works in O(|model_delta|) + O(num_vars in model), but the latter term has a
|
|
|
|
|
* very small constant factor.
|
|
|
|
|
*/
|
2020-10-29 14:25:39 +01:00
|
|
|
std::string FindErrorInMPModelDeltaProto(const MPModelDeltaProto& delta,
|
|
|
|
|
const MPModelProto& model);
|
2019-07-18 05:53:45 -07:00
|
|
|
|
|
|
|
|
/**
|
2019-09-02 11:32:05 +02:00
|
|
|
* If the model is valid and non-empty, returns it (possibly after extracting
|
|
|
|
|
* the model_delta). If invalid or empty, updates `response` and returns null.
|
2019-07-18 05:53:45 -07:00
|
|
|
*/
|
2020-11-16 17:50:35 +01:00
|
|
|
absl::optional<LazyMutableCopy<MPModelProto>>
|
2020-10-29 14:25:39 +01:00
|
|
|
ExtractValidMPModelOrPopulateResponseStatus(const MPModelRequest& request,
|
|
|
|
|
MPSolutionResponse* response);
|
2019-09-02 11:32:05 +02:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Like ExtractValidMPModelOrPopulateResponseStatus(), but works in-place:
|
|
|
|
|
* if the MPModel needed extraction, it will be populated in the request, and
|
|
|
|
|
* it returns the success boolean.
|
|
|
|
|
*/
|
|
|
|
|
bool ExtractValidMPModelInPlaceOrPopulateResponseStatus(
|
2020-10-29 14:25:39 +01:00
|
|
|
MPModelRequest* request, MPSolutionResponse* response);
|
2019-07-18 05:53:45 -07:00
|
|
|
|
2019-07-17 07:08:02 -07:00
|
|
|
/**
|
2019-11-20 14:28:11 -08:00
|
|
|
* Returns an empty string if the solution hint given in the model is a feasible
|
|
|
|
|
* solution. Otherwise, returns a description of the first reason for
|
2019-07-17 07:08:02 -07:00
|
|
|
* infeasibility.
|
|
|
|
|
*
|
|
|
|
|
* This function can be useful for debugging/checking that the given solution
|
|
|
|
|
* hint is feasible when it is expected to be the case. The feasibility is
|
|
|
|
|
* checked up to the given tolerance using the
|
|
|
|
|
* ::operations_research::IsLowerWithinTolerance() function.
|
|
|
|
|
*/
|
2020-10-29 14:25:39 +01:00
|
|
|
std::string FindFeasibilityErrorInSolutionHint(const MPModelProto& model,
|
2018-06-08 16:40:43 +02:00
|
|
|
double tolerance);
|
2015-10-23 13:45:43 +02:00
|
|
|
|
2019-07-18 05:53:45 -07:00
|
|
|
// Partially merges a MPConstraintProto onto another, skipping only the
|
|
|
|
|
// repeated fields "var_index" and "coefficients". This is used within
|
|
|
|
|
// FindErrorInMPModelDeltaProto.
|
|
|
|
|
// See the unit test MergeMPConstraintProtoExceptTermsTest that explains why we
|
|
|
|
|
// need this.
|
2020-10-29 14:25:39 +01:00
|
|
|
void MergeMPConstraintProtoExceptTerms(const MPConstraintProto& from,
|
|
|
|
|
MPConstraintProto* to);
|
2019-07-18 05:53:45 -07:00
|
|
|
|
2019-09-02 11:32:05 +02:00
|
|
|
// Applies the given model_delta to "model". Assumes that
|
2021-08-23 16:52:06 +02:00
|
|
|
// FindErrorInMPModelDeltaProto() found no error. For full error checking,
|
|
|
|
|
// please use ExtractValidMPModelOrPopulateResponseStatus() instead.
|
2020-10-29 14:25:39 +01:00
|
|
|
void ApplyVerifiedMPModelDelta(const MPModelDeltaProto& delta,
|
|
|
|
|
MPModelProto* model);
|
2019-09-02 11:32:05 +02:00
|
|
|
|
2020-10-22 23:36:58 +02:00
|
|
|
} // namespace operations_research
|
2015-06-18 14:08:50 +02:00
|
|
|
|
2020-10-22 23:36:58 +02:00
|
|
|
#endif // OR_TOOLS_LINEAR_SOLVER_MODEL_VALIDATOR_H_
|