@inproceedings{0e40b74f1bb0453c898e65903716bce3,
title = "Repeating history: Execution replay for parallel Haskell programs",
abstract = "Parallel profiling tools, such as ThreadScope for Parallel Haskell, allow programmers to obtain information about the performance of their parallel programs. However, the information they provide is not always sufficiently detailed to precisely pinpoint the cause of some performance problems. Often, this is because the cost of obtaining that information would be prohibitive for a complete program execution. In this paper, we adapt the well-known technique of execution replay to make it possible to simulate a previous run of a program. We ensure that the non-deterministic parallel behaviour of the Parallel Haskell application is properly emulated while its deterministic functionality is unmodified. In this way, we can gather additional data about the behaviour of a parallel program by replaying some parts of it with more detailed profiling information. We exploit this ability to identify performance bottlenecks in a quicksort implementation, and to derive a version that achieves an 82% speedup over a naive parallelisation.",
keywords = "Parallel Program, Garbage Collection, Program Execution, Thread Block, Runtime System",
author = "Henrique Ferreiro and Vladimir Janjic and Castro, {Laura M.} and Kevin Hammond",
year = "2013",
month = sep,
day = "3",
doi = "10.1007/978-3-642-40447-4_15",
language = "English",
isbn = "9783642404467",
series = "Lecture Notes in Computer Science",
publisher = "Springer ",
pages = "231--246",
editor = "Hans-Wolfgang Loidl and Ricardo Pe{\~n}a",
booktitle = "Trends in Functional Programming - 13th International Symposium, TFP 2012, Revised Selected Papers",
note = "13th Symposium on Trends in Functional Programming, TFP 2012 ; Conference date: 12-06-2012 Through 12-06-2012",
}