Welcome! This is the codebase for assignments of our reinforcement learning (RL) course.
As this course is still polishing and growing, please feel free to open issues if you find anything wrong or confusing in codes or documents in this repository. We will respond to you as soon as possible. If you get stuck or mess up, take a look at the latest version of this repo may help, since somebody may already raise issues and bug is fixed by new commits.
Follow the instruction in each assignment's README.md
to submit your work.
We appreciate you for suggestion and contribution to improve this course!
Generally, the way you use this repo is:
- Check the latest release at the time the tutor announced a new assignment is coming.
- Read the assignment document, which is the
README.md
at each assignment directory. - Fork this repo and clone it to your computer.
- Create a new branch and do your assignment on it. * (This is to avoid messing up when new assignment is released.)
- Fill the empty functions or slots or cells we left for you.
- Follow the instructions in code comments to check if everything works well.
- Submit materials to correspondent staff, following the submission instruction in the assignments.
Beautiful codes and comments make extra credits. Our aesthetic standard is PEP 8.
Note *: The commands to create a new branch is:
git clone https://github.com/YOUR_GITHUB_ACCOUNT/ierg5350-assignment.git
cd ierg5350-assignment
git checkout -b solution # This line creates and checkout to a new branch named `solution`
# Now, you are in `solution` branch now!
Since the assignments are released one by one, you need to sync your local repo with the latest official repo when new assignment is released. Our suggesting procedure is:
- setup the official repo as another git remote:
git clone https://github.com/YOUR_GITHUB_ACCOUNT/ierg5350-assignment.git
cd ierg5350-assignment
git remote add upstream https://github.com/whoever/whatever.git
(by using this command, you have created a new remote named upstream
)
- checkout to the master branch of your forked repo:
git checkout master
- pull the latest contents from the official repo:
git pull upstream master
(by using this command, you have pulled the new commits from the branch namedmaster
in the remote namedupstream
) - Now, let's checkout to your own branch (where the previous assignment is finished)
git checkout solution
- Merge the latest content in
master
into your solution branch:git merge master
In this course, we assume you already have the basic knowledge of python. In each assignment, we will import some useful packages like the reinforcement learning environment Gym, scientific computing Numpy, machine learning framework PyTorch etc.
We will list the packages required at each assignment. So till now, you only need to set up your python environment firstly. We highly recommend you to use python 3, since python 2 is gradually getting deprecated in the community. If you already have one, then you can skip the next section.
The general procedure of environment setup is:
- Prepare your python environment
- Install Jupyter notebook and Gym as they are used at each assignment
- Install packages we listed in each assignment
- If you use other packages, list their names and versions in your report
We recommend you to use a virtual environment to setup the python environment. It is optional, but has many advantages for doing this:
- The packages installed during this course will not affect other projects on your computers since the environment is independent.
- Other members can run your codes in this course seamless. Since we all using the same environment and packages.
- The robustness and compatibility of codes is also an important criterion to assess your completion of assignments. This is because if the program is not runnable at TA's computer, your code is considered as not runnable.
- In your future research career, a clear code management is highly important.
We recommend you to use anaconda python environments. First, download the package and install anaconda following the instruction at https://www.anaconda.com/distribution/
Then create your environment via typing command line:
conda create -n ierg5350 python=3.7
By doing this, you created an environment name ierg5350
with python 3.7 installed. Then you need to activate your environment:
conda activate ierg5350
If you activate your environment successfully, you will see (ierg5350) COMPUTERNAME:~ USERNAME$
at your shell.
Then you can install the packages we listed at each assignment like:
pip install XXX=1.0.0
where the XXX==1.0.0
means to install package XXX
with the specified version 1.0.0
. The packages' names and versions will be listed at each assignment.
If you use other packages that you think helpful, you need to list them with the version number at your report. Make sure the extra package DO NOT help you to finish the essential part of the assignment. The following example is NOT acceptable.
import numpy as np
from CheatingKLDivergencePackage import get_kl
def compute_kl(dist1, dist2):
"""
Problem 1: You need to implement the computing of KL
Divergence given two distribution instances.
You should only use numpy package.
The return should be a float that greater than 0.
"""
return get_kl(dist1, dist2)
In some assignments, we may provide you with a single jupyter notebook file. Note that we use the "classic jupyter notebook" instead of the latest jupyter lab. Before you open it, you need to install the package (if you use a virtual environment, remember to activate it before installation)
# activate your environment
conda activate ierg5350
# install it
pip install notebook
Now you have installed the jupyter notebook, type the following commands to run:
# activate your environment
conda activate ierg5350
# go to the root directory
cd ierg5350-assignment
jupyter notebook
Now you have opened up a jupyter notebook at your server. Open your browser and go to http://localhost:8888
(8888 is the port number, you can change it by starting jupyter notebook via jupyter notebook --port 8889
).
Now click into FILE.ipynb
and start coding!
For more information, please visit: https://jupyter.org/install.html
Gym provides you many handy RL environments (this "environment" is different from the "python environment" previously seen), so you can easily use the interfaces to conduct your RL research. For example, you do not need to implement a Go game to train your alphaGo, you only need to call the API provided by Gym. By the way, in this course, we do not require you to implement alphaGo.
To install Gym, in command line type:
# activate your environment
conda activate ierg5350
# install it
pip install gym
This is it. Now you can run it in ipython for a little test.
# type in command line (ipython should already be installed by anaconda)
ipython
# If ipython is not install, try:
# conda install ipython
Now you have enter ipython, copy and paste:
import gym
env = gym.make('CartPole-v0')
env.reset()
for _ in range(500):
env.render()
# take a random action
obs, reward, done, info = env.step(env.action_space.sample())
if done:
env.reset() # press q to quit
env.close()
You will see a window pop up at your computer. Type quit()
and enter in ipython to leave.
Congratulation, you have installed gym. Now click the directory and start your assignments!
2020-2021 Term 1, IERG 5350: Reinforcement Learning. Department of Information Engineering, The Chinese University of Hong Kong. Course Instructor: Professor ZHOU Bolei. Assignment author: PENG Zhenghao, SUN Hao, ZHAN Xiaohang.