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.19.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.19-py3-none-any.whl (42.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mantra_dataset-0.0.19.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.19.tar.gz
Algorithm Hash digest
SHA256 018922e43b53dab8e7d370131c998376fe52d99fc0f3cebc0a0af09bd22ab182
MD5 901fa202cf9f93d07b13aee35331a938
BLAKE2b-256 07f64d9176a19d97bc373acc97f9f3049a99460fc76dc01a35e6a5e9a2cc121c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mantra_dataset-0.0.19-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.19-py3-none-any.whl
Algorithm Hash digest
SHA256 2e048bd18ac7116e215836a594e35a75a7de7487607602b849b13c4b01397fd7
MD5 b5b4218d24d1e26f1cb1791f0ece6443
BLAKE2b-256 bc4cd815607778db53e49c352073bd5690cab534627b0d1c0384863f37827a36

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