Skip to content

JuliaFolds2/FoldsDagger.jl

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FoldsDagger

FoldsDagger.jl is a proof-of-concept package for Transducers.jl-compatible parallel fold (foldx_dagger and transduce_dagger) implemented using Dagger.jl framework. It also provides FLoops.jl executor DaggerEx. The result of fold implemented by FoldsDagger.jl is deterministic and does not depend on a particular run-time scheduling.

Example:

julia> using FoldsDagger, FLoops

julia> @floop DaggerEx() for (i, v) in pairs([0, 1, 3, 2]), (j, w) in pairs([3, 1, 5])
           d = abs(v - w)
           @reduce() do (dmax = -1; d), (imax = 0; i), (jmax = 0; j)
               if isless(dmax, d)
                   dmax = d
                   imax = i
                   jmax = j
               end
           end
       end
       (dmax, imax, jmax)
(5, 1, 3)

About

Folds-based data parallelism using Dagger.jl

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Julia 100.0%