

<!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>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="Logsignatures" href="logsignatures.html" />
    <link rel="prev" title="Library API" href="libraryapi.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 current"><a class="reference internal" href="libraryapi.html">Library API</a><ul class="current">
<li class="toctree-l2 current"><a class="current reference internal" href="#">Signatures</a></li>
<li class="toctree-l2"><a class="reference internal" href="logsignatures.html">Logsignatures</a></li>
<li class="toctree-l2"><a class="reference internal" href="path.html">Path</a></li>
<li class="toctree-l2"><a class="reference internal" href="utilities.html">Utilities</a></li>
</ul>
</li>
<li class="toctree-l1"><a class="reference internal" href="../examples/examples.html">Examples</a></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="libraryapi.html">Library API</a> &raquo;</li>
        
      <li>Signatures</li>
    
    
      <li class="wy-breadcrumbs-aside">
        
            
            <a href="../../_sources/pages/reference/signatures.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="signatures">
<span id="reference-signatures"></span><h1>Signatures<a class="headerlink" href="#signatures" title="Permalink to this headline">¶</a></h1>
<p>At the heart of the package is the <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> function.</p>
<div class="admonition note">
<p class="admonition-title">Note</p>
<p>It comes with quite a lot of optional arguments, but most of them won’t need to be used for most use cases. See <a class="reference internal" href="../examples/simple.html#examples-simple"><span class="std std-ref">Simple example</span></a> for a straightforward look at how to use it.</p>
</div>
<dl class="function">
<dt id="signatory.signature">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">signature</code><span class="sig-paren">(</span><em class="sig-param">path: torch.Tensor</em>, <em class="sig-param">depth: int</em>, <em class="sig-param">stream: bool = False</em>, <em class="sig-param">basepoint: Union[bool</em>, <em class="sig-param">torch.Tensor] = False</em>, <em class="sig-param">inverse: bool = False</em>, <em class="sig-param">initial: Union[None</em>, <em class="sig-param">torch.Tensor] = None</em>, <em class="sig-param">scalar_term: bool = False</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.signature" title="Permalink to this definition">¶</a></dt>
<dd><p>Applies the signature transform to a stream of data.</p>
<p>The input <code class="xref py py-attr docutils literal notranslate"><span class="pre">path</span></code> is expected to be a three-dimensional tensor, with dimensions <span class="math notranslate nohighlight">\((N, L, C)\)</span>, where
<span class="math notranslate nohighlight">\(N\)</span> is the batch size, <span class="math notranslate nohighlight">\(L\)</span> is the length of the input sequence, and <span class="math notranslate nohighlight">\(C\)</span> denotes the number of
channels. Thus each batch element is interpreted as a stream of data <span class="math notranslate nohighlight">\((x_1, \ldots, x_L)\)</span>, where each
<span class="math notranslate nohighlight">\(x_i \in \mathbb{R}^C\)</span>.</p>
<p>Let <span class="math notranslate nohighlight">\(f = (f_1, \ldots, f_C) \colon [0, 1] \to \mathbb{R}^C\)</span>, be the unique continuous piecewise linear path
such that <span class="math notranslate nohighlight">\(f(\tfrac{i - 1}{N - 1}) = x_i\)</span>. Then and the signature transform of depth <code class="xref py py-attr docutils literal notranslate"><span class="pre">depth</span></code> is
computed, defined by</p>
<div class="math notranslate nohighlight">
\[\mathrm{Sig}(\text{path}) = \left(\left( \,\underset{0 &lt; t_1 &lt; \cdots &lt; t_k &lt; 1}{\int\cdots\int} \prod_{j = 1}^k \frac{\mathrm d f_{i_j}}{\mathrm dt}(t_j) \mathrm dt_1 \cdots \mathrm dt_k \right)_{\!\!1 \leq i_1, \ldots, i_k \leq C}\right)_{\!\!1\leq k \leq \text{depth}}.\]</div>
<p>This gives a tensor of shape</p>
<div class="math notranslate nohighlight">
\[(N, C + C^2 + \cdots + C^\text{depth}).\]</div>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>path</strong> (<a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>) – The batch of input paths to apply the signature transform to.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – The depth to truncate the signature at.</p></li>
<li><p><strong>stream</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to False. If False then the usual signature transform of the whole path is
computed. If True then the signatures of all paths <span class="math notranslate nohighlight">\((x_1, \ldots, x_j)\)</span>, for <span class="math notranslate nohighlight">\(j=2, \ldots, L\)</span>,
are returned. (Or <span class="math notranslate nohighlight">\(j=1, \ldots, L\)</span> is <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code> is passed, see below.)</p></li>
<li><p><strong>basepoint</strong> (bool or <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>, optional) – Defaults to False. If <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code> is True then an
additional point <span class="math notranslate nohighlight">\(x_0 = 0 \in \mathbb{R}^C\)</span> is prepended to the path before the signature transform is
applied. (If this is False then the signature transform is invariant to translations of the path, which may
or may not be desirable. Setting this to True removes this invariance.)
Alternatively it may be a <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a> specifying the value of <span class="math notranslate nohighlight">\(x_0\)</span>, in which case it should
have shape <span class="math notranslate nohighlight">\((N, C)\)</span>.</p></li>
<li><p><strong>inverse</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to False. If True then it is in fact the inverse signature that is computed.
(Signatures form a group under the operation of the tensor product; the inverse is defined with respect to
this operation.) From a machine learning perspective it does not particularly matter whether the signature
or the inverse signature is computed - both represent essentially the same information as each other.</p></li>
<li><p><strong>initial</strong> (None or <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>, optional) – Defaults to None. If it is a <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a> then it
must be of size <span class="math notranslate nohighlight">\((N, C + C^2 + ... + C^\text{depth})\)</span>, corresponding to the signature of another path.
Then this signature is pre-tensor-multiplied on to the signature of <code class="xref py py-attr docutils literal notranslate"><span class="pre">path</span></code>. For a more thorough
explanation, see <a class="reference internal" href="../examples/online.html#examples-online"><span class="std std-ref">this example</span></a>.</p></li>
<li><p><strong>scalar_term</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to False. If True then the first channel of the computed signature will
be filled with the constant 1 (in accordance with the usual mathematical definition). If False then this
channel is omitted (in accordance with useful machine learning practice).</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p><p>A <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>. Given an input <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a> of shape <span class="math notranslate nohighlight">\((N, L, C)\)</span>, and input arguments
<code class="xref py py-attr docutils literal notranslate"><span class="pre">depth</span></code>, <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code>, <code class="xref py py-attr docutils literal notranslate"><span class="pre">stream</span></code>, then the return value is, in pseudocode:</p>
<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="k">if</span> <span class="n">stream</span><span class="p">:</span>
    <span class="k">if</span> <span class="n">basepoint</span> <span class="ow">is</span> <span class="bp">True</span> <span class="ow">or</span> <span class="nb">isinstance</span><span class="p">(</span><span class="n">basepoint</span><span class="p">,</span> <span class="n">torch</span><span class="o">.</span><span class="n">Tensor</span><span class="p">):</span>
        <span class="k">return</span> <span class="n">torch</span><span class="o">.</span><span class="n">Tensor</span> <span class="n">of</span> <span class="n">shape</span> <span class="p">(</span><span class="n">N</span><span class="p">,</span> <span class="n">L</span><span class="p">,</span> <span class="n">C</span> <span class="o">+</span> <span class="n">C</span><span class="o">^</span><span class="mi">2</span> <span class="o">+</span> <span class="o">...</span> <span class="o">+</span> <span class="n">C</span><span class="o">^</span><span class="n">depth</span><span class="p">)</span>
    <span class="k">else</span><span class="p">:</span>
        <span class="k">return</span> <span class="n">torch</span><span class="o">.</span><span class="n">Tensor</span> <span class="n">of</span> <span class="n">shape</span> <span class="p">(</span><span class="n">N</span><span class="p">,</span> <span class="n">L</span> <span class="o">-</span> <span class="mi">1</span><span class="p">,</span> <span class="n">C</span> <span class="o">+</span> <span class="n">C</span><span class="o">^</span><span class="mi">2</span> <span class="o">+</span> <span class="o">...</span> <span class="o">+</span> <span class="n">C</span><span class="o">^</span><span class="n">depth</span><span class="p">)</span>
<span class="k">else</span><span class="p">:</span>
    <span class="k">return</span> <span class="n">torch</span><span class="o">.</span><span class="n">Tensor</span> <span class="n">of</span> <span class="n">shape</span> <span class="p">(</span><span class="n">N</span><span class="p">,</span> <span class="n">C</span> <span class="o">+</span> <span class="n">C</span><span class="o">^</span><span class="mi">2</span> <span class="o">+</span> <span class="o">...</span> <span class="o">+</span> <span class="n">C</span><span class="o">^</span><span class="n">depth</span><span class="p">)</span>
</pre></div>
</div>
<p>Note that the number of output channels may be calculated via the convenience function
<a class="reference internal" href="#signatory.signature_channels" title="signatory.signature_channels"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_channels()</span></code></a>.</p>
</p>
</dd>
</dl>
</dd></dl>

<dl class="class">
<dt id="signatory.Signature">
<em class="property">class </em><code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">Signature</code><span class="sig-paren">(</span><em class="sig-param">depth: int</em>, <em class="sig-param">stream: bool = False</em>, <em class="sig-param">inverse: bool = False</em>, <em class="sig-param">scalar_term: bool = False</em>, <em class="sig-param">**kwargs</em><span class="sig-paren">)</span><a class="headerlink" href="#signatory.Signature" title="Permalink to this definition">¶</a></dt>
<dd><p><a class="reference external" href="https://pytorch.org/docs/stable/nn.html#torch.nn.Module" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.nn.Module</span></code></a> wrapper around the <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> function.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>depth</strong> (<em>int</em>) – as <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.</p></li>
<li><p><strong>stream</strong> (<em>bool</em><em>, </em><em>optional</em>) – as <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.</p></li>
<li><p><strong>inverse</strong> (<em>bool</em><em>, </em><em>optional</em>) – as <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.</p></li>
<li><p><strong>scalar_term</strong> (<em>bool</em><em>, </em><em>optional</em>) – as <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.</p></li>
</ul>
</dd>
</dl>
<dl class="method">
<dt id="signatory.Signature.forward">
<code class="sig-name descname">forward</code><span class="sig-paren">(</span><em class="sig-param">path: torch.Tensor</em>, <em class="sig-param">basepoint: Union[bool</em>, <em class="sig-param">torch.Tensor] = False</em>, <em class="sig-param">initial: Union[None</em>, <em class="sig-param">torch.Tensor] = None</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.Signature.forward" title="Permalink to this definition">¶</a></dt>
<dd><p>The forward operation.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>path</strong> (<a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>) – As <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.</p></li>
<li><p><strong>basepoint</strong> (bool or <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>, optional) – As <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.</p></li>
<li><p><strong>initial</strong> (None or <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>, optional) – As <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>As <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.</p>
</dd>
</dl>
</dd></dl>

</dd></dl>

<dl class="function">
<dt id="signatory.signature_channels">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">signature_channels</code><span class="sig-paren">(</span><em class="sig-param">channels: int</em>, <em class="sig-param">depth: int</em>, <em class="sig-param">scalar_term: bool = False</em><span class="sig-paren">)</span> &#x2192; int<a class="headerlink" href="#signatory.signature_channels" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes the number of output channels from a signature call. Specifically, it computes</p>
<div class="math notranslate nohighlight">
\[\text{channels} + \text{channels}^2 + \cdots + \text{channels}^\text{depth}.\]</div>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>channels</strong> (<em>int</em>) – The number of channels in the input; that is, the dimension of the space that the input path
resides in.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – The depth of the signature that is being computed.</p></li>
<li><p><strong>scalar_term</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to False. Whether to include the constant ‘1’ scalar that may be
included.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>An int specifying the number of channels in the signature of the path.</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="signatory.extract_signature_term">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">extract_signature_term</code><span class="sig-paren">(</span><em class="sig-param">sigtensor: torch.Tensor</em>, <em class="sig-param">channels: int</em>, <em class="sig-param">depth: int</em>, <em class="sig-param">scalar_term: bool = False</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.extract_signature_term" title="Permalink to this definition">¶</a></dt>
<dd><p>Extracts a particular term from a signature.</p>
<p>The signature to depth <span class="math notranslate nohighlight">\(d\)</span> of a batch of paths in <span class="math notranslate nohighlight">\(\mathbb{R}^\text{C}\)</span> is a tensor with
<span class="math notranslate nohighlight">\(C + C^2 + \cdots + C^d\)</span> channels. (See <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.) This function extracts the <code class="xref py py-attr docutils literal notranslate"><span class="pre">depth</span></code>
term of that, returning a tensor with just <span class="math notranslate nohighlight">\(C^\text{depth}\)</span> channels.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>sigtensor</strong> (<a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>) – The signature to extract the term from. Should be a result from the
<a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> function.</p></li>
<li><p><strong>channels</strong> (<em>int</em>) – The number of input channels <span class="math notranslate nohighlight">\(C\)</span>.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – The depth of the term to be extracted from the signature.</p></li>
<li><p><strong>scalar_term</strong> (<em>bool</em><em>, </em><em>optional</em>) – Whether the signature was called with scalar_term=True or not.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>The <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a> corresponding to the <code class="xref py py-attr docutils literal notranslate"><span class="pre">depth</span></code> term of the signature.</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="signatory.signature_combine">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">signature_combine</code><span class="sig-paren">(</span><em class="sig-param">sigtensor1: torch.Tensor</em>, <em class="sig-param">sigtensor2: torch.Tensor</em>, <em class="sig-param">input_channels: int</em>, <em class="sig-param">depth: int</em>, <em class="sig-param">inverse: bool = False</em>, <em class="sig-param">scalar_term: bool = False</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.signature_combine" title="Permalink to this definition">¶</a></dt>
<dd><p>Combines two signatures into a single signature.</p>
<p>Usage is most clear by example. See <a class="reference internal" href="../examples/combine.html#examples-combine"><span class="std std-ref">Combining signatures</span></a>.</p>
<p>See also <a class="reference internal" href="#signatory.multi_signature_combine" title="signatory.multi_signature_combine"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.multi_signature_combine()</span></code></a> for a more general version.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>sigtensor1</strong> (<a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>) – The signature of a path, as returned by <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>. This
should be a two-dimensional tensor.</p></li>
<li><p><strong>sigtensor2</strong> (<a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>) – The signature of a second path, as returned by <a class="reference internal" href="#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>,
with the same shape as <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code>. Note that when the signature of the second path was created, it
should have been called with <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code> set to the final value of the path that created
<code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code>. (See <a class="reference internal" href="../examples/combine.html#examples-combine"><span class="std std-ref">Combining signatures</span></a>.)</p></li>
<li><p><strong>input_channels</strong> (<em>int</em>) – The number of channels in the two paths that were used to compute <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code> and
<code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code>. This must be the same for both <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code> and <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code>.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – The depth that <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code> and <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code> have been calculated to. This must be
the same for both <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code> and <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code>.</p></li>
<li><p><strong>inverse</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to False. Whether <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code> and <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code> were created
with <code class="xref py py-attr docutils literal notranslate"><span class="pre">inverse=True</span></code>. This must be the same for both <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code> and <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code>.</p></li>
<li><p><strong>scalar_term</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to False. Whether <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code> and <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code> were created
with <code class="xref py py-attr docutils literal notranslate"><span class="pre">scalar_term=True</span></code>. This must the same for both <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code> and <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code>.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>Let <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1</span></code> be the path whose signature is <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor1</span></code>. Let <code class="xref py py-attr docutils literal notranslate"><span class="pre">path2</span></code> be the path whose
signature is <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code>. Then this function returns the signature of the concatenation of <code class="xref py py-attr docutils literal notranslate"><span class="pre">path1</span></code>
and <code class="xref py py-attr docutils literal notranslate"><span class="pre">path2</span></code> along their stream dimension.</p>
</dd>
</dl>
<div class="admonition danger">
<p class="admonition-title">Danger</p>
<p>There is a subtle bug which can occur when using this function incautiously. Make sure that <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensor2</span></code>
is created with an appropriate <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code>, see <a class="reference internal" href="../examples/combine.html#examples-combine"><span class="std std-ref">Combining signatures</span></a>.</p>
<p>If this is not done then the return value of this function will be essentially meaningless numbers.</p>
</div>
</dd></dl>

<dl class="function">
<dt id="signatory.multi_signature_combine">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">multi_signature_combine</code><span class="sig-paren">(</span><em class="sig-param">sigtensors: List[torch.Tensor], input_channels: int, depth: int, inverse: bool = False, scalar_term: bool = False</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.multi_signature_combine" title="Permalink to this definition">¶</a></dt>
<dd><p>Combines multiple signatures into a single signature.</p>
<p>See also <a class="reference internal" href="#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> for a simpler version.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>sigtensors</strong> (list of <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.Tensor</span></code></a>) – Signature of multiple paths, all of the same shape. They should all
be two-dimensional tensors.</p></li>
<li><p><strong>input_channels</strong> (<em>int</em>) – As <a class="reference internal" href="#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>.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – As <a class="reference internal" href="#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>.</p></li>
<li><p><strong>inverse</strong> (<em>bool</em><em>, </em><em>optional</em>) – As <a class="reference internal" href="#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>.</p></li>
<li><p><strong>scalar_term</strong> (<em>bool</em><em>, </em><em>optional</em>) – As <a class="reference internal" href="#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>.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>Let <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensors</span></code> be a list of tensors, call them <span class="math notranslate nohighlight">\(\text{sigtensor}_i\)</span> for
<span class="math notranslate nohighlight">\(i = 0, 1, \ldots, k\)</span>. Let <span class="math notranslate nohighlight">\(\text{path}_i\)</span> be the path whose signature is
<span class="math notranslate nohighlight">\(\text{sigtensor}_i\)</span>. Then this function returns the signature of the concatenation of
<span class="math notranslate nohighlight">\(\text{path}_i\)</span> along their stream dimension.</p>
</dd>
</dl>
<div class="admonition danger">
<p class="admonition-title">Danger</p>
<p>Make sure that each element of <code class="xref py py-attr docutils literal notranslate"><span class="pre">sigtensors</span></code> is created with an appropriate <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code>, as with
<a class="reference internal" href="#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>.</p>
</div>
</dd></dl>

</div>


           </div>
           
          </div>
          <footer>
  
    <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
      
        <a href="logsignatures.html" class="btn btn-neutral float-right" title="Logsignatures" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
      
      
        <a href="libraryapi.html" class="btn btn-neutral float-left" title="Library API" 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>