Keywords
Runtime systems, thread programming, accelerators, hardware abstraction, performance portability.
Course description:
This course will present the state of the art of runtime system support for programming heterogeneous platforms. Heterogeneous computing platforms—such as multicores equipped with accelerators—are notoriously difficult to program due to the strong differences in performance characteristics among the various available computing units and also to the discrete memory spaces of accelerating boards.
The course will present the StarPU runtime system developed at Inria by the STORM Team in Bordeaux.
Learning outcomes
Participants will understand the benefit of the task-based programming model together with performance modeling, automatic data management and dynamic scheduling in speeding up application development on heterogeneous computing platforms and providing long term performance portability.
Prerequisites
Basic knowledge of C programming language and accelerator programming languages (nVidia Cuda, OpenCL).