Relay: A High-Level Compiler for Deep Learning

Jared Roesch,Steven Lyubomirsky,Marisa Kirisame,Logan Weber,Josh Pollock,Luis Vega,Ziheng Jiang,Tianqi Chen,Thierry Moreau,Zachary Tatlock
DOI: https://doi.org/10.48550/arXiv.1904.08368
2019-08-25
Abstract:Frameworks for writing, compiling, and optimizing deep learning (DL) models have recently enabled progress in areas like computer vision and natural language processing. Extending these frameworks to accommodate the rapidly diversifying landscape of DL models and hardware platforms presents challenging tradeoffs between expressivity, composability, and portability. We present Relay, a new compiler framework for DL. Relay's functional, statically typed intermediate representation (IR) unifies and generalizes existing DL IRs to express state-of-the-art models. The introduction of Relay's expressive IR requires careful design of domain-specific optimizations, addressed via Relay's extension mechanisms. Using these extension mechanisms, Relay supports a unified compiler that can target a variety of hardware platforms. Our evaluation demonstrates Relay's competitive performance for a broad class of models and devices (CPUs, GPUs, and emerging accelerators). Relay's design demonstrates how a unified IR can provide expressivity, composability, and portability without compromising performance.
Machine Learning,Programming Languages
What problem does this paper attempt to address?