BaCO: A Fast and Portable Bayesian Compiler Optimization Framework

Hellsten EO; Souza A; Lenfers J; Lacouture R; Hsu O; Ejjeh A; Kjolstad F; Steuwer M; Olukotun K; Nardi L

Research article in edited proceedings (conference) | Peer reviewed

Abstract

We introduce the Bayesian Compiler Optimization framework (BaCO), a general purpose autotuner for modern compilers targeting CPUs, GPUs, and FPGAs. BaCO provides the flexibility needed to handle the requirements of modern autotuning tasks. Particularly, it deals with permutation, ordered, and continuous parameter types along with both known and unknown parameter constraints. To reason about these parameter types and efficiently deliver high-quality code, BaCO uses Bayesian optimization algorithms specialized towards the autotuning domain. We demonstrate BaCO's effectiveness on three modern compiler systems: TACO, RISE & ELEVATE, and HPVM2FPGA for CPUs, GPUs, and FPGAs respectively. For these domains, BaCO outperforms current state-of-the-art auto-tuners by delivering on average 1.36X--1.56X faster code with a tiny search budget, and BaCO is able to reach expert-level performance 2.9X--3.9X faster.

Details about the publication

PublisherAssociation for Computing Machinery
Book titleProceedings of the 28th ACM International Conference on Architectural Support for Programming Languages and Operating Systems, Volume 4
Page range19–42-19–42
Publishing companyAssociation for Computing Machinery
Place of publicationNew York, NY, USA
Title of seriesASPLOS '23
Volume of series4
StatusPublished
Release year2024 (07/02/2024)
ConferenceASPLOS 2023, Vancouver, Canada
ISBN9798400703942
DOI10.1145/3623278.3624770
Keywordscompiler optimizations, high-performance computing, bayesian optimization, autotuning, autoscheduling

Authors from the University of Münster

Lenfers, Johannes
Professur für Praktische Informatik (Prof. Gorlatch)