This repository contains the code for the paper Many Models at the Edge: Characterizing and Improving Deep Inference via Model-Level Caching, presented at ACSOS'21.
As deep learning models becoming more widely used the main limiting resource will become memory. This drives a need for the development of techniques for conserving memory. We propose model-level caching for this.
We first motivate the need for model-level caching by examining the scale of the workload expected for deep learning and the needs of models. When considered together it is apparent that while a few models are very popular, and thus would use dedicated host, the over 97% of models sit idle more than half the time. This implies that they are more constrained by memory availability than they are computational.
Addressing this will require prioritizing the usage of memory through model-level caching. We introduce a first step in this direction, a simple eviction policy for a model cache that can free up space for new models. This policy is called CremeBrulee and we realize it in a testbed and in simulation.
src-simulator
- Code for simuation
src-testbed
- Code for simulation
src-workload
- Code for generation event drive simulation
run_scripts
- Scripts used to generate workload and run testbed and simulation
datasets
- Location for azure FaaS datasets to be store, as well as instructions on finding them
docker
- Contains custom docker files for testbed implementation
measurements
- Basic model measurements for deep learning models from AWS
m5.large
instance for simulation.
- Basic model measurements for deep learning models from AWS
models
- Location to keep models, including script to create sample models from Keras
@article{Ogden_Many_Models_at,
author = {Ogden, Samuel S. and Gilman, Guin and Walls, Robert J. and Guo, Tian},
title = {{Many Models at the Edge: Characterizing and Improving Deep Inference via Model-Level Caching}},
url = {https://github.com/cake-lab/CremeBrulee}
}
To be added....