You heard about the amazing results achieved by Deepmind with AlphaGo Zero and by OpenAI in Dota 2! Don't you want to know how they work? This is the right opportunity for you and me to finally learn Deep RL and use it on new exciting projects.
The ultimate aim is to use these general-purpose technologies and apply them to all sorts of important real world problems. Demis Hassabis
This repository wants to guide you through the Deep Reinforcement Learning algorithms, from the most basic ones to the highly advanced AlphaGo Zero. You will find the main topics organized by week and the resources suggested to learn them. Also, every week I will provide practical examples implemented in python to help you better digest the theory. You are highly encouraged to modify and play with them!
Now we have also a Slack channel. To get an invitation, email me at [email protected]
This is my first project of this kind, so please, if you have any idea, suggestion or improvement contact me at [email protected].
To learn Deep Learning, Computer Vision or Natural Language Processing check my 1-Year-ML-Journey
- Basic level of Python and PyTorch
- Machine Learning
- Basic knowledge in Deep Learning (MLP, CNN and RNN)
- Week 1 - Introduction
- Week 2 - RL Basics
- Week 3 - Value Function Approximation and DQN
- Week 4 - Policy gradient methods and A2C
- Week 5 - Advanced Policy Gradients - TRPO & PPO
- Week 6 - Evolution Strategies and Genetic Algorithms
- Week 7 - Model-Based reinforcement learning
- Week 8 - Advanced Concepts and Project Of Your Choice
- Last 4 days - Review + Sharing
- Best resources
- Additional resources
- An introduction to Reinforcement Learning by Arxiv Insights
- Introduction and course overview - CS294 by Levine
- Deep Reinforcement Learning: Pong from Pixels by Karpathy
- Great introductory paper: Deep Reinforcement Learning: An Overview
- Start coding: From Scratch: AI Balancing Act in 50 Lines of Python
Those who cannot remember the past are condemned to repeat it - George Santayana
This week, we will learn about the basic blocks of reinforcement learning, starting from the definition of the problem all the way through the estimation and optimization of the functions that are used to express the quality of a policy or state.
- Markov Decision Process RL by David Silver
- Markov Processes
- Markov Decision Processes
- Planning by Dynamic Programming RL by David Silver
- Policy iteration
- Value iteration
- Model-Free Prediction RL by David Silver
- Monte Carlo Learning
- Temporal Difference Learning
- TD(ฮป)
- Model-Free Control RL by David Silver
- ฦ-greedy policy iteration
- GLIE Monte Carlo Search
- SARSA
- Importance Sampling
Q-learning applied to FrozenLake. For exercise, you can solve the game using SARSA or implement Q-learning by yourself. In the former case, only few changes are needed.
- ๐ Read chapters 3,4,5,6,7 of Reinforcement Learning An Introduction - Sutton, Barto
- ๐บ Value functions introduction - DRL UC Berkley by Sergey Levine
This week we'll learn more advanced concepts and apply deep neural network to Q-learning algorithms.
- Value functions approximation - RL by David Silver
- Differentiable function approximators
- Incremental methods
- Batch methods (DQN)
- Advanced Q-learning algorithms - DRL UC Berkley by Sergey Levine
- Replay Buffer
- Double Q-learning
- Continous actions (NAF,DDPG)
- Pratical tips
- Playing Atari with Deep Reinforcement Learning - 2013
- Human-level control through deep reinforcement learning - 2015
- Rainbow: Combining Improvements in Deep Reinforcement Learning - 2017
- Deep Reinforcement Learning with Double Q-learning - 2015
- Prioritized Experience Replay - 2015
- Dueling Network Architectures for Deep Reinforcement Learning - 2016
- Noisy networks for exploration - 2017
- Distributional Reinforcement Learning with Quantile Regression - 2017
DQN and some variants applied to Pong
This week the goal is to develop a DQN algorithm to play an Atari game. To make it more interesting I developed three extensions of DQN: Double Q-learning, Multi-step learning, Dueling networks and Noisy Nets. Play with them, and if you feel confident, you can implement Prioritized replay, Dueling networks or Distributional RL. To know more about these improvements read the papers!
Week 4 introduce Policy Gradient methods, a class of algorithms that optimize directly the policy. Also, you'll learn about Actor-Critic algorithms. These algorithms combine both policy gradient (the actor) and value function (the critic).
- Policy gradient Methods - RL by David Silver
- Finite Difference Policy Gradient
- Monte-Carlo Policy Gradient
- Actor-Critic Policy Gradient
- Policy gradient intro - CS294-112 by Sergey Levine (RECAP, optional)
- Policy Gradient (REINFORCE and Vanilla PG)
- Variance reduction
- Actor-Critic - CS294-112 by Sergey Levine (More in depth)
- Actor-Critic
- Discout factor
- Actor-Critic algorithm design (batch mode or online)
- state-dependent baseline
- Policy Gradient methods for reinforcement learning with function approximation
- Asynchronous Methods for Deep Reinforcement Learning
Vanilla PG and A2C The exercise of this week is to implement a policy gradient method or a more sophisticated actor-critic. In the repository you can find an implemented version of PG and A2C. Pay attention that A2C give me strange result. You can try to make it works or implement an asynchronous version of A2C (A3C).
- ๐ Intuitive RL: Intro to Advantage-Actor-Critic (A2C)
- ๐ Asynchronous Actor-Critic Agents (A3C)
This week is about advanced policy gradient methods that improve the stability and the convergence of the "Vanilla" policy gradient methods. You'll learn and implement PPO, a RL algorithm developed by OpenAI and adopted in OpenAI Five.
- Advanced policy gradients - CS294-112 by Sergey Levine
- Problems with "Vanilla" Policy Gradient Methods
- Policy Performance Bounds
- Monotonic Improvement Theory
- Algorithms: NPO, TRPO, PPO
- Natural Policy Gradients, TRPO, PPO - John Schulman, Berkey DRL Bootcamp - (RECAP, optional)
- Limitations of "Vanilla" Policy Gradient Methods
- Natural Policy Gradient
- Trust Region Policy Optimization, TRPO
- Proximal Policy Optimization, PPO
This week, you have to implement PPO or TRPO. I suggest PPO given its simplicity (compared to TRPO). In the project folder Week5 you can find an implementation of PPO that learn to play BipedalWalker. Furthermore, in the folder you can find other resources that will help you in the development of the project. Have fun!
To learn more about PPO read the paper and take a look at the Arxiv Insights's video
NB: the hyperparameters of the PPO implementation I released, can be tuned to improve the convergence.
- ๐ To better understand PPO and TRPO: The Pursuit of (Robotic) Happiness
- ๐บ Nuts and Bolts of Deep RL
- ๐ PPO best practice: Training with Proximal Policy Optimization
- ๐บ Explanation of the PPO algorithm by Arxiv Insights
In the last year, Evolution strategies (ES) and Genetic Algorithms (GA) has been shown to achieve comparable results to RL methods. They are derivate-free black-box algorithms that require more data than RL to learn but are able to scale up across thousands of CPUs. This week we'll look at this black-box algorithms.
- Evolution Strategies
- Genetic Algorithms
- Deep Neuroevolution: Genetic Algorithms are a Competitive Alternative for Training Deep Neural Networks for Reinforcement Learning
- Evolution Strategies as a Scalable Alternative to Reinforcement Learning
The project is to implement a ES or GA. In the Week6 repository you can find a basic implementation of the paper Evolution Strategies as a Scalable Alternative to Reinforcement Learning to solve LunarLanderContinuous. You can modify it to play more difficult environments or add your ideas.
The algorithms studied up to now are model-free, meaning that they only choose the better action given a state. These algorithms achieve very good performance but require a lot of training data. Instead, model-based algorithms, learn the environment and plan the next actions accordingly to the model learned. These methods are more sample efficient than model-free but overall achieve worst performance. In this week you'll learn the theory behind these methods and implement one of the last algorithms.
- Model-Based RL by Davide Silver (Deepmind) (concise version)
- Integrating Learning and Planning
- Model-Based RL Overview
- Integrated architectures
- Simulation-Based search
- Integrating Learning and Planning
- Model-Based RL by Sergey Levine (Berkley) (in depth version)
- Learning dynamical systems from data
- Overview of model-based RL
- Global and local models
- Learning with local models and trust regions
- Learning policies by imitating optimal controllers
- Backpropagation into a policy with learned models
- Guided policy search algorithm
- Imitating optimal control with DAgger
- Advanced model learning and images
- Models in latent space
- Models directly in image space
- Inverse models
- Learning dynamical systems from data
- Imagination-Augmented Agents for Deep Reinforcement Learning - 2017
- Reinforcement learning with unsupervised auxiliary tasks - 2016
- Neural Network Dynamics for Model-Based Deep Reinforcement Learning with Model-Free Fine-Tuning - 2018
As a project, I chose to implement the model-based algorithm described in this paper. You can find my implementation here. NB: Instead of implementing it on Mujoco as in the paper, I used RoboSchool, an open-source simulator for robot, integrated with OpenAI Gym.
This last week is about advanced RL concepts and a project of your choice.
- Sergey Levine (Berkley)
- David Silver (Deepmind)
Here you can find some project ideas.
- Pommerman (Multiplayer)
- AI for Prosthetics Challenge (Challenge)
- Word Models (Paper implementation)
- Request for research OpenAI (Research)
- Retro Contest (Transfer learning)
- AlphaGo Zero
- Paper
- DeepMind blog post: AlphaGo Zero: Learning from scratch
- Arxiv Insights video: How AlphaGo Zero works - Google DeepMind
- OpenAI Five
- OpenAI blog post: OpenAI Five
- Arxiv Insights video: OpenAI Five: Facing Human Pro's in Dota II
Congratulation for completing the 60 Days RL Challenge!! Let me know if you enjoyed it and share it!
See you!
๐บ Deep Reinforcement Learning - UC Berkeley class by Levine, check here their site.
๐บ Reinforcement Learning course - by David Silver, DeepMind. Great introductory lectures by Silver, a lead researcher on AlphaGo. They follow the book Reinforcement Learning by Sutton & Barto.
๐ Reinforcement Learning: An Introduction - by Sutton & Barto. The "Bible" of reinforcement learning. Here you can find the PDF draft of the second version.
๐ Awesome Reinforcement Learning. A curated list of resources dedicated to reinforcement learning
๐ GroundAI on RL. Papers on reinforcement learning