Skip to main content

A package for working with higher-order datasets like manifold triangulations.

Project description

MANTRA: The Manifold Triangulations Assemblage

arXiv DOI Maintainability GitHub contributors CHANGELOG License

image

MANTRA is a dataset consisting of combinatorial triangulations of manifolds. It can be used to create novel algorithms in topological deep learning or debug existing ones. See our ICLR 2025 paper for more details and our benchmarks repository for additional code to reproduce all experiments.

Please use the following citation for our work:

@inproceedings{Ballester25a,
  title         = {{MANTRA}: {T}he {M}anifold {T}riangulations {A}ssemblage},
  author        = {Rubén Ballester and Ernst Röell and Daniel Bīn Schmid and Mathieu Alain and Sergio Escalera and Carles Casacuberta and Bastian Rieck},
  year          = 2025,
  booktitle     = {International Conference on Learning Representations},
  url           = {https://openreview.net/forum?id=X6y5CC44HM},
}

Getting the Dataset

The raw MANTRA dataset consisting of $2$- and $3$-manifolds with up to $10$ vertices is provided here. For machine-learning applications and research, we provide a custom dataset loader package, which can be installed via the following command:

pip install mantra-dataset

After installation, the dataset can be used like this:

from mantra.datasets import ManifoldTriangulations

dataset = ManifoldTriangulations(
    root="./data",      # root folder for storing data
    dimension=2,        # Whether to load 2- or 3-manifolds
    version="latest"    # Which version of the dataset to load
)

Provided you have pytorch-geometric installed, here is a more comprehensive example, showing the use of random node features and how to transform it for using graph neural networks:

from torch_geometric.transforms import Compose
from torch_geometric.transforms import FaceToEdge

from mantra.datasets import ManifoldTriangulations
from mantra.transforms import NodeIndex
from mantra.transforms import RandomNodeFeatures


dataset = ManifoldTriangulations(
    root="./data",
    dimension=2,
    version="latest",
    transform=Compose(
        [
            NodeIndex(),
            RandomNodeFeatures(),
            # Converts face indices to edge indices, thus essentially
            # making the 1-skeleton available to a model.
            FaceToEdge(remove_faces=False),
        ]
    ),
    force_reload=True,
)

More Examples

Please find more example notebooks in the examples folder:

  1. Adding new tasks to MANTRA
  2. Training a GNN on MANTRA
  3. Visualizing the MANTRA dataset

FAQ

Q: Why MANTRA?

A: MANTRA is one of the first datasets providing prediction tasks that provably depend on the high-order features of the input data, in the case of MANTRA, simplices. MANTRA contributes to the benchmarking ecosystem for high-order neural networks by providing a large set of triangulations with precomputed topological properties that can be easily computed with deterministic algorithms but that are hard to compute for predictive models. The topological properties contained in MANTRA are elementary, meaning that good networks tackling complex topological problems should be able to completely solve this dataset. Currently, there is no model that can solve all the prediction tasks proposed in the dataset's paper.

Q: Why topological features?

A: Topology forms a fundamental theoretical foundation for natural sciences like physics and biology. Understanding a system's topology often reveals critical insights hardly accessible through other analytical methods. For neural networks to effectively tackle problems in these domains, they must develop capabilities to leverage topological information. This requires network architectures capable of identifying basic topological invariants in data—precisely the invariants that MANTRA provides. By incorporating these topological features, neural networks can capture essential structural and relational properties that traditional approaches might miss, enhancing their ability to model complex natural phenomena.

Q: Which are the main functions and classes implemented in this dataset?

A: The core class of the MANTRA package is ManifoldTriangulations. ManifoldTriangulations allows the user to load the MANTRA dataset using a InMemoryDataset format from torch_geometric. The transforms NodeIndex, RandomNodeFeatures, DegreeTransform, and DegreeTransformOneHotare also provided in this package. Concretely, NodeIndex transforms the original triangulation format in a torch-like tensor, and RandomNodeFeatures, DegreeTransform, and DegreeTransformOneHot assign input feature vectors to vertices in a the x attribute of the input Data representing a triangulation based either on random features or on the degree of each vertex, respectively.

Have a question that's not answered here? Please open an issue on our GitHub repository.

Acknowledgements

This work is dedicated to Frank H. Lutz, who passed away unexpectedly on November 10, 2023. May his memory be a blessing.

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

mantra_dataset-0.0.18.tar.gz (53.0 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mantra_dataset-0.0.18-py3-none-any.whl (42.2 kB view details)

Uploaded Python 3

File details

Details for the file mantra_dataset-0.0.18.tar.gz.

File metadata

  • Download URL: mantra_dataset-0.0.18.tar.gz
  • Upload date:
  • Size: 53.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mantra_dataset-0.0.18.tar.gz
Algorithm Hash digest
SHA256 27d08b9c7b6b85d08e85fea73378c300456c656c2a717ef43dce9243478f807e
MD5 f949f0340003c2586d44cd7e6f5dbaf3
BLAKE2b-256 13e32f8412242c1bf12e699f462350d80a2d3f338c6bfb9d03b6f6faabc684ff

See more details on using hashes here.

File details

Details for the file mantra_dataset-0.0.18-py3-none-any.whl.

File metadata

  • Download URL: mantra_dataset-0.0.18-py3-none-any.whl
  • Upload date:
  • Size: 42.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mantra_dataset-0.0.18-py3-none-any.whl
Algorithm Hash digest
SHA256 747ce828c44d2bd66d9f2e5870404ee8b0a92635585739a82a13c453cc8e9daa
MD5 51b60f5f052a2194bc5dd8208c56fd51
BLAKE2b-256 3959e61cbfd1302126c37dad9109c9588a0aa0293665f65e6492f9d3edb55454

See more details on using hashes here.

Supported by

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