A toolkit for universal, autodiff-native software components.
Project description
Tesseract Core
Universal, autodiff-native software components for Simulation Intelligence 📦
Read the docs | Showcases & tutorials | Report an issue | Community forum | Contribute
The problem
Real-world scientific workflows span multiple tools, languages, and computing environments. You might have a mesh generator in C++, a solver in Julia, and post-processing in Python. Getting these to work together is painful. Getting gradients to flow through them for optimization is nearly impossible.
Existing autodiff frameworks work great within a single codebase, but fall short when your pipeline crosses framework boundaries or includes legacy tools.
The solution
Tesseract packages scientific software into self-contained, portable components that:
- Run anywhere — Local machines, cloud, HPC clusters. Same container, same results.
- Expose clean interfaces — CLI, REST API, and Python SDK. No more deciphering undocumented scripts.
- Propagate gradients — Each component can expose derivatives, enabling end-to-end optimization across heterogeneous pipelines.
- Self-document — Schemas, types, and API docs are generated automatically.
Who is this for?
- Researchers interfacing with (differentiable) simulators or probabilistic models, or who need to combine tools from different ecosystems.
- R&D engineers packaging research code for use by others, without spending weeks on DevOps.
- Platform engineers deploying scientific workloads at scale with consistent interfaces and dependency isolation.
Example: Shape optimization across tools
The rocket fin optimization case study combines three Tesseracts:
[SpaceClaim geometry] → [Mesh + SDF] → [PyMAPDL FEA solver]
↑ |
└──────── gradients flow back ─────────┘
Each component uses a different differentiation strategy (analytic adjoints, finite differences, JAX autodiff), yet they compose into a single optimizable pipeline that is one jax.grad call away from end-to-end gradients.
[!TIP] More examples in the example gallery and community showcases.
Quick start
Getting started: install, build an example, and run it.
[!NOTE] Requires Docker and Python 3.10+.
CLI:
# Install Tesseract Core
$ pip install tesseract-core
# Create a new project in the current directory
$ tesseract init --name my-tesseract
# Edit `tesseract_api.py`, or download an example
$ curl -so ./tesseract_api.py https://raw.githubusercontent.com/pasteurlabs/tesseract-core/main/examples/vectoradd/tesseract_api.py
# Build it into a container
$ tesseract build .
# Run it
$ tesseract run my-tesseract apply '{"inputs": {"a": [1, 2, 3], "b": [10, 20, 30]}}'
# → {"result": [11, 22, 33]}
# Compute the Jacobian
$ tesseract run my-tesseract jacobian '{"inputs": {"a": [1, 2, 3], "b": [10, 20, 30]}, "jac_inputs": ["a"], "jac_outputs": ["result"]}'
# → {"result": {"a": [[1, 0, 0], [0, 1, 0], [0, 0, 1]]}}
Python SDK:
from tesseract_core import Tesseract
with Tesseract.from_image("my-tesseract") as t:
result = t.apply({"a": [1, 2, 3], "b": [10, 20, 30]})
jac = t.jacobian({"a": [1, 2, 3], "b": [10, 20, 30]}, jac_inputs=["a"], jac_outputs=["result"])
Core features
- Containerized — Docker-based packaging ensures reproducibility and dependency isolation.
- Multi-interface — Use the same components via CLI, REST API, and Python SDK.
- Differentiable — First-class support for Jacobians, JVPs, and VJPs across component and network boundaries.
- Schema-validated — Pydantic models define explicit input/output contracts.
- Language-agnostic — Wrap Python, Julia, C++, Fortran, or any executable behind a thin Python API.
- Self-documenting — Auto-generated API docs and schemas for every Tesseract (
tesseract apidoc <name>).
Auto-generated API documentation (tesseract apidoc).
The Ecosystem
- Tesseract Core — CLI, Python SDK, and runtime (this repo).
- Tesseract-JAX — Embed Tesseracts as JAX primitives into end-to-end differentiable JAX programs.
- Tesseract-Streamlit — Auto-generate interactive web apps from Tesseracts.
Learn more
- Documentation
- Creating your first Tesseract
- Differentiable programming guide
- Design patterns
- Example gallery
Citing Tesseract
If you use Tesseract in your research, please cite:
@article{TesseractCore,
doi = {10.21105/joss.08385},
url = {https://doi.org/10.21105/joss.08385},
year = {2025},
publisher = {The Open Journal},
volume = {10},
number = {111},
pages = {8385},
author = {Häfner, Dion and Lavin, Alexander},
title = {Tesseract Core: Universal, autodiff-native software components for Simulation Intelligence},
journal = {Journal of Open Source Software}
}
License
Tesseract Core is licensed under the Apache License 2.0 and is free to use, modify, and distribute (under the terms of the license).
Tesseract is a registered trademark of Pasteur Labs, Inc. and may not be used without permission.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tesseract_core-1.8.1.tar.gz.
File metadata
- Download URL: tesseract_core-1.8.1.tar.gz
- Upload date:
- Size: 1.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0aef504ae5592d1e29c5d9748b74017fa1aaa1c92efb3fbc13c48a4816cc1b5a
|
|
| MD5 |
33fc626cfcb26158e0fb1c3ae5d84c00
|
|
| BLAKE2b-256 |
18a9889bb2255607975ba844e6bbb138b6b9b330791ccbf4f034a6302e77e6ed
|
Provenance
The following attestation bundles were made for tesseract_core-1.8.1.tar.gz:
Publisher:
publish.yml on pasteurlabs/tesseract-core
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tesseract_core-1.8.1.tar.gz -
Subject digest:
0aef504ae5592d1e29c5d9748b74017fa1aaa1c92efb3fbc13c48a4816cc1b5a - Sigstore transparency entry: 1439892668
- Sigstore integration time:
-
Permalink:
pasteurlabs/tesseract-core@95c3ca8f30d81652aef48e030987ac508d0cce73 -
Branch / Tag:
refs/tags/v1.8.1 - Owner: https://github.com/pasteurlabs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@95c3ca8f30d81652aef48e030987ac508d0cce73 -
Trigger Event:
release
-
Statement type:
File details
Details for the file tesseract_core-1.8.1-py3-none-any.whl.
File metadata
- Download URL: tesseract_core-1.8.1-py3-none-any.whl
- Upload date:
- Size: 138.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9014788d73447f3d0d3f532918c7f1e04d76c9f64229e05dfb7713c3b5b3fe54
|
|
| MD5 |
bc4529238a95c90095caf64db338e5a5
|
|
| BLAKE2b-256 |
69b3ce3f2c2299a9777cedb1bddb45237d50cab7e8124d2e4cfc1925825c8a1d
|
Provenance
The following attestation bundles were made for tesseract_core-1.8.1-py3-none-any.whl:
Publisher:
publish.yml on pasteurlabs/tesseract-core
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tesseract_core-1.8.1-py3-none-any.whl -
Subject digest:
9014788d73447f3d0d3f532918c7f1e04d76c9f64229e05dfb7713c3b5b3fe54 - Sigstore transparency entry: 1439892690
- Sigstore integration time:
-
Permalink:
pasteurlabs/tesseract-core@95c3ca8f30d81652aef48e030987ac508d0cce73 -
Branch / Tag:
refs/tags/v1.8.1 - Owner: https://github.com/pasteurlabs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@95c3ca8f30d81652aef48e030987ac508d0cce73 -
Trigger Event:
release
-
Statement type: