Nimble: Lightweight and Parallel GPU Task Scheduling for Deep Learning
Seoul National University
arXiv:2012.02732 [cs.LG], (4 Dec 2020)
@misc{kwon2020nimble,
title={Nimble: Lightweight and Parallel GPU Task Scheduling for Deep Learning},
author={Woosuk Kwon and Gyeong-In Yu and Eunji Jeong and Byung-Gon Chun},
year={2020},
eprint={2012.02732},
archivePrefix={arXiv},
primaryClass={cs.LG}
}
Deep learning (DL) frameworks take advantage of GPUs to improve the speed of DL inference and training. Ideally, DL frameworks should be able to fully utilize the computation power of GPUs such that the running time depends on the amount of computation assigned to GPUs. Yet, we observe that in scheduling GPU tasks, existing DL frameworks suffer from inefficiencies such as large scheduling overhead and unnecessary serial execution. To this end, we propose Nimble, a DL execution engine that runs GPU tasks in parallel with minimal scheduling overhead. Nimble introduces a novel technique called ahead-of-time (AoT) scheduling. Here, the scheduling procedure finishes before executing the GPU kernel, thereby removing most of the scheduling overhead during run time. Furthermore, Nimble automatically parallelizes the execution of GPU tasks by exploiting multiple GPU streams in a single GPU. Evaluation on a variety of neural networks shows that compared to PyTorch, Nimble speeds up inference and training by up to 22.34x and 3.61x, respectively. Moreover, Nimble outperforms state-of-the-art inference systems, TensorRT and TVM, by up to 2.81x and 1.70x, respectively.
December 13, 2020 by hgpu