Package org.jacop.constraints
Class Alldifferent
- java.lang.Object
-
- org.jacop.constraints.DecomposedConstraint<Constraint>
-
- org.jacop.constraints.Constraint
-
- org.jacop.constraints.Alldifferent
-
- All Implemented Interfaces:
SatisfiedPresent,UsesQueueVariable
- Direct Known Subclasses:
Alldiff
public class Alldifferent extends Constraint implements UsesQueueVariable, SatisfiedPresent
Alldifferent constraint assures that all FDVs has differnet values. It uses partial consistency technique.- Version:
- 4.8
-
-
Field Summary
Fields Modifier and Type Field Description protected TimeStamp<java.lang.Integer>grounded(package private) static java.util.concurrent.atomic.AtomicIntegeridNumberIntVar[]listIt specifies a list of variables which must take different values.protected java.util.Map<IntVar,java.lang.Integer>positionMapping(package private) java.util.LinkedHashSet<IntVar>variableQueue-
Fields inherited from class org.jacop.constraints.Constraint
afcWeight, atomicExecution, consistencyPruningEvents, constraintScope, earlyTerminationOK, increaseWeight, numberId, scope, trace, watchedVariableGrounded
-
Fields inherited from class org.jacop.constraints.DecomposedConstraint
queueIndex
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedAlldifferent()Alldifferent(java.util.List<? extends IntVar> variables)It constructs the alldifferent constraint for the supplied variable.Alldifferent(IntVar[] list)It constructs the alldifferent constraint for the supplied variable.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidconsistency(Store store)It is a (most probably incomplete) consistency function which removes the values from variables domains.intgetDefaultConsistencyPruningEvent()voidimpose(Store store)It imposes the constraint in a given store.booleannotSatisfied()Check whether the constraint is not satisfied based on bipartite graph matching.voidqueueVariable(int level, Var V)This is a function called to indicate which variable in a scope of constraint has changed.booleansatisfied()It checks if the constraint is satisfied.private booleansatisfiedBound()private booleansatisfiedFullCheck(Store S)java.lang.StringtoString()It produces a string representation of a constraint state.-
Methods inherited from class org.jacop.constraints.Constraint
afc, arguments, cleanAfterFailure, decompose, getConsistencyPruningEvent, getGuideConstraint, getGuideValue, getGuideVariable, grounded, grounded, id, impose, imposeDecomposition, increaseWeight, intArrayToString, long2int, numberArgs, removeConstraint, requiresMonotonicity, setConsistencyPruningEvent, setConstraintScope, setScope, setScope, setScope, setScope, setScope, setWatchedVariableGrounded, supplyGuideFeedback, toInt, toInt, updateAFC, watchedVariableGrounded
-
Methods inherited from class org.jacop.constraints.DecomposedConstraint
auxiliaryVariables, checkInput, checkInput, checkInputForDuplication, checkInputForDuplicationSkipSingletons, checkInputForNullness, checkInputForNullness, checkInputForNullness, derivative, getDubletonsSkipSingletons, imposeDecomposition
-
-
-
-
Field Detail
-
idNumber
static final java.util.concurrent.atomic.AtomicInteger idNumber
-
list
public IntVar[] list
It specifies a list of variables which must take different values.
-
variableQueue
java.util.LinkedHashSet<IntVar> variableQueue
-
positionMapping
protected java.util.Map<IntVar,java.lang.Integer> positionMapping
-
grounded
protected TimeStamp<java.lang.Integer> grounded
-
-
Constructor Detail
-
Alldifferent
protected Alldifferent()
-
Alldifferent
public Alldifferent(IntVar[] list)
It constructs the alldifferent constraint for the supplied variable.- Parameters:
list- variables which are constrained to take different values.
-
Alldifferent
public Alldifferent(java.util.List<? extends IntVar> variables)
It constructs the alldifferent constraint for the supplied variable.- Parameters:
variables- variables which are constrained to take different values.
-
-
Method Detail
-
consistency
public void consistency(Store store)
Description copied from class:ConstraintIt is a (most probably incomplete) consistency function which removes the values from variables domains. Only values which do not have any support in a solution space are removed.- Specified by:
consistencyin classConstraint- Parameters:
store- constraint store within which the constraint consistency is being checked.
-
getDefaultConsistencyPruningEvent
public int getDefaultConsistencyPruningEvent()
- Specified by:
getDefaultConsistencyPruningEventin classConstraint
-
satisfied
public boolean satisfied()
Description copied from interface:SatisfiedPresentIt checks if the constraint is satisfied. It can return false even if constraint is satisfied but not all variables in its scope are grounded. It needs to return true if all variables in its scope are grounded and constraint is satisfied.Implementations of this interface for constraints that are not PrimitiveConstraint may require constraint imposition and consistency check as a requirement to work correctly.
- Specified by:
satisfiedin interfaceSatisfiedPresent- Returns:
- true if constraint is possible to verify that it is satisfied.
-
satisfiedFullCheck
private boolean satisfiedFullCheck(Store S)
-
notSatisfied
public boolean notSatisfied()
Check whether the constraint is not satisfied based on bipartite graph matching.- Returns:
- true if constraint is not satisfied
-
impose
public void impose(Store store)
Description copied from class:ConstraintIt imposes the constraint in a given store.- Overrides:
imposein classConstraint- Parameters:
store- the constraint store to which the constraint is imposed to.
-
queueVariable
public void queueVariable(int level, Var V)Description copied from class:ConstraintThis is a function called to indicate which variable in a scope of constraint has changed. It also indicates a store level at which the change has occurred.- Overrides:
queueVariablein classConstraint- Parameters:
level- the level of the store at which the change has occurred.V- variable which has changed.
-
satisfiedBound
private boolean satisfiedBound()
-
toString
public java.lang.String toString()
Description copied from class:ConstraintIt produces a string representation of a constraint state.- Overrides:
toStringin classConstraint
-
-