Input pipelines, which ingest and transform input data, are an essential part of training Machine Learning (ML) models. However, it is challenging to implement efficient input pipelines, as it requires reasoning about parallelism, asynchrony, and variability in fine-grained profiling information. Our analysis of over two million ML jobs in Google datacenters reveals that a significant fraction of model training jobs could benefit from faster input data pipelines. At the same time, our analysis indicates that most jobs do not saturate host hardware, pointing in the direction of software-based bottlenecks.
Motivated by these findings, we propose Plumber, a tool for finding bottlenecks in ML input pipelines. Plumber uses an extensible and interpretable operational analysis analytical model to automatically tune parallelism, prefetching, and caching under host resource constraints. Across five representative ML pipelines, Plumber obtains speedups of up to 47x for misconfigured pipelines. By automating caching, Plumber obtains end-to-end speedups of over 50% compared to state-of-the-art tuners.
Michael is a final year PhD student in the Computer Science Department of Carnegie Mellon University advised by George Amvrosiadis and Virginia Smith. He received his bachelor’s degree from Georgia Institute of Technology, and his research was supported by an NDSEG fellowship. He is broadly interested in computer systems and is currently working on systems for machine learning, with a particular emphasis on data pipelines (e.g., data augmentations, I/O formats, and pipeline design).