Python bindings for functional maps
Project description
pyFM - Python Functional Maps Library
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
- Required: numpy, scipy, tqdm, scikit-learn
- Optional:
potpourri3d(geodesics),robust_laplacian(Delaunay/tufted Laplacian)
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:
- The Heat Method for Distance Computation
- A Concise and Provably Informative Multi-Scale Signature Based on Heat Diffusion
- The Wave Kernel Signature: A Quantum Mechanical Approach To Shape Analysis
- ZoomOut: Spectral Upsampling for Efficient Shape Correspondence, with MatLab implementation here
- Deblurring and Denoising of Maps between Shapes, with Matlab implementation here
- Functional Maps: A Flexible Representation of Maps Between Shapes
- Informative Descriptor Preservation via Commutativity for Shape Matching
- Continuous and Orientation-preserving Correspondences via Functional Maps, only the orientation preserving / reversing term, matlab implementation can be found here
- Map-Based Exploration of Intrinsic Shape Differences and Variability
- An Optimization Approach to Improving Collections of Shape Maps
- Limit Shapes – A Tool for Understanding Shape Differences and Variability in 3D Model Collections
- CONSISTENT ZOOMOUT: Efficient Spectral Map Synchronization, with Matlab implementation here
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
- Discrete Optimization for Shape Matching and Smooth Non-Rigid Shape Matching via Effective Dirichlet Energy Optimization, already implemented here
- Reversible Harmonic Maps, already implemented here
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
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 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5e4050b113a14ec60080c07499498a672d2b7ef261beb99624c0136f053c1e40
|
|
| MD5 |
d468e00bebb8afbb662990b1b16d03e5
|
|
| BLAKE2b-256 |
1134dbb4acd15e51470001e421d7c8536135c9ee0f920adbca79d10bcef434f9
|
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1585144c193a04e944df15fec2a8fadf571c4912d248a546d8e9101f5c27b88f
|
|
| MD5 |
c8b131896bb9f308d04cecaa43235f53
|
|
| BLAKE2b-256 |
834357c722eda038ef4122d1fea945d9dd43a5ef50640a4462cc057cde72e822
|