Skip to content
/ ares Public

Ares: A framework for quantifying the resilience of deep neural networks

Notifications You must be signed in to change notification settings

alugupta/ares

Repository files navigation

Ares: A framework for quantifying the resilience of deep neural networks

Models

This repository supports the training, optimization, and evaluation of the following models:

  1. MNIST-LeNet300-100 ( Three FC layers, MNIST dataset )
  2. MNIST-LeNet5 ( Two convolutional layers, two FC layers, MNIST dataset )
  3. TIDIGITS-X ( Simple RNN, GRU, and LSTM networks, TIDIGITS dataset )
  4. CiFar10-VGG ( VGG-esque convolutional network, CiFar10 dataset )
  5. CiFar10-AlexNet
  6. ImageNet-VGG16 ( VGG16 convolutional network, ImageNet dataset )
  7. ImageNet-ResNet50 ( ResNet50 convolutional network, ImageNet dataset )
  8. ImageNet-IncenptionV3
  9. ImageNet-MobileNet

Follow the structure in ares/dl_models/models/ to modify the model architectures or build additional models.

Getting started

To get started quickly, you can run simple training and testing examples using the various configurations in ares/run_models.py, and some examples are provided in ares/run.sh. You may need to edit the run_experiment.sh file to correctly configure paths to imagenet and other external data. A docker script to create the correct path structure and run the tools is provided. Run ares/run_experiement.sh

Ares Experiments

The experiments in ares/experiments are provided to perform the fault-injection analyses found in Ares. We provide examples for how to train, evaluate, quantize, and inject faults in models under ares/experiments/train, ares/experiments/eval, ares/experiments/quantize, and ares/experiments/bits.

Before running each of the experiments, add the Ares' root directory to your PYTONPATH as follows: export PYTHONPATH=<path-to-ares>/:$PYTOHNPATH. In addition, for tidigits and imagenet, edit imagenet_base.py, run_experiment.py and/or tidigits_utils.py to make sure the data filepaths are correct. For imagenet, ares assumes the train and test set are stored one 256 batch per file, with the labels stored as a numpy array.

Training

Examples of training models can be found in ares/experiments/train/train.sh.

The MNIST and CiFAR datasets are made available through the Keras deep learning framework. TIDIGITs and ImageNet must be downloaded and pre-processed separately, however pre-trained models for ImageNet (e.g., VGG16, ResNet50) are available through Pytorch and will be automatically downloaded by the framework.

Quantization

To quantize models, run ares/experiments/quantize/run.sh.

The quantization transform emulates fixed-point datatypes for weights. Note that activations and arithmetic operations still have full-precision.

Evaluation

After training and quantizing models, ares/experiments/eval/eval.sh can be used to evaluate the models on the validation and test sets.

Fault-injection

The ares/experiments/bits/bits.py experiment implements the core fault-injection framework of Ares. We illustrate an example of how to inject static persistent faults in the weights for the models. The transform for random fault injection is implemented in ares/dl_models/transform/random_fault.py. Examples of running the fault injection framework can be found in ares/experiments/bits/run.sh.

Examples of how to inject faults into activations will be provided shortly. In the meantime, please contact us if you have questions regarding this.

Link to paper

Visit ACM's digital library to read the full paper.

Citation

If you use Ares, please cite us:

   @inproceedings{Reagen:2018:AFQ:3195970.3195997,
   author = {Reagen, Brandon and Gupta, Udit and Pentecost, Lillian and Whatmough, Paul and Lee, Sae Kyu and Mulholland, Niamh and Brooks, David and Wei, Gu-Yeon},
   title = {Ares: A Framework for Quantifying the Resilience of Deep Neural Networks},
   booktitle = {Proceedings of the 55th Annual Design Automation Conference},
   series = {DAC '18},
   year = {2018},
   isbn = {978-1-4503-5700-5},
   location = {San Francisco, California},
   pages = {17:1--17:6},
   articleno = {17},
   numpages = {6},
   url = {http://doi.acm.org/10.1145/3195970.3195997},
   doi = {10.1145/3195970.3195997},
   acmid = {3195997},
   publisher = {ACM},
   address = {New York, NY, USA},}

Contact Us

For any further questions please contact [email protected]

About

Ares: A framework for quantifying the resilience of deep neural networks

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •