This directory contains steps and artifacts to run a PyTorch sample workload on Graphene. Specifically, this example uses a pre-trained model for image classification. We tested this on Ubuntu 16.04 and 18.04. The sample uses the package versions of Python (3.5 and 3.6) coming with each distribution.
The workload reads an image from a file on disk input.jpg
and runs the classifier to detect what
object is present in the image. For the image shipping with the workload, the output should be
[('Labrador retriever', 41.58518600463867), ('golden retriever', 16.59165382385254), ('Saluki, gazelle hound', 16.286855697631836), ('whippet', 2.853914976119995), ('Ibizan hound, Ibizan Podenco', 2.3924756050109863)]
With high probability (41%) the classifier detected the image to contain a Labrador retriever.
The following steps should suffice to run the workload on a stock Ubuntu 16.04 and 18.04 installation.
sudo apt-get install python3-pip lsb-release
to installpip
andlsb_release
. The former is required to install additional Python packages while the latter is used by the Makefile.pip3 install --user torchvision pillow
to install the torchvision and pillow Python packages and their dependencies (usually in $HOME/.local). WARNING: This downloads several hundred megabytes of data!python3 -c 'import torchvision ; torchvision.models.alexnet(pretrained=True)'
to download the pre-trained model ($HOME/.cache/torch). WARNING: This downloads about 200MB of data!
Run make
to build the non-SGX version and make SGX=1
to build the SGX version.
Execute any one of the following commands to run the workload
- natively:
python3 pytorchexample.py
- Graphene w/o SGX:
./pal_loader ./pytorch.manifest ./pytorchexample.py
- Graphene with SGX:
SGX=1 ./pal_loader ./pytorch.manifest ./pytorchexample.py