RaftLib[1] is a portable parallel processing system that aims to provide extreme performance while increasing programmer productivity. It enables a programmer to assemble a massively parallel program (both local and distributed) using simple iostream-like operators. RaftLib handles threading, memory allocation, memory placement, and auto-parallelization of compute kernels.[2] It enables applications to be constructed from chains of compute kernels forming a task and pipeline parallel compute graph. Programs are authored in C++ (although other language bindings are planned).

Original author(s)Jonathan Beard
Initial releaselate 2014 (late 2014)
Preview release
0.7a / May 15, 2016 (2016-05-15)
Written inC++
Operating systemLinux, macOS, Windows (planned)
TypeData analytics, HPC, Signal Processing, Machine Learning, Algorithms, Big Data
LicenseApache License 2.0


Here is a Hello World example for demonstration purposes:[3]

#include <raft>
#include <raftio>
#include <cstdlib>
#include <string>

class hi : public raft::kernel
    hi() : raft::kernel()
       output.addPort< std::string >( "0" ); 

    virtual raft::kstatus run()
        output[ "0" ].push( std::string( "Hello World\n" ) );
        return( raft::stop ); 

main( int argc, char **argv )
    /** instantiate print kernel **/
    raft::print< std::string > p;
    /** instantiate hello world kernel **/
    hi hello;
    /** make a map object **/
    raft::map m;
    /** add kernels to map, both hello and p are executed concurrently **/
    m += hello >> p;
    /** execute the map **/
    return( EXIT_SUCCESS );


This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.