

<!DOCTYPE html>
<!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
<!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
<head>
  <meta charset="utf-8">
  
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  
  <title>Translation and sampling (reparameterisation) invariance of signatures &mdash; Signatory 1.2.1 documentation</title>
  

  
  
  
  

  
  <script type="text/javascript" src="../../_static/js/modernizr.min.js"></script>
  
    
      <script type="text/javascript" id="documentation_options" data-url_root="../../" src="../../_static/documentation_options.js"></script>
        <script type="text/javascript" src="../../_static/jquery.js"></script>
        <script type="text/javascript" src="../../_static/underscore.js"></script>
        <script type="text/javascript" src="../../_static/doctools.js"></script>
        <script type="text/javascript" src="../../_static/language_data.js"></script>
        <script async="async" type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/latest.js?config=TeX-AMS-MML_HTMLorMML"></script>
    
    <script type="text/javascript" src="../../_static/js/theme.js"></script>

    

  
  <link rel="stylesheet" href="../../_static/css/theme.css" type="text/css" />
  <link rel="stylesheet" href="../../_static/pygments.css" type="text/css" />
  <link rel="stylesheet" href="../../_static/theme_overrides.css" type="text/css" />
    <link rel="index" title="Index" href="../../genindex.html" />
    <link rel="search" title="Search" href="../../search.html" />
    <link rel="next" title="Using signatures in neural networks" href="neuralnetworks.html" />
    <link rel="prev" title="Computing signatures over multiple intervals of the same path efficiently" href="intervals.html" /> 
</head>

<body class="wy-body-for-nav">

   
  <div class="wy-grid-for-nav">
    
    <nav data-toggle="wy-nav-shift" class="wy-nav-side">
      <div class="wy-side-scroll">
        <div class="wy-side-nav-search" >
          

          
            <a href="../../index.html" class="icon icon-home"> Signatory
          

          
          </a>

          
            
            
              <div class="version">
                1.2.1
              </div>
            
          

          
<div role="search">
  <form id="rtd-search-form" class="wy-form" action="../../search.html" method="get">
    <input type="text" name="q" placeholder="Search docs" />
    <input type="hidden" name="check_keywords" value="yes" />
    <input type="hidden" name="area" value="default" />
  </form>
</div>

          
        </div>

        <div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
          
            
            
              
            
            
              <p class="caption"><span class="caption-text">Documentation</span></p>
<ul class="current">
<li class="toctree-l1"><a class="reference internal" href="../usage/introduction.html">Introduction</a></li>
<li class="toctree-l1"><a class="reference internal" href="../usage/installation.html">Installation</a></li>
<li class="toctree-l1"><a class="reference internal" href="../reference/libraryapi.html">Library API</a></li>
<li class="toctree-l1 current"><a class="reference internal" href="examples.html">Examples</a><ul class="current">
<li class="toctree-l2"><a class="reference internal" href="simple.html">Simple example</a></li>
<li class="toctree-l2"><a class="reference internal" href="online.html">Computing the signature of an incoming stream of data</a></li>
<li class="toctree-l2"><a class="reference internal" href="combine.html">Combining signatures</a></li>
<li class="toctree-l2"><a class="reference internal" href="intervals.html">Computing signatures over multiple intervals of the same path efficiently</a></li>
<li class="toctree-l2 current"><a class="current reference internal" href="#">Translation and sampling (reparameterisation) invariance of signatures</a><ul>
<li class="toctree-l3"><a class="reference internal" href="#translation-invariance">Translation invariance</a></li>
<li class="toctree-l3"><a class="reference internal" href="#sampling-reparameterisation-invariance">Sampling (reparameterisation) invariance</a></li>
</ul>
</li>
<li class="toctree-l2"><a class="reference internal" href="neuralnetworks.html">Using signatures in neural networks</a></li>
</ul>
</li>
</ul>
<p class="caption"><span class="caption-text">Extras</span></p>
<ul>
<li class="toctree-l1"><a class="reference internal" href="../miscellaneous/citation.html">Citation</a></li>
<li class="toctree-l1"><a class="reference internal" href="../miscellaneous/faq.html">FAQ and Known Issues</a></li>
<li class="toctree-l1"><a class="reference internal" href="../understanding/advice.html">Advice on using signatures</a></li>
<li class="toctree-l1"><a class="reference internal" href="../miscellaneous/sourcecode.html">Source Code</a></li>
<li class="toctree-l1"><a class="reference internal" href="../miscellaneous/acknowledgements.html">Acknowledgements</a></li>
</ul>

            
          
        </div>
      </div>
    </nav>

    <section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">

      
      <nav class="wy-nav-top" aria-label="top navigation">
        
          <i data-toggle="wy-nav-top" class="fa fa-bars"></i>
          <a href="../../index.html">Signatory</a>
        
      </nav>


      <div class="wy-nav-content">
        
        <div class="rst-content">
        
          















<div role="navigation" aria-label="breadcrumbs navigation">

  <ul class="wy-breadcrumbs">
    
      <li><a href="../../index.html">Docs</a> &raquo;</li>
        
          <li><a href="examples.html">Examples</a> &raquo;</li>
        
      <li>Translation and sampling (reparameterisation) invariance of signatures</li>
    
    
      <li class="wy-breadcrumbs-aside">
        
            
            <a href="../../_sources/pages/examples/translation.rst.txt" rel="nofollow"> View page source</a>
          
        
      </li>
    
  </ul>

  
  <hr/>
</div>
          <div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
           <div itemprop="articleBody">
            
  <div class="section" id="translation-and-sampling-reparameterisation-invariance-of-signatures">
<span id="examples-translation"></span><h1>Translation and sampling (reparameterisation) invariance of signatures<a class="headerlink" href="#translation-and-sampling-reparameterisation-invariance-of-signatures" title="Permalink to this headline">¶</a></h1>
<p>One of the big attractions of the signature transform is that it may optionally be invariant to two particular types of noise.</p>
<div class="section" id="translation-invariance">
<h2>Translation invariance<a class="headerlink" href="#translation-invariance" title="Permalink to this headline">¶</a></h2>
<p>The signature is translation invariant. That is, given some stream of data <span class="math notranslate nohighlight">\(x_1, \ldots, x_n\)</span> with <span class="math notranslate nohighlight">\(x_i \in \mathbb{R}^c\)</span>, and some <span class="math notranslate nohighlight">\(y \in \mathbb{R}^c\)</span>, then the signature of <span class="math notranslate nohighlight">\(x_1, \ldots, x_n\)</span> is equal to the signature of <span class="math notranslate nohighlight">\(x_1 + y, \ldots, x_n + y\)</span>.</p>
<p>Sometimes this is desirable, sometimes it isn’t. If it isn’t desirable, then the simplest solution is to add a ‘basepoint’. That is, add a point <span class="math notranslate nohighlight">\(0 \in \mathbb{R}^c\)</span> to the start of the path. This will allow us to notice any translations, as the signature of <span class="math notranslate nohighlight">\(0, x_1, \ldots, x_n\)</span> and the signature of <span class="math notranslate nohighlight">\(0, x_1 + y, \ldots, x_n + y\)</span> will be different.</p>
<p>In code, this can be accomplished very easily by using the <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code> argument. Simply set it to <code class="xref py py-attr docutils literal notranslate"><span class="pre">True</span></code> to add such a basepoint to the path before taking the signature:</p>
<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">import</span> <span class="nn">torch</span>
<span class="kn">import</span> <span class="nn">signatory</span>
<span class="n">path</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">rand</span><span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="mi">10</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
<span class="n">sig</span> <span class="o">=</span> <span class="n">signatory</span><span class="o">.</span><span class="n">signature</span><span class="p">(</span><span class="n">path</span><span class="p">,</span> <span class="mi">3</span><span class="p">,</span> <span class="n">basepoint</span><span class="o">=</span><span class="bp">True</span><span class="p">)</span>
</pre></div>
</div>
</div>
<div class="section" id="sampling-reparameterisation-invariance">
<h2>Sampling (reparameterisation) invariance<a class="headerlink" href="#sampling-reparameterisation-invariance" title="Permalink to this headline">¶</a></h2>
<p>The signature is sampling invariant. This has a precise mathematical description in terms of <em>reparameterisation</em>, but the intuition is that it doesn’t matter how many times you measure the underlying path; the signature transform may be applied regardless of how long the stream of data is, or how finely it is sampled. Increasing the number of samples does not require changing anything in the mathematics or in the code. It will simply increase how well the signature of the stream of the data approximates the signature of the underlying path.</p>
<div class="admonition tip">
<p class="admonition-title">Tip</p>
<p>This makes the signature transform an attractive tool when dealing with missing or irregularly-sampled data.</p>
</div>
<p>Let’s given an explicit example.</p>
<p>Suppose the underlying path looks like this:</p>
<a class="reference internal image-reference" href="../../_images/Figure_1.png"><img alt="../../_images/Figure_1.png" src="../../_images/Figure_1.png" style="width: 400px;" /></a>
<p>And that we observe this at particular points (the underlying path is shown as well for clarity):</p>
<a class="reference internal image-reference" href="../../_images/Figure_2.png"><img alt="../../_images/Figure_2.png" src="../../_images/Figure_2.png" style="width: 400px;" /></a>
<p>Alternatively, perhaps we observed this at some other set of points:</p>
<a class="reference internal image-reference" href="../../_images/Figure_3.png"><img alt="../../_images/Figure_3.png" src="../../_images/Figure_3.png" style="width: 400px;" /></a>
<p>Then the signature transform of <span class="math notranslate nohighlight">\(x_1, \ldots, x_{6}\)</span> and <span class="math notranslate nohighlight">\(y_1, \ldots, y_{10}\)</span> will be approximately the same, despite the fact that the two sequences are of different lengths, and sampled at different points.</p>
<div class="admonition important">
<p class="admonition-title">Important</p>
<p>The reason for this is that <em>the index of an element in a sequence</em> is not information that is used by the signature transform.</p>
<p>What this means is that if time (and things that depend on the passing of time, such as speed) is something which you expect your machine learning model to depend upon, then you must <em>explicitly specify</em> this in your stream of data. This is a great advantage of the signature transform: you can use your understanding of the problem at hand to decide whether or not time should be included. Contrast a recurrent neural network, where the passing of time is often <em>implicitly</em> specified by the index of an element in a sequence.</p>
<p>For example, if you want to do handwriting recognition, then you probably don’t care how fast someone wrote something: only the shape of what they wrote.</p>
</div>
</div>
</div>


           </div>
           
          </div>
          <footer>
  
    <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
      
        <a href="neuralnetworks.html" class="btn btn-neutral float-right" title="Using signatures in neural networks" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
      
      
        <a href="intervals.html" class="btn btn-neutral float-left" title="Computing signatures over multiple intervals of the same path efficiently" accesskey="p" rel="prev"><span class="fa fa-arrow-circle-left"></span> Previous</a>
      
    </div>
  

  <hr/>

  <div role="contentinfo">
    <p>
        &copy; Copyright 2020, redacted for anonymity

    </p>
  </div>
  Built with <a href="http://sphinx-doc.org/">Sphinx</a> using a <a href="https://github.com/rtfd/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>. 

</footer>

        </div>
      </div>

    </section>

  </div>
  


  <script type="text/javascript">
      jQuery(function () {
          SphinxRtdTheme.Navigation.enable(true);
      });
  </script>

  
  
    
   

</body>
</html>