
aima.core.search.csp.Assignment Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aima-core Show documentation
Show all versions of aima-core Show documentation
AIMA-Java Core Algorithms from the book Artificial Intelligence a Modern Approach 3rd Ed.
package aima.core.search.csp;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Hashtable;
import java.util.List;
/**
* An assignment assigns values to some or all variables of a CSP.
*
* @author Ruediger Lunde
*/
public class Assignment {
/**
* Contains all assigned variables. Positions reflect the the order in which
* the variables were assigned to values.
*/
List variables;
/** Maps variables to their assigned values. */
Hashtable variableToValue;
public Assignment() {
variables = new ArrayList();
variableToValue = new Hashtable();
}
public List getVariables() {
return Collections.unmodifiableList(variables);
}
public Object getAssignment(Variable var) {
return variableToValue.get(var);
}
public void setAssignment(Variable var, Object value) {
if (!variableToValue.containsKey(var))
variables.add(var);
variableToValue.put(var, value);
}
public void removeAssignment(Variable var) {
if (hasAssignmentFor(var)) {
variables.remove(var);
variableToValue.remove(var);
}
}
public boolean hasAssignmentFor(Variable var) {
return variableToValue.get(var) != null;
}
/**
* Returns true if this assignment does not violate any constraints of
* constraints
.
*/
public boolean isConsistent(List constraints) {
for (Constraint cons : constraints)
if (!cons.isSatisfiedWith(this))
return false;
return true;
}
/**
* Returns true if this assignment assigns values to every variable of
* vars
.
*/
public boolean isComplete(List vars) {
for (Variable var : vars) {
if (!hasAssignmentFor(var))
return false;
}
return true;
}
/**
* Returns true if this assignment assigns values to every variable of
* vars
.
*/
public boolean isComplete(Variable[] vars) {
for (Variable var : vars) {
if (!hasAssignmentFor(var))
return false;
}
return true;
}
/**
* Returns true if this assignment is consistent as well as complete with
* respect to the given CSP.
*/
public boolean isSolution(CSP csp) {
return isConsistent(csp.getConstraints())
&& isComplete(csp.getVariables());
}
public Assignment copy() {
Assignment copy = new Assignment();
for (Variable var : variables) {
copy.setAssignment(var, variableToValue.get(var));
}
return copy;
}
@Override
public String toString() {
boolean comma = false;
StringBuffer result = new StringBuffer("{");
for (Variable var : variables) {
if (comma)
result.append(", ");
result.append(var + "=" + variableToValue.get(var));
comma = true;
}
result.append("}");
return result.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy