19#include "google/protobuf/text_format.h"
45 LOG(DFATAL) <<
"Invalid bop::BopSolveStatus";
60 void Reset()
override;
68 const MPVariable*
const variable,
double new_value,
69 double old_value)
override;
78 int64_t
nodes()
const override;
84 bool IsLP()
const override;
85 bool IsMIP()
const override;
106 void NonIncrementalChange();
110 std::vector<MPSolver::BasisStatus> column_status_;
111 std::vector<MPSolver::BasisStatus> row_status_;
113 std::atomic<bool> interrupt_solver_;
123 interrupt_solver_(false) {}
129 if (interrupt_solver_) {
154 if (!
solver_->solution_hint_.empty()) {
155 const int num_vars =
solver_->variables_.size();
156 if (
solver_->solution_hint_.size() != num_vars) {
157 LOG(
WARNING) <<
"Bop currently doesn't handle partial solution hints. "
158 <<
"Filling the missing positions with zeros...";
161 for (
const std::pair<const MPVariable*, double>& p :
163 initial_solution[glop::ColIndex(p.first->index())] =
169 solver_->solver_specific_parameter_string_);
173 time_limit->RegisterExternalBooleanAsLimit(&interrupt_solver_);
175 initial_solution.
empty()
190 const size_t num_vars =
solver_->variables_.size();
192 for (
int var_id = 0; var_id < num_vars; ++var_id) {
194 const glop::ColIndex lp_solver_var_id(
var->index());
197 var->set_solution_value(
static_cast<double>(solution_value));
201 const size_t num_constraints =
solver_->constraints_.size();
210 linear_program_.
Clear();
211 interrupt_solver_ =
false;
215 NonIncrementalChange();
219 NonIncrementalChange();
223 NonIncrementalChange();
227 NonIncrementalChange();
231 NonIncrementalChange();
235 NonIncrementalChange();
240 double new_value,
double old_value) {
241 NonIncrementalChange();
245 NonIncrementalChange();
250 NonIncrementalChange();
258 LOG(DFATAL) <<
"Number of iterations not available";
263 LOG(DFATAL) <<
"Number of nodes not available";
268 return row_status_[constraint_index];
272 return column_status_[variable_index];
285 interrupt_solver_ =
true;
296 const glop::ColIndex num_cols(
solver_->variables_.size());
303 if (
var->integer()) {
314 const glop::RowIndex num_rows(
solver_->constraints_.size());
315 for (glop::RowIndex
row(0);
row < num_rows; ++
row) {
319 const double lb =
ct->lb();
320 const double ub =
ct->ub();
325 for (
const auto& entry :
ct->coefficients_) {
326 const int var_index = entry.first->index();
328 const glop::ColIndex
col(var_index);
329 const double coeff = entry.second;
338 for (
const auto& entry :
solver_->objective_->coefficients_) {
339 const int var_index = entry.first->index();
340 const glop::ColIndex
col(var_index);
341 const double coeff = entry.second;
376 google::protobuf::TextFormat::MergeFromString(
parameters, ¶meters_);
381void BopInterface::NonIncrementalChange() {
#define DCHECK(condition)
#define DCHECK_EQ(val1, val2)
#define VLOG(verboselevel)
void SetScalingMode(int value) override
void SetDualTolerance(double value) override
void AddRowConstraint(MPConstraint *const ct) override
void SetLpAlgorithm(int value) override
void ExtractObjective() override
void * underlying_solver() override
bool IsContinuous() const override
bool InterruptSolve() override
MPSolver::ResultStatus Solve(const MPSolverParameters ¶m) override
void SetPrimalTolerance(double value) override
void ClearConstraint(MPConstraint *const constraint) override
bool SetSolverSpecificParametersAsString(const std::string ¶meters) override
void SetObjectiveCoefficient(const MPVariable *const variable, double coefficient) override
void SetCoefficient(MPConstraint *const constraint, const MPVariable *const variable, double new_value, double old_value) override
MPSolver::BasisStatus row_status(int constraint_index) const override
void SetObjectiveOffset(double value) override
void SetVariableInteger(int index, bool integer) override
void SetParameters(const MPSolverParameters ¶m) override
void ExtractNewConstraints() override
BopInterface(MPSolver *const solver)
std::string SolverVersion() const override
void SetRelativeMipGap(double value) override
void SetConstraintBounds(int index, double lb, double ub) override
void SetPresolveMode(int value) override
void SetVariableBounds(int index, double lb, double ub) override
void AddVariable(MPVariable *const var) override
void ExtractNewVariables() override
int64_t nodes() const override
bool IsLP() const override
bool IsMIP() const override
int64_t iterations() const override
void SetOptimizationDirection(bool maximize) override
MPSolver::BasisStatus column_status(int variable_index) const override
void ClearObjective() override
The class for constraints of a Mathematical Programming (MP) model.
double offset() const
Gets the constant term in the objective.
This mathematical programming (MP) solver class is the main class though which users build and solve ...
ResultStatus
The status of solving the problem.
@ FEASIBLE
feasible, or stopped by limit.
@ NOT_SOLVED
not been solved yet.
@ INFEASIBLE
proven infeasible.
@ ABNORMAL
abnormal, i.e., error of some kind.
bool SetSolverSpecificParametersAsString(const std::string ¶meters)
Advanced usage: pass solver specific parameters in text format.
int64_t time_limit() const
const MPObjective & Objective() const
Returns the objective object.
BasisStatus
Advanced usage: possible basis status values for a variable and the slack variable of a linear constr...
virtual void SetIntegerParamToUnsupportedValue(MPSolverParameters::IntegerParam param, int value)
void set_constraint_as_extracted(int ct_index, bool extracted)
MPSolver::ResultStatus result_status_
int last_constraint_index_
static constexpr int64_t kUnknownNumberOfNodes
double best_objective_bound_
void ResetExtractionInformation()
bool variable_is_extracted(int var_index) const
static constexpr int64_t kUnknownNumberOfIterations
void set_variable_as_extracted(int var_index, bool extracted)
void SetCommonParameters(const MPSolverParameters ¶m)
SynchronizationStatus sync_status_
This class stores parameter settings for LP and MIP solvers.
@ PRESOLVE
Advanced usage: presolve mode.
@ PRESOLVE_ON
Presolve is on.
@ PRESOLVE_OFF
Presolve is off.
static const int kDefaultIntegerParamValue
The class for variables of a Mathematical Programming (MP) model.
static std::unique_ptr< TimeLimit > FromParameters(const Parameters ¶meters)
Creates a time limit object initialized from an object that provides methods max_time_in_seconds() an...
PROTOBUF_ATTRIBUTE_REINITIALIZES void Clear() final
void set_log_search_progress(bool value)
void set_max_time_in_seconds(double value)
ABSL_MUST_USE_RESULT BopSolveStatus SolveWithTimeLimit(const glop::LinearProgram &linear_problem, TimeLimit *time_limit)
glop::Fractional best_bound() const
glop::Fractional objective_value() const
const glop::DenseRow & variable_values() const
void SetParameters(const BopParameters ¶meters)
void SetVariableBounds(ColIndex col, Fractional lower_bound, Fractional upper_bound)
void SetObjectiveOffset(Fractional objective_offset)
void SetCoefficient(RowIndex row, ColIndex col, Fractional value)
void SetConstraintBounds(RowIndex row, Fractional lower_bound, Fractional upper_bound)
ColIndex CreateNewVariable()
void SetVariableType(ColIndex col, VariableType type)
void SetObjectiveCoefficient(ColIndex col, Fractional value)
RowIndex CreateNewConstraint()
void SetMaximizationProblem(bool maximize)
void assign(IntType size, const T &v)
ModelSharedTimeLimit * time_limit
A C++ wrapper that provides a simple and unified interface to several linear programming and mixed in...
@ FEASIBLE_SOLUTION_FOUND
Collection of objects used to extend the Constraint Solver library.
MPSolverInterface * BuildBopInterface(MPSolver *const solver)