java 矩阵乘法的mapreduce程序实现

map函数:对于矩阵M中的每个元素m(ij),产生一系列的key-value对<(i,k),(M,j,m(ij))>
其中k=1,2.....知道矩阵N的总列数;对于矩阵N中的每个元素n(jk),产生一系列的key-value对<(i , k) , (N , j ,n(jk)>, 其中i=1,2.......直到i=1,2.......直到矩阵M的总列数。
map
package com.cb.matrix;
import static org.mockito.Matchers.intThat;
import java.io.IOException;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.io.Text;
import org.apache.hadoop.mapred.FileSplit;
import org.apache.hadoop.mapreduce.Mapper;
import com.sun.org.apache.bcel.internal.generic.NEW;
public class MatrixMapper extends Mapper<Object, Text, Text, Text> {
private Text map_key=new Text();
private Text map_value= new Text();
private int columnN;
private int rowM;
/**
* 执行map()函数前先由conf.get()得到main函数中提供的必要变量
* 也就是从输入文件名中得到的矩阵维度信息
*/
@Override
protected void setup(Mapper<Object, Text, Text, Text>.Context context) throws IOException, InterruptedException {
// TODO Auto-generated method stub
Configuration config=context.getConfiguration();
columnN=Integer.parseInt(config.get("columnN"));
rowM =Integer.parseInt(config.get("rowM"));
}
@Override
protected void map(Object key, Text value, Mapper<Object, Text, Text, Text>.Context context)
throws IOException, InterruptedException {
// TODO Auto-generated method stub
//得到文件名,从而区分输入矩阵M和N
FileSplit fileSplit=(FileSplit)context.getInputSplit();
String fileName=fileSplit.getPath().getName();
if (fileName.contains("M")) {
String[] tuple =value.toString().split(",");
int i =Integer.parseInt(tuple[0]);
String[] tuples=tuple[1].split("\t");
int j=Integer.parseInt(tuples[0]);
int Mij=Integer.parseInt(tuples[1]);
for(int k=1;k<columnN+1;k++){
map_key.set(i+","+k);
map_value.set("M"+","+j+","+Mij);
context.write(map_key, map_value);
}
}
else if(fileName.contains("N")){
String[] tuple=value.toString().split(",");
int j=Integer.parseInt(tuple[0]);
String[] tuples =tuple[1].split("\t");
int k=Integer.parseInt(tuples[0]);
int Njk=Integer.parseInt(tuples[1]);
for(int i=1;i<rowM+1;i++){
map_key.set(i+","+k);
map_value.set("N"+","+j+","+Njk);
context.write(map_key, map_value);
}
}
}
}
reduce函数:对于每个键(i,k)相关联的值(M,j,m(ij))及(N,j,n(jk)),根据相同的j值将m(ij)和n(jk)分别存入不同的数组中,然后将俩者的第j个元素抽取出来分别相乘,最后相加,即可得到p(jk)的值。
reducer
package com.cb.matrix;
import java.io.IOException;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.io.Text;
import org.apache.hadoop.mapreduce.Reducer;
public class MatrixReducer extends Reducer<Text, Text, Text, Text> {
private int sum=0;
private int columnM;
@Override
protected void setup(Reducer<Text, Text, Text, Text>.Context context) throws IOException, InterruptedException {
// TODO Auto-generated method stub
Configuration conf =context.getConfiguration();
columnM=Integer.parseInt(conf.get("columnM"));
}
@Override
protected void reduce(Text arg0, Iterable<Text> arg1, Reducer<Text, Text, Text, Text>.Context arg2)
throws IOException, InterruptedException {
// TODO Auto-generated method stub
int[] M=new int[columnM+1];
int[] N=new int[columnM+1];
for(Text val:arg1){
String[] tuple=val.toString().split(",");
if(tuple[0].equals("M")){
M[Integer.parseInt(tuple[1])]=Integer.parseInt(tuple[2]);
}else{
N[Integer.parseInt(tuple[1])]=Integer.parseInt(tuple[2]);
}
for(int j=1;j<columnM+1;j++){
sum+=M[j]*N[j];
}
arg2.write(arg0, new Text(Integer.toString(sum)));
sum=0;
}
}
}
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# java
# 矩阵乘法的mapreduce程序实现
# 矩阵乘法
# mapreduce
# 深入探究如何使用Java编写MapReduce程序
# Java大数据处理的核心技术MapReduce框架
# Java大数据开发Hadoop MapReduce
# java实现MapReduce对文件进行切分的示例代码
# Java基础之MapReduce框架总结与扩展知识点
# Java/Web调用Hadoop进行MapReduce示例代码
# java连接hdfs ha和调用mapreduce jar示例
# Java编写Mapreduce程序过程浅析
# 也就
# 是从
# 希望能
# 相关联
# 谢谢大家
# 组中
# 先由
# mapred
# Text
# FileSplit
# Mapper
# sun
# apache
# IOException
# io
# Configuration
# conf
# hadoop
# bcel
# map_key
相关文章:
建站之星如何助力网站排名飙升?揭秘高效技巧
建站之星安全性能如何?防护体系能否抵御黑客入侵?
建站上传速度慢?如何优化加速网站加载效率?
外贸公司网站制作哪家好,maersk船公司官网?
宝塔面板创建网站无法访问?如何快速排查修复?
代刷网站制作软件,别人代刷火车票靠谱吗?
孙琪峥织梦建站教程如何优化数据库安全?
如何批量查询域名的建站时间记录?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
网站企业制作流程,用什么语言做企业网站比较好?
如何通过建站之星自助学习解决操作问题?
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
清除minerd进程的简单方法
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
如何快速生成专业多端适配建站电话?
如何选择靠谱的建站公司加盟品牌?
制作公司内部网站有哪些,内网如何建网站?
制作宣传网站的软件,小红书可以宣传网站吗?
如何选择服务器才能高效搭建专属网站?
建站之星在线版空间:自助建站+智能模板一键生成方案
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
济南网站建设制作公司,室内设计网站一般都有哪些功能?
高防服务器租用首荐平台,企业级优惠套餐快速部署
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
Python如何创建带属性的XML节点
宝塔面板如何快速创建新站点?
企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?
如何设计高效校园网站?
如何在云主机上快速搭建网站?
宝塔建站后网页无法访问如何解决?
如何通过宝塔面板实现本地网站访问?
建站之星CMS五站合一模板配置与SEO优化指南
已有域名和空间如何快速搭建网站?
如何在Tomcat中配置并部署网站项目?
如何选择域名并搭建高效网站?
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
广德云建站网站建设方案与建站流程优化指南
如何选择适配移动端的WAP自助建站平台?
建站之星后台密码遗忘?如何快速找回?
如何配置支付宝与微信支付功能?
C#如何在一个XML文件中查找并替换文本内容
如何在阿里云域名上完成建站全流程?
高防服务器租用指南:配置选择与快速部署攻略
建站之星价格显示格式升级,你的预算足够吗?
北京的网站制作公司有哪些,哪个视频网站最好?
Swift中循环语句中的转移语句 break 和 continue
建站主机功能解析:服务器选择与快速搭建指南
免费视频制作网站,更新又快又好的免费电影网站?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
*请认真填写需求信息,我们会在24小时内与您取得联系。