

<!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>Combining 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="Computing signatures over multiple intervals of the same path efficiently" href="intervals.html" />
    <link rel="prev" title="Computing the signature of an incoming stream of data" href="online.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 current"><a class="current reference internal" href="#">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"><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>Combining signatures</li>
    
    
      <li class="wy-breadcrumbs-aside">
        
            
            <a href="../../_sources/pages/examples/combine.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="combining-signatures">
<span id="examples-combine"></span><h1>Combining signatures<a class="headerlink" href="#combining-signatures" title="Permalink to this headline">¶</a></h1>
<p>Suppose we have two paths, and want to combine their signatures. That is, we know the signatures of the two paths, and would like to know the signature of the two paths concatenated together. This can be done with the <a class="reference internal" href="../reference/signatures.html#signatory.signature_combine" title="signatory.signature_combine"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_combine()</span></code></a> function.</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">depth</span> <span class="o">=</span> <span class="mi">3</span>
<span class="n">input_channels</span> <span class="o">=</span> <span class="mi">5</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">10</span><span class="p">,</span> <span class="n">input_channels</span><span class="p">)</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">5</span><span class="p">,</span> <span class="n">input_channels</span><span class="p">)</span>
<span class="n">sig_path1</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">path1</span><span class="p">,</span> <span class="n">depth</span><span class="p">)</span>
<span class="n">sig_path2</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">path2</span><span class="p">,</span> <span class="n">depth</span><span class="p">,</span>
                                <span class="n">basepoint</span><span class="o">=</span><span class="n">path1</span><span class="p">[:,</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="p">:])</span>

<span class="c1">### OPTION 1: efficient, using signature_combine</span>
<span class="n">sig_combined</span> <span class="o">=</span> <span class="n">signatory</span><span class="o">.</span><span class="n">signature_combine</span><span class="p">(</span><span class="n">sig_path1</span><span class="p">,</span> <span class="n">sig_path2</span><span class="p">,</span>
                                           <span class="n">input_channels</span><span class="p">,</span> <span class="n">depth</span><span class="p">)</span>

<span class="c1">### OPTION 2: inefficient, without using signature_combine</span>
<span class="n">path_combined</span> <span class="o">=</span> <span class="n">torch</span><span class="o">.</span><span class="n">cat</span><span class="p">([</span><span class="n">path1</span><span class="p">,</span> <span class="n">path2</span><span class="p">],</span> <span class="n">dim</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
<span class="n">sig_combined</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_combined</span><span class="p">,</span> <span class="n">depth</span><span class="p">)</span>

<span class="c1">### Both options will produce the same value for sig_combined</span>
</pre></div>
</div>
<div class="admonition danger">
<p class="admonition-title">Danger</p>
<p>Note in particular that the end of <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1</span></code> is used as the <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code> when calculating <code class="xref py py-attr docutils literal notranslate"><span class="pre">sig_path2</span></code> in Option 1. It is important that <code class="xref py py-attr docutils literal notranslate"><span class="pre">path2</span></code> starts from the same place that <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1</span></code> finishes. Otherwise there will be a jump between the end of <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1</span></code> and the start of <code class="xref py py-attr docutils literal notranslate"><span class="pre">path2</span></code> which the signature will not see.</p>
<p>If it is known that <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1[:,</span> <span class="pre">-1,</span> <span class="pre">:]</span> <span class="pre">==</span> <span class="pre">path2[:,</span> <span class="pre">0,</span> <span class="pre">:]</span></code>, so that in fact <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1</span></code> does finish where <code class="xref py py-attr docutils literal notranslate"><span class="pre">path2</span></code> starts, then only in this case can the use of <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code> safely be skipped. (And if <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code> is set to this value then it will not change the result.)</p>
</div>
<p>With Option 2 it is clearest what is being computed. However this is also going to be slower: the signature of <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1</span></code> is already known, but Option 2 does not use this information at all, and instead performs a lot of unnecessary computation. Furthermore its calculation requires holding all of <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1</span></code> in memory, instead of just <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1[:,</span> <span class="pre">-1,</span> <span class="pre">:]</span></code>.</p>
<p>Note how with Option 1, once <code class="xref py py-attr docutils literal notranslate"><span class="pre">sig_path1</span></code> has been computed, then the only thing that must now be held in memory is <code class="xref py py-attr docutils literal notranslate"><span class="pre">sig_path1</span></code> and <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1[:,</span> <span class="pre">-1,</span> <span class="pre">:]</span></code>. This means that the amount of memory required is independent of the length of <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1</span></code>. Thus if <code class="xref py py-attr docutils literal notranslate"><span class="pre">path</span></code> is very long, or can grow to arbitrary length as time goes by, then the use of this option (over Option 2) is crucial.</p>
<div class="admonition tip">
<p class="admonition-title">Tip</p>
<p>Combining signatures in this way is the most sensible way to do things if the signature of <code class="xref py py-attr docutils literal notranslate"><span class="pre">path2</span></code> is actually desirable information on its own.</p>
<p>However if only the signature of the combined path is of interest, then this can be computed even more efficiently by</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">sig_path1</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">path1</span><span class="p">,</span> <span class="n">depth</span><span class="p">)</span>
<span class="n">sig_combined</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">path2</span><span class="p">,</span> <span class="n">depth</span><span class="p">,</span>
                                   <span class="n">basepoint</span><span class="o">=</span><span class="n">path1</span><span class="p">[:,</span> <span class="o">-</span><span class="mi">1</span><span class="p">,</span> <span class="p">:],</span>
                                   <span class="n">initial</span><span class="o">=</span><span class="n">sig_path1</span><span class="p">)</span>
</pre></div>
</div>
<p>For further examples of this nature, 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>.</p>
</div>
</div>


           </div>
           
          </div>
          <footer>
  
    <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
      
        <a href="intervals.html" class="btn btn-neutral float-right" title="Computing signatures over multiple intervals of the same path efficiently" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
      
      
        <a href="online.html" class="btn btn-neutral float-left" title="Computing the signature of an incoming stream of data" 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>