27 #ifndef OR_TOOLS_BOP_BOP_LS_H_
28 #define OR_TOOLS_BOP_BOP_LS_H_
32 #include "absl/container/flat_hash_map.h"
33 #include "absl/container/flat_hash_set.h"
34 #include "absl/random/random.h"
81 std::vector<sat::Literal>* propagated_literals);
103 class LocalSearchAssignmentIterator;
122 bool ShouldBeRun(
const ProblemState& problem_state)
const override;
127 int64 state_update_stamp_;
132 const int max_num_decisions_;
141 std::unique_ptr<LocalSearchAssignmentIterator> assignment_iterator_;
156 template <
typename IntType>
169 void ChangeState(IntType i,
bool should_be_inside);
173 int size()
const {
return size_; }
176 const std::vector<IntType>&
Superset()
const {
return stack_; }
189 std::vector<IntType> stack_;
190 std::vector<bool> in_stack_;
194 std::vector<int> saved_sizes_;
195 std::vector<int> saved_stack_sizes_;
200 template <
typename IntType>
208 for (IntType i(0); i < size; ++i) {
209 hashes_[i] = random_.
Rand64();
222 for (
const IntType i : set)
hash ^= hashes_[i];
268 const sat::LinearBooleanProblem& problem);
288 void Assign(
const std::vector<sat::Literal>& literals);
318 return infeasible_constraint_set_.
size();
323 return infeasible_constraint_set_.
Superset();
341 return constraint_lower_bounds_[constraint];
346 return constraint_upper_bounds_[constraint];
353 return constraint_values_[constraint];
367 void InitializeConstraintSetHasher();
374 DEFINE_INT_TYPE(ConstraintIndexWithDirection,
int32);
375 ConstraintIndexWithDirection FromConstraintIndex(ConstraintIndex
index,
377 return ConstraintIndexWithDirection(2 *
index.value() + (up ? 1 : 0));
382 void MakeObjectiveConstraintInfeasible(
int delta);
386 struct ConstraintEntry {
387 ConstraintEntry(ConstraintIndex c,
int64 w) : constraint(c),
weight(w) {}
388 ConstraintIndex constraint;
398 BopSolution assignment_;
399 BopSolution reference_;
402 BacktrackableIntegerSet<ConstraintIndex> infeasible_constraint_set_;
407 std::vector<int> flipped_var_trail_backtrack_levels_;
408 std::vector<VariableIndex> flipped_var_trail_;
411 std::vector<sat::Literal> tmp_potential_repairs_;
412 NonOrderedSetHasher<ConstraintIndexWithDirection> constraint_set_hasher_;
413 absl::flat_hash_map<uint64, std::vector<sat::Literal>>
414 hash_to_potential_repairs_;
440 const sat::LinearBooleanProblem& problem,
466 TermIndex init_term_index,
467 TermIndex start_term_index)
const;
471 bool RepairIsValid(ConstraintIndex ct_index, TermIndex term_index)
const;
488 void SortTermsOfEachConstraints(
int num_variables);
492 by_constraint_matrix_;
507 int max_num_decisions,
508 int max_num_broken_constraints,
515 use_potential_one_flip_repairs_ = v;
539 return better_solution_has_been_found_;
552 void UseCurrentStateAsReference();
555 static constexpr
size_t kStoredMaxDecisions = 4;
563 SearchNode(ConstraintIndex c, TermIndex t) : constraint(c), term_index(t) {}
564 ConstraintIndex constraint;
565 TermIndex term_index;
569 void ApplyDecision(sat::Literal
literal);
580 bool NewStateIsInTranspositionTable(sat::Literal l);
583 void InsertInTranspositionTable();
587 void InitializeTranspositionTableKey(
588 std::array<int32, kStoredMaxDecisions>*
a);
593 bool EnqueueNextRepairingTermIfAny(ConstraintIndex ct_to_repair,
596 const int max_num_decisions_;
597 const int max_num_broken_constraints_;
598 bool better_solution_has_been_found_;
599 AssignmentAndConstraintFeasibilityMaintainer maintainer_;
600 SatWrapper*
const sat_wrapper_;
601 OneFlipConstraintRepairer repairer_;
602 std::vector<SearchNode> search_nodes_;
606 std::vector<sat::Literal> tmp_propagated_literals_;
621 bool use_transposition_table_;
622 absl::flat_hash_set<std::array<int32, kStoredMaxDecisions>>
623 transposition_table_;
625 bool use_potential_one_flip_repairs_;
631 int64 num_skipped_nodes_;
635 int64 num_improvements_;
636 int64 num_improvements_by_one_flip_repairs_;
637 int64 num_inspected_one_flip_repairs_;
void resize(size_type new_size)
A simple class to enforce both an elapsed time limit and a deterministic time limit in the same threa...
AssignmentAndConstraintFeasibilityMaintainer(const sat::LinearBooleanProblem &problem)
const BopSolution & reference() const
int64 ConstraintLowerBound(ConstraintIndex constraint) const
const std::vector< ConstraintIndex > & PossiblyInfeasibleConstraints() const
void AddBacktrackingLevel()
void UseCurrentStateAsReference()
static const ConstraintIndex kObjectiveConstraint
int NumInfeasibleConstraints() const
std::string DebugString() const
void SetReferenceSolution(const BopSolution &reference_solution)
int64 ConstraintUpperBound(ConstraintIndex constraint) const
size_t NumConstraints() const
bool ConstraintIsFeasible(ConstraintIndex constraint) const
bool Assignment(VariableIndex var) const
int64 ConstraintValue(ConstraintIndex constraint) const
void Assign(const std::vector< sat::Literal > &literals)
const std::vector< sat::Literal > & PotentialOneFlipRepairs()
const std::vector< IntType > & Superset() const
void ClearAndResize(IntType n)
void AddBacktrackingLevel()
BacktrackableIntegerSet()
void ChangeState(IntType i, bool should_be_inside)
const std::string & name() const
bool Value(VariableIndex var) const
~LocalSearchAssignmentIterator()
void SynchronizeSatWrapper()
LocalSearchAssignmentIterator(const ProblemState &problem_state, int max_num_decisions, int max_num_broken_constraints, SatWrapper *sat_wrapper)
void UseTranspositionTable(bool v)
std::string DebugString() const
void UsePotentialOneFlipRepairs(bool v)
void Synchronize(const ProblemState &problem_state)
double deterministic_time() const
const BopSolution & LastReferenceAssignment() const
bool BetterSolutionHasBeenFound() const
LocalSearchOptimizer(const std::string &name, int max_num_decisions, sat::SatSolver *sat_propagator)
~LocalSearchOptimizer() override
uint64 Hash(IntType e) const
bool IsInitialized() const
void Initialize(int size)
void IgnoreElement(IntType e)
uint64 Hash(const std::vector< IntType > &set) const
sat::Literal GetFlip(ConstraintIndex ct_index, TermIndex term_index) const
static const TermIndex kInvalidTerm
ConstraintIndex ConstraintToRepair() const
bool RepairIsValid(ConstraintIndex ct_index, TermIndex term_index) const
TermIndex NextRepairingTerm(ConstraintIndex ct_index, TermIndex init_term_index, TermIndex start_term_index) const
static const TermIndex kInitTerm
OneFlipConstraintRepairer(const sat::LinearBooleanProblem &problem, const AssignmentAndConstraintFeasibilityMaintainer &maintainer, const sat::VariablesAssignment &sat_assignment)
static const ConstraintIndex kInvalidConstraint
const sat::VariablesAssignment & SatAssignment() const
SatWrapper(sat::SatSolver *sat_solver)
std::vector< sat::Literal > FullSatTrail() const
int ApplyDecision(sat::Literal decision_literal, std::vector< sat::Literal > *propagated_literals)
void ExtractLearnedInfo(LearnedInfo *info)
bool IsModelUnsat() const
double deterministic_time() const
const VariablesAssignment & Assignment() const
bool IsModelUnsat() const
SharedTimeLimit * time_limit
The vehicle routing library lets one model and solve generic vehicle routing problems ranging from th...
ConstraintTerm(VariableIndex v, int64 w)