-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathabstract.txt
9 lines (5 loc) · 3.47 KB
/
abstract.txt
1
2
3
4
5
6
7
8
9
The physical limitations of microprocessor design have forced the industry towards increasingly heterogeneous designs to extract performance, with an an increasing pressure to offload traditionally CPU based workloads to the GPU. This trend has not been matched with adequate software tools; the popular languages OpenCL and CUDA provide a very low level model with little abstraction above the hardware. Programming at this level requires expert knowledge of both the domain and the target hardware, and achieving performance requires laborious hand tuning of each program. This has led to a growing disparity between the availability of parallelism in modern hardware, and the ability for application developers to exploit it.
The goal of this work is to bring the performance of hand tuned heterogeneous code to high level programming, by incorporating autotuning into Algorithmic Skeletons. Algorithmic Skeletons simplify parallel programming by providing reusable, high-level, patterns of computation. However, achieving performant skeleton implementations is a difficult task; skeleton authors must attempt to anticipate and tune for a wide range of architectures and use cases. This results in implementations that target the general case and cannot provide the performance advantages that are gained from tuning low level optimization parameters for individual programs and architectures. Autotuning offers promising performance benefits by tailoring parameter values to individual cases, but the high cost of searching the optimization space limits the practicality of autotuning for real world programming. We believe that performing machine learning-based autotuning at the skeletal level of the can overcome these issues.
In this work, we present OmniTune - an extensible and distributed framework for autotuning optimization parameters in algorithmic skeletons at runtime. OmniTune enables a collaborative approach to performance tuning, in which machine learning training data is shared across a network of cooperating systems, amortizing the cost of exploring the optimization space. We demonstrate the practicality of OmniTune by autotuning the OpenCL workgroup size of stencil skeletons in SkelCL. SkelCL is an Algorithmic Skeleton framework which abstracts the complexities of OpenCL programming, exposing a set of data parallel skeletons for high level heterogeneous programming in C++. Selecting an appropriate OpenCL workgroup size is critical for the performance of programs, and requires knowledge of the underlying hardware (Figure 1), the data being operated on, and the program implementation (Figure 2).
Our autotuning approach employs the novel application of linear regressors for classification of workgroup size, extracting 102 features at runtime describing the program, device, and dataset, and predicting optimal workgroup sizes based on training data collected using synthetically generated stencil benchmarks.
In an empirical study of 429 combinations of programs, architectures, and datasets, we find that OmniTune provides a median 3.79x speedup over the best possible fixed workgroup size, achieving 94% of the maximum performance. Our results demonstrate that autotuning at the skeletal level - when combined with sophisticated machine learning techniques - can raise the performance above that of human experts, without requiring any effort from the user. By introducing OmniTune and demonstrating its practical utility, we hope to contribute toward increasing the programmability of heterogeneous systems.