Coroutine pipelines provide an attractive structuring mechanism for complex programs that process streams of data, with the advantage over lazy streams that both ends of a pipeline may interact with the I/O system, as may processes in the middle. Two popular Haskell libraries, Pipes and Conduit, support such pipelines. In both libraries, pipelines are implemented in a direct style by combining a free monad of communication events with an interpreter for (pseudo-)parallel composition that interleaves the events of its argument processes. These implementations both suffer from a slow-down when processes are deeply nested in sequence or in parallel. We propose an alternative implementation of pipelines based on continuations that does not suffer from this slow-down. What is more, the implementation is significantly faster on small, communication-intensive examples even where they do not suffer from the slow-down, and faster even than comparable programs based on lazy streams. The continuation-based implementation may be derived from the direct-style implementation by algebraic reasoning.
Mon 4 SepDisplayed time zone: Belfast change
13:00 - 14:30 | Functional Programming TechniquesResearch Papers at L1 Chair(s): Graham Hutton University of Nottingham | ||
13:00 22mTalk | Faster Coroutine Pipelines Research Papers Mike Spivey University of Oxford, UK DOI | ||
13:22 22mTalk | A Pretty But Not Greedy Printer (Functional Pearl) Research Papers Jean-Philippe Bernardy University of Gothenburg DOI | ||
13:45 22mTalk | Generic Functional Parallel Algorithms: Scan and FFT Research Papers Conal Elliott Target, USA DOI | ||
14:07 22mTalk | A Unified Approach to Solving Seven Programming Problems (Functional Pearl) Research Papers William E. Byrd University of Utah, USA, Michael Ballantyne University of Utah, USA, Gregory Rosenblatt n.n., n.n., Matthew Might University of Utah, USA DOI |