

<!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>Path &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="Utilities" href="utilities.html" />
    <link rel="prev" title="Logsignatures" href="logsignatures.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 current"><a class="current reference internal" href="#">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>Path</li>
    
    
      <li class="wy-breadcrumbs-aside">
        
            
            <a href="../../_sources/pages/reference/path.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="path">
<span id="reference-path"></span><h1>Path<a class="headerlink" href="#path" title="Permalink to this headline">¶</a></h1>
<dl class="class">
<dt id="signatory.Path">
<em class="property">class </em><code class="sig-prename descclassname">signatory.</code><code class="sig-name descname">Path</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">basepoint: Union[bool</em>, <em class="sig-param">torch.Tensor] = False</em>, <em class="sig-param">remember_path: bool = True</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.Path" title="Permalink to this definition">¶</a></dt>
<dd><p>Calculates signatures and logsignatures on intervals of an input path.</p>
<p>By doing some precomputation, it can rapidly calculate the signature or logsignature over any slice of the input
path. This is particularly useful if you need the signature or logsignature of a path over many different intervals:
using this class will be much faster than computing the signature or logsignature of each sub-path each time.</p>
<p>May be efficiently sliced and indexed along its batch dimension via [] syntax. This will return a new Path without
copying the underlying data.</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 ))"><em>torch.Tensor</em></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>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="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>remember_path</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to True. Whether to record the <a class="reference internal" href="#signatory.Path.path" title="signatory.Path.path"><code class="xref py py-attr docutils literal notranslate"><span class="pre">path</span></code></a> argument that this was
called with. If True, then it will be accessible as the <code class="code docutils literal notranslate"><span class="pre">.path</span></code> attribute. This argument may be set to
False if it is known that the underlying path is no longer of interest and should not kept in memory just
because it was passed as an argument here.</p></li>
<li><p><strong>scalar_term</strong> (<em>bool</em><em>, </em><em>optional</em>) – Defaults to False. Whether to include the scalar ‘1’ when calling the
<a class="reference internal" href="#signatory.Path.signature" title="signatory.Path.signature"><code class="xref py py-meth docutils literal notranslate"><span class="pre">signatory.Path.signature()</span></code></a> method; see also the equivalent argument for <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>
</ul>
</dd>
</dl>
<dl class="method">
<dt id="signatory.Path.signature">
<code class="sig-name descname">signature</code><span class="sig-paren">(</span><em class="sig-param">start: Optional[int] = None</em>, <em class="sig-param">end: Optional[int] = None</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.Path.signature" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the signature on a particular interval.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>start</strong> (<em>int</em><em> or </em><em>None</em><em>, </em><em>optional</em>) – Defaults to the start of the path. The start point of the interval to
calculate the signature on.</p></li>
<li><p><strong>end</strong> (<em>int</em><em> or </em><em>None</em><em>, </em><em>optional</em>) – Defaults to the end of the path. The end point of the interval to calculate
the signature on.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p><p>The signature on the interval <code class="code docutils literal notranslate"><span class="pre">[start,</span> <span class="pre">end]</span></code>.</p>
<p>In the simplest case, when <a class="reference internal" href="#signatory.Path.path" title="signatory.Path.path"><code class="xref py py-attr docutils literal notranslate"><span class="pre">path</span></code></a> and <a class="reference internal" href="#signatory.Path.depth" title="signatory.Path.depth"><code class="xref py py-attr docutils literal notranslate"><span class="pre">depth</span></code></a> are the arguments that this class was initialised
with (and <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code> was not passed), then this function returns a value equal to
<code class="code docutils literal notranslate"><span class="pre">signatory.signature(path[start:end],</span> <span class="pre">depth)</span></code>.</p>
<p>In general, let <code class="code docutils literal notranslate"><span class="pre">p</span> <span class="pre">=</span> <span class="pre">torch.cat(self.path,</span> <span class="pre">dim=1)</span></code>, so that it is all given paths (including those
<a class="reference internal" href="#signatory.Path.path" title="signatory.Path.path"><code class="xref py py-attr docutils literal notranslate"><span class="pre">path</span></code></a> from both initialistion and <a class="reference internal" href="#signatory.Path.update" title="signatory.Path.update"><code class="xref py py-meth docutils literal notranslate"><span class="pre">signatory.Path.update()</span></code></a>, and any <code class="xref py py-attr docutils literal notranslate"><span class="pre">basepoint</span></code>)
concatenated together. Then this function will return a value equal to
<code class="code docutils literal notranslate"><span class="pre">signatory.signature(p[start:end],</span> <span class="pre">depth)</span></code>.</p>
</p>
</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.logsignature">
<code class="sig-name descname">logsignature</code><span class="sig-paren">(</span><em class="sig-param">start: Optional[int] = None</em>, <em class="sig-param">end: Optional[int] = None</em>, <em class="sig-param">mode: str = 'words'</em><span class="sig-paren">)</span> &#x2192; torch.Tensor<a class="headerlink" href="#signatory.Path.logsignature" title="Permalink to this definition">¶</a></dt>
<dd><p>Returns the logsignature on a particular interval.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>start</strong> (<em>int</em><em> or </em><em>None</em><em>, </em><em>optional</em>) – As <a class="reference internal" href="#signatory.Path.signature" title="signatory.Path.signature"><code class="xref py py-meth docutils literal notranslate"><span class="pre">signatory.Path.signature()</span></code></a>.</p></li>
<li><p><strong>end</strong> (<em>int</em><em> or </em><em>None</em><em>, </em><em>optional</em>) – As <a class="reference internal" href="#signatory.Path.signature" title="signatory.Path.signature"><code class="xref py py-meth docutils literal notranslate"><span class="pre">signatory.Path.signature()</span></code></a>.</p></li>
<li><p><strong>mode</strong> (<em>str</em><em>, </em><em>optional</em>) – As <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>.</p></li>
</ul>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>The logsignature on the interval <code class="xref py py-attr docutils literal notranslate"><span class="pre">[start,</span> <span class="pre">end]</span></code>. See the documentation for
<a class="reference internal" href="#signatory.Path.signature" title="signatory.Path.signature"><code class="xref py py-meth docutils literal notranslate"><span class="pre">signatory.Path.signature()</span></code></a>.</p>
</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.update">
<code class="sig-name descname">update</code><span class="sig-paren">(</span><em class="sig-param">path: torch.Tensor</em><span class="sig-paren">)</span> &#x2192; None<a class="headerlink" href="#signatory.Path.update" title="Permalink to this definition">¶</a></dt>
<dd><p>Concatenates the given path onto the path already stored.</p>
<p>This means that the signature of the new overall path can now be asked for via <a class="reference internal" href="#signatory.Path.signature" title="signatory.Path.signature"><code class="xref py py-meth docutils literal notranslate"><span class="pre">signatory.Path.signature()</span></code></a>.
Furthermore this will be dramatically faster than concatenating the two paths together and then creating a new
Path object: the ‘concatenation’ occurs implicitly, without actually involving any recomputation or reallocation
of memory.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><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 ))"><em>torch.Tensor</em></a>) – The path to concatenate on. 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>
</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.remember_path">
<em class="property">property </em><code class="sig-name descname">remember_path</code><a class="headerlink" href="#signatory.Path.remember_path" title="Permalink to this definition">¶</a></dt>
<dd><p>Whether this Path remembers the <a class="reference internal" href="#signatory.Path.path" title="signatory.Path.path"><code class="xref py py-attr docutils literal notranslate"><span class="pre">path</span></code></a> argument it was called with.</p>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.path">
<em class="property">property </em><code class="sig-name descname">path</code><a class="headerlink" href="#signatory.Path.path" title="Permalink to this definition">¶</a></dt>
<dd><p>The path(s) that this Path was created with.</p>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.depth">
<em class="property">property </em><code class="sig-name descname">depth</code><a class="headerlink" href="#signatory.Path.depth" title="Permalink to this definition">¶</a></dt>
<dd><p>The depth that Path has calculated the signature to.</p>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.size">
<code class="sig-name descname">size</code><span class="sig-paren">(</span><em class="sig-param">index: Optional[int] = None</em><span class="sig-paren">)</span> &#x2192; Union[int, torch.Size]<a class="headerlink" href="#signatory.Path.size" title="Permalink to this definition">¶</a></dt>
<dd><p>The size of the input path. As <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor.size" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-meth docutils literal notranslate"><span class="pre">torch.Tensor.size()</span></code></a>.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><p><strong>index</strong> (<em>int</em><em> or </em><em>None</em><em>, </em><em>optional</em>) – As <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor.size" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-meth docutils literal notranslate"><span class="pre">torch.Tensor.size()</span></code></a>.</p>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>As <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor.size" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-meth docutils literal notranslate"><span class="pre">torch.Tensor.size()</span></code></a>.</p>
</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.shape">
<em class="property">property </em><code class="sig-name descname">shape</code><a class="headerlink" href="#signatory.Path.shape" title="Permalink to this definition">¶</a></dt>
<dd><p>The shape of the input path. As <code class="xref py py-attr docutils literal notranslate"><span class="pre">torch.Tensor.shape</span></code>.</p>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.channels">
<code class="sig-name descname">channels</code><span class="sig-paren">(</span><span class="sig-paren">)</span> &#x2192; int<a class="headerlink" href="#signatory.Path.channels" title="Permalink to this definition">¶</a></dt>
<dd><p>The number of channels of the input stream.</p>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.signature_size">
<code class="sig-name descname">signature_size</code><span class="sig-paren">(</span><em class="sig-param">index: Optional[int] = None</em><span class="sig-paren">)</span> &#x2192; Union[int, torch.Size]<a class="headerlink" href="#signatory.Path.signature_size" title="Permalink to this definition">¶</a></dt>
<dd><p>The size of the signature of the path. As <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor.size" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-meth docutils literal notranslate"><span class="pre">torch.Tensor.size()</span></code></a>.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><p><strong>index</strong> (<em>int</em><em> or </em><em>None</em><em>, </em><em>optional</em>) – As <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor.size" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-meth docutils literal notranslate"><span class="pre">torch.Tensor.size()</span></code></a>.</p>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>As <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor.size" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-meth docutils literal notranslate"><span class="pre">torch.Tensor.size()</span></code></a>.</p>
</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.signature_shape">
<em class="property">property </em><code class="sig-name descname">signature_shape</code><a class="headerlink" href="#signatory.Path.signature_shape" title="Permalink to this definition">¶</a></dt>
<dd><p>The shape of the signature of the path. As <code class="xref py py-attr docutils literal notranslate"><span class="pre">torch.Tensor.shape</span></code>.</p>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.signature_channels">
<code class="sig-name descname">signature_channels</code><span class="sig-paren">(</span><span class="sig-paren">)</span> &#x2192; int<a class="headerlink" href="#signatory.Path.signature_channels" title="Permalink to this definition">¶</a></dt>
<dd><p>The number of signature channels; as <a class="reference internal" href="signatures.html#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>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.logsignature_size">
<code class="sig-name descname">logsignature_size</code><span class="sig-paren">(</span><em class="sig-param">index: Optional[int] = None</em><span class="sig-paren">)</span> &#x2192; Union[int, torch.Size]<a class="headerlink" href="#signatory.Path.logsignature_size" title="Permalink to this definition">¶</a></dt>
<dd><p>The size of the logsignature of the path. As <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor.size" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-meth docutils literal notranslate"><span class="pre">torch.Tensor.size()</span></code></a>.</p>
<dl class="field-list simple">
<dt class="field-odd">Parameters</dt>
<dd class="field-odd"><p><strong>index</strong> (<em>int</em><em> or </em><em>None</em><em>, </em><em>optional</em>) – As <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor.size" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-meth docutils literal notranslate"><span class="pre">torch.Tensor.size()</span></code></a>.</p>
</dd>
<dt class="field-even">Returns</dt>
<dd class="field-even"><p>As <a class="reference external" href="https://pytorch.org/docs/stable/tensors.html#torch.Tensor.size" title="(in PyTorch vmaster (1.5.0a0+2a01d34 ))"><code class="xref py py-meth docutils literal notranslate"><span class="pre">torch.Tensor.size()</span></code></a>.</p>
</dd>
</dl>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.logsignature_shape">
<em class="property">property </em><code class="sig-name descname">logsignature_shape</code><a class="headerlink" href="#signatory.Path.logsignature_shape" title="Permalink to this definition">¶</a></dt>
<dd><p>The shape of the logsignature of the path. As <code class="xref py py-attr docutils literal notranslate"><span class="pre">torch.Tensor.shape</span></code>.</p>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.logsignature_channels">
<code class="sig-name descname">logsignature_channels</code><span class="sig-paren">(</span><span class="sig-paren">)</span> &#x2192; int<a class="headerlink" href="#signatory.Path.logsignature_channels" title="Permalink to this definition">¶</a></dt>
<dd><p>The number of logsignature channels; as <a class="reference internal" href="logsignatures.html#signatory.logsignature_channels" title="signatory.logsignature_channels"><code class="xref py py-func docutils literal notranslate"><span class="pre">signatory.logsignature_channels()</span></code></a>.</p>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.shuffle">
<code class="sig-name descname">shuffle</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#signatory.Path.shuffle" title="Permalink to this definition">¶</a></dt>
<dd><p>Randomly permutes the Path along its batch dimension, and returns as a new Path. Returns a tuple of the
new Path object, and the random permutation that produced it.</p>
</dd></dl>

<dl class="method">
<dt id="signatory.Path.shuffle_">
<code class="sig-name descname">shuffle_</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#signatory.Path.shuffle_" title="Permalink to this definition">¶</a></dt>
<dd><p>In place version of <a class="reference internal" href="#signatory.Path.shuffle" title="signatory.Path.shuffle"><code class="xref py py-meth docutils literal notranslate"><span class="pre">signatory.Path.shuffle()</span></code></a>.</p>
</dd></dl>

</dd></dl>

<div class="admonition warning">
<p class="admonition-title">Warning</p>
<p>If repeatedly making forward and backward passes (for example when training a neural network) and you have a learnt layer before the <a class="reference internal" href="#signatory.Path" title="signatory.Path"><code class="xref py py-class docutils literal notranslate"><span class="pre">signatory.Path</span></code></a>, then make sure to construct a new <a class="reference internal" href="#signatory.Path" title="signatory.Path"><code class="xref py py-class docutils literal notranslate"><span class="pre">signatory.Path</span></code></a> object for each forward pass.</p>
<p>Reusing the same object between forward passes will mean that signatures aren’t computed using the latest information, as the internal buffers will still correspond to the data passed in when the <a class="reference internal" href="#signatory.Path" title="signatory.Path"><code class="xref py py-class docutils literal notranslate"><span class="pre">signatory.Path</span></code></a> object was first constructed.</p>
</div>
</div>


           </div>
           
          </div>
          <footer>
  
    <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
      
        <a href="utilities.html" class="btn btn-neutral float-right" title="Utilities" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
      
      
        <a href="logsignatures.html" class="btn btn-neutral float-left" title="Logsignatures" 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>