Assignment 2
Written Assignment - Game Playing, CSPs & Logic
Max possible score:
- 4308: 150 Points (+5 Points EC)
- 5360: 150 Points (+5 Points EC)
Task 1
Max:
[4308: 20 Points,
5360: 20 Points]
Figure 1: A game search tree.
a. (4308: 8 points, 5360: 8 points) In the game search tree of
Figure 1, if we use Minmax algorithm to find the strategy to use,
indicate the minmax values are for all the nodes. Also incidcate which
action the Minmax algorithm
will pick to exectute.
b. (4308: 7 points, 5360: 7 points)
In the game search tree of Figure 1, indicate what nodes will be pruned
using alpha-beta search, and what the minmax values are for
the rest of the nodes. Assume that alpha-beta
search expands nodes in a left-to-right order. Finally incidcate which
action the Minmax algorithm
will pick to exectute. Is this answer different from part a?
c. (4308: 5 points, 5360: 5 points) This question is also on
the game search tree
of Figure 1. Suppose we are given some additional knowledge about the
game: the maximum utility value is 12 i.e., it is not mathematically
possible for the MAX player to get an outcome greater than 12 and the
minimum utility value is 2 i.e., it is not mathematically
possible for the MIN player to get an outcome lower than 2. How can
this knowledge be used to further improve the efficiency of alpha-beta
search? Indicate the nodes that will be pruned using this improvement.
Again, assume that alpha-beta search expands
nodes in a left-to-right order.
Task 2
Max: [4308: 10 Points,
5360: 10 Points]
Suppose that you want to implement an algorithm that will compete on a
two-player deterministic game of perfect information. Your opponent is
a supercomputer called DeepGreen. DeepGreen does not use Minimax. You
are given a library function DeepGreenMove(S), that takes any state S
as an argument, and returns the move that DeepGreen will choose for
that state S (more precisely, DeepGreenMove (S) returns the state
resulting from the opponent's move).
Write
an algorithm in pseudocode (following the style of the Minimax
pseudocode) that will always make an optimal decision given the
knowledge we have about DeepGreen. You are free to use the library
function DeepGreenMove(S) in your pseudocode. What advantage would this
algorithm have over Minimax? (if none, Justify).
Task 3
Max: [4308: 10 Points,
5360: 10 Points]
Figure 2: An Expectiminmax tree.
Find
the value of every non-terminal node in the expectiminmax tree given
above. Also indicate which action will be performed by the algoirithm.
What is lowest and highest possible outcome of a single game if the
minmax strategy is followed against an optimal opponent?
Task 4
Max: [4308: 35 Points (+5 Pts EC),
5360: 35 Points (+5 Pts EC)]
Consider the following map.
Figure 3: Outline of a Map
The problem is to color the sections such that no two sections
sharing a border have the same color. You are allowed to use the colors
(Red, Green, Blue).
Part a (8 points): Draw
the Constraint Graph for this problem.
Part b (10 points):
Assuming you are using Backtracking search to solve this problem and
that you are using MRV with Degree heuristic to select the
variable, Which variable will be selected at each level of the search
tree [You do not need to draw the tree. Just let me know which variable
will be selected and why (MRV and degree values)]. Note: Multiple
possible correct answers. You only have to give one.
Part c (12 points): Assume you assign the color 'Red' to the
first
variable selected in part b. Show the steps involved in checking the
remaining legal values for all other variables using Arc Consistency.
Part d (5 points): Can you use structure of the problem to make
solving it more efficient?
Part e: (5 points EC): Give one valid solution to this
problem. (You just have to give the solution. No need to give all the
steps)
Task 5
Max: [4308: 8 Points,
5360: 8 Points]
A |
B |
C |
KB |
S1 |
True |
True |
True |
True |
True |
True |
True |
False |
False |
True |
True |
False |
True |
True |
True |
True |
False |
False |
False |
True |
False |
True |
True |
False |
False |
False |
True |
False |
False |
False |
False |
False |
True |
True |
True |
False |
False |
False |
False |
False |
KB and S1 are two propositional logic statements, that are constructed
using symbols A, B, C, and using various connectives. The above truth
table shows, for each combination of values of A, B, C, whether KB and
S1 are true or false.
Part a: Given the above
information, does KB entail S1? Justify your answer.
Part b: Given the above
information, does statement NOT(KB) entail statement NOT(S1)? Justify
your answer.
Task 6
Max: [4308: 8 Points,
5360: 8 Points]
Suppose that some knowledge base contains various
propositional-logic sentences that utilize symbols A, B, C, D
(connected with various connectives). There are only two cases when the
knowledge base is false:
- First case: when A is true, B is false, C is true, D is true.
- Second case: when A is false, B is false, C is true, D is false.
In all other cases, the knowledge base is true. Write a conjunctive
normal form (CNF) for the knowledge base.
Task 7
Max: [4308: 24 Points,
5360: 24 Points]
Consider the KB
A => C
B <=> C
D => A
(B AND E) => G
B => F
E
D
Show that this entails G (if possible) by
i. Forward Chaining
ii. Backward Chaining
iii. Resolution
Task 8
Max: [4308: 35 Points,
5360: 35 Points]
John and Mary sign the following contract:
- If it rains on Monday, then John must give Mary a check for
$100 on Tuesday
- If John gives Mary a check for $100 on Tuesday, Mary must mow
the lawn on Wednesday.
What truly happened those days is the following:
- It did not rain on Monday
- John gave Mary a check for $100 on Tueday
- Mary mowed the lawn on Wednesday.
Part a (10 pts): Write a first order logic
statement to express the contract. Make sure that you clearly define
what constants and predicates that you use are. (NOTE: DO NOT use
functions)
Part b (8 pts): Write a logical
statement to
express what truly happened. When possible, use the same predicates and
constants as in
question 6a. If you need to define any new predicates or constants,
clearly define what
they stand for.
Part c (12 pts): Define the symbols
required to convert any KB involved in the above
domanin from FOL to Propositional logic. Use this to convert the
answers to part a and b to Propositional Logic.
Part d (5 pts):
Was the contract violated
or not, Justify your answer [Note: Contract is definitely not violated
if the events entail the contract. Contract is definitly violated if
the events entail the opposite of the contract. Unknown otherwise]