final-search-csp-sols
pdf
keyboard_arrow_up
School
Hong Kong Polytechnic University *
*We aren’t endorsed by this school
Course
273
Subject
Computer Science
Date
Nov 24, 2024
Type
Pages
5
Uploaded by lixun73230
CS 188
Summer 2023
Final Review Search Solutions
Q1. Power Pellets
Consider a Pacman game where Pacman can eat 3 types of pellets:
•
Normal pellets (n-pellets), which are worth one point.
•
Decaying pellets (d-pellets), which are worth
max
(0
,
5
−
t
) points, where
t
is time.
•
Growing pellets (g-pellets), which are worth
t
points, where
t
is time.
The location and type of each pellet is fixed. The pellet’s point value stops changing once eaten. For example,
if Pacman eats one g-pellet at
t
= 1 and one d-pellet at
t
= 2, Pacman will have won 1 + 3 = 4 points.
Pacman needs to find a path to win at least 10 points but he wants to minimize distance travelled. The cost
between states is equal to distance travelled.
(a)
Which of the following must be including for a minimum, sufficient state space?
■
Pacman’s location
□
Location and type of each pellet
□
How far Pacman has travelled
■
Current time
□
How many pellets Pacman has eaten and the point value of each eaten pellet
■
Total points Pacman has won
■
Which pellets Pacman has eaten
A state space should include which pellets are left on the board, the current value of pellets, Pacman’s location,
and the total points collected so far. With this in mind:
(1) The starting location and type of each pellet are not included in the state space as this is something that
does not change during the search. This is analogous to how the walls of a Pacman board are not included in
the state space.
(2) How far Pacman has travelled does not need to be explicitly tracked by the state, since this will be reflected
in the cost of a path.
(3) Pacman does need the current time to determine the value of pellets on the board.
(4) The number of pellets Pacman has eaten is extraneous.
(5) Pacman must track the total number of points won for the goal test.
(6) Pacman must know which pellets remain on the board, which is the complement of the pellets he has eaten.
(b)
Which of the following are admissible heuristics? Let
x
be the number of points won so far.
■
Distance to closest pellet, except if in the goal state, in which case the heuristic value is 0.
□
Distance needed to win 10
−
x
points, determining the value of all pellets as if they were n-pellets.
■
Distance needed to win 10
−
x
points, determining the value of all pellets as if they were g-pellets
(i.e. all pellet values will be
t
.)
□
Distance needed to win 10
−
x
points, determining the value of all pellets as if they were d-pellets
(i.e. all pellet values will be
max
(0
,
5
−
t
).
□
Distance needed to win 10
−
x
points assuming all pellets maintain current point value (g-pellets stop
1
increasing in value and d-pellets stop decreasing in value)
□
None of the above
(1) Admissible; to get 10 points Pacman will always have to travel at least as far as the distance to the closest
pellet, so this will always be an underestimate.
(2) Not admissible; if all the pellets are actually g-pellets, assuming they are n-pellets will lead to Pacman
collecting more pellets in more locations, and thus travel further.
(3) Ambiguous; if pellets are n-pellets or d-pellets, Pacman will generally have to go further, except at the
beginning of the game when d-pellets are worth more, in which case this heuristic will over-estimate the cost to
the goal. However, if Pacman is allowed to stay in place with no cost, then this heuristic is admissable because
the heuristic will instead calculate all pellet values as 10. This option was ignored in scoring.
(4) Not admissible; if pellets are n-pellets or g-pellets, Pacman would have an overestimate.
(5) Not admissible; if pellets are g-pellets, then using the current pellet value might lead Pacman to collect more
locations, and thus travel further than necesarry.
(c)
Instead of finding a path which minimizes distance, Pacman would like to find a path which minimizes
the following:
C
new
=
a
∗
t
+
b
∗
d
where
t
is the amount of time elapsed,
d
is the distance travelled, and
a
and
b
are non-negative constants
such that
a
+
b
= 1. Pacman knows an admissible heuristic when he is trying to minimize time (i.e. when
a
= 1
, b
= 0),
h
t
, and when he is trying to minimize distance,
h
d
(i.e. when
a
= 0
, b
= 1).
Which of the following heuristics is guaranteed to be admissible when minimizing
C
new
?
□
mean
(
h
t
, h
d
)
■
min
(
h
t
, h
d
)
□
max
(
h
t
, h
d
)
■
a
∗
h
t
+
b
∗
h
d
□
None of the above
For this question, think about the inequality
C
new
=
a
∗
t
+
b
∗
d
≥
a
∗
h
t
+
b
∗
h
d
. We can guarantee a heuristic
h
new
is admissible if
h
new
≤
a
∗
h
t
+
b
∗
h
d
(1) If
a
=
b
, 0
.
5
∗
h
t
+ 0
.
5
∗
h
d
is not guaranteed to be less than
a
∗
h
t
+
b
∗
h
d
, so this will not be admissible.
(2)
min
(
h
t
, h
d
) =
a
∗
min
(
h
t
, h
d
) +
b
∗
min
(
h
t
, h
d
)
≤
a
∗
h
t
+
b
∗
h
d
(3)
max
(
h
t
, h
d
) will be greater than
a
∗
h
t
+
b
∗
h
d
unless
h
t
=
h
d
, wo this will not be admissible.
(4) Admissible.
2
Q2. Rubik’s Search
A Rubik’s cube has about 4
.
3
×
10
19
possible configurations, but any configuration can be solved in 20 moves
or less. We pose the problem of solving a Rubik’s cube as a search problem, where the states are the possible
configurations, and there is an edge between two states if we can get from one state to another in a single
move. Thus, we have 4
.
3
×
10
19
states. Each edge has cost 1. Since we can make 27 moves from each state, the
branching factor is 27. Since any configuration can be solved in 20 moves or less, we have
h
∗
(
n
)
≤
20.
For each of the following searches, estimate the approximate number of states expanded. Mark the option that
is closest to the number of states expanded by the search. Assume that the shortest solution for our start state
takes exactly 20 moves. Note that 27
20
is much larger than 4
.
3
×
10
19
.
(a)
DFS Tree Search
(i)
Best Case:
'!
20
*$
4
.
3
×
10
19
*$
27
20
*$
∞
(never finishes)
(ii)
Worst Case:
*$
20
*$
4
.
3
×
10
19
*$
27
20
'!
∞
(never finishes)
(b)
DFS graph search
(i)
Best Case:
'!
20
*$
4
.
3
×
10
19
*$
27
20
*$
∞
(never finishes)
(ii)
Worst Case:
*$
20
'!
4
.
3
×
10
19
*$
27
20
*$
∞
(never finishes)
(c)
BFS tree search
(i)
Best Case:
*$
20
*$
4
.
3
×
10
19
'!
27
20
*$
∞
(never finishes)
(ii)
Worst Case:
*$
20
*$
4
.
3
×
10
19
'!
27
20
*$
∞
(never finishes)
(d)
BFS graph search
(i)
Best Case:
*$
20
'!
4
.
3
×
10
19
*$
27
20
*$
∞
(never finishes)
(ii)
Worst Case:
*$
20
'!
4
.
3
×
10
19
*$
27
20
*$
∞
(never finishes)
(e)
A* tree search with a perfect heuristic, h*(n), Best Case
'!
20
*$
4
.
3
×
10
19
*$
27
20
*$
∞
(never finishes)
(f)
A* tree search with a bad heuristic, h(n) = 20 - h*(n), Worst Case
*$
20
*$
4
.
3
×
10
19
'!
27
20
*$
∞
(never finishes)
(g)
A* graph search with a perfect heuristic, h*(n), Best Case
'!
20
*$
4
.
3
×
10
19
*$
27
20
*$
∞
(never finishes)
(h)
A* graph search with a bad heuristic, h(n) = 20 - h*(n), Worst Case
*$
20
'!
4
.
3
×
10
19
*$
27
20
*$
∞
(never finishes)
3
Your preview ends here
Eager to read complete document? Join bartleby learn and gain access to the full version
- Access to all documents
- Unlimited textbook solutions
- 24/7 expert homework help
Q3. CSPs: Potluck Pandemonium
The potluck is coming up and the staff haven’t figured out what to bring yet! They’ve pooled their resources
and determined that they can bring some subset of the following items.
1. Pho
2. Apricots
3. Frozen Yogurt
4. Fried Rice
5. Apple Pie
6. Animal Crackers
There are five people on the course staff: Taylor, Jonathan, Faraz, Brian, and Alvin. Each of them will only
bring one item to the potluck.
i. If (F)araz brings the same item as someone else, it cannot be (B)rian.
ii. (A)lvin has pho-phobia so he won’t bring Pho, but he’ll be okay if someone else brings it.
iii. (B)rian is no longer allowed near a stove, so he can only bring items 2, 3, or 6.
iv. (F)araz literally can’t even; he won’t bring items 2, 4, or 6.
v. (J)onathan was busy, so he didn’t see the last third of the list. Therefore, he will only bring item 1, 2, 3,
or 4.
vi. (T)aylor will only bring an item that is before an item that (J)onathan brings.
vii. (T)aylor is allergic to animal crackers, so he won’t bring item 6. (If someone else brings it, he’ll just stay
away from that table.)
viii. (F)araz and (J)onathan will only bring items that have the same first letter (e.g. Frozen Yogurt and Fried
Rice).
ix. (B)rian will only bring an item that is after an item that (A)lvin brings on the list.
x. (J)onathan and (T)aylor want to be unique; they won’t bring the same item as anyone else.
(a)
Which of the listed constraints are unary constraints?
□
i
■
ii
■
iii
■
iv
■
v
□
vi
■
vii
□
viii
□
ix
□
x
(b)
Rewrite implicit constraint viii. as an explicit constraint.
(F, J)
∈ {
(3, 4), (4, 3),
(2, 5), (5, 2),
(2, 6), (6, 2),
(5, 6), (6, 5),
(1, 1), (2, 2), (3, 3),
(4, 4), (5, 5), (6, 6)
}
4
(c)
How many edges are there in the constraint graph for this CSP?
There are 9 edges in this constraint graph.
(d)
The table below shows the variable domains after all unary constraints have been enforced.
A
2
3
4
5
6
B
2
3
6
F
1
3
5
J
1
2
3
4
T
1
2
3
4
5
Following the MRV heuristic, which variable should we assign first? Break all ties alphabetically.
*$
A
'!
B
*$
F
*$
J
*$
T
(e)
To decouple this from the previous question, assume that we choose to assign (F)araz first. In this question,
we will choose which value to assign to using the Least Constraining Value method.
To determine the number of remaining values, enforce arc consistency to prune the domains. Then, count
the total number of possible assignments (
not
the total number of remaining values). It may help you
to enforce arc consistency twice, once before assigning values to (F)araz, and then again after assigning a
value.
(i)
Assigning F =
1
results in
0
possible assignments.
Assigning F = 1 leaves no possible values in J’s domain (due to constraint viii).
(ii)
Assigning F =
3
results in
5
possible assignments.
Assigning F = 3 leaves J’s domain as
{
4
}
. Enforcing arc consistency gives A =
{
2
,
3
,
5
}
, B =
{
6
}
, and T
=
{
1
,
2
}
. Therefore, the 5 possible assignments are (A, B, F, J, T) = (2, 6, 3, 4, 1), (3, 6, 3, 4, 1), (5, 6,
3, 4, 1), (3, 6, 3, 4, 2), (5, 6, 3, 4, 2).
(iii)
Assigning F =
5
results in
3
possible assignments.
Assigning F = 5 leaves J’s domain as
{
2
}
. Enforcing arc consistency gives A =
{
3
,
4
,
5
}
, B =
{
6
}
, and T
=
{
1
}
. Therefore, the 3 possible assignments are (A, B, F, J, T) = (3, 6, 5, 2, 1), (4, 6, 5, 2, 1), (5, 6, 5,
2, 1).
(iv)
Using the LCV method, which value should we assign to F? If there is a tie, choose the lower number.
*$
1
*$
2
'!
3
*$
4
*$
5
*$
6
5
Related Documents
Recommended textbooks for you
data:image/s3,"s3://crabby-images/b07d2/b07d213e918ba3400fad4d1f9e78c04885a77c1c" alt="Text book image"
Operations Research : Applications and Algorithms
Computer Science
ISBN:9780534380588
Author:Wayne L. Winston
Publisher:Brooks Cole
data:image/s3,"s3://crabby-images/1d7e7/1d7e7583d6f456277727f8d158d820c51233aa30" alt="Text book image"
C++ for Engineers and Scientists
Computer Science
ISBN:9781133187844
Author:Bronson, Gary J.
Publisher:Course Technology Ptr
data:image/s3,"s3://crabby-images/f69b6/f69b6127845775e68542aa44ed44f5dcebe26fad" alt="Text book image"
Microsoft Visual C#
Computer Science
ISBN:9781337102100
Author:Joyce, Farrell.
Publisher:Cengage Learning,
data:image/s3,"s3://crabby-images/76250/762503ef8bed15d929593c1ab492e2e2028e039d" alt="Text book image"
EBK JAVA PROGRAMMING
Computer Science
ISBN:9781337671385
Author:FARRELL
Publisher:CENGAGE LEARNING - CONSIGNMENT
Recommended textbooks for you
- Operations Research : Applications and AlgorithmsComputer ScienceISBN:9780534380588Author:Wayne L. WinstonPublisher:Brooks ColeC++ for Engineers and ScientistsComputer ScienceISBN:9781133187844Author:Bronson, Gary J.Publisher:Course Technology PtrMicrosoft Visual C#Computer ScienceISBN:9781337102100Author:Joyce, Farrell.Publisher:Cengage Learning,
- EBK JAVA PROGRAMMINGComputer ScienceISBN:9781337671385Author:FARRELLPublisher:CENGAGE LEARNING - CONSIGNMENT
data:image/s3,"s3://crabby-images/b07d2/b07d213e918ba3400fad4d1f9e78c04885a77c1c" alt="Text book image"
Operations Research : Applications and Algorithms
Computer Science
ISBN:9780534380588
Author:Wayne L. Winston
Publisher:Brooks Cole
data:image/s3,"s3://crabby-images/1d7e7/1d7e7583d6f456277727f8d158d820c51233aa30" alt="Text book image"
C++ for Engineers and Scientists
Computer Science
ISBN:9781133187844
Author:Bronson, Gary J.
Publisher:Course Technology Ptr
data:image/s3,"s3://crabby-images/f69b6/f69b6127845775e68542aa44ed44f5dcebe26fad" alt="Text book image"
Microsoft Visual C#
Computer Science
ISBN:9781337102100
Author:Joyce, Farrell.
Publisher:Cengage Learning,
data:image/s3,"s3://crabby-images/76250/762503ef8bed15d929593c1ab492e2e2028e039d" alt="Text book image"
EBK JAVA PROGRAMMING
Computer Science
ISBN:9781337671385
Author:FARRELL
Publisher:CENGAGE LEARNING - CONSIGNMENT