paranyversion

Parallelize any computation

Generalized map reduce for parallel computers (not distributed computing). Can process in parallel an infinite stream of elements.

Can process a very large file in parallel on a multicore computer; provided there is a way to cut your file into independent blocks (the 'demux' function). The processing function is called 'work'. The function gathering the results is called 'mux'. The number of processors running your computation in parallel is called 'nprocs'. The chunk size (number of items) processed by one call to the 'work' function is called 'csize'.

There is a minimalist Parmap module, if you want to switch to/from Parmap easily.

Read the corresponding ocamldoc before using.

USING THIS LIBRARY IN A MISSION CRITICAL, LONG-RUNNING SOFTWARE THAT IS NEVER SUPPOSED TO CRASH IS NOT ADVIZED. WHILE THIS LIBRARY IS HIGH PERFORMANCE, IT IS ALSO DANGEROUS. USE AT YOUR OWN RISKS.

AuthorFrancois Berenger
LicenseLGPL-2.0-or-later
Published
Homepagehttps://github.com/UnixJunkie/parany
Issue Trackerhttps://github.com/UnixJunkie/parany/issues
Maintainerunixjunkie@sdf.org
Dependencies
Source [http] https://github.com/UnixJunkie/parany/archive/v12.2.0.tar.gz
sha256=9344432b7e055c5e28c125b1f5ac8448371af9694b353da11287bff64fcf3dcc
md5=57d379987aa5b8b8b4bde14dbee5c227
Edithttps://github.com/ocaml/opam-repository/tree/master/packages/parany/parany.12.2.0/opam
Required by