Skip to content
/ SCEME Public

This is the implementation of the ECCV 2020 paper "Connecting the Dots: Detecting Adversarial Perturbations Using Context Inconsistency"

Notifications You must be signed in to change notification settings

sli057/SCEME

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

This repository holds the codes used in Connecting the Dots: Detecting Adversarial Perturbations Using Context Inconsistency, ECCV 2020.

Key Dependencies

  1. Python2

  2. TensorFlow 1.5.0 (CUDA 9.0), other version might be okay (e.g, TensorFlow 1.3.0)

  3. PyTorch 1.3.0

Installation

  1. Clone the SIN repository
# Make sure to clone with --recursive
git clone --recursive https://github.com/sli057/SCEME.git
  1. Build the Cython modules

(You may need to change "arch=" according to you GPU type.)

cd $SCEME_ROOT/lib
make

Step1: Build SCEME and train context-aware Faster R-CNN

We provided the pre-trained model on VOC0712 dataset for both Faster R-CNN and the context-aware Faster R-CNN, you could download them from Dropbox

Faster R-CNN: output/faster_rcnn_end2end/voc_2007_trainval+voc_2012_trainval/VGGnet_wo_context/VGGnet_wo_context.ckpt

Context-ware Faster R-CNN: output/faster_rcnn_end2end/voc_2007_trainval+voc_2012_trainval/VGGnet_wt_context/VGGnet_wt_context.ckpt

  1. Test with the pre-trained models

    cd context_model
    python test_FasterRCNN.py --net_final '../output/faster_rcnn_end2end/voc_2007_trainval+voc_2012_trainval/VGGnet_wo_context/VGGnet_wo_context.ckpt'
    python test_context_model.py --net_final '../output/faster_rcnn_end2end/voc_2007_trainval+voc_2012_trainval/VGGnet_wt_context/VGGnet_wt_context.ckpt'
    
  2. If you want to train your own models

    cd context_model
    python train_FasterRCNN.py --train_set YOUR_DATASET
    python train_context_model.py  --train_set YOUR_DATASET
    

Step2: Adversarial attacks on Faster RCNN

We provide both digital (FGSM +IFGSM ) and physical attack codes.

Generate perturbations

cd attack_detector

  1. digital miscategorization attack
python digital_attack.py --attack_type 'miscls'
  1. digital hiding attack
python digital_attack.py --attack_type 'hiding'
  1. digital appearing attack
python digital_attack.py --attack_type 'appear'
  1. physical miscategorization attack
python physical_attack.py --attack_type 'miscls'
  1. physical hiding attack
python physical_attack.py --attack_type 'hiding'
  1. physical appearing attack
python physical_attack.py --attack_type 'appear'

Collect the generated perturbations

cd script_extract_files
python extract_attack.py

Step 3: Collect context profiles

cd context_profile
python get_context_profiles.py

Note that there will be overwhelming number of "background" context profiles generated, you may stop collecting "background" context profile after certain point.

Note that it is not necessary to collect context profiles for all the images, just stop the running if you have got enough training/testing samples.

Note that it is necessary to run the last line get_dataset(voc_classes, root_dir, set_dirs, sub_dirs) to generate txt files for auto-encoder training and testing.

Step 4: Adversarial detection via AutoEncoders

The AutoEncoder is trained and tested with PyTorch

Train the AutoEncoders with the collected benign context profiles.

cd detect_attacks
python run_training_testing.py --mode 'train'

Test the reconstruction error on both benign and perturbed context profiles.

python run_training_testing.py --mode 'test'

Calculate the ROC-AUC.

python test_ROC-AUC.py

References

Faster R-CNN tf version

Context-aware Faster R-CNN

Physical perturbation generation

About

This is the implementation of the ECCV 2020 paper "Connecting the Dots: Detecting Adversarial Perturbations Using Context Inconsistency"

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published