Point2mesh
Reconstruct Watertight Meshes from Point Clouds [SIGGRAPH 2020]
Point2Mesh is a technique for reconstructing a surface mesh from an input point cloud. This approach "learns" from a single object, by optimizing the weights of a CNN to deform some initial mesh to shrink-wrap the input point cloud. The argument for going this route is: since the (local) convolutional kernels are optimized globally across the entire shape, this encourages local-scale geometric self-similarity across the reconstructed shape surface. The project is written primarily in Python, distributed under the MIT License license, first published in 2020. It has gained significant community traction with 1,235 stars and 134 forks on GitHub. Key topics include: 3d-graphics, deep-learning, mesh-processing, pointcloud, pytorch.
Point2Mesh in PyTorch
SIGGRAPH 2020 [Paper] [Project Page]<br>
Point2Mesh is a technique for reconstructing a surface mesh from an input point cloud.
This approach "learns" from a single object, by optimizing the weights of a CNN to deform some initial mesh to shrink-wrap the input point cloud.
The argument for going this route is: since the (local) convolutional kernels are optimized globally across the entire shape,
this encourages local-scale geometric self-similarity across the reconstructed shape surface.
<img src="docs/images/global_anky.gif" align="center" width="250px"> <br>
The code was written by Rana Hanocka and Gal Metzer.
Getting Started
Installation
- Clone this repo:
bashgit clone https://github.com/ranahanocka/point2mesh.git cd point2mesh
Setup Conda Environment
- Relies on PyTorch version 1.4 (or 1.5) and PyTorch3D version 0.2.0. <br>
Install via conda environmentconda env create -f environment.yml(creates an environment called point2mesh)
Install "Manifold" Software
This code relies on the Robust Watertight Manifold Software.
First cd into the location you wish to install the software. For example, we used cd ~/code.
Then follow the installation instructions in the Watertight README.
If you installed Manifold in a different path than ~/code/Manifold/build, please update options.py accordingly (see this line)
Running Examples
Get Data
Download our example data
bashbash ./scripts/get_data.sh
Running Reconstruction
First, if using conda env first activate env e.g. source activate point2mesh.
All the scripts can be found in ./scripts/examples.
Here are a few examples:
Giraffe
bashbash ./scripts/examples/giraffe.sh
Bull
bashbash ./scripts/examples/bull.sh
Tiki
bashbash ./scripts/examples/tiki.sh
Noisy Guitar
bashbash ./scripts/examples/noisy_guitar.sh
... and more.
All the examples
To run all the examples in this repo:
bashbash ./scripts/run_all_examples.sh
Running different Examples
You should provide an initial mesh file. If the shape has genus 0, you can use the convex hull script provided in ./scripts/process_data/convex_hull.py
Citation
If you find this code useful, please consider citing our paper
@article{Hanocka2020p2m,
title = {Point2Mesh: A Self-Prior for Deformable Meshes},
author = {Hanocka, Rana and Metzer, Gal and Giryes, Raja and Cohen-Or, Daniel},
year = {2020},
issue_date = {July 2020},
publisher = {Association for Computing Machinery},
volume = {39},
number = {4},
issn = {0730-0301},
url = {https://doi.org/10.1145/3386569.3392415},
doi = {10.1145/3386569.3392415},
journal = {ACM Trans. Graph.},
}
Questions / Issues
If you have questions or issues running this code, please open an issue.
Contributors
Showing top 2 contributors by commit count.
