3DCertify is the first verifier to certify the robustness of 3D point cloud models against semantic, real-world transformations and point perturbations. It leverages first-order Taylor approximations to efficiently compute linear relaxations of any differentiable transformation function. These relaxations can be used to certify a network's robustness to common transformations such as rotation, shifting, or twisting, using a state-of-the-art general network verifier as a backend (e.g., ERAN or auto_LiRPA). Furthermore, 3DCertify improves these certifiers with a tighter relaxation for max pool layers, which are particularly challenging and a crucial component of point cloud architectures.
This repository contains all implementations, models, and instructions required to reproduce the experiments from our ICCV'21 paper. Please refer to the paper for the theoretical introduction and analysis, as well as detailed results.
This work is part of the SafeAI project at the SRI lab of ETH Zurich.
Clone this repository, including all submodules:
git clone --recurse-submodules https://github.com/eth-sri/3dcertify.git
Create a conda environment with the required dependencies:
conda env create -f environment.yml
conda activate 3dcertify
Setup dependencies and install ERAN:
cd ERAN
# select an ELINA version compatible with the selected version of ERAN
sed -i'' -e '/^cd ELINA$/a git checkout 2c9a4ea' install.sh
./install.sh
cd ..
For DeepG3D relaxations, install Deepg3D (see also deepg3d/README.md
):
cd deepg3d/code
mkdir build
make deepg_pointclouds
cd ../..
For experiments using auto_LiRPA, install auto_LiRPA (see also auto_LiRPA/README.md
):
cd auto_LiRPA
python setup.py develop
git apply ../auto_LiRPA.diff
cd ..
DeepG3D and some parts of DeepPoly use the GUROBI solver for certification. To run our code, apply for and download an academic GUROBI License.
All experiments from our paper can be reproduced by running the commands listed below with appropriate parameters. Some
basic pretrained models are provided with this repository in models/
, all additional models used in our experiments
can be downloaded at https://files.sri.inf.ethz.ch/pointclouds/pretrained-models.zip or via the script in
models/download_models.sh
. Alternatively, you can train you own models using our training scripts train_*.py
.
Note: the datasets will be downloaded and processed automatically the first time the script is used. Depending on processing power, this may take several hours.
python verify_transformation.py \
--model models/64p_natural.pth \
--num_points 64 \
--transformation RotationZ \
--theta 1deg \
--intervals 1 \
--relaxation taylor \
--pooling improved_max \
--experiment example1
Available transformations: RotationX
, RotationY
, RotationZ
, TwistingZ
, TaperingZ
, ShearingZ
For automatic composition of arbitrary transformations chain them using a + symbol, e.g. RotateZ+RotateX
or
TaperingZ+TwistingZ+RotationZ
.
A detailed description of all parameters and their possible values can be accessed via the integrated help
python verify_transformation.py -h
.
python verify_perturbation.py \
--model models/64p_ibp.pth \
--num_points 64 \
--eps 0.01 \
--pooling improved_max \
--experiment example2
Compute relaxations with DeepG3D:
- Create a directory with a config file with parameters and relaxations, such as
deepg3d/code/examples/modelnet40_64p_rotationz_theta_1_intervals_1/config.txt
. Refer to the Deepg3D README for more information. - enter the
deepg3d/code
directory and run.build/deepg_pointclouds examples/modelnet40_64p_rotationz_theta_1_intervals_1
Then verify using 3DCertify:
python verify_deepg.py \
--model models/64p_natural.pth \
--spec-dir deepg3d/code/examples/modelnet40_64p_rotationz_theta_1_intervals_1 \
--num_points 64 \
--pooling improved_max \
--experiment example3
python verify_segmentation.py \
--model models/64p_segmentation.pth \
--num_points 64 \
--transformation RotationZ \
--theta 1deg \
--intervals 1 \
--relaxation taylor \
--experiment example4
python verify_lirpa.py \
--model models/64p_natural.pth \
--num_points 64 \
--theta 1deg \
--experiment example5
@inproceedings{lorenz2021robustness,
author = {Tobias Lorenz and
Anian Ruoss and
Mislav Balunovi{\'c} and
Gagandeep Singh and
Martin Vechev},
title = {Robustness Certification for Point Cloud Models},
year = 2021,
month = {October},
booktitle = {Proceedings of the IEEE/CVF International Conference on Computer Vision (ICCV)}
pages = {7608-7618}
}
- Tobias Lorenz ([email protected])
- Anian Ruoss ([email protected])
- Mislav Balunović ([email protected])
- Gagandeep Singh ([email protected])
- Martin Vechev ([email protected])
Licensed under the Apache-2.0 License