Repository is archived
No commit activity in last 3 years
No release in over 3 years
This is a full implementation of the MapReduce algorithm specifically for use with lambdas. It is useful for problems that are a natural fit for the MapReduce model (such as building cross-references) when the data set fits easily within memory.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies
 Project Readme

lambda_map_reduce gem

A MapReduce implementation for use with lambdas.

Installation

Run gem install lambda_map_reduce on the command line or add gem 'lambda_map_reduce' to your project's Gemfile.

Usage

LambdaMapReduce.map_reduce takes an Enumerable, a mapper lambda, and a reducer lambda.

The mapper lambda is called once for every item in the Enumerable. It should take a single item and return an Array of [key, value] pairs.

The algorithm will shuffle all value items with the same key together, and pass the resulting [key, Array of values] Arrays to the reducer, which should return a single item.

The mapper and reducer may return nil. The result of the algorithm is the Array of items produced from each reducer call.

An example from the team_api gem's CrossReferencer class:

require 'lambda_map_reduce'

module TeamApi
  class CrossReferencer
    def self.create_tag_xrefs(site, items, category, xref_data)
      items_to_tags = lambda do |item|
        item_xref = xref_data.item_to_xref item
        item[category].map { |tag| [tag, item_xref] } unless item[category].nil?
      end
      create_tag_xrefs = lambda do |tag, item_xrefs|
        [tag, tag_xref(site, category, tag, item_xrefs)]
      end
      LambdaMapReduce.map_reduce(items, items_to_tags, create_tag_xrefs).to_h
    end
  end
end

Public domain

This project is in the worldwide public domain. As stated in CONTRIBUTING:

This project is in the public domain within the United States, and copyright and related rights in the work worldwide are waived through the CC0 1.0 Universal public domain dedication.

All contributions to this project will be released under the CC0 dedication. By submitting a pull request, you are agreeing to comply with this waiver of copyright interest.