Awesome
DeltaConv
[Paper] [Project page] [Replicability Stamp]
Code for the SIGGRAPH 2022 paper "DeltaConv: Anisotropic Operators for Geometric Deep Learning on Point Clouds" by Ruben Wiersma, Ahmad Nasikun, Elmar Eisemann, and Klaus Hildebrandt.
Anisotropic convolution is a central building block of CNNs but challenging to transfer to surfaces. DeltaConv learns combinations and compositions of operators from vector calculus, which are a natural fit for curved surfaces. The result is a simple and robust anisotropic convolution operator for point clouds with state-of-the-art results.
Top: unlike images, surfaces have no global coordinate system. Bottom: DeltaConv learns both scalar and vector features using geometric operators.
Contents
Installation
- Clone this repository:
git clone https://github.com/rubenwiersma/deltaconv.git
- Create a conda environment from the
environment.yml
:
conda env create -n deltaconv -f environment.yml
Done!
Manual installation
If you wish to install DeltaConv in your own environment, proceed as follows.
-
Make sure that you have installed:
- Numpy -
pip install numpy
- PyTorch - see instructions
- PyG -
conda install pyg -c pyg
- Numpy -
-
Install DeltaConv:
pip install deltaconv
Building DeltaConv for yourself
- Make sure you clone the repository with submodules:
git clone --recurse-submodules https://github.com/rubenwiersma/deltaconv.git
If you have already cloned the repository without submodules, you can fix it with git submodule update --init --recursive
.
- Install from folder:
cd [root_folder]
pip install ./
Replicating the experiments
See the README.md in replication_scripts
for instructions on replicating the experiments and using the pre-trained weights (available in experiments/pretrained_weights
).
In short, you can run bash scripts to replicate our experiments. For example, evaluating pre-trained weights on ShapeNet:
cd [root_folder]
conda activate deltaconv
bash replication_scripts/pretrained/shapenet.sh
You can also directly run the python files in experiments
:
python experiments/train_shapenet.py
Use the -h
or --help
flag to find out which arguments can be passed to the training script:
python experiments/train_shapenet.py -h
You can keep track of the training process with tensorboard:
tensorboard --logdir=experiments/runs/shapenet_all
Anisotropic Diffusion
The code that was used to generate Figure 2 from the paper and Figure 2 and 3 from the supplement is a notebook in the folder experiments/anisotropic_diffusion
.
Data
ModelNet40, ShapeNet, SHREC, and human body shape segmentation automatically download the datasets from a public repository and place them in the correct folder. Note: this can take a while. The data for ScanObjectNN can be downloaded from the ScanObjectNN website: https://hkust-vgd.github.io/scanobjectnn/. Download and extract the files into experiments/data/ScanObjectNN/raw
. The folder structure in experiments/data/ScanObjectNN
should look like:
ScanObjectNN
└─── raw
└─── main_split
| | train_objectdataset.h5
| | test_objectdataset.h5
| | ...
|
└─── main_split_nobg
| train_objectdataset.h5
| test_objectdataset.h5
| ...
FAQ
Can I run these scripts with low GPU memory?
Yes, you can reduce the memory requirements by changing some of the arguments for the train/test scripts. Some suggestions: reduce the batch size (e.g., 8: --batch_size 8
), reduce the number of points (e.g., 512 points: --num_points 512
), reduce the number of neighbors per point (e.g., 15 neighbors: --k 15
). Note that these changes will affect the accuracy of the models.
Can I get the scripts to run faster?
There are a couple of ways to reduce the time it takes to train a model. Some of these are explained in the answer on memory (e.g., reduce the number of points, reduce the number of neighbors). For ShapeNet, it's also possible to only train/test on a subset of the data. You can adjust this with the class_choice
argument, e.g. --class_choice Airplane
.
How can I run the bash scripts on Windows? The bash scripts typically only run one or two commands. You could the commands line by line if you are unable to run .sh scripts in your preferred command-line interace.
How did you render the figures in the paper? The figures in the paper are rendered in Blender, using Animation Nodes to load in the point clouds and features. A detailed explanation can be found in the folder visualization.
Tests
In the paper, we make statements about a number of properties of DeltaConv that are either a result of prior work or due to the implementation. We created a test suite to ensure that these properties hold for the implementation, along with unit tests for each module. For example:
- Section 3.6, 3.7: Vector MLPs are equivariant to norm-preserving transformations, or coordinate-independent (rotations, reflections)
test/nn/test_mlp.py
test/nn/test_nonlin.py
- Section 3.7: DeltaConv is coordinate-independent, a forward pass on a shape with one choice of bases leads to the same output and weight updates when run with different bases
test/nn/test_deltaconv.py
- Introduction, section 3.2: The operators are robust to noise and outliers.
test/geometry/test_grad_div.py
- Supplement, section 1: Vectors can be mapped between points with equation (15).
test/geometry/test_grad_div.py
Visualization
The figures in the paper are rendered in Blender, using Animation Nodes to load in the point clouds and features. A detailed explanation can be found in the folder visualization.
Citations
Please cite our paper if this code contributes to an academic publication:
@Article{Wiersma2022DeltaConv,
author = {Ruben Wiersma, Ahmad Nasikun, Elmar Eisemann, Klaus Hildebrandt},
journal = {Transactions on Graphics},
title = {DeltaConv: Anisotropic Operators for Geometric Deep Learning on Point Clouds},
year = {2022},
month = jul,
number = {4},
volume = {41},
doi = {10.1145/3528223.3530166},
publisher = {ACM},
}
The farthest point sampling code relies on Geometry Central:
@misc{geometrycentral,
title = {geometry-central},
author = {Nicholas Sharp and Keenan Crane and others},
note = {www.geometry-central.net},
year = {2019}
}
And we make use of PyG (and underlying packages) to load point clouds, compute sparse matrix products, and compute nearest neighbors:
@inproceedings{Fey/Lenssen/2019,
title={Fast Graph Representation Learning with {PyTorch Geometric}},
author={Fey, Matthias and Lenssen, Jan E.},
booktitle={ICLR Workshop on Representation Learning on Graphs and Manifolds},
year={2019},
}