Class ProbabilityValueSelector<Solution_>
- java.lang.Object
-
- ai.timefold.solver.core.impl.heuristic.selector.AbstractSelector<Solution_>
-
- ai.timefold.solver.core.impl.heuristic.selector.AbstractDemandEnabledSelector<Solution_>
-
- ai.timefold.solver.core.impl.heuristic.selector.value.decorator.ProbabilityValueSelector<Solution_>
-
- All Implemented Interfaces:
SelectionCacheLifecycleListener<Solution_>,IterableSelector<Solution_,Object>,Selector<Solution_>,EntityIndependentValueSelector<Solution_>,ValueSelector<Solution_>,PhaseLifecycleListener<Solution_>,SolverLifecycleListener<Solution_>,Iterable<Object>,EventListener
public final class ProbabilityValueSelector<Solution_> extends AbstractDemandEnabledSelector<Solution_> implements EntityIndependentValueSelector<Solution_>, SelectionCacheLifecycleListener<Solution_>
-
-
Field Summary
Fields Modifier and Type Field Description protected NavigableMap<Double,Object>cachedEntityMapprotected doubleprobabilityWeightTotal-
Fields inherited from class ai.timefold.solver.core.impl.heuristic.selector.AbstractSelector
logger, phaseLifecycleSupport, workingRandom
-
-
Constructor Summary
Constructors Constructor Description ProbabilityValueSelector(EntityIndependentValueSelector<Solution_> childValueSelector, SelectionCacheType cacheType, SelectionProbabilityWeightFactory<Solution_,Object> probabilityWeightFactory)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidconstructCache(SolverScope<Solution_> solverScope)voiddisposeCache(SolverScope<Solution_> solverScope)Iterator<Object>endingIterator(Object entity)IfSelector.isNeverEnding()is true, thenValueSelector.iterator(Object)will never end.booleanequals(Object other)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.longgetSize(Object entity)Similar toIterableSelector.getSize(), but requires an entity.GenuineVariableDescriptor<Solution_>getVariableDescriptor()inthashCode()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<Object>iterator()Iterator<Object>iterator(Object entity)Similar toIterable.iterator(), but requires an entity.StringtoString()-
Methods inherited from class ai.timefold.solver.core.impl.heuristic.selector.AbstractSelector
phaseEnded, phaseStarted, solvingEnded, solvingStarted, stepEnded, stepStarted
-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface ai.timefold.solver.core.impl.heuristic.selector.IterableSelector
spliterator
-
Methods inherited from interface ai.timefold.solver.core.impl.phase.event.PhaseLifecycleListener
phaseEnded, phaseStarted, stepEnded, stepStarted
-
Methods inherited from interface ai.timefold.solver.core.impl.solver.event.SolverLifecycleListener
solvingEnded, solvingError, solvingStarted
-
-
-
-
Field Detail
-
cachedEntityMap
protected NavigableMap<Double,Object> cachedEntityMap
-
probabilityWeightTotal
protected double probabilityWeightTotal
-
-
Constructor Detail
-
ProbabilityValueSelector
public ProbabilityValueSelector(EntityIndependentValueSelector<Solution_> childValueSelector, SelectionCacheType cacheType, SelectionProbabilityWeightFactory<Solution_,Object> probabilityWeightFactory)
-
-
Method Detail
-
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<Solution_>- Overrides:
getCacheTypein classAbstractSelector<Solution_>- Returns:
- never null
-
constructCache
public void constructCache(SolverScope<Solution_> solverScope)
- Specified by:
constructCachein interfaceSelectionCacheLifecycleListener<Solution_>
-
disposeCache
public void disposeCache(SolverScope<Solution_> solverScope)
- Specified by:
disposeCachein interfaceSelectionCacheLifecycleListener<Solution_>
-
getVariableDescriptor
public GenuineVariableDescriptor<Solution_> getVariableDescriptor()
- Specified by:
getVariableDescriptorin interfaceValueSelector<Solution_>- Returns:
- never null
-
isCountable
public boolean isCountable()
Description copied from interface:SelectorIf false, thenSelector.isNeverEnding()is true.- Specified by:
isCountablein interfaceSelector<Solution_>- 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<Solution_>- Returns:
- true if the
Iterator.hasNext()of theIteratorcreated byIterable.iterator()never returns false (except when it's empty).
-
getSize
public long getSize(Object entity)
Description copied from interface:ValueSelectorSimilar toIterableSelector.getSize(), but requires an entity.- Specified by:
getSizein interfaceValueSelector<Solution_>- Parameters:
entity- never null- Returns:
- the approximate number of elements generated by this
Selector, always>= 0
-
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<Solution_,Object>- Returns:
- the approximate number of elements generated by this
Selector, always>= 0
-
iterator
public Iterator<Object> iterator(Object entity)
Description copied from interface:ValueSelectorSimilar toIterable.iterator(), but requires an entity.- Specified by:
iteratorin interfaceValueSelector<Solution_>- Parameters:
entity- never null- Returns:
- never null
-
endingIterator
public Iterator<Object> endingIterator(Object entity)
Description copied from interface:ValueSelectorIfSelector.isNeverEnding()is true, thenValueSelector.iterator(Object)will never end. This returns an endingIterator, that tries to matchValueSelector.iterator(Object)as much as possible, but return each distinct element only once and therefore it might not respect the configuration of thisValueSelectorentirely.- Specified by:
endingIteratorin interfaceValueSelector<Solution_>- Parameters:
entity- never null- Returns:
- never null
- See Also:
ValueSelector.iterator(Object)
-
equals
public boolean equals(Object other)
- Specified by:
equalsin classAbstractDemandEnabledSelector<Solution_>
-
hashCode
public int hashCode()
- Specified by:
hashCodein classAbstractDemandEnabledSelector<Solution_>
-
-