14 #ifndef OR_TOOLS_SAT_PRESOLVE_CONTEXT_H_
15 #define OR_TOOLS_SAT_PRESOLVE_CONTEXT_H_
73 CpModelProto* mapping)
77 params_(*
model->GetOrCreate<SatParameters>()),
98 int64_t
MinOf(
int ref)
const;
99 int64_t
MaxOf(
int ref)
const;
106 int64_t
MinOf(
const LinearExpressionProto& expr)
const;
107 int64_t
MaxOf(
const LinearExpressionProto& expr)
const;
111 return domains[
var].IsIncludedIn(domain);
138 int ref,
const Domain& domain,
bool* domain_modified =
nullptr);
147 const std::string&
message =
"") {
302 int var_in_equality, int64_t coeff_in_equality,
303 const ConstraintProto& equality,
304 std::vector<int>* new_vars_in_objective =
nullptr);
309 return objective_map_;
312 return objective_domain_is_constraining_;
328 return constraint_to_vars_[c];
332 return var_to_constraints_[
var];
336 return interval_usage_[c];
361 const SatParameters&
params()
const {
return params_; }
410 bool AddRelation(
int x,
int y, int64_t c, int64_t o,
AffineRelation* repo);
412 void AddVariableUsage(
int c);
413 void UpdateLinear1Usage(
const ConstraintProto&
ct,
int c);
417 bool VariableIsNotRepresentativeOfEquivalenceClass(
int var)
const;
421 bool RemapEncodingMaps();
427 bool CanonicalizeEncoding(
int* ref, int64_t*
value);
441 void InsertVarValueEncodingInternal(
int literal,
int var, int64_t
value,
442 bool add_constraints);
445 const SatParameters& params_;
450 bool is_unsat =
false;
453 std::vector<Domain> domains;
459 absl::flat_hash_map<int, int64_t> objective_map_;
460 int64_t objective_overflow_detection_;
461 std::vector<std::pair<int, int64_t>> tmp_entries_;
462 bool objective_domain_is_constraining_ =
false;
464 double objective_offset_;
465 double objective_scaling_factor_;
468 std::vector<std::vector<int>> constraint_to_vars_;
469 std::vector<absl::flat_hash_set<int>> var_to_constraints_;
472 std::vector<int> constraint_to_linear1_var_;
473 std::vector<int> var_to_num_linear1_;
476 std::vector<std::vector<int>> constraint_to_intervals_;
477 std::vector<int> interval_usage_;
480 absl::flat_hash_map<int, SavedVariable> abs_relations_;
486 absl::flat_hash_map<int64_t, SavedVariable> constant_to_ref_;
490 std::deque<int> encoding_remap_queue_;
494 absl::flat_hash_map<int, absl::flat_hash_map<int64_t, SavedLiteral>>
501 absl::flat_hash_map<int,
502 absl::flat_hash_map<int64_t, absl::flat_hash_set<int>>>
504 absl::flat_hash_map<int,
505 absl::flat_hash_map<int64_t, absl::flat_hash_set<int>>>
516 std::vector<int> tmp_new_usage_;
519 absl::flat_hash_set<int> removed_variables_;
524 absl::flat_hash_map<std::tuple<int, int, int, int>,
int>
525 reified_precedences_cache_;
#define DCHECK(condition)
#define VLOG(verboselevel)
We call domain any subset of Int64 = [kint64min, kint64max].
A simple class to enforce both an elapsed time limit and a deterministic time limit in the same threa...
Class that owns everything related to a particular optimization model.
int64_t MaxOf(int ref) const
SparseBitset< int64_t > modified_domains
bool StoreAbsRelation(int target_ref, int ref)
bool ConstraintVariableUsageIsConsistent()
PresolveContext(Model *model, CpModelProto *cp_model, CpModelProto *mapping)
void AddImplication(int a, int b)
void InsertVarValueEncoding(int literal, int ref, int64_t value)
bool ModelIsUnsat() const
bool VariableIsOnlyUsedInEncoding(int ref) const
ABSL_MUST_USE_RESULT bool IntersectDomainWith(int ref, const Domain &domain, bool *domain_modified=nullptr)
std::vector< absl::flat_hash_set< int > > var_to_lb_only_constraints
bool ConstraintVariableGraphIsUpToDate() const
bool StoreLiteralImpliesVarNEqValue(int literal, int var, int64_t value)
const Domain & ObjectiveDomain() const
SolverLogger * logger() const
bool DomainOfVarIsIncludedIn(int var, const Domain &domain)
bool VariableWithCostIsUniqueAndRemovable(int ref) const
void WriteObjectiveToProto() const
int GetLiteralRepresentative(int ref) const
ABSL_MUST_USE_RESULT bool SetLiteralToTrue(int lit)
bool StoreAffineRelation(int ref_x, int ref_y, int64_t coeff, int64_t offset)
std::vector< int > tmp_literals
std::vector< absl::flat_hash_set< int > > var_to_ub_only_constraints
bool ObjectiveDomainIsConstraining() const
CpModelProto * mapping_model
bool SubstituteVariableInObjective(int var_in_equality, int64_t coeff_in_equality, const ConstraintProto &equality, std::vector< int > *new_vars_in_objective=nullptr)
const std::vector< int > & ConstraintToVars(int c) const
int GetOrCreateVarValueEncoding(int ref, int64_t value)
void UpdateNewConstraintsVariableUsage()
bool VariableIsUniqueAndRemovable(int ref) const
void RemoveVariableFromAffineRelation(int var)
ABSL_MUST_USE_RESULT bool NotifyThatModelIsUnsat(const std::string &message="")
bool PropagateAffineRelation(int ref)
Domain DomainOf(int ref) const
int64_t num_presolve_operations
void InitializeNewDomains()
int GetVariableRepresentative(int ref) const
std::string AffineRelationDebugString(int ref) const
const absl::flat_hash_map< int, int64_t > & ObjectiveMap() const
int NewIntVar(const Domain &domain)
void MarkVariableAsRemoved(int ref)
DomainDeductions deductions
std::vector< Domain > tmp_left_domains
bool DomainIsEmpty(int ref) const
void CanonicalizeDomainOfSizeTwo(int var)
bool LiteralIsTrue(int lit) const
absl::flat_hash_map< std::string, int > stats_by_rule_name
void StoreBooleanEqualityRelation(int ref_a, int ref_b)
int IntervalUsage(int c) const
CpModelProto * working_model
bool HasVarValueEncoding(int ref, int64_t value, int *literal=nullptr)
bool DomainContains(int ref, int64_t value) const
bool LiteralIsFalse(int lit) const
void UpdateRuleStats(const std::string &name, int num_times=1)
ABSL_MUST_USE_RESULT bool CanonicalizeObjective()
const SatParameters & params() const
void RemoveAllVariablesFromAffineRelationConstraint()
AffineRelation::Relation GetAffineRelation(int ref) const
bool VariableIsNotUsedAnymore(int ref) const
void UpdateConstraintVariableUsage(int c)
bool keep_all_feasible_solutions
bool IsFixed(int ref) const
int NumAffineRelations() const
std::vector< Domain > tmp_term_domains
int NumEquivRelations() const
const absl::flat_hash_set< int > & VarToConstraints(int var) const
ModelRandomGenerator * random()
ABSL_MUST_USE_RESULT bool SetLiteralToFalse(int lit)
std::string RefDebugString(int ref) const
int GetOrCreateConstantVar(int64_t cst)
int GetOrCreateReifiedPrecedenceLiteral(int time_i, int time_j, int active_i, int active_j)
void ClearPrecedenceCache()
absl::flat_hash_set< int > tmp_literal_set
void ReadObjectiveFromProto()
void AddImplyInDomain(int b, int x, const Domain &domain)
bool CanBeUsedAsLiteral(int ref) const
bool VariableWasRemoved(int ref) const
void RegisterVariablesUsedInAssumptions()
void ExploitFixedDomain(int var)
int64_t MinOf(int ref) const
bool GetAbsRelation(int target_ref, int *ref)
bool StoreLiteralImpliesVarEqValue(int literal, int var, int64_t value)
int Get(PresolveContext *context) const
int Get(PresolveContext *context) const
GurobiMPCallbackContext * context
constexpr int kAffineRelationConstraint
constexpr int kAssumptionsConstraint
constexpr int kObjectiveConstraint
Collection of objects used to extend the Constraint Solver library.