Class FilteringValueRangeSelector<Solution_>
- Type Parameters:
Solution_- the solution type
- All Implemented Interfaces:
IterableSelector<Solution_,,Object> Selector<Solution_>,IterableValueSelector<Solution_>,ValueSelector<Solution_>,PhaseLifecycleListener<Solution_>,SolverLifecycleListener<Solution_>,Iterable<Object>,EventListener
The decorator can only be applied to list variables.
e1 = entity_range[v1, v2, v3]
e2 = entity_range[v1, v4]
v1 = [v2, v3, v4]
v2 = [v1, v3]
v3 = [v1, v2]
v4 = [v1]
This node is currently used by the ListChangeMoveSelector and ListSwapMoveSelector selectors.
To illustrate its usage, let’s assume how moves are generated for the list swap type.
Initially, the swap move selector used a left value selector to choose a value.
After that, it uses a right value selector to choose another value to swap them.
Based on the previously described process and the current goal of this node, we can observe that once a value is selected using the left value selector, the right node can filter out all non-reachable values and generate a valid move. A move is considered valid only if both entities accept each other's values. The filtering process of invalid values allows the solver to explore the solution space more efficiently.
-
Field Summary
Fields inherited from class ai.timefold.solver.core.impl.heuristic.selector.AbstractSelector
logger, phaseLifecycleSupport, workingRandom -
Constructor Summary
ConstructorsConstructorDescriptionFilteringValueRangeSelector(IterableValueSelector<Solution_> nonReplayingValueSelector, IterableValueSelector<Solution_> replayingValueSelector, boolean randomSelection, boolean checkSourceAndDestination) -
Method Summary
Modifier and TypeMethodDescriptionendingIterator(Object entity) IfSelector.isNeverEnding()is true, thenValueSelector.iterator(Object)will never end.booleanUnless this selector itself caches, this returnsSelectionCacheType.JUST_IN_TIME, even if a selector child caches.<T> SelectionSorter<Solution_,T> Returns the selection sorter applied to the node.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.longSimilar toIterableSelector.getSize(), but requires an entity.inthashCode()booleanIf false, thenSelector.isNeverEnding()is true.booleanIs true ifSelector.isCountable()is false or if this selector is in random order (for most cases).iterator()Similar toIterable.iterator(), but requires an entity.voidphaseEnded(AbstractPhaseScope<Solution_> phaseScope) voidphaseStarted(AbstractPhaseScope<Solution_> phaseScope) voidsolvingStarted(SolverScope<Solution_> solverScope) Methods inherited from class ai.timefold.solver.core.impl.heuristic.selector.AbstractSelector
solvingEnded, stepEnded, stepStartedMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface ai.timefold.solver.core.impl.heuristic.selector.IterableSelector
spliteratorMethods inherited from interface ai.timefold.solver.core.impl.phase.event.PhaseLifecycleListener
stepEnded, stepStartedMethods inherited from interface ai.timefold.solver.core.impl.solver.event.SolverLifecycleListener
solvingEnded, solvingError
-
Constructor Details
-
FilteringValueRangeSelector
public FilteringValueRangeSelector(IterableValueSelector<Solution_> nonReplayingValueSelector, IterableValueSelector<Solution_> replayingValueSelector, boolean randomSelection, boolean checkSourceAndDestination)
-
-
Method Details
-
solvingStarted
- Specified by:
solvingStartedin interfaceSolverLifecycleListener<Solution_>- Overrides:
solvingStartedin classAbstractSelector<Solution_>
-
phaseStarted
- Specified by:
phaseStartedin interfacePhaseLifecycleListener<Solution_>- Overrides:
phaseStartedin classAbstractSelector<Solution_>
-
phaseEnded
- Specified by:
phaseEndedin interfacePhaseLifecycleListener<Solution_>- Overrides:
phaseEndedin classAbstractSelector<Solution_>
-
getChildValueSelector
-
getSelectionSorter
Description copied from interface:ValueSelectorReturns the selection sorter applied to the node. By default, it returns null and must be overridden by the child class if necessary.- Specified by:
getSelectionSorterin interfaceValueSelector<Solution_>- Type Parameters:
T- the sorter value type.- Returns:
- the selection sorter.
-
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
-
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
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
Description copied from interface:ValueSelectorSimilar toIterable.iterator(), but requires an entity.- Specified by:
iteratorin interfaceValueSelector<Solution_>- Parameters:
entity- never null- Returns:
- never null
-
iterator
-
endingIterator
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:
-
equals
- Specified by:
equalsin classAbstractDemandEnabledSelector<Solution_>
-
hashCode
public int hashCode()- Specified by:
hashCodein classAbstractDemandEnabledSelector<Solution_>
-