Class FilteringEntityByEntitySelector<Solution_>
- Type Parameters:
Solution_- the solution type
- All Implemented Interfaces:
ListIterable<Object>,EntitySelector<Solution_>,IterableSelector<Solution_,,Object> ListIterableSelector<Solution_,,Object> Selector<Solution_>,PhaseLifecycleListener<Solution_>,SolverLifecycleListener<Solution_>,Iterable<Object>,EventListener
The decorator can only be applied to basic variables.
e1 = entity_range[v1, v2, v3]
e2 = entity_range[v1, v4]
e3 = entity_range[v1, v4, v5]
Let's consider the following use-cases:
- e1(null) - e2(null): e2 is reachable by e1 because both assigned values are null.
- e1(v2) - e2(v1): e2 is not reachable by e1 because its value range does not accept v2.
- e2(v1) - e3(v4): e3 is reachable by e2 because e2 accepts v4 and e3 accepts v1.
This node is currently used by the SwapMoveSelector selector.
To explain its functionality, let's consider how moves are generated for the basic swap type.
Initially, the swap move selector employs a left entity selector to choose one entity.
Then, it uses a right entity selector to select another entity, with the goal of swapping their values.
Based on the previously described process and the current goal of this node, we can observe that once an entity is selected using the left selector, the right node can filter out all non-reachable entities and generate a valid move. A move is considered valid only if both entities accept each other's values. The filtering process of invalid entities allows the solver to explore the solution space more efficiently.
- See Also:
-
Field Summary
Fields inherited from class ai.timefold.solver.core.impl.heuristic.selector.AbstractSelector
logger, phaseLifecycleSupport, workingRandom -
Constructor Summary
ConstructorsConstructorDescriptionFilteringEntityByEntitySelector(EntitySelector<Solution_> childEntitySelector, EntitySelector<Solution_> replayingEntitySelector, boolean randomSelection) -
Method Summary
Modifier and TypeMethodDescriptionIfSelector.isNeverEnding()is true, thenIterable.iterator()will never end.booleanlonggetSize()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.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()listIterator(int index) voidphaseEnded(AbstractPhaseScope<Solution_> phaseScope) voidphaseStarted(AbstractPhaseScope<Solution_> phaseScope) voidsolvingStarted(SolverScope<Solution_> solverScope) voidstepStarted(AbstractStepScope<Solution_> stepScope) Methods inherited from class ai.timefold.solver.core.impl.heuristic.selector.AbstractSelector
getCacheType, solvingEnded, stepEndedMethods 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
stepEndedMethods inherited from interface ai.timefold.solver.core.impl.heuristic.selector.Selector
getCacheTypeMethods inherited from interface ai.timefold.solver.core.impl.solver.event.SolverLifecycleListener
solvingEnded, solvingError
-
Constructor Details
-
FilteringEntityByEntitySelector
public FilteringEntityByEntitySelector(EntitySelector<Solution_> childEntitySelector, EntitySelector<Solution_> replayingEntitySelector, boolean randomSelection)
-
-
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_>
-
stepStarted
- Specified by:
stepStartedin interfacePhaseLifecycleListener<Solution_>- Overrides:
stepStartedin classAbstractSelector<Solution_>
-
getEntityDescriptor
- Specified by:
getEntityDescriptorin interfaceEntitySelector<Solution_>- Returns:
- never null
-
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
-
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).
-
endingIterator
Description copied from interface:EntitySelectorIfSelector.isNeverEnding()is true, thenIterable.iterator()will never end. This returns an endingIterator, that tries to matchIterable.iterator()as much as possible, but returns each distinct element only once and returns every element that might possibly be selected and therefore it might not respect the configuration of thisEntitySelectorentirely.- Specified by:
endingIteratorin interfaceEntitySelector<Solution_>- Returns:
- never null
- See Also:
-
iterator
-
listIterator
- Specified by:
listIteratorin interfaceListIterable<Solution_>- Returns:
- never null, see
List.listIterator(). - See Also:
-
listIterator
- Specified by:
listIteratorin interfaceListIterable<Solution_>- Parameters:
index- lower than the size of thisListIterable, seeList.listIterator(int).- Returns:
- never null, see
List.listIterator(int). - See Also:
-
equals
- Specified by:
equalsin classAbstractDemandEnabledSelector<Solution_>
-
hashCode
public int hashCode()- Specified by:
hashCodein classAbstractDemandEnabledSelector<Solution_>
-