Class DefaultSubChainSelector
- java.lang.Object
-
- org.optaplanner.core.impl.heuristic.selector.AbstractSelector
-
- org.optaplanner.core.impl.heuristic.selector.value.chained.DefaultSubChainSelector
-
- All Implemented Interfaces:
Iterable<SubChain>,EventListener,ListIterable<SubChain>,SelectionCacheLifecycleListener,IterableSelector<SubChain>,ListIterableSelector<SubChain>,Selector,SubChainSelector,PhaseLifecycleListener,SolverLifecycleListener
public class DefaultSubChainSelector extends AbstractSelector implements SubChainSelector, SelectionCacheLifecycleListener
This is the commonSubChainSelectorimplementation.
-
-
Field Summary
Fields Modifier and Type Field Description protected List<SubChain>anchorTrailingChainListprotected static SelectionCacheTypeCACHE_TYPEprotected SingletonInverseVariableSupplyinverseVariableSupplyprotected intmaximumSubChainSizeprotected intminimumSubChainSizeUnlikeDefaultPillarSelector#minimumSubPillarSizeandDefaultPillarSelector#maximumSubPillarSize, the sub selection here is a sequence.protected booleanrandomSelectionprotected EntityIndependentValueSelectorvalueSelector-
Fields inherited from class org.optaplanner.core.impl.heuristic.selector.AbstractSelector
logger, phaseLifecycleSupport, workingRandom
-
-
Constructor Summary
Constructors Constructor Description DefaultSubChainSelector(EntityIndependentValueSelector valueSelector, boolean randomSelection, int minimumSubChainSize, int maximumSubChainSize)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description protected longcalculateSubChainSelectionSize(SubChain anchorTrailingChain)voidconstructCache(DefaultSolverScope solverScope)voiddisposeCache(DefaultSolverScope solverScope)SelectionCacheTypegetCacheType()Unless this selector itself caches, this returnsSelectionCacheType.JUST_IN_TIME, even if a selector child caches.longgetSize()A random JITSelectorwithSelector.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.GenuineVariableDescriptorgetVariableDescriptor()booleanisCountable()If false, thenSelector.isNeverEnding()is true.booleanisNeverEnding()Is true ifSelector.isCountable()is false or if this selector is in random order (for most cases).Iterator<SubChain>iterator()ListIterator<SubChain>listIterator()ListIterator<SubChain>listIterator(int index)voidsolvingEnded(DefaultSolverScope solverScope)voidsolvingStarted(DefaultSolverScope solverScope)StringtoString()-
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 java.lang.Iterable
forEach, spliterator
-
Methods inherited from interface org.optaplanner.core.impl.phase.event.PhaseLifecycleListener
phaseEnded, phaseStarted, stepEnded, stepStarted
-
-
-
-
Field Detail
-
CACHE_TYPE
protected static final SelectionCacheType CACHE_TYPE
-
valueSelector
protected final EntityIndependentValueSelector valueSelector
-
randomSelection
protected final boolean randomSelection
-
inverseVariableSupply
protected SingletonInverseVariableSupply inverseVariableSupply
-
minimumSubChainSize
protected final int minimumSubChainSize
UnlikeDefaultPillarSelector#minimumSubPillarSizeandDefaultPillarSelector#maximumSubPillarSize, the sub selection here is a sequence. For example from ABCDE, it can select BCD, but not ACD.
-
maximumSubChainSize
protected final int maximumSubChainSize
-
-
Constructor Detail
-
DefaultSubChainSelector
public DefaultSubChainSelector(EntityIndependentValueSelector valueSelector, boolean randomSelection, int minimumSubChainSize, int maximumSubChainSize)
-
-
Method Detail
-
getVariableDescriptor
public GenuineVariableDescriptor getVariableDescriptor()
- Specified by:
getVariableDescriptorin interfaceSubChainSelector- Returns:
- never null
-
getCacheType
public SelectionCacheType getCacheType()
Description copied from interface:SelectorUnless this selector itself caches, this returnsSelectionCacheType.JUST_IN_TIME, even if a selector child caches.- Specified by:
getCacheTypein interfaceSelector- Overrides:
getCacheTypein classAbstractSelector- Returns:
- never null
-
solvingStarted
public void solvingStarted(DefaultSolverScope solverScope)
- Specified by:
solvingStartedin interfaceSolverLifecycleListener- Overrides:
solvingStartedin classAbstractSelector
-
solvingEnded
public void solvingEnded(DefaultSolverScope solverScope)
- Specified by:
solvingEndedin interfaceSolverLifecycleListener- Overrides:
solvingEndedin classAbstractSelector
-
constructCache
public void constructCache(DefaultSolverScope solverScope)
- Specified by:
constructCachein interfaceSelectionCacheLifecycleListener
-
disposeCache
public void disposeCache(DefaultSolverScope solverScope)
- Specified by:
disposeCachein interfaceSelectionCacheLifecycleListener
-
isCountable
public boolean isCountable()
Description copied from interface:SelectorIf false, thenSelector.isNeverEnding()is true.- Specified by:
isCountablein interfaceSelector- Returns:
- true if all the
ValueRanges 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:SelectorIs 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:
isNeverEndingin interfaceSelector- Returns:
- true if the
Iterator.hasNext()of theIteratorcreated byIterable.iterator()never returns false (except when it's empty).
-
getSize
public long getSize()
Description copied from interface:IterableSelectorA random JITSelectorwithSelector.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:
getSizein interfaceIterableSelector<SubChain>- Returns:
- the approximate number of elements generated by this
Selector, always>= 0
-
calculateSubChainSelectionSize
protected long calculateSubChainSelectionSize(SubChain anchorTrailingChain)
-
listIterator
public ListIterator<SubChain> listIterator()
- Specified by:
listIteratorin interfaceListIterable<SubChain>- Returns:
- never null, see
List.listIterator(). - See Also:
List.listIterator()
-
listIterator
public ListIterator<SubChain> listIterator(int index)
- Specified by:
listIteratorin interfaceListIterable<SubChain>- Parameters:
index- lower than the size of thisListIterable, seeList.listIterator(int).- Returns:
- never null, see
List.listIterator(int). - See Also:
List.listIterator()
-
-