generalized Algebraic Dynamic Programming Homepage
Ideas implemented here are described in a couple of papers:
- Christian Hoener zu Siederdissen
Sneaking Around ConcatMap: Efficient Combinators for Dynamic Programming
2012, Proceedings of the 17th ACM SIGPLAN international conference on Functional programming
paper preprint - Andrew Farmer, Christian Höner zu Siederdissen, and Andy Gill.
The HERMIT in the stream: fusing stream fusion’s concatMap
2014, Proceedings of the ACM SIGPLAN 2014 workshop on Partial evaluation and program manipulation.
paper - Christian Höner zu Siederdissen, Ivo L. Hofacker, and Peter F. Stadler.
Product Grammars for Alignment and Folding
2014, IEEE/ACM Transactions on Computational Biology and Bioinformatics. 99
paper - Christian Höner zu Siederdissen, Sonja J. Prohaska, and Peter F. Stadler
Algebraic Dynamic Programming over General Data Structures
2015, BMC Bioinformatics
preprint - Maik Riechert, Christian Höner zu Siederdissen, and Peter F. Stadler
Algebraic dynamic programming for multiple context-free languages
2016, Theoretical Computer Science
preprint
ADPfusion combines stream-fusion (using the stream interface provided by the vector library) and type-level programming to provide highly efficient dynamic programming combinators.
From the programmers' viewpoint, ADPfusion behaves very much like the original ADP implementation http://bibiserv.techfak.uni-bielefeld.de/adp/ developed by Robert Giegerich and colleagues, though both combinator semantics and backtracking are different.
The library internals, however, are designed not only to speed up ADP by a large margin (which this library does), but also to provide further runtime improvements by allowing the programmer to switch over to other kinds of data structures with better time and space behaviour. Most importantly, dynamic programming tables can be strict, removing indirections present in lazy, boxed tables.
As an example, even rather complex ADP code tends to be completely optimized to loops that use only unboxed variables (Int# and others, indexIntArray# and others).
Completely novel (compared to ADP), is the idea of allowing efficient monadic combinators. This facilitates writing code that performs backtracking, or samples structures stochastically, among others things.
ADPfusion is "mostly" a library, with some examples. It is suggested to use nix (flakes).
nix develop
will drop you into a development shell, where all dependencies are available.- The small
ghcicabal
andbuildcabal
programs are available within the dev-shell. ghcicabal
provides an interactive shell, which makes more dependencies available.buildcabal src/NeedlemanWunsch.hs
(for example) builds the NeedlemanWunsch example using globally (via Nix) available libraries, ignoring local cabal builds.
- The small
- One example program is immediately available:
nix run .#NW
provides a simple "Needleman-Wunsch" style alignment algorithm. Use it as such:where the numberszcat runtimes/0100.input.gz | head -n 2 | time nix run .#NW -- 1 -1
1 -1
call for a single backtrace in the Forward mode, and no calculation in the backward mode (here these modes are only used for showing consistency, in more serious programs, we calculate posterior probabilities with their combined outputs). For comparison, aC
program is available as well:It does not provide a backward mode or backtracing, since we are mostly interested in running time performance comparisons.zcat runtimes/0100.input.gz | head -n 2 | time nix run .#C
- Otherwise, examples can be enabled using cabal via
-fexamples
These have been moved to HACKING.md.
Christian Hoener zu Siederdissen
Friedrich-Schiller-Universitaet Jena, Germany
[email protected]
https://choener.github.io/