Files
ml_debug/docs/evidence/alexirpan_rl_hard.md
wassname 4393cceefd initial: ML debugging folklore skill
Deep research to uplift LLMs for ML debugging, opinionated by source
selection. Distilled from Schulman, Jones, Rahtz, Goodfellow, CS231n,
FSDL, and more. Includes runnable diagnostic scripts and LLM-specific
anti-patterns.

Author: wassname (https://github.com/wassname)
2026-03-06 10:11:30 +08:00

1104 lines
61 KiB
Markdown
Raw Permalink Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
Source: https://www.alexirpan.com/2018/02/14/rl-hard.html
Title: Deep Reinforcement Learning Doesn't Work Yet - Alex Irpan (2018)
Fetched-via: uvx markitdown https://www.alexirpan.com/2018/02/14/rl-hard.html
Fetch-status: verbatim
[Sorta Insightful](/)
[Reviews](/recs/)
[Projects](/projects/)
[Puzzles](/puzzles/)
[Archive](/archive/)
[Research](/research/)
[About](/about/)
[![](/public/feed-icon.png)](/feed.xml)
In a world where everyone has opinions, one man...also has opinions
# Deep Reinforcement Learning Doesn't Work Yet
Feb 14, 2018
*June 24, 2018 note: If you want to cite an example from the post, please
cite the paper which that example came from. If you want to cite the
post as a whole, you can use the following BibTeX:*
```
@misc{rlblogpost,
title={Deep Reinforcement Learning Doesn't Work Yet},
author={Irpan, Alex},
howpublished={\url{https://www.alexirpan.com/2018/02/14/rl-hard.html}},
year={2018}
}
```
---
*This mostly cites papers from Berkeley, Google Brain, DeepMind, and OpenAI
from the past few years, because that work is most visible to me.
Im almost certainly missing stuff from older literature and other
institutions, and for that I apologize - Im just one guy, after all.*
# Introduction
Once, on Facebook, I made the following claim.
> Whenever someone asks me if reinforcement learning can solve their problem, I tell them it cant. I think this is right at least 70% of the time.
![Futurama Bender meme](/public/rl-hard/bender-70.jpg)
Deep reinforcement learning is surrounded by mountains and mountains of hype. And
for good reasons!
Reinforcement learning is an incredibly general paradigm,
and in principle, a robust and performant RL system should be great at
everything. Merging this paradigm with the empirical power of deep learning
is an obvious fit. Deep RL is one of the closest things that looks anything like
AGI, and thats the kind of dream that fuels billions
of dollars of funding.
Unfortunately, it doesnt really work yet.
Now, I believe it *can* work. If I didnt believe in reinforcement learning,
I wouldnt be working on it.
But there are a lot of problems in the way, many of which feel fundamentally
difficult. The beautiful demos of learned agents hide all the blood, sweat, and
tears that go into creating them.
Several times now, Ive seen people get lured by recent work. They try
deep reinforcement learning for the first time, and without fail, they
underestimate deep RLs difficulties.
Without fail, the “toy problem” is not as easy as it looks. And without fail,
the field destroys them a few times, until they learn how to set realistic
research expectations.
This isnt the fault of anyone in particular. Its more of a systemic problem.
Its easy to write a story around a positive result. Its hard to do the same
for negative ones. The problem is that the negative ones are the ones that
researchers run into the most often. In some ways, the negative cases are
actually more important than the positives.
In the rest of the post, I explain why deep RL doesnt work, cases where
it does work, and ways I can see it working more reliably in the future.
Im not doing this because I want people to stop working on deep RL.
Im doing this because I believe its easier to make progress on problems if
theres agreement on what those problems are, and its easier to build
agreement if people actually talk about the problems, instead of independently
re-discovering the same issues over and over again.
I want to see more deep RL research. I want new people to join the field. I
also want new people to know what theyre getting into.
Before getting into the rest of the post, a few remarks.
* I cite several papers in this post. Usually, I cite the paper for its
compelling negative examples, leaving out the positive ones. **This doesnt
mean I dont like the paper.** I like these papers - theyre worth a read, if
you have the time.
* I use “reinforcement learning” and “deep reinforcement learning”
interchangeably, because in my day-to-day, “RL” always implicitly
means deep RL.
**I am criticizing the empirical behavior of deep reinforcement
learning, not reinforcement learning in general.**
The papers I cite usually represent the agent with a deep neural net.
Although the empirical criticisms *may* apply to linear RL or tabular RL, Im not
confident they generalize to smaller problems.
The hype around deep RL is driven by the promise of applying RL to large, complex,
high-dimensional environments where good function approximation is necessary.
It is that hype in particular that needs to be addressed.
* This post is structured to go from pessimistic to optimistic.
I know its a bit long, but Id appreciate it if you would take the time to
read the entire post before replying.
Without further ado, here are some of the failure cases of deep RL.
# Deep Reinforcement Learning Can Be Horribly Sample Inefficient
The most well-known benchmark for deep reinforcement learning is Atari. As shown
in the now-famous Deep Q-Networks paper, if you combine Q-Learning with
reasonably sized neural networks and some optimization tricks, you can achieve
human or superhuman performance in several Atari games.
Atari games run at 60 frames per second. Off the
top of your head, can you estimate how many frames a state of the art DQN
needs to reach human performance?
The answer depends on the game, so lets take a look at a recent Deepmind
paper, [Rainbow DQN (Hessel et al, 2017)](https://arxiv.org/abs/1710.02298).
This paper does an ablation study over several incremental advances made to the
original DQN architecture, demonstrating that a combination of all advances gives
the best performance. It exceeds human-level performance on over 40 of the 57 Atari
games attempted. The results are displayed in this handy chart.
![Figure from Rainbow DQN](/public/rl-hard/rainbow_dqn.png)
The y-axis is “median human-normalized score”. This is computed by training
57 DQNs, one for each Atari game, normalizing the score of each agent such that
human performance is 100%, then plotting the median performance across the
57 games. RainbowDQN passes the 100% threshold at about *18 million* frames.
This corresponds to about 83 hours of play experience, plus however long it takes
to train the model. A lot of time, for an Atari game that most humans pick up
within a few minutes.
Mind you, 18 million frames is actually pretty good, when you consider that the
previous record
([Distributional DQN (Bellemare et al, 2017)](https://arxiv.org/pdf/1707.06887.pdf))
needed 70 million frames to hit 100% median performance, which is about 4x more
time. As for the [Nature DQN (Mnih et al, 2015)](https://www.nature.com/articles/nature14236),
it never hits 100% median performance, even after 200 million frames of
experience.
The planning fallacy says that finishing something usually takes longer than
you think it will. Reinforcement
learning has its own planning fallacy - learning a policy usually needs more
samples than you think it will.
This is not an Atari-specific issue. The 2nd most popular benchmark is the
MuJoCo benchmarks, a set of tasks set in the MuJoCo physics
simulator. In these tasks, the input state is usually the position and velocity
of each joint of some simulated robot. Even without having to solve vision,
these benchmarks take between \(10^5\) to \(10^7\) steps to learn, depending
on the task. This is an astoundingly large amount of experience to
control such a simple environment.
The [DeepMind parkour paper (Heess et al, 2017)](https://arxiv.org/abs/1707.02286),
demoed below,
trained policies by using 64 workers for over 100 hours. The paper does not clarify what “worker”
means, but I assume it means 1 CPU.
These results are *super cool*. When it first came out, I was surprised
deep RL was even able to learn these running gaits.
At the same time, the fact that this needed 6400 CPU hours is a bit
disheartening. Its not that I expected it to need less time…its more that
its disappointing that deep RL is still orders of magnitude above a practical
level of sample efficiency.
Theres an obvious counterpoint here: what if we just ignore sample efficiency?
There are several settings where its easy to generate experience. Games are
a big example. But, for any setting where this *isnt* true, RL faces an uphill
battle, and unfortunately, most real-world settings fall under this category.
# If You Just Care About Final Performance, Many Problems are Better Solved by Other Methods
When searching for solutions to any research problem, there are usually
trade-offs between different objectives. You can optimize for getting a really
good solution for that research problem, or you can optimize for making a good
research contribution. The best problems are ones where getting a good solution
requires making good research contributions, but it can be hard to find
approachable problems that meet that criteria.
For purely getting good performance, deep RLs track record isnt
that great, because it consistently gets beaten by other methods.
Here is a video of the MuJoCo robots, controlled with online trajectory
optimization. The correct actions are computed in near real-time, online, with
no offline training. Oh, and its running on 2012 hardware. ([Tassa et al, IROS 2012](https://homes.cs.washington.edu/~todorov/papers/TassaIROS12.pdf)).
I think these behaviors compare well to the parkour
paper. Whats different between this paper and that one?
The difference is that Tassa et al use model predictive control, which gets to
perform planning against a ground-truth world model (the physics simulator).
Model-free RL doesnt do this planning, and therefore has a much harder
job. On the other hand, if planning against a model helps this much, why
bother with the bells and whistles of training an RL policy?
In a similar vein, you can easily outperform DQN in Atari with off-the-shelf
Monte Carlo Tree Search. Here are baseline
numbers from [Guo et al, NIPS 2014](https://papers.nips.cc/paper/5421-deep-learning-for-real-time-atari-game-play-using-offline-monte-carlo-tree-search-planning).
They compare the scores of a trained DQN to the scores of a UCT agent
(where UCT is the standard version of MCTS used today.)
![DQN results](/public/rl-hard/dqn_atari.png)
![MCTS results](/public/rl-hard/uct_atari.png)
Again, this isnt a fair comparison, because DQN does no search, and MCTS gets to
perform search against a ground truth model (the Atari emulator).
However, sometimes you dont care about fair comparisons. Sometimes you just
want the thing to work. (If youre interested in a full evaluation of UCT,
see the appendix of the original
[Arcade Learning Environment paper (Bellemare et al, JAIR 2013)](http://www.marcgbellemare.info/static/publications/bellemare13arcade.pdf).)
Reinforcement learning can theoretically work for anything, including
environments where a model of the world isnt known. However, this generality
comes at a price: its hard to exploit any problem-specific information that
could help with learning, which forces you to use tons of samples to learn
things that could have been hardcoded.
The rule-of-thumb is that except in rare cases, domain-specific algorithms
work faster and better than reinforcement learning. This isnt a problem if
youre doing deep RL for deep RLs sake, but I
personally find it frustrating when I compare RLs performance to, well,
anything else. One reason I liked AlphaGo so much was *because* it was an
unambiguous win for deep RL, and that doesnt happen very often.
This makes it harder for me to explain to laypeople why my problems
are cool and hard and interesting, because they often dont have the context
or experience to appreciate *why* theyre hard.
Theres an explanation gap between what people think deep RL can do, and
what it can really do. Im working in robotics right now. Consider the company
most people think of
when you mention robotics:
[Boston Dynamics](https://www.youtube.com/channel/UC7vVhkEfw4nOGp8TyDk7RcQ).
This doesnt use reinforcement learning. Ive had a few conversations where
people thought it used RL, but it doesnt.
If you look up research papers from the group, you find papers mentioning
[time-varying LQR, QP solvers, and convex optimization](https://dspace.mit.edu/openaccess-disseminate/1721.1/110533).
In other words, they mostly apply classical robotics techniques. Turns out
those classical techniques can work pretty well, when you apply them right.
# Reinforcement Learning Usually Requires a Reward Function
Reinforcement learning assumes the existence of a reward function. Usually,
this is either given, or it is hand-tuned offline and kept fixed over the course
of learning. I say “usually” because there are exceptions, such as imitation
learning or inverse RL, but most RL approaches treat the reward as an oracle.
Importantly,
for RL to do the right thing, your reward function must capture *exactly* what
you want.
And I mean *exactly*. RL has an annoying tendency to overfit to your reward,
leading to things you didnt expect. This is why Atari is such a nice benchmark. Not only
is it easy to get lots of samples, the goal in every game is to maximize score,
so you never have to worry about defining your reward, and you know everyone
else has the same reward function.
This is also why the MuJoCo tasks are popular. Because theyre run in simulation,
you have perfect knowledge of all object state, which makes reward function design
a lot easier.
In the Reacher task, you control a two-segment arm, thats connected to a central
point, and the goal is to move the end of the arm to a target location. Below
is a video of a successfully learned policy.
Since all locations are known, reward can be defined as the distance
from the end of the arm to the target, plus a small control cost. In principle,
you can do this in the real world too, if you have enough sensors to get
accurate enough positions for your environment. But depending on what you want
your system to do, it could be hard to define a reasonable reward.
By itself, requiring a reward function wouldnt be a big deal, except…
# Reward Function Design is Difficult
Making *a* reward function isnt that difficult. The difficulty comes when
you try to design a reward function that encourages the behaviors you want
while still being learnable.
In the HalfCheetah environment, you have a two-legged robot, restricted to a
vertical plane, meaning it can only run forward or backward.
[
</source>
Your browser does not support the video element.
](/public/rl-hard/upright_half_cheetah.mp4)
The goal is to learn a running gait. Reward is the velocity of the HalfCheetah.
This is a *shaped* reward, meaning it gives increasing reward in states
that are closer to the end goal. This is in contrast to *sparse* rewards, which
give reward at the goal state, and no reward anywhere else.
Shaped rewards are often much easier to learn, because they provide positive feedback
even when the policy hasnt figured out a full solution to the problem.
Unfortunately, shaped rewards can bias learning. As said earlier, this can lead
to behaviors that dont match what you want.
A good example is the boat racing game, from an [OpenAI blog post](https://blog.openai.com/faulty-reward-functions/).
The intended goal is to finish the race. You can imagine that a sparse reward
would give +1 reward for finishing under a given time, and 0 reward otherwise.
The provided reward gives points for hitting checkpoints, and also
gives reward for collecting powerups that let you finish the race faster.
It turns out farming the powerups gives more points than finishing the race.
To be honest, I was a bit annoyed when this blog post first came out. This
wasnt because I thought it was making a bad point! It was because I thought
the point it made was blindingly obvious. Of course reinforcement learning
does weird things when the reward is misspecified! It felt like the post
was making an unnecessarily large deal out of the given example.
Then I started writing this blog post, and realized the most compelling video
of misspecified reward *was* the boat racing video. And since then, that videos
been used in several presentations bringing awareness to the problem. So, okay,
Ill begrudgingly admit this was a good blog post.
RL algorithms fall along a continuum, where they get to assume more or less
knowledge about the environment theyre in. The broadest category, model-free RL,
is almost the same as black-box optimization. These methods are only allowed to
assume they are in an MDP. Otherwise, they are given nothing else. The agent
is simply told that this gives +1 reward, this doesnt, and it has to learn
the rest on its own.
And like black-box optimization, the problem is that anything that gives
+1 reward is good, even if the +1 reward isnt coming for the right reasons.
A classic non-RL example is the time someone applied genetic algorithms to
circuit design, and
[got a circuit where an unconnected logic gate was necessary to the final
design](https://en.wikipedia.org/wiki/Evolvable_hardware#Introduction).
![Circuit with crazy gates](/public/rl-hard/circuit.png)
The gray cells are required to get correct behavior, including the one in the top-left corner,
even though its connected to nothing.
[From “An Evolved Circuit, Intrinsic in Silicon, Entwined with Physics”](http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.50.9691&rep=rep1&type=pdf)
For a more recent example, see this
[2017 blog post from Salesforce](https://www.salesforce.com/products/einstein/ai-research/tl-dr-reinforced-model-abstractive-summarization/).
Their goal is text summarization.
Their baseline model is trained with supervised learning, then evaluated with
an automated metric called ROUGE. ROUGE is non-differentiable, but RL can
deal with non-differentiable rewards, so they tried applying RL to optimize
ROUGE directly. This gives high ROUGE (hooray!), but it doesnt actually
give good summaries. Heres an example.
> Button was denied his 100th race for McLaren after an ERS prevented him from making it to the start-line. It capped a miserable weekend for the Briton. Button has out-qualified. Finished ahead of Nico Rosberg at Bahrain. Lewis Hamilton has. In 11 races. . The race. To lead 2,000 laps. . In. . . And.
[Paulus et al, 2017](https://arxiv.org/abs/1705.04304)
So, despite the RL model giving the highest ROUGE score…
![Salesforce ROUGE performance](/public/rl-hard/salesforce_rouge.png)
they ended up using a different model instead.
Heres another fun example. This is [Popov et al, 2017](https://arxiv.org/abs/1704.03073),
sometimes known as “the Lego stacking paper”.
The authors use a distributed version of DDPG to learn a grasping policy. The
goal is to grasp the red block, and stack it on top of the blue block.
They got it to work, but they ran into a neat failure case.
For the initial lifting motion, reward is given based on how high the red block
is. This is defined by the z-coordinate of the
bottom face of the block. One of the failure modes was that the policy learned
to tip the red block over, instead of picking it up.
Now, clearly this isnt the intended solution. But RL doesnt care.
From the perspective of reinforcement learning, it got rewarded for flipping
a block, so its going to keep flipping blocks.
One way to address this is to make the reward sparse, by only giving positive
reward after the robot stacks the block. Sometimes, this works, because the
sparse reward is learnable. Often, it doesnt, because the lack of positive
reinforcement makes everything too difficult.
The other way to address this is to do careful reward shaping, adding new
reward terms and tweaking coefficients of existing ones until the behaviors
you want to learn fall out of the RL algorithm. Its *possible* to fight
RL on this front, but its a very unfulfilling fight. On occasion, its
necessary, but Ive never felt like Ive learnt anything by doing it.
For reference, here is one of the reward functions from the Lego stacking
paper.
![Lego grasp reward function](/public/rl-hard/lego_reward.png)
I dont know how much time was spent designing this reward, but based on the
number of terms and the number of different coefficients, Im going to
guess “a lot”.
In talks with other RL researchers, Ive heard several anecdotes about
the novel behavior theyve seen from improperly defined rewards.
* A coworker is teaching an
agent to navigate a room. The episode terminates if the agent
walks out of bounds. He didnt add any penalty if the episode terminates this
way. The final policy learned to be suicidal, because negative reward was
plentiful, positive reward was too hard to achieve, and a quick death ending
in 0 reward was preferable to a long life that risked negative reward.
* A friend is training a simulated robot arm to reach towards a point
above a table. It turns out the point was defined *with respect to the table*,
and the table wasnt anchored to anything.
The policy learned to slam the table really hard, making the table fall
over, which moved the target point too. The target point *just so happened*
to fall next to the end of the arm.
* A researcher gives a talk about using RL to train a simulated robot hand to
pick up a hammer and hammer in a nail. Initially, the reward was defined
by how far the nail was pushed into the hole. Instead of
picking up the hammer, the robot used its own limbs to punch the nail in.
So, they added a reward term to encourage picking up the hammer, and retrained
the policy.
They got the policy to pick up the hammer…but then it threw the hammer at the
nail instead of actually using it.
Admittedly, these are all secondhand accounts, and I havent seen videos of
any of these behaviors.
However, none of it sounds implausible to me.
Ive been burned by RL too many times to believe otherwise.
I know people who like to tell stories about [paperclip optimizers](https://en.wikipedia.org/wiki/Instrumental_convergence#Paperclip_maximizer). I get it,
I really do. But honestly, Im sick of hearing those stories, because they
always speculate up some superhuman misaligned AGI to create a just-so story.
Theres no reason to speculate that far when present-day examples happen
all the time.
# Even Given a Good Reward, Local Optima Can Be Hard To Escape
The previous examples of RL are sometimes called “reward hacking”. To me,
this implies a clever, out-of-the-box solution that gives more reward than the
intended answer of the reward function designer.
Reward hacking is the exception. The much more common case is a poor local optima
that comes from getting the exploration-exploitation trade-off wrong.
Heres one of my favorite videos. This is an implementation of
[Normalized Advantage Function](https://arxiv.org/abs/1603.00748), learning
on the HalfCheetah environment.
[
</source>
Your browser does not support the video element.
](/public/rl-hard/upsidedown_half_cheetah.mp4)
From an outside perspective, this is really, *really* dumb. But we can
only say its dumb because we can see the 3rd person view, and have a bunch of
prebuilt knowledge that tells us running on your feet is better.
RL doesnt know this! It sees a state vector, it sends action vectors, and it
knows its getting some positive reward. Thats it.
Heres my best guess for what happened during learning.
* In random exploration, the policy found falling forward was better than
standing still.
* It did so enough to “burn in” that behavior, so now its falling forward
consistently.
* After falling forward, the policy learned that if it does a one-time application
of a lot of force, itll do a backflip that gives a bit more reward.
* It explored the backflip enough to become confident this was a good idea,
and now backflipping is burned into the policy.
* Once the policy is backflipping consistently, which is easier for the
policy: learning to right itself and then run “the standard way”, or learning
or figuring out how to move forward while lying on its back? I would
guess the latter.
Its very funny, but it definitely isnt what I wanted the robot to do.
Heres another failed run, this time on the Reacher environment.
[
</source>
Your browser does not support the video element.
](/public/rl-hard/failed_reacher.mp4)
In this run, the initial random weights tended to output highly positive or
highly negative action outputs. This makes most of the actions output the
maximum or minimum acceleration possible. Its really easy to spin super fast:
just output high magnitude forces at every joint. Once the robot gets going, its hard
to deviate from this policy in a meaningful way - to deviate, you have to take
several exploration steps to stop the rampant spinning. Its certainly
possible, but in this run, it didnt happen.
These are both cases of the classic exploration-exploitation problem that has dogged
reinforcement learning since time immemorial.
Your data comes from your current policy. If your current policy explores too
much you get junk data and learn nothing. Exploit too much and you burn-in
behaviors that arent optimal.
There are several intuitively pleasing ideas for addressing this - intrinsic
motivation, curiosity-driven exploration, count-based exploration, and so forth.
Many of these approaches were first proposed in the 1980s or earlier, and
several of them have been revisited with deep learning models. However, as far
as I know, none of them work consistently across all environments. Sometimes
they help, sometimes they dont. It would be nice if there was an exploration
trick that worked everywhere, but Im skeptical a silver bullet of that caliber
will be discovered anytime soon. Not because people arent trying, but because
exploration-exploitation
is really, really, really, really, really hard.
To quote [Wikipedia](https://en.wikipedia.org/wiki/Multi-armed_bandit),
> Originally considered by Allied scientists in World War II, it proved so intractable that, according to Peter Whittle, the problem was proposed to be dropped over Germany so that German scientists could also waste their time on it.
(Reference: [Q-Learning for Bandit Problems, Duff 1995](http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.57.1916&rep=rep1&type=pdf))
Ive taken to imagining deep RL as a demon thats
deliberately misinterpreting your reward and actively searching for the laziest
possible local optima. Its a bit ridiculous, but Ive found its actually a
productive mindset to have.
# Even When Deep RL Works, It May Just Be Overfitting to Weird Patterns In the Environment
> Deep RL is popular because its the only area in ML where its socially
> acceptable to train on the test set.
[Source](https://twitter.com/jacobandreas/status/924356906344267776)
The upside of reinforcement learning is that if you want to do
well in an environment, youre free to overfit like crazy. The downside is that
if you want to generalize to any other environment, youre probably going to
do poorly, because you overfit like crazy.
DQN can solve a lot of the Atari games, but it does so by focusing all of
learning on a single goal - getting really good at one game. The final model
wont generalize to other games, because it hasnt been trained that way.
You can finetune a learned DQN to a new Atari game
(see [Progressive Neural Networks (Rusu et al, 2016)](https://arxiv.org/abs/1606.04671)),
but theres no guarantee itll transfer and people usually dont expect it to
transfer.
Its not the wild success people see from pretrained ImageNet features.
To forestall some obvious comments: yes, in principle, training on a wide
distribution of environments should make these issues go away.
In some cases, you get such a distribution for free. An example
is navigation, where you can sample goal locations randomly, and use
universal value functions to generalize.
(See [Universal Value Function Approximators, Schaul et al, ICML 2015](http://proceedings.mlr.press/v37/schaul15.pdf).)
I find this work very promising, and I give more examples of this work later.
However, I dont think the
generalization capabilities of deep RL are strong enough to handle a diverse
set of tasks yet. Perception has gotten a lot better, but deep RL has yet to
have its “ImageNet for control” moment. OpenAI Universe tried to spark
this, but from what I heard, it was too difficult to solve, so not much got
done.
Until we have that kind of generalization moment, were stuck with policies that
can be surprisingly narrow in scope.
As an example of this (and as an opportunity to poke fun at some of my own work),
consider [Can Deep RL Solve Erdos-Selfridge-Spencer Games? (Raghu et al, 2017)](https://arxiv.org/abs/1711.02301).
We studied a toy 2-player combinatorial game, where theres a closed-form analytic solution
for optimal play.
In one of our first experiments, we fixed player 1s behavior, then trained
player 2 with RL. By doing this, you can treat player 1s actions as part
of the environment. By training player 2 against the optimal player 1, we showed
RL could reach high performance. But when we deployed the same
policy against a non-optimal player 1, its performance dropped, because it
didnt generalize to non-optimal opponents.
[Lanctot et al, NIPS 2017](https://arxiv.org/abs/1711.00832) showed a
similar result. Here, there are two agents
playing laser tag. The agents are trained with multiagent reinforcement
learning. To test generalization, they run the training with 5 random
seeds. Heres a video of agents that have been trained against one
another.
As you can see, they learn to move towards and shoot each other. Then, they
took player 1 from one experiment, and pitted it against player 2 from a
*different* experiment. If the learned policies generalize, we should see
similar behavior.
Spoiler alert: they dont.
This seems to be a running theme in multiagent RL. When agents are trained
against one another, a kind of co-evolution happens. The agents get really good
at beating each other, but when they get deployed against an unseen player,
performance drops. Id also like to point out that the
only difference between these videos is the random seed. Same learning
algorithm, same hyperparameters. The diverging behavior is purely from randomness
in initial conditions.
That being said, there are some neat results from competitive self-play environments
that seem to contradict this. [OpenAI has a nice blog post of some of their work in this space](https://blog.openai.com/competitive-self-play/).
Self-play is also an important part of both
AlphaGo and AlphaZero. My intuition is that if your agents are learning at
the same pace, they can continually challenge each other and speed up each others
learning, but if one of them learns much faster, it exploits the weaker player
too much and overfits. As you relax from symmetric self-play to general
multiagent settings, it gets harder to ensure learning happens at the same
speed.
# Even Ignoring Generalization Issues, The Final Results Can be Unstable and Hard to Reproduce
Almost every ML algorithm has hyperparameters, which influence the behavior
of the learning system. Often, these are picked by hand, or by random search.
Supervised learning is stable. Fixed dataset, ground truth targets. If you
change the hyperparameters a little bit,
your performance wont change that much. Not all hyperparameters perform
well, but with all the empirical tricks discovered over the years,
many hyperparams will show signs of life during training. These signs of life are
super important, because they tell you that youre on the right track, youre
doing something reasonable, and its worth investing more time.
Currently, deep RL isnt stable at all, and its just hugely annoying for research.
When I started working at Google Brain, one of the first
things I did was implement the algorithm from the Normalized Advantage Function
paper. I figured it would only take me about 2-3 weeks. I had several things
going for me: some familiarity with Theano (which transferred to TensorFlow
well), some deep RL experience, and the first author of the NAF paper was
interning at Brain, so I could bug him with questions.
It ended up taking me 6 weeks to reproduce results, thanks to several software
bugs. The question is, why did it take so long to find these bugs?
To answer this, lets consider the simplest continuous control task in
OpenAI Gym: the Pendulum task. In this task, theres a pendulum, anchored
at a point, with gravity acting on the pendulum. The input state is
3-dimensional. The action space is 1-dimensional, the amount of torque to apply.
The goal is to balance the pendulum perfectly straight up.
This is a tiny problem, and its made even easier by a well shaped reward.
Reward is defined by the angle of the pendulum. Actions bringing the pendulum
closer to the vertical not only give reward, they give *increasing* reward.
The reward landscape is basically concave.
Below is a video of a policy that *mostly* works. Although the policy doesnt
balance straight up, it outputs the exact torque needed to counteract
gravity.
[
</source>
Your browser does not support the video element.
](/public/rl-hard/pendulum_example.mp4)
Here is a plot of performance, after I fixed all the bugs. Each line is the
reward curve from one of 10 independent runs. Same hyperparameters, the only
difference is the random seed.
![Graph of Pendulum results](/public/rl-hard/pendulum_results.png)
Seven of these runs worked. Three of these runs didnt. *A 30%
failure rate counts as working.*
Heres another plot from some published work,
[“Variational Information Maximizing Exploration” (Houthooft et al, NIPS 2016)](https://arxiv.org/abs/1605.09674).
The environment is HalfCheetah. The reward is modified to be sparser, but the
details arent too important.
The y-axis is episode reward, the x-axis is number of timesteps, and the
algorithm used is TRPO.
![Plot from VIME paper](/public/rl-hard/vime.png)
The dark line is the median performance over 10 random seeds, and the shaded
region is the 25th to 75th percentile. Dont get me wrong, this plot is a good
argument in favor of VIME. But on the other hand, the 25th percentile line
is really close to 0 reward. That means about 25% of runs are failing, just
because of random seed.
Look, theres variance in supervised learning too, but its rarely this bad.
If my supervised learning code failed to beat random chance 30% of the time, Id
have super high confidence there was a bug in data loading or training. If
my reinforcement learning code does no better than random, I have no idea if
its a bug, if my hyperparameters are bad, or if I simply got unlucky.
![Dimensions of debugging](/public/rl-hard/dimensionsdebugging.png)
This picture is from [“Why is Machine Learning Hard?”](http://ai.stanford.edu/~zayd/why-is-machine-learning-hard.html).
The core thesis is that machine learning adds more dimensions to your space
of failure cases, which exponentially increases the number of ways you can fail.
Deep RL adds a new dimension: random chance. And the only way you can address
random chance is by throwing enough experiments at the problem to drown out
the noise.
**When your training algorithm is both sample inefficient and unstable, it heavily
slows down your rate of productive research.** Maybe it only takes 1 million
steps. But when you multiply that by 5 random seeds, and then multiply that with
hyperparam tuning, you need an exploding amount of compute to test hypotheses
effectively.
> If it makes you feel any better, Ive been doing this for a while and it took me last ~6 weeks to get a from-scratch policy gradients implementation to work 50% of the time on a bunch of RL problems. And I also have a GPU cluster available to me, and a number of friends I get lunch with every day whove been in the area for the last few years.
>
> Also, what we know about good CNN design from supervised learning land doesnt seem to apply to reinforcement learning land, because youre mostly bottlenecked by credit assignment / supervision bitrate, not by a lack of a powerful representation. Your ResNets, batchnorms, or very deep networks have no power here.
>
> [Supervised learning] wants to work. Even if you screw something up youll usually get something non-random back. RL must be forced to work. If you screw something up or dont tune something well enough youre exceedingly likely to get a policy that is even worse than random. And even if its all well tuned youll get a bad policy 30% of the time, just because.
>
> Long story short your failure is more due to the difficulty of deep RL, and much less due to the difficulty of “designing neural networks”.
[Hacker News comment from Andrej Karpathy, back when he was at OpenAI](https://news.ycombinator.com/item?id=13519044)
Instability to random seed is like a canary in a coal mine. If pure randomness
is enough to lead to this much variance between runs, imagine how much an actual
difference in the code could make.
Luckily, we dont have to imagine, because this was inspected by
the paper [“Deep Reinforcement Learning That Matters” (Henderson et al, AAAI 2018)](https://arxiv.org/abs/1709.06560).
Among its conclusions are:
* Multiplying the reward by a constant can cause significant differences in performance.
* Five random seeds (a common reporting metric) may not be enough to argue
significant results, since with careful selection you can get non-overlapping
confidence intervals.
* Different implementations of the same algorithm have different performance on
the same task, even when the same hyperparameters are used.
My theory is that RL is very sensitive to both your initialization and to the
dynamics of your training process, because your data is always collected online
and the only supervision you get is a single scalar for reward. A policy that
randomly stumbles onto good training examples will bootstrap itself much
faster than a policy that doesnt. A policy that fails to discover good training
examples in time will collapse towards learning nothing at all, as it becomes
more confident that any deviation it tries will fail.
# But What About All The Great Things Deep RL Has Done For Us?
Deep reinforcement learning has certainly done some very cool things. DQN is
old news now, but was absolutely *nuts* at the time. A single model was able to
learn directly from raw pixels, without tuning for each game individually.
And AlphaGo and AlphaZero continue to be very impressive achievements.
However, outside of these successes, its hard to find cases where deep RL
has created practical real world value.
I tried to think of real-world, productionized uses of deep RL, and it was
surprisingly difficult. I expected to find something in recommendation systems,
but I believe those are still dominated by [collaborative filtering](https://en.wikipedia.org/wiki/Collaborative_filtering)
and [contextual bandits](https://research.yahoo.com/publications/5863/contextual-bandit-approach-personalized-news-article-recommendation).
In the end, the best I could find were two Google projects: [reducing data
center power usage](https://deepmind.com/blog/deepmind-ai-reduces-google-data-centre-cooling-bill-40/),
and the recently announced [AutoML Vision effort](https://cloud.google.com/automl/).
Jack Clark from OpenAI
[tweeted a similar request and found a similar conclusion](https://twitter.com/jackclarkSF/status/919584404472602624).
(The tweet is from last year, before AutoML was announced.)
I know Audis doing something with deep RL, since they demoed a self-driving
RC car at NIPS and said it used deep RL. I know theres some
neat work
[optimizing device placement for large Tensorflow graphs (Mirhoseini et al, ICML 2017)](https://arxiv.org/abs/1706.04972).
Salesforce has their text summarization model, which worked if you massaged the
RL carefully enough.
Finance companies are surely experimenting with RL as we speak, but so far
theres no definitive proof. (Of course, finance companies have reasons to be cagey
about how they play the market, so perhaps the evidence there is never going to
be strong.) Facebooks been doing some neat work with deep RL for chatbots and
conversation. Every Internet company ever has probably thought about adding RL to
their ad-serving model, but if anyones done it, theyve kept quiet about it.
The way I see it, either deep RL is still a research topic that isnt robust
enough for widespread use, or its usable and the people whove gotten it
to work arent publicizing it. I think the former is more likely.
If you came to me with an image classification problem, Id point you to
pretrained ImageNet models, and theyd probably do great.
Were in a world where
[the people behind *Silicon Valley* can build a real Not Hotdog app](https://medium.com/%40timanglade/how-hbos-silicon-valley-built-not-hotdog-with-mobile-tensorflow-keras-react-native-ef03260747f3)
as a joke. I have trouble seeing the same happen with deep RL.
# Given Current Limitations, When Could Deep RL Work For Me?
A priori, its really hard to say. The problem with trying to solve everything
with RL is that youre trying to solve several very different environments
with the same approach. Its only natural that it wont work all the time.
That being said, we can draw conclusions from the current list of deep
reinforcement learning successes. These are projects where deep RL either
learns some qualitatively impressive behavior, or
it learns something better than comparable prior work. (Admittedly, this
is a very subjective criteria.)
Heres my list so far.
* Things mentioned in the previous sections: DQN, AlphaGo, AlphaZero,
the parkour bot, reducing power center usage, and AutoML with Neural
Architecture Search.
* [OpenAIs Dota 2 1v1 Shadow Fiend bot, which beat top pro players in a
simplified duel setting.](https://blog.openai.com/dota-2/)
* [A Super Smash Brothers Melee bot](https://arxiv.org/abs/1702.06230) that can beat
pro players at [1v1 Falcon dittos](https://www.youtube.com/watch?v=dXJUlqBsZtE).
(Firoiu et al, 2017).
(A quick aside: machine learning recently beat pro players at no-limit
heads up Texas HoldEm. This was done by both [Libratus (Brown et al, IJCAI 2017)](https://www.ijcai.org/proceedings/2017/0772.pdf)
and [DeepStack (Moravčík et al, 2017)](https://arxiv.org/abs/1701.01724).
Ive talked to a few people who believed this was done with deep RL.
Theyre both very cool, but they dont use deep RL.
They use counterfactual regret minimization and clever iterative solving of
subgames.)
From this list, we can identify common properties that make learning easier.
None of the properties below are *required* for learning, but satisfying more
of them is definitively better.
* **It is easy to generate near unbounded amounts of experience.**
It should be clear why this helps. The more data you have, the easier the learning
problem is. This applies to
Atari, Go, Chess, Shogi, and the simulated environments for the parkour bot.
It likely applies to the power center project too, because
[in prior work (Gao, 2014)](https://googleblog.blogspot.com/2014/05/better-data-centers-through-machine.html),
it was shown that neural nets can predict energy efficiency with high
accuracy. Thats exactly the kind of simulated model youd want for training an
RL system.
It might apply to the Dota 2 and SSBM work, but it depends on the throughput
of how quickly the games can be run, and how many machines were available to
run them.
* **The problem is simplified into an easier form.** One of the common errors
Ive seen in deep RL is to dream too big. Reinforcement learning can do
anything! That doesnt mean you have to do everything at once.
The OpenAI Dota 2 bot only played the early game, only played Shadow Fiend against Shadow
Fiend in a 1v1 laning setting, used hardcoded item builds, and presumably
called the [Dota 2 API](https://developer.valvesoftware.com/wiki/Dota_2_Workshop_Tools/Scripting/API)
to avoid having to solve perception. The SSBM bot acheived superhuman performance,
but it was only in 1v1 games, with Captain Falcon only, on Battlefield only,
in an infinite time match.
This isnt a dig at either bot. Why work on a hard problem when you dont
even know the easier one is solvable? The
broad trend of all research is to demonstrate the smallest proof-of-concept
first and generalize it later. OpenAI is extending their Dota 2 work, and
theres ongoing work to extend the SSBM bot [to other characters](https://github.com/vladfi1/phillip).
* **There is a way to introduce self-play into learning.** This is a component
of AlphaGo, AlphaZero, the Dota 2 Shadow Fiend bot, and the SSBM Falcon bot. I
should note that by self-play, I mean exactly the setting where the game is
competitive, and both players can be controlled by the same agent. So far,
that setting seems to have the most stable and well-performing behavior.
* **Theres a clean way to define a learnable, ungameable reward.** Two player games
have this: +1 for a win, -1 for a loss. The [original neural architecture search paper from Zoph et al, ICLR 2017](https://openreview.net/forum?id=r1Ue8Hcxg) had this: validation accuracy of
the trained model. Any time you introduce reward shaping, you introduce a chance
for learning a non-optimal policy that optimizes the wrong objective.
If youre interested in further reading on what makes a good reward,
a good search term is [“proper scoring rule”](https://en.wikipedia.org/wiki/Scoring_rule#Proper_scoring_rules).
See [this Terrence Tao blog post](https://terrytao.wordpress.com/2016/06/01/how-to-assign-partial-credit-on-an-exam-of-true-false-questions/) for an approachable example.
As for learnability, I have no advice besides trying it out to see if it
works.
* **If the reward has to be shaped, it should at least be rich.**
In Dota 2, reward can come from last hits (triggers after every monster kill
by either player), and health (triggers after every attack or skill that
hits a target.) These reward signals
come quick and often. For the SSBM bot, reward can be given for damage dealt
and taken, which gives signal for every attack that successfully lands. The shorter
the delay between action and consequence, the faster the feedback loop gets
closed, and the easier it is for reinforcement learning to figure out a path to high reward.
# A Case Study: Neural Architecture Search
We can combine a few of the principles to analyze the success of Neural
Architecture Search. According to the initial [ICLR 2017 version](https://arxiv.org/abs/1611.01578),
after 12800 examples, deep RL was able to design state-of-the art neural
net architectures. Admittedly, each example required training a neural net
to convergence, but this is still very sample efficient.
As mentioned above, the reward is validation accuracy.
This is a very rich reward signal - if a neural net design decision only increases
accuracy from 70% to 71%, RL will still pick up on this. Additionally, theres
evidence that hyperparameters in deep learning are close to
linearly independent. (This was empirically shown in [Hyperparameter
Optimization: A Spectral Approach (Hazan et al, 2017)](https://arxiv.org/abs/1706.00764) - a summary by me is
[here](/2017/06/27/hyperparam-spectral.html) if interested.)
NAS isnt exactly tuning hyperparameters, but I think its reasonable
that neural net design decisions would act similarly. This is good
news for learning, because the correlations between decision and performance
are strong. Finally, not only is the reward rich, its actually what we care
about when we train models.
The combination of all these points helps me understand why it “only” takes about
12800 trained networks to learn a better one, compared to the millions of examples
needed in other environments. Several parts of the problem are all pushing in
RLs favor.
Overall, success stories this strong are still the exception, not the rule.
Many things have to go right for reinforcement learning to be a plausible
solution, and even then, its not a free ride to make that solution happen.
In short: deep RL is currently not a plug-and-play technology.
# Looking to The Future
Theres an old saying - every researcher learns how to hate their area of
study. The trick is that researchers will press on despite this, because they
like the problems too much.
Thats roughly how I feel about deep reinforcement learning. Despite my
reservations, I think people absolutely should be throwing RL at different
problems, including ones where it probably shouldnt work. How else are we
supposed to make RL better?
I see no reason why deep RL couldnt work, given more time. Several very
interesting things are going to happen when deep RL is robust enough for wider
use. The question is
how itll get there.
Below, Ive listed some futures I find plausible. For the futures
based on further research, Ive provided citations to relevant papers in those
research areas.
**Local optima are good enough:** It would be very arrogant to claim humans are
globally optimal at anything. I would guess were juuuuust good enough to get
to civilization stage, compared to any other species. In the same vein, an
RL solution doesnt have to achieve a global optima, as long as its local optima
is better than the human baseline.
**Hardware solves everything:** I know some people who believe that the most
influential thing that can be done for AI is simply scaling up hardware. Personally,
Im skeptical that hardware will fix everything, but its certainly going to
be important. The faster you can run things, the less you care about sample
inefficiency, and the easier it is to brute-force your way past exploration
problems.
**Add more learning signal:** Sparse rewards are hard to learn because you get
very little information about what thing help you. Its possible we can either hallucinate
positive rewards ([Hindsight Experience Replay, Andrychowicz et al, NIPS 2017](https://arxiv.org/abs/1707.01495)), define auxiliary tasks ([UNREAL, Jaderberg et al, NIPS 2016](https://arxiv.org/abs/1611.05397)),
or bootstrap with self-supervised learning to build good world model. Adding
more cherries to the cake, so to speak.
**Model-based learning unlocks sample efficiency:** Heres how I describe
model-based RL: “Everyone wants to do it, not many people know how.” In principle,
a good model fixes a bunch of problems. As seen in AlphaGo, having a model
at all makes it much easier to learn a good solution.
Good world models will transfer well to new tasks,
and rollouts of the world model let you imagine new experience. From what Ive
seen, model-based approaches use fewer samples as well.
The problem is that learning good models is hard. My impression is that
low-dimensional state models work sometimes, and image
models are usually too hard. But, if this gets easier, some interesting things
could happen.
[Dyna (Sutton, 1991)](http://citeseerx.ist.psu.edu/viewdoc/download;jsessionid=711FEF6BA26BBF98C28BC111B26F8761?doi=10.1.1.48.6005&rep=rep1&type=pdf) and
[Dyna-2 (Silver et al., ICML 2008)](http://www0.cs.ucl.ac.uk/staff/D.Silver/web/Applications_files/dyna2.pdf) are
classical papers in this space.
For papers combining model-based learning with deep nets, I would recommend a few recent papers from the Berkeley robotics labs:
[Neural Network Dynamics for Model-Based Deep RL with Model-Free Fine-Tuning (Nagabandi et al, 2017](http://bair.berkeley.edu/blog/2017/11/30/model-based-rl/),
[Self-Supervised Visual Planning with Temporal Skip Connections (Ebert et al, CoRL 2017)](https://arxiv.org/abs/1710.05268),
[Combining Model-Based and Model-Free Updates for Trajectory-Centric Reinforcement Learning (Chebotar et al, ICML 2017)](https://arxiv.org/abs/1703.03078).
[Deep Spatial Autoencoders for Visuomotor Learning (Finn et al, ICRA 2016)](http://rll.berkeley.edu/dsae/dsae.pdf),
and [Guided Policy Search (Levine et al, JMLR 2016)](http://jmlr.org/papers/v17/15-522.html).
**Use reinforcement learning just as the fine-tuning step:** The first AlphaGo
paper started with supervised learning, and then did RL fine-tuning on top of it.
This is a nice recipe, since it lets you use a faster-but-less-powerful method
to speed up initial learning. Its worked in other contexts - see
[Sequence Tutor (Jaques et al, ICML 2017)](https://arxiv.org/abs/1611.02796).
You can view this as starting the RL process with a reasonable prior, instead of
a random one, where the problem of learning the prior is offloaded to some
other approach.
**Reward functions could be learnable:** The promise of ML is that we can use
data to learn things that are better than human design. If reward function design
is so hard, Why not apply this to learn better reward functions? Imitation
learning and inverse reinforcement learning are both rich fields that have
shown reward functions can be implicitly
defined by human demonstrations or human ratings.
For famous papers in inverse RL and imitation learning, see
[Algorithms for Inverse Reinforcement Learning (Ng and Russell, ICML 2000)](http://ai.stanford.edu/~ang/papers/icml00-irl.pdf),
[Apprenticeship Learning via Inverse Reinforcement Learning (Abbeel and Ng, ICML 2004)](http://ai.stanford.edu/~ang/papers/icml04-apprentice.pdf),
and [DAgger (Ross, Gordon, and Bagnell, AISTATS 2011)](https://www.cs.cmu.edu/~sross1/publications/Ross-AIStats11-NoRegret.pdf).
For recent work scaling these ideas to deep learning, see [Guided Cost Learning (Finn et al, ICML 2016)](https://arxiv.org/abs/1603.00448), [Time-Constrastive Networks (Sermanet et al, 2017)](https://arxiv.org/abs/1704.06888),
and [Learning From Human Preferences (Christiano et al, NIPS 2017)](https://blog.openai.com/deep-reinforcement-learning-from-human-preferences/). (The Human Preferences paper in particular showed
that a reward learned from human ratings was actually better-shaped for learning
than the original hardcoded reward, which is a neat practical result.)
For longer term work that doesnt use deep learning, I liked
[Inverse Reward Design (Hadfield-Menell et al, NIPS 2017)](https://arxiv.org/abs/1711.02827)
and [Learning Robot Objectives from Physical Human Interaction (Bajcsy et al, CoRL 2017)](http://proceedings.mlr.press/v78/bajcsy17a/bajcsy17a.pdf).
**Transfer learning saves the day:** The promise of transfer learning is that
you can leverage knowledge from previous tasks to speed up learning of new ones.
I think this is absolutely the future, when task learning is robust enough to
solve several disparate tasks. Its hard to do transfer learning if you cant
learn at all, and given task A and task B, it can be very hard to predict
whether A transfers to B. In my experience, its either super obvious, or super
unclear, and even the super obvious cases arent trivial to get working.
[Universal Value Function Approximators (Schaul et al, ICML 2015)](http://proceedings.mlr.press/v37/schaul15.pdf),
[Distral (Whye Teh et al, NIPS 2017)](https://arxiv.org/abs/1707.04175),
and [Overcoming Catastrophic Forgetting (Kirkpatrick et al, PNAS 2017)](https://deepmind.com/blog/enabling-continual-learning-in-neural-networks/) are recent works in this direction.
For older work, consider reading [Horde (Sutton et al, AAMAS 2011)](http://citeseerx.ist.psu.edu/viewdoc/download?doi=10.1.1.297.6455&rep=rep1&type=pdf).
Robotics
in particular has had lots of progress in sim-to-real transfer (transfer learning
between a simulated version of a task and the real task). See [Domain Randomization (Tobin et al, IROS 2017)](https://blog.openai.com/spam-detection-in-the-physical-world/), [Sim-to-Real Robot
Learning with Progressive Nets (Rusu et al, CoRL 2017)](https://arxiv.org/abs/1610.04286),
and
[GraspGAN (Bousmalis et al, 2017)](https://research.googleblog.com/2017/10/closing-simulation-to-reality-gap-for.html). (Disclaimer: I worked on GraspGAN.)
**Good priors could heavily reduce learning time:** This is closely tied to
several of the previous points. In one view, transfer learning is about using
past experience to build a good prior for learning other tasks.
RL algorithms are designed to apply to any Markov Decision Process, which is
where the pain of generality comes in.
If we accept that our solutions will only perform well on a small section of
environments, we should be able to leverage shared structure to solve those
environments in an efficient way.
One point Pieter Abbeel
likes to mention in his talks is that deep RL only needs to solve tasks that
we expect to need in the real world. I agree it makes a lot of sense.
There should exist
a real-world prior that lets us quickly learn new real-world tasks, at the cost
of slower learning on non-realistic tasks, but thats a perfectly acceptable trade-off.
The difficulty is that such a real-world prior will be very hard to design.
However, I think theres a good chance it wont be impossible.
Personally, Im excited by the recent work in metalearning, since it provides
a data-driven way to generate reasonable priors.
For example, if I wanted to use RL to do warehouse navigation, Id get pretty
curious about using metalearning to learn a good navigation prior,
and then fine-tuning the prior for the specific warehouse the robot will be
deployed in.
This very much seems like the future, and the question is whether metalearning
will get there or not.
A summary of recent learning-to-learn work can be found in
[this post from BAIR (Berkeley AI Research)](http://bair.berkeley.edu/blog/2017/07/18/learning-to-learn/).
**Harder environments could paradoxically be easier:** One of the big lessons
from the DeepMind parkour paper is that if you make your task very difficult
by adding several task variations, you can actually make the learning
easier, because the policy cannot overfit to any one setting without losing
performance on all the other settings. Weve seen a similar thing in the
domain randomization papers, and even back to ImageNet: models trained on
ImageNet will generalize way better than ones trained on CIFAR-100. As I said
above, maybe were just an “ImageNet for control” away from making RL
considerably more generic.
Environment wise, there are a lot of options. [OpenAI Gym](https://github.com/openai/gym)
easily has the most traction, but theres also the [Arcade Learning Environment](https://github.com/mgbellemare/Arcade-Learning-Environment), [Roboschool](https://github.com/openai/roboschool),
[DeepMind Lab](https://github.com/deepmind/lab), the [DeepMind Control Suite](https://github.com/deepmind/dm_control), and [ELF](https://github.com/facebookresearch/ELF).
Finally, although its unsatisfying from a research
perspective, the empirical issues of deep RL may not matter for practical purposes. As a
hypothetical example, suppose a finance company is using deep RL. They train a
trading agent based on past data from the US stock market, using 3 random seeds.
In live A/B testing, one gives 2% less revenue, one performs the
same, and one gives 2% more revenue. In that hypothetical, reproducibility
doesnt matter - you deploy the model with 2% more revenue and celebrate.
Similarly, it doesnt matter that the trading agent may only perform well
in the United States - if it generalizes poorly to the worldwide market,
just dont deploy it there. There is a large gap between doing something
extraordinary and making that extraordinary success reproducible, and maybe its
worth focusing on the former first.
# Where We Are Now
In many ways, I find myself annoyed with the current state of deep RL.
And yet, its attracted some of the strongest research
interest Ive ever seen. My feelings are best summarized by a mindset Andrew
Ng mentioned in his [Nuts and Bolts of Applying Deep Learning](https://www.youtube.com/watch?v=F1ka6a13S9I)
talk - a lot of short-term pessimism, balanced by even more long-term optimism.
Deep RL is a bit messy right now, but I still believe in where it could be.
That being said,
the next time someone asks me whether reinforcement learning can solve their
problem, Im still going to tell them that no, it cant. But Ill also tell
them to ask me again in a few years. By then, maybe it can.
\* \* \*
*This post went through a lot of revision. Thanks go to following people
for reading earlier drafts:
Daniel Abolafia,
[Kumar Krishna Agrawal](https://kumarkrishna.github.io),
[Surya Bhupatiraju](https://www.linkedin.com/in/suryabhupa/),
[Jared Quincy Davis](https://www.linkedin.com/in/jaredquincydavis/),
[Ashley Edwards](http://cc.gatech.edu/~aedwards/),
[Peter Gao](https://www.linkedin.com/in/pgaooo/),
Julian Ibarz,
Sherjil Ozair,
[Vitchyr Pong](https://people.eecs.berkeley.edu/~vitchyr/),
Alex Ray,
and Kelvin Xu. There were several more reviewers who Im crediting
anonymously - thanks for all the feedback.*
[← MIT Mystery Hunt 2018](/2018/01/18/mh-2018.html)
[Blog Posts and Research Papers →](/2018/03/07/blog-paper.html)
Please enable JavaScript to view the [comments powered by Disqus.](https://disqus.com/?ref_noscript)
## Sorta Insightful
* Email: alexirpan [at] berkeley [dot] edu
* [alexirpan](https://github.com/alexirpan)