Skip to content

Latest commit

 

History

History
48 lines (44 loc) · 2.2 KB

README.md

File metadata and controls

48 lines (44 loc) · 2.2 KB

PPML-Comparison

Overview

This repo contains code to run comparisons among different PPML architectures, including:

Usage

To get started, clone the repository by running

git clone https://github.com/TCSo/PPML-Comparison.git

cd into the PPML-Comparison directory with

cd PPML-Comparison

Install the following python dependencies (and others if they come up). Follow HE-MAN-Concrete and ZAMA Concrete ML's repo page for more setup and dependency guides.

pip install argparse pathlib numpy tqdm torch numpy torchvision 

For first time setup only, clone and build the HE-MAN-Concrete framework. Skip this step if the repository is already setup.

make setup

To generate test data, models, and run comparison, simple run

make

This will run all of the comparison code, specifically:

  • clean the directory
  • training the necessary models using planetext with MNIST training data, and generate the onnx models as well as the testing input and output files
  • run the models and data in the HE-MAN-Concrete framework and generate evaluation statistics
  • run the models and data in the ZAMA Concrete ML framework and generate evaluation statistics

Content
The content of the repository includes

  • data: contains all the MNIST data that we will be using to evaluate the PPML encrypted models.
  • calibration-data: contains a subset (representative) set of the MNIST data for calibrating the encrypted models.
  • thirdparty: contains third party repositories that the comparison runs on.
  • models.py: contains the pytorch models used for comparison, training, and data generation.
  • stats.py: contains the reading and comparison of model outputs.
  • Makefile: contains all the make commands for easy usage of this repository.
  • notebook.ipynb: just a iPython Notebook to interact with the files.

Acknowledgement
Part of the code (training loop) is referenced from UC Berkeley's CS182/282A assignments