Skip to main content

Python bindings for functional maps

Project description

pyFM - Python Functional Maps Library

animated

NEW API Documentation is available here

This package contains a comprehensive Python implementation for shape correspondence using functional maps, featuring code from multiple papers

Core Features

  • Complete TriMesh class with geometric measures (geodesics, normals, LBO projections, differential operators)
  • Fast Laplace-Beltrami Operator implementation
  • Shape descriptors (HKS, WKS) with flexible parameter control
  • Efficient correspondence refinement (ICP, ZoomOut)
  • Fast functional-to-pointwise map conversion
  • Functional Map Network utilities

Installation

pip install pyfmaps

Key Dependencies

Design Philosophy

This codebase prioritizes readability and adaptability over rigid modularity. The implementation seeks to make it easy to:

  • Read and understand the underlying algorithms
  • Copy and modify code snippets for your research
  • Experiment with and extend existing methods
  • Avoid rewriting core functionality from scratch

Under the hood, core algorithms are implemented as standalone functions operating on basic numpy arrays. This dual-layer design means you can use the high-level interface for standard workflows, but still easily extract and modify the core functions for your research, as they work with simple numpy arrays.

While this approach differs from highly modular packages like scikit-learn, it better serves researchers who need to modify and build upon existing shape correspondence methods.

This design choice comes with some trade-offs:

  • Less abstraction means potentially more code to achieve certain tasks
  • Users need some familiarity with shape correspondence concepts
  • Implementation favors explicit algorithms over general-purpose interfaces

I selected this approach from my personal experience with research codebases and may not suit everyone's needs. More generic and abstracted implementations of geometric processing can be expected to appear soonish in the scikit-shapes or geomstats libraries.

Notation Convention

  • Functional maps (FM_12): mesh1 → mesh2
  • Pointwise maps (p2p_21): mesh2 → mesh1

Documentation & Examples

Implemented Papers

This library implements methods from several key papers in shape correspondence, including:

Torch Version

Most functions in this package can easily be translated to torch. However, for clarity of the code, a separate version will be released.

For now, the torch implementations can be found in different githubs (see my GitHub profile).

Coming Soon

Contact and Citation

You can contact me for any questions or requests at robin.magnet@inria.fr

This package has not (yet) been presented as a paper in itself, although all my works heavily rely on this.

If you use this package or copy and paste parts of it for you experiments, please cite this github or one of the following paper. Note these papers never directly refer to pyfmaps as so I am fine with you only citing the github for now.

@inproceedings{magnetDWKSLocalDescriptor2021,
  title = {{{DWKS}} : {{A Local Descriptor}} of {{Deformations Between Meshes}} and {{Point Clouds}}},
  shorttitle = {{{DWKS}}},
  booktitle = {2021 {{IEEE}}/{{CVF International Conference}} on {{Computer Vision}} ({{ICCV}})},
  author = {Magnet, Robin and Ovsjanikov, Maks},
  publisher = {IEEE},
}


@inproceedings{magnetSmoothNonRigidShape2022,
  title = {Smooth {{Non-Rigid Shape Matching}} via {{Effective Dirichlet Energy Optimization}}},
  booktitle = {2022 {{International Conference}} on {{3D Vision}} ({{3DV}})},
  author = {Magnet, Robin and Ren, Jing and {Sorkine-Hornung}, Olga and Ovsjanikov, Maks},
  year = {2022},
  publisher = {{IEEE}},

}

@article{magnetScalableEfficientFunctional2023,
  title = {Scalable and {{Efficient Functional Map Computations}} on {{Dense Meshes}}},
  author = {Magnet, Robin and Ovsjanikov, Maks},
  year = {2023},
  journal = {Computer Graphics Forum},
}

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

pyfmaps-1.0.1.tar.gz (56.5 kB view details)

Uploaded Source

Built Distribution

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

pyfmaps-1.0.1-py3-none-any.whl (60.5 kB view details)

Uploaded Python 3

File details

Details for the file pyfmaps-1.0.1.tar.gz.

File metadata

  • Download URL: pyfmaps-1.0.1.tar.gz
  • Upload date:
  • Size: 56.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for pyfmaps-1.0.1.tar.gz
Algorithm Hash digest
SHA256 5e4050b113a14ec60080c07499498a672d2b7ef261beb99624c0136f053c1e40
MD5 d468e00bebb8afbb662990b1b16d03e5
BLAKE2b-256 1134dbb4acd15e51470001e421d7c8536135c9ee0f920adbca79d10bcef434f9

See more details on using hashes here.

File details

Details for the file pyfmaps-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: pyfmaps-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 60.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for pyfmaps-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1585144c193a04e944df15fec2a8fadf571c4912d248a546d8e9101f5c27b88f
MD5 c8b131896bb9f308d04cecaa43235f53
BLAKE2b-256 834357c722eda038ef4122d1fea945d9dd43a5ef50640a4462cc057cde72e822

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