讲解MLNC、辅导Matlab编程语言、讲解CID留学生、辅导Matlab语言
- 首页 >> Matlab编程October 25, 2018
MLNC – Machine Learning & Neural Computation – Dr Aldo Faisal
Coursework 1 - Grid World
To be returned via Blackboard as indicated online.
Your coursework should contain: your name, your CID and your degree course at the top of the first
page. You text should provide brief analytical derivations and calculations as necessary in-line, so that
the markers can understand what you did. Please use succinct answers to the questions. Your final
document should be submitted as a single .zip file, containing one single PDF file, in the format of
CID FirstnameLastname.pdf (example: 012345678 JaneXu.pdf), and one single .m file, also in the
format CID FirstnameLastname.m. Note, that therefore all code that you have written or modified must
be within that one Matlab file. Do not submit multiple Matlab files, do not modify other Matlab files.
Your Matlab script should contain a function that takes no arguments and is called RunCoursework(),
that should produce all the Matlab-based results of your coursework (in clearly labelled text and/or figure
output). This function should be able to run on its own, in a clean Matlab installation and directory with
only the code we provided for the coursework present.
Please additionally paste the same fully-commented Matlab source code in the appendix of your PDF
submission. You are allowed to use all built-in Matlab functions and any Matlab functions supplied by
the course or written by you.
The markers may subtract points for badly commented code, coding that does not run and coding that
does not follow the specifications. Figures should be clearly readable, labelled and visible – poor quality
or difficult to understand figures may result in a loss of points.
Your coursework should not be longer than 4 single sided pages with 2 centimetre margins all around
and 12pt font. You are encouraged to discuss with other students, but your answers should be yours, i.e.,
written by you, in your own words, showing your own understanding. You have to produce your own
code. If you have questions about the coursework please make use of labs or Piazza, but note that GTAs
cannot provide you with answers that directly solve the coursework.
Marks are shown next to each question. Note that the marks are only indicative.
Figure 1: Grid World
This coursework uses the simple Grid World shown in Figure 1. There are 14 states, corresponding to locations
on a grid – two cells (marked in grey) are walls and therefore cannot be occupied. This Grid World has two
terminal states, s2 (the Goal state, in green) and s3 (the Penalty state, in red).
The starting state can vary. In each simulation there is an equal probability of starting from one of the
states s11, s12, s13, s14 (i.e. there is 1
4 probability of starting from any of these states).
Possible actions in this world are N, E, S and W (North, East, South, West), which correspond to
moving in the four cardinal directions of the compass.
The effects of actions are not deterministic, and only succeed in moving in the desired direction with
probability p. Alternatively, the agent will move perpendicular to its desired direction in either adjacent
direction with probability (1p)
2 . After the movement direction is determined, and if a wall blocks the agent’s path, then the agent will stay
where it is, otherwise it will move to the corresponding adjacent. So for example, in the grid world where
p = 0.8, an agent at state s5 which chooses to move north will move north to state s1 with probability
0.8; will move east to state s6 with probability 0.1; or will move west staying in state s5 with probability
0.1 (in which case it will bang into the wall and come to rest in state s5).
The agent receives a reward of 1
for every transition (i.e. a movement cost), except those movements
ending in state s3 (marked P for penalty) or state s2 (marked with G for goal). For transitioning to s3
there is a penalty of 10.
For transitioning to s2 there is a reward of 0.
We provide the code PersonalisedGridWorld.p. It contains the function that sets up the Grid World
with p probability of successful transition and returns the full MDP information. Note that .p files are
similar to normal Matlab functions/scripts, but are not human-readable (i.e. you do not/should not edit
it).
2
>> [NumStates, NumActions, TransitionMatrix, ...
RewardMatrix, StateNames, ActionNames, AbsorbingStates] ...
= PersonalisedGridWorld(p);
With NumStates being the number of states in the Grid World, and NumActions the number of actions
the agent can take. The TransitionMatrix is a NumStates ? NumStates NumActions
array of specified transition probabilities between (first dimension) successor state, (second dimension)
prior state, and (third dimension) action. RewardMatrix is the NumStates NumStates ?
NumActions array of reward values between (first dimension) successor state, (second dimension) prior
state, and (third dimension) action. StateNames is a NumStates1 matrix containing the name of
each state. ActionNames is a NumActions1 matrix containing the name of each action. Finally,
AbsorbingStates is a NumStates1 matrix specifying which states are terminal.
The coursework is personalised by your CID number. Throughout the exercise we set p = 0.5+0.5 x
10 and
= 0.2+0.5 y
10 , where x is the penultimate digit of your College ID (CID), and y is the last digit of your
CID. If your CID is 876543210 we have X = 1 and y = 0 resulting in p = 0.55 and
= 0.2.
Questions
Points per questions are indicative only. Questions become progressively more challenging.
1. (1 point) State your CID and personalised p and
(no need to show derivation).
2. (15 points) Assume the MDP is operating under an unbiased policy u, compute the value function
V u
(s) for every non-terminal state (s1, s4 ...,s14) by any dynamic programming method of your
choice. Report your result in the following format:
State s1 s4 s5 s6 s7 s8 s9 s10 s11 s12 s13 s14
Value 2 2.54 1
3 ...
3. (25 points) Assume you are observing the following state transitions from the above MDP: {s14, s10, s8, s4, s3},
{s11, s9, s5, s6, s6, s2}, {s12, s11, s11, s9, s5, s9, s5, s1, s2}.
(a) What is the likelihood that the above observed 3 sequences were generated by an unbiased policy
Report the value of the likelihood.
(b) Find a policy ?M for the observed 3 sequences that has higher likelihood than the likelihood of u
to have generated these sequences. Report it in the following table format. Note, that as not all
states are visited by these 3 sequences you only have to report the policy for visited, non-transient
states. Report your result using the following format:
State s1 s4 s5 s6 s7 s8 s9 s10 s11 s12 s13 s14
Action N S W ...
4. (39 points)
(a) Assume an unbiased policy u in this MDP. Generate 10 traces from this MDP and write them out.
When writing them out use one line for each trace, use symbols S1, S4, ..., S14, actions N, E, S,
W, and the rewards in the following format (please make sure we can easily copy and paste these
values from the PDF in one go), e.g. the output must be in the following format (so that we can
copy and paste the text from your PDF into our automatic testing software).
S12,W,-1,S11,N,-1,S9,N,-1,S5,N,-1,S1,N,-1,S1,E,0
S14,E,-1,S10,E,-1,S8,W,-1,S7,S,-1,S6,N,0
3
(b) Apply First-Visit Batch Monte-Carlo Policy Evaluation to estimate the value function
from
these 10 traces alone. Report the value function for every non-terminal state (s1, s4 ...,s14) using
the format specified in Question 2.
(c) Quantify the difference between
obtained from Q4.b and
obtained from Q2 by defining
a measure that reports in a single number how similar these two value functions are. Justify your
choice of measure. Then, plot the value of the proposed similarity measure against the number of
traces used. Start plotting the measure using the first trace, then the first and second trace, and so
forth. Comment on how increasing the number of traces affects the similarity measure.
5. (20 points)
(a) Implement -greedy first-visit Monte Carlo control. Evaluate the learning and control for two settings
of , namely 0.1 and 0.75.
For each setting of , plot two types of learning curves:
i. Plot reward against episodes.
ii. Plot trace length per episode against episodes.
Note: An episode is one complete trace. A trial is many episodes starting from an initialisation of
the agent. The learning curves are stochastic quantities, you may need to run a good number of
repeated learning experiments to average out the variability across trials. Specify the number of
trials and plot mean ± standard deviation of your learning curves.