Skip to content

In this research group project, we explored how to utilize the technique of ensemble to effectively defend the neural networks from gradient-based attacks.

Notifications You must be signed in to change notification settings

yishen734/ensemble-adversarial-training

Repository files navigation

Abstract

The model security has been an increasingly severe concern in the machine learning community. Experiments show that small perturbations to the original data (i.e. adversarial attacks) could lead to model’s misclassification. The ultimate goal of our project is to propose effective defense methods to defend against gradient-based adversarial attacks and explore the effect of system diversity on defense performance.

Generally, this research project is separated into two stages: (1) Reimplement three classic attacks and three defenses. (2) Research on ensemble defense methods. All the attack and defense methods will be experimented on the dataset CIFAR-10 using VGG-19 as the backbone. We select the three defenses that we implemented as the baseline and our ensemble defense methods finally prove to be much more effective.

Attacks methods: (1) L-BFGS (2) Fast Gradient Sign Method (FGSM) (3) Universal Adversarial Attack (UAA)

Defense methods: (1) Random Input Transformation (RIT) (2) Random Noising (RN) (3) FGSM Adversarial Training (FGSM AT) (4) Ensemble-based Defense (the defense that we mainly research on)

Please refer to our group's final report to see more details.

For testing attacks, run following three codes.

For LBFGS attack, run python main.py LBFGS.

For FGSM attack, run python main.py FGSM.

For UAA attack, run python main.py UAA.

For testing defenses, run following code.

For RIT and RN, the corresponding code has been removed, because our experiments show that these two methods doesn't work for pictures with small resolution.

For FGSM-AT defense, run python main.py FGSM-AT.

For testing random-ensemble methods, follow these steps.

  1. Run python random_ensemble.py <sample_rate> <output_dir>

    • Set the sample_rate to ["0.3","0.4","0.5","0.6","1.0"] respectively and set <output_dir> to the corresponding directories where you want to save the model pools. For example, you can run python random_ensemble.py 0.3 ./model_files/30_sample_rate/ for sample_rate=0.3.
    • This will give us a model pool as size of 20.
  2. Change the directory URLs in the file eval.py.

    • First, in line 164, set base_classifier_dir to the URL of best_model.pth, the base classifier used to generate adversarial samples.

    • Second, in line 165, set left_aside_model_dir to the URL of the non-defense model which will be used for comparison.

    • Third, change the list pool_dir, which should contain the URL of models trained from each sample rate, please follow the sample rate order ["0.3","0.4","0.5","0.6","1.0"].

  3. Run python eval.py for evaluation.

For testing AT-ensemble methods, follow these steps.

  1. Run python AT-ensemble.py <sample_rate> <input_dir> <output_dir>

    • Set the sample_rate to ["0.3","0.4","0.5","0.6","1.0"] respectively , set <input_dir> to the directories of exists models and set <output_dir> to the corresponding directories where you want to save the model pools. For example, you can run python random_ensemble.py 0.3 ./model_files/30_sample_rate/ ./model_files/30_sample_rate_AT/ for sample_rate=0.3.
    • This will give us a AT model pool as size of 20.
  2. Follow the second and third steps in the random-ensemble testing method.

File Structure

|____attackers
| |____attacker_base.py
| |____fgsm.py
| |____lbfgs.py
| |____uaa.py
|____defenders
| |____defender_base.py
| |____fgsm_AT.py
|____eval.py
|____main.py
|____model_files
| |____best_model.pth*
| |____model0_parameter.pkl*
| |____README.txt
|____models
| |____train.py
|____random_ensemble.py
|____README.md
|____VGG.py

* Important: before execute our programs, you need first download the base classifier, then store it under the ./model_files/ directory. Then download the non-defense comparison model, then store it under the ./model_files/ directory.

Notes

  1. The first time you run our code, you may need to wait a few minutes for downlaoding the CIFAR-10 dataset.
  2. The result of each attack or defense, will be printed in the console after finishing.
  3. The UAA attack may take a long time to train (more than 12 hours). Please pay attention to that.

About

In this research group project, we explored how to utilize the technique of ensemble to effectively defend the neural networks from gradient-based attacks.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •  

Languages