Hercules: A Compiler for Productive Programming of Heterogeneous Systems
University of Illinois, Urbana-Champaign, Urbana, Illinois, USA
arXiv:2503.10855 [cs.PL], (13 Mar 2025)
Modern computing systems increasingly rely on composing heterogeneous devices to improve performance and efficiency. Programming these systems is often unproductive: algorithm implementations must be coupled to system-specific logic, including device-specific optimizations, partitioning, and inter-device communication and synchronization, which requires developing different programs for different system configurations. We propose the Juno language, which represents general purpose applications in an imperative form that can be transformed into parallel, optimized, system-specific code using an expressive and granular imperative scheduling language. We also introduce the Hercules compiler, which uses a novel intermediate representation to represent general and device-specific parallel code in a manner that is easy to analyze and manipulate using schedules. Our system achieves competitive performance with hand-optimized device-specific code (geomean speedups of 1.25× and 1.48× on the CPU and GPU) and significantly outperforms a prior general purpose heterogeneous programming system (geomean speedups of 9.31× and 16.18× on the CPU and GPU).
March 23, 2025 by hgpu