14 #ifndef OR_TOOLS_SAT_PRESOLVE_CONTEXT_H_ 15 #define OR_TOOLS_SAT_PRESOLVE_CONTEXT_H_ 22 #include "absl/base/attributes.h" 102 int64_t
MinOf(
int ref)
const;
103 int64_t
MaxOf(
int ref)
const;
112 int64_t
SizeMin(
int ct_ref)
const;
113 int64_t
SizeMax(
int ct_ref)
const;
114 int64_t
EndMin(
int ct_ref)
const;
115 int64_t
EndMax(
int ct_ref)
const;
146 return domains[
var].IsIncludedIn(domain);
178 int ref,
const Domain& domain,
bool* domain_modified =
nullptr);
189 bool* domain_modified =
nullptr);
194 const std::string&
message =
"") {
266 bool debug_no_recursion =
false);
413 int var_in_equality, int64_t coeff_in_equality,
415 std::vector<int>* new_vars_in_objective =
nullptr);
420 return objective_map_;
423 return objective_domain_is_constraining_;
439 return constraint_to_vars_[c];
443 return var_to_constraints_[
var];
447 return interval_usage_[c];
481 int active_i,
int active_j);
483 std::tuple<int, int64_t, int, int64_t, int64_t, int, int>
541 bool AddRelation(
int x,
int y, int64_t c, int64_t o,
AffineRelation* repo);
543 void AddVariableUsage(
int c);
548 bool VariableIsNotRepresentativeOfEquivalenceClass(
int var)
const;
554 bool CanonicalizeEncoding(
int* ref, int64_t*
value);
568 void InsertVarValueEncodingInternal(
int literal,
int var, int64_t
value,
569 bool add_constraints);
577 bool is_unsat_ =
false;
580 std::vector<Domain> domains;
586 absl::flat_hash_map<int, int64_t> objective_map_;
587 int64_t objective_overflow_detection_;
588 std::vector<std::pair<int, int64_t>> tmp_entries_;
589 bool objective_domain_is_constraining_ =
false;
591 double objective_offset_;
592 double objective_scaling_factor_;
593 int64_t objective_integer_offset_;
594 int64_t objective_integer_scaling_factor_;
597 std::vector<std::vector<int>> constraint_to_vars_;
598 std::vector<absl::flat_hash_set<int>> var_to_constraints_;
601 std::vector<int> constraint_to_linear1_var_;
602 std::vector<int> var_to_num_linear1_;
605 std::vector<std::vector<int>> constraint_to_intervals_;
606 std::vector<int> interval_usage_;
609 absl::flat_hash_map<int, SavedVariable> abs_relations_;
615 absl::flat_hash_map<int64_t, SavedVariable> constant_to_ref_;
619 absl::flat_hash_map<int, absl::flat_hash_map<int64_t, SavedLiteral>>
626 absl::flat_hash_map<int,
627 absl::flat_hash_map<int64_t, absl::flat_hash_set<int>>>
629 absl::flat_hash_map<int,
630 absl::flat_hash_map<int64_t, absl::flat_hash_set<int>>>
641 std::vector<int> tmp_new_usage_;
644 absl::flat_hash_set<int> removed_variables_;
649 absl::flat_hash_map<std::tuple<int, int64_t, int, int64_t, int64_t, int, int>,
651 reified_precedences_cache_;
654 absl::flat_hash_map<std::string, int> stats_by_rule_name_;
656 bool model_is_expanded_ =
false;
666 #endif // OR_TOOLS_SAT_PRESOLVE_CONTEXT_H_ bool CanonicalizeAffineVariable(int ref, int64_t coeff, int64_t mod, int64_t rhs)
int32_t assumptions(int index) const
int Get(PresolveContext *context) const
int64_t MinOf(int ref) const
A simple class to enforce both an elapsed time limit and a deterministic time limit in the same threa...
std::vector< int > tmp_literals
void InitializeNewDomains()
bool VariableIsUniqueAndRemovable(int ref) const
bool StoreBooleanEqualityRelation(int ref_a, int ref_b)
bool ModelIsUnsat() const
void NotifyThatModelIsExpanded()
void ReadObjectiveFromProto()
#define SOLVER_LOG(logger,...)
ModelRandomGenerator * random()
void RemoveVariableFromAffineRelation(int var)
bool ConstraintVariableGraphIsUpToDate() const
bool ConstraintVariableUsageIsConsistent()
SparseBitset< int64_t > modified_domains
void UpdateRuleStats(const std::string &name, int num_times=1)
Class that owns everything related to a particular optimization model.
void AddToObjective(int var, int64_t value)
bool StoreLiteralImpliesVarNEqValue(int literal, int var, int64_t value)
const absl::flat_hash_set< int > & VarToConstraints(int var) const
bool ConstraintIsOptional(int ct_ref) const
int GetOrCreateConstantVar(int64_t cst)
void CanonicalizeDomainOfSizeTwo(int var)
int64_t StartMin(int ct_ref) const
constexpr int kAssumptionsConstraint
bool ConstraintIsInactive(int ct_index) const
bool GetAbsRelation(int target_ref, int *ref)
const Domain & ObjectiveDomain() const
std::string RefDebugString(int ref) const
constexpr int kAffineRelationConstraint
bool VariableIsNotUsedAnymore(int ref) const
bool keep_all_feasible_solutions
std::string AffineRelationDebugString(int ref) const
bool StoreAbsRelation(int target_ref, int ref)
int64_t FixedValue(int ref) const
void WriteVariableDomainsToProto() const
int LiteralForExpressionMax(const LinearExpressionProto &expr) const
int64_t EndMin(int ct_ref) const
const std::vector< int > & ConstraintToVars(int c) const
bool ExpressionIsAffineBoolean(const LinearExpressionProto &expr) const
CpModelProto * mapping_model
bool StoreAffineRelation(int ref_x, int ref_y, int64_t coeff, int64_t offset, bool debug_no_recursion=false)
bool VariableIsOnlyUsedInEncodingAndMaybeInObjective(int ref) const
int64_t num_presolve_operations
void UpdateConstraintVariableUsage(int c)
CpModelProto * working_model
bool ObjectiveDomainIsConstraining() const
void ExploitFixedDomain(int var)
bool CanBeUsedAsLiteral(int ref) const
int IntervalUsage(int c) const
ABSL_MUST_USE_RESULT bool SetLiteralToFalse(int lit)
Domain DomainOf(int ref) const
int NewIntVar(const Domain &domain)
const SatParameters & params() const
bool LoadModelForProbing(PresolveContext *context, Model *local_model)
bool HasVarValueEncoding(int ref, int64_t value, int *literal=nullptr)
bool VariableIsRemovable(int ref) const
int64_t EndMax(int ct_ref) const
bool ExpressionIsSingleVariable(const LinearExpressionProto &expr) const
int64_t SizeMax(int ct_ref) const
bool VariableWasRemoved(int ref) const
void ClearPrecedenceCache()
int64_t MaxOf(int ref) const
void RegisterVariablesUsedInAssumptions()
void WriteObjectiveToProto() const
std::tuple< int, int64_t, int, int64_t, int64_t, int, int > GetReifiedPrecedenceKey(const LinearExpressionProto &time_i, const LinearExpressionProto &time_j, int active_i, int active_j)
bool PropagateAffineRelation(int ref)
void AddToObjectiveOffset(int64_t value)
ABSL_MUST_USE_RESULT bool ScaleFloatingPointObjective()
void MarkVariableAsRemoved(int ref)
std::vector< absl::flat_hash_set< int > > var_to_ub_only_constraints
bool DomainIsEmpty(int ref) const
ABSL_MUST_USE_RESULT bool IntersectDomainWith(int ref, const Domain &domain, bool *domain_modified=nullptr)
absl::flat_hash_set< int > tmp_literal_set
bool VariableWithCostIsUniqueAndRemovable(int ref) const
ABSL_MUST_USE_RESULT bool NotifyThatModelIsUnsat(const std::string &message="")
ABSL_MUST_USE_RESULT bool SubstituteVariableInObjective(int var_in_equality, int64_t coeff_in_equality, const ConstraintProto &equality, std::vector< int > *new_vars_in_objective=nullptr)
bool ModelIsExpanded() const
SolverLogger * logger() const
bool DomainContains(int ref, int64_t value) const
#define DCHECK(condition)
bool LiteralIsTrue(int lit) const
We call domain any subset of Int64 = [kint64min, kint64max].
int Get(PresolveContext *context) const
void AddImplication(int a, int b)
void UpdateNewConstraintsVariableUsage()
int64_t StartMax(int ct_ref) const
bool VariableWithCostIsUnique(int ref) const
Domain DomainSuperSetOf(const LinearExpressionProto &expr) const
bool IsFullyEncoded(int ref) const
DomainDeductions deductions
std::vector< absl::flat_hash_set< int > > var_to_lb_only_constraints
bool InsertVarValueEncoding(int literal, int ref, int64_t value)
bool DomainOfVarIsIncludedIn(int var, const Domain &domain)
std::vector< Domain > tmp_term_domains
void CanonicalizeVariable(int ref)
void AddImplyInDomain(int b, int x, const Domain &domain)
bool ExpressionIsALiteral(const LinearExpressionProto &expr, int *literal=nullptr) const
int GetVariableRepresentative(int ref) const
bool StoreLiteralImpliesVarEqValue(int literal, int var, int64_t value)
Collection of objects used to extend the Constraint Solver library.
bool IsFixed(int ref) const
int64_t SizeMin(int ct_ref) const
bool ExploitExactlyOneInObjective(absl::Span< const int > exactly_one)
bool IntervalIsConstant(int ct_ref) const
ABSL_MUST_USE_RESULT bool CanonicalizeObjective(bool simplify_domain=true)
const absl::flat_hash_map< int, int64_t > & ObjectiveMap() const
void RemoveAllVariablesFromAffineRelationConstraint()
std::vector< Domain > tmp_left_domains
std::string IntervalDebugString(int ct_ref) const
constexpr int kObjectiveConstraint
bool LiteralIsFalse(int lit) const
ABSL_MUST_USE_RESULT bool SetLiteralToTrue(int lit)
int GetOrCreateVarValueEncoding(int ref, int64_t value)
void RemoveVariableFromObjective(int var)
int NumEquivRelations() const
GurobiMPCallbackContext * context
int NumAffineRelations() const
int GetOrCreateAffineValueEncoding(const LinearExpressionProto &expr, int64_t value)
PresolveContext(Model *model, CpModelProto *cp_model, CpModelProto *mapping)
AffineRelation::Relation GetAffineRelation(int ref) const
int GetLiteralRepresentative(int ref) const
int GetOrCreateReifiedPrecedenceLiteral(const LinearExpressionProto &time_i, const LinearExpressionProto &time_j, int active_i, int active_j)