首页 >

JS实现简单的二维矩阵乘积运算【javascript】

web前端|js教程

JS实现简单的二维矩阵乘积运算【javascript】

JS,二维矩阵,乘积运算
web前端-js教程
仿5173源码2012,ubuntu保存串口数据,tomcat8多数据源,皮肤爬虫感疥虫,教务系统管理系统php代码,乐高SEOlzw
Console控制台截图如下:
有赞后台模板源码,vscode 删除所有插件,ubuntu apk编辑,tomcat 进程自启动,eclipse 爬虫,php json封装,衡阳搜狗seo优化排名,常用网站首页代码,html表格模板 套用lzw
(上图为输出结果直接上代码了(A矩阵可以乘以B矩阵的前提是A矩阵的列数等于B矩阵的行数)
网页php客服源码下载,vscode快速添加模板,ubuntu 安装扫雷,tomcat系列介绍,退出sqlite3命令,qq登陆插件,怎么看出前端用的什么框架,爬虫用哪种编译器,php 转2进制,东莞快速seo价格,网站模板安装步骤,手机WAP网页网址导航,外贸 英 模板lzw
      demo            function log(msg) {      console.log(msg);    }    /**    * 可视化的打印出矩阵的数据    */    function printMatrixData(data) {      console.log(data);      if(!data) {        return;      }      var numberSize = 5;      for(var i=0, len=data.length; i<len; i++) {        var row = data[i];        var rowLog = "(";        for(var j=0, jLen=row.length; j<jLen; j++) {          rowLog += row[j];          // 补齐空格          rowLog += indent(numberSize - (row[j]+"").length);        }        rowLog+=")";        console.log(rowLog);      }    }    /**    * 拼接指定长度的空格    */    function indent(length) {      var empty = "";      for(var i=0; i<length; i++) {        empty += " ";      }      return empty;    }    /**    * 矩阵原型    */    function Matrix(data) {      // 这里必须传一个二维数组,最好严格检验一下      if(typeof data !== "object",| typeof data.length === "undefined",| !data) {        throw new Error("data's type is error");      }      this.data = data;      this.cols = data.length;    }    var M = {      findByLocation: function(data, xIndex, yIndex) {        if(data && data[xIndex]) {          return data[xIndex][yIndex];        }      },      // 矩阵乘积      multiply: function(m, n) {        if(!m instanceof Matrix && !n instanceof Matrix) {          throw new Error("data's type is error");        }        var mData = m.data;        var nData = n.data;        if(mData.length == 0,| nData.length == 0) {          return 0;        }        if(mData[0].length != nData.length) {          throw new Error("the two martrix data is not allowed to dot");        }        var result = [];        for(var i=0, len=mData.length; i<len; i++) {          var mRow = mData[i];          result[i] = [];          for(var j=0, jLen=mRow.length; j<jLen; j++) {            var resultRowCol = 0;            // 如果n矩阵没有足够的列数相乘,转入m矩阵下一行            if(typeof this.findByLocation(nData, 0, j) === "undefined") {              break;            }            for(var k=0, kLen=jLen; k<kLen; k++) {              resultRowCol += mRow[k]*this.findByLocation(nData, k, j);            }            result[i][j] = resultRowCol;          }        }        return result;      }    };    var m = new Matrix([[2, -1], [-2, 1], [-1, 2]]);    var n = new Matrix([[4, -3], [3, 5]]);    var result = M.multiply(m, n);    printMatrixData(result);    var m2 = new Matrix([[2, 3, 1], [5, 2, 4], [-3, 2, 0]]);    var n2 = new Matrix([[11], [5], [8]]);    var result2 = M.multiply(m2, n2);    printMatrixData(result2);  
更多关于JavaScript运算相关内容感兴趣的读者可查看本站专题:《JavaScript数学运算用法总结》


  • 暂无相关文章