

<!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>Computing signatures over multiple intervals of the same path efficiently &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="Translation and sampling (reparameterisation) invariance of signatures" href="translation.html" />
    <link rel="prev" title="Combining signatures" href="combine.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 current"><a class="current reference internal" href="#">Computing signatures over multiple intervals of the same path efficiently</a></li>
<li class="toctree-l2"><a class="reference internal" href="translation.html">Translation and sampling (reparameterisation) invariance of signatures</a></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>Computing signatures over multiple intervals of the same path efficiently</li>
    
    
      <li class="wy-breadcrumbs-aside">
        
            
            <a href="../../_sources/pages/examples/intervals.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="computing-signatures-over-multiple-intervals-of-the-same-path-efficiently">
<span id="examples-intervals"></span><h1>Computing signatures over multiple intervals of the same path efficiently<a class="headerlink" href="#computing-signatures-over-multiple-intervals-of-the-same-path-efficiently" title="Permalink to this headline">¶</a></h1>
<p>The basic <a class="reference internal" href="../reference/signatures.html#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> function computes the signature of a whole stream of data. Sometimes we have a whole stream of data, and then want to compute the signature of just the data sitting in some subinterval.</p>
<p>Naively, we could just slice it:</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="c1"># WARNING! THIS IS SLOW AND INEFFICIENT CODE</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">1</span><span class="p">,</span> <span class="mi">1000</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
<span class="n">sig1</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="p">:</span><span class="mi">40</span><span class="p">,</span> <span class="p">:],</span> <span class="mi">3</span><span class="p">)</span>
<span class="n">sig2</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">300</span><span class="p">:</span><span class="mi">600</span><span class="p">,</span> <span class="p">:],</span> <span class="mi">3</span><span class="p">)</span>
<span class="n">sig3</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">400</span><span class="p">:</span><span class="mi">990</span><span class="p">,</span> <span class="p">:],</span> <span class="mi">3</span><span class="p">)</span>
<span class="n">sig4</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">700</span><span class="p">:,</span> <span class="p">:],</span> <span class="mi">3</span><span class="p">)</span>
<span class="n">sig5</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>
</pre></div>
</div>
<p>However in this scenario it is possible to be much more efficient by doing some precomputation, which can then allow for computing such signatures very rapidly. This is done by the <a class="reference internal" href="../reference/path.html#signatory.Path" title="signatory.Path"><code class="xref py py-class docutils literal notranslate"><span class="pre">signatory.Path</span></code></a> class.</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">1</span><span class="p">,</span> <span class="mi">1000</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
<span class="n">path_class</span> <span class="o">=</span> <span class="n">signatory</span><span class="o">.</span><span class="n">Path</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">sig1</span> <span class="o">=</span> <span class="n">path_class</span><span class="o">.</span><span class="n">signature</span><span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="mi">40</span><span class="p">)</span>
<span class="n">sig2</span> <span class="o">=</span> <span class="n">path_class</span><span class="o">.</span><span class="n">signature</span><span class="p">(</span><span class="mi">300</span><span class="p">,</span> <span class="mi">600</span><span class="p">)</span>
<span class="n">sig3</span> <span class="o">=</span> <span class="n">path_class</span><span class="o">.</span><span class="n">signature</span><span class="p">(</span><span class="mi">400</span><span class="p">,</span> <span class="mi">990</span><span class="p">)</span>
<span class="n">sig4</span> <span class="o">=</span> <span class="n">path_class</span><span class="o">.</span><span class="n">signature</span><span class="p">(</span><span class="mi">700</span><span class="p">,</span> <span class="bp">None</span><span class="p">)</span>
<span class="n">sig5</span> <span class="o">=</span> <span class="n">path_class</span><span class="o">.</span><span class="n">signature</span><span class="p">()</span>
</pre></div>
</div>
<p>In fact, the <a class="reference internal" href="../reference/path.html#signatory.Path" title="signatory.Path"><code class="xref py py-class docutils literal notranslate"><span class="pre">signatory.Path</span></code></a> class supports adding data to it as well:</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">path1</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">1</span><span class="p">,</span> <span class="mi">1000</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
<span class="n">path_class</span> <span class="o">=</span> <span class="n">signatory</span><span class="o">.</span><span class="n">Path</span><span class="p">(</span><span class="n">path1</span><span class="p">,</span> <span class="mi">3</span><span class="p">)</span>
<span class="c1"># path_class is considering a path of length 1000</span>
<span class="c1"># calculate signatures as normal</span>
<span class="n">sig1</span> <span class="o">=</span> <span class="n">path_class</span><span class="o">.</span><span class="n">signature</span><span class="p">(</span><span class="mi">40</span><span class="p">,</span> <span class="bp">None</span><span class="p">)</span>
<span class="n">sig2</span> <span class="o">=</span> <span class="n">path_class</span><span class="o">.</span><span class="n">signature</span><span class="p">(</span><span class="mi">500</span><span class="p">,</span> <span class="mi">600</span><span class="p">)</span>
<span class="c1"># more data arrives</span>
<span class="n">path2</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">1</span><span class="p">,</span> <span class="mi">200</span><span class="p">,</span> <span class="mi">5</span><span class="p">)</span>
<span class="n">path_class</span><span class="o">.</span><span class="n">update</span><span class="p">(</span><span class="n">path2</span><span class="p">)</span>
<span class="c1"># path_class is now considering a path of length 1200</span>
<span class="n">sig3</span> <span class="o">=</span> <span class="n">path_class</span><span class="o">.</span><span class="n">signature</span><span class="p">(</span><span class="mi">900</span><span class="p">,</span> <span class="mi">1150</span><span class="p">)</span>
</pre></div>
</div>
<div class="admonition note">
<p class="admonition-title">Note</p>
<p>To be able to compute signatures over intervals like this, then of course <a class="reference internal" href="../reference/path.html#signatory.Path" title="signatory.Path"><code class="xref py py-class docutils literal notranslate"><span class="pre">signatory.Path</span></code></a> must hold information about the whole stream of data in memory.</p>
<p>If only the signature of the whole path is of interest then the main <a class="reference internal" href="../reference/signatures.html#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> function will work fine.</p>
<p>If the signature of a path for which data continues to arrive (analogous to the use of <a class="reference internal" href="../reference/path.html#signatory.Path.update" title="signatory.Path.update"><code class="xref py py-meth docutils literal notranslate"><span class="pre">signatory.Path.update()</span></code></a> above) is of interest, then see <a class="reference internal" href="online.html#examples-online"><span class="std std-ref">Computing the signature of an incoming stream of data</span></a>, which demonstrates how to efficiently use the <a class="reference internal" href="../reference/signatures.html#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> function in this way.</p>
<p>If the signature on adjacent disjoint intervals is required, and the signature on the union of these intervals is desired, then see <a class="reference internal" href="combine.html#examples-combine"><span class="std std-ref">Combining signatures</span></a> for how to compute the signature on each of these intervals, and how to efficiently combine them to find the signature on larger intervals. This then avoids the overhead of the <a class="reference internal" href="../reference/path.html#signatory.Path" title="signatory.Path"><code class="xref py py-class docutils literal notranslate"><span class="pre">signatory.Path</span></code></a> class.</p>
</div>
</div>


           </div>
           
          </div>
          <footer>
  
    <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
      
        <a href="translation.html" class="btn btn-neutral float-right" title="Translation and sampling (reparameterisation) invariance of signatures" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
      
      
        <a href="combine.html" class="btn btn-neutral float-left" title="Combining signatures" 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>