开发者

Permutations with MapReduce

开发者 https://www.devze.com 2023-03-16 17:40 出处:网络
Is there a way开发者_JS百科 to generate permutations with MapReduce? input file: 1title1 2title2 3title3

Is there a way开发者_JS百科 to generate permutations with MapReduce?

input file:

1  title1
2  title2
3  title3

my goal:

1,2  title1,title2
1,3  title1,title3
2,3  title2,title3


Since a file will have n inputs, the permutations should have n^2 outputs. It makes sense that you could have n tasks perform n of those operations. I believe you could do this (assuming only for one file):

Put your input file into the DistributedCache to be accessible as read-only to your Mapper/Reducers. Make an input split on each line of the file (like in WordCount). The mapper will thus recieve one line (e.g. title1 in your example). Then read the lines out of the file in the DistributedCache and emit your key/value pairs: with the key as your input and the values as each line from the file from DistributedCache.

In this model, you should only need a Map step.

Something like:

public static class PermuteMapper
   extends Mapper<Object, Text, Text, Text>{

private static final IN_FILENAME="file.txt";
          
public void map(Object key, Text value, Context context
                ) throws IOException, InterruptedException {

  String inputLine = value.toString();

  // set the property mapred.cache.files in your
  // configuration for the file to be available
  Path[] cachedPaths = DistributedCache.getLocalCacheArchives(conf);
  if ( cachedPaths[0].getName().equals(IN_FILENAME) ) {
     // function defined elsewhere
     String[] cachedLines = getLinesFromPath(cachedPaths[0]);
     for (String line : cachedLines)
       context.emit(inputLine, line);
  }
}
}
0

精彩评论

暂无评论...
验证码 换一张
取 消