Home

Awesome

<p align="center"> <!-- CI --> <a href="https://circleci.com/gh/facebookresearch/theseus/tree/main"> <img src="https://circleci.com/gh/facebookresearch/theseus/tree/main.svg?style=svg" alt="CircleCI" height="20"> </a> <!-- License --> <a href="https://github.com/facebookresearch/theseus/blob/main/LICENSE"> <img src="https://img.shields.io/badge/license-MIT-blue.svg" alt="License" height="20"> </a> <!-- pypi --> <a href="https://pypi.org/project/theseus-ai/"> <img src="https://img.shields.io/pypi/v/theseus-ai" alt="pypi" heigh="20"> <!-- Downloads counter --> <a href="https://pypi.org/project/theseus-ai/"> <img src="https://pepy.tech/badge/theseus-ai" alt="PyPi Downloads" height="20"> </a> <!-- Python --> <a href="https://www.python.org/downloads/release/"> <img src="https://img.shields.io/badge/python-3.7%20%7C%203.8%20%7C%203.9-blue.svg" alt="Python" height="20"> </a> <!-- Pre-commit --> <a href="https://github.com/pre-commit/pre-commit"> <img src="https://img.shields.io/badge/pre--commit-enabled-green?logo=pre-commit&logoColor=white" alt="pre-commit" height="20"> </a> <!-- Black --> <a href="https://github.com/psf/black"> <img src="https://img.shields.io/badge/code%20style-black-000000.svg" alt="black" height="20"> </a> <!-- PRs --> <a href="https://github.com/facebookresearch/theseus/blob/main/CONTRIBUTING.md"> <img src="https://img.shields.io/badge/PRs-welcome-green.svg" alt="PRs" height="20"> </a> </p> <p align="center"> <i>A library for differentiable nonlinear optimization</i> </p> <p align="center"> <a href="https://arxiv.org/abs/2207.09442">Paper</a> • <a href="https://ai.facebook.com/blog/theseus-a-library-for-encoding-domain-knowledge-in-end-to-end-ai-models/">Blog</a> • <a href="https://sites.google.com/view/theseus-ai/">Webpage</a> • <a href="https://github.com/facebookresearch/theseus/tree/main/tutorials">Tutorials</a> • <a href="https://theseus-ai.readthedocs.io/">Docs</a> </p>

Theseus is an efficient application-agnostic library for building custom nonlinear optimization layers in PyTorch to support constructing various problems in robotics and vision as end-to-end differentiable architectures.

Differentiable nonlinear optimization provides a general scheme to encode inductive priors, as the objective function can be partly parameterized by neural models and partly with expert domain-specific differentiable models. The ability to compute gradients end-to-end is retained by differentiating through the optimizer which allows neural models to train on the final task loss, while also taking advantage of priors captured by the optimizer.


Current Features

Application agnostic interface

Our implementation provides an easy to use interface to build custom optimization layers and plug them into any neural architecture. Following differentiable features are currently available:

Efficiency based design

We support several features that improve computation times and memory consumption:

Getting Started

Prerequisites

Installing

pypi

pip install theseus-ai

We currently provide wheels with our CUDA extensions compiled using CUDA 10.2 and Python 3.9. For other CUDA versions, consider installing from source or using our build script.

From source

git clone https://github.com/facebookresearch/theseus.git && cd theseus
pip install -e .

If you are interested in contributing to Theseus, instead install

pip install -e ".[dev]"

and follow the more detailed instructions in CONTRIBUTING.

Running unit tests (requires dev installation)

python -m pytest theseus

By default, unit tests include tests for our CUDA extensions. You can add the option -m "not cudaext" to skip them when installing without CUDA support.

Examples

Simple example. This example is fitting the curve $y$ to a dataset of $N$ observations $(x,y) \sim D$. This is modeled as an Objective with a single CostFunction that computes the residual $y - v e^x$. The Objective and the GaussNewton optimizer are encapsulated into a TheseusLayer. With RMSprop and MSE loss, $x$ is learned by differentiating through the TheseusLayer.

import torch
import theseus as th

x_true, y_true, v_true = read_data() # shapes (1, N), (1, N), (1, 1)
x = th.Variable(torch.randn_like(x_true), name="x")
y = th.Variable(y_true, name="y")
v = th.Vector(1, name="v") # a manifold subclass of Variable for optim_vars

def error_fn(optim_vars, aux_vars): # returns y - v * exp(x)
    x, y = aux_vars
    return y.tensor - optim_vars[0].tensor * torch.exp(x.tensor)

objective = th.Objective()
cost_function = th.AutoDiffCostFunction(
    [v], error_fn, y_true.shape[1], aux_vars=[x, y],
    cost_weight=th.ScaleCostWeight(1.0))
objective.add(cost_function)
layer = th.TheseusLayer(th.GaussNewton(objective, max_iterations=10))

phi = torch.nn.Parameter(x_true + 0.1 * torch.ones_like(x_true))
outer_optimizer = torch.optim.RMSprop([phi], lr=0.001)
for epoch in range(10):
    solution, info = layer.forward(
        input_tensors={"x": phi.clone(), "v": torch.ones(1, 1)},
        optimizer_kwargs={"backward_mode": th.BackwardMode.IMPLICIT})
    outer_loss = torch.nn.functional.mse_loss(solution["v"], v_true)
    outer_loss.backward()
    outer_optimizer.step()

See tutorials, and robotics and vision examples to learn about the API and usage.

Citing Theseus

If you use Theseus in your work, please cite the paper with the BibTeX below.

@article{pineda2022theseus,
  title   = {{Theseus: A Library for Differentiable Nonlinear Optimization}},
  author  = {Luis Pineda and Taosha Fan and Maurizio Monge and Shobha Venkataraman and Paloma Sodhi and Ricky Chen and Joseph Ortiz and Daniel DeTone and Austin Wang and Stuart Anderson and Jing Dong and Brandon Amos and Mustafa Mukadam},
  journal = {arXiv preprint arXiv:2207.09442},
  year    = {2022}
}

License

Theseus is MIT licensed. See the LICENSE for details.

Additional Information

Theseus is made possible by the following contributors:

<a href="https://github.com/facebookresearch/theseus/graphs/contributors"> <img src="https://contrib.rocks/image?repo=facebookresearch/theseus" /> </a>

Made with contrib.rocks.