

<!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>Installation &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="Library API" href="../reference/libraryapi.html" />
    <link rel="prev" title="Introduction" href="introduction.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="introduction.html">Introduction</a></li>
<li class="toctree-l1 current"><a class="current reference internal" href="#">Installation</a><ul>
<li class="toctree-l2"><a class="reference internal" href="#install-from-source">Install from source</a></li>
</ul>
</li>
<li class="toctree-l1"><a class="reference internal" href="../reference/libraryapi.html">Library API</a></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>Installation</li>
    
    
      <li class="wy-breadcrumbs-aside">
        
            
            <a href="../../_sources/pages/usage/installation.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="installation">
<span id="usage-installation"></span><h1>Installation<a class="headerlink" href="#installation" title="Permalink to this headline">¶</a></h1>
<p>Available for Python 2.7, 3.5, 3.6, 3.7, 3.8 and Linux, Mac, Windows. Requires <a class="reference external" href="http://pytorch.org/">PyTorch</a> 1.2.0, 1.3.0, 1.3.1, 1.4.0 or 1.5.0.</p>
<p>Install via:</p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span>pip install <span class="nv">signatory</span><span class="o">==</span>&lt;SIGNATORY_VERSION&gt;.&lt;TORCH_VERSION&gt; --no-cache-dir --force-reinstall
</pre></div>
</div>
<p>where <code class="docutils literal notranslate"><span class="pre">&lt;SIGNATORY_VERSION&gt;</span></code> is the version of Signatory you would like to download (the most recent version is 1.2.1) and <code class="docutils literal notranslate"><span class="pre">&lt;TORCH_VERSION&gt;</span></code> is the version of PyTorch you are using.</p>
<div class="admonition-example admonition">
<p class="admonition-title">Example</p>
<p>For example, if you are using PyTorch 1.3.0 and want Signatory 1.1.4, then you should run:</p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span>pip install <span class="nv">signatory</span><span class="o">==</span><span class="m">1</span>.1.4.1.3.0 --no-cache-dir --force-reinstall
</pre></div>
</div>
<p>Yes, this looks a bit odd. This is needed to work around <a class="reference external" href="https://github.com/pytorch/pytorch/issues/28754">limitations of PyTorch</a> and <a class="reference external" href="https://www.python.org/dev/peps/pep-0440/">pip</a>.</p>
<p>Take care <strong>not</strong> to run <code class="docutils literal notranslate"><span class="pre">pip</span> <span class="pre">install</span> <span class="pre">signatory</span></code>, as this will likely download the wrong version.</p>
<p>The <code class="docutils literal notranslate"><span class="pre">--no-cache-dir</span> <span class="pre">--force-reinstall</span></code> flags are because <code class="docutils literal notranslate"><span class="pre">pip</span></code> doesn’t expect to need to care about versions quite as much as this, so it will sometimes erroneously use inappropriate caches if not told otherwise.</p>
</div>
<p>After installation, just <code class="docutils literal notranslate"><span class="pre">import</span> <span class="pre">signatory</span></code> inside Python.</p>
<p>If you have any problems with installation then check the FAQ [link redacted for anonymity; see ‘docs’ folder of supplementary material]. If that doesn’t help then feel free to open an issue [link redacted for anonymity; see ‘docs’ folder of supplementary material].</p>
<div class="section" id="install-from-source">
<span id="usage-install-from-source"></span><h2>Install from source<a class="headerlink" href="#install-from-source" title="Permalink to this headline">¶</a></h2>
<p>For most use-cases, the prebuilt binaries available as described above should be sufficient. However installing from source is also perfectly feasible, and usually not too tricky.</p>
<p>You’ll need to have a C++ compiler installed and known to <code class="docutils literal notranslate"><span class="pre">pip</span></code>, and furthermore this must be the same compiler that PyTorch uses. (This is <code class="docutils literal notranslate"><span class="pre">msvc</span></code> on Windows, <code class="docutils literal notranslate"><span class="pre">gcc</span></code> on Linux, and <code class="docutils literal notranslate"><span class="pre">clang</span></code> on Macs.) You must have already installed <a class="reference external" href="http://pytorch.org/">PyTorch</a>. (You don’t have to compile PyTorch itself from source, though!)</p>
<p>Then run <strong>either</strong></p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span>pip install <span class="nv">signatory</span><span class="o">==</span>&lt;SIGNATORY_VERSION&gt;.&lt;TORCH_VERSION&gt; --no-binary signatory
</pre></div>
</div>
<p>(where <code class="docutils literal notranslate"><span class="pre">&lt;SIGNATORY_VERSION&gt;</span></code> and <code class="docutils literal notranslate"><span class="pre">&lt;TORCH_VERSION&gt;</span></code> are as above.)</p>
<p><strong>or</strong></p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span>git clone <span class="o">[</span>link redacted <span class="k">for</span> anonymity<span class="o">]</span>
<span class="nb">cd</span> signatory
python setup.py install
</pre></div>
</div>
<p>If you chose the first option then you’ll get just the files necessary to run Signatory.</p>
<p>If you choose the second option then tests, benchmarking code, and code to build the documentation will also be provided. Subsequent to this,</p>
<ul>
<li><div class="line-block">
<div class="line">Tests can be run, see <code class="docutils literal notranslate"><span class="pre">python</span> <span class="pre">command.py</span> <span class="pre">test</span> <span class="pre">--help</span></code>.</div>
<div class="line">This requires installing <a class="reference external" href="https://github.com/bottler/iisignature">iisignature</a> and <a class="reference external" href="https://pytest.org">pytest</a>.</div>
</div>
</li>
<li><div class="line-block">
<div class="line">Speed and memory  benchmarks can be performed, see <code class="docutils literal notranslate"><span class="pre">python</span> <span class="pre">command.py</span> <span class="pre">benchmark</span> <span class="pre">--help</span></code>.</div>
<div class="line">This requires installing <a class="reference external" href="https://github.com/bottler/iisignature">matplotlib, iisignature</a>, <a class="reference external" href="https://pypi.org/project/esig/">esig</a>, and <a class="reference external" href="https://pypi.org/project/memory-profiler/su">memory profiler</a>.</div>
</div>
</li>
<li><div class="line-block">
<div class="line">Documentation can be built via <code class="docutils literal notranslate"><span class="pre">python</span> <span class="pre">command.py</span> <span class="pre">docs</span></code>.</div>
<div class="line">This requires installing <a class="reference external" href="https://pypi.org/project/Sphinx/">Sphinx</a>, <a class="reference external" href="https://pypi.org/project/sphinx-rtd-theme/">sphinx_rtd_theme</a> and <a class="reference external" href="https://github.com/patrick-kidger/py2annotate">py2annotate</a>.</div>
</div>
</li>
</ul>
<div class="admonition note">
<p class="admonition-title">Note</p>
<p>If on Linux then the commands stated above should probably work.</p>
<p>If on Windows then it is probably first necessary to run a command of the form</p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span><span class="s2">&quot;C:/Program Files (x86)/Microsoft Visual Studio/2017/Enterprise/VC/Auxiliary/Build/vcvars64.bat&quot;</span>
</pre></div>
</div>
<p>(the exact command will depend on your operating system and version of Visual Studio).</p>
<p>If on a Mac then the installation command should instead look like either</p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span><span class="nv">MACOSX_DEPLOYMENT_TARGET</span><span class="o">=</span><span class="m">10</span>.9 <span class="nv">CC</span><span class="o">=</span>clang <span class="nv">CXX</span><span class="o">=</span>clang++ pip install <span class="nv">signatory</span><span class="o">==</span>&lt;SIGNATORY_VERSION&gt;.&lt;TORCH_VERSION&gt; --no-binary signatory
</pre></div>
</div>
<p>or</p>
<div class="highlight-bash notranslate"><div class="highlight"><pre><span></span><span class="nv">MACOSX_DEPLOYMENT_TARGET</span><span class="o">=</span><span class="m">10</span>.9 <span class="nv">CC</span><span class="o">=</span>clang <span class="nv">CXX</span><span class="o">=</span>clang++ python setup.py install
</pre></div>
</div>
<p>depending on the choice of installation method.</p>
</div>
<p>A helpful point of reference for getting this to work might be the official build scripts [link redacted for anonymity, see ‘code/.github/workflows’ in supplementary material] for Signatory.</p>
<p>Note that PyTorch does not support the following combinations, so Signatory doesn’t either:</p>
<ul class="simple">
<li><p>Windows and Python 2.7</p></li>
<li><p>Windows and Python 3.5 and PyTorch 1.4, 1.5</p></li>
<li><p>Python 2.7 and PyTorch 1.5</p></li>
<li><p>Python 3.8 and PyTorch 1.2, 1.3, 1.3.1</p></li>
</ul>
</div>
</div>


           </div>
           
          </div>
          <footer>
  
    <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
      
        <a href="../reference/libraryapi.html" class="btn btn-neutral float-right" title="Library API" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
      
      
        <a href="introduction.html" class="btn btn-neutral float-left" title="Introduction" 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>