<!DOCTYPE html>
<html lang="en-us">

  <head>
  <link href="http://gmpg.org/xfn/11" rel="profile">
  <meta http-equiv="content-type" content="text/html; charset=utf-8">

  <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1">

  <title>
    
      An Understanding of Learning from Demonstrations for Neural Text Generation &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/2021/12/01/text-gen-via-lfd/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/public/css/custom.css">
  <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=PT+Serif:400,400italic,700%7CPT+Sans:400">

  <link rel="apple-touch-icon-precomposed" sizes="144x144" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/atom.xml">

  

  <script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.1/MathJax.js?config=TeX-AMS-MML_HTMLorMML" type="text/javascript" ></script>
 <!-- <script type="text/x-mathjax-config"> MathJax.Hub.Config({ TeX: { equationNumbers: { autoNumber: "AMS" } } }); </script> -->
  <script type="text/x-mathjax-config">
      MathJax.Hub.Config({
        tex2jax: { inlineMath: [ ['$','$'], ["\\(","\\)"] ],
         processEscapes: false
        }
      });
</script>
</head>


  <body>

    <!-- Target for toggling the sidebar `.sidebar-checkbox` is for regular
     styles, `#sidebar-checkbox` for behavior. -->
<input type="checkbox" class="sidebar-checkbox" id="sidebar-checkbox">
<!-- <input type="checkbox" class="sidebar-checkbox" id="sidebar-checkbox" > -->

<!-- Toggleable sidebar -->
<div class="sidebar" id="sidebar">
  <div class="sidebar-item">
    <p>For short-term, peer-sourced tests of time, generalizations, specializations, reproductions, etc.!</p>
  </div>

  <nav class="sidebar-nav">

    

    
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/ccf04899-a1fd-464c-872c-d8bc40331399_1642189076/tags/">Tags</a>
        
      
    

    <a class="sidebar-nav-item" href="https://github.com/iclr-blog-track/iclr-blog-track.github.io">GitHub project</a>
    <span class="sidebar-nav-item">Currently vICLR Spring 2021</span>
  </nav>

  <div class="sidebar-item">
    <p>
      &copy; 2022. All rights reserved.
    </p>
  </div>
</div>


    <!-- Wrap is the content to shift when toggling the sidebar. We wrap the
         content to avoid any CSS collisions with our real content. -->
    <div class="wrap">
      <div class="masthead">
        <div class="container">
          <h3 class="masthead-title">
            <a href="/" title="Home">The ICLR Blog Track</a>
            <small></small>
          </h3>
        </div>
      </div>

      <div class="container content">
        <div class="post">
  <h1 id="iclr-post-title" class="post-title">An Understanding of Learning from Demonstrations for Neural Text Generation</h1>
  <span class="post-date">01 Dec 2021 | 
    <a class="content-tag" href="/tags/#text-generation"> Text Generation </a>
  
    <a class="content-tag" href="/tags/#reinforcement-learning"> Reinforcement Learning </a>
  
    <a class="content-tag" href="/tags/#learning-from-demonstration"> Learning from Demonstration </a>
  </span>

  <span id="iclr-post-authors" class="post-date">(Blind Review)</span>
  <h1 id="an-understanding-of-learning-from-demonstrations-for-neural-text-generation">An Understanding of Learning from Demonstrations for Neural Text Generation</h1>

<p>In this blog post, we will go over the <a href="https://arxiv.org/pdf/2009.07839.pdf">ICLR 2021 paper titled <em>Text Generation by Learning from Demonstration</em></a>. This paper introduces a learning method based on offline, off-policy reinforcement learning (RL) which addresses two key limitations of a training objective used in neural text generation models: Maximum Likelihood Estimate (MLE).</p>

<p><strong>Goal of this blog post</strong>: Our main goal with this blog post is to provide researchers and practitioners in both NLP and RL with (1) a better understanding of algorithm presented in this paper (GOLD), and (2) an understanding of how RL is used for text generation.</p>

<h2 id="outline-of-this-blog-post">Outline of this Blog Post</h2>

<ol>
  <li><a href="#the-problem-with-text-generation-via-mle">The Problem with Text Generation via MLE</a></li>
  <li><a href="#background">Background</a></li>
  <li><a href="#training-for-gold">Training for GOLD</a></li>
  <li><a href="#mle-vs-gold">MLE vs GOLD</a></li>
  <li><a href="#concluding-remarks">Concluding Remarks</a></li>
  <li><a href="#references">References</a></li>
</ol>

<h1 id="the-problem-with-text-generation-via-mle">The Problem with Text Generation via MLE</h1>

<p><img src="/public/images/2021-12-01-text-gen-via-lfd/text-gen-diagram.png" alt="Text-Gen-Diagram" /></p>

<p>The standard method for language generation relies on autoregressive models learned using an MLE objective function. Autoregressive models generate text sequentially by predicting the next token to generate based on a history (i.e. previously-generated tokens). The above image provides an example of how an autoregressive model generates a translation of the English text “This is a blog post” to its Spanish counterpart: “Esta es una publicación de blog.”</p>

<p>At a high level, the MLE objective function for text generation aims at maximizing the probability of a token given previous text and some context. In the above figure for example, the MLE objective would teach a generation model to assign high probability to “publicaión” given the context “This is a blog post” and history “Esta es una”.</p>

<p>While the MLE objective has seen incredible success, it suffers from two unfortunate problems:</p>

<ol>
  <li>
    <p><strong>Exposure Bias</strong> - The history used to predict the next token differs between training and evaluation. During evaluation, this is text generated by the model (i.e. previously-predicted text is used as input to predict new tokens). However, during training, this is the gold standard text found in the training dataset. This is rather problematic because the training process draws tokens from the training data’s token distribution whereas evaluation draws tokens from the model’s token distribution <a href="#Ranzato2016">(Ranzato et al., 2016)</a>.
Thus, one incorrect error during token prediction and the model (1) cascade errors for subsequent predictions and (2) produce text that is unlikely under the gold standard’s distribution.</p>
  </li>
  <li>
    <p><strong>Training + Evaluation Metric Mismatch</strong>: We train generation models using MLE, but we evaluate them using metrics such as F1-score, BLEU <a href="#Papineni2002">(Papineni et al., 2002)</a>, or ROGUE <a href="#Lin2004">(Lin, 2004)</a>. This means that we are not optimizing our model to generate text that addresses these metrics.</p>
  </li>
</ol>

<p>The paper we describe in this blog post introduces a method called Generation by Off-policy Learning from Demonstrations (GOLD) that utilizes RL methods to fine-tune a text-generation model trained using MLE. GOLD addresses the above problems as follows:</p>

<ol>
  <li>
    <p><strong>Exposure Bias</strong>: GOLD trains the model to choose the next token given a context and tokens generated by the model. This is in contrast to MLE training, where the next token is chosen given a context and gold standard text.</p>
  </li>
  <li>
    <p><strong>Training + Evaluation Metric Mismatch</strong>: GOLD uses reward signals to train the text generation model. This reward signal can be defined by evaluation metrics or text quality metrics.</p>
  </li>
</ol>

<p>We begin by providing some background on the RL concepts that we will see in this blog post and how those concepts relate to MLE.</p>

<h1 id="background">Background</h1>

<p>From the initial $n$-gram language models to the various iterations on Transformer based language models of today, language generation has long formulated itself as essentially a maximum likelihood estimation (MLE) problem. The question we ask when using MLE is: given the history of $n$ words $x_1, \dots x_i$ from a sentence $x = \langle x_1, \dots, x_n \rangle$, how likely will a generation model predict $x_{i+1}$ next?. MLE formalizes this question by computing the probability distribution over the entire vocabulary of next possible words and choosing the word with the highest probability.</p>

<p>Despite its wide adoption for text generation, MLE does have a few limitations. In addition to the limitations presented in the previous section, MLE also doesn’t allow for any exploration - at each time step the likelihood is maximized and that is selected as the next output. This greedy next word selection approach is generally addressed through beam search or nucleus sampling; however it still retains the same core problem. In order to address this, we can instead reformulate the text generation problem as a Reinforcement Learning (RL) problem.</p>

<p>Reinforcement Learning is the branch of machine learning that aims to find an optimal behavior strategy for an agent to obtain optimal rewards in an environment. These problems are formulated as an actor taking some action in a state to transition to a new state where it gets a reward for having taken that action. In the context of text generation, states are the word sequences of a text generated so far, actions are represented as choosing a next word, and rewards represent the quality of the next word generated.</p>

<p>The RL framework can be addressed using several different algorithms which can be categorized as falling under the fields of <em>value-based</em>, <em>policy gradient-based</em> or <em>model-based</em> approaches. Value-based RL aims to learn the state or state-action value. Value-based RL is generally adopted through Q-learning where the average expected reward at each state is estimated. Model-based RL aims to learn the model of the world and then plan using the model. The model is updated and re-planned often. Policy-based RL aims to directly learn the stochastic policy function that maps state to action. The agent acts by sampling from the policy. The paper presented in this blog post focuses on a policy-based RL approach called <em>policy gradient</em>.</p>

<h2 id="policy-gradient">Policy Gradient</h2>

<p>Before diving into how the paper makes use of offline policy gradients to address the shortcomings of MLE, we will first give some background on policy gradient and mention how it relates to MLE. The goal of reinforcement learning can be formalized as finding the policy $\pi$ that maximizes the expected sum of rewards (if the policy is parameterized, then we are finding a parameterized policy $\pi_{\theta}$):</p>

\[J(\theta) = max_{\pi_{\theta}}~\mathbb{E}_{\tau \sim \pi_{\theta}} \Big[ \sum_{t=0}^{T} \gamma^t r_t \Big]\]

<p>We will now derive the policy gradient update from this objective function. Let $\tau = \langle s_0, a_0, \dots , s_T, a_T \rangle$ denote a path or a trajectory (i.e. state-action sequence) and the reward function over this path as $R(\tau) = \sum_{t=0}^{T} R(s_t, a_t)$. First, let’s start by taking the gradient with respect to $\theta$:</p>

\[\begin{align*}
\nabla_{\theta} J(\theta) &amp; = \nabla_{\theta} \sum_{\tau} P(\tau; \theta) R(\tau) = \sum_{\tau} \nabla_{\theta} P(\tau; \theta) R(\tau) \\
&amp; = \sum_{\tau} \frac{P(\tau; \theta)}{P(\tau; \theta)} \nabla_{\theta} P(\tau; \theta) R(\tau) \\
&amp; = \sum_{\tau} P(\tau; \theta) \frac{\nabla_{\theta} P(\tau; \theta)}{P(\tau; \theta)} R(\tau) \\
&amp; = \sum_{\tau} P(\tau; \theta) \nabla_{\theta}~log P(\tau; \theta) R(\tau)
\end{align*}\]

<p>where $P(\tau; \theta) = \prod_{t=0}^{T} P(s_{t+1} | s_t, a_t) \pi_{\theta}(a_t | s_t)$. Now we approximate with the empirical estimate for $M$ sample paths under policy $\pi_{\theta}$.</p>

\[\nabla_{\theta} J(\theta) \approx \frac{1}{M} \sum_{i=1}^{M} \nabla_{\theta}~log P(\tau^i; \theta) R(\tau^i)\]

<p>This is valid even when $R$ is discontinuous and you have a discrete set of paths. Now we can calculate the probability of a path. This consists of taking the product of the dynamics model or the probability of transitioning from a state given the current state and the applied action:</p>

\[\begin{align*}
\nabla_{\theta} log~P(\tau^i; \theta) &amp; = \nabla_{\theta} \prod_{t=0}^{T} P(s_{t+1}^i | s_t^i, a_t^i) \pi_{\theta}(a_t^i | s_t^i) \\
&amp; = \nabla_{\theta} \Big[ \sum_{t=0}^{T} log~P(s_{t+1}^i | s_t^i, a_t^i) + \sum_{t=0}^{T} log~\pi_{\theta}(a_t^i | s_t^i) \Big] \\
\end{align*}\]

<p>The dynamics model isn’t needed in this case because it doesn’t depend on $\theta$ and thus:</p>

\[\nabla_{\theta} log~P(\tau^i; \theta) = \nabla_{\theta} \sum_{t=0}^{T} log~\pi_{\theta} (a_t^i | s_t^i)\]

<p>This brings us finally to the policy gradient:</p>

\[\nabla_{\theta} J(\theta) = \mathbb{E}_{\tau \sim \pi_{\theta}} \Big[ \sum_{t=0}^{T} log~\pi_{\theta}(a_t|s_t) R(\tau) \Big]\]

<p>Compared to the MLE objective, this is the exact same equation except that the policy gradient update equation includes $R(\tau)$ whereas MLE doesn’t. With policy gradients, the agent is able to explore and thus needs to receive a reward for the action whereas with MLE there is only one possible action to take which is the maximum likelihood with reward 1.</p>

<h2 id="off-policy-vs-on-policy-learning">Off-Policy vs On-Policy Learning</h2>

<p>Given that we now understand the connection between policy gradient and MLE, we now turn our focus to on-policy learning and, the method that GOLD uses, off-policy learning. On-policy RL samples from the current policy when deciding next actions whereas off-policy RL samples from an another policy. This distinction can be made for value based, model based and policy gradient RL approaches. For example, within value based RL, Q-learning is an off policy approach whereas SARSA (state-action-reward-state-action) is on policy. This is because Q-learning uses $\epsilon$-greedy as the policy to determine actions which is different from the current learned policy. SARSA instead uses the current policy in order to determine actions. A similar paradigm applies to policy gradient approaches.</p>

<p>If training samples are collected through the policy we try to optimize for, it is called an on-policy algorithm. However, this means that we cannot use training samples from previous training steps, as they were collected with a different version of the policy. This is where off-policy algorithms have an advantage: off-policy algorithms do not require that the training samples are collected with the current policy. Off-policy algorithms have a “behavior policy” that is used to collect training samples to train the “target policy.” Having a behavior policy allows the agent to be more explorative while collecting experience. Furthermore, an off-policy algorithm allows the agent to save and reuse past experience for better sample efficiency.</p>

<p>Despite its advantages, off-policy policy gradient does also come with a problem. Since the behavior policy is different from the target policy, the training samples it collects are different from those that would have been collected with the target policy. To correct the discrepancy between these two distributions of training samples, off-policy policy gradient requires another technique called importance sampling (described below).</p>

<h2 id="importance-sampling">Importance Sampling</h2>

<p>Importance sampling is a technique of estimating the expected value of a function $f(x)$ where $x$ has a data distribution $p$ using samples another distribution $q$:</p>

\[\mathbb{E}_p[f(x)] = \mathbb{E}_q (\frac{f(X)p(X)}{q(X)})\]

<p>In the context of RL, importance sampling estimates the value functions for a policy $\pi$ with samples collected previously from another, possibly older policy $\pi’$. Calculating the total rewards of taking an action is often very expensive, and thus if the new action is relatively close to the old one, importance sampling allows us to calculate the new rewards based on the old calculation. Otherwise, whenever we update the policy $\pi$, you’d need to collect a completely new trajectory to calculate the expected rewards. When the current policy diverges from the old policy too much, the accuracy decreases and both policies need to be resynced regularly. In this situation a trust-region is defined as the region for which the approximation is still accurate enough for those new policies within the region.</p>

<h1 id="training-for-gold">Training for GOLD</h1>

<h2 id="notations">Notations</h2>

<p>Before we dive into the algorithm’s details, we provide a table of notations that we will use in this section:</p>

<table>
  <thead>
    <tr>
      <th style="text-align: center">Symbol</th>
      <th style="text-align: center">Meaning</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td style="text-align: center">$V$</td>
      <td style="text-align: center">Vocabulary (set of tokens)</td>
    </tr>
    <tr>
      <td style="text-align: center">$p_{MLE}$</td>
      <td style="text-align: center">Parameterized model trained using MLE</td>
    </tr>
    <tr>
      <td style="text-align: center">$T$</td>
      <td style="text-align: center">Text length</td>
    </tr>
    <tr>
      <td style="text-align: center">$x$</td>
      <td style="text-align: center">Input context</td>
    </tr>
    <tr>
      <td style="text-align: center">$y$</td>
      <td style="text-align: center">Output sequence (either from model or reference)</td>
    </tr>
    <tr>
      <td style="text-align: center">$y_t \in V$ (also denoted as $a_t$ )</td>
      <td style="text-align: center">Token index $t$ in output sequence (either from model or reference)</td>
    </tr>
    <tr>
      <td style="text-align: center">$y_{\textit{model}}$ ($y_{\textit{model}, t}$)</td>
      <td style="text-align: center">Model output sequence ($t^{th}$ token in sequence)</td>
    </tr>
    <tr>
      <td style="text-align: center">$y_{\textit{ref}}$ ($y_{\textit{ref}, t}$)</td>
      <td style="text-align: center">Reference output sequence ($t^{th}$ token in sequence)</td>
    </tr>
    <tr>
      <td style="text-align: center">$D =$ {$(x_i,y_i) | 1 \leq i \leq  N$}</td>
      <td style="text-align: center">Dataset of demonstrations (set of context-reference pairs)</td>
    </tr>
    <tr>
      <td style="text-align: center">$N$</td>
      <td style="text-align: center">Number of demonstrations in $D$</td>
    </tr>
    <tr>
      <td style="text-align: center">$s_t$</td>
      <td style="text-align: center">State (in text generation, this is ($y_{0:t-1},x$)</td>
    </tr>
    <tr>
      <td style="text-align: center">$\pi_{\theta}$</td>
      <td style="text-align: center">Policy parameterized by $\theta$</td>
    </tr>
    <tr>
      <td style="text-align: center">$\pi_{b}$</td>
      <td style="text-align: center">Behavior policy generating demonstrations $D$</td>
    </tr>
    <tr>
      <td style="text-align: center">$M$</td>
      <td style="text-align: center">Number of training steps for GOLD</td>
    </tr>
    <tr>
      <td style="text-align: center">$b$</td>
      <td style="text-align: center">Baseline used in RL for reducing variance</td>
    </tr>
  </tbody>
</table>

<h2 id="gold-algorithm">GOLD Algorithm</h2>

<p>The Generation by Off-policy Learning from Demonstrations (GOLD) algorithm is an off-policy and offline reinforcement learning method that fine-tunes text generation models trained using MLE. It specifically treats text generation as a sequential decision-making process, where the policy is to choose the next token $y_t \in V$ from $V$ given the <em>state</em> of the text $(y_{0:t-1},x)$ ($\pi_{\theta}(y_t|s_t) = p(y_t| y_{0:t-1},x)$), where $y_{0:t-1}$ is the history (either from the reference or model-generated). This policy is parameterized by $\theta$ which is updated using the policy gradient method and a set of demonstrations $D$ containing context-reference pairs.</p>

<p>While it is possible for GOLD to train a text generation model from scratch, there are some major difficulties with it. The action space in text generation is $V$, which can be exceptionally large (typically around $10^4$ tokens or more). This large action space is problematic for RL methods as the overall space it searches can be massive ($O(V^T)$, where $T$ is the average length of each text) and thus will take a longer time to converge to an optimal policy. To improve convergence speed, GOLD starts with a pretrained model and fine-tunes it rather than training one from scratch <a href="#Ranzato2016">(Ranzato et al., 2016)</a>, <a href="#Keneshloo2019">(Keneshloo et al., 2019)</a>.</p>

<p><img src="/public/images/2021-12-01-text-gen-via-lfd/gold-alg-simple.png" alt="GOLD-Algorithm" /></p>

<p>A few things to note in the above algorithm:</p>
<ol>
  <li>There are two policies. The first one is used for importance sampling and is denoted by $\pi_{b}$. The second one is the text generation policy that will be used for generating text during evaluation, denoted by $\pi_{\theta}$.</li>
  <li>The minibatch $B$ is sampled from a dataset of demonstrations $D$. Each $(s_i^t, a_i^t)$ is constructed from a single demonstration $(x_i,y_i) \in D$ as follows: ($s_i^t = (y_{0:t-1}, x), a_i^t = y_t$). Thus, each demonstration will provide $T$ $(s_i^t, a_i^t)$ pairs.</li>
</ol>

<h2 id="how-gold-uses-importance-sampling">How GOLD uses Importance Sampling</h2>
<p>In offline RL, we are provided a set of demonstrations constructed from policy $\pi_{b}$, and we want to learn a policy $\pi_{\theta}$ given these demonstrations. One problem we have here is that the expected value of the return ${\hat Q}(s_t,a_t)$ is supposed to be computed using samples generated by $\pi_{\theta}$. However, we do not have this; rather, we have demonstrations generated by $\pi_{b}$. Thus, we utilize importance sampling to estimate the expectation of ${\hat Q}(s_t,a_t)$ under $\pi_{\theta}$ given samples from $\pi_{b}$.</p>

<p>The weight at index $t$ used by importance sampling is computed as:</p>

\[\begin{align*}
w_t = \prod_{t'=0}^{t}\frac{\pi_{\theta}(a_{t'}|s_{t'})}{\pi_{b}(a_{t'}|s_{t'})}
\end{align*}\]

<p>Intuitively, this captures the probability ratio between the learned policy and the behavioral policy for tokens $y_{0:t}$. However, there are two problems with this equation:</p>
<ol>
  <li>According to the paper, multiplying per-token importance weights for token indices $0$ to $t$ is sensitive to hyperparameters and takes longer to converge.</li>
  <li>We do not know $b$, only the demonstrations constructed by it.</li>
</ol>

<p>To address (1), we can estimate the weights using its per-token form: $w_t =\frac{\pi_{\theta}(a_{t}|s_{t})}{\pi_{b}(a_{t}|s_{t})}$. While this estimate is biased, it has been shown to reduce variance and works reasonably well if both $\pi_{b}$ and $\pi_{\theta}$ are close <a href="#Serban2017">(Serban et al., 2017)</a>, <a href="#Levine2020">(Levine et al, 2020)</a>.
To address (2), we can estimate $\pi_{b}$, but the paper instead assumes a uniform distribution $\pi_{b}(\tau)$ = 1/N, making $\pi_{b}(a_{t}|s_{t})$ constant. This assumption implies that each demonstration in the dataset is equally likely. This then changes the importance weight to $w_t = \pi_{\theta}(a_{t}|s_{t})$.</p>

<h2 id="reward-functions">Reward Functions</h2>

<p>The reward function $r_t = R(s_t, a_t)$ is what steers GOLD to find an optimal policy and thus has a big impact on the performance of a model trained by GOLD. Ideally, we want the reward function to represent the perceptual quality of text (how likely a human would have generated the text given a context) <a href="#Huszar2015">(Huszar, 2015)</a>, <a href="#Hashimoto2019">(Hashimoto et al., 2019)</a>,
so that our learned policy generates text that a human would generate. To this end, three different reward functions are introduced which fall into two categories: <em>sequence-level reward</em> and <em>token-level reward</em>.</p>

<p><strong>Sequence-level reward</strong>: This reward function only provides a reward if the entire demonstration constructed by the model is in the dataset (this does not make assumptions about the likelihood of the demonstrations in the dataset; all are equally likely):</p>

\[R(s_t,a_t) := \begin{cases}
1 &amp; \textit{if }(s_{0:T},a_{0:T}) \in D \wedge t == T \\
0 &amp; \textit{otherwise}
\end{cases}\]

<p>This function is sparse in that it will only be non-zero exactly $N$ times, where $N$ is the number of demonstrations in $D$. RL methods do not do well with sparse rewards as a reward of 0 does not provide any learning signal. Their experiments (summarized in <a href="#mle-vs-gold">MLE vs GOLD</a>) even show that GOLD with this reward function (referred to as GOLD-$\delta$) performs worse than the reward functions that we describe next, which are less sparse.</p>

<p><strong>Token-level reward</strong>: The previous reward function assumes all demonstrations in the dataset are equally likely. However, in text generation tasks, a context can have multiple correct outputs (e.g. if our context is a news article, there can be multiple, different correct summaries of it), each of which can be associated with a probability based on the tokens it contains. This implies then that a context’s reference (text that we want the model to generate) also has a probability associated with it.</p>

<p>To assign a probability to each of the references, we can use an approximation of text perceptual quality, specifically the MLE solution $p_{MLE}$. According to the paper, $p_{MLE}$ is a reasonable approximation to text perceptual quality when $p_{MLE}$ is restricted only to the demonstrations. Given this estimation, two reward functions are defined based on how they are applied to the value function ${\hat Q}(s_t,a_t)$:</p>

<ol>
  <li>
    <p><strong>${\hat Q}(s_t,a_t)$ is a product of probabilities</strong>: $R_p(s,a) := log~p_{MLE}(a|s)$ and ${\hat Q}(s_t,a_t) = \sum_{t’=t}^{T}\gamma^{t’-t} log~p_{MLE}(a_{t’}|s_{t’})$. A sequence will have high reward only if every token has a high likelihood under $p_{MLE}$. Thus, we can think of this as a “strict” reward in that there is no room for errors. GOLD with this reward function is referred to as GOLD-$p$ in the paper.</p>
  </li>
  <li>
    <p><strong>${\hat Q}(s_t,a_t)$ is a sum of probabilities</strong>: $R_s(s,a) := p_{MLE}(a|s)$ and ${\hat Q}(s_t,a_t) = \sum_{t’=t}^{T}\gamma^{t’-t} p_{MLE}(a_{t’}|s_{t’})$ A sequence can have high reward even if one of the tokens is not very likely under $p_{MLE}$ as the low-likelihood token will be marginalized out during summation. In contrast to (1), this reward is more lenient in that there is room for some errors. GOLD with this reward function is referred to as GOLD-$s$ in the paper.</p>
  </li>
</ol>

<h2 id="why-gold-does-offline-rl-vs-online-rl">Why GOLD does Offline RL vs Online RL</h2>
<p>Online RL usually utilizes exploration methods to discover new courses of action in an environment. However, exploration can be detrimental for text generation as it may yield text that has zero reward (e.g. text that is syntactically incorrect). For example, if we have a news article that we want to summarize, exploration could yield summaries that are off-topic. Furthermore, the large action space in text generation makes exploration challenging as space of syntactically incorrect text is most likely larger than the space of syntactically correct text. Thus, we do not want any exploration, but we do want to keep as close as possible to the provided demonstrations.</p>

<p>Offline RL makes sense to use then as it focuses on learning a policy based only on demonstrations. Another advantage with offline RL is that the environment dynamics are known and deterministic in text generation (i.e. the transition from state $y_{0:t-1}$ to $y_{0:t}$ is done by appending $y_t$ to $y_{0:t-1}$). Thus, there is no need to interact with an environment to get the next state.</p>

<h2 id="training-objective">Training Objective</h2>
<p>Recall that the training objective for policy gradient aims to find a policy  that maximizes the expected cumulative reward:</p>

\[J(\theta)=max_{\pi_{\theta}}\mathbb{E}_{\tau \sim \pi_{\theta}} \Big[\sum_{t=0}^{T}\gamma^{t}r_t\Big]\]

<p>Recall from <a href="#background">Background</a> that taking the gradient of this objective function yields the following (instead of $R(\tau)$, we have ${\hat Q}(s_t,a_t)$):</p>

\[\nabla J(\theta)= \mathbb{E}_{\tau \sim \pi_{\theta}} \Big[\sum_{t=0}^{T} \nabla_{\theta}~log(\pi_{\theta}(a_t|s_t)){\hat Q}(s_t,a_t)\Big]\]

<p>Adding the approximated importance sampling weight $\tilde{\pi}_{\theta}(s_t,a_t)$ yields the final gradient:</p>

\[\nabla J(\theta)= \mathbb{E}_{\tau \sim \pi_{\theta}} \Big[\sum_{t=0}^{T} max(u, \tilde{\pi}_{\theta}(a_t|s_t))\nabla_{\theta}~log(\pi_{\theta}(a_t|s_t)){\hat Q}(s_t,a_t)\Big]\]

\[\nabla J(\theta) \approx \sum_{i=0}^{|B|} \Big[\sum_{t=0}^{T} max(u, \tilde{\pi}_{\theta}(a^i_t|s^i_t))\nabla_{\theta}~log(\pi_{\theta}(a^i_t|s^i_t)){\hat Q}(s^i_t,a^i_t)\Big]\]

<p>where the importance sampling weight is lower-bounded by $u$. One thing to note here is that the parameters for the policy used in importance sampling $\tilde{\pi}_{\theta}$ is kept frozen and thus is not updated by the gradient. This policy is, however, periodically updated to be the main policy $\pi_{\theta}$ in the GOLD algorithm. Another thing to note here is that ${\hat Q}$ and $\tilde{\pi}_{\theta}$ utilizes references from the demonstration dataset (i.e. $y_{0:t-1}$ from $s^i_t = (y_{0:t-1}, x)$ are references) while $\pi_{\theta}$ uses model-generated outputs (i.e. $y_{0:t-1}$ from $s^i_t=(y_{0:t-1}, x)$ are model-generated outputs).</p>

<h1 id="mle-vs-gold">MLE vs GOLD</h1>

<p>GOLD was evaluated on four different language generation tasks: <em>extractive summarization</em> (simply called summarization in the original paper), <em>extreme summarization</em>, <em>machine translation</em>, and <em>question generation</em>. The below table provides a summary of the tasks used in the paper, and their corresponding datasets and metrics:</p>

<table>
  <thead>
    <tr>
      <th>Task</th>
      <th>Task Description</th>
      <th>Dataset</th>
      <th>Metric</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>Extractive Summarization (ESUM) (called CNN/DM in paper)</td>
      <td>Generate a few sentence summary given a piece of text, where the sentences are extracted from the original text</td>
      <td><a href="https://github.com/pytorch/fairseq/blob/master/examples/bart/README.summarization.md">CNN/DailyMail</a></td>
      <td>ROUGE-1/2/L</td>
    </tr>
    <tr>
      <td>Extreme Summarization (XSUM)</td>
      <td>Generate a single sentence summary given a piece of text</td>
      <td><a href="https://github.com/pytorch/fairseq/blob/master/examples/bart/README.summarization.md">BBC news</a></td>
      <td>ROUGE-1/2/L</td>
    </tr>
    <tr>
      <td>Machine Translation (MT)</td>
      <td>Generate a translation of a given text in a particular language</td>
      <td><a href="https://github.com/pytorch/fairseq/tree/master/examples/translation">IWSLT14 De-En</a></td>
      <td>BLEU-4</td>
    </tr>
    <tr>
      <td>Natural Question Generation (NQG)</td>
      <td>Generate a question that can be answered by a short span of text found within a given passage</td>
      <td><a href="https://github.com/clovaai/FocusSeq2Seq">SQuAD QA</a></td>
      <td>BLEU-4</td>
    </tr>
  </tbody>
</table>

<p>We will mainly focus on the overall findings in this blog post. More specific experiment results can be found in the original paper.</p>

<h2 id="mle-vs-gold---transformer-and-non-transformer-models">MLE vs GOLD - Transformer and Non-Transformer Models</h2>

<p>GOLD was first compared against MLE for two off-the-shelf non-Transformer models: NQG++ <a href="#Zhou2017">(Zhou et al., 2017)</a> for NQG and Pointer Generator Network (PGN) <a href="#See2017">(See et al.)</a> for extractive summarization (i.e. NQG++ and PGN were trained either with GOLD or MLE). Overall, their results indicated that NQG and PGN trained using GOLD will achieve better BLEU and ROGUE scores than MLE. One interesting thing to note here is that this improvement is at the cost of perplexity; for NQG, MLE had 29.25 compared to 158.45 for the GOLD-$s$ variant (lower perplexity is better). GOLD was then compared against two Transformer models: pretrained BART <a href="#Lewis2020">(Lewis et al, 2020)</a> for NQG, and extractive and extreme summarization, and the original Transformer <a href="#Vaswani2017">(Vaswani et al., 2017)</a> for machine translation. Their results indicate that BART and the Transformer trained using GOLD will achieve better BLEU and ROGUE scores than MLE. Similar to the non-Transformer model, this performance gain is at the cost of perplexity.</p>

<h2 id="mle-vs-gold---human-evaluation">MLE vs GOLD - Human Evaluation</h2>

<p>In addition to the standard metrics in the literature, sentences generated by GOLD+BART were compared against MLE+BART from a human standpoint. The tasks used in these experiments were NQG, ESUM, and XSUM. Specifically, human evaluation was crowdsourced using Amazon Mechanical Turk, where 200 pairs of examples were created for each of the three tasks and each of the three tasks were done by 15 unique evaluators.</p>

<p><strong>NQG Evaluation</strong>: A source paragraph, the questions generated by the MLE-trained model and GOLD-$s$-trained model, and the words in the paragraph that answered the generated questions were presented to each evaluator. Each evaluator was then asked to determine which question was better, or if there was a tie.</p>

<p><strong>ESUM/XSUM Evaluation</strong>: A reference summary of an article, and a summary generated by the MLE-trained model and GOLD-s-model were presented to each
evaluator. Each evaluator was then asked to determine which summary was closer in meaning to the reference summary.</p>

<p>Overall, their results indicate that the workers preferred the output generated via the GOLD-trained model compared to the MLE-trained model.</p>

<h2 id="addressing-exposure-bias--traineval-mismatch">Addressing Exposure Bias + Train/Eval Mismatch</h2>

<p>Recall the main goal of GOLD was to address two key problems with the MLE objective: training/evaluation metric mismatch and exposure bias. Let’s now go into how GOLD exactly addresses these.</p>

<ol>
  <li>
    <p><strong>Exposure Bias</strong>: GOLD suffers less from exposure bias compared to MLE as it uses the history distribution induced by the model when training rather than the gold history. To test this hypothesis, an experiment is run on the NQG task, where text output quality between the two models as the output length increases is used as a proxy when measuring exposure bias. This output quality is computed by using the ratings of Amazon Mechanical Turk workers. Their results indicate that the questions generated with GOLD do not suffer from quality degradation whereas MLE does. As model-generated data is used during inference, it is likely that the first few states would be quite similar to the gold history for models trained using MLE. However, as the model continues to generate output, the difference will accumulate and the model-generated distribution will deviate further and further away from the gold standard’s distribution. To verify that the performance drop is caused by exposure bias and not from other factors of long-sequence generation, the two models are also evaluated by being conditioned on gold histories during evaluation. This would zero out exposure bias, so both models should have similar performance across all time steps. Their results indicate that the NLL losses remain stable across time steps for both MLE and GOLD, supporting the claim that exposure bias caused the performance degradation of MLE.</p>
  </li>
  <li>
    <p><strong>Training/Evaluation Metric Mismatch</strong>: GOLD suffers less from training/evaluation mismatch compared to MLE. To test this hypothesis, an experiment is run on the NQG and ESUM tasks, where the distributions of token-level negative log likelihood (NLL) loss is used to better understand the impact of this mismatch. Evaluation metrics encourage high precision (i.e. text generated from a model must be high quality); thus models that have high precision would be best matched with the evaluation metrics. Their results indicate that the NLL loss is spread out when training using MLE, which indicates that models trained using it try to generate all tokens in the vocabulary. This aligns with the idea that MLE encourages models with high recall, where the model is able generate more diverse text for a given context (i.e. it generates relevant text with irrelevant text for a given context). Their results also indicate that the NLL loss for models trained using GOLD are concentrated on near-zero losses. This actually aligns with the idea that GOLD encourages higher precision, where models trained using it generate a single text given a context (i.e. generates relevant text without irrelevant text for a given context). Thus, models trained using GOLD are better matched with evaluation metrics.</p>
  </li>
</ol>

<h1 id="concluding-remarks">Concluding Remarks</h1>

<p>This blog post provides a better understanding of the GOLD algorithm from the ICLR 2021 paper <em>Text Generation by Learning from Demonstration</em>, and an understanding of how RL is used in text generation. We hope this has been of help to researchers and practitioners in the field of RL and NLP.</p>

<p>We now look to provide some future research questions that we thought of during our survey of this work:</p>
<ol>
  <li>Can we steer GOLD to generate diverse text given a single context? - “Diverse” has several meanings. The paper goes into three different definitions, but we focus on one of them here: the ability to generate a variety of correct generations given one context. GOLD currently can produce high-quality text for a single context and different text given different contexts; however, it may not be able to provide high-quality diverse texts given a single context.</li>
  <li>Can we apply contexts other than text to RL-based language generation models? - This paper focused mainly on textual context (e.g. source text for translation or articles for text summarization). However, there are definitely other non-textual contexts that can be used for text generation. Take for example an image which could be used for caption generation, or game states from computer games, which could be used to generate text for text-based game-playing or story generation.</li>
</ol>

<h1 id="references">References</h1>

<p><a name="Ranzato2016">Marc’Aurelio Ranzato, Sumit Chopra, Michael Auli, and Wojciech Zaremba. Sequence level training with recurrent neural networks. In International Conference on Learning Representations, San Juan, Puerto Rico, May 2-4, 2016, Conference Track Proceedings, 2016.</a></p>

<p><a name="Papineni2002">Kishore Papineni, Salim Roukos, Todd Ward, and Wei-Jing Zhu. Bleu: a method for automatic evaluation of machine translation. In Proceedings of the 40th Annual Meeting of the Association for Computational Linguistics, pp. 311–318, Philadelphia, Pennsylvania, USA, July 2002.</a></p>

<p><a name="Lin2004">Chin-Yew Lin. ROUGE: A package for automatic evaluation of summaries. In Text Summarization Branches Out, pp. 74–81, Barcelona, Spain, July 2004.</a></p>

<p><a name="Keneshloo2019">Yaser Keneshloo, Tian Shi, Naren Ramakrishnan, and Chandan K Reddy. Deep reinforcement learning for sequence-to-sequence models. IEEE Transactions on Neural Networks and Learning Systems, 2019.</a></p>

<p><a name="Serban2017">Iulian V Serban, Chinnadhurai Sankar, Mathieu Germain, Saizheng Zhang, Zhouhan Lin, Sandeep Subramanian, Taesup Kim, Michael Pieper, Sarath Chandar, Nan Rosemary Ke, Sai Rajeshwar, Alexandre de Brebisson, Jose M. R. Sotelo, Dendi Suhubdy, Vincent Michalski, Alexandre Nguyen, Joelle Pineau and Yoshua Bengio. A deep reinforcement learning chatbot. arXiv preprint arXiv:1709.02349, 2017.<a></a></a></p>

<p><a name="Levine2020">Sergey Levine, Aviral Kumar, George Tucker, and Justin Fu. Offline reinforcement learning: Tutorial, review, and perspectives on open problems. arXiv preprint arXiv:2005.01643, 2020.</a></p>

<p><a name="Huszar2015">Ferenc Huszar. How (not) to train your generative model: Scheduled sampling, likelihood, adversary? arXiv preprint arXiv:1511.05101, 2015.</a></p>

<p><a name="Hashimoto2019">Tatsunori Hashimoto, Hugh Zhang, and Percy Liang. Unifying human and statistical evaluation for natural language generation. In Proceedings of the 2019 Conference of the North American Chapter of the Association for Computational Linguistics: Human Language Technologies, Volume 1 (Long and Short Papers), pp. 1689–1701, Minneapolis, Minnesota, June 2019.</a></p>

<p><a name="Zhou2017">Qingyu Zhou, Nan Yang, Furu Wei, Chuanqi Tan, Hangbo Bao, and Ming Zhou. Neural question generation from text: A preliminary study. In National CCF Conference on Natural Language Processing and Chinese Computing, pp. 662–671. Springer, 2017.</a></p>

<p><a name="See2017">Abigail See, Peter J. Liu, and Christopher D. Manning. Get to the point: Summarization with pointer-generator networks. In Proceedings of the 55th Annual Meeting of the Association for Computational Linguistics (Volume 1: Long Papers), pp. 1073–1083, Vancouver, Canada, July 2017.</a></p>

<p><a name="Lewis2020">Mike Lewis, Yinhan Liu, Naman Goyal, Marjan Ghazvininejad, Abdelrahman Mohamed, Omer Levy, Veselin Stoyanov, and Luke Zettlemoyer. BART: Denoising sequence-to-sequence pre-training for natural language generation, translation, and comprehension. In Proceedings of the 58th Annual Meeting of the Association for Computational Linguistics, Seattle, USA, July 2020.</a></p>

<p><a name="Lewis2020">Mike Lewis, Yinhan Liu, Naman Goyal, Marjan Ghazvininejad, Abdelrahman Mohamed, Omer Levy, Veselin Stoyanov, and Luke Zettlemoyer. BART: Denoising sequence-to-sequence pre-training for natural language generation, translation, and comprehension. In Proceedings of the 58th Annual Meeting of the Association for Computational Linguistics, Seattle, USA, July 2020.</a></p>

<p><a name="Vaswani2017">Ashish Vaswani, Noam Shazeer, Niki Parmar, Jakob Uszkoreit, Llion Jones, Aidan N Gomez, Lukasz Kaiser, and Illia Polosukhin. Attention is all you need. In Advances in Neural Information Processing Systems, pp. 5998–6008, 2017.</a></p>

</div>

<div id="bibtex-container" class="related">
  For attribution in academic contexts, please cite this work as
  <pre id="bibtex-academic-attribution">

  </pre>

  BibTeX citation
  <pre id="bibtex-box">

  </pre>
</div>
<script>
  let authorsSpan = document.getElementById("iclr-post-authors");
  let authorsText = authorsSpan.textContent;
  let lnameFnameInstitution = authorsText.split(";");
  let lfiList = lnameFnameInstitution.map(lfi => lfi.split(",").map(item => item.trim()));
  let bibtexLFI = lfiList.map(lfi => lfi[0] + ", " + lfi[1]).join(" and ")
  let academicLFI = lfiList.map(lfi => lfi[0]);
  {
    if(academicLFI.length > 2) academicLFI = academicLFI[0] + ", et al.";
    else if(academicLFI.length == 2) academicLFI = academicLFI[0] + " & " + academicLFI[1];
    else academicLFI = academicLFI[0];
  }

  let titleSpan = document.getElementById("iclr-post-title");
  let titleText = titleSpan.textContent.trim();
  let bibtexTitleShorthand = (lfiList[0][1]+
    "2022"+
    titleText.split(" ").slice(0, 3).join("")
  ).replace(" ", "").replace(/[\p{P}$+<=>^`|~]/gu, '').toLowerCase().trim();

  let bibtexTemplate = `
@inproceedings{${bibtexTitleShorthand}},
  author = {${bibtexLFI}},
  title = {${titleText}},
  booktitle = {ICLR Blog Track},
  year = {2022},
  note = {${window.location.href}},
  url  = {${window.location.href}}
}
  `.trim();
  document.getElementById("bibtex-box").innerText = bibtexTemplate;

  let academicTemplate = `
${academicLFI}, "${titleText}", ICLR Blog Track, 2022.
`.trim();
  document.getElementById("bibtex-academic-attribution").innerText = academicTemplate;

</script>



<script src="https://utteranc.es/client.js"
        repo="iclr-blog-track/iclr-blog-track.github.io"
        issue-term="pathname"
        label="utterance"
        theme="boxy-light"
        crossorigin="anonymous"
        >
</script>


      </div>
    </div>

    <label for="sidebar-checkbox" class="sidebar-toggle"></label>

    <script src='/public/js/script.js'></script>
  </body>
</html>
