Cuneiform (programming language)

From Wikipedia Quality
Jump to: navigation, search

Cuneiform is an open-source workflow language

for large-scale scientific data analysis.

It is a statically typed functional programming language promoting parallel computing. It features a versatile foreign function interface allowing users to integrate software from many external programming languages. At the organizational level Cuneiform provides facilities like conditional branching and general recursion making it Turing-complete. In this, Cuneiform is the attempt to close the gap between scientific workflow systems like Taverna, KNIME, or Galaxy and large-scale data analysis programming models like MapReduce or Pig Latin while offering the generality of a functional programming language.

Cuneiform is implemented in distributed Erlang. If run in distributed mode it drives a POSIX-compliant distributed file system like Gluster or Ceph (or a FUSE integration of some other file system, e.g., HDFS). Alternatively, Cuneiform scripts can be executed on top of HTCondor or Hadoop.Cuneiform is influenced by the work of Peter Kelly who proposes functional programming as a model for scientific workflow execution.

In this, Cuneiform is distinct from related workflow languages based on dataflow programming like Swift or Nextflow.