一: 矩阵的加法与减法

规则:矩阵的加法与减法要求两个矩阵的行列完全相等,方可以完成两个矩阵的之间的运算。

举例说明如下

二:矩阵的乘法

规则:矩阵的乘法要求两个矩阵符合A(mx k),  B( k x n)即矩阵A的列数与矩阵B的行数相等,否

则无法完成矩阵运算。举例说明如下:

Java代码如下:

[java] view plaincopy

 
  1. package pet.shop;
  2. public class BasicMatrixMath {
  3. public final static int OPERATION_ADD = 1;
  4. public final static int OPERATION_SUB = 2;
  5. public final static int OPERATION_MUL = 4;
  6. /**
  7. * To be able to add two matrices, they must be of the same size
  8. * @param matrixa
  9. * @param matrixb
  10. */
  11. public int[][] add(int[][] matrixa, int[][] matrixb) {
  12. if(legalOperation(matrixa, matrixb, OPERATION_ADD)) {
  13. for(int i=0; i<matrixa.length; i++) {
  14. for(int j=0; j<matrixa[0].length; j++) {
  15. matrixa[i][j] = matrixa[i][j] + matrixb[i][j];
  16. }
  17. }
  18. }
  19. return matrixa;
  20. }
  21. /**
  22. * To be able to substract two matrices, they must be of the same size
  23. *
  24. * @param matrixa
  25. * @param matrixb
  26. */
  27. public int[][] substract(int[][] matrixa, int[][] matrixb) {
  28. if(legalOperation(matrixa, matrixb, OPERATION_SUB)) {
  29. for(int i=0; i<matrixa.length; i++) {
  30. for(int j=0; j<matrixa[0].length; j++) {
  31. matrixa[i][j] = matrixa[i][j] - matrixb[i][j];
  32. }
  33. }
  34. }
  35. return matrixa;
  36. }
  37. /**
  38. *
  39. * @param matrixa
  40. * @param matrixb
  41. */
  42. public int[][] multiplication(int[][] matrixa, int[][] matrixb) {
  43. if(legalOperation(matrixa, matrixb, OPERATION_SUB)) {
  44. int[][] result = new int[matrixa.length][matrixb[0].length];
  45. for(int i=0; i<matrixa.length; i++) {
  46. for(int j=0; j<matrixb[0].length; j++) {
  47. // i will complete this tomorrow @2012/09/17
  48. result[i][j] = calculateSingleResult(matrixa, matrixb, i, j);
  49. }
  50. }
  51. return result;
  52. }
  53. else
  54. {
  55. return null;
  56. }
  57. }
  58. private int calculateSingleResult(int[][] matrixa, int[][] matrixb, int row, int col) {
  59. int result = 0;
  60. for(int k=0; k<matrixa[0].length; k++) {
  61. result += matrixa[row][k] * matrixb[k][col];
  62. }
  63. return result;
  64. }
  65. /**
  66. *
  67. * @param matrixa
  68. * @param b
  69. */
  70. public int[][] multiplication(int[][] matrixa, int b) {
  71. for(int i=0; i<matrixa.length; i++) {
  72. for(int j=0; j<matrixa[0].length; j++) {
  73. matrixa[i][j] = matrixa[i][j] * b;
  74. }
  75. }
  76. return matrixa;
  77. }
  78. /**
  79. * validate whether the parameters is valid parameters.
  80. *
  81. * @param a
  82. * @param b
  83. * @param type
  84. * @return
  85. */
  86. private boolean legalOperation(int[][] a, int[][] b, int type) {
  87. boolean legal = true;
  88. if(type == OPERATION_ADD || type == OPERATION_SUB)
  89. {
  90. if(a.length != b.length || a[0].length != b[0].length) {
  91. legal = false;
  92. }
  93. }
  94. else if(type == OPERATION_MUL)
  95. {
  96. if(a[0].length != b.length) {
  97. legal = false;
  98. }
  99. }
  100. return legal;
  101. }
  102. /**
  103. *  test code here !!!!
  104. * @param args
  105. */
  106. public static void main(String[] args) {
  107. int[][] a = new int[][]{{1,2},{3,4}};
  108. int[][] b = new int[][]{{7, 8}, {6, 5}};
  109. BasicMatrixMath bmm = new BasicMatrixMath();
  110. System.out.println("addition two matrix");
  111. int[][] result = bmm.add(a, b);
  112. for(int i=0; i<result.length; i++) {
  113. for(int j=0; j<result[0].length; j++) {
  114. System.out.print("\t" + result[i][j]);
  115. }
  116. System.out.println();
  117. }
  118. System.out.println("substract two matrix");
  119. result = bmm.substract(a, b);
  120. for(int i=0; i<result.length; i++) {
  121. for(int j=0; j<result[0].length; j++) {
  122. System.out.print("\t" + result[i][j]);
  123. }
  124. System.out.println();
  125. }
  126. System.out.println("multiplex one matrix");
  127. result = bmm.multiplication(a, 3);
  128. for(int i=0; i<result.length; i++) {
  129. for(int j=0; j<result[0].length; j++) {
  130. System.out.print("\t" + result[i][j]);
  131. }
  132. System.out.println();
  133. }
  134. System.out.println("multiplex two matrix");
  135. result = bmm.multiplication(a, b);
  136. for(int i=0; i<result.length; i++) {
  137. for(int j=0; j<result[0].length; j++) {
  138. System.out.print("\t" + result[i][j]);
  139. }
  140. System.out.println();
  141. }
  142. }
  143. }

基本矩阵运算的Java实现的更多相关文章

  1. Java第三方工具库/包汇总

    一.科学计算或矩阵运算库 科学计算包: JMathLib是一个用于计算复杂数学表达式并能够图形化显示计算结果的Java开源类库.它是Matlab.Octave.FreeMat.Scilab的一个克隆, ...

  2. Spark案例分析

    一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...

  3. Java调用jama实现矩阵运算

    Java调用jama实现矩阵运算 一.jama简介 Jama是一个基本的线性代数java包.包括一个基本的Matrix类和5个矩阵分解类. Matrix类提供了基本的线性代数数值运算的功能,不同的构造 ...

  4. Java读取mat文件

    概述 使用ujmp中的jmatio模块读取.mat文件到java程序中. 其实,ujmp主要是在模块core中实现了矩阵运算,其余模块都是复用了已有的开源库.模块jmatio是复用了已有的JMatIo ...

  5. JAMA:Java矩阵包

    原文链接:JAMA:Java矩阵包 API文档链接:线性代数Java包 JAMA jama是一个非常好用的java的线性代数软件包.适用于日常编程可能碰到的各种矩阵运算问题,提供了一个优雅的简便的解决 ...

  6. 用java写bp神经网络(一)

    根据前篇博文<神经网络之后向传播算法>,现在用java实现一个bp神经网络.矩阵运算采用jblas库,然后逐渐增加功能,支持并行计算,然后支持输入向量调整,最后支持L-BFGS学习算法. ...

  7. 158个JAVA免豆精品资料汇总

    附件完整版下载地址: http://down.51cto.com/data/431561 附件部分预览~ java中国移动收费系统[源代码] http://down.51cto.com/data/70 ...

  8. 【转】【JAVA资料免费下载】158个JAVA免豆精品资料汇总——下载目录

    附件完整版下载地址: http://down.51cto.com/data/431561 附件部分预览~ java中国移动收费系统[源代码] http://down.51cto.com/data/70 ...

  9. JavaSE基础之矩阵运算

    JavaSE基础之矩阵运算 1.矩阵类:Matrix.java 包括矩阵的加.乘运算,行列式的求解,最大最小元素等 package cn.com.zfc.help; import java.text. ...

随机推荐

  1. JS中判断 !="" 或者 !=null 失效

    var id; //... if (!id&& typeof (id) != "undefined" && id!= 0) { //id为null ...

  2. Java分别与MySQL、Oracle、SQL Server数据库建立连接

    1.与MySQL连接 jar包下载地址: Class.forName("com.mysql.jdbc.Driver");//加载数据库驱动(MySQL的jar包) String u ...

  3. mybatis+oracle添加一条数据并返回所添加数据的主键问题

    最近做mybatis+oracle项目的时候解决添加一条数据并返回所添加数据的主键问题 controller层 @RequestMapping("/addplan") public ...

  4. contiki-process_run()

    process_run()函数位于main函数中 ) { do { } ); idle_count++; } 找到函数的声明处: /** * Run the system once - call po ...

  5. SSIS学习笔记

    SSIS全称(Sql Server Integration Services),是 Microsoft BI 解决方案的一大利器.除了作为ETL的一种工具,在以下方面还有着突出的表现: (1) 系统维 ...

  6. <js>实现回车键登陆方法,并处理谷歌与火狐不兼容的问题

    1.在body中添加onkeydown事件 <body onkeydown="keyLogin(event);">2.使用js相应登陆添加方法//添加回车登陆事件 fu ...

  7. js刷新框架子页面的七种方法代码

    面以三个页面分别命名为framedemo.html,top.html,button.html为例来具体说明如何做.其中framedemo.html由上下两个页面组成,代码如下: <!DOCTYP ...

  8. python——django的post请求

    两次被同一块石头绊倒简直不可原谅!第一次写django程序的时候,就因为ajax post请求折腾了整整一天,时隔两个多月昨天又被虐一整晚.叔可忍婶儿也不能忍了!!!重要的事情写下来,为以后轻松碾压p ...

  9. selenium遇到readonly元素的输入

    方法:去掉该元素的readonly属性 使用js来去掉 ((JavaScriptExecutor ) driver).executeScript($("input#{放置元素的CLASS}[ ...

  10. Elasticsearch 检索

    说到查询,那么索引也是一个绕不开的话题,可以说,没有索引就没有检索,先来看一个示意图 左边是索引过程,右边是检索过程.关键的步骤是分词过程,我用等号表示这两个过程一样,而且,必须一样,这个等号并不是模 ...