@inproceedings{1f018a133fa645bca9ec1b00591fc2b8,
title = "Parcae: A system for flexible parallel execution",
abstract = "Workload, platform, and available resources constitute a parallel program's execution environment. Most parallelization efforts statically target an anticipated range of environments, but performance generally degrades outside that range. Existing approaches address this problem with dynamic tuning but do not optimize a multiprogrammed system holistically. Further, they either require manual programming effort or are limited to array-based data-parallel programs. This paper presents Parcae, a generally applicable automatic system for platform-wide dynamic tuning. Parcae includes (i) the Nona compiler, which creates flexible parallel programs whose tasks can be efficiently reconfigured during execution; (ii) the Decima monitor, which measures resource availability and system performance to detect change in the environment; and (iii) the Morta executor, which cuts short the life of executing tasks, replacing them with other functionally equivalent tasks better suited to the current environment. Parallel programs made flexible by Parcae outperform original parallel implementations in many interesting scenarios.",
keywords = "Adaptivity, Automatic parallelization, Code generation, Compiler, Flexible, Multicore, Parallel, Performance portability, Run-time, Tuning",
author = "Arun Raman and Ayal Zaks and Lee, {Jae W.} and August, {David I.}",
year = "2012",
doi = "10.1145/2254064.2254082",
language = "English (US)",
isbn = "9781450312059",
series = "Proceedings of the ACM SIGPLAN Conference on Programming Language Design and Implementation (PLDI)",
pages = "133--144",
booktitle = "PLDI'12 - Proceedings of the 2012 ACM SIGPLAN Conference on Programming Language Design and Implementation",
note = "33rd ACM SIGPLAN Conference on Programming Language Design and Implementation, PLDI'12 ; Conference date: 11-06-2012 Through 16-06-2012",
}