1. Bayesian Optimization for auto-tuning GPU kernels
- Author
-
Floris-Jan Willemsen, Ben Van Werkhoven, Rob Van Nieuwpoort, and Multiscale Networked Systems (IvI, FNWI)
- Subjects
FOS: Computer and information sciences ,Computer Science - Machine Learning ,D.1.3 ,Computer Science - Performance ,C.4 ,I.6.3 ,G.3 ,Machine Learning (cs.LG) ,Performance (cs.PF) ,Computer Science - Distributed, Parallel, and Cluster Computing ,Optimization and Control (math.OC) ,FOS: Mathematics ,Distributed, Parallel, and Cluster Computing (cs.DC) ,Mathematics - Optimization and Control - Abstract
Finding optimal parameter configurations for tunable GPU kernels is a non-trivial exercise for large search spaces, even when automated. This poses an optimization task on a non-convex search space, using an expensive to evaluate function with unknown derivative. These characteristics make a good candidate for Bayesian Optimization, which has not been applied to this problem before. However, the application of Bayesian Optimization to this problem is challenging. We demonstrate how to deal with the rough, discrete, constrained search spaces, containing invalid configurations. We introduce a novel contextual variance exploration factor, as well as new acquisition functions with improved scalability, combined with an informed acquisition function selection mechanism. By comparing the performance of our Bayesian Optimization implementation on various test cases to the existing search strategies in Kernel Tuner, as well as other Bayesian Optimization implementations, we demonstrate that our search strategies generalize well and consistently outperform other search strategies by a wide margin., In context of the 2021 International Workshop on Performance Modeling, Benchmarking and Simulation of High Performance Computer Systems (PMBS) at SuperComputing 2021. Pending publication in IEEE Computer Society Technical Consortium on High Performance Computing (TCHPC)
- Published
- 2021