Skip to main content

Backtracking Search for CSPs

Sometimes we can finish the constraint propagation process and still have variables with multiple possible values. In that case we have to search for a solution.

CSP is commutative: the order of application of any given set of actions does not matter. We need only consider a single variable at each node in the search tree.

With this restriction, the number of leaves is $d^n$, as we would hope (instead of $n! \cdot d^n$). At each level of the tree we do have to choose which variable we will deal with, but we never have to backtrack over that choice.

Backtracking repeatedly chooses an unassigned variable, and then tries all values in the domain of that variable in turn, trying to extend each one into a solution via a recursive call. If the call succeeds, the solution is returned, and if it fails, the assignment is restored to the previous state, and we try the next value. If no value works then we return failure.

Variable and value ordering

Which variable $X$ should be assigned next?

  • The current assignment could not bring to any solution, but we might need time to discover this
  • Choose the right variable in order to discover inconsistencies in the current assignment as soon as possible

Two heuristics:

  • minimum-remaining-values (MRV)
  • Degree

In what order should the values of $X$ be considered?

  • The current assignment could bring to a solution (could be part of a solution)
  • Choose the right value to assign to $X$ in order to reach the solution as quickly as possible

One heuristic:

  • Least-constraining-value

These aspects are domain-independent and made possibile by the factored representation of the state

minimum-remaining-values (MRV) heuristic

It also has been called the “most constrained variable” or “fail-first” heuristic, the latter because it picks a variable that is most likely to cause a failure soon, thereby pruning the search tree.

If some variable $X$ has no legal values left, the MRV heuristic will select $X$ and failure will be detected immediately—avoiding pointless searches through other variables. The MRV heuristic usually performs better than a random or static ordering, sometimes by orders of magnitude, although the results vary depending on the problem.