Skip to content
This repository has been archived by the owner on May 25, 2021. It is now read-only.

Latest commit

 

History

History
52 lines (37 loc) · 1.29 KB

README.md

File metadata and controls

52 lines (37 loc) · 1.29 KB

worktree

Hierarchical, concurrent MapReduce framework

Create a nested work tree where each node has mapper child functions and a reducer function. All child map functions are executed concurrently in goroutines, and the reducer is called once all the mappers finish.

Inspired by https://github.com/goibibo/lithosphere/blob/master/tree.go

Usage:

type TwoArgs struct {
    X int
    Y int
}

func leaf2(i interface{}) interface{} {
    args := i.(TwoArgs)

    return args.X * args.Y
}

func merge2(results []interface{}) interface{} {
    var sum int
    for _, x := range results {
        sum += x.(int)
    }
    return sum
}

func leaf1(i interface{}) interface{} {
    args := i.(TwoArgs)

    return args.X + args.Y
}

func main() {

    // TWO Level work tree

    l2 := li.CommandTree{}
    l2.AddMapper(leaf2, TwoArgs{2, 3})
    l2.AddMapper(leaf2, TwoArgs{2, 2})
    l2.AddReducer(merge2)

    l1 := li.CommandTree{}
    l1.AddMapper(l2.Run, nil) // When nesting use nil for Run
    l1.AddMapper(leaf2, TwoArgs{2, 2})
    l1.AddReducer(merge2)

    fmt.Println(l1.Run(nil).(int))

}