Class DefaultSubChainSelector<Solution_>
java.lang.Object
org.optaplanner.core.impl.heuristic.selector.AbstractSelector<Solution_>
org.optaplanner.core.impl.heuristic.selector.value.chained.DefaultSubChainSelector<Solution_>
- All Implemented Interfaces:
Iterable<SubChain>
,EventListener
,ListIterable<SubChain>
,SelectionCacheLifecycleListener<Solution_>
,IterableSelector<Solution_,
,SubChain> ListIterableSelector<Solution_,
,SubChain> Selector<Solution_>
,SubChainSelector<Solution_>
,PhaseLifecycleListener<Solution_>
,SolverLifecycleListener<Solution_>
public class DefaultSubChainSelector<Solution_>
extends AbstractSelector<Solution_>
implements SubChainSelector<Solution_>, SelectionCacheLifecycleListener<Solution_>
This is the common
SubChainSelector
implementation.-
Field Summary
Modifier and TypeFieldDescriptionprotected static final SelectionCacheType
protected SingletonInverseVariableSupply
protected final int
protected final int
protected final boolean
protected final EntityIndependentValueSelector<Solution_>
Fields inherited from class org.optaplanner.core.impl.heuristic.selector.AbstractSelector
logger, phaseLifecycleSupport, workingRandom
-
Constructor Summary
ConstructorDescriptionDefaultSubChainSelector
(EntityIndependentValueSelector<Solution_> valueSelector, boolean randomSelection, int minimumSubChainSize, int maximumSubChainSize) -
Method Summary
Modifier and TypeMethodDescriptionprotected long
calculateSubChainSelectionSize
(SubChain anchorTrailingChain) void
constructCache
(SolverScope<Solution_> solverScope) void
disposeCache
(SolverScope<Solution_> solverScope) Unless this selector itself caches, this returnsSelectionCacheType.JUST_IN_TIME
, even if a selector child caches.long
getSize()
A random JITSelector
withSelector.isNeverEnding()
true should return a size as if it would be able to return each distinct element only once, because the size can be used inSelectionProbabilityWeightFactory
.boolean
If false, thenSelector.isNeverEnding()
is true.boolean
Is true ifSelector.isCountable()
is false or if this selector is in random order (for most cases).iterator()
listIterator
(int index) void
solvingEnded
(SolverScope<Solution_> solverScope) void
solvingStarted
(SolverScope<Solution_> solverScope) toString()
Methods inherited from class org.optaplanner.core.impl.heuristic.selector.AbstractSelector
phaseEnded, phaseStarted, stepEnded, stepStarted
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.optaplanner.core.impl.heuristic.selector.IterableSelector
spliterator
Methods inherited from interface org.optaplanner.core.impl.phase.event.PhaseLifecycleListener
phaseEnded, phaseStarted, stepEnded, stepStarted
Methods inherited from interface org.optaplanner.core.impl.solver.event.SolverLifecycleListener
solvingError
-
Field Details
-
CACHE_TYPE
-
valueSelector
-
randomSelection
protected final boolean randomSelection -
inverseVariableSupply
-
minimumSubChainSize
protected final int minimumSubChainSize -
maximumSubChainSize
protected final int maximumSubChainSize -
anchorTrailingChainList
-
-
Constructor Details
-
DefaultSubChainSelector
public DefaultSubChainSelector(EntityIndependentValueSelector<Solution_> valueSelector, boolean randomSelection, int minimumSubChainSize, int maximumSubChainSize)
-
-
Method Details
-
getVariableDescriptor
- Specified by:
getVariableDescriptor
in interfaceSubChainSelector<Solution_>
- Returns:
- never null
-
getCacheType
Description copied from interface:Selector
Unless this selector itself caches, this returnsSelectionCacheType.JUST_IN_TIME
, even if a selector child caches.- Specified by:
getCacheType
in interfaceSelector<Solution_>
- Overrides:
getCacheType
in classAbstractSelector<Solution_>
- Returns:
- never null
-
solvingStarted
- Specified by:
solvingStarted
in interfaceSolverLifecycleListener<Solution_>
- Overrides:
solvingStarted
in classAbstractSelector<Solution_>
-
solvingEnded
- Specified by:
solvingEnded
in interfaceSolverLifecycleListener<Solution_>
- Overrides:
solvingEnded
in classAbstractSelector<Solution_>
-
constructCache
- Specified by:
constructCache
in interfaceSelectionCacheLifecycleListener<Solution_>
-
disposeCache
- Specified by:
disposeCache
in interfaceSelectionCacheLifecycleListener<Solution_>
-
isCountable
public boolean isCountable()Description copied from interface:Selector
If false, thenSelector.isNeverEnding()
is true.- Specified by:
isCountable
in interfaceSelector<Solution_>
- Returns:
- true if all the
ValueRange
s are countable (for example a double value range between 1.2 and 1.4 is not countable)
-
isNeverEnding
public boolean isNeverEnding()Description copied from interface:Selector
Is true ifSelector.isCountable()
is false or if this selector is in random order (for most cases). Is never true when this selector is in shuffled order (which is less scalable but more exact).- Specified by:
isNeverEnding
in interfaceSelector<Solution_>
- Returns:
- true if the
Iterator.hasNext()
of theIterator
created byIterable.iterator()
never returns false (except when it's empty).
-
getSize
public long getSize()Description copied from interface:IterableSelector
A random JITSelector
withSelector.isNeverEnding()
true should return a size as if it would be able to return each distinct element only once, because the size can be used inSelectionProbabilityWeightFactory
.- Specified by:
getSize
in interfaceIterableSelector<Solution_,
SubChain> - Returns:
- the approximate number of elements generated by this
Selector
, always>= 0
-
calculateSubChainSelectionSize
-
iterator
-
listIterator
- Specified by:
listIterator
in interfaceListIterable<Solution_>
- Returns:
- never null, see
List.listIterator()
. - See Also:
-
listIterator
- Specified by:
listIterator
in interfaceListIterable<Solution_>
- Parameters:
index
- lower than the size of thisListIterable
, seeList.listIterator(int)
.- Returns:
- never null, see
List.listIterator(int)
. - See Also:
-
toString
-