<!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>
    
      Contrasting LMU with LSTM &middot; The ICLR Blog Track
    
  </title>

  
  <link rel="canonical" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/2021/09/01/Contrasting-LMU-with-LSTM/">
  

  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/public/css/poole.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/public/css/syntax.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/public/css/lanyon.css">
  <link rel="stylesheet" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/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/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/public/apple-touch-icon-precomposed.png">
  <link rel="shortcut icon" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/public/favicon.ico">

  <link rel="alternate" type="application/rss+xml" title="RSS" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/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/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/">ICLR 2022 Blog Track</a>
        
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/about/">About</a>
        
      
    
      
    
      
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/submitting/">Submitting</a>
        
      
    
      
        
          <a class="sidebar-nav-item" href="https://iclr.iro.umontreal.ca/2c374fb5-36ff-4d46-aecc-1cadd962a845_1639780789/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; 2021. 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">Contrasting LMU with LSTM</h1>
  <span class="post-date">01 Sep 2021 | 
    <a class="content-tag" href="/tags/#machine-learning"> machine-learning </a>
  </span>

  <span id="iclr-post-authors" class="post-date">Anonymous</span>
  <p>Both Hidden Markov Model (HMM) and Recurrent Neural Network (RNN) suffer from disappearing transitions and (vanishing \&amp; exploding) gradient problems. LSTM maintains a long time-range dependency on a sequencing task. However, information flow in the network tends to saturate once the number of time steps exceeds a few thousand. Legendre Memory Unit (LMU) is a revolutionary evolution on the design of RNN that can conveniently handle extremely long-range dependency. Let’s try to figure out why the LMU exceeds the performance of the LSTM in this blog. We proceed by reviewing the paper that introduced LMU.
This article is a summary of the paper titled <a href="https://papers.nips.cc/paper/9689-legendre-memory-units-continuous-time-representation-in-recurrent-neural-networks.pdf">Legendre Memory Units: Continuous-Time Representation in Recurrent Neural Networks</a> published in <a href="https://nips.cc/">NeurIPS 2019</a>.
Information about the paper are as follows:</p>
<ul>
  <li>Authors: Aaron R. Voelker, Ivana Kajic, Chris Eliasmith</li>
  <li>Source code:  <a href="https://github.com/abr/neurips2019">Keras implementation of LMU</a>.</li>
  <li>Video: <a href="https://youtu.be/8t64QaTdBcU">video link</a>
We will not rehash the description of LSTM in this blog as Chris Olah has already given an excellent explanation in his blog post titled <a href="https://colah.github.io/posts/2015-08-Understanding-LSTMs/">Understanding LSTM Networks</a>. We provide a quick summary of his blog to set the stage for understanding LMU.
    <h5 id="what-is-a-legendre-transforms-how-does-it-relate-to-the-popular-fourier-transforms">What is a Legendre transforms, how does it relate to the popular Fourier transforms?</h5>
    <p>Legendre transformation is a self-inverse transformation of a quantity into a set of convex functions. For example, in classical mechanics, we can decompose “position” into conjugate quantity (e.g velocity, acceleration, and momentum). There exists a specialization of the Legendre transformation to non-convex functions. Fourier transformation is a function that converts quantities from the time domain into frequency domains. On the contrary, inverse Fourier transforms to convert from the frequency domain back into the time domain.
Legendre transformation models the problem as a convex set defined by many supporting hyperplanes. We contrast with Fourier transforms where any function can be modeled as a weighted combination of sine (cosine) functions. The conjugate quantity in Legendre transformation can be likened to the orthonormal basis in the Fourier transformation. These transformations (Legendre transformation, Fourier transformation) have wide applicability in several applied domains. For more information on <a href="https://jmanton.wordpress.com/2010/11/21/introduction-to-the-legendre-transform/">Legendre transformation</a>.</p>
    <h3 id="lstm">LSTM</h3>
    <p>LSTM depends on a mix of gating mechanisms and non-linearity to minimize the vanishing and exploding gradient problems that occur in default RNNs. Some of the vanishing gradient problems are due to saturation. Saturation leads to loss of performance in LSTM, and as a result, several variants of LSTM have been proposed in the literature to minimize the effect of saturation.
The reliance on squeezing function ( such as sigmoid, tanh for their gating effects) plays a role in an increased chance of saturation, inadvertently affecting the ability to capture long time-range dependency in a sequence.
The LSTM has the weights of its parameters initialized to random values. Unfortunately, this problematic decision could have a significant impact on the quality of the optimization.</p>
    <h3 id="lmu">LMU</h3>
    <p>LMU makes use of fewer computational resources to maintain long-range time dependencies by decomposing time history in a $d$, number of Ordinary Differential Equation (ODE) where the sliding window is represented by using Legendre polynomials with at most $d-1$ degree. LMU can handle extremely long-time range dependency using fewer internal states to conveniently capture the dynamics of the sequence within long time intervals.
Let us rehash the mathematical formulation of LMU and use this knowledge to understand why the LMU is superior in performance to the LSTM. 
The cell begins with F(s) as shown in the LMU paper. $\theta$ is a strictly positive scalar value and represents the size of the window.
\begin{equation}
F(s) = e^{-\theta s}
\end{equation}
Taking the natural log of both sides results in
\begin{equation}
ln F(s) = ln e^{-\theta s}
\end{equation}
\begin{equation}
ln F(s) = -\theta s
\end{equation}
The paper makes the assumption that $s$ is equivalent to state vector, $m(t) \in R^{d}$. $\hat{m(t)}$ is updated value of state vector, and $m(t)$ is current value of state vector.
Equation 1 of the paper shows $\theta \hat{m(t)} = Am(t) + Bu(t)$. This is a common formulation in dynamic system modeling and hence a link to this <a href="https://kenluck2001.github.io/blog_post/pysmooth_a_time_series_library_from_first_principles.html">blog</a> that discusses Kalman filters.
In pursuance of the desired long-range dependency, it is desirable to ensure that $A, B$ are initialized using Equation 2 in the paper as this routine has sound theoretical underpinnings.
The mathematical origins of the routine follow from Pade’s approximation and Legendre polynomials. This scheme results in an architecture that is less likely to saturate as the long time-range dependency is preserved even with smaller time steps.
Using the mathematical formulation in the paper alone. Let us try to write a simplistic pseudo-code to describe the algorithm of LMU in use. With the loss of generality, let us assume a batch size of 1 and the number of iterations set to 1.</p>
  </li>
  <li>Initialize A, B, m(t)</li>
  <li>Run the code block every epoch</li>
  <li>for $t$ in $\theta … n$</li>
  <li>for $\hat{\theta}$ in  $t-\theta$ … $t$    # handle boundaries
    <ul>
      <li>$u(t - \hat{\theta}) = \sum_{i=0}^{d-1} P_{i} \left( \frac{\hat{\theta}}{\theta}\right) m_{i}(t)$   using $P_{i}$ as one of the basis Legendre polynomial from Equation 3 in paper.</li>
    </ul>
  </li>
  <li>$\hat{m(t)} = \frac{Am(t)}{\theta} +  \frac{Bu(t)}{\theta}$</li>
  <li>$m(t) = \hat{m(t)}$ # update the state vector</li>
  <li>update $A, B$ until convergence
The behavior of the LMU can be controlled by setting the window, $\theta$, and the size ($d$) of the state vector, $m(t)$. We can make a storage space versus performance trade-off on a sequencing task by carefully tuning these parameters.
For example, higher values of $d$ can increase the capacity of the cell to retain information that spans long time intervals. Conversely, smaller values of $d$ result in the opposite effects. The effect of modifying the sliding window, $\theta$ is similar ef to the parameter, $d$. As a result, $m(t)$ and $\theta$ are the memory of the dynamic system.
ODE is making a resurgent in the neural world.  For example, the LMU unit makes use of an ODE solver. Here is an excellent tutorial on the <a href="https://jontysinai.github.io/jekyll/update/2019/01/18/understanding-neural-odes.html">ODE</a>. One way to view ResNet is to assume it employs an implicit ODE. The reasoning follows that it has a structure similar to the Euler method for solving ODE by beginning with the input and adding gradient residuals at each layer.
    <h3 id="conclusion">Conclusion</h3>
    <p>The LMU would serve as a better building block for creating encode-decoder architecture to improve sequence-to-sequence modeling tasks. Other structures that work with LSTM are interchangeable with LMU e.g. bidirectional LMU.</p>
  </li>
</ul>

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