C++ Reference

C++ Reference: Routing

Detailed Description

Definition at line 1915 of file constraint_solveri.h.

Public Member Functions

 LocalSearchMonitor (Solver *const solver)
 
 ~LocalSearchMonitor () override
 
std::string DebugString () const override
 
virtual void BeginOperatorStart ()=0
 Local search operator events. More...
 
virtual void EndOperatorStart ()=0
 
virtual void BeginMakeNextNeighbor (const LocalSearchOperator *op)=0
 
virtual void EndMakeNextNeighbor (const LocalSearchOperator *op, bool neighbor_found, const Assignment *delta, const Assignment *deltadelta)=0
 
virtual void BeginFilterNeighbor (const LocalSearchOperator *op)=0
 
virtual void EndFilterNeighbor (const LocalSearchOperator *op, bool neighbor_found)=0
 
virtual void BeginAcceptNeighbor (const LocalSearchOperator *op)=0
 
virtual void EndAcceptNeighbor (const LocalSearchOperator *op, bool neighbor_found)=0
 
virtual void BeginFiltering (const LocalSearchFilter *filter)=0
 
virtual void EndFiltering (const LocalSearchFilter *filter, bool reject)=0
 
void Install () override
 Install itself on the solver. More...
 
virtual void EnterSearch ()
 Beginning of the search. More...
 
virtual void RestartSearch ()
 Restart the search. More...
 
virtual void ExitSearch ()
 End of the search. More...
 
virtual void BeginNextDecision (DecisionBuilder *const b)
 Before calling DecisionBuilder::Next. More...
 
virtual void EndNextDecision (DecisionBuilder *const b, Decision *const d)
 After calling DecisionBuilder::Next, along with the returned decision. More...
 
virtual void ApplyDecision (Decision *const d)
 Before applying the decision. More...
 
virtual void RefuteDecision (Decision *const d)
 Before refuting the decision. More...
 
virtual void AfterDecision (Decision *const d, bool apply)
 Just after refuting or applying the decision, apply is true after Apply. More...
 
virtual void BeginFail ()
 Just when the failure occurs. More...
 
virtual void EndFail ()
 After completing the backtrack. More...
 
virtual void BeginInitialPropagation ()
 Before the initial propagation. More...
 
virtual void EndInitialPropagation ()
 After the initial propagation. More...
 
virtual bool AcceptSolution ()
 This method is called when a solution is found. More...
 
virtual bool AtSolution ()
 This method is called when a valid solution is found. More...
 
virtual void NoMoreSolutions ()
 When the search tree is finished. More...
 
virtual bool LocalOptimum ()
 When a local optimum is reached. More...
 
virtual bool AcceptDelta (Assignment *delta, Assignment *deltadelta)
 
virtual void AcceptNeighbor ()
 After accepting a neighbor during local search. More...
 
virtual void AcceptUncheckedNeighbor ()
 After accepting an unchecked neighbor during local search. More...
 
virtual bool IsUncheckedSolutionLimitReached ()
 Returns true if the limit of solutions has been reached including unchecked solutions. More...
 
Solversolver () const
 
virtual void PeriodicCheck ()
 Periodic call to check limits in long running methods. More...
 
virtual int ProgressPercent ()
 Returns a percentage representing the propress of the search before reaching limits. More...
 
virtual void Accept (ModelVisitor *const visitor) const
 Accepts the given model visitor. More...
 

Static Public Attributes

static constexpr int kNoProgress = -1
 

Constructor & Destructor Documentation

◆ LocalSearchMonitor()

LocalSearchMonitor ( Solver *const  solver)
explicit

◆ ~LocalSearchMonitor()

~LocalSearchMonitor ( )
override

Member Function Documentation

◆ Accept()

virtual void Accept ( ModelVisitor *const  visitor) const
virtualinherited

Accepts the given model visitor.

Reimplemented in RegularLimit, and OptimizeVar.

◆ AcceptDelta()

virtual bool AcceptDelta ( Assignment delta,
Assignment deltadelta 
)
virtualinherited

Reimplemented in OptimizeVar.

◆ AcceptNeighbor()

virtual void AcceptNeighbor ( )
virtualinherited

After accepting a neighbor during local search.

◆ AcceptSolution()

virtual bool AcceptSolution ( )
virtualinherited

This method is called when a solution is found.

It asserts whether the solution is valid. A value of false indicates that the solution should be discarded.

Reimplemented in OptimizeVar.

◆ AcceptUncheckedNeighbor()

virtual void AcceptUncheckedNeighbor ( )
virtualinherited

After accepting an unchecked neighbor during local search.

Reimplemented in SearchLog.

◆ AfterDecision()

virtual void AfterDecision ( Decision *const  d,
bool  apply 
)
virtualinherited

Just after refuting or applying the decision, apply is true after Apply.

This is called only if the Apply() or Refute() methods have not failed.

◆ ApplyDecision()

virtual void ApplyDecision ( Decision *const  d)
virtualinherited

Before applying the decision.

Reimplemented in SearchLog.

◆ AtSolution()

virtual bool AtSolution ( )
virtualinherited

This method is called when a valid solution is found.

If the return value is true, then search will resume after. If the result is false, then search will stop there.

Reimplemented in SearchLog, ImprovementSearchLimit, and OptimizeVar.

◆ BeginAcceptNeighbor()

virtual void BeginAcceptNeighbor ( const LocalSearchOperator op)
pure virtual

◆ BeginFail()

virtual void BeginFail ( )
virtualinherited

Just when the failure occurs.

Reimplemented in SearchLog.

◆ BeginFiltering()

virtual void BeginFiltering ( const LocalSearchFilter filter)
pure virtual

◆ BeginFilterNeighbor()

virtual void BeginFilterNeighbor ( const LocalSearchOperator op)
pure virtual

◆ BeginInitialPropagation()

virtual void BeginInitialPropagation ( )
virtualinherited

Before the initial propagation.

Reimplemented in SearchLog.

◆ BeginMakeNextNeighbor()

virtual void BeginMakeNextNeighbor ( const LocalSearchOperator op)
pure virtual

◆ BeginNextDecision()

virtual void BeginNextDecision ( DecisionBuilder *const  b)
virtualinherited

Before calling DecisionBuilder::Next.

Reimplemented in OptimizeVar, and SearchLimit.

◆ BeginOperatorStart()

virtual void BeginOperatorStart ( )
pure virtual

Local search operator events.

◆ DebugString()

std::string DebugString ( ) const
inlineoverridevirtual

Reimplemented from BaseObject.

Definition at line 1920 of file constraint_solveri.h.

◆ EndAcceptNeighbor()

virtual void EndAcceptNeighbor ( const LocalSearchOperator op,
bool  neighbor_found 
)
pure virtual

◆ EndFail()

virtual void EndFail ( )
virtualinherited

After completing the backtrack.

◆ EndFiltering()

virtual void EndFiltering ( const LocalSearchFilter filter,
bool  reject 
)
pure virtual

◆ EndFilterNeighbor()

virtual void EndFilterNeighbor ( const LocalSearchOperator op,
bool  neighbor_found 
)
pure virtual

◆ EndInitialPropagation()

virtual void EndInitialPropagation ( )
virtualinherited

After the initial propagation.

Reimplemented in SearchLog.

◆ EndMakeNextNeighbor()

virtual void EndMakeNextNeighbor ( const LocalSearchOperator op,
bool  neighbor_found,
const Assignment delta,
const Assignment deltadelta 
)
pure virtual

◆ EndNextDecision()

virtual void EndNextDecision ( DecisionBuilder *const  b,
Decision *const  d 
)
virtualinherited

After calling DecisionBuilder::Next, along with the returned decision.

◆ EndOperatorStart()

virtual void EndOperatorStart ( )
pure virtual

◆ EnterSearch()

virtual void EnterSearch ( )
virtualinherited

Beginning of the search.

Reimplemented in SearchLog, SearchLimit, OptimizeVar, and SolutionCollector.

◆ ExitSearch()

virtual void ExitSearch ( )
virtualinherited

End of the search.

Reimplemented in SearchLog, and RegularLimit.

◆ Install()

void Install ( )
overridevirtual

Install itself on the solver.

Reimplemented from SearchMonitor.

◆ IsUncheckedSolutionLimitReached()

virtual bool IsUncheckedSolutionLimitReached ( )
inlinevirtualinherited

Returns true if the limit of solutions has been reached including unchecked solutions.

Reimplemented in RegularLimit.

Definition at line 3706 of file constraint_solver.h.

◆ LocalOptimum()

virtual bool LocalOptimum ( )
virtualinherited

When a local optimum is reached.

If 'true' is returned, the last solution is discarded and the search proceeds with the next one.

◆ NoMoreSolutions()

virtual void NoMoreSolutions ( )
virtualinherited

When the search tree is finished.

Reimplemented in SearchLog.

◆ PeriodicCheck()

virtual void PeriodicCheck ( )
virtualinherited

Periodic call to check limits in long running methods.

Reimplemented in SearchLimit.

◆ ProgressPercent()

virtual int ProgressPercent ( )
inlinevirtualinherited

Returns a percentage representing the propress of the search before reaching limits.

Reimplemented in RegularLimit.

Definition at line 3715 of file constraint_solver.h.

◆ RefuteDecision()

virtual void RefuteDecision ( Decision *const  d)
virtualinherited

Before refuting the decision.

Reimplemented in SearchLog, SearchLimit, and OptimizeVar.

◆ RestartSearch()

virtual void RestartSearch ( )
virtualinherited

Restart the search.

◆ solver()

Solver* solver ( ) const
inlineinherited

Definition at line 3708 of file constraint_solver.h.

Member Data Documentation

◆ kNoProgress

constexpr int kNoProgress = -1
staticconstexprinherited

Definition at line 3637 of file constraint_solver.h.


The documentation for this class was generated from the following file: