This week: watch Lesson 4, Constraint Satisfaction, and read Chapter 6 in AIMA (Russell & Norvig).
Assignment 2: Tridirectional Search
**Due: September 24! Here is the GitHub repo.
I need to read the book to understand this chapter.
data:image/s3,"s3://crabby-images/d4bec/d4becd7adb656fe7acd83066783cecd54a97167c" alt="Constrint Satisfaction Problem"
challenge question
data:image/s3,"s3://crabby-images/33a13/33a13880097a80ec239472a39bef6f69584faad2" alt="Quiz: GSP Challenge Question"
- use the techniques mentioned in the quiz to solve a problem like this
Map Coloring problem
- question: color the map with a minimum number of colors while no states adjacent will be colored the same.
data:image/s3,"s3://crabby-images/88477/88477529c9e1015ab37f2bd89dc587dd420d1d1a" alt="map"
The map-coloring problem has the following components:
- Variables
- Domains
- Constraints: or rules to specify the problem.
- Unary constraints concerns only one variable.
- The problem can be illustrated by a Constraint Graph if the constraints are binary.
Constraint Graph
data:image/s3,"s3://crabby-images/fca0f/fca0f1bd9118a0e642ec1d3f0e8129e6d2dfc946" alt="Map coloring"
- Nodes are variables
- Arc (Edges) represents constraints.
data:image/s3,"s3://crabby-images/b2db4/b2db467b8a356116e39b97179337de56ebfe766c" alt="quiz"
data:image/s3,"s3://crabby-images/69466/694662db3c7ad04a5b5e7d31728ee3a512bc5d48" alt="quize: my answer"
There are multiple solutions to the quiz. But all the solutions must follow the rules (satisfy the constraints).
- Constraints can be multi-nary and soft constraints.
Constraint Hypergraph for the challenge question
data:image/s3,"s3://crabby-images/68f19/68f190cd7f74ae501462676930869a841af7926a" alt="image.png"
Backtracking Search
data:image/s3,"s3://crabby-images/78396/78396f62f7a1d36be37a7ef0fbf1272dbfcb9159" alt="psuedo code"
data:image/s3,"s3://crabby-images/b9870/b9870756759f479c82daed4f66b872c1f503268a" alt="Example"
- backtrack search is like depth-first search, it goes deeper and deeper until it reaches a "dead-end"
- In case of dead-end, the algorithm backtrack up to the upper division to try another branch.
- repeat these steps until the solution is reached.
There are ways to improve the search efficiency
- choose the least constraining value for each step
- choose the variable with the fewest legal values
data:image/s3,"s3://crabby-images/03814/03814484274a422f01a52e4b434b2e96d7c7ecd5" alt="Least constraining value"
- in the image above, in the branching step, which area should we choose to color? Least constrain value will choose the right-upper corner because it has more color to choose from. if we choose orange again, we will leave green to be unused (or lest constrained).
[Minimum remaining values]: or we can choose the middle-lower region because it has the least color to choose from.
When there is a tie, a heuristic could be used to select the next step/ area to explore.
quiz
data:image/s3,"s3://crabby-images/cd1a0/cd1a0de2ced6ec7c46862ded9f6adc0bcf2c6597" alt="quiz"
- we can use minimal remain values to choose the region adjacent to the red and blue blocks because this will make it region only have 2 colors to choose from (minimum remaining values)
- Or we can choose the one on the top if it since it only has one color to choose from (least constraining values) since it only have Green to use.
forward checking
- we can also use forward checking as a warning system for dead-end branches
data:image/s3,"s3://crabby-images/53116/53116f9ca61b289cb44ff0522a419ac542c452c6" alt="forward checking"
- forward checking keeps track of the available domain for each variable in each step
- a dead-end is reached when there is no domain for an unresolved variable.
data:image/s3,"s3://crabby-images/3e271/3e2713bceb4cda7029b9346f502a49719f80798a" alt="Arc Consistency"
- Arc Consistency: all the variables have at least a value in the possible domain.
- Neighbors should not have the same color, thus a selection of a color can have a chain effect on the domain for variables.
- when we find a region has no value available to assign, return 'Failure' to the problem.
Question: select all the possible values for each region and indicate whether the entire network arc consistent or not.
Structured CSPs
data:image/s3,"s3://crabby-images/4d8fa/4d8fa5fd478b27b91ce98fb2a4bb43cb3c52863c" alt="Structured CSPs"
data:image/s3,"s3://crabby-images/a2052/a20522cb5837c9db1e8ad4465cc4e3c5b52bff14" alt="Conditioned CSP as tree"
- How fast the algorithm will be?
Iterative Algorithms
data:image/s3,"s3://crabby-images/156b4/156b440545160e41f7ab71b2a74284df7bf4fc53" alt="Iterative Algorithms"
- Iterative Algorithms works very well then the solutions are plenty or very few.
- the problem becomes hard to solve when the ratio of constraints and solutions reaches a critical ratio
data:image/s3,"s3://crabby-images/c2fd4/c2fd4f7a70f6e8bde528cb5153a0483ec860e5f1" alt=""
the challenge question
data:image/s3,"s3://crabby-images/d91a4/d91a4d77cc68a8141a25ddd231d09857531b766a" alt="challenge question"
can be resolved by forward-checking: checking the available domains for values.
s Readings
AIMA: Chapter 6