This repository is the official PyTorch implementation of IF-Defense: 3D Adversarial Point Cloud Defense via Implicit Function based Restoration, where we study adversarial defense in 3D point cloud and propose an deep implicit function based defense method that achieves state-of-the-art (SOTA) performance against all the existing attacks on several typical point cloud networks.
Point cloud is an important 3D data representation widely used in many essential applications (e.g. autonomous driving, robotics). Leveraging deep neural networks (DNNs), recent works have shown great success in processing 3D point clouds. However, DNNs are vulnerable to adversarial attacks, bringing security threat to those safety-critical applications.
Although adversarial attack and defense are widely studied in 2D images, little attention is paid to its 3D counterpart. In this paper, we show that 3D attack is not a simple extension of 2D. We summarize the attack effects of existing methods from a 3D-specific geometric-aware perspective. The small and local perturbations are point perturbation, which includes out-of-surface perturbation and on-surface perturbation. The larger and more global attacks are surface distortion including local part removal and geometric deformation.
In this paper, we propose a novel 3D adversarial point cloud defense method leveraging implicit function based restoration. It is composed of two steps: 1) it predicts an implicit function that captures the clean shape through a surface recovery module, and 2) restores a clean and complete point cloud via optimizing towards the predicted implicit surface under geometry- and distribution- aware constraints. Our experimental results show that IF-Defense achieves the state-of-the-art defense performance against all existing adversarial attacks on PointNet, PointNet++, DGCNN, PointConv and RS-CNN.
In this repo, we provide PyTorch implementations for baseline attacks (Perturb, Add, kNN, Drop), defenses (SRS, SOR, DUP-Net) and three variants of IF-Defense (ONet-Mesh, ONet-Opt, ConvONet-Opt). We hope this open source codebase can benefit the community of 3D adversarial attack and defense in point cloud.
If you find our code or paper useful, please considering citing
@article{wu2020if,
title={IF-Defense: 3D Adversarial Point Cloud Defense via Implicit Function based Restoration},
author={Wu, Ziyi and Duan, Yueqi and Wang, He and Fan, Qingnan and Guibas, Leonidas J},
journal={arXiv preprint arXiv:2010.05272},
year={2020}
}
- 2021.1.4 Happy new year! I upload some scripts used to generate ModelNet40 training data where I trained my implicit functions. Have a look at
ONet/data_proc/
if you need them - 2020.12.18 New implementations of adding_cluster and adding_object attacks are provided in
baselines/
! These attacks are more physically-realizable and can pose severe threats to point cloud models in real world deployment - 2020.11.18 V2 paper of IF-Defense on arXiv! Check out our new results on RS-CNN, extreme sparse input point clouds and adaptive attack
- 2020.10.13 IF-Defense code release, paper on arXiv available here
Our project is developed using Python 3.7.7, PyTorch 1.5.0 with CUDA10.1. We recommend you to use anaconda for dependency configuration.
First create an anaconda environment called IF-Defense
by
conda create -n IF-Defense python=3.7
conda activate IF-Defense
All the required packages are listed in the requirements.txt file. First use pip to install them by
python -m pip install -r requirements.txt
Then, you need to install torch, torchvision and torch-scatter manually to fit in with your server environment (e.g. CUDA version). For the torch and torchvision used in my project, run
conda install pytorch==1.5.0 torchvision==0.6.0 cudatoolkit=10.1 -c pytorch
For torch-scatter (used in ConvONet), please follow their official instruction.
The code in this project is mainly divided into three folders, each of which has a detailed README file explaining its usage. Here I will briefly outline the structure of this repo.
baselines/
contains code for training/testing the victim models as well as some baseline attack and defense methods.
ONet/
implements two variants of our IF-Defense, ONet-Mesh and ONet-Opt.
ConvONet/
is another variant (and also the strongest in most cases) of IF-Defense, ConvONet-Opt.
Please go to each folder to see how to use the code in detail.
The comprehensive comparisons between different defense methods against various attacks on four victim models can be found in the paper (Table.2, 3, 4, 5). Here we plot the results as histograms for more straightforward demonstration, where the x-axis are different attacks, y-axis is accuracy and higher is better and our IF-Defense is the last three columns of each cluster.
Note that, the last three columns are three variants of our methods.
We show defense point clouds of SOR, DUP-Net and three variants of IF-Defense. Our methods successfully 1) recover the head of the airplane under point dropping attack and 2) restore uniform point distributions under kNN attack. More visualizations can be found in the appendix of the paper.
IF-Defense is released under the MIT License. See the LICENSE file for more details.
We thank the authors of following works for opening source their excellent codes.
- PointNet/PointNet++, DGCNN, PointConv, RS-CNN
- Perturb/Add attack, kNN attack, Drop attack
- PU-Net, DUP-Net
- ONet, ConvONet
We also thank the authors of related papers/repos for their inspiring discussions with us.
If you have any questions about the paper or the code, please contact Ziyi Wu ([email protected])