<!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>
    
      Discovering Non-Monotonic Autoregressive Ordering for Text Generation Models using Sinkhorn Distributions &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/2021/12/22/non-monotonic-autoregressive-ordering/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/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/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/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/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/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">Discovering Non-Monotonic Autoregressive Ordering for Text Generation Models using Sinkhorn Distributions</h1>
  <span class="post-date">22 Dec 2021 | 
    <a class="content-tag" href="/tags/#autoregressive"> autoregressive </a>
  
    <a class="content-tag" href="/tags/#non-monotonic"> non-monotonic </a>
  
    <a class="content-tag" href="/tags/#nlg"> NLG </a>
  
    <a class="content-tag" href="/tags/#text-generation"> text-generation </a>
  
    <a class="content-tag" href="/tags/#sinkhorn-distributions"> sinkhorn-distributions </a>
  </span>

  <span id="iclr-post-authors" class="post-date">Anonymous</span>
  <h1 id="overview">Overview</h1>

<hr />

<p>Natural-Language-Generation (NLG) is a process for producing a sequence of natural language tokens. While the <em>input</em> to the NLG pipeline includes, but is not limited to, audio, video, image, structured documents, and natural language itself, the <em>output</em> is restricted to human readable texts.</p>

<p>Neural NLG models typically comprise a neural network, called an encoder, for converting inputs to points in vector spaces and a decoder (<a href="#decoding-approaches">Decoding Strategies</a>), that uses the encoded representations, for producing tokens (which can be words, characters or subwords). These tokens, after post-processing, are combined to form a human-readable natural language text.</p>

<p><em>While the primary target audience for this blog are researchers in NLG, anyone with an interest in knowing about or exploring a new research topic in NLG should find this insightful.</em></p>

<p>Since the main focus of this blog is on decoding strategies and a very specific problem in the same domain, we start with an overview of the standard practices in decoding.</p>

<h2 id="decoding-strategies">Decoding Strategies</h2>

<p><strong>Autoregressive Generation</strong>: The most conventional approach for obtaining outputs from a decoder is through something called <em>Autoregressive Generation</em>. In this, the decoder utilizes information obtained from the encoder as well as the previous sequentially generated tokens, to produce a new token. 
Early papers [<a href="#Uria">Uria 2016</a>, <a href="#Germain">Germain 2015</a>, <a href="#Vinyals">Vinyals 2015</a>] showed that the order in which the tokens are generated is critical for determining the <em>best</em> autoregressive sequence. However, owing to the simplicity and intuitiveness of using the standard <em>left-to-right order</em>, they became ubiquituous. The paper (as well as this blog) is an attempt to restore the interest in analysing different ordering schemes for autoregressive token generation. The two main ordering schemes under autoregressive decoding are:</p>

<ol>
<li>    
<em>Monotonic Ordering</em>: A pre-determined order of sequence generation, be it <i>left-to-right</i> or <i>right-to-left</i>, is referred to as monotonic ordering. Mathematically, the modeling objective is:
$$
p(\mathbf{y} \vert \mathbf{x}) = p(y_1 \vert \mathbf{x}) \prod_{i=2}^n p(y_i \vert y_{&lt;i}, \mathbf{x})
$$
Note that the ordering information is implicit in this formulation. It is assumed that the best ordering of sequence to be generated is known.
</li>
<li>    
<em>Adaptive Non-Monotonic Ordering </em>: In the most general cases, determining the order of prediction of generated tokens is helpful for obtaining an optimal final sequence $\mathbf{y}$. More formally, the modeling objective for such an approach is:

$$
p(\mathbf{y}, \mathbf{z} \vert \mathbf{x}) = p(y_{z_1} \vert \mathbf{x})p(z_1 \vert y_{z_1}, \mathbf{x})\prod_{i=2}^n p(y_{z_i} \vert z_{&lt;i}, y_{z_{&lt;i}}\mathbf{x})p(z_i \vert z_{&lt;i}, y_{z_{\leq i}}\mathbf{x})
$$

Although mathematically sound, determining the <i>best order</i> using previous known approaches is empirically challenging, especially in situations where the domain of the data is not provided. The model needs to infer that *adaptively* from the data.

</li>
</ol>

<p align="center">
  <img src="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/images/2021-12-22-non-monotonic-autoregressive-ordering/main_fig_p.png" alt="Decoding" width="60%" />
</p>

<ul>
  <li>In the above figure the top autoregressive strategy (natural order) is that of <em>monotonic left-to-right ordering</em>, while the lower one (generation order) is that of <em>adaptive non-monotonic ordering</em>. It can be seen that in the <em>adaptive non-monotonic</em> strategy the more descriptive tokens or content words like <span style="color:red"> people, now </span> are produced before fillers and determiners like  <span style="color:red">on, the</span>. Note that the generated tokens are permuted (automatically based on the ordering \(\mathbf{z}\)) to form the natural order in case of <em>non-monotonic ordering</em> strategy, for grammaticality.</li>
</ul>

<p>While being empirically superior in terms of quality, auto-regressive generations are <b>time-inefficient</b>. Each token is predicted sequentially and in the case of <i>Non-Monotonic and adaptive ordering</i> the number of time-steps doubles with every new output token since the location is also being predicted apart from the actual token of generation itself. To address this issue of time-inefficiency, another set of techniques were developed under the umbrella term <i>non-autoregressive generation</i>.</p>

<p><strong>Non-Autoregressive Generation</strong>: These approaches decode multiple tokens in parallel but under certain conditional-independent constraints. While being time-efficient, the quality of generations of these sequences is lower as compared to <i>auto-regressive</i> approaches. Most of the work focusing on Non-Autoregressive approaches, typically tries to alleviate the inaccuracies introduced due to the <i>conditional-independence between tokens</i> constraint. This blog discusses the paper [<a href="#Xuanlin">Li 2021</a>] that utilizes one such method to obtain a good set of <i> non-monotonic, adaptive orderings </i> to guide the final <i> autoregressive </i> token generation model.</p>

<hr />

<p><strong>In this post, we will be focusing on one of the lesser explored area - <em>Non-Monotonic Autoregressive Order (NMAO) in  Decoding</em>. In particular, we will be discussing the ICLR 2021 paper “Discovering Non-monotonic Autoregressive Orderings with Variational Inference” [<a href="#Xuanlin">Li 2021</a>], the background needed for understanding the work as well as the way-forward.</strong></p>

<h2 id="table-of-content">Table of Content</h2>

<ol>
  <li><a href="#what-is-the-main-focus-of-this-paper">What is the main focus of this paper?</a></li>
  <li><a href="#2-background">Background</a>
    <ul>
      <li><a href="#a-special-matrices-and-operations">Special Matrices, and Operations</a></li>
      <li><a href="#b-prelude-to-gumbel-sinkhorn">Towards Gumbel Sinkhorn Distribution</a></li>
      <li><a href="#c-jensens-inequality">Jensen’s Inequality</a></li>
      <li><a href="#d-log-trick">The Log Trick</a></li>
    </ul>
  </li>
  <li><a href="#3-what-are-sinkhorn-networks--optional-reading">What are Sinkhorn Networks ?</a></li>
  <li><a href="#4-how-are-nmao-discovered">How are Non-Monotonic Autoregressive Orderings (NMAO) discovered using Sinkhorn Networks ?</a>
    <ul>
      <li><a href="#formulation">Problem Formulation</a></li>
      <li><a href="#variational-order-inference">Variational Order Inference</a></li>
      <li><a href="#optimization-procedure">Optimization Procedure</a></li>
    </ul>
  </li>
  <li><a href="#5-voi-in-practice">Show Me Some Experiments and Results</a>
    <ul>
      <li><a href="#a-quantitative-results">Quantitative Results</a></li>
      <li><a href="#b-qualitative-results">Qualitative Results</a></li>
    </ul>
  </li>
  <li><a href="#6-what-next">What Next ?</a></li>
  <li><a href="#7-conclusion">Conclusion and TL;DR</a></li>
</ol>

<hr />

<h1 id="what-is-the-main-focus-of-this-paper">What is the main focus of this paper?</h1>

<p>The primary aim of this work is to produce high-quality token sequences. An intermediate important step in this is to generate an optimal ordering for guiding autoregressive token generation models. To generate optimal ordering, the paper proposes a <em>domain-independent unsupervised non-autoregressive learner</em> based on Sinkhorn Networks. The key contributions of this paper are:</p>
<ol>
<li>
Propose an encoder architecture that conditions on training examples to output autoregressive orders using techniques in combinatorical optimization. 
</li>
<li>
Propose Variational Order Inference (VOI) that learns an approximate posterior over autoregressive orders. 
</li>
<li>
Develop a practical algorithm for solving the resulting non-differentiable Evidence Lower Bound Objective (ELBO) end-to-end with policy gradients.
</li>
</ol>

<p>In this blog, we will break down each of the contributions and also discuss the results as well as future research directions. Being a technically dense paper, it is imperative to develop a certain level of mathematical maturity. To that end, we provide the necessary mathematical background in the next section.</p>

<hr />

<h1 id="2-background">2. Background</h1>
<p>In this section, we develop the mathematical background necessary for understanding and appreciating the technical contributions of this work.
We start with some special matrices and operations.</p>

<h2 id="a-special-matrices-and-operations">(A) Special Matrices, and Operations</h2>

<h3 id="permutation-sequences-and-permutation-matrix">Permutation Sequences and Permutation Matrix</h3>

<p>A <a href="https://en.wikipedia.org/wiki/Permutation">Permutation sequence</a> is arrangement of elements of a set into any sequence. Mathematically, it is a function \(\sigma: S \to S\), where S is any set, such that every element occurs exactly once as an image value. One such example is $\sigma_i({1,3,5,2,4}) = (3,2,1,5,4)$. A set of all such permutations is denoted as \(\mathcal{S}_n\)</p>

<p><a href="https://en.wikipedia.org/wiki/Permutation_matrix">Permutation Matrices</a> (\(P\)) are square binary matrices having exactly one entry as 1 in each row and each column and 0 elsewhere. A set of all such permutation matrices is denoted as \(\mathcal{P}_{n \times n}\).</p>

<p>It can easily be seen that there exists a natural bijection between \(\mathcal{S}_n\) and \(\mathcal{P}_{n \times n}\). The equivalence between Permutation matrices and sequences can best be understood through an example. Let us consider an \(n\)-dimensional vector (or sequence) \(\mathbf{a} = (a_1, a_2, a_3, a_4)\), and we apply a permutation \(\sigma\) to get 
\((a_2, a_1, a_4, a_3)\) i.e., \(\sigma(a_1, a_2, a_3, a_4)=(a_2, a_1, a_4, a_3)\). The corresponding permutation matrix \(P \in \mathcal{P}_{n \times n}\) for this is 
\(\begin{bmatrix}
0 &amp; 1 &amp; 0 &amp; 0 \\
1 &amp; 0 &amp; 0 &amp; 0 \\
0 &amp; 0 &amp; 0 &amp; 1 \\
0 &amp; 0 &amp; 1 &amp; 0 
\end{bmatrix}\)</p>

<p>This is because:</p>

\[\begin{bmatrix}
0 &amp; 1 &amp; 0 &amp; 0 \\
1 &amp; 0 &amp; 0 &amp; 0 \\
0 &amp; 0 &amp; 0 &amp; 1 \\
0 &amp; 0 &amp; 1 &amp; 0
\end{bmatrix}
\begin{bmatrix}
a_1\\ 
a_2\\
a_3\\
a_4
\end{bmatrix} = 
\begin{bmatrix}
a_2\\ 
a_1\\
a_4\\
a_3
\end{bmatrix} =
\sigma(a_1, a_2, a_3, a_4)\]

<h3 id="matrix-permanents-textpermx-and-bethe-permanents-textperm_bx">Matrix permanents \(\text{perm}(X)\) and Bethe permanents \(\text{perm}_B(X)\)</h3>

<p>Let us recall first the definition of a determinant of a matrix before moving to matrix permanents.</p>

<p>Consider a matrix: \(X \in \mathbb{R}_{n \times n}\). The matrix <strong>determinant</strong> of \(X\) is defined as:</p>

\[\texttt{det}(X) = \sum_{\sigma \in S_n} \left( \texttt{sgn}(\sigma)\prod^{n}_{i=1}X_{i, \sigma_i}\right)\]

<p>where \(\texttt{sgn}(\sigma)\) equals \(+1\) if \(\sigma\) is an even permutation and equals \(−1\) if \(\sigma\) is an odd permutation.</p>

<p>The matrix <strong>permanent</strong> is similar in formulation, but without the \(\texttt{sgn}\) operator. Formally,</p>

\[\texttt{perm}(X) = \sum_{\sigma \in S_n} \prod^{n}_{i=1}X_{i, \sigma_i}\]

<p>While determinants find applications in combinatorics as well as have geometric interpretations (volume of an \(n\)-dimensional parallelepiped), a matrix permanent is mainly used as a combinatorial object and has no such geometric interpretations.</p>

<p>For a special case of non-negative entries i.e., \(X \in \mathbb{R}^+_{n \times n}\) (<em>this will be useful for us later in</em> <a href="#variational-order-inference"><em>VOI</em></a>), the permanent can be approximated using by solving a certain Bethe free energy optimization problem [<a href="#Yedidia">Yedidia 2001</a>]. The <strong>Bethe permanent</strong> is an approximation for a matrix \(X \in \mathbb{R}^+_{n \times n}\) is defined as:</p>

\[\texttt{perm}_B(A) = \texttt{exp}\left(\max_{\gamma \in \mathcal{B}_{n \times n}} \sum_{i, j}\left(\gamma_{i,j}\log X_{i,j} - \gamma_{i,j}\log \gamma_{i,j} + (1-\gamma_{i,j})\log (1-\gamma_{i,j})\right)\right)\]

<p>where \(\mathcal{B}_{n \times n}\) is a <em>doubly-stochastic matrix</em> i.e., a matrix whose each entry is a non-negative real number and each row and each column sums to 1. For e.g.,
\(\begin{bmatrix}
\frac{7}{12} &amp; 0 &amp; \frac{5}{12}  \\
\frac{2}{12} &amp; \frac{6}{12} &amp; \frac{4}{12}  \\
\frac{3}{12} &amp; \frac{6}{12}  &amp; \frac{3}{12} 
\end{bmatrix}\)</p>

<p>Since bethe permanent is an approximation, we should be aware of its upper and lower bounds w.r.t. the matrix permanent [<a href="#Vontobel">Votobel 2010</a>]. Note that the following inequality holds:</p>

\[\sqrt{2}^{-n} \texttt{perm}(A) \leq \texttt{perm}_B(A) \leq \texttt{perm}(A)\]

<p>Now that we have defined all these special types of matrices, it is a good time to talk about Birkhoff Polytopes which is useful for understanding <a href="#3-what-are-sinkhorn-networks--optional-reading">Sinkhorn Networks</a>, and the rest of the blog.</p>

<h3 id="birkhoff-polytopes">Birkhoff Polytopes:</h3>

<p>The <a href="https://en.wikipedia.org/wiki/Birkhoff_polytope">Birkhoff polytope</a> \(\mathcal{B}_n\) is the convex polytope in \(R^{n \times n}\) whose points are the doubly stochastic matrices. This polytope has \(n!\) vertices and by the <a href="https://en.wikipedia.org/wiki/Birkhoff%E2%80%93von_Neumann_theorem">Birkhoff–von Neumann theorem</a> it follows that each vertex is a <strong>permutation matrices</strong>. Further more, any <em>doubly-stochastic matrix</em> can be represented as a convex combination of permutation matrices.</p>

<p>By definitions of permutation matrices, double-stochastic matrices it should be evident that 
\(\mathcal{P}_{n \times n} \subset \mathcal{B}_{n \times n} \subset \mathbb{R}^+_{n \times n}\)</p>

<h2 id="b-prelude-to-gumbel-sinkhorn">(B) Prelude to Gumbel-Sinkhorn</h2>

<h3 id="definition-frobenius-norm">Definition: Frobenius Norm</h3>

<p>Given two matrices $A$ and $B$, $\langle A,B \rangle_F = Tr(A^\top B) = \sum_{ij}\overline{A_{ij}}B_{ij}$</p>

<h3 id="discrete-approximations-for-vectors">Discrete Approximations for Vectors</h3>

<p>We build upon the Sinkhorn operators through an analogy of softmax for permutations.</p>

<p><em>1. Normalization - Softmax Operator</em>: One way to approximate discrete classes from continuous values is using a temperature-dependent softmax function, defined component-wise as: \(\texttt{softmax}_\tau(x)_i = \frac{\texttt{exp}(x_i/\tau}{\sum_j\texttt{exp}(x_j/\tau}\). For \(\tau &gt; 0\), \(\texttt{softmax}_\tau(x)\) is a point in the <a href="https://en.wikipedia.org/wiki/Simplex">probability simplex</a> i.e., a set of vector points such that the co-ordinate wise sum of each of those vectors is 1.
It is also known that as \(\tau \to 0\), \(\texttt{softmax}_\tau(x) \to \texttt{one-hot}(x)_i\), i.e., a binary vector containing only one \(1\) entry at the argmax of \(\texttt{softmax}_\tau(x)\) and \(0\), elsewhere.</p>

<p><em>2. Maximization Problem</em>:
Finding \(\texttt{one-hot}(x)_i\) can be cast as a maximization problem i.e.,
\(\text{argmax }{x_i}=\text{argmax}_{s\in\mathcal{S}_n}\langle x,s\rangle\), where \(\mathcal{S}_n\) is a set of all \(n\)-dimensional permutations, defined earlier.
In essence, we start with a normalization of a vector (\(\texttt{softmax}\) operation), then cast the \(\texttt{one-hot}\) permutation vector finding as a linear-maximization problem.</p>

<h3 id="sinkhorn-operations-discrete-approximations-for-matrices">Sinkhorn Operations: Discrete Approximations for Matrices</h3>

<p>Moving to two-dimensions i.e., vectors to matrices, we do a similar thing. We first define a normalization operator (called Sinkhorn Operator), and then formulate the problem of finding a permutation matrix as a linear-maximization problem. An equivalent temperature dependent Sinkhorn operator helps in a discrete approximation of continuous values in a <a href="#birkhoff-polytopes">Birkhoff polytope</a>.</p>

<p><em>1. Normalization - Sinkhorn Operator</em>:
Let \(X \in \mathbb{R}_{n \times n}\) and \(A \in \mathbb{R}^+_{n \times n}\). A Sinkhorn operator is an iterative construct defined as follows:</p>

\[S^0(X) = \exp(X) \\
S^l(X) = \mathcal{T}_c(\mathcal{T}_r(S^{l-1}(X))) \\
S(X) = \lim_{l \to \infty}S^l(X),\]

<p>where \(\mathcal{T}_c = A \oslash (A\mathbf{1}_N\mathbf{1}_N^\top)\) and \(\mathcal{T}_r = A \oslash (\mathbf{1}_N\mathbf{1}_N^\top A)\). Here \(\oslash\) represents element-wise division, and \(\mathbf{1}_N\) is the vector of all \(1\)s. Informally, iterative application of \(\mathcal{T}\) results in normalizing a non-negative matrix along columns and rows.</p>

<p><strong>Important</strong>: It is interesting to note that \(S(X)\) belongs to the Birkhoff polytope i.e., it is necessarily a doubly-stochastic matrix. [<a href="#Sinkhorn1964">Sinkhorn 1964</a>]</p>

<p><em>2. Maximization Problem</em>:
Finding a \(\texttt{one-hot}\) vector in two-dimensions is equivalent to finding a permutation matrix. This too can be cast as a maximization problem involving matrix \(X\) as follows:</p>

\[M(X) = \text{argmax}_{P \in \mathcal{P}_N} \langle P, X\rangle_F\]

<p>here \(M(\cdot)\) is called the matching operator.</p>

<p>Like softmax, a temperature-dependent Sinkhorn operator also has some similar interesting properties when \(\tau \to 0\). But first we need to understand that the temperature-dependent Sinkhorn operator \(S(X/\tau)\) solves a certain entropy-regularized problem in the Birkhoff polytope \(\mathcal{B}_n\).</p>

<h4 id="theorem-1">Theorem 1</h4>

<p>For a doubly-stochastic matrix \(P\) (having entropy as: \(h(P) = - \sum_{i, j}P_{ij}\log P_{ij}\)),</p>

\[S(X/\tau) = \text{argmax}_{P \in \mathcal{B}_N} \langle P, X\rangle _F + \tau h(P)\]

<p>and under certain assumptions regarding the entries of $X$ (see <a href="#Mena">Mena 2018</a>) , the following convergence holds:</p>

\[M(X) = \lim_{\tau \to 0^+} S(X/\tau)\]

<p>where M(X) is a permutation matrix from the Birkhoff Polytope.</p>

<p>In practice, since taking limits for the Sinkhorn operator on \(l\) is infeasible, a truncated version of the Sinkhorn operator is considered ($l \to L$ where $L \in \mathbb{N}$).</p>

<h2 id="c-jensens-inequality">(C) Jensens’ Inequality</h2>

<p>For a convex function $f$ the following inequality (<a href="https://en.wikipedia.org/wiki/Jensen%27s_inequality">Jensens’ Inequality</a>) holds:</p>

\[f(\mathbb{E}(X)) \leq \mathbb{E}(f(x)),\]

<p>where $\mathbb{E}(X)$ is the Expectation over the random variable $X$.  It can be intuitively understood through the following diagram. Here $f$ is a univariate function over $X$. Functional value of the Expectation (<span style="color:black;text:bold">black line</span>) is less than the Expectation value of the function (<span style="color:magenta">magenta/pink line</span>)</p>

<p align="center">
  <img src="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/images/2021-12-22-non-monotonic-autoregressive-ordering/ConvexFunction.svg" alt="Convex Functions" width="50%" />
</p>

<h2 id="d-log-trick">(D) Log Trick</h2>

<p>In policy gradient algorithms, we are required to compute gradients of the Expected Value of Logs. A clever replacement trick helps in deriving the gradient, easily. <em>The following is for the discrete random variable, however a similar results holds true for continuous random variables.</em></p>

<p>Let \(\mathbb{E}_{q_\phi}[\log(p_\theta) - b]\) be the expected value of \(\log(p_\theta) - b\) under the distribution $q_\phi$. Here \(b\) (will be useful and referred to as baseline formulation in <a href="#optimization-procedure">Optimization Procedure</a>) is a constant. Then the derivative of it w.r.t. \(\phi\) is,</p>

\[\begin{split}
\nabla_\phi \mathbb{E}_{q_\phi}[\log(p_\theta) - b] &amp;= \nabla_\phi \sum(\log(p_\theta) - b).q_\phi\\
&amp;=  \sum(\log(p_\theta)-b).\nabla_\phi q_\phi
\end{split}\]

<p>We know that the following holds</p>

\[\begin{split}
&amp;\nabla_\phi \log(q_\phi)  &amp;= \frac{1}{q_\phi}. \nabla_\phi q_\phi \\
\implies &amp;\nabla_\phi q_\phi &amp;= q_\phi(\nabla_\phi \log(q_\phi))
\end{split}\]

<p>Replacing the value of $\nabla_\phi q_\phi$ in the previous equation, we get</p>

\[\begin{split}
\nabla_\phi \mathbb{E}_{q_\phi}[\log(p_\theta) - b] &amp;= \sum(\log(p_\theta) - b).q_\phi \nabla_\phi \log(q_\phi)\\
&amp;= \mathbb{E}_{q_\phi}[(\log(p_\theta) - b).\nabla_\phi \log(q_\phi)] &amp; \\
\text{We know that } \nabla_\phi \mathbb{E}_{q_\phi}[\log(p_\theta) - b] &amp;= \nabla_\phi \mathbb{E}_{q_\phi}[\log(p_\theta)] &amp; (\because b \text{ is a constant}) \\
\implies
\nabla_\phi \mathbb{E}_{q_\phi}[\log(p_\theta)] &amp;= \mathbb{E}_{q_\phi}[(\log(p_\theta) - b).\nabla_\phi \log(q_\phi)] &amp; \\
\end{split}\]

<p><em>Now that we have developed a certain understanding of the mathematical background, let’s discuss Sinkhorn Networks. These networks form one of the main components for finding</em> <strong>good non-monotonic autoregressive orderings.</strong></p>

<hr />

<h1 id="3-what-are-sinkhorn-networks--optional-reading">3. What are Sinkhorn Networks ? [Optional Reading]</h1>

<p><span style="color:purple"> <i>This section is optional and the reader may jump to the Gumbel-Sinkhorn Summary Table directly, if they wish to. We put it here for completeness, since it forms the encoder network in the </i> </span> <a href="#variational-order-inference">VOI model</a> [<a href="#4-how-are-nmao-discovered">Click here to go to section 4</a>]</p>

<p>Sinkhorn Networks (<a href="#Mena">Mena 2016</a>) are supervised models for learning to reconstruct scrambled objects or permutations \(\tilde{X}\) given a set of training examples (\(X_i, \tilde{X_i}\)).</p>

<p align="center">
  <img src="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/images/2021-12-22-non-monotonic-autoregressive-ordering/network.png" alt="Sinkhorn Networks" width="65%" />
</p>

<p>From the above figure it can be seen that the original distorted input \(\tilde{X}\) goes through transformations \(g, g_1, g_2\). The its output is then passed through the temperature-dependent Sinkhorn operator \(S(\cdot)\) during training, and the matching operator \(M(\cdot)\) during inference. \(S(\cdot)\) can be thought of as a soft-permutation. Here, \(P_{\theta, \tilde{X}}\) (in the ideal case) is a permutation matrix mapping \(X \to \tilde{X}\). Unlike traditional neural networks where output changes with any change in the input, Sinkhorn networks are only dependent on the <strong>content of the input and not the order in which they are presented to the network</strong>.</p>

<p>This entails that we should only consider those networks that satisfy the following property of <em>permutation equivariance</em> i.e., \(P_{\theta, P'\tilde{X}}(P'\tilde{X}) = P'(P_{\theta, \tilde{X}}\tilde{X})\), where \(P'\) is any arbitrary permutation matrix.</p>

<p><strong>The main goal of a sinkhorn network is to solve permutation problems like the jigsaw puzzle given in the diagram above or sorting a set of</strong> \(N\) <strong>numbers.</strong> Therefore, it naturally fits into the paradigm of finding good orderings for autoregressive generations and will be leveraged by VOI (<a href="#variational-order-inference">Variational Order Inference</a>). <em>VOI will <strong>not</strong> have access to the ground truth</em> \(X\) <em>for learning good networks although it will have access to gradients based on the final objective of the model, which is to generate high-quality sequences</em>.</p>

<p>While being technically sound, there is another aspect which needs to be understood before moving to the main model - Gumbel-Sinkhorn and Gumbel-Matching distributions.</p>

<p>The best way to go about it is through an analogy with the ubiquituous Gumbel-Softmax. In computational graphs containing stochastic nodes i.e., latent probabistic representations, <a href="#Kingma">Kingma and Welling (2014)</a> proposed the reparameterization trick viz the gumbel trick. Since reparameterisation is not directly differentiable, sampling under a softmax approximation is considered [<a href="#Jang">Jang 2017</a>]. A similar construction is done for Sinkhorn networks where we would want to sample from the Gumbel-Matching Distribution (gumbel-dependent distribution for the matching operator). The Gumbel-softmax is replaced with the Gumbel-Sinkhorn distribution and sampling is done through it (we will see this in the algorithm for <a href="#variational-order-inference">VOI</a>). Without going into complete mathematical details about each step, we state the following useful theorem and the associated table for easy reference.</p>

<h3 id="theorem-2">Theorem 2</h3>
<p>Let \(X \in \mathbb{R}_{n \times n}, \tau &gt; 0\). The \(\textbf{Gumbel-Sinkhorn distribution } \mathcal{G.S.}(X,\tau)\) is defined as follows:</p>

\[\mathcal{G.S.}(X,\tau) = S \left(\frac{X+ \epsilon}{\tau}\right)\]

<p>where \(\epsilon\) is a matrix of i.i.d standard Gumbel noise. Moreover \(\mathcal{G.S.}(X,\tau) \overset{\text{a.s}}{\to} \mathcal{G.M.}(X)\) as \(\tau \to 0^+\). \(\mathcal{G.M.}(X)\) is the Gumbel-Matching distribution.</p>

<p>Since we would want to ideally sample from \(\mathcal{G.M.}(X)\), which makes the backpropagation through the network infeasible directly, a good strategy would be to first sample from \(\mathcal{G.S.}(X,\tau)\) and approximate sample from \(\mathcal{G.M.}(X)\) by taking \(\tau \to 0^+\).
For more information on a.s or almost sure convergence, please refer [<a href="#Convergence">3</a>].</p>

<p>The following table is helpful in understanding the analogy between Gumbel-softmax and Gumbel Sinkhorn Distribution</p>

<table>
<tr>
<th>
</th>
<th>
Classes/Categories
</th>
<th>
Permutations
</th>
</tr>
<tr>
<th>
Polytope
</th>
<td>
Probability Simplex $\mathcal{S}$
</td>
<td>
Birkhoff polytope $\mathcal{B_N}$
</td>
</tr>

<tr>
<th>
Linear program <br />
Approximation
</th>
<td>
$\text{argmax }{x_i}=\text{argmax}_{s\in\mathcal{S}}\langle x,s\rangle$ <br />
$\text{argmax}_i x_i =  \lim_{\tau\rightarrow 0^+}  \text{softmax}(x/\tau)$
</td>
<td>
$M(X)=\text{argmax}_{P\in\mathcal{B}}\left&lt; P,X\right&gt;_F$ <br />
$M(X) = \lim_{\tau\rightarrow 0^+} S(X/\tau)$
</td>
</tr>

<tr>
<th>
Entropy <br />
Entropy regularized linear program
</th>
<td>
$h(s)=\sum_i -s_i \log s_i $ <br />
$ \text{softmax}(x/\tau)=\text{argmax}_{s\in\mathcal{S}}\langle x,s\rangle +\tau h(s)$
</td>
<td>
$h(P)=\sum_{i,j}-P_{i,j}\log\left(P_{i,j}\right)$ <br />
$S(X/\tau)=\text{argmax}_{P\in\mathcal{B}}\left&lt; P,X\right&gt;_F +\tau h(P)$
</td>
</tr>

<tr>
<th>
Reparameterization <br /> <br />
Continuous  approximation
</th>
<td>
$\textbf{Gumbel-max trick}$  <br />
$\text{argmax}_i (x_i+\epsilon_i)$ <br />
$\textbf{Concrete}$ <br />
$\text{softmax}((x+\epsilon)/\tau)$
</td>
<td>
$\textbf{Gumbel-Matching }\mathcal{G}{M}(X)$ <br />
$M(X+\epsilon)$ <br />
$\textbf{Gumbel-Sinkhorn }\mathcal{G}{S}(X,\tau)$ <br />
$S((X+\epsilon)/\tau)$
</td>
</tr>
</table>

<hr />

<h1 id="4-how-are-nmao-discovered">4. How are NMAO discovered?</h1>

<p>The key highlight of the paper is to use variational inference combined with <em>partial</em> Sinkhorn networks for discovering non-monotonic ordering of sequences which in turn is used for generating high-quality autoregressive tokens.</p>

<p>We first formulate the problem, and then discuss the proposed model with an inference framework called Variational Order Inference(VOI). In VOI, we will find out that the Sinkhorn distributions play an important role in sampling <strong>good orderings</strong> \(\mathbf{z}\) (defined in formulation).</p>

<h2 id="formulation">Formulation</h2>

<p>Consider a sequence of source tokens (or source representations in case of non-text input domains) \(\mathbf{x} = (x_1, \ldots, x_m)\). The goal of an NLG model is to model a sequence of target tokens \(\mathbf{y} = (y_1, \ldots,  y_n)\), conditioned on \(x\).</p>

<p>In the standard autoregressive modeling with fixed orderings (monotonic auto-regressive), the model is formulated as follows:</p>

\[p(\mathbf{y} \vert \mathbf{x}) = p(y_1 \vert \mathbf{x}) \prod_{i=2}^n p(y_i|y_{&lt;i}, \mathbf{x})\]

<p>In this work, however, the focus is on modeling non-monotonic autoregressive NLG frameworks, where the position or ordering of the sequence token is not fixed. Let the latent variable to model these orderings be denoted as \(\mathbf{z} = (z_1, \ldots, z_n)\). Each \(z_i\) denotes the position at which \(y_{z_i}\) should be inserted into the sequence \(\mathbf{y}\). Thus instead of modeling \(p(\mathbf{y} \vert \mathbf{x})\) directly, we are interested in modeling \(p(\mathbf{y}, \mathbf{z}\vert\mathbf{x})\) first and marginalizing it over \(z\) to obtain \(p(\mathbf{y} \vert \mathbf{x})\). In order to model this autoregressively, \(p(\mathbf{y}, \mathbf{z}\vert\mathbf{x})\) is factorized as follows:</p>

\[p(\mathbf{y}, \mathbf{z} \vert \mathbf{x}) = p(y_{z_1}\vert\mathbf{x})p(z_1 \vert y_{z_1}, \mathbf{x})\prod_{i=2}^n p(y_{z_i} \vert z_{&lt;i}, y_{z_{&lt;i}}\mathbf{x})p(z_i \vert z_{&lt;i}, y_{z_{\leq i}}\mathbf{x}),\]

<p>Note that \(y_{z_i}\) denotes that the generated token needs to be put in position \(z_i\) of the output sequence, and \(\mathbf{z} \in \mathcal{S}_n\), where \(\mathcal{S}_n\) is a set of permutations of {1, \(\ldots\), n}</p>

<h2 id="variational-order-inference">Variational Order Inference</h2>
<p>The ultimate goal of any NLG model is to obtain <em>high-quality</em> generations conditioned on the original source values. Mathematically, one would like to maximize the likelihood of obtaining output sequence $\mathbf{y}$ i.e., maximize \(\mathbb{E}_{(x,y)\sim\mathcal{D}}[\log p_\theta(\mathbf{y}\vert\mathbf{x})]\). Simplifying it further in terms of latent variable orders $z$ and variational inference, we get the following:</p>

\[\mathbb{E}_{(x,y) \sim \mathcal{D}}[\log p_\theta(\mathbf{y} \vert \mathbf{x})] = \mathbb{E}_{(x,y) \sim \mathcal{D}} \log \left[ \mathbb{E}_{z \sim q_\phi (\mathbf{z} \vert \mathbf{y}, \mathbf{x})} \left[ \frac{p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x})}{q_\phi(\mathbf{z} \vert \mathbf{x}, \mathbf{y})} \right] \right]\]

<p>We know that “$\log$” is a <a href="https://en.wikipedia.org/wiki/Concave_function">concave function</a>. Therefore “$-\log$” is a <a href="https://en.wikipedia.org/wiki/Convex_function">convex function</a>. 
Now applying the <a href="#c-jensens-inequality">Jensen’s inequality</a> on inner \(\log\) and \(\mathbb{E}\) in the RHS, we get</p>

\[\mathbb{E}_{(x,y) \sim \mathcal{D}} \log \left[ \mathbb{E}_{z \sim q_\phi (\mathbf{z}|\mathbf{y}, \mathbf{x})} \left[ \frac{p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x})}{q_\phi(\mathbf{z} \vert \mathbf{x}, \mathbf{y})} \right] \right] \geq \mathbb{E}_{(x,y) \sim \mathcal{D}} \left[ \mathbb{E}_{z \sim q_\phi (\mathbf{z}\vert\mathbf{y}, \mathbf{x})} \left[ \log p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x}) \right] + \mathcal{H}_{q_\phi}( \cdot \vert \mathbf{y}, \mathbf{x}) \right] \\

\mathbb{E}_{(x,y) \sim \mathcal{D}}[\log p_\theta(\mathbf{y}\vert\mathbf{x})] \geq \mathbb{E}_{(x,y) \sim \mathcal{D}} \left[ \mathbb{E}_{z \sim q_\phi (\mathbf{z} \vert \mathbf{y}, \mathbf{x})} \left[ \log p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x}) \right] + \mathcal{H}_{q_\phi}( \cdot \vert \mathbf{y}, \mathbf{x}) \right]\]

<p>We call the right hand side the <strong>main objective</strong> or \(\texttt{ELBO}\). This is the Evidence Lower Bound that needs to be maximized. In other words, we will be using <strong>gradient ascent</strong> i.e., \(\theta = \theta + \alpha_\theta g_\theta\) and \(\phi = \phi + \alpha_\phi g_\phi\), where \(\alpha\) are the learning rates, \(\phi, \theta\) are network parameters and \(g\) are the corresponding gradients of \(\texttt{ELBO}\) w.r.t the network parameters.</p>

<p>Let us understand this diagrammatically via computational graphs to develop better intuitions. Consider the following figure.</p>

<p align="center">
  <img src="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/images/2021-12-22-non-monotonic-autoregressive-ordering/VOI.png" alt="VOI" width="95%" />
</p>

<p>\(\mathbf{y}\) is taken in its natural order and passed through a <strong>non-autoregressive network</strong> (\(\phi\) and the permutation generator (pink)) along with the source value \(\mathbf{x}\) and outputs the latent order \(\mathbf{z}\) (yellow) in the forward pass. \(\theta\) (green) takes in the source value \(\mathbf{x}\) and predicts both \(\mathbf{y}\) as well as the ordering sequence in which the tokens of \(\mathbf{y}\) need to appear (in blue).</p>

<p><strong>[IMPORTANT] Caveat</strong>: The encoder \(\phi\) is in part a <a href="#3-what-are-sinkhorn-networks--optional-reading">Sinkhorn network</a> (albeit without the ground truth order sequence - this is learned from the main objective of the model \(p(\mathbf{y}, \mathbf{z} \vert \mathbf{x})\) through policy gradients), while the decoder \(\theta\) is a fully-differentiable sequence-to-sequence network (in this paper, the transformer network [<a href="#Vaswani">Vaswani 2017</a>, <a href="#Gu">Gu 2019</a>] - which itself has an encoder and a decoder).</p>

<p>The <strong>main objective</strong> is jointly optimized for $\theta$ and $\phi$. <strong>It should be noted that only the decoder $\theta$ is useful during inference/testing (See the blue highlighted portion in the main figure)</strong>. $\phi$ is therefore an assistive network for obtaining <em>high-quality orderings</em> to correctly guide the decoder \(\theta\) towards finally producing <em>high-quality generations</em>.</p>

<h2 id="optimization-procedure">Optimization Procedure</h2>

<p>As discussed before, we will be using <strong>gradient ascent</strong> i.e., \(\theta = \theta + \alpha_\theta g_\theta\) and \(\phi = \phi + \alpha_\phi g_\phi\), where \(\alpha\) are the learning rates, \(\phi, \theta\) are network parameters and \(g\) are the corresponding gradients of \(\texttt{ELBO}\) w.r.t the network parameters. Let’s find out the gradients w.r.t each network parameter.</p>

<h3 id="gradients-for-the-decoder-network-theta">Gradients for the Decoder Network (\(\theta\)):</h3>

<p>Gradient update for \(\theta\) is done using the Monte Carlo gradient estimate. First sample $K$ latent ordering \(\mathbf{z}_1, \ldots, \mathbf{z}_K\) from \(\phi\) (pink in the diagram). Notice in the <strong>main objective</strong> that \(\theta\) appears only in the first term on the RHS. And then the update happens on \(\theta\) using the following gradient estimate:</p>

\[g_\theta = \mathbb{E}_{y \sim \mathcal{D}} \left[ \frac{1}{K} \sum_{i=1}^K \nabla_\theta \log p_\theta (\mathbf{y}, \mathbf{z}_i \vert \mathbf{x}) \right]\]

<h3 id="gradients-for-the-encoder-network-phi-and-finding-optimal-ordering">Gradients for the Encoder Network (\(\phi\)) and finding optimal ordering:</h3>

<p>Although this network would play no role in the final inference model, it does provide the most useful information based on which the decoder \(\theta\) learns to generate <em>high-quality</em> sequences. 
The discrete nature of \(\mathbf{z}\) makes it impossible for gradients to flow from the blue network (\(\log p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x})\)) to the yellow one (\(\phi\)).</p>

<p>Owing to the complexity of this step, we break it down into 2 Stages:</p>

<h4 id="stage-1--the-mdp-formulation"><strong>Stage 1 : The MDP Formulation</strong></h4>

<p>In order to make gradient (backpropagation) flow tractable, the <strong>main objective</strong> is formulated as a one-step Markov decision process having the following constituent parameters (State space: \(\mathcal{S}\), Action space: \(\mathcal{A}\), Reward function: \(\mathcal{R}\)):</p>

<ul>
  <li>
    <p>State Space: \(\mathcal{S} =  (\mathbf{x}, \mathbf{y}) \in \mathcal{D}\)</p>
  </li>
  <li>
    <p>Action Space: \(\mathcal{A} =  S_{\text{length}(\mathbf{y})} \text{ with entropy }\mathcal{H}_{q_\phi}( \cdot \vert \mathbf{y}, \mathbf{x})\)</p>
  </li>
  <li>
    <p>Reward function: \(\mathcal{R} = \log p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x})\)</p>
  </li>
</ul>

<p>Let’s consider the <strong>main objective</strong> again. It is found that adding an coefficient to the entropy term with annealing, speeds up the convergence of the <strong>decoder</strong> network. We now derive the gradient of the <strong>main objective</strong> w.r.t. the encoder network parameters \(\phi\). Because of an MDP formulation, described above, this gradient will be useful as a policy gradient step. Notice that the method involves baseline formulation (\(b(\mathbf{y}, \mathbf{x})\)), which is independent of \(z\), and <a href="#d-log-trick">the log trick</a></p>

\[\begin{split}
g_\phi &amp;= \mathbb{E}_{(x,y) \sim \mathcal{D}} \left[ \mathbb{E}_{z \sim q_\phi (\mathbf{z} \vert \mathbf{y}, \mathbf{x})} \left[ \nabla_\phi \log q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x})) (\log p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x}) - b(\mathbf{y}, \mathbf{x})) \right] + \beta.\nabla_\phi\mathcal{H}_{q_\phi}( \cdot \vert \mathbf{y}, \mathbf{x}) \right]
\end{split}\]

<p>However, it is to be noted that \(b\) is dependent on the state space (\(\mathbf{x}, \mathbf{y}\)). This is done to normalize the reward scale difference across state space, reducing gradient variance and stabilizing the training. In particular,</p>

\[b(\mathbf{y}, \mathbf{x}) = \mathbb{E}_{z \sim q_\phi}[\log p_\theta(\mathbf{y}, \mathbf{z}_i \vert \mathbf{x})]\]

<p>This, can again be estimated using the Monte-Carlo estimates</p>

\[b(\mathbf{y}, \mathbf{x}) \approx \frac{1}{K}\sum_{i=1}^K\log p_\theta(\mathbf{y}, \mathbf{z}_i \vert \mathbf{x})\]

<h4 id="stage-2-closed-form-of-q_phimathbfz-vert-mathbfy-mathbfx">Stage <strong>2: Closed form of</strong> \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x})\)</h4>

<p><strong>Stage 2.a: Closed form of</strong> \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x})\)  <strong>- The Numerator</strong></p>

<p>Having developed an intuition about the gradient RL formulation, we now proceed to discuss one of the critical components of the gradient update  - Obtaining a closed form for the distribution \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x})\). In order to understand this, let us recall our preliminaries on <a href="#a-special-matrices-and-operations">Permutation-Matrices, Birkhoff-Polytopes</a>, and <a href="#gumbel-softmax-and-gumbel-sinkhorn-equivalence">Gumbel-Sinkhorn</a>. We know that \(\mathcal{P}_{n \times n} \subset \mathcal{B}_{n \times n} \subset \mathbb{R}^+_{n \times n}\) and a natural bijection occurs between the the set of permutation matrices \(\mathcal{P}_{n \times n}\) and the set of permutation vectors \(\mathcal{S}_n\).</p>

<p>Let us consider a function \(f_n : \mathcal{S}_n \to \mathcal{P}_{n \times n}\) where \(f_n(\mathbf{z})_i = \texttt{one-hot}(z_i)\). Now since \(z \in \mathcal{S}_n\), \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x}) = q_\phi(f_n(\mathbf{z}) \vert \mathbf{y}, \mathbf{x})\). We now proceed with modeling the distribution \(q_\phi( \cdot \vert \mathbf{y}, \mathbf{x})\). This is exactly the Gumbel-Matching distribution \(\mathcal{G}.\mathcal{M}.(X)\) over \(\mathcal{P}_{n \times n}\) we defined earlier, where \(X = \phi(\mathbf{y}, {x}) \in \mathbb{R}^{n \times n}\). Now for \(P \in \mathcal{P}_{n \times n}\),</p>

\[q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x}) = q_\phi(f_n^{-1}(P) \vert \mathbf{y}, \mathbf{x})  = q_\phi(P \vert \mathbf{y}, \mathbf{x}) \propto \texttt{exp} \langle X, P \rangle_F\]

<p>Note that \(\texttt{exp} \langle X, P \rangle_F\) is only the numerator for the closed of \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x})\). We will discuss about the denominator and final update in Stage 2.b</p>

<p>To obtain samples in \(\mathcal{P}_{n \times n}\) from the Gumbel-Matching distribution, relax \(\mathcal{P}_{n \times n}\) to \(\mathcal{B}_{n \times n}\) by defining the Gumbel-Sinkhorn distribution \(\mathcal{G}.\mathcal{S}.(X, \tau)\). Based on <a href="#theorem-1">Theorem 1</a>, we know that as \(\tau \to 0^+\), \(\mathcal{G}.\mathcal{S}.(X, \tau) \overset{\text{a.s}}{\to} \mathcal{G}.\mathcal{M}.(X)\). For more information on a.s or almost sure convergence, please refer <a href="#Convergence">3</a>].
After relaxation, to approximately sample from \(\mathcal{G}.\mathcal{M}.(X)\), first sample from \(\mathcal{G}.\mathcal{S}.(X, \tau)\) and then apply the <a href="#Hungarian">Hungarian Algorithm</a></p>

<p><strong>Stage 2.b: Closed form of</strong> \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x})\) <strong>- The Denominator</strong></p>

<p>We have already seen that the numerator of \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x}) = \texttt{exp} \langle X, P \rangle_F\), which is tractable. However, the denominator is \(\sum_{P \in \mathcal{P}_{n \times n}}\texttt{exp} \langle X, P \rangle_F\) i.e., a summation over all permutation matrices which is intractable since there are \(n!\) permutation matrices in \(\mathcal{P}_{n \times n}\). Let us first see what it looks like:</p>

\[\begin{split}
q_\phi(\cdot \vert \mathbf{y}, \mathbf{x}) &amp;= \sum_{P \in \mathcal{P}_{n \times n}}\texttt{exp} \langle X, P \rangle_F \\
&amp;= \sum_{\sigma \in S_n} \texttt{exp}\left(\sum_{i=1}^n X_{i, \sigma(i)}\right)\\
&amp;= \sum_{\sigma \in S_n} \prod_{i=1}^n \left(\texttt{exp}(X)\right)_{i, \sigma(i)}\\
&amp;= \texttt{perm}\left(\texttt{exp}(X)\right)
\end{split}\]

<p>We take the help of <a href="#a-special-matrices-and-operations">Bethe permanents</a> defined earlier, and approximate \(\sum_{P \in \mathcal{P}_{n \times n}}\texttt{exp} \langle X, P \rangle_F\) as Bethe permanents.</p>

<p>Having finally obtained the closed form solution of \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x})\), we can optimize \(\phi\) using gradient ascent (since we want to maximize \(\texttt{ELBO}\)) by applying \(g_\phi\).</p>

<h3 id="taking-care-of-the-large-permutation-space">Taking care of the large permutation space</h3>

<p>We have seen that \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x})\) is tremendously complex and requires a lot of computations. A natural question here is: <em>Why go through all this, if the ultimate goal is to just get better final sequences?</em> \(p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x})\). <em>Infact, we won’t even be using the</em> \(\phi\) <em>model during inference.</em> 
While the approximation using Bethe permutation makes \(q_\phi(\mathbf{z} \vert \mathbf{y}, \mathbf{x})\) tractable, it needs to be established whether the overall quality of generations would actually become better. We describe that in a few lines here.</p>

<p>In practice, if \(p_\theta(\mathbf{y}, \mathbf{z}^* \vert \mathbf{x}) \geq p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x}) \forall z \in S_n\) then \(p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x})\) <em>increases</em> as the edit distance between \(\mathbf{z}\) and \(\mathbf{z}^*\) <em>decreases</em>, where \(\mathbf{z}^*\) is the <strong>optimal ordering of the sequence</strong>.</p>

<p>This is what the final update procedure looks like</p>

<p align="center">
  <img src="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/images/2021-12-22-non-monotonic-autoregressive-ordering/VOI_Algo.png" alt="VOI Algorithm" width="75%" />
</p>

<p>Once the model has been trained, we need to generate autoregressive sequences. This is descibed in the following sub-section.</p>

<h3 id="inference">Inference</h3>

<p>As had been previously discussed, \(\phi\) is just an assistive network and will be discarded during inference. The main goal of \(\phi\) is to find a latent order which maximized the probability of \(p_\theta(\mathbf{y}, \mathbf{z} \vert \mathbf{x})\). The decoder model (which is in fact a full sequence-to-sequence <a href="#Vaswani">transformer network</a>) takes an input source value (image, text, etc) and outputs the corresponding text auto-regressively, predicting the sequence tokens as well as the orderings.</p>

<p>In the next section, we discuss the experiments conducted in the paper and the results obtained.</p>

<hr />

<h1 id="5-voi-in-practice">5. VOI in practice</h1>

<p>In the following section, we discuss the findings of running VOI on different NLG tasks. Without going into the exact experimental details regarding each, we discuss only the key findings of the work. We categorize them into the following headings.</p>

<h2 id="a-quantitative-results">A. Quantitative Results</h2>

<h3 id="baselines">Baselines</h3>

<p>Before moving to the quantitative results, we give a brief overview of the baselines that the model is compared with. In this section <strong>Ours</strong> refers to the model (mainly the decoder \(\theta\)) proposed in the original paper [<a href="#Xuanlin">Li 2021</a>].</p>

<ol>
  <li>InDIGO - SAO[<a href="#Gu">Gu 2019</a>]: Previous state-of-the-art baseline in adaptive ordering strategy.</li>
  <li>Ours - Random: Random ordering + Decoder</li>
  <li>Ours - L2R [<a href="#Wu">Wu 2018</a>]: Left-to-right Ordering (standard ordering) + Decoder</li>
  <li>Ours - Common [<a href="#Ford">Ford 2018</a>]: Common-First order is defined as generating words with ordering determined by their relative frequency from high to low + Decoder</li>
  <li>Ours - Rare [<a href="#Ford">Ford 2018</a>]: Reverse of Common-First ordering + Decoder</li>
  <li>Ours - VOI [<a href="#Xuanlin">Li 2021</a>]: This work with non-autoregressive ordering prediction using Sinkhorn Networks + Decoder</li>
</ol>

<table>
    <tr>
    <th colspan="1" rowspan="3">Order</th>
    <th colspan="4">Image Captioning</th>
    <th colspan="2">Code Generation</th>
    <th colspan="3">Text Summarization</th>
    <th colspan="3">Machine Translation</th>
    </tr>
    <tr>
    <th colspan="4">MS-COCO</th>
    <th colspan="2">Django</th>
    <th colspan="3">Gigaword</th>
    <th colspan="3">WMT16 Ro-En</th>
    </tr>
    <tr>
    <th>BLEU</th>
    <th>METEOR</th>
    <th>R-L</th>
    <th>CIDEr</th>
    <th>BLEU</th>
    <th>Accuracy</th>
    <th>R-1</th>
    <th>R-2</th>
    <th>R-L</th>
    <th>BLEU</th>
    <th>METEOR</th>
    <th>TER</th>
    </tr>
    <tr>
    <th>InDIGO - SAO</th>
    <td> 29.3 </td>
    <td> 24.9 </td>
    <td> 54.5 </td>
    <td> 92.9 </td>
    <td> 42.6 </td>
    <td> 32.9 </td>
    <td> -- </td>
    <td> -- </td>
    <td> -- </td>
    <td> 32.5 </td>
    <td> 53.0 </td>
    <td> 49.0 </td>
    </tr>
    <tr>
    <th>Ours - Random</th>
    <td> 28.9 </td>
    <td> 24.2 </td>
    <td> 55.2 </td>
    <td> 92.8 </td>
    <td> 21.6 </td>
    <td> 26.9 </td>
    <td> 30.1 </td>
    <td> 11.6 </td>
    <td> 27.6 </td>
    <td> -- </td>
    <td> -- </td>
    <td> -- </td>
    </tr>
    <tr>
    <th>Ours - L2R</th>
    <td> 30.5 </td>
    <td> 25.3 </td>
    <td> 54.5 </td>
    <td> 95.6 </td>
    <td> 40.5 </td>
    <td> 33.7 </td>
    <td> 35.6 </td>
    <td> 17.2 </td>
    <td> 33.2 </td>
    <td> 32.7 </td>
    <td> 54.4 </td>
    <td> 50.2 </td>
    </tr>
    <tr>
    <th>Ours - Common</th>
    <td> 28.0 </td>
    <td> 24.8 </td>
    <td> 55.5 </td>
    <td> 90.3 </td>
    <td> 37.1 </td>
    <td> 29.8 </td>
    <td> 33.9 </td>
    <td> 15.0 </td>
    <td> 31.1 </td>
    <td> 27.4 </td>
    <td> 50.1 </td>
    <td> 53.9 </td>
    </tr>
    <tr>
    <th>Ours - Rare</th>
    <td> 28.1 </td>
    <td> 24.5 </td>
    <td> 52.9 </td>
    <td> 91.4 </td>
    <td> 31.1 </td>
    <td> 27.9 </td>
    <td> 34.1 </td>
    <td> 15.2 </td>
    <td> 31.3 </td>
    <td> 26.0 </td>
    <td> 48.5 </td>
    <td> 55.1 </td>
    </tr>
    <tr>
    <th>Ours - VOI</th>
    <td><b> 31.0 </b></td>
    <td><b> 25.7 </b></td>
    <td><b> 56.0 </b></td>
    <td><b> 100.6 </b></td>
    <td><b> 44.6 </b></td>
    <td><b> 34.3 </b></td>
    <td><b> 36.6 </b></td>
    <td><b> 17.6 </b></td>
    <td><b> 34.0 </b></td>
    <td> 32.9 </td>
    <td> 54.6 </td>
    <td> 49.3 </td>
    </tr>
</table>

<p>The above table presents the quantitative results for 4 different tasks (each with an associated dataset). The metrics being used are task-specific. It can be seen that VOI seems to be performing better than the baselines in all the tasks, thereby establishing itself as an effective model.</p>

<p>In addition to this, the paper also reports <strong>faster training run-times</strong> compared to its baseline InDIGO [<a href="#Gu">Gu 2019</a>]. This is expected because VOI outputs latent orderings non-autoregressively in a single forward pass while InDIGO searches for the orderings sequentially. Also, the search time increases with the length of the final sequence for InDIGO while it remains constant for VOI.</p>

<h2 id="b-qualitative-results">B. Qualitative Results</h2>

<p>In this section we try to answer three interesting questions:</p>

<p><strong>Question 1.</strong> <em>Does the generation order of tokens convey anything about the sentence and the VOI model?</em></p>

<p align="center">
  <img src="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/images/2021-12-22-non-monotonic-autoregressive-ordering/generationorder.png" alt="Generation Order" width="75%" />
</p>

<p>The key insight here is that the model generates the sentence in the following order: <strong>What to write about</strong> $\to$ <strong>How to write it</strong></p>

<p>In the above figure, the tokens are generated in a top-down fashion. It can be seen that the inference model generates descriptive tokens like nouns, numerals, adverbs, verbs, adjectives e.g., “<span style="color:red">woman, phone</span>”, first, while the uninformative text fillers like “<span style="color:red">in, a, her</span>” are generated at the end. It is similar in some ways to how humans think about sentences, where <em>what to write about</em> precedes <em>how to write it</em>.</p>

<p>This behaviour can also be seen in the following diagram based on the overall dataset statistics.</p>

<p align="center">
  <img src="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/images/2021-12-22-non-monotonic-autoregressive-ordering/pos_index.png" alt="Local Analysis" width="85%" />
</p>

<p>Here it can be seen that the VOI model favours nouns, numerics, adverbs much before pronouns and determiners, as we had seen already. This is in contrast to baseline-L2R ordering where determiners and conjunctions statistically appear much before descriptive tokens like nouns.</p>

<p><strong>Question 2.</strong> <em>Does the model generate orderings other than the standard left-to-right order? If not, it might be computationally wasteful to use this scheme.</em></p>

<p>While the local analysis showed that descriptive words are favoured, this does not fully merit a full understanding of the order strategy that was learned. In general, we want to see if a <strong>fixed ordering strategy is favoured over an adaptive strategy.</strong></p>

<p>To address this, the author compare the orderings \(\mathbf{w}, \mathbf{z}\) for the same output sequence \(\mathbf{y}\). The two metrics used for this analysis are <a href="#errataincomplete-formulation-in-the-main-paper">Normalized Levenshtein Distance</a> \(\mathcal{D}_{\text{NLD}} = \frac{\text{lev}(\mathbf{w}, \mathbf{z})}{n}\), where \(n\) is the length of \(\mathbf{y}\), and the <a href="#errataincomplete-formulation-in-the-main-paper">correlation</a> between the two orderings \(\mathcal{D}_{\text{ORC}}(\mathbf{w},\mathbf{z})\).</p>

<p align="center">
  <img src="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/images/2021-12-22-non-monotonic-autoregressive-ordering/global_stats.png" alt="Global Analysis" width="85%" />
</p>

<p>In the above figure, we see the comparison between VOI learned (adaptive) orders and a set of predefined orders (solid lines). The reference is an L2R fixed ordering model with the same set of predefined orders (dashed lines).</p>

<p>The figure leads to two observations:</p>

<ol>
  <li>It can be seen that although the VOI model favours left-to-right orderings, \(\mathcal{D}_{\text{ORC}}(\mathbf{w},\mathbf{z}) = 0.6\) shows that left-to-right ordering might not be the perfect strategy. A non-zero value for rare-orderings also indicates that sometimes a more complex ordering strategy might be followed to obtain the <em>high-quality</em> generations \(\mathbf{y}\).</li>
  <li>Interestingly, as the generated sequences increase in length, \(\mathcal{D}_{\text{NLD}}\) keeps on decreasing till the final value of 0.57. This shows that approximately half of the tokens (but not all) are already arranged according to a left-to-right generation order. The authors hypothesize that certain phrases might be getting generated from left-to-right, but their arrangement follows a <em>best-first</em> strategy. In other words, the model prefers generation of key semantic phrases, with the correct order of tokens in them, over filler/non-descriptive phrases.</li>
</ol>

<p><strong>Question 3.</strong> <em>To what extent is the generation order learned by Variational Order Inference dependent on the contents of the conditioning variable \(\mathbf{x}\)?. In other words is it adaptive?</em></p>

<p align="center">
  <img src="https://iclr.iro.umontreal.ca/6abdd1f6-d54f-472c-a236-50cabe6b6d5a_1642246469/public/images/2021-12-22-non-monotonic-autoregressive-ordering/perturb.png" alt="Effect of Perturbation" width="75%" />
</p>

<p>With reference to the above figure, VOI first obtains generations \(\mathbf{y}\), and its generation order \(\mathbf{z}\) based on the original source image \(\mathbf{x}\). 
In the next stage, keeping the generation \(\mathbf{y}\) fixed, features are selectively removed from the image \(\mathbf{x}\) (colored bounding boxes) and consequently a new <em>generation-order</em> \(\mathbf{w}\) is inferred for each new image \(\mathbf{x}'\). It is observed that through this operation, the original generation-order \(\mathbf{z}\) and the new generation-order \(\mathbf{w}\) differ from each other which results in non-zero edit distance when measured in terms of <a href="#errataincomplete-formulation-in-the-main-paper">Normalized Levenshtein Distance</a> (\(\mathcal{D}_{\text{NLD}}\)) between \(\mathbf{z}\)  and \(\mathbf{w}\). In the above figure, when the <span style="color:red"> Bus </span> is removed from the image the corresponding change in \(\mathcal{D}_{\text{NLD}}\) is as much as \(0.7\). This shows that the model learns an adaptive strategy to produce generation-orders.</p>

<hr />

<h1 id="6-what-next">6. What Next?</h1>

<p>The first thing would be to get hands on experience with the official code available at <a href="https://github.com/xuanlinli17/autoregressive_inference">https://github.com/xuanlinli17/autoregressive_inference</a>. Handling of the entropy function \(\mathcal{H}_{q_\phi}( \cdot \vert \mathbf{y}, \mathbf{x})\) is an interesting aspect within the code which hasn’t been discussed here. Interested readers are also advised to go through Appendix B.3 in [<a href="#Mena">Mena 2018</a>] to know how the value of entropy is approximated. Dabbling with the code-base would give an opportunity to not only assess the strengths of the model, but also its limitations.</p>

<p>It was interesting to see that the proposed model worked really well in terms of computational speed as well as generation quality. This work paves way to a lot of follow up work. Some good research question worth looking at are:</p>

<ol>
  <li>In this paper, token sequence \(y\) is generated before ordering sequence \(z\). What would happen if \(z\) is generated before the \(y\)?</li>
  <li>Can such an approach be useful for other domains like image generation ?</li>
  <li>Is it possible to develop a non-autoregressive decoder model for generating \(y\) ? Although non-autoregressive models are typically non-monotonic, it might be interesting to see if there is a substantial speed up in terms of inference times.</li>
  <li>While being useful for conditional text generation, can such an approach help or be inducted into open-text-generation problems (Language Modeling with a twist)?</li>
  <li>Are there any other such combinatorial optimization models (like Sinkhorn Networks), that might help in producing optimal orders?</li>
  <li>From a theoretical and an analytical perspective, it might be interesting to see if there exists a unique optimal ordering or is there a set of plausible orderings - all leading to the same <em>high-quality</em> final output.</li>
</ol>

<hr />

<h1 id="7-conclusion">7. Conclusion</h1>

<p>In the blog post we did the following:</p>

<ul>
  <li>Discussed various decoding strategies - monotonic autoregressive, non-monotonic autoregressive ordering and briefly shed light on non-autoregressive ordering [<a href="#overview">Go to Top</a>]</li>
  <li>Developed a comprehensive mathematical background especially the Sinkhorn Operator which is a Matrix equivalent of softmax operator which works on vectors. [<a href="#2-background">Go to Background</a>]</li>
  <li>Gave a brief introduction to Sinkhorn Networks and noted that they are useful for jigsaw puzzle problems. [<a href="#3-what-are-sinkhorn-networks--optional-reading">Go to Sinkhorn Networks</a>]</li>
  <li>Sinkhorn Networks were used for predicted non-monotonic autoregressive ordering, which ultimately helped in predicting orderings akin to how humans would think about a sentence. [<a href="#4-how-are-nmao-discovered">Go to NMAO discovery</a>]</li>
  <li>Deep dive into Variational Order inference and the Optimization procedure. We connected all the necessary background, and Sinkhorn networks to finally get a model that is able to generate <em>high-quality texts</em>. [<a href="#variational-order-inference">Go to VOI</a>], [<a href="#optimization-procedure">Go to Optimization Procedure</a>]</li>
  <li>Discussed the performance of VOI model, and saw that they are faster as compared to other non-monotonic autoregressive models, as well as more intuitive and high performing. [<a href="#5-voi-in-practice">Go to Results</a>]</li>
  <li>Dabbled with some future research directions in this domain. [<a href="#6-what-next">Go to What Next?</a>]</li>
</ul>

<hr />

<h2 id="tldr">TL;DR</h2>

<p>We discussed an important but less researched topic - Discovering non-monotonic orderings for guiding models to obtain high-quality texts. We specifically discussed the model proposed in the ICLR 2021 paper by <a href="#Xuanlin">Li 2021</a>. This model uses Gumbel-Sinkhorn distributions to assist a decoder model by providing <em>good-quality generation orders</em> during training. The trained models helped in generating high-quality outputs for four important NLG tasks: (a) Image Captioning (b) Code Generation (c) Text Summarization and (d) Machine Translation. Interestingly, the model behaviour replicated human behaviour in some sense - Considering what to write about, before figuring out how to write about it.</p>

<hr />

<h3 id="errataincomplete-formulation-in-the-main-paper">Errata/Incomplete formulation in the main paper:</h3>
<ol>
<li>
Normalized Levenshein Distance - Equation (6): 
For two generation orders $\mathbf{w}, \mathbf{z} \in S_n$:

$$
\begin{split}
  \text{lev}(\mathbf{w}, \mathbf{z}) &amp;=
    \begin{cases}
      \color{red}{|\mathbf{w}|} &amp; \color{red}{\text{if } |\mathbf{z}| = 0}\\
      \color{red}{|\mathbf{z}|} &amp; \color{red}{\text{if } |\mathbf{w}| = 0}\\
      \color{red}{\text{lev}(\text{tail}(\mathbf{w}), \text{tail}(\mathbf{z}))} &amp; \color{red}{\text{if } \mathbf{w}[0] = \mathbf{z}[0]}\\
      1 + \text{min}\begin{cases}
      \text{lev}(\text{tail}(\mathbf{w}), \mathbf{z}) \\
      \text{lev}(\mathbf{w}, \text{tail}(\mathbf{z})) \\
      \text{lev}(\text{tail}(\mathbf{w}), \mathbf{z})
      \end{cases}
      &amp; \text{otherwise}
    \end{cases} \\
    \mathcal{D}_{\text{NLD}} (\mathbf{w}, \mathbf{z}) &amp;= \frac{\text{lev}(\mathbf{w}, \mathbf{z})}{n}
  \end{split}
$$
</li>
<li>
Equation (7): $$\mathcal{D}_{\text{ORC}}(\mathbf{w},\mathbf{z}) = 1 - 6. \sum_{i=0}^n \frac{(\mathbf{w}_i-\mathbf{z}_i)\color{red}{^2}}{(n^3-n)}$$
</li>
</ol>
<hr />

<p>Please</p>

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

<p><a name="Xuanlin" href="https://openreview.net/pdf?id=jP1vTH3inC">[1] Xuanlin Li, Brandon Trabucco, Dong Huk Park, Michael Luo, Sheng Shen, Trevor Darrell, Yang Gao. Discovering Non-monotonic Autoregressive Orderings with Variational Inference. ICLR, 2021 </a></p>

<p><a name="Mena" href="https://arxiv.org/pdf/1802.08665.pdf">[2] Gonzalo Mena, David Belanger, Scott Linderman, Jasper Snoek. Learning Latent Permutations with Gumbel-Sinkhorn Networks. ICLR, 2018. </a></p>

<p><a name="Convergence" href="https://en.wikipedia.org/w/index.php?title=Convergence_of_random_variables&amp;oldid=1059383340">[3] Wikipedia contributors. “Convergence of random variables.” Wikipedia, The Free Encyclopedia. Wikipedia, The Free Encyclopedia, 9 Dec. 2021. Web. 13 Jan. 2022. </a></p>

<p><a name="Hungarian" href="https://www.jstor.org/stable/2098689">[4] James R. Munkres. Algorithms for the Assignment and Transportation Problems. Journal of the Society for Industrial and Applied Mathematics, 5(1):32–38, March 1957. </a></p>

<p><a name="Yedidia" href="https://www.merl.com/publications/docs/TR2001-16.pdf">[5] Jonathan S. Yedidia, William T. Freeman, Yair Weiss. Bethe free energy, Kikuchi approximations, and belief propagation algorithms. Mitsubishi Electric Research Laboratories, Inc., 2001 </a></p>

<p><a name="Vontobel" href="https://arxiv.org/pdf/1107.4196.pdf">[6] P. O. Vontobel. The bethe permanent of a non-negative matrix. In 2010 48th Annual Allerton Conference on Communication, Control, and Computing (Allerton), pp. 341–346, 2010.</a></p>

<p><a name="Sinkhorn1964">[7] Richard Sinkhorn “A Relationship Between Arbitrary Positive Matrices and Doubly Stochastic Matrices,” The Annals of Mathematical Statistics, Ann. Math. Statist. 35(2), 876-879, (June, 1964)</a></p>

<p><a name="Uria" href="http://jmlr.org/papers/v17/16-272.html">[8] Benigno Uria, Marc-Alexandre Coˆte ́, Karol Gregor, Iain Murray, and Hugo Larochelle. Neural autoregressive distribution estimation. J. Mach. Learn. Res., 17:205:1–205:37, 2016 </a></p>

<p><a name="Germain" href="http://proceedings.mlr.press/v37/germain15.html">[9] Mathieu Germain, Karol Gregor, Iain Murray, and Hugo Larochelle. Made: Masked autoencoder for distribution estimation. volume 37 of Proceedings of Machine Learning Research, pp. 881–889, Lille, France, 07–09 Jul 2015. PMLR. </a></p>

<p><a name="Vaswani" href="https://proceedings.neurips.cc/paper/2017/file/3f5ee243547dee91fbd053c1c4a845aa-Paper.pdf">[10] Ashish Vaswani, Noam Shazeer, Niki Parmar, Jakob Uszkoreit, Llion Jones, Aidan N Gomez, Łukasz Kaiser, and Illia Polosukhin. Attention is all you need. In I. Guyon, U. V. Luxburg, S. Bengio, H. Wallach, R. Fergus, S. Vishwanathan, and R. Garnett (eds.), Advances in Neural Information Processing Systems 30, pp. 5998–6008. Curran Associates, Inc., 2017 </a></p>

<p><a name="Gu" href="https://doi.org/10.1162/tacl_a_00292">[11] Jiatao Gu, Qi Liu, Kyunghyun Cho. Insertion-based Decoding with Automatically Inferred Generation Order. Transactions of the Association for Computational Linguistics (2019) 7: 661–676. </a></p>

<p><a name="Wu" href="https://www.aclweb.org/anthology/D18-1396">[12] Lijun Wu, Xu Tan, Di He, Fei Tian, Tao Qin, Jianhuang Lai, and Tie-Yan Liu. Beyond error propagation in neural machine translation: Characteristics of language also matter. In Proceedings of the 2018 Conference on Empirical Methods in Natural Language Processing, pp. 3602–3611, Brussels, Belgium, October-November 2018. Association for Computational Linguistics. </a></p>

<p><a name="Ford" href="https://aclanthology.org/D18-1324.pdf">[13] Nicolas Ford, Daniel Duckworth, Mohammad Norouzi, and George E Dahl. The importance of generation order in language modeling. In Proceedings of the 2018 Conference on Empirical Methods in Natural Language Processing, pp. 2942–2946, Brussels, Belgium, October-November 2018. Association for Computational Linguistics. </a></p>

<p><a name="Vinyals" href="https://arxiv.org/pdf/1511.06391.pdf">[14] Oriol Vinyals, Samy Bengio, Manjunath Kudlur. Order Matters: Sequence to sequence for sets. ICLR, 2015 </a></p>

<p><a name="Kingma" href="https://arxiv.org/pdf/1312.6114.pdf">[15] Diederik P Kingma, Max Welling. Auto-Encoding Variational Bayes. ICLR, 2014 </a></p>

<p><a name="Jang" href="https://arxiv.org/pdf/1611.01144.pdf">[16] Eric Jang, Shixiang Gu, Ben Poole. Categorical Reparameterization with Gumbel-Softmax. ICLR, 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>


<div class="related">
  <h2>Related posts</h2>
  <ul class="related-posts">
    
      <li>
        <h3>
          <a href="/2021/09/01/sample-submission/">
            Sample Submission
            <small>01 Sep 2021 | 
    <a class="content-tag" href="/tags/#autoregressive"> autoregressive </a>
  
    <a class="content-tag" href="/tags/#non-monotonic"> non-monotonic </a>
  
    <a class="content-tag" href="/tags/#nlg"> NLG </a>
  
    <a class="content-tag" href="/tags/#text-generation"> text-generation </a>
  
    <a class="content-tag" href="/tags/#sinkhorn-distributions"> sinkhorn-distributions </a>
  </small>
          </a>
        </h3>
      </li>
    
      <li>
        <h3>
          <a href="/2020/04/02/example-content/">
            Example content (Basic Markdown)
            <small>02 Apr 2020 | 
    <a class="content-tag" href="/tags/#autoregressive"> autoregressive </a>
  
    <a class="content-tag" href="/tags/#non-monotonic"> non-monotonic </a>
  
    <a class="content-tag" href="/tags/#nlg"> NLG </a>
  
    <a class="content-tag" href="/tags/#text-generation"> text-generation </a>
  
    <a class="content-tag" href="/tags/#sinkhorn-distributions"> sinkhorn-distributions </a>
  </small>
          </a>
        </h3>
      </li>
    
  </ul>
</div>


<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>
