

<!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>Logsignatures &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="Path" href="path.html" />
    <link rel="prev" title="Signatures" href="signatures.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"><a class="reference internal" href="signatures.html">Signatures</a></li>
<li class="toctree-l2 current"><a class="current reference internal" href="#">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>Logsignatures</li>
    
    
      <li class="wy-breadcrumbs-aside">
        
            
            <a href="../../_sources/pages/reference/logsignatures.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="logsignatures">
<span id="reference-logsignatures"></span><h1>Logsignatures<a class="headerlink" href="#logsignatures" title="Permalink to this headline">¶</a></h1>
<dl class="function">
<dt id="signatory.logsignature">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">logsignature</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">mode: str = 'words'</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.logsignature" title="Permalink to this definition">¶</a></dt>
<dd><p>Applies the logsignature transform to a stream of data.</p>
<p>The <code class="xref py py-attr docutils literal notranslate"><span class="pre">modes</span></code> argument determines how the logsignature is represented.</p>
<p>Note that if performing many logsignature calculations for the same depth and size of input, then you will
see a performance boost (at the cost of using a little extra memory) by using <a class="reference internal" href="#signatory.LogSignature" title="signatory.LogSignature"><code class="xref py py-class docutils literal notranslate"><span class="pre">signatory.LogSignature</span></code></a>
instead of <a class="reference internal" href="#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a>.</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="signatures.html#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>depth</strong> (<em>int</em>) – as <a class="reference internal" href="signatures.html#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="signatures.html#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="signatures.html#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="signatures.html#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>mode</strong> (<em>str</em><em>, </em><em>optional</em>) – Defaults to <code class="code docutils literal notranslate"><span class="pre">&quot;words&quot;</span></code>. How the output should be presented. Valid values are
<code class="code docutils literal notranslate"><span class="pre">&quot;words&quot;</span></code>, <code class="code docutils literal notranslate"><span class="pre">&quot;brackets&quot;</span></code>, or <code class="code docutils literal notranslate"><span class="pre">&quot;expand&quot;</span></code>. Precisely what each of these options mean is
described in the
“Returns” section below. For machine learning applications, <code class="code docutils literal notranslate"><span class="pre">&quot;words&quot;</span></code> is the appropriate choice. The
other two options are mostly only interesting for mathematicians.</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>, of almost the same shape as the tensor returned from <a class="reference internal" href="signatures.html#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> called
with the same arguments.</p>
<p>If <code class="code docutils literal notranslate"><span class="pre">mode</span> <span class="pre">==</span> <span class="pre">&quot;expand&quot;</span></code> then it will be exactly the same shape as the returned tensor from
<a class="reference internal" href="signatures.html#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a>.</p>
<p>If <code class="code docutils literal notranslate"><span class="pre">mode</span> <span class="pre">in</span> <span class="pre">(&quot;brackets&quot;,</span> <span class="pre">&quot;words&quot;)</span></code> then the channel dimension will instead be of size
<code class="code docutils literal notranslate"><span class="pre">signatory.logsignature_channels(path.size(-1),</span> <span class="pre">depth)</span></code>. (Where <code class="code docutils literal notranslate"><span class="pre">path.size(-1)</span></code> is the number of
input channels.)</p>
<p>The different modes correspond to different mathematical representations of the logsignature.</p>
<div class="admonition tip">
<p class="admonition-title">Tip</p>
<p>If you haven’t studied tensor algebras and free Lie algebras, and none of the following explanation makes
sense to you, then you probably want to leave <code class="xref py py-attr docutils literal notranslate"><span class="pre">mode</span></code> on its default value of <code class="code docutils literal notranslate"><span class="pre">&quot;words&quot;</span></code> and it
will all be fine!</p>
</div>
<p>If <code class="code docutils literal notranslate"><span class="pre">mode</span> <span class="pre">==</span> <span class="pre">&quot;expand&quot;</span></code> then the logsignature is presented as a member of the tensor algebra; the numbers
returned correspond to the coefficients of all words in the tensor algebra.</p>
<p>If <code class="code docutils literal notranslate"><span class="pre">mode</span> <span class="pre">==</span> <span class="pre">&quot;brackets&quot;</span></code> then the logsignature is presented in terms of the coefficients of the Lyndon
basis of the free Lie algebra.</p>
<p>If <code class="code docutils literal notranslate"><span class="pre">mode</span> <span class="pre">==</span> <span class="pre">&quot;words&quot;</span></code> then the logsignature is presented in terms of the coefficients of a particular
computationally efficient basis of the free Lie algebra (that is not a Hall basis). Every basis element is given
as a sum of Lyndon brackets. When each bracket is expanded out and the sum computed, the sum will contain
precisely one Lyndon word (and some collection of non-Lyndon words). Moreover
every Lyndon word is represented uniquely in this way. We identify these basis elements with each corresponding
Lyndon word. This is natural as the coefficients in this basis are found just by extracting the coefficients of
all Lyndon words from the tensor algebra representation of the logsignature.</p>
<p>In all cases, the ordering corresponds to the ordering on words given by first ordering the words by length,
and then ordering each length class lexicographically.</p>
</p>
</dd>
</dl>
</dd></dl>

<dl class="class">
<dt id="signatory.LogSignature">
<em class="property">class </em><code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">LogSignature</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">mode: str = 'words'</em>, <em class="sig-param">**kwargs</em><span class="sig-paren">)</span><a class="headerlink" href="#signatory.LogSignature" 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.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a> function.</p>
<p>This <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> performs certain optimisations to allow it to calculate multiple logsignatures faster
than multiple calls to <a class="reference internal" href="#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a>.</p>
<p>Specifically, these optimisations will apply if this <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> is called with an input <code class="code docutils literal notranslate"><span class="pre">path</span></code>
with the same number of channels as the last input <code class="code docutils literal notranslate"><span class="pre">path</span></code> it was called with, as is likely to be very common
in machine learning set-ups. For larger depths or numbers of channels, this speedup will be substantial.</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.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</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.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</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.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a>.</p></li>
<li><p><strong>mode</strong> (<em>str</em><em>, </em><em>optional</em>) – as <a class="reference internal" href="#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a>.</p></li>
</ul>
</dd>
</dl>
<dl class="method">
<dt id="signatory.LogSignature.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><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.LogSignature.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.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a>.</p></li>
<li><p><strong>basepoint</strong> (<em>bool</em><em> or </em><a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><em>torch.Tensor</em></a><em>, </em><em>optional</em>) – As <a class="reference internal" href="#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</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.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a>.</p>
</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="signatory.LogSignature.prepare">
<code class="sig-name descname">prepare</code><span class="sig-paren">(</span><em class="sig-param">in_channels: int</em><span class="sig-paren">)</span> &#x2192; None<a class="headerlink" href="#signatory.LogSignature.prepare" title="Permalink to this definition">¶</a></dt>
<dd><p>Prepares for computing logsignatures for paths of the specified number of channels. This will be done
anyway automatically whenever this <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> is called, if it hasn’t been called already; this
method simply allows to have it done earlier, for example when benchmarking.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><p><strong>in_channels</strong> (<em>int</em>) – The number of input channels of the path that this instance will subsequently be called
with. (corresponding to <code class="code docutils literal notranslate"><span class="pre">path.size(-1)</span></code>.)</p>
</dd>
</dl>
</dd></dl>

</dd></dl>

<dl class="function">
<dt id="signatory.logsignature_channels">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">logsignature_channels</code><span class="sig-paren">(</span><em class="sig-param">in_channels: int</em>, <em class="sig-param">depth: int</em><span class="sig-paren">)</span> &#x2192; int<a class="headerlink" href="#signatory.logsignature_channels" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes the number of output channels from a logsignature call with <code class="xref py py-attr docutils literal notranslate"><span class="pre">mode</span> <span class="pre">in</span> <span class="pre">(&quot;words&quot;,</span> <span class="pre">&quot;brackets&quot;)</span></code>.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>in_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. If calling <a class="reference internal" href="#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a> with argument <code class="xref py py-attr docutils literal notranslate"><span class="pre">path</span></code> then <code class="xref py py-attr docutils literal notranslate"><span class="pre">in_channels</span></code>
should be equal to <code class="xref py py-attr docutils literal notranslate"><span class="pre">path.size(-1)</span></code>.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – The depth of the signature that is being computed.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>An <code class="xref py py-attr docutils literal notranslate"><span class="pre">int</span></code> specifying the number of channels in the logsignature of the path.</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="signatory.signature_to_logsignature">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">signature_to_logsignature</code><span class="sig-paren">(</span><em class="sig-param">signature: torch.Tensor</em>, <em class="sig-param">channels: int</em>, <em class="sig-param">depth: int</em>, <em class="sig-param">stream: bool = False</em>, <em class="sig-param">mode: str = 'words'</em>, <em class="sig-param">scalar_term: bool = False</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.signature_to_logsignature" title="Permalink to this definition">¶</a></dt>
<dd><p>Calculates the logsignature corresponding to a signature.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>signature</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 result of a call to <a class="reference internal" href="signatures.html#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>channels</strong> (<em>int</em>) – The number of input channels of the <code class="xref py py-attr docutils literal notranslate"><span class="pre">path</span></code> that <a class="reference internal" href="signatures.html#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> was called
with.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – The value of <code class="xref py py-attr docutils literal notranslate"><span class="pre">depth</span></code> that <a class="reference internal" href="signatures.html#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> was called with.</p></li>
<li><p><strong>stream</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to False. The value of <code class="xref py py-attr docutils literal notranslate"><span class="pre">stream</span></code> that <a class="reference internal" href="signatures.html#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> was
called with.</p></li>
<li><p><strong>mode</strong> (<em>str</em><em>, </em><em>optional</em>) – Defaults to <code class="code docutils literal notranslate"><span class="pre">&quot;words&quot;</span></code>. As <a class="reference internal" href="#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a>.</p></li>
<li><p><strong>scalar_term</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to False. The value of <code class="xref py py-attr docutils literal notranslate"><span class="pre">scalar_term</span></code> that
<a class="reference internal" href="signatures.html#signatory.signature" title="signatory.signature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature()</span></code></a> was called with.</p></li>
</ul>
</dd>
</dl>
<div class="admonition-example admonition">
<p class="admonition-title">Example</p>
<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">import</span> <span class="nn">signatory</span>
<span class="kn">import</span> <span class="nn">torch</span>
<span class="n">batch</span><span class="p">,</span> <span class="n">stream</span><span class="p">,</span> <span class="n">channels</span> <span class="o">=</span> <span class="mi">8</span><span class="p">,</span> <span class="mi">8</span><span class="p">,</span> <span class="mi">8</span>
<span class="n">depth</span> <span class="o">=</span> <span class="mi">3</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="n">batch</span><span class="p">,</span> <span class="n">stream</span><span class="p">,</span> <span class="n">channels</span><span class="p">)</span>
<span class="n">signature</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="n">depth</span><span class="p">)</span>
<span class="n">logsignature</span> <span class="o">=</span> <span class="n">signatory</span><span class="o">.</span><span class="n">signature_to_logsignature</span><span class="p">(</span><span class="n">signature</span><span class="p">,</span> <span class="n">channels</span><span class="p">,</span> <span class="n">depth</span><span class="p">)</span>
</pre></div>
</div>
</div>
<dl class="field-list simple">
<dt class="field-odd">Returns</dt>
<dd class="field-odd"><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> representing the logsignature corresponding to the given signature. See
<a class="reference internal" href="#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a>.</p>
</dd>
</dl>
</dd></dl>

<dl class="class">
<dt id="signatory.SignatureToLogSignature">
<em class="property">class </em><code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">SignatureToLogSignature</code><span class="sig-paren">(</span><em class="sig-param">channels: int</em>, <em class="sig-param">depth: int</em>, <em class="sig-param">stream: bool = False</em>, <em class="sig-param">mode: str = 'words'</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.SignatureToLogSignature" 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_to_logsignature" title="signatory.signature_to_logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_to_logsignature()</span></code></a> function.</p>
<p>Calling this <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> on an input <code class="code docutils literal notranslate"><span class="pre">signature</span></code> with the same number of channels as the last
<code class="code docutils literal notranslate"><span class="pre">signature</span></code> it was called with will be faster than multiple calls to the
<a class="reference internal" href="#signatory.signature_to_logsignature" title="signatory.signature_to_logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_to_logsignature()</span></code></a> function, in the same way that <a class="reference internal" href="#signatory.LogSignature" title="signatory.LogSignature"><code class="xref py py-class docutils literal notranslate"><span class="pre">signatory.LogSignature</span></code></a> will be
faster than <a class="reference internal" href="#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a>.</p>
<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>) – as <a class="reference internal" href="#signatory.signature_to_logsignature" title="signatory.signature_to_logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_to_logsignature()</span></code></a>.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – as <a class="reference internal" href="#signatory.signature_to_logsignature" title="signatory.signature_to_logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_to_logsignature()</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_to_logsignature" title="signatory.signature_to_logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_to_logsignature()</span></code></a>.</p></li>
<li><p><strong>mode</strong> (<em>str</em><em>, </em><em>optional</em>) – as <a class="reference internal" href="#signatory.signature_to_logsignature" title="signatory.signature_to_logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_to_logsignature()</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_to_logsignature" title="signatory.signature_to_logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_to_logsignature()</span></code></a>.</p></li>
</ul>
</dd>
</dl>
<dl class="method">
<dt id="signatory.SignatureToLogSignature.forward">
<code class="sig-name descname">forward</code><span class="sig-paren">(</span><em class="sig-param">signature: torch.Tensor</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.SignatureToLogSignature.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"><p><strong>signature</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_to_logsignature" title="signatory.signature_to_logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_to_logsignature()</span></code></a>.</p>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>As <a class="reference internal" href="#signatory.signature_to_logsignature" title="signatory.signature_to_logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.signature_to_logsignature()</span></code></a>.</p>
</dd>
</dl>
</dd></dl>

</dd></dl>

</div>


           </div>
           
          </div>
          <footer>
  
    <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
      
        <a href="path.html" class="btn btn-neutral float-right" title="Path" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
      
      
        <a href="signatures.html" class="btn btn-neutral float-left" title="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>