Skip to main content

Differentiable computations of the signature and logsignature transforms, on both CPU and GPU.

Project description

Differentiable computations of the signature and logsignature transforms, on both CPU and GPU.

What are signatures?

If you’re reading this then it’s probably because you already know what the signature transform is, and are looking to use it in your project. But in case you’ve stumbled across this and are curious what this ‘signature’ thing is…

The signature transform is a transformation that takes in a stream of data (often a time series), and returns a collection of statistics about that stream of data, called the signature. This collection of statistics determines the path essentially uniquely. Importantly, the signature is rich enough that every continuous function of the input stream may be approximated arbitrarily well by a linear function of its signature; the signature transform is what we call a universal nonlinearity. If you’re doing machine learning then you probably understand why this is such a desirable property!

Check out this for a primer on the use of the signature transform in machine learning, just as a feature transformation, and this for a more in-depth look at integrating the signature transform into neural networks.

Installation

Available for Python 2.7, Python 3.5, Python 3.6, Python 3.7 and Linux, Mac, Windows. Requires PyTorch 1.2.0 or 1.3.0.

Install via:

pip install signatory==<SIGNATORY_VERSION>.<TORCH_VERSION>

where <SIGNATORY_VERSION> is the version of Signatory you would like to download (the most recent version is 1.1.4) and <TORCH_VERSION> is the version of PyTorch you are using.

For example, if you are using PyTorch 1.3.0 and want Signatory 1.1.4, then you should run:

pip install signatory==1.1.4.1.3.0

Yes, this looks a bit odd. This is needed to work around limitations of PyTorch and pip.

Take care not to run pip install signatory, as this will likely download the wrong version.

After installation, just import signatory inside Python.

Installation from source is also possible; please consult the documentation. This also includes information on how to run the tests and benchmarks.

If you have any problems with installation then check the FAQ. If that doesn’t help then feel free to open an issue.

Documentation

The documentation is available here.

Example

Usage is straightforward. As a simple example,

import signatory
import torch
batch, stream, channels = 1, 10, 2
depth = 4
path = torch.rand(batch, stream, channels)
signature = signatory.signature(path, depth)

For further examples, see the documentation.

Citation

If you found this library useful in your research, please consider citing

@misc{signatory,
    title={{Signatory: differentiable computations of the signature and logsignature transforms, on both CPU and GPU}},
    author={Kidger, Patrick},
    note={\texttt{https://github.com/patrick-kidger/signatory}},
    year={2019}
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

signatory-1.1.4.1.3.0.tar.gz (53.9 kB view hashes)

Uploaded Source

Built Distributions

signatory-1.1.4.1.3.0-cp37-cp37m-win_amd64.whl (262.3 kB view hashes)

Uploaded CPython 3.7m Windows x86-64

signatory-1.1.4.1.3.0-cp37-cp37m-macosx_10_7_x86_64.whl (289.0 kB view hashes)

Uploaded CPython 3.7m macOS 10.7+ x86-64

signatory-1.1.4.1.3.0-cp36-cp36m-win_amd64.whl (262.3 kB view hashes)

Uploaded CPython 3.6m Windows x86-64

signatory-1.1.4.1.3.0-cp36-cp36m-macosx_10_7_x86_64.whl (289.1 kB view hashes)

Uploaded CPython 3.6m macOS 10.7+ x86-64

signatory-1.1.4.1.3.0-cp35-cp35m-win_amd64.whl (259.5 kB view hashes)

Uploaded CPython 3.5m Windows x86-64

signatory-1.1.4.1.3.0-cp35-cp35m-macosx_10_6_x86_64.whl (284.9 kB view hashes)

Uploaded CPython 3.5m macOS 10.6+ x86-64

signatory-1.1.4.1.3.0-cp27-cp27m-macosx_10_6_x86_64.whl (287.1 kB view hashes)

Uploaded CPython 2.7m macOS 10.6+ x86-64

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page