

<!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>Utilities &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="Examples" href="../examples/examples.html" />
    <link rel="prev" title="Path" href="path.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"><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 current"><a class="current reference internal" href="#">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>Utilities</li>
    
    
      <li class="wy-breadcrumbs-aside">
        
            
            <a href="../../_sources/pages/reference/utilities.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="utilities">
<span id="reference-utilities"></span><h1>Utilities<a class="headerlink" href="#utilities" title="Permalink to this headline">¶</a></h1>
<p>The following miscellaneous operations are provided as a convenience.</p>
<hr class="docutils" />
<dl class="class">
<dt id="signatory.Augment">
<em class="property">class </em><code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">Augment</code><span class="sig-paren">(</span><em class="sig-param">in_channels: int, layer_sizes: Tuple[int, ...], kernel_size: int, stride: int = 1, padding: int = 0, dilation: int = 1, bias: bool = True, activation: Callable[torch.Tensor, torch.Tensor] = &lt;function relu&gt;, include_original: bool = True, include_time: bool = True, **kwargs</em><span class="sig-paren">)</span><a class="headerlink" href="#signatory.Augment" title="Permalink to this definition">¶</a></dt>
<dd><p>Augmenting a stream of data before feeding it into a signature is often useful; the hope is to obtain
higher-order information in the signature. One way to do this is in a data-dependent way is to apply a feedforward
neural network to sections of the stream, so as to obtain another stream; on this stream the signature is then
applied; that is what 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> does.</p>
<p>Thus 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 essentially unrelated to signatures, but is provided as it is often useful in
the same context. As described in
<a class="reference external" href="https://papers.nips.cc/paper/8574-deep-signature-transforms">Deep Signature Transforms – Bonnier et al. 2019</a>,
it is often advantageous to augment a path before taking the signature.</p>
<p>The input path 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>Then this stream may be ‘augmented’ via some function</p>
<div class="math notranslate nohighlight">
\[\phi \colon \mathbb{R}^{C \times k} \to \mathbb{R}^{\widehat{C}}\]</div>
<p>giving a stream of data</p>
<div class="math notranslate nohighlight">
\[\left(\phi(x_1, ... x_k), \ldots, \phi(x_{n - k + 1}, \ldots, x_n)\right),\]</div>
<p>which is essentially a three-dimensional tensor with dimensions <span class="math notranslate nohighlight">\((N, L - k + 1, \widehat{C})\)</span>.</p>
<p>Thus this essentially operates as a one dimensional convolution, except that a whole network is swept across the
input, rather than just a single convolutional layer.</p>
<p>Both the original stream and time can be specifically included in the augmentation. (This usually tends to give
better empirical results.) For example, if both <code class="xref py py-attr docutils literal notranslate"><span class="pre">include_original</span></code> is True and <code class="xref py py-attr docutils literal notranslate"><span class="pre">include_time</span></code> is True,
then each <span class="math notranslate nohighlight">\(\phi(x_i, ... x_{k + i - 1})\)</span> is of the form</p>
<div class="math notranslate nohighlight">
\[\left(\frac{i}{T}, x_i, \varphi(x_i, ... x_{k + i - 1})\right).\]</div>
<p>where <span class="math notranslate nohighlight">\(T\)</span> is a constant appropriately chosen so that the first entry moves between <span class="math notranslate nohighlight">\(0\)</span> and <span class="math notranslate nohighlight">\(1\)</span> as
<span class="math notranslate nohighlight">\(i\)</span> varies. (Specifically, <span class="math notranslate nohighlight">\(T = L - k + 1 + 2 \times \text{padding}\)</span>.)</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>) – Number of channels <span class="math notranslate nohighlight">\(C\)</span> in the input stream.</p></li>
<li><p><strong>layer_sizes</strong> (<em>tuple of int</em>) – Specifies the sizes of the layers of the feedforward neural network to apply to
the stream. The final value of this tuple specifies the number of channels in the augmented stream,
corresponding to the value <span class="math notranslate nohighlight">\(\widehat{C}\)</span> in the preceding discussion.</p></li>
<li><p><strong>kernel_size</strong> (<em>int</em>) – Specifies the size of the kernel to slide over the stream, corresponding to the value
<span class="math notranslate nohighlight">\(k\)</span> in the preceding discussion.</p></li>
<li><p><strong>stride</strong> (<em>int</em><em>, </em><em>optional</em>) – <p>Defaults to 1. How far to move along the input stream before re-applying the
feedforward neural network. Thus the output stream is given by</p>
<div class="math notranslate nohighlight">
\[(\phi(x_1, \ldots, x_k),
 \phi(x_{1 + \text{stride}}, \ldots, x_{k + 2 \times \text{stride}}),
 \phi(x_{1 + 2 \times \text{stride}}, \ldots, x_{k + 2 \times \text{stride}}),
 \ldots)\]</div>
</p></li>
<li><p><strong>padding</strong> (<em>int</em><em>, </em><em>optional</em>) – Defaults to 0. How much zero padding to add to either end of the the input stream
before sweeping the feedforward neural network along it.</p></li>
<li><p><strong>dilation</strong> (<em>int</em><em>, </em><em>optional</em>) – The spacing between input elements given to the feedforward neural network.
Defaults to 1. Harder to describe; see the equivalent argument for <a class="reference external" href="https://pytorch.org/docs/stable/nn.html#torch.nn.Conv1d" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-class docutils literal notranslate"><span class="pre">torch.nn.Conv1d</span></code></a>.</p></li>
<li><p><strong>bias</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to True. Whether to use biases in the neural network.</p></li>
<li><p><strong>activation</strong> (<em>callable</em><em>, </em><em>optional</em>) – Defaults to ReLU. The activation function to use in the feedforward neural
network.</p></li>
<li><p><strong>include_original</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to True. Whether or not to include the original stream
(pre-augmentation) in the augmented stream.</p></li>
<li><p><strong>include_time</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to True. Whether or not to also augment the stream with a ‘time’ value.
These are values in <span class="math notranslate nohighlight">\([0, 1]\)</span> corresponding to how far along the stream dimension the element is.</p></li>
</ul>
</dd>
</dl>
<div class="admonition note">
<p class="admonition-title">Note</p>
<p>Thus the resulting stream of data has shape <span class="math notranslate nohighlight">\((N, L, \text{out_channels})\)</span>, where in pseudocode:</p>
<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="n">out_channels</span> <span class="o">=</span> <span class="n">layer_sizes</span><span class="p">[</span><span class="o">-</span><span class="mi">1</span><span class="p">]</span>
<span class="k">if</span> <span class="n">include_original</span><span class="p">:</span>
    <span class="n">out_channels</span> <span class="o">+=</span> <span class="n">in_channels</span>
<span class="k">if</span> <span class="n">include_time</span><span class="p">:</span>
    <span class="n">out_channels</span> <span class="o">+=</span> <span class="mi">1</span>
</pre></div>
</div>
</div>
<dl class="method">
<dt id="signatory.Augment.forward">
<code class="sig-name descname">forward</code><span class="sig-paren">(</span><em class="sig-param">x: torch.Tensor</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.Augment.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>x</strong> (<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>) – The path to augment.</p>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>The augmented path.</p>
</dd>
</dl>
</dd></dl>

</dd></dl>

<hr class="docutils" />
<dl class="function">
<dt id="signatory.all_words">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">all_words</code><span class="sig-paren">(</span><em class="sig-param">channels: int</em>, <em class="sig-param">depth: int</em><span class="sig-paren">)</span> &#x2192; List[List[int]]<a class="headerlink" href="#signatory.all_words" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes the collection of all words up to length <code class="xref py py-attr docutils literal notranslate"><span class="pre">depth</span></code> in an alphabet of size
<code class="xref py py-attr docutils literal notranslate"><span class="pre">channels</span></code>. Each letter is represented by an integer <span class="math notranslate nohighlight">\(i\)</span> in the range
<span class="math notranslate nohighlight">\(0 \leq i &lt; \text{channels}\)</span>.</p>
<p>Signatures may be thought of as a sum of coefficients of words. This gives the words in the order that they
correspond to the values returned by <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>Logsignatures may be thought of as a sum of coefficients of words. This gives the words in the order that they
correspond to the values returned by <a class="reference internal" href="logsignatures.html#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a> with <code class="code docutils literal notranslate"><span class="pre">mode=&quot;expand&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>channels</strong> (<em>int</em>) – The size of the alphabet.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – The maximum word length.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>A list of lists of integers. Each sub-list corresponds to one word. The words are ordered by length, and
then ordered lexicographically within each length class.</p>
</dd>
</dl>
</dd></dl>

<hr class="docutils" />
<dl class="function">
<dt id="signatory.lyndon_words">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">lyndon_words</code><span class="sig-paren">(</span><em class="sig-param">channels: int</em>, <em class="sig-param">depth: int</em><span class="sig-paren">)</span> &#x2192; List[List[int]]<a class="headerlink" href="#signatory.lyndon_words" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes the collection of all Lyndon words up to length <code class="xref py py-attr docutils literal notranslate"><span class="pre">depth</span></code> in an alphabet of size
<code class="xref py py-attr docutils literal notranslate"><span class="pre">channels</span></code>. Each letter is represented by an integer <span class="math notranslate nohighlight">\(i\)</span> in the range
<span class="math notranslate nohighlight">\(0 \leq i &lt; \text{channels}\)</span>.</p>
<p>Logsignatures may be thought of as a sum of coefficients of Lyndon words. This gives the words in the order that
they correspond to the values returned by <a class="reference internal" href="logsignatures.html#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a> with <code class="code docutils literal notranslate"><span class="pre">mode=&quot;words&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>channels</strong> (<em>int</em>) – The size of the alphabet.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – The maximum word length.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>A list of lists of integers. Each sub-list corresponds to one Lyndon word. The words are ordered by length, and
then ordered lexicographically within each length class.</p>
</dd>
</dl>
</dd></dl>

<dl class="function">
<dt id="signatory.lyndon_brackets">
<code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">lyndon_brackets</code><span class="sig-paren">(</span><em class="sig-param">channels: int</em>, <em class="sig-param">depth: int</em><span class="sig-paren">)</span> &#x2192; List[Union[int, List]]<a class="headerlink" href="#signatory.lyndon_brackets" title="Permalink to this definition">¶</a></dt>
<dd><p>Computes the collection of all Lyndon words, in their standard bracketing, up to length <code class="xref py py-attr docutils literal notranslate"><span class="pre">depth</span></code> in an
alphabet of size <code class="xref py py-attr docutils literal notranslate"><span class="pre">channels</span></code>. Each letter is represented by an integer <span class="math notranslate nohighlight">\(i\)</span> in the range
<span class="math notranslate nohighlight">\(0 \leq i &lt; \text{channels}\)</span>.</p>
<p>Logsignatures may be thought of as a sum of coefficients of Lyndon brackets. This gives the brackets in the order
that they correspond to the values returned by <a class="reference internal" href="logsignatures.html#signatory.logsignature" title="signatory.logsignature"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature()</span></code></a> with <code class="code docutils literal notranslate"><span class="pre">mode=&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>channels</strong> (<em>int</em>) – The size of the alphabet.</p></li>
<li><p><strong>depth</strong> (<em>int</em>) – The maximum word length.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>A list. Each element corresponds to a single Lyndon word with its standard bracketing. The words are ordered by
length, and then ordered lexicographically within each length class.</p>
</dd>
</dl>
</dd></dl>

</div>


           </div>
           
          </div>
          <footer>
  
    <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
      
        <a href="../examples/examples.html" class="btn btn-neutral float-right" title="Examples" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
      
      
        <a href="path.html" class="btn btn-neutral float-left" title="Path" 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>