2019-10-19 20:43:17html
This paper is from: https://medium.com/data-from-the-trenches/curiosity-driven-learning-through-next-state-prediction-f7f4e2f592fa ios
In the last few years, we’ve seen a lot of breakthroughs in reinforcement learning (RL). From 2013 with the first deep learning model to successfully learn a policy directly from pixel input using reinforcement learning to the OpenAI Dexterity project in 2019, we live in an exciting moment in RL research.git
Today, we’ll learn about curiosity-driven learning methods, one of the most promising series of strategies in deep reinforcement learning. Thanks to this method, we were able to successfully train an agent that wins the first level of Super Mario Bros with only curiosity as a reward.github
Remember that RL is based on the reward hypothesis, which is the idea that each goal can be described as the maximization of the rewards. However, the current problem with extrinsic rewards (i.e., rewards given by the environment) is that this function is hard coded by a human, which is not scalable to real world problems (such as designing a good reward function for autonomous vehicles).vim
The idea of curiosity-driven learning is to build a reward function that is intrinsic to the agent (that is generated by the agent itself). In this sense, the agent will act as a self-learner since it will be the student, but also its own feedback master.app
Sound crazy? Yes, probably. But that’s the genius idea that was re-introduced in the 2017 paper Curiosity-Driven Exploration by Self-Supervised Prediction. The results were then improved with the second paper Large-Scale Study of Curiosity-Driven Learning. Why re-introduced? Because curiosity has been a subject of research in RL since the 90s with the amazing work of Mr. J. Schmidhuber, which you can read here.less
They discovered that curiosity-driven learning agents perform as well as if they had extrinsic rewards and that they were able to generalize better with unexplored environments.dom
Modern RL suffers from two problems:ide
First, the sparse rewards or non-existing rewards problem: that is, most rewards do not contain information, and hence are set to zero. However, as rewards act as feedback for RL agents, if they don’t receive any, their knowledge of which action is appropriate (or not) cannot change.post
For instance, in Vizdoom 「DoomMyWayHome,」 your agent is only rewarded if it finds the vest. However, the vest is far away from your starting point, so most of your rewards will be zero.
Therefore, if our agent does not receive useful feedback (dense rewards), it will take much longer to learn an optimal policy.
The second big problem is that the extrinsic reward function is handmade — that is, in each environment, a human has to implement a reward function. But how we can scale that in big and complex environments?
Therefore, a solution to these problems is to develop a reward function that is intrinsic to the agent, i.e., generated by the agent itself. This intrinsic reward mechanism is known as curiosity because it explores states that are novel/unfamiliar. In order to achieve that, our agent will receive a high reward when exploring new trajectories.
This reward design is based on how human plays — some suppose we have an intrinsic desire to explore environments and discover new things! There are different ways to calculate this intrinsic reward, and we’ll focus on this article on curiosity through next-state prediction.
Curiosity is an intrinsic reward that is equal to the error of our agent of predicting the next state, given the current state and action taken. More formally, we can define this as:
Why? Because the idea of curiosity is to encourage our agent to perform actions that reduce the uncertainty in the agent’s ability to predict the consequences of its own actions (uncertainty will be higher in areas where the agent has spent less time, or in areas with complex dynamics).
Let’s break it down further. Say you play Super Mario Bros:
Consequently, measuring error requires building a model of environmental dynamics that predicts the next state given the current state and the action. The question that we can ask here is: how we can calculate this error?
To calculate curiosity, we will use a module introduced in the first paper called Intrinsic Curiosity module.
Before diving into the description of the module, we must ask ourselves: how can our agent predict the next state given our current state and our action?
But we can’t predict s(t+1) by predicting the next frame as we usually do. Why?
First, because it’s hard to build a model that is able to predict high-dimension continuous state space, such as an image. It’s hard to predict the pixels directly, but now imagine you’re in Doom, and you move left — you need to predict 248*248 = 61504 pixels!
It means that in order to generate curiosity, we can’t predict the pixels directly and need to use a better feature representation by projecting the raw pixels space into a feature space that will hopefully only keep the relevant information elements that can be leveraged by our agent.
Three rules are defined in the original paper for a good representation feature space:
The second reason we can’t predict s(t+1) by predicting the next frame as we usually do? It might just not be the right thing to do:
Imagine you need to study the movement of the tree leaves in a breeze. First of all, it’s already hard enough to model breeze, so predicting the pixel location of each leaves at each time step is even harder.
So instead of making predictions in the raw sensory space (pixels), we need to transform the raw sensory input (array of pixels) into a feature space with only relevant information.
Let’s take this example: your agent is a self driving car. If we want to create a good feature representation, we need to model:
A good feature representation would be our car (controlled by our agent) and the other cars (we can’t control it, but that can affect the agent), but we don’t need to model the leaves (it doesn’t affect the agent, and we can’t control it). By only keeping this information, we will have a feature representation with less noise.
The desired embedding space should:
In order to calculate the predicted next state and the real feature representation of the next state, we can use an Intrinsic Curiosity Module (ICM).
The ICM Module is the system that helps us to generate curiosity. It’s composed of two neural networks; each of them has an important task.
The Inverse Model (g), aims at predicting the action â(t), and in doing so, it learns an internal feature representation of the state and next state, denoted by Φ(s(t)) and Φ(s(t+1)).
You may ask, why do we need to predict the action if we want Φ(s(t)) and Φ(s(t+1))? Remember that we want our state representations to only consider elements that can affect our agent or that it can control.
Since this neural network is only used to predict the action, it has no incentive to represent within its feature embedding space the factors of variation in an environment that does not affect the agent itself.
Lastly, the inverse model loss is given by the cross entropy between our predicted action â(t) and the real action a(t):
The Forward Model (f), predicts the feature representation of next state hat_Φ(s(t+1)) given Φ(s(t)) and a(t).
Consequently, curiosity will be a real number, i.e., the L2 normed difference between our predicted feature vector of the next state hat_Φ(s(t+1)) (predicted by the Forward Model) and the real feature vector of the next state Φ(s(t+1)) (generated by the Inverse Model).
Finally, the overall optimization problem of this module is a composition of Inverse Loss and Forward Loss.
And we provide the prediction error of the forward dynamics model to the agent as an intrinsic reward to encourage its curiosity.
That was a lot of information and mathematics!
To recap:
We wanted to see if our agent was able to play Super Mario Bros using only curiosity as reward. In order to do that, we used the official implementation of Deepak Pathak et al.
We trained our agent on 32 parallel environments for 15 hours on a small NVIDIA GeForce 940M GPU.
We can see in this video that our agent was able to beat the first level of Super Mario Bros without extrinsic rewards. This proves the fact that curiosity is a good reward to train our agent.
That’s all for today! Now that you understand the theory, you should read the two papers’ experiment results Curiosity-driven Exploration by Self-supervised Prediction and Large-Scale Study of Curiosity-Driven Learning.
Next time, we’ll learn about random network distillation and how it solves a major problem of ICM: the procrastinating agents.