全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

java 矩阵乘法的mapreduce程序实现

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小时内与您取得联系。