Guerric Chupin
Functional Reactive Programming, restated
Chupin, Guerric; Nilsson, Henrik
Authors
Henrik Nilsson
Abstract
Functional Reactive Programming is an approach to declarative programming of reactive systems by describing interactions between time-varying values. FRP implementations are often realised as an embedding in a functional host language, making for very expressive reactive programming frameworks. However, this expressiveness comes at a cost: current embedded FRP implementations incur substantial performance overheads, in particular for values that (notionally) vary continuously. The basic idea of FRP is closely related to synchronous data-flow and continuous system simulation languages. In contrast to FRP, these handle values that vary continuously efficiently, but are less expressive. This paper seeks to bridge this gap by proposing a novel approach to embedded FRP-implementation that uses the fundamental implementation approach of synchronous datalow and simulation languages for efficient handling of continuously varying values, while retaining the expressiveness normally associated with FRP, as well as paying attention to values that only change relatively infrequently. These ideas are applicable beyond FRP, for example for implementing flexible embedded simulation languages. We evaluate our approach on a range of benchmarks, including an existing full-fledged video game where using our new FRP implementation as a drop-in replacement for the old one gave a three-fold performance improvement.
Citation
Chupin, G., & Nilsson, H. (2019). Functional Reactive Programming, restated. In PPDP '19: Proceedings of the 21st International Symposium on Principles and Practice of Programming Languages 2019. https://doi.org/10.1145/3354166.3354172
Conference Name | PPDP '19: Principles and Practice of Programming Languages 2019 |
---|---|
Start Date | Oct 7, 2019 |
End Date | Oct 9, 2019 |
Acceptance Date | Jun 20, 2019 |
Online Publication Date | Oct 7, 2019 |
Publication Date | Oct 7, 2019 |
Deposit Date | Sep 4, 2020 |
Publicly Available Date | Sep 24, 2020 |
Publisher | Association for Computing Machinery (ACM) |
Book Title | PPDP '19: Proceedings of the 21st International Symposium on Principles and Practice of Programming Languages 2019 |
ISBN | 9781450372497 |
DOI | https://doi.org/10.1145/3354166.3354172 |
Public URL | https://nottingham-repository.worktribe.com/output/4882090 |
Publisher URL | https://dl.acm.org/doi/10.1145/3354166.3354172 |
Files
ppdp2019
(818 Kb)
PDF
You might also like
Getting more out of Stan: some ideas from the Haskell bindings
(2018)
Conference Proceeding
Runtime verification and validation of functional reactive systems
(2020)
Journal Article
Conceptual modelling: Towards detecting modelling errors in engineering applications
(2019)
Journal Article
A principled approach to the implementation of argumentation models
(2014)
Journal Article