# 1 CMSC 471 Fall 2002 Class #6 – Wednesday, September 18.

## Presentation on theme: "1 CMSC 471 Fall 2002 Class #6 – Wednesday, September 18."— Presentation transcript:

1 CMSC 471 Fall 2002 Class #6 – Wednesday, September 18

2 Today’s class Constraint Processing / Constraint Satisfaction Problem (CSP) paradigm Algorithms for CSPs –Backtracking (systematic search) –Constraint propagation (k-consistency) –Variable ordering heuristics –Backjumping and dependency-directed backtracking Viewing scheduling as a CSP

3 Constraint Processing Russell & Norvig 3.7, 4.2 end, 4.3-4.5

4 Overview Constraint Processing offers a powerful problem-solving paradigm –View a problem as a set of variables to which we have to assign values that satisfy a number of problem-specific constraints. –Constraint programming, CSPs, constraint logic programming… Algorithms for CSPs –Backtracking (systematic search) –Constraint propagation (k-consistency) –Variable ordering heuristics –Backjumping and dependency-directed backtracking

5 Informal Definition of CSP CSP = Constraint Satisfaction Problem Given (1) a finite set of variables (2) each with a domain of possible values (often finite) (3) a set of constraints that limit the values the variables can take on A solution is an assignment of a value to each variable such that the constraints are all satisfied. Tasks might be to decide if a solution exists, to find a solution, to find all solutions, or to find the “best solution” according to some metric.

6 Informal Example: Map Coloring Color the following map using three colors (red, green, blue) such that no two adjacent regions have the same color. E DA C B

7 Informal Example: Map Coloring Variables: A, B, C, D, E all of domain RGB Domains: RGB = {red, green, blue} Constraints: A  B, A  C,A  E, A  D, B  C, C  D, D  E One solution: A=red, B=green, C=blue, D=green, E=blue E DA C B E DA C B =>

8 Example: SATisfiability Given a set of propositions containing variables, find an assignment of the variables to {false,true} that satisfies them. Example, the clauses: –A or B or ~C, ~A or D –(equivalent to C -> A or B, D -> A) Are satisfied by A = false B = true C = false D = false

9 Real-world problems Scheduling Temporal reasoning Building design Planning Optimization/satisfaction Vision Graph layout Network management Natural language processing Molecular biology / genomics VLSI design

10 Formal definition of a constraint network (CN) A constraint network (CN) consists of a set of variables X = {x 1, x 2, … x n } –each with an associated domain of values {d 1, d 2, … d n }. –The domains are typically finite a set of constraints {c 1, c 2 … c m } where –each constraint defines a predicate which is a relation over a particular subset of X. –E.g., C i involves variables {X i1, X i2, … X ik } and defines the relation R i  D i1 x D i2 x … D ik Unary constraint: only involves one variable Binary constraint: only involves two variables

11 Formal definition of a CN (cont.) Instantiations –An instantiation of a subset of variables S is an assignment of a legal domain value to each variable in in S –An instantiation is legal iff it does not violate any (relevant) constraints. A solution is an instantiation of all of the variables in the network.

12 Typical Tasks for CSP Solutions: –Does a solution exist? –Find one solution –Find all solutions –Given a partial instantiation, do any of the above Transform the CN into an equivalent CN that is easier to solve.

13 Binary CSP A binary CSP is a CSP in which all of the constraints are binary or unary. Any non-binary CSP can be converted into a binary CSP by introducing additional variables. A binary CSP can be represented as a constraint graph, which has a node for each variable and an arc between two nodes if and only there is a constraint involving the two variables. –Unary constraint appears as self-referential arc

14 Example: Crossword Puzzle 123 4 5

15 Running Example: XWORD Puzzle Variables and their domains –X1 is 1 acrossD1 is 5-letter words –X2 is 2 downD2 is 4-letter words –X3 is 3 downD3 is 3-letter words –X4 is 4 acrossD4 is 4-letter words –X5 is 5 acrossD5 is 2-letter words Constraints (implicit/intensional) –C12 is “the 3rd letter of X1 must equal the 1st letter of X2” –C13 is “the 5th letter of X1 must equal the 1st letter of X3”. –C24 is … –C25 is … –C34 is...

16 123 4 5 Variables: X1 X2 X3 X4 X5 Domains: D1 = {hoses, laser, sheet, snail,steer} D2 = {hike, aron, keet, earn, same} D3 = {run, sun, let, yes, eat, ten} D4 = {hike, aron, keet, earn, same} D5 = {no, be, us, it} Constraints (explicit/extensional): C12 = {(hoses,same), (laser,same), (sheet,earn), (steer,earn)} C13 =... X1 X4 X5 X2 X3

17 Solving Constraint Problems Systematic search –Generate and test –Backtracking Constraint propagation (consistency) Variable ordering heuristics Backjumping and dependency-directed backtracking

18 Generate and test: XWORD Try each possible combination until you find one that works: –Hoses – hike – run – hike – no –Hoses – hike – run – hike – be –Hoses – hike – run – hike – us Doesn’t check constraints until all variables have been instantiated Very inefficient way to explore the space of possibilities

19 Systematic search: Backtracking (a.k.a. depth-first search) Consider the variables in some order Pick an unassigned variable and give it a provisional value such that it is consistent with all of the constraints If no such assignment can be made, we’ve reached a dead end and need to backtrack to the previous variable Continue this process until a solution is found or we backtrack to the initial variable and have exhausted all possible vlaues

20 Backtracking: XWORD 1 2 3 4 5  X1=hosesX1=laser X2=aron X2=same X2=hike … … … X3=run X3=sunX3=let X4=hike X4=same … hoses u n a m e

21 Problems with backtracking Thrashing: keep repeating the same failed variable assignments –Consistency checking can help –Intelligent backtracking schemes can also help Inefficiency: can explore areas of the search space that aren’t likely to succeed –Variable ordering can help

22 Consistency Node consistency –A node X is node-consistent if every value in the domain of X is consistent with X’s unary constraints –A graph is node-consistent if all nodes are node-consistent Arc consistency –An arc (X, Y) is arc-consistent if, for every value x of X, there is a value y for Y that satisfies the constraint represented by the arc. –A graph is arc-consistent if all arcs are arc-consistent To create arc consistency, we perform constraint propagation: that is, we repeatedly reduce the domain of each variable to be consistent with its arcs

23 Constraint propagation: XWORD example 123 4 5 X1 X2X4 hoses laser sheet snail steer hike aron keet earn same hike aron keet earn same

24 K-consistency K- consistency generalizes the notion of arc consistency to sets of more than two variables. –A graph is K-consistent if, for legal values of any K-1 variables in the graph, and for any Kth variable V k, there is a legal value for V k Strong K-consistency = J-consistency for all J<=K Node consistency = strong 1-consistency Arc consistency = strong 2-consistency Path consistency = strong 3-consistency

25 Why do we care? 1.If we have a CSP with N variables that is known to be strongly N-consistent, we can solve it without backtracking 2.For any CSP that is strongly K- consistent, if we find an appropriate variable ordering (one with “small enough” branching factor), we can solve the CSP without backtracking

26 Improving Backtracking Use other search techniques: uniform cost, A*, … Variable ordering can help improve backtracking. Typical heuristics: –P refer variables which maximally constrain the rest of the search space –When picking a value, choose the least constraining value Smarter backtracking: Backjumping, backmarking, dependency-directed backtracking

Download ppt "1 CMSC 471 Fall 2002 Class #6 – Wednesday, September 18."

Similar presentations