//矩阵运算的函数
;(function(global){ global.Matrix = {
//生成对角矩阵,非零元素都为1
eye : function( n ){
var result = [];
var arr;
for ( var i = 0; i < n; i++ ) {
arr = []
for ( var j = 0; j < n; j++ ) {
if (i === j )
arr[j] = 1;
else
arr[j] = 0;
}
result.push( arr );
}
return result;
},
//生成全零的矩阵,height:行,width:列
zeros : function( height, width ) {
return this._produceSameNumber( height, width, 0 );
},
ones : function( height, width ) {
return this._produceSameNumber( height, width, 1 );
}, //生成数字全部一样的矩阵,比如说0或者1
_produceSameNumber : function( height, width, number ) {
var result = [];
var arr;
for ( var i = 0; i < height; i++ ) {
arr = (new Array( width )).join( ',' ).split( ',' ).map( function(){
return number;
});
result.push( arr );
}
return result;
}, //定义矩阵相加或是相减
_addOrSub : function( arr1, arr2, operater ) {
var shape1 = this.shape(arr1);
var shape2 = this.shape( arr2);
var result = [], arr;
if ( !_isSameShape( shape1, shape2 ) ) {
throw new Error( '两个数组的维度不同,不能相加')
}else{
for ( var i = 0; i < shape1[0]; i++ ) {
arr = [];
for ( var j = 0; j < shape1[1]; j++ ) {
if ( operater )
arr[j] = _getItem(arr1, i, j) + _getItem( arr2, i, j);
else
arr[j] = _getItem(arr1, i, j) - _getItem( arr2, i, j);
}
result.push( arr );
}
}
return result;
}, add : function( arr1, arr2 ) {
return this._addOrSub( arr1, arr2, true);
}, sub : function( arr1, arr2 ) {
return this._addOrSub( arr1, arr2, false);
},
//字符转矩阵
toMatrix:function(config){
if(Object.prototype.toString.call(config)=="[object String]") {
var list2 = config.split("\n")
list2 = list2.map(function (item) {
var arr = item.split(",")
return arr
})
return list2;
}else{
return config;
}
},
//转字符
toString:function(data){
var arr=[]
data.forEach(function(item){
arr.push(item.join(","))
})
return arr.join("\n")
},
//矩阵的数乘
multip : function( arr, number ) {
var shape1 = this.shape(arr);
var result = [], a; for ( var i = 0; i < shape1[0]; i++ ) {
a = arr[i].map( function( item ) {
return item * number;
});
result.push( a );
} return result;
}, //矩阵之间的相乘
dot : function( arr1, arr2 ) {
var shape1 = this.shape( arr1 );
var shape2 = this.shape( arr2 ); var result = [], arr;
// console.log( shape1, shape2 )
//必须的条件是:第一个矩阵的列数等于第二个矩阵的行数
if ( shape1[1] !== shape2[0] ) {
throw new Error('两个矩阵不满足矩阵相乘的规范,' +
'规范是第一个矩阵的列数等于第二个矩阵的行数,请检查。')
}else{
//先将整个的数组构造出来
for ( var i = 0; i < shape1[0]; i++ ) {
result.push([]);
} //最终的矩阵的行列分别为:shape1[0] shape2[1]
//先从列开始循环比较好
for ( i = 0; i < shape2[1]; i++ ) {
for ( var j = 0; j < shape1[0]; j++ ) {
var row = _getRow( arr1, shape1, j);
var column = _getColumn( arr2, shape2, i );
// console.log( row, column )
result[j][i] = singleMultip( row, column );
}
}
}
return result;
}, //获取矩阵的转置矩阵
transpose : function( arr ) {
var shape = this.shape( arr );
var result, a; //result需要有与原来相反的行和列,行列的数量调换
result = ( new Array( shape[1] ) ).join( ',' ).split( ',' ).map( function(){
return [];
}); //将原来的行转变成现在的列
for ( var i = 0; i < shape[0]; i++ ) {
var row = _getRow( arr, shape, i );
result.forEach( function( item, index ) {
item.push( row[index] );
} )
}
return result;
}, //获取这个矩阵的行和列
shape : function( M ) {
var height,width;
if ( _isArray( M ) && M.length > 0 ) {
if ( _isArray( M[0] ) ){
height = M.length;
width = M[0].length;
}else{
throw new Error( '数组的第一个元素不是数组形式或者' +
'数组长度等于0,请检查' );
}
}else{
throw new Error( M + '不是数组形式或者数组长度等于0,请检查' );
}
return [height, width ];
}
}; function _isArray( arr ) {
if ( Array.isArray ){
return Array.isArray( arr );
}else {
return Object.prototype.toString.call( arr ).toLowerCase() === '[object array]';
}
} function _isSameShape( shape1, shape2 ) {
return shape1[0] === shape2[0] && shape1[1] === shape2[1];
} function _getItem( arr, i, j ) {
var result = _isArray( arr[0] ) ? arr[i][j] : arr[j];
return result;
} //获取数组的某一列的所有值
function _getColumn( arr, shape, j ) {
var result = [];
for (var i = 0; i < shape[0]; i++ ) {
result.push( _getItem( arr, i, j ) );
}
return result;
} //取出数组某一行的所有值
function _getRow( arr, shape, i ) {
//如果数组是二维数组的话,返回某一行的数据,某则返回整个数组
if ( _isArray( arr[0] ) ) {
return __copy(arr[i]);
}else{
return arr;
}
} //一个单行与单列的矩阵相乘
function singleMultip( arr1, arr2 ) {
var result = 0;
for ( var i = 0; i < arr1.length; i++ ) {
result += arr1[i] * arr2[i];
}
return result;
} //深度复制数组
function __copy( arr ) {
return arr.map( function(item){
return item;
})
}
})(global);
module.exports=Matrix; //var b = Matrix.ones( 4,3 );
//console.log(Matrix.toString(b))
//b=Matrix.transpose(b)
//console.log(Matrix.toString(b))

  

一个矩阵 JavaScript的更多相关文章

  1. IT公司100题-35- 求一个矩阵中最大的二维矩阵(元素和最大)

    问题描述: 求一个矩阵中最大的二维矩阵(元素和最大).如: 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 中最大的是: 4 5 9 10   分析: 2*2子数组的最大和.遍历求和,时 ...

  2. artDialog是一个基于javascript编写的对话框组件,它拥有精致的界面与友好的接口

    artDialog是一个基于javascript编写的对话框组件,它拥有精致的界面与友好的接口 自适应内容 artDialog的特殊UI框架能够适应内容变化,甚至连外部程序动态插入的内容它仍然能自适应 ...

  3. 【前端酷站】分享一个纯 Javascript 的图表库与立体像素风制作~

    今天小编为大家推荐一个神奇的酷站.ECharts,一个纯 Javascript 的图表库. 以下是各个几个不错的界面的介绍: 首页:http://echarts.baidu.com/ 在首页有完整的说 ...

  4. Task 4.2 求一个矩阵的最大子矩阵的和

    任务:输入一个二维整形数组,数组里有正数也有负数.二维数组中连续的一个子矩阵组成一个子数组,每个子数组都有一个和.求所有子数组的和的最大值.要求时间复杂度为O(n). (1)设计思想:把二维矩阵分解成 ...

  5. 给定一个矩阵 A, 返回 A 的转置矩阵。

    给定一个矩阵 A, 返回 A 的转置矩阵. 矩阵的转置是指将矩阵的主对角线翻转,交换矩阵的行索引与列索引. 示例 1: 输入:[[1,2,3],[4,5,6],[7,8,9]]输出:[[1,4,7], ...

  6. 剑指offer - 顺时针打印矩阵 - JavaScript

    题目描述 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下 4 X 4 矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 则依次打印 ...

  7. 开博第二篇:记一个利用JavaScript,编写PS脚本,开发图片量产工具

    背景:身在一个有实业的电商公司,设计部的妹子们总是会有做不完的商品图片,当然了,要是做点有技术含量的美化工作也罢,但是最近她们很是无聊,总是要做一些重复性的工作,就比如如题所说的,图片量产,量产什么呢 ...

  8. 一个意想不到的Javascript内存泄漏

    原文:http://point.davidglasser.net/2013/06/27/surprising-javascript-memory-leak.html 本周我在Meter的同事追踪到了一 ...

  9. Code Kata:螺旋矩阵 javascript实现

    1 2 3 4  5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9  如图所示,就是一个5*5的螺旋矩阵 我的思路如下: 第一步:拆分 ...

随机推荐

  1. 编写高质量代码改善C#程序的157个建议——建议28:理解延迟求值和主动求值之间的区别

    建议28:理解延迟求值和主动求值之间的区别 要理解延迟求值(lazy evaluation)和主动求值(eager evaluation),先看个例子: List<, , , , , , , , ...

  2. 日期多选插件Kalendae.js

    在项目中要实现日期多选的功能,于是在网上找到Kalendae.js,此文主要记录本人对于Kalendae.js的一些用法,以便以后查阅,希望对读者也有所帮助 主要内容如下: Kalendaejs一句话 ...

  3. 团队项目第六周-Alpha阶段项目复审(深海划水队)

    经小组讨论后得出以下排名: 队名 优点 缺点 排名 大猪蹄子队 界面优美,功能简洁易懂,单词解释较为完善 互动方式.操作简易性有待优化,有部分功能尚未完成 1 Running Duck队 基本功能已经 ...

  4. Vue 兄弟组件通过事件广播传递数据

    非父子组件传值 通过事件广播实现非父子组件传值1.新建js,引入并实例化Vue import Vue from 'vue' var VueEvent = new Vue(); export defau ...

  5. Hexo基本使用

    1. 简述 Hexo是一个基于Node.js的博客系统,常用于搭建在GitHub上. 其本质其实是一个基于Node.js的内嵌webserver的程序,可以通过一些命令根据markdown生成静态页面 ...

  6. Glib之GObject宏介绍

    G_DEFINE_TYPE定义一个静态类型 /** * G_DEFINE_TYPE(`G_DEFINE_TYPE_WITH_CODE`比`G_DEFINE_TYPE`就是多了一个自定义代码参数_C_) ...

  7. CSR(certSigningRequest文件)导出步骤

    1.打开钥匙串访问 2.请求证书 3.电子邮箱.保存位置 电子邮箱其实是可以乱填的,但是为了规范,还是填注册时用的邮箱吧. 4.保存到桌面 5.结果

  8. UIImageView 动画

    1.UIImageView 动画 1.1 播放图片集 @property (nonatomic, strong) UIImageView *playImageView; self.playImageV ...

  9. kali linux之skipfish,arachni

    c语言编写,实验性的主动web安全评估工具,递归爬网,基于字典的探测,速度较快--(多路单线程,启发式自动内容识别),误报率低 常用参数 -I 只检查包含/xx/的url -X 不检查包含/xx/的u ...

  10. ASPxGridView后台实现隐藏新增按钮

    (ASPxGridView2.Columns[0] as GridViewCommandColumn).NewButton.Visible = false;//0应该代表的是NewButton所在的列 ...