http://blog.fens.me/hadoop-mapreduce-matrix/
data:image/s3,"s3://crabby-images/38fa8/38fa87133ec50b8600686cc46e1e4fe7993495a3" alt=""
k, v 表示key 和 value。
1,1 A:1 1 表示第一行乘第一列,A矩阵的第一位是1.
data:image/s3,"s3://crabby-images/19f0c/19f0c8852222af5eaf34bd71bfb55fbe16293ddc" alt=""
data:image/s3,"s3://crabby-images/f0e95/f0e956a1eebf61d76a551f90ce3234558bf6b6ad" alt=""
Example:
data:image/s3,"s3://crabby-images/89a8e/89a8e837320dec9446ba4748c79ec16ae21d8719" alt=""
http://hadoopgeek.com/mapreduce-matrix-multiplication/
output matrix[0,0]位置上会用0 row of matrix A * 0 col of Matrix B.
得到的a list of values会再sum up起来。
data:image/s3,"s3://crabby-images/4b7a4/4b7a4557c0c5cbeac1a4bd7c20ca35fa00dd61e2" alt=""
mapper output: <key =(output row, output col), value = 一个乘法的值>
然后要把所有这个位置上的值做一个加法。
A*B = C matrix
C matrix上位置<r, c>的值= A的row<r, >里乘*B的col <, c> dot-product。
但是我们不能直接<r,c>当做key 因为我们有2个mapper for different matrixA, matrix B.
最后加起来。
data:image/s3,"s3://crabby-images/8363d/8363d1c79ffcdfbd9ca647522543d00ca7ebf249" alt=""
data:image/s3,"s3://crabby-images/3d35d/3d35d78b00d7c4327f94c6bc714eee88fa84aa7b" alt=""
网友评论