16#ifndef OR_TOOLS_SAT_LP_UTILS_H_
17#define OR_TOOLS_SAT_LP_UTILS_H_
24#include "ortools/linear_solver/linear_solver.pb.h"
26#include "ortools/sat/boolean_problem.pb.h"
27#include "ortools/sat/cp_model.pb.h"
28#include "ortools/sat/sat_parameters.pb.h"
60 MPModelProto* mp_model);
65 MPModelProto* mp_model,
66 SolverLogger* logger);
72 const MPModelProto& mp_model,
73 SolverLogger* logger);
80 SolverLogger* logger);
90 SolverLogger* logger);
98 const MPModelProto& mp_model,
99 CpModelProto* cp_model,
100 SolverLogger* logger);
110 MPModelProto* output);
124 const std::vector<std::pair<int, double>>& objective,
125 double objective_offset,
bool maximize,
126 CpModelProto* cp_model, SolverLogger* logger);
138 const CpModelProto& model_proto_with_floating_point_objective,
139 const CpObjectiveProto& integer_objective,
140 const int64_t inner_integer_objective_lower_bound);
147 LinearBooleanProblem* problem);
151 glop::LinearProgram* lp);
bool ScaleAndSetObjective(const SatParameters ¶ms, const std::vector< std::pair< int, double > > &objective, double objective_offset, bool maximize, CpModelProto *cp_model, SolverLogger *logger)
bool ConvertCpModelProtoToMPModelProto(const CpModelProto &input, MPModelProto *output)
void ConvertBooleanProblemToLinearProgram(const LinearBooleanProblem &problem, glop::LinearProgram *lp)
bool ConvertBinaryMPModelProtoToBooleanProblem(const MPModelProto &mp_model, LinearBooleanProblem *problem)
void RemoveNearZeroTerms(const SatParameters ¶ms, MPModelProto *mp_model, SolverLogger *logger)
bool ConvertMPModelProtoToCpModelProto(const SatParameters ¶ms, const MPModelProto &mp_model, CpModelProto *cp_model, SolverLogger *logger)
bool MPModelProtoValidationBeforeConversion(const SatParameters ¶ms, const MPModelProto &mp_model, SolverLogger *logger)
bool MakeBoundsOfIntegerVariablesInteger(const SatParameters ¶ms, MPModelProto *mp_model, SolverLogger *logger)
double ComputeTrueObjectiveLowerBound(const CpModelProto &model_proto_with_floating_point_objective, const CpObjectiveProto &integer_objective, const int64_t inner_integer_objective_lower_bound)
std::vector< double > ScaleContinuousVariables(double scaling, double max_bound, MPModelProto *mp_model)
std::vector< double > DetectImpliedIntegers(MPModelProto *mp_model, SolverLogger *logger)
int FindRationalFactor(double x, int limit, double tolerance)
Collection of objects used to extend the Constraint Solver library.
static int input(yyscan_t yyscanner)