Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/facaiy/dag-lite
An experimental DAG library with functional programming technology.
https://github.com/facaiy/dag-lite
dag functional-programming scala-library
Last synced: 3 days ago
JSON representation
An experimental DAG library with functional programming technology.
- Host: GitHub
- URL: https://github.com/facaiy/dag-lite
- Owner: facaiy
- License: mit
- Created: 2017-05-10T07:17:52.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2017-06-24T01:48:07.000Z (over 7 years ago)
- Last Synced: 2023-07-04T02:14:19.789Z (over 1 year ago)
- Topics: dag, functional-programming, scala-library
- Language: Scala
- Size: 37.1 KB
- Stars: 4
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# DAG-lite
[](https://travis-ci.org/facaiy/DAG-lite)
[](http://search.maven.org/#search|ga|1|g:"io.github.facaiy"%20AND%20a:"DAG-lite")An experimental DAG library with functional programming technology.
features:
+ lazy evaluation.
+ concurrent computing.### Install
1. maven
```
io.github.facaiy
DAG-lite
0.2.0
```2. sbt:
The configuration should be right, while it need to be verified.
```
"io.github.facaiy" %% "DAG-lite" % "0.2.0"
```Note: the 0.2.x release is only tested on scala 2.11.8 *with JDK 8* on Linux and Mac.
### Usage
1. A simple example:
```scala
def read[A](): A
def process1[A](a: A): A
def process2[A](as: Seq[A]): A
def write1[A](a: A): Unit
def write2[A](as: Seq[A]): Unit// create nodes
import io.github.facaiy.dag.core._// InputNode(uid, function)
val inputNode1 = InputNode("input1", read)
val inputNode2 = InputNode("input2", read)
// ProcessNode(uid, dependencyUids, function)
val internalNode1 = ProcessNode("process1", "input1", process1)
val internalNode2 = ProcessNode("process2", Seq("input1", "input2"), process2)
// OutputNode(uid, dependencyUids, function)
val outputNode1 = OutputNode("output1", "process1", write1)
val outputNode2 = OutputNode("output2", Seq("process1", "process2"), write2)val nodes = Seq(inputNode, internalNode1, internalNode2, outputNode1, outputNode2)
// build network
import io.github.facaiy.dag.serial.Implicits._val lm = nodes.toLazyNetwork
/**
* input1 ---> process1 ---> output1
* | |
* v v
* input2 ---> process2 ---> output2
*/// run if needed
lm("output1").getValue
lm("output2").getValue
```2. Experimental: to run nodes in parallel.
```scala
// build network
import io.github.facaiy.dag.parallel.Implicits._val pm = nodes.toLazyNetwork
/**
* input1 ---> process1 ---> output1
* | |
* v v
* input2 ---> process2 ---> output2
*/// run if needed
pm("output1").getValue // wait forever.import scala.concurrent.duration._
pm("output2").getValue(10 seconds) // wait 10 seconds.
```