rhine: Functional Reactive Programming with type-level clocks

[ bsd3, frp, library ] [ Propose Tags ]

Rhine is a library for synchronous and asynchronous Functional Reactive Programming (FRP). It separates the aspects of clocking, scheduling and resampling from each other, and ensures clock-safety on the type level. Signal processing units can be annotated by clocks, which hold the information when data will be input, processed and output. Different components of the signal network will become active at different times, or work at different rates. To schedule the components and allow them to communicate, several standard scheduling and resampling solutions are implemented. Own schedules and resampling buffers can be implemented in a reusable fashion. A (synchronous) program outputting "Hello World!" every tenth of a second looks like this: flow $ arrMSync_ (putStrLn "Hello World!") (waitClock :: Millisecond 100)

[Skip to Readme]
Versions [faq],,,,,,,,,,,,, 0.6.0, 0.7.0
Dependencies base (>=4.9 && <5), containers (==0.5.*), dunai (==0.4.0.*), free (==5.0.*), rhine, time (==1.8.*), transformers (>=0.4 && <0.6) [details]
License BSD-3-Clause
Author Manuel Bärenz
Maintainer maths@manuelbaerenz.de
Category FRP
Source repo head: git clone git@github.com:turion/rhine.git
this: git clone git@github.com:turion/rhine.git(tag v0.4.0.1)
Uploaded by turion at 2018-06-25T15:17:59Z
Distributions NixOS:0.7.0, Stackage:
Executables Demonstration, HelloWorld
Downloads 6367 total (12 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Hackage Matrix CI
Docs available [build log]
Last success reported on 2018-06-25 [all 1 reports]




Maintainer's Corner

For package maintainers and hackage trustees

Readme for rhine-

[back to package description]

This is the main library.