OptaPlanner core 6.0.0.Beta3

org.optaplanner.core.api.domain.variable
Annotation Type PlanningVariable


@Target(value=METHOD)
@Retention(value=RUNTIME)
public @interface PlanningVariable

Specifies that a bean property can be changed and should be optimized by the optimization algorithms.

It is specified on a getter of a java bean property of a PlanningEntity class.


Optional Element Summary
 boolean chained
          In some use cases, such as Vehicle Routing, planning entities are chained.
 boolean nullable
          A nullable planning variable will automatically add the planning value null to the ValueRange.
 Class<? extends SelectionFilter> reinitializeVariableEntityFilter
          Construction heuristics only change reinitializable planning variables.
 Class<? extends Comparator> strengthComparatorClass
          Allows a collection of planning values for this variable to be sorted by strength.
 Class<? extends SelectionSorterWeightFactory> strengthWeightFactoryClass
          The SelectionSorterWeightFactory alternative for strengthComparatorClass().
 

nullable

public abstract boolean nullable
A nullable planning variable will automatically add the planning value null to the ValueRange.

In repeated planning use cases, it's recommended to specify a reinitializeVariableEntityFilter() for every nullable planning variable too.

nullable() true is not compatible with {#link #chained} true. nullable() true is not compatible with a primitive property type.

Returns:
true if null is a valid value for this planning variable
Default:
false

reinitializeVariableEntityFilter

public abstract Class<? extends SelectionFilter> reinitializeVariableEntityFilter
Construction heuristics only change reinitializable planning variables. Non reinitializable planning variable is ignored by construction heuristics. This is especially useful in repeated planning use cases, in which starting from scratch would waste previous results and time.

If no reinitializeVariableEntityFilter() is specified, the default considers an entity uninitialized for a variable if its value is null (even if nullable() is true).

The method SelectionFilter.accept(ScoreDirector, Object) returns false if the selection entity should be reinitialized for this variable and it returns true if the selection entity should not be reinitialized for this variable

Returns:
PlanningVariable.NullReinitializeVariableEntityFilter when it is null (workaround for annotation limitation)
Default:
org.optaplanner.core.api.domain.variable.PlanningVariable.NullReinitializeVariableEntityFilter.class

strengthComparatorClass

public abstract Class<? extends Comparator> strengthComparatorClass
Allows a collection of planning values for this variable to be sorted by strength. A strengthWeight estimates how strong a planning value is. Some algorithms benefit from planning on weaker planning values first or from focusing on them.

The Comparator should sort in ascending strength. For example: sorting 3 computers on strength based on their RAM capacity: Computer B (1GB RAM), Computer A (2GB RAM), Computer C (7GB RAM),

Do not use together with strengthWeightFactoryClass().

Returns:
PlanningVariable.NullStrengthComparator when it is null (workaround for annotation limitation)
See Also:
strengthWeightFactoryClass()
Default:
org.optaplanner.core.api.domain.variable.PlanningVariable.NullStrengthComparator.class

strengthWeightFactoryClass

public abstract Class<? extends SelectionSorterWeightFactory> strengthWeightFactoryClass
The SelectionSorterWeightFactory alternative for strengthComparatorClass().

Do not use together with strengthComparatorClass().

Returns:
PlanningVariable.NullStrengthWeightFactory when it is null (workaround for annotation limitation)
See Also:
strengthComparatorClass()
Default:
org.optaplanner.core.api.domain.variable.PlanningVariable.NullStrengthWeightFactory.class

chained

public abstract boolean chained
In some use cases, such as Vehicle Routing, planning entities are chained. A chained variable recursively points to a planning fact, which is called the anchor. So either it points directly to the anchor (that planning fact) or it points to another planning entity with the same planning variable (which recursively points to the anchor). Chains always have exactly 1 anchor, thus they never loop and the tail is always open. Chains never split into a tree: a anchor or planning entity has at most 1 trailing planning entity.

When a chained planning entity changes position, then chain correction must happen:

For example: Given A <- B <- C <- D <- X <- Y, when B moves between X and Y, pointing to X, then Y is also changed to point to B and C is also changed to point to A, giving the result A <- C <- D <- X <- B <- Y.

nullable() true is not compatible with {#link #chained} true.

Returns:
true if changes to this variable need to trigger chain correction
Default:
false

OptaPlanner core 6.0.0.Beta3

Copyright © 2006-2013 JBoss by Red Hat. All Rights Reserved.