Skip to content

Web-based Tool for visualisation and generation of adversarial examples by attacking ImageNet Models like VGG, AlexNet, ResNet etc.

Notifications You must be signed in to change notification settings

viktoriussuwandi/adversarial_lab

Repository files navigation

Adversarial Attack Visualization

Source code for the website and the project to generate adversarial examples to fool common Machine Learning models.

This is the repository for Visualizing and Comparision of Various Adversarial Attacks on user Uploaded Images using a User-Friendly interface using the DNN framework Pytorch, using popular SOTA Pretrained TorchVision ModelZoo. The Following Attacks have been implemented so far and code can be found inside GAE/attacks.py

  1. FGSM
    • Fast Gradient Sign Method, Untargeted
    • Fast Gradient Sign Method, Targeted
  2. Iterative
    • Basic Iterative Method, Untargeted
    • Least Likely Class Iterative Method
  3. DeepFool, untargeted
  4. LBFGS, targeted

Coming Soon: Carlini-Wagner l2, and Many More

Screenshots

Demo Image 1

Installation

Clone the git repository :

git clone https://github.com/dsgiitr/adversarial_gen_demo.git

Python 3 with Pytorch 1.4.0 is the primary requirement. The requirements.txt file contains a listing of required Python packages; to install all requirements, run the following:

pip3 install -r requirements.txt

Deploying webserver:

After downloading the repo, run python3 app.py:

$ cd adversarial_gen_demo
$ python3 app.py

Fire up your browser and navigate to localhost:5000 or your_server_url:5000. Upload any image in JPG format, Select SOTA torchvision model and Adversarial Attack strategy. Experiment with the parameters for a particular algorithm and push 'Generate'. After a short while, the server returns Ajax response with Perturbed Image and Perturbation of the Original Image along with Top 5 Classified Labels for the Same.

GAE

It is a simple Pytorch Library containing Simple Fast implementations of Adversarial Attack Strategies using Pytorch. Cleverhans-Future and Advertorch can be referred for proper Robust implementations. GAE is easy to understand and only Processes a single image file at a time (as of now). Usage of the Following can be found on Attacks Tutorial on Imagenet.ipynb notebook.

Framework

- Python `Flask`-based server
	- Python backend allows access to Pytorch 
- Front-end using JQuery and Bootstrap

About

Web-based Tool for visualisation and generation of adversarial examples by attacking ImageNet Models like VGG, AlexNet, ResNet etc.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Jupyter Notebook 96.6%
  • HTML 1.9%
  • Python 1.5%