Class PhaseToSolverTerminationBridge
- java.lang.Object
-
- org.optaplanner.core.impl.solver.event.SolverLifecycleListenerAdapter<Solution_>
-
- org.optaplanner.core.impl.phase.event.PhaseLifecycleListenerAdapter
-
- org.optaplanner.core.impl.solver.termination.AbstractTermination
-
- org.optaplanner.core.impl.solver.termination.PhaseToSolverTerminationBridge
-
- All Implemented Interfaces:
EventListener,PhaseLifecycleListener,SolverLifecycleListener,Termination
public class PhaseToSolverTerminationBridge extends AbstractTermination
-
-
Field Summary
-
Fields inherited from class org.optaplanner.core.impl.solver.termination.AbstractTermination
logger
-
-
Constructor Summary
Constructors Constructor Description PhaseToSolverTerminationBridge(Termination solverTermination)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description doublecalculatePhaseTimeGradient(AbstractPhaseScope phaseScope)doublecalculateSolverTimeGradient(DefaultSolverScope solverScope)A timeGradient is a relative estimate of how long the search will continue.TerminationcreateChildThreadTermination(DefaultSolverScope solverScope, ChildThreadType childThreadType)booleanisPhaseTerminated(AbstractPhaseScope phaseScope)Called by thePhaseafter every step and every move to determine if the search should stop.booleanisSolverTerminated(DefaultSolverScope solverScope)Called by theSolverafter every phase to determine if the search should stop.voidphaseEnded(AbstractPhaseScope phaseScope)voidphaseStarted(AbstractPhaseScope phaseScope)voidsolvingEnded(DefaultSolverScope solverScope)voidsolvingStarted(DefaultSolverScope solverScope)voidstepEnded(AbstractStepScope stepScope)voidstepStarted(AbstractStepScope stepScope)StringtoString()
-
-
-
Constructor Detail
-
PhaseToSolverTerminationBridge
public PhaseToSolverTerminationBridge(Termination solverTermination)
-
-
Method Detail
-
solvingStarted
public void solvingStarted(DefaultSolverScope solverScope)
- Specified by:
solvingStartedin interfaceSolverLifecycleListener- Overrides:
solvingStartedin classSolverLifecycleListenerAdapter
-
phaseStarted
public void phaseStarted(AbstractPhaseScope phaseScope)
- Specified by:
phaseStartedin interfacePhaseLifecycleListener- Overrides:
phaseStartedin classPhaseLifecycleListenerAdapter
-
stepStarted
public void stepStarted(AbstractStepScope stepScope)
- Specified by:
stepStartedin interfacePhaseLifecycleListener- Overrides:
stepStartedin classPhaseLifecycleListenerAdapter
-
stepEnded
public void stepEnded(AbstractStepScope stepScope)
- Specified by:
stepEndedin interfacePhaseLifecycleListener- Overrides:
stepEndedin classPhaseLifecycleListenerAdapter
-
phaseEnded
public void phaseEnded(AbstractPhaseScope phaseScope)
- Specified by:
phaseEndedin interfacePhaseLifecycleListener- Overrides:
phaseEndedin classPhaseLifecycleListenerAdapter
-
solvingEnded
public void solvingEnded(DefaultSolverScope solverScope)
- Specified by:
solvingEndedin interfaceSolverLifecycleListener- Overrides:
solvingEndedin classSolverLifecycleListenerAdapter
-
isSolverTerminated
public boolean isSolverTerminated(DefaultSolverScope solverScope)
Description copied from interface:TerminationCalled by theSolverafter every phase to determine if the search should stop.- Parameters:
solverScope- never null- Returns:
- true if the search should terminate.
-
isPhaseTerminated
public boolean isPhaseTerminated(AbstractPhaseScope phaseScope)
Description copied from interface:TerminationCalled by thePhaseafter every step and every move to determine if the search should stop.- Parameters:
phaseScope- never null- Returns:
- true if the search should terminate.
-
calculateSolverTimeGradient
public double calculateSolverTimeGradient(DefaultSolverScope solverScope)
Description copied from interface:TerminationA timeGradient is a relative estimate of how long the search will continue.Clients that use a timeGradient should cache it at the start of a single step because some implementations are not time-stable.
If a timeGradient can not be calculated, it should return -1.0. Several implementations (such a
SimulatedAnnealingAcceptor) require a correctly implemented timeGradient.A Termination's timeGradient can be requested after they are terminated, so implementations should be careful not to return a timeGradient above 1.0.
- Parameters:
solverScope- never null- Returns:
- timeGradient t for which
0.0 <= t <= 1.0 or -1.0when it is not supported. At the start of a solver t is 0.0 and at the end t would be 1.0.
-
calculatePhaseTimeGradient
public double calculatePhaseTimeGradient(AbstractPhaseScope phaseScope)
Description copied from interface:Termination- Parameters:
phaseScope- never null- Returns:
- timeGradient t for which
0.0 <= t <= 1.0 or -1.0when it is not supported. At the start of a phase t is 0.0 and at the end t would be 1.0.
-
createChildThreadTermination
public Termination createChildThreadTermination(DefaultSolverScope solverScope, ChildThreadType childThreadType)
Description copied from interface:Termination- Specified by:
createChildThreadTerminationin interfaceTermination- Overrides:
createChildThreadTerminationin classAbstractTermination- Parameters:
solverScope- never nullchildThreadType- never null- Returns:
- not null
-
-