From 0be80aeddbc76aace6c5061b3f2b9f2b5c38bb44 Mon Sep 17 00:00:00 2001 From: Len Dierickx Date: Wed, 29 May 2019 20:43:47 +0200 Subject: [PATCH] Update docs and paths --- README.md | 2 +- docs.json | 1314 ++++++++++++++++---------------- docs/Matrix.html | 353 +++++---- docs/global.html | 4 +- docs/index.html | 6 +- docs/matrix.js.html | 180 ++--- docs/util_concat.js.html | 4 +- docs/util_dot.js.html | 4 +- docs/util_generate.js.html | 4 +- docs/util_identity.js.html | 4 +- docs/util_round.js.html | 4 +- docs/util_transpose.js.html | 4 +- lib/@astuanax/funmatrix.js | 176 ++--- lib/@astuanax/funmatrix.min.js | 4 +- package.json | 2 +- src/matrix.js | 176 ++--- 16 files changed, 1175 insertions(+), 1066 deletions(-) diff --git a/README.md b/README.md index d8dee68..7f414b8 100755 --- a/README.md +++ b/README.md @@ -9,7 +9,7 @@ The documentation is done using jsdocs and can be found in the /docs folder or a ## Install funmatrix.js -```$ npm install @astuanax/funmatrix.js --save``` +```$ npm install @astuanax/funmatrix --save``` ## Example diff --git a/docs.json b/docs.json index 2d00334..bc9afe2 100644 --- a/docs.json +++ b/docs.json @@ -3,7 +3,7 @@ "comment": "/**\n * @class Matrix\n * @classdesc Matrix applicative providing standard matrix operations\n * @summary The Matrix class should not be instantiated with the new keyword. Instead use the Matrix.of syntax to create a new Matrix. Unfortunatly jsdocs does not allow for the constructor to be hidden.\n * @hidecontructor\n * @see of\n * @example\n *\n * const m = Matrix.of([[1,2],[2,3],[4,5]])\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 12, + "lineno": 15, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -32,11 +32,11 @@ "comment": "", "meta": { "range": [ - 745, - 793 + 875, + 923 ], "filename": "matrix.js", - "lineno": 23, + "lineno": 26, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -59,11 +59,11 @@ "comment": "", "meta": { "range": [ - 773, - 791 + 903, + 921 ], "filename": "matrix.js", - "lineno": 24, + "lineno": 27, "columnno": 2, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -81,18 +81,114 @@ "scope": "global" }, { - "comment": "/**\n * @memberOf Matrix\n * @property {string} type\n * @type {string}\n * @example\n *\n * const m = Matrix.of([[1,2],[2,3],[4,5]])\n * m.type === 'Matrix'\n */", + "comment": "/**\n * @memberOf Matrix\n * @static\n * @function Matrix.of\n * @desc Creates a Matrix object and flattens the Matrix\n * @param val {array|function} An array of arrays\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.of([[1,2],[2,3],[4,5]])\n *\n */", + "meta": { + "filename": "matrix.js", + "lineno": 30, + "columnno": 0, + "path": "/Volumes/BigOne/github/funMatrix/src", + "code": {} + }, + "memberof": "Matrix", + "scope": "static", + "kind": "function", + "name": "of", + "description": "Creates a Matrix object and flattens the Matrix", + "params": [ + { + "type": { + "names": [ + "array", + "function" + ] + }, + "description": "An array of arrays", + "name": "val" + } + ], + "returns": [ + { + "type": { + "names": [ + "Matrix" + ] + } + } + ], + "examples": [ + "const m = Matrix.of([[1,2],[2,3],[4,5]])" + ], + "longname": "Matrix.of" + }, + { + "comment": "", "meta": { "range": [ - 951, - 983 + 1178, + 1348 ], "filename": "matrix.js", - "lineno": 36, + "lineno": 42, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { "id": "astnode100000055", + "name": "Matrix.of", + "type": "FunctionExpression", + "paramnames": [ + "val" + ] + }, + "vars": { + "this.__value": "Matrix.of#__value" + } + }, + "undocumented": true, + "name": "of", + "longname": "Matrix.of", + "kind": "function", + "memberof": "Matrix", + "scope": "static" + }, + { + "comment": "", + "meta": { + "range": [ + 1283, + 1301 + ], + "filename": "matrix.js", + "lineno": 45, + "columnno": 4, + "path": "/Volumes/BigOne/github/funMatrix/src", + "code": { + "id": "astnode100000074", + "name": "this.__value", + "type": "Identifier", + "value": "val", + "paramnames": [] + } + }, + "undocumented": true, + "name": "__value", + "longname": "Matrix.of#__value", + "kind": "member", + "memberof": "Matrix.of", + "scope": "instance" + }, + { + "comment": "/**\n * @memberOf Matrix\n * @property {string} type\n * @type {string}\n * @example\n *\n * const m = Matrix.of([[1,2],[2,3],[4,5]])\n * m.type === 'Matrix'\n */", + "meta": { + "range": [ + 1506, + 1538 + ], + "filename": "matrix.js", + "lineno": 60, + "columnno": 0, + "path": "/Volumes/BigOne/github/funMatrix/src", + "code": { + "id": "astnode100000086", "name": "Matrix.prototype.type", "type": "Literal", "value": "Matrix", @@ -127,15 +223,15 @@ "comment": "/**\n * @memberOf Matrix\n * @property {number} precision\n * @type {number}\n * @example\n *\n * const m = Matrix.of([[1,2],[2,3],[4,5]])\n * m.precision === 4\n */", "meta": { "range": [ - 1144, - 1174 + 1699, + 1729 ], "filename": "matrix.js", - "lineno": 47, + "lineno": 71, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000063", + "id": "astnode100000094", "name": "Matrix.prototype.precision", "type": "Literal", "value": 4, @@ -167,10 +263,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member setPrecision\n * @param precision {number} Set the number of decimals for rounding\n * @example\n *\n * const m = Matrix.of([[1,2],[2,3],[4,5]])\n * m.setPrecision(10)\n * m.precision === 10\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#setPrecision\n * @param precision {number} Set the number of decimals for rounding\n * @example\n *\n * const m = Matrix.of([[1,2],[2,3],[4,5]])\n * m.setPrecision(10)\n * m.precision === 10\n */", "meta": { "filename": "matrix.js", - "lineno": 49, + "lineno": 73, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -199,15 +295,15 @@ "comment": "", "meta": { "range": [ - 1414, - 1499 + 1976, + 2061 ], "filename": "matrix.js", - "lineno": 60, + "lineno": 84, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000071", + "id": "astnode100000102", "name": "Matrix.prototype.setPrecision", "type": "FunctionExpression", "paramnames": [ @@ -229,15 +325,15 @@ "comment": "", "meta": { "range": [ - 1471, - 1497 + 2033, + 2059 ], "filename": "matrix.js", - "lineno": 61, + "lineno": 85, "columnno": 2, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000081", + "id": "astnode100000112", "name": "this.precision", "type": "Identifier", "value": "precision", @@ -255,7 +351,7 @@ "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member isSymmetric\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSymmetric()\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 64, + "lineno": 88, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -282,15 +378,15 @@ "comment": "", "meta": { "range": [ - 1674, - 1810 + 2236, + 2372 ], "filename": "matrix.js", - "lineno": 75, + "lineno": 99, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000087", + "id": "astnode100000118", "name": "Matrix.prototype.isSymmetric", "type": "FunctionExpression", "paramnames": [] @@ -311,15 +407,15 @@ "comment": "", "meta": { "range": [ - 1727, - 1743 + 2289, + 2305 ], "filename": "matrix.js", - "lineno": 76, + "lineno": 100, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000096", + "id": "astnode100000127", "name": "a", "type": "MemberExpression", "value": "this.__value" @@ -337,15 +433,15 @@ "comment": "", "meta": { "range": [ - 1752, - 1786 + 2314, + 2348 ], "filename": "matrix.js", - "lineno": 77, + "lineno": 101, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000102", + "id": "astnode100000133", "name": "b", "type": "MemberExpression", "value": ".__value" @@ -360,10 +456,10 @@ "params": [] }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member isSquare\n * @desc Boolean indicating whether this contains a square Matrix\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSquare()\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#isSquare\n * @desc Boolean indicating whether this contains a square Matrix\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSquare()\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 81, + "lineno": 105, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -391,15 +487,15 @@ "comment": "", "meta": { "range": [ - 2045, - 2136 + 2614, + 2705 ], "filename": "matrix.js", - "lineno": 93, + "lineno": 117, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000117", + "id": "astnode100000148", "name": "Matrix.prototype.isSquare", "type": "FunctionExpression", "paramnames": [] @@ -413,10 +509,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member isOrthogonal\n * @param M {Matrix|array}\n * @returns {boolean}\n * @example\n *\n * const result = [[-0.3092, -0.9510], [-0.9510, 0.3092]]\n * const A = Matrix.fromArray(result)\n * true === A.isOrthogonal()\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#isOrthogonal\n * @param M {Matrix|array}\n * @returns {boolean}\n * @example\n *\n * const result = [[-0.3092, -0.9510], [-0.9510, 0.3092]]\n * const A = Matrix.fromArray(result)\n * true === A.isOrthogonal()\n */", "meta": { "filename": "matrix.js", - "lineno": 97, + "lineno": 121, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -454,15 +550,15 @@ "comment": "", "meta": { "range": [ - 2393, - 2535 + 2969, + 3111 ], "filename": "matrix.js", - "lineno": 109, + "lineno": 133, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000137", + "id": "astnode100000168", "name": "Matrix.prototype.isOrthogonal", "type": "FunctionExpression", "paramnames": [] @@ -483,15 +579,15 @@ "comment": "", "meta": { "range": [ - 2447, - 2480 + 3023, + 3056 ], "filename": "matrix.js", - "lineno": 110, + "lineno": 134, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000146", + "id": "astnode100000177", "name": "AxAt", "type": "CallExpression", "value": "" @@ -509,15 +605,15 @@ "comment": "", "meta": { "range": [ - 2489, - 2508 + 3065, + 3084 ], "filename": "matrix.js", - "lineno": 111, + "lineno": 135, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000157", + "id": "astnode100000188", "name": "I", "type": "CallExpression", "value": "" @@ -532,10 +628,10 @@ "params": [] }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member getCols\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getCols() === 2\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#getCols\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getCols() === 2\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 115, + "lineno": 139, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -562,15 +658,15 @@ "comment": "", "meta": { "range": [ - 2699, - 2773 + 3282, + 3356 ], "filename": "matrix.js", - "lineno": 126, + "lineno": 150, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000169", + "id": "astnode100000200", "name": "Matrix.prototype.getCols", "type": "FunctionExpression", "paramnames": [] @@ -584,10 +680,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member equals\n * @param M {Matrix|array}\n * @returns {Boolean}\n * @example\n *\n * var a = [[1, 1], [1, 1]]\n * var A = Matrix.of(a)\n * var B = Matrix.of(a)\n * true === A.equals(B)\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#equals\n * @param M {Matrix|array}\n * @returns {Boolean}\n * @example\n *\n * var a = [[1, 1], [1, 1]]\n * var A = Matrix.of(a)\n * var B = Matrix.of(a)\n * true === A.equals(B)\n */", "meta": { "filename": "matrix.js", - "lineno": 130, + "lineno": 154, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -625,15 +721,15 @@ "comment": "", "meta": { "range": [ - 2999, - 3087 + 3589, + 3677 ], "filename": "matrix.js", - "lineno": 143, + "lineno": 167, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000186", + "id": "astnode100000217", "name": "Matrix.prototype.equals", "type": "FunctionExpression", "paramnames": [ @@ -649,10 +745,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member getRows\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getRows() // 2\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#getRows\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getRows() // 2\n */", "meta": { "filename": "matrix.js", - "lineno": 147, + "lineno": 171, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -679,15 +775,15 @@ "comment": "", "meta": { "range": [ - 3247, - 3318 + 3844, + 3915 ], "filename": "matrix.js", - "lineno": 157, + "lineno": 181, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000207", + "id": "astnode100000238", "name": "Matrix.prototype.getRows", "type": "FunctionExpression", "paramnames": [] @@ -701,10 +797,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member getShape\n * @returns {Array}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getShape() // [2, 2]\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#getShape\n * @returns {Array}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getShape() // [2, 2]\n */", "meta": { "filename": "matrix.js", - "lineno": 161, + "lineno": 185, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -731,15 +827,15 @@ "comment": "", "meta": { "range": [ - 3484, - 3569 + 4088, + 4173 ], "filename": "matrix.js", - "lineno": 171, + "lineno": 195, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { - "id": "astnode100000222", + "id": "astnode100000253", "name": "Matrix.prototype.getShape", "type": "FunctionExpression", "paramnames": [] @@ -753,106 +849,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @static\n * @function of\n * @desc Creates a Matrix object and flattens the Matrix\n * @param val {array|function} An array of arrays\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.of([[1,2],[2,3],[4,5]])\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#map\n * @description Maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.of([[1, 1], [1, 1]])\n * m.map(x => x.map(y => y+ 1))\n * // [[2, 2], [2, 2]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 175, - "columnno": 0, - "path": "/Volumes/BigOne/github/funMatrix/src", - "code": {} - }, - "memberof": "Matrix", - "scope": "static", - "kind": "function", - "name": "of", - "description": "Creates a Matrix object and flattens the Matrix", - "params": [ - { - "type": { - "names": [ - "array", - "function" - ] - }, - "description": "An array of arrays", - "name": "val" - } - ], - "returns": [ - { - "type": { - "names": [ - "Matrix" - ] - } - } - ], - "examples": [ - "const m = Matrix.of([[1,2],[2,3],[4,5]])" - ], - "longname": "Matrix.of" - }, - { - "comment": "", - "meta": { - "range": [ - 3817, - 3987 - ], - "filename": "matrix.js", - "lineno": 187, - "columnno": 0, - "path": "/Volumes/BigOne/github/funMatrix/src", - "code": { - "id": "astnode100000241", - "name": "Matrix.of", - "type": "FunctionExpression", - "paramnames": [ - "val" - ] - }, - "vars": { - "this.__value": "Matrix.of#__value" - } - }, - "undocumented": true, - "name": "of", - "longname": "Matrix.of", - "kind": "function", - "memberof": "Matrix", - "scope": "static" - }, - { - "comment": "", - "meta": { - "range": [ - 3922, - 3940 - ], - "filename": "matrix.js", - "lineno": 190, - "columnno": 4, - "path": "/Volumes/BigOne/github/funMatrix/src", - "code": { - "id": "astnode100000260", - "name": "this.__value", - "type": "Identifier", - "value": "val", - "paramnames": [] - } - }, - "undocumented": true, - "name": "__value", - "longname": "Matrix.of#__value", - "kind": "member", - "memberof": "Matrix.of", - "scope": "instance" - }, - { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member map\n * @description Maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.of([[1, 1], [1, 1]])\n * m.map(x => x.map(y => y+ 1))\n * // [[2, 2], [2, 2]]\n *\n */", - "meta": { - "filename": "matrix.js", - "lineno": 196, + "lineno": 199, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -891,11 +891,11 @@ "comment": "", "meta": { "range": [ - 4294, - 4374 + 4487, + 4567 ], "filename": "matrix.js", - "lineno": 210, + "lineno": 213, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -915,10 +915,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @static\n * @function map\n * @description Static function that maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @param M {Matrix|array} Matrix or array to map\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.map(x= > x.map(y => y+ 1), [[1, 1], [1, 1]])\n * // [[2, 2], [2, 2]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @static\n * @function Matrix.map\n * @description Static function that maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @param M {Matrix|array} Matrix or array to map\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.map(x= > x.map(y => y+ 1), [[1, 1], [1, 1]])\n * // [[2, 2], [2, 2]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 214, + "lineno": 217, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -967,11 +967,11 @@ "comment": "", "meta": { "range": [ - 4744, - 4812 + 4944, + 5012 ], "filename": "matrix.js", - "lineno": 228, + "lineno": 231, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -990,10 +990,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member fold\n * @description Reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @returns {Matrix}\n * @example\n *\n * // Flatten Matrix\n * Matrix.of([[1, 1], [1, 1]]).fold((prev, next) => prev.concat(next))\n * // [1, 1, 1, 1]\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#fold\n * @description Reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @returns {Matrix}\n * @example\n *\n * // Flatten Matrix\n * Matrix.of([[1, 1], [1, 1]]).fold((prev, next) => prev.concat(next))\n * // [1, 1, 1, 1]\n */", "meta": { "filename": "matrix.js", - "lineno": 232, + "lineno": 235, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1032,11 +1032,11 @@ "comment": "", "meta": { "range": [ - 5127, - 5213 + 5334, + 5420 ], "filename": "matrix.js", - "lineno": 245, + "lineno": 248, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1056,10 +1056,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @static\n * @function fold\n * @description Static function to reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @param M {Matrix} The Matrix to reduce\n * @returns {Matrix}\n * @example\n\n * // Sum of all matrix values\n * const reducer = (prev, next) => Number(prev) + next.reduce((acc, x) => acc + x, 0)\n * const A = Matrix.of([[1, 1], [1, 1]]\n * Matrix.fold(reducer, A)\n * // 4\n */", + "comment": "/**\n * @memberOf Matrix\n * @static\n * @function Matrix.fold\n * @description Static function to reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @param M {Matrix} The Matrix to reduce\n * @returns {Matrix}\n * @example\n\n * // Sum of all matrix values\n * const reducer = (prev, next) => Number(prev) + next.reduce((acc, x) => acc + x, 0)\n * const A = Matrix.of([[1, 1], [1, 1]]\n * Matrix.fold(reducer, A)\n * // 4\n */", "meta": { "filename": "matrix.js", - "lineno": 249, + "lineno": 252, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1107,11 +1107,11 @@ "comment": "", "meta": { "range": [ - 5668, - 5738 + 5882, + 5952 ], "filename": "matrix.js", - "lineno": 265, + "lineno": 268, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1130,10 +1130,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member ap\n * @description Applies a Matrix to a function\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * const A = Matrix.of([[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * Matrix.of(f).ap(M)\n * // [[6], [15], [24]\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#ap\n * @description Applies a Matrix to a function\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * const A = Matrix.of([[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * Matrix.of(f).ap(M)\n * // [[6], [15], [24]\n */", "meta": { "filename": "matrix.js", - "lineno": 269, + "lineno": 272, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1171,11 +1171,11 @@ "comment": "", "meta": { "range": [ - 6058, - 6136 + 6279, + 6357 ], "filename": "matrix.js", - "lineno": 283, + "lineno": 286, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1195,10 +1195,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @static\n * @function ap\n * @description Applies a Matrix to a function\n * @param f {function}\n * @param M {Matrix|array}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * Matrix.ap(f, [[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * // [[6], [15], [24]\n */", + "comment": "/**\n * @memberOf Matrix\n * @static\n * @function Matrix.ap\n * @description Applies a Matrix to a function\n * @param f {function}\n * @param M {Matrix|array}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * Matrix.ap(f, [[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * // [[6], [15], [24]\n */", "meta": { "filename": "matrix.js", - "lineno": 287, + "lineno": 290, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1245,11 +1245,11 @@ "comment": "", "meta": { "range": [ - 6456, - 6522 + 6684, + 6750 ], "filename": "matrix.js", - "lineno": 301, + "lineno": 304, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1268,10 +1268,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = A.concat(B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = A.concat(B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 305, + "lineno": 308, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1309,11 +1309,11 @@ "comment": "", "meta": { "range": [ - 6908, - 6997 + 7143, + 7232 ], "filename": "matrix.js", - "lineno": 322, + "lineno": 325, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1334,10 +1334,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @static\n * @function concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param A {Matrix}\n * @param B {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = Matrix.concat(A, B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @static\n * @function Matrix.concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param A {Matrix}\n * @param B {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = Matrix.concat(A, B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 326, + "lineno": 329, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1383,11 +1383,11 @@ "comment": "", "meta": { "range": [ - 7412, - 7498 + 7654, + 7740 ], "filename": "matrix.js", - "lineno": 344, + "lineno": 347, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1406,10 +1406,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member empty\n * @description Return an empty Matrix from an existing Matrix\n * @returns {Matrix}\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#empty\n * @description Return an empty Matrix from an existing Matrix\n * @returns {Matrix}\n */", "meta": { "filename": "matrix.js", - "lineno": 348, + "lineno": 351, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1434,11 +1434,11 @@ "comment": "", "meta": { "range": [ - 7642, - 7718 + 7891, + 7967 ], "filename": "matrix.js", - "lineno": 355, + "lineno": 358, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1456,10 +1456,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @static\n * @function empty\n * @description Return an empty Matrix from an existing Matrix\n * @param rows {number}\n * @param cols {number}\n * @returns {Matrix}\n */", + "comment": "/**\n * @memberOf Matrix\n * @static\n * @function Matrix.empty\n * @description Return an empty Matrix from an existing Matrix\n * @param rows {number}\n * @param cols {number}\n * @returns {Matrix}\n */", "meta": { "filename": "matrix.js", - "lineno": 359, + "lineno": 362, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1502,11 +1502,11 @@ "comment": "", "meta": { "range": [ - 7910, - 8106 + 8166, + 8362 ], "filename": "matrix.js", - "lineno": 368, + "lineno": 371, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1528,11 +1528,11 @@ "comment": "", "meta": { "range": [ - 7971, - 7995 + 8227, + 8251 ], "filename": "matrix.js", - "lineno": 369, + "lineno": 372, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1551,10 +1551,10 @@ "params": [] }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const A = Matrix.of(a)\n * const Aidentity = A.identity()\n * // [[1, 0, 0], [0, 1, 0]]\n *\n*/", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const A = Matrix.of(a)\n * const Aidentity = A.identity()\n * // [[1, 0, 0], [0, 1, 0]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 375, + "lineno": 378, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1582,11 +1582,11 @@ "comment": "", "meta": { "range": [ - 8390, - 8471 + 8654, + 8735 ], "filename": "matrix.js", - "lineno": 389, + "lineno": 392, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1604,10 +1604,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @static\n * @function identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.identity(3, 2)\n * // [[1, 0, 0], [0, 1, 0]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @static\n * @function Matrix.identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.identity(3, 2)\n * // [[1, 0, 0], [0, 1, 0]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 393, + "lineno": 396, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1635,11 +1635,11 @@ "comment": "", "meta": { "range": [ - 8673, - 8859 + 8944, + 9130 ], "filename": "matrix.js", - "lineno": 405, + "lineno": 408, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1666,11 +1666,11 @@ "comment": "", "meta": { "range": [ - 8723, - 8747 + 8994, + 9018 ], "filename": "matrix.js", - "lineno": 406, + "lineno": 409, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1689,10 +1689,10 @@ "params": [] }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */", "meta": { "filename": "matrix.js", - "lineno": 410, + "lineno": 413, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1724,11 +1724,11 @@ "comment": "", "meta": { "range": [ - 8976, - 9073 + 9254, + 9351 ], "filename": "matrix.js", - "lineno": 418, + "lineno": 421, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1748,10 +1748,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @static\n * @function combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */", + "comment": "/**\n * @memberOf Matrix\n * @static\n * @function Matrix.combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */", "meta": { "filename": "matrix.js", - "lineno": 422, + "lineno": 425, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1783,11 +1783,11 @@ "comment": "", "meta": { "range": [ - 9190, - 9277 + 9475, + 9562 ], "filename": "matrix.js", - "lineno": 430, + "lineno": 433, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1808,10 +1808,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @param f\n * @returns {Matrix}\n * @example\n *\n * // Create matrix\n * const m = Matrix.of([[1, 2], [3, 4]])\n *\n * // Generate identity matrix\n * const I = m.identity() // [[1, 0], [0, 1]]\n *\n * if(m.dot(I).equals(m)) {\n * console.log('Dot product with identity matrix returns the same matrix')\n * }\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @param f\n * @returns {Matrix}\n * @example\n *\n * // Create matrix\n * const m = Matrix.of([[1, 2], [3, 4]])\n *\n * // Generate identity matrix\n * const I = m.identity() // [[1, 0], [0, 1]]\n *\n * if(m.dot(I).equals(m)) {\n * console.log('Dot product with identity matrix returns the same matrix')\n * }\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 434, + "lineno": 437, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1847,11 +1847,11 @@ "comment": "", "meta": { "range": [ - 9713, - 9819 + 10005, + 10111 ], "filename": "matrix.js", - "lineno": 455, + "lineno": 458, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1871,10 +1871,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @static\n * @function dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @returns {Matrix}\n * @example\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const b = [[7, 8], [9, 10], [11, 12]]\n *\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n *\n * Matrix.dot(A, B) // [[58, 64], [139, 154]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @static\n * @function Matrix.dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @returns {Matrix}\n * @example\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const b = [[7, 8], [9, 10], [11, 12]]\n *\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n *\n * Matrix.dot(A, B) // [[58, 64], [139, 154]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 459, + "lineno": 462, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1907,11 +1907,11 @@ "comment": "", "meta": { "range": [ - 10165, - 10237 + 10464, + 10536 ], "filename": "matrix.js", - "lineno": 476, + "lineno": 479, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1932,10 +1932,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member fill\n * @desc Fill up an empty matrix with the provided map function\n * @param f\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).fill(x => 42)\n * // [[42,42,42], [42,42,42], [42,42,42]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#fill\n * @desc Fill up an empty matrix with the provided map function\n * @param f\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).fill(x => 42)\n * // [[42,42,42], [42,42,42], [42,42,42]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 480, + "lineno": 483, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -1968,11 +1968,11 @@ "comment": "", "meta": { "range": [ - 10520, - 10605 + 10826, + 10911 ], "filename": "matrix.js", - "lineno": 493, + "lineno": 496, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -1995,10 +1995,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member zeros\n * @desc Fill up an empty matrix with zeros\n * @returns {Matrix}\n *\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).zeros()\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#zeros\n * @desc Fill up an empty matrix with zeros\n * @returns {Matrix}\n *\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).zeros()\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 497, + "lineno": 500, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2026,11 +2026,11 @@ "comment": "", "meta": { "range": [ - 10845, - 10923 + 11158, + 11236 ], "filename": "matrix.js", - "lineno": 510, + "lineno": 513, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2051,10 +2051,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @function zeros\n * @desc Fill up an empty matrix with zeros\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.zeros(3, 3)\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @function Matrix.zeros\n * @desc Fill up an empty matrix with zeros\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.zeros(3, 3)\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 514, + "lineno": 517, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2095,18 +2095,18 @@ "examples": [ "const A = Matrix.zeros(3, 3)\n// [[0,0,0], [0,0,0], [0,0,0]]" ], - "scope": "static", - "longname": "Matrix.zeros" + "longname": "Matrix.zeros", + "scope": "static" }, { "comment": "", "meta": { "range": [ - 11234, - 11342 + 11554, + 11662 ], "filename": "matrix.js", - "lineno": 527, + "lineno": 530, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2134,11 +2134,11 @@ "comment": "", "meta": { "range": [ - 11281, - 11305 + 11601, + 11625 ], "filename": "matrix.js", - "lineno": 528, + "lineno": 531, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2157,10 +2157,10 @@ "params": [] }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member ones\n * @desc Fill up an empty matrix with ones\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).ones()\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#ones\n * @desc Fill up an empty matrix with ones\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).ones()\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 532, + "lineno": 535, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2188,11 +2188,11 @@ "comment": "", "meta": { "range": [ - 11576, - 11653 + 11903, + 11980 ], "filename": "matrix.js", - "lineno": 544, + "lineno": 547, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2213,10 +2213,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @function ones\n * @desc Fill up an empty matrix with ones\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.ones(1, 1)\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @function Matrix.ones\n * @desc Fill up an empty matrix with ones\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.ones(1, 1)\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 548, + "lineno": 551, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2257,18 +2257,18 @@ "examples": [ "const A = Matrix.ones(1, 1)\n// [[1,1,1], [1,1,1], [1,1,1]]" ], - "scope": "static", - "longname": "Matrix.ones" + "longname": "Matrix.ones", + "scope": "static" }, { "comment": "", "meta": { "range": [ - 11961, - 12068 + 12295, + 12402 ], "filename": "matrix.js", - "lineno": 561, + "lineno": 564, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2296,11 +2296,11 @@ "comment": "", "meta": { "range": [ - 12007, - 12031 + 12341, + 12365 ], "filename": "matrix.js", - "lineno": 562, + "lineno": 565, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2319,10 +2319,10 @@ "params": [] }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member random\n * @desc Fill up an empty matrix with random values\n * @param {function} [f = e => Math.random() * 2 - 1]\n * @returns {Matrix}\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#random\n * @desc Fill up an empty matrix with random values\n * @param {function} [f = e => Math.random() * 2 - 1]\n * @returns {Matrix}\n */", "meta": { "filename": "matrix.js", - "lineno": 566, + "lineno": 569, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2359,11 +2359,11 @@ "comment": "", "meta": { "range": [ - 12256, - 12360 + 12597, + 12701 ], "filename": "matrix.js", - "lineno": 574, + "lineno": 577, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2386,10 +2386,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @function random\n * @desc Fill up an empty matrix with random numbers\n * @param f {function} Function which returns random values. Default random values are between -1 and 1\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n */", + "comment": "/**\n * @memberOf Matrix\n * @function Matrix.random\n * @desc Fill up an empty matrix with random numbers\n * @param f {function} Function which returns random values. Default random values are between -1 and 1\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n */", "meta": { "filename": "matrix.js", - "lineno": 578, + "lineno": 581, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2436,18 +2436,18 @@ } } ], - "scope": "static", - "longname": "Matrix.random" + "longname": "Matrix.random", + "scope": "static" }, { "comment": "", "meta": { "range": [ - 12701, - 12839 + 13049, + 13187 ], "filename": "matrix.js", - "lineno": 587, + "lineno": 590, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2476,11 +2476,11 @@ "comment": "", "meta": { "range": [ - 12783, - 12807 + 13131, + 13155 ], "filename": "matrix.js", - "lineno": 588, + "lineno": 591, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2499,10 +2499,10 @@ "params": [] }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member toArray\n * @desc Returns the array from the matrix\n * @returns {Array}\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#toArray\n * @desc Returns the array from the matrix\n * @returns {Array}\n */", "meta": { "filename": "matrix.js", - "lineno": 592, + "lineno": 595, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2527,11 +2527,11 @@ "comment": "", "meta": { "range": [ - 12964, - 13060 + 13319, + 13415 ], "filename": "matrix.js", - "lineno": 599, + "lineno": 602, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2552,10 +2552,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member clone\n * @desc Returns a clone of the matrix\n * @returns {Matrix}\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#clone\n * @desc Returns a clone of the matrix\n * @returns {Matrix}\n */", "meta": { "filename": "matrix.js", - "lineno": 603, + "lineno": 606, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2580,11 +2580,11 @@ "comment": "", "meta": { "range": [ - 13180, - 13260 + 13542, + 13622 ], "filename": "matrix.js", - "lineno": 610, + "lineno": 613, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2602,10 +2602,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member fromArray\n * @desc Returns a Matrix from an array\n * @returns {Array}\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#fromArray\n * @desc Returns a Matrix from an array\n * @returns {Array}\n */", "meta": { "filename": "matrix.js", - "lineno": 614, + "lineno": 617, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2630,11 +2630,11 @@ "comment": "", "meta": { "range": [ - 13384, - 13479 + 13753, + 13848 ], "filename": "matrix.js", - "lineno": 621, + "lineno": 624, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2657,10 +2657,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member transpose\n * @desc Returns a transposed Matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([-1, 2], [3, 4], [-8, 2])\n * const b = A.transpose().toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#transpose\n * @desc Returns a transposed Matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([-1, 2], [3, 4], [-8, 2])\n * const b = A.transpose().toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */", "meta": { "filename": "matrix.js", - "lineno": 625, + "lineno": 628, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2688,11 +2688,11 @@ "comment": "", "meta": { "range": [ - 13740, - 13838 + 14116, + 14214 ], "filename": "matrix.js", - "lineno": 637, + "lineno": 640, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2710,10 +2710,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @function transpose\n * @desc Returns a transposed Matrix\n * @param M {Matrix|array} A Matrix or a matrix array\n * @returns {Matrix}\n * @example\n *\n * const a = [-1, 2], [3, 4], [-8, 2]\n * const b = Matrix.transpose(a).toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */", + "comment": "/**\n * @memberOf Matrix\n * @function Matrix.transpose\n * @desc Returns a transposed Matrix\n * @param M {Matrix|array} A Matrix or a matrix array\n * @returns {Matrix}\n * @example\n *\n * const a = [-1, 2], [3, 4], [-8, 2]\n * const b = Matrix.transpose(a).toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */", "meta": { "filename": "matrix.js", - "lineno": 641, + "lineno": 644, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2746,18 +2746,18 @@ "examples": [ "const a = [-1, 2], [3, 4], [-8, 2]\nconst b = Matrix.transpose(a).toArray()\n// returns [[-1, 3,-8], [2, 4, 2]]" ], - "scope": "static", - "longname": "Matrix.transpose" + "longname": "Matrix.transpose", + "scope": "static" }, { "comment": "", "meta": { "range": [ - 14137, - 14206 + 14520, + 14589 ], "filename": "matrix.js", - "lineno": 653, + "lineno": 656, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2777,18 +2777,18 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @member add\n * @instance\n * @param M {Matrix|number} Add a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.add(1) // [[6, 5]]\n * const B = Matrix.of([[5, 5]])\n * B.add(B) // [[10, 10]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @function Matrix.add\n * @instance\n * @param M {Matrix|number} Add a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.add(1) // [[6, 5]]\n * const B = Matrix.of([[5, 5]])\n * B.add(B) // [[10, 10]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 657, + "lineno": 660, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} }, "memberof": "Matrix", - "kind": "member", + "kind": "function", "name": "add", - "scope": "instance", + "scope": "static", "params": [ { "type": { @@ -2813,17 +2813,17 @@ "examples": [ "const A = Matrix.of([[5, 4]])\nA.add(1) // [[6, 5]]\nconst B = Matrix.of([[5, 5]])\nB.add(B) // [[10, 10]]" ], - "longname": "Matrix#add" + "longname": "Matrix.add" }, { "comment": "", "meta": { "range": [ - 14472, - 14818 + 14864, + 15210 ], "filename": "matrix.js", - "lineno": 671, + "lineno": 674, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2846,10 +2846,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @member subtract\n * @instance\n * @param M {Matrix|number} Subtract a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.subtract(1) // [[4, 2]]\n * const B = Matrix.of([[5, 5]])\n * B.subtract(B) // [[0, 0]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#subtract\n * @instance\n * @param M {Matrix|number} Subtract a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.subtract(1) // [[4, 2]]\n * const B = Matrix.of([[5, 5]])\n * B.subtract(B) // [[0, 0]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 682, + "lineno": 685, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2888,11 +2888,11 @@ "comment": "", "meta": { "range": [ - 15102, - 15458 + 15501, + 15857 ], "filename": "matrix.js", - "lineno": 696, + "lineno": 699, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2915,10 +2915,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @member multiply\n * @instance\n * @desc Mutliply a scalar or a mtraix with a matrix. Throws an error if the multiplication is not possible.\n * @param M {Matrix|number}\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.multiply(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.multiply(B) // [[25, 25]]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#multiply\n * @instance\n * @desc Mutliply a scalar or a mtraix with a matrix. Throws an error if the multiplication is not possible.\n * @param M {Matrix|number}\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.multiply(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.multiply(B) // [[25, 25]]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 707, + "lineno": 710, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -2957,11 +2957,11 @@ "comment": "", "meta": { "range": [ - 15824, - 16270 + 16230, + 16676 ], "filename": "matrix.js", - "lineno": 722, + "lineno": 725, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -2984,10 +2984,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @member additiveinverse\n * @instance\n * @desc Function that returns the matrix obtained by changing the sign of every matrix element. The additive inverse of matrix A is written –A.\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5,-5], [-4, 4]])\n * const minusA = A.additiveinverse()\n * // [[-5, 5], [4, -4]]\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#additiveinverse\n * @instance\n * @desc Function that returns the matrix obtained by changing the sign of every matrix element. The additive inverse of matrix A is written –A.\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5,-5], [-4, 4]])\n * const minusA = A.additiveinverse()\n * // [[-5, 5], [4, -4]]\n */", "meta": { "filename": "matrix.js", - "lineno": 734, + "lineno": 737, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -3015,11 +3015,11 @@ "comment": "", "meta": { "range": [ - 16626, - 16714 + 17039, + 17127 ], "filename": "matrix.js", - "lineno": 746, + "lineno": 749, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3037,10 +3037,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @member hadamard\n * @instance\n * @see multiply\n * @param M\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.hadamard(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.hadamard(B) // [[25, 25]]\n\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#hadamard\n * @instance\n * @see multiply\n * @param M\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.hadamard(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.hadamard(B) // [[25, 25]]\n\n */", "meta": { "filename": "matrix.js", - "lineno": 750, + "lineno": 753, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -3075,11 +3075,11 @@ "comment": "", "meta": { "range": [ - 16970, - 17051 + 17390, + 17471 ], "filename": "matrix.js", - "lineno": 765, + "lineno": 768, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3099,10 +3099,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member lu\n * @desc Calculates LU decomposition of the current Matrix\n * @returns {Matrix[]}\n * @example\n *\n * const result = [[3, -7, -2, 2], [-3, 5, 1, 0], [6, -4, 0, -5], [-9, 5, -5, 12]]\n * const A = Matrix.fromArray(result)\n * const lu = A.lu()\n * // L.__value = [ [ 1, 0, 0, 0 ], [ -1, 1, 0, 0 ], [ 2, -5, 1, 0 ], [ -3, 8, 3, 1 ] ]\n * // U.__value = [ [ 3, -7, -2, 2 ], [ 0, -2, -1, 2 ], [ 0, 0, -1, 1 ], [ 0, 0, 0, -1 ] ]\n * Matrix.dot(lu[0], lu[1]) // returns clone of A\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#lu\n * @desc Calculates LU decomposition of the current Matrix\n * @returns {Matrix[]}\n * @example\n *\n * const result = [[3, -7, -2, 2], [-3, 5, 1, 0], [6, -4, 0, -5], [-9, 5, -5, 12]]\n * const A = Matrix.fromArray(result)\n * const lu = A.lu()\n * // L.__value = [ [ 1, 0, 0, 0 ], [ -1, 1, 0, 0 ], [ 2, -5, 1, 0 ], [ -3, 8, 3, 1 ] ]\n * // U.__value = [ [ 3, -7, -2, 2 ], [ 0, -2, -1, 2 ], [ 0, 0, -1, 1 ], [ 0, 0, 0, -1 ] ]\n * Matrix.dot(lu[0], lu[1]) // returns clone of A\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 769, + "lineno": 772, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -3130,11 +3130,11 @@ "comment": "", "meta": { "range": [ - 17580, - 18217 + 18007, + 18644 ], "filename": "matrix.js", - "lineno": 785, + "lineno": 788, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3169,11 +3169,11 @@ "comment": "", "meta": { "range": [ - 17624, - 17642 + 18051, + 18069 ], "filename": "matrix.js", - "lineno": 786, + "lineno": 789, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3195,11 +3195,11 @@ "comment": "", "meta": { "range": [ - 17651, - 17661 + 18078, + 18088 ], "filename": "matrix.js", - "lineno": 787, + "lineno": 790, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3221,11 +3221,11 @@ "comment": "", "meta": { "range": [ - 17670, - 17686 + 18097, + 18113 ], "filename": "matrix.js", - "lineno": 788, + "lineno": 791, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3247,11 +3247,11 @@ "comment": "", "meta": { "range": [ - 17695, - 17711 + 18122, + 18138 ], "filename": "matrix.js", - "lineno": 789, + "lineno": 792, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3273,11 +3273,11 @@ "comment": "", "meta": { "range": [ - 17720, - 17736 + 18147, + 18163 ], "filename": "matrix.js", - "lineno": 790, + "lineno": 793, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3299,11 +3299,11 @@ "comment": "", "meta": { "range": [ - 17749, - 17754 + 18176, + 18181 ], "filename": "matrix.js", - "lineno": 792, + "lineno": 795, "columnno": 11, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3325,11 +3325,11 @@ "comment": "", "meta": { "range": [ - 17868, - 17887 + 18295, + 18314 ], "filename": "matrix.js", - "lineno": 794, + "lineno": 797, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3352,11 +3352,11 @@ "comment": "", "meta": { "range": [ - 17901, - 17910 + 18328, + 18337 ], "filename": "matrix.js", - "lineno": 795, + "lineno": 798, "columnno": 13, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3378,11 +3378,11 @@ "comment": "", "meta": { "range": [ - 17932, - 17983 + 18359, + 18410 ], "filename": "matrix.js", - "lineno": 796, + "lineno": 799, "columnno": 6, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3405,11 +3405,11 @@ "comment": "", "meta": { "range": [ - 17999, - 18008 + 18426, + 18435 ], "filename": "matrix.js", - "lineno": 797, + "lineno": 800, "columnno": 15, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3431,11 +3431,11 @@ "comment": "", "meta": { "range": [ - 18032, - 18101 + 18459, + 18528 ], "filename": "matrix.js", - "lineno": 798, + "lineno": 801, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3458,11 +3458,11 @@ "comment": "", "meta": { "range": [ - 18129, - 18134 + 18556, + 18561 ], "filename": "matrix.js", - "lineno": 801, + "lineno": 804, "columnno": 13, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3484,11 +3484,11 @@ "comment": "", "meta": { "range": [ - 18156, - 18189 + 18583, + 18616 ], "filename": "matrix.js", - "lineno": 802, + "lineno": 805, "columnno": 6, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3508,10 +3508,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member rref\n * @returns {Matrix|array}\n * @example\n *\n * var A = Matrix.of([[-1, 1], [-1, 0], [0, -1], [-1, -2]])\n * A.rref() // [ [ 1, 0 ], [ -0, 1 ], [ 0, 0 ], [ 0, 0 ] ]\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#rref\n * @returns {Matrix|array}\n * @example\n *\n * var A = Matrix.of([[-1, 1], [-1, 0], [0, -1], [-1, -2]])\n * A.rref() // [ [ 1, 0 ], [ -0, 1 ], [ 0, 0 ], [ 0, 0 ] ]\n */", "meta": { "filename": "matrix.js", - "lineno": 808, + "lineno": 811, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -3539,11 +3539,11 @@ "comment": "", "meta": { "range": [ - 18438, - 19424 + 18872, + 19858 ], "filename": "matrix.js", - "lineno": 818, + "lineno": 821, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3575,11 +3575,11 @@ "comment": "", "meta": { "range": [ - 18482, - 18490 + 18916, + 18924 ], "filename": "matrix.js", - "lineno": 819, + "lineno": 822, "columnno": 6, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3601,11 +3601,11 @@ "comment": "", "meta": { "range": [ - 18499, - 18526 + 18933, + 18960 ], "filename": "matrix.js", - "lineno": 820, + "lineno": 823, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3627,11 +3627,11 @@ "comment": "", "meta": { "range": [ - 18539, - 18544 + 18973, + 18978 ], "filename": "matrix.js", - "lineno": 822, + "lineno": 825, "columnno": 11, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3653,11 +3653,11 @@ "comment": "", "meta": { "range": [ - 18647, - 18652 + 19081, + 19086 ], "filename": "matrix.js", - "lineno": 826, + "lineno": 829, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3679,11 +3679,11 @@ "comment": "", "meta": { "range": [ - 18755, - 18760 + 19189, + 19194 ], "filename": "matrix.js", - "lineno": 830, + "lineno": 833, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3706,11 +3706,11 @@ "comment": "", "meta": { "range": [ - 18878, - 18907 + 19312, + 19341 ], "filename": "matrix.js", - "lineno": 838, + "lineno": 841, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3732,11 +3732,11 @@ "comment": "", "meta": { "range": [ - 18912, - 18961 + 19346, + 19395 ], "filename": "matrix.js", - "lineno": 839, + "lineno": 842, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3759,11 +3759,11 @@ "comment": "", "meta": { "range": [ - 18966, - 18995 + 19400, + 19429 ], "filename": "matrix.js", - "lineno": 840, + "lineno": 843, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3786,11 +3786,11 @@ "comment": "", "meta": { "range": [ - 19005, - 19040 + 19439, + 19474 ], "filename": "matrix.js", - "lineno": 842, + "lineno": 845, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3812,11 +3812,11 @@ "comment": "", "meta": { "range": [ - 19054, - 19059 + 19488, + 19493 ], "filename": "matrix.js", - "lineno": 843, + "lineno": 846, "columnno": 13, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3838,11 +3838,11 @@ "comment": "", "meta": { "range": [ - 19094, - 19127 + 19528, + 19561 ], "filename": "matrix.js", - "lineno": 844, + "lineno": 847, "columnno": 6, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3865,11 +3865,11 @@ "comment": "", "meta": { "range": [ - 19148, - 19153 + 19582, + 19587 ], "filename": "matrix.js", - "lineno": 847, + "lineno": 850, "columnno": 13, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3891,11 +3891,11 @@ "comment": "", "meta": { "range": [ - 19216, - 19251 + 19650, + 19685 ], "filename": "matrix.js", - "lineno": 849, + "lineno": 852, "columnno": 6, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3918,11 +3918,11 @@ "comment": "", "meta": { "range": [ - 19267, - 19272 + 19701, + 19706 ], "filename": "matrix.js", - "lineno": 850, + "lineno": 853, "columnno": 15, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3944,11 +3944,11 @@ "comment": "", "meta": { "range": [ - 19309, - 19371 + 19743, + 19805 ], "filename": "matrix.js", - "lineno": 851, + "lineno": 854, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -3968,10 +3968,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member solve\n * @param b\n * @returns {Array}\n * @example\n *\n * // Solve xA = b\n * // 5x + y = 7\n * // 3x - 4y = 18\n * // Solution for x and y:\n * // x = 2\n * // y = -3\n *\n * const A = Matrix.of([[5, 1], [3, -4]])\n * const solveA = A.solve([7, 18]) // [2, -3]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#solve\n * @param b\n * @returns {Array}\n * @example\n *\n * // Solve xA = b\n * // 5x + y = 7\n * // 3x - 4y = 18\n * // Solution for x and y:\n * // x = 2\n * // y = -3\n *\n * const A = Matrix.of([[5, 1], [3, -4]])\n * const solveA = A.solve([7, 18]) // [2, -3]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 859, + "lineno": 862, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -4003,11 +4003,11 @@ "comment": "", "meta": { "range": [ - 19734, - 20256 + 20175, + 20697 ], "filename": "matrix.js", - "lineno": 878, + "lineno": 881, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4047,11 +4047,11 @@ "comment": "", "meta": { "range": [ - 19782, - 19798 + 20223, + 20239 ], "filename": "matrix.js", - "lineno": 879, + "lineno": 882, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4073,11 +4073,11 @@ "comment": "", "meta": { "range": [ - 19807, - 19818 + 20248, + 20259 ], "filename": "matrix.js", - "lineno": 880, + "lineno": 883, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4099,11 +4099,11 @@ "comment": "", "meta": { "range": [ - 19827, - 19836 + 20268, + 20277 ], "filename": "matrix.js", - "lineno": 881, + "lineno": 884, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4125,11 +4125,11 @@ "comment": "", "meta": { "range": [ - 19845, - 19854 + 20286, + 20295 ], "filename": "matrix.js", - "lineno": 882, + "lineno": 885, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4151,11 +4151,11 @@ "comment": "", "meta": { "range": [ - 19863, - 19881 + 20304, + 20322 ], "filename": "matrix.js", - "lineno": 883, + "lineno": 886, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4177,11 +4177,11 @@ "comment": "", "meta": { "range": [ - 19888, - 19893 + 20329, + 20334 ], "filename": "matrix.js", - "lineno": 884, + "lineno": 887, "columnno": 6, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4203,11 +4203,11 @@ "comment": "", "meta": { "range": [ - 19902, - 19908 + 20343, + 20349 ], "filename": "matrix.js", - "lineno": 885, + "lineno": 888, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4229,11 +4229,11 @@ "comment": "", "meta": { "range": [ - 19917, - 19923 + 20358, + 20364 ], "filename": "matrix.js", - "lineno": 886, + "lineno": 889, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4255,11 +4255,11 @@ "comment": "", "meta": { "range": [ - 19936, - 19941 + 20377, + 20382 ], "filename": "matrix.js", - "lineno": 888, + "lineno": 891, "columnno": 11, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4281,11 +4281,11 @@ "comment": "", "meta": { "range": [ - 19970, - 19975 + 20411, + 20416 ], "filename": "matrix.js", - "lineno": 889, + "lineno": 892, "columnno": 13, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4307,11 +4307,11 @@ "comment": "", "meta": { "range": [ - 19997, - 20027 + 20438, + 20468 ], "filename": "matrix.js", - "lineno": 890, + "lineno": 893, "columnno": 6, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4334,11 +4334,11 @@ "comment": "", "meta": { "range": [ - 20038, - 20053 + 20479, + 20494 ], "filename": "matrix.js", - "lineno": 892, + "lineno": 895, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4361,11 +4361,11 @@ "comment": "", "meta": { "range": [ - 20058, - 20063 + 20499, + 20504 ], "filename": "matrix.js", - "lineno": 893, + "lineno": 896, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4388,11 +4388,11 @@ "comment": "", "meta": { "range": [ - 20079, - 20088 + 20520, + 20529 ], "filename": "matrix.js", - "lineno": 895, + "lineno": 898, "columnno": 11, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4414,11 +4414,11 @@ "comment": "", "meta": { "range": [ - 20113, - 20118 + 20554, + 20559 ], "filename": "matrix.js", - "lineno": 896, + "lineno": 899, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4440,11 +4440,11 @@ "comment": "", "meta": { "range": [ - 20132, - 20141 + 20573, + 20582 ], "filename": "matrix.js", - "lineno": 897, + "lineno": 900, "columnno": 13, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4466,11 +4466,11 @@ "comment": "", "meta": { "range": [ - 20163, - 20193 + 20604, + 20634 ], "filename": "matrix.js", - "lineno": 898, + "lineno": 901, "columnno": 6, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4493,11 +4493,11 @@ "comment": "", "meta": { "range": [ - 20204, - 20239 + 20645, + 20680 ], "filename": "matrix.js", - "lineno": 900, + "lineno": 903, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4517,10 +4517,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @member inverse\n * @instance\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1, 1], [2, 4]]).inverse()\n * // [ [ 2, -0.5 ], [ -1, 0.5 ] ]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#inverse\n * @instance\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1, 1], [2, 4]]).inverse()\n * // [ [ 2, -0.5 ], [ -1, 0.5 ] ]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 905, + "lineno": 908, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -4547,11 +4547,11 @@ "comment": "", "meta": { "range": [ - 20443, - 20752 + 20891, + 21200 ], "filename": "matrix.js", - "lineno": 916, + "lineno": 919, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4579,11 +4579,11 @@ "comment": "", "meta": { "range": [ - 20492, - 20508 + 20940, + 20956 ], "filename": "matrix.js", - "lineno": 917, + "lineno": 920, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4605,11 +4605,11 @@ "comment": "", "meta": { "range": [ - 20517, - 20533 + 20965, + 20981 ], "filename": "matrix.js", - "lineno": 918, + "lineno": 921, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4631,11 +4631,11 @@ "comment": "", "meta": { "range": [ - 20542, - 20566 + 20990, + 21014 ], "filename": "matrix.js", - "lineno": 919, + "lineno": 922, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4657,11 +4657,11 @@ "comment": "", "meta": { "range": [ - 20576, - 20723 + 21024, + 21171 ], "filename": "matrix.js", - "lineno": 921, + "lineno": 924, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4683,11 +4683,11 @@ "comment": "", "meta": { "range": [ - 20636, - 20655 + 21084, + 21103 ], "filename": "matrix.js", - "lineno": 922, + "lineno": 925, "columnno": 10, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4706,10 +4706,10 @@ "params": [] }, { - "comment": "/**\n * @memberOf Matrix\n * @member rank\n * @instance\n * @returns {Number}\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#rank\n * @instance\n * @returns {Number}\n */", "meta": { "filename": "matrix.js", - "lineno": 929, + "lineno": 932, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -4733,11 +4733,11 @@ "comment": "", "meta": { "range": [ - 20832, - 21013 + 21287, + 21468 ], "filename": "matrix.js", - "lineno": 935, + "lineno": 938, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4763,11 +4763,11 @@ "comment": "", "meta": { "range": [ - 20878, - 20896 + 21333, + 21351 ], "filename": "matrix.js", - "lineno": 936, + "lineno": 939, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4789,11 +4789,11 @@ "comment": "", "meta": { "range": [ - 20903, - 20913 + 21358, + 21368 ], "filename": "matrix.js", - "lineno": 937, + "lineno": 940, "columnno": 6, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4815,11 +4815,11 @@ "comment": "", "meta": { "range": [ - 20925, - 20930 + 21380, + 21385 ], "filename": "matrix.js", - "lineno": 938, + "lineno": 941, "columnno": 11, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4841,11 +4841,11 @@ "comment": "", "meta": { "range": [ - 20963, - 20991 + 21418, + 21446 ], "filename": "matrix.js", - "lineno": 939, + "lineno": 942, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4865,10 +4865,10 @@ "scope": "inner" }, { - "comment": "/**\n * @memberOf Matrix\n * @member dimension\n * @instance\n * @see rank\n * @returns {Number}\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#dimension\n * @instance\n * @see rank\n * @returns {Number}\n */", "meta": { "filename": "matrix.js", - "lineno": 944, + "lineno": 947, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -4895,11 +4895,11 @@ "comment": "", "meta": { "range": [ - 21111, - 21176 + 21573, + 21638 ], "filename": "matrix.js", - "lineno": 951, + "lineno": 954, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4917,10 +4917,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @member diag\n * @instance\n * @desc Returns an array containing the values on the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diag()\n * // [1, 1, 1]\n *\n * const diag0 = Matrix.zeros(5, 5).diag()\n * // [0, 0, 0, 0, 0]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#diag\n * @instance\n * @desc Returns an array containing the values on the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diag()\n * // [1, 1, 1]\n *\n * const diag0 = Matrix.zeros(5, 5).diag()\n * // [0, 0, 0, 0, 0]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 955, + "lineno": 958, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -4948,11 +4948,11 @@ "comment": "", "meta": { "range": [ - 21463, - 21588 + 21932, + 22057 ], "filename": "matrix.js", - "lineno": 970, + "lineno": 973, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -4973,10 +4973,10 @@ "scope": "instance" }, { - "comment": "/**\n * @memberOf Matrix\n * @function diag\n * @desc Returns an array containing the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.diag([[2, 1], [1, 5]])\n * // [2, 5]\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @function Matrix.diag\n * @desc Returns an array containing the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.diag([[2, 1], [1, 5]])\n * // [2, 5]\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 976, + "lineno": 979, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -5009,18 +5009,18 @@ "examples": [ "const diag1 = Matrix.diag([[2, 1], [1, 5]])\n// [2, 5]" ], - "scope": "static", - "longname": "Matrix.diag" + "longname": "Matrix.diag", + "scope": "static" }, { "comment": "", "meta": { "range": [ - 21866, - 21925 + 22342, + 22401 ], "filename": "matrix.js", - "lineno": 988, + "lineno": 991, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5040,10 +5040,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @member diagproduct\n * @instance\n * @desc Returns the product of the values on the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diagproduct()\n * // 1\n *\n * const diag0 = Matrix.zeros(5, 5).diagproduct()\n * // 0\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#diagproduct\n * @instance\n * @desc Returns the product of the values on the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diagproduct()\n * // 1\n *\n * const diag0 = Matrix.zeros(5, 5).diagproduct()\n * // 0\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 992, + "lineno": 995, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -5071,11 +5071,11 @@ "comment": "", "meta": { "range": [ - 22207, - 22341 + 22690, + 22824 ], "filename": "matrix.js", - "lineno": 1007, + "lineno": 1010, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5099,11 +5099,11 @@ "comment": "", "meta": { "range": [ - 22289, - 22302 + 22772, + 22785 ], "filename": "matrix.js", - "lineno": 1009, + "lineno": 1012, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5123,10 +5123,10 @@ "scope": "inner" }, { - "comment": "/**\n * @memberOf Matrix\n * @function diagproduct\n * @desc Returns the product of the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.diagproduct([[2, 1], [1, 5]])\n * // 10\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @function Matrix.diagproduct\n * @desc Returns the product of the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.diagproduct([[2, 1], [1, 5]])\n * // 10\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 1014, + "lineno": 1017, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -5159,18 +5159,18 @@ "examples": [ "const diag1 = Matrix.diagproduct([[2, 1], [1, 5]])\n// 10" ], - "scope": "static", - "longname": "Matrix.diagproduct" + "longname": "Matrix.diagproduct", + "scope": "static" }, { "comment": "", "meta": { "range": [ - 22625, - 22698 + 23115, + 23188 ], "filename": "matrix.js", - "lineno": 1026, + "lineno": 1029, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5190,10 +5190,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @member sum\n * @instance\n * @desc Returns the sum of the values in the Matrix\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).sum()\n * // 9\n *\n * const diag0 = Matrix.zeros(5, 5).sum()\n * // 0\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#sum\n * @instance\n * @desc Returns the sum of the values in the Matrix\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).sum()\n * // 9\n *\n * const diag0 = Matrix.zeros(5, 5).sum()\n * // 0\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 1030, + "lineno": 1033, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -5221,11 +5221,11 @@ "comment": "", "meta": { "range": [ - 22950, - 23104 + 23447, + 23601 ], "filename": "matrix.js", - "lineno": 1045, + "lineno": 1048, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5249,11 +5249,11 @@ "comment": "", "meta": { "range": [ - 23019, - 23065 + 23516, + 23562 ], "filename": "matrix.js", - "lineno": 1047, + "lineno": 1050, "columnno": 4, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5273,10 +5273,10 @@ "scope": "inner" }, { - "comment": "/**\n * @memberOf Matrix\n * @function sum\n * @desc Returns the sum of the values in the Matrix\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.sum([[2, 1], [1, 5]])\n * // 9\n *\n */", + "comment": "/**\n * @memberOf Matrix\n * @function Matrix.sum\n * @desc Returns the sum of the values in the Matrix\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.sum([[2, 1], [1, 5]])\n * // 9\n *\n */", "meta": { "filename": "matrix.js", - "lineno": 1052, + "lineno": 1055, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -5309,18 +5309,18 @@ "examples": [ "const diag1 = Matrix.sum([[2, 1], [1, 5]])\n// 9" ], - "scope": "static", - "longname": "Matrix.sum" + "longname": "Matrix.sum", + "scope": "static" }, { "comment": "", "meta": { "range": [ - 23365, - 23422 + 23869, + 23926 ], "filename": "matrix.js", - "lineno": 1064, + "lineno": 1067, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5340,10 +5340,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @member kronecker\n * @instance\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param M {Matrix} The right side Matrix of the product (this ⊗ M)\n * @returns {Matrix}\n */", + "comment": "/**\n * @memberOf Matrix\n * @member Matrix#kronecker\n * @instance\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param M {Matrix} The right side Matrix of the product (this ⊗ M)\n * @returns {Matrix}\n */", "meta": { "filename": "matrix.js", - "lineno": 1068, + "lineno": 1071, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -5379,11 +5379,11 @@ "comment": "", "meta": { "range": [ - 23686, - 24188 + 24197, + 24700 ], "filename": "matrix.js", - "lineno": 1076, + "lineno": 1079, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5420,11 +5420,11 @@ "comment": "", "meta": { "range": [ - 23738, - 23756 + 24249, + 24267 ], "filename": "matrix.js", - "lineno": 1077, + "lineno": 1080, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5446,11 +5446,11 @@ "comment": "", "meta": { "range": [ - 23765, - 23783 + 24276, + 24294 ], "filename": "matrix.js", - "lineno": 1078, + "lineno": 1081, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5472,11 +5472,11 @@ "comment": "", "meta": { "range": [ - 23792, - 23807 + 24303, + 24318 ], "filename": "matrix.js", - "lineno": 1079, + "lineno": 1082, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5498,11 +5498,11 @@ "comment": "", "meta": { "range": [ - 23816, - 23831 + 24327, + 24342 ], "filename": "matrix.js", - "lineno": 1080, + "lineno": 1083, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5524,11 +5524,11 @@ "comment": "", "meta": { "range": [ - 23841, - 23860 + 24352, + 24371 ], "filename": "matrix.js", - "lineno": 1082, + "lineno": 1085, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5550,11 +5550,11 @@ "comment": "", "meta": { "range": [ - 23869, - 23886 + 24380, + 24397 ], "filename": "matrix.js", - "lineno": 1083, + "lineno": 1086, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5576,11 +5576,11 @@ "comment": "", "meta": { "range": [ - 23896, - 23926 + 24407, + 24437 ], "filename": "matrix.js", - "lineno": 1085, + "lineno": 1088, "columnno": 8, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5602,11 +5602,11 @@ "comment": "", "meta": { "range": [ - 23939, - 23944 + 24450, + 24455 ], "filename": "matrix.js", - "lineno": 1087, + "lineno": 1090, "columnno": 11, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5628,11 +5628,11 @@ "comment": "", "meta": { "range": [ - 23973, - 23978 + 24484, + 24489 ], "filename": "matrix.js", - "lineno": 1088, + "lineno": 1091, "columnno": 13, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5654,11 +5654,11 @@ "comment": "", "meta": { "range": [ - 24009, - 24014 + 24520, + 24525 ], "filename": "matrix.js", - "lineno": 1089, + "lineno": 1092, "columnno": 15, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5680,11 +5680,11 @@ "comment": "", "meta": { "range": [ - 24047, - 24052 + 24558, + 24563 ], "filename": "matrix.js", - "lineno": 1090, + "lineno": 1093, "columnno": 17, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5706,11 +5706,11 @@ "comment": "", "meta": { "range": [ - 24078, - 24132 + 24589, + 24643 ], "filename": "matrix.js", - "lineno": 1091, + "lineno": 1094, "columnno": 10, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5730,10 +5730,10 @@ "scope": "static" }, { - "comment": "/**\n * @memberOf Matrix\n * @function kronecker\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param A {Matrix} The left side Matrix of the product (A ⊗ B)\n * @param B {Matrix} The right side Matrix of the product (A ⊗ B)\n * @returns {Matrix}\n */", + "comment": "/**\n * @memberOf Matrix\n * @function Matrix.kronecker\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param A {Matrix} The left side Matrix of the product (A ⊗ B)\n * @param B {Matrix} The right side Matrix of the product (A ⊗ B)\n * @returns {Matrix}\n */", "meta": { "filename": "matrix.js", - "lineno": 1099, + "lineno": 1103, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": {} @@ -5771,18 +5771,18 @@ } } ], - "scope": "static", - "longname": "Matrix.kronecker" + "longname": "Matrix.kronecker", + "scope": "static" }, { "comment": "", "meta": { "range": [ - 24503, - 24576 + 25022, + 25095 ], "filename": "matrix.js", - "lineno": 1107, + "lineno": 1111, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { @@ -5806,11 +5806,11 @@ "comment": "", "meta": { "range": [ - 24578, - 24599 + 25097, + 25118 ], "filename": "matrix.js", - "lineno": 1111, + "lineno": 1115, "columnno": 0, "path": "/Volumes/BigOne/github/funMatrix/src", "code": { diff --git a/docs/Matrix.html b/docs/Matrix.html index c01c8db..df49cd7 100644 --- a/docs/Matrix.html +++ b/docs/Matrix.html @@ -24,7 +24,7 @@
@@ -101,7 +101,7 @@

new MatrixSource:
@@ -167,74 +167,6 @@

Members

-
-

add

- - - - - - - - -
- - - - - - - - - - - - - - - - - - - - - - - - - - -
Source:
-
- - - - - - - -
- - - - - - - -
Example
- -
const A = Matrix.of([[5, 4]])
-A.add(1) // [[6, 5]]
-const B = Matrix.of([[5, 5]])
-B.add(B) // [[10, 10]]
- - -
- - -

additiveinverse

@@ -278,7 +210,7 @@

additi
Source:
@@ -349,7 +281,7 @@

apSource:
@@ -421,7 +353,7 @@

cloneSource:
@@ -481,7 +413,7 @@

combineSource:
@@ -552,7 +484,7 @@

concatSource:
@@ -626,7 +558,7 @@

diagSource:
@@ -699,7 +631,7 @@

diagproduc
Source:
@@ -768,7 +700,7 @@

dimensionSource:
@@ -839,7 +771,7 @@

dotSource:
@@ -916,7 +848,7 @@

emptySource:
@@ -976,7 +908,7 @@

equalsSource:
@@ -1048,7 +980,7 @@

fillSource:
@@ -1118,7 +1050,7 @@

foldSource:
@@ -1189,7 +1121,7 @@

fromArraySource:
@@ -1249,7 +1181,7 @@

getColsSource:
@@ -1315,7 +1247,7 @@

getRowsSource:
@@ -1381,7 +1313,7 @@

getShapeSource:
@@ -1447,7 +1379,7 @@

hadamardSource:
@@ -1526,7 +1458,7 @@

identitySource:
@@ -1594,7 +1526,7 @@

inverseSource:
@@ -1660,7 +1592,7 @@

isOrthogo
Source:
@@ -1731,7 +1663,7 @@

isSquareSource:
@@ -1797,7 +1729,7 @@

isSymmetri
Source:
@@ -1867,7 +1799,7 @@

kroneckerSource:
@@ -1931,7 +1863,7 @@

luSource:
@@ -2005,7 +1937,7 @@

mapSource:
@@ -2076,7 +2008,7 @@

multiplySource:
@@ -2148,7 +2080,7 @@

onesSource:
@@ -2268,7 +2200,7 @@
Properties:
Source:
@@ -2348,7 +2280,7 @@

randomSource:
@@ -2408,7 +2340,7 @@

rankSource:
@@ -2468,7 +2400,7 @@

rrefSource:
@@ -2534,7 +2466,7 @@

setPrecis
Source:
@@ -2601,7 +2533,7 @@

solveSource:
@@ -2674,7 +2606,7 @@

subtractSource:
@@ -2746,7 +2678,7 @@

sumSource:
@@ -2819,7 +2751,7 @@

toArraySource:
@@ -2883,7 +2815,7 @@

transposeSource:
@@ -3004,7 +2936,7 @@
Properties:
Source:
@@ -3084,7 +3016,7 @@

zerosSource:
@@ -3117,6 +3049,171 @@

Methods

+
+ + + +

(static) add(M) → {Matrix}

+ + + + + + + + + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
Source:
+
+ + + + + + + +
+ + + + + + + + + +
Parameters:
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameTypeDescription
M + + +Matrix +| + +number + + + + + Add a Matrix or a number + +
+ + + + + + + + + + + + + + +
+
Returns:
+ + + +
+
+ Type: +
+
+ +Matrix + + +
+
+ + + +
+ + + +
+
Example
+ +
const A = Matrix.of([[5, 4]])
+A.add(1) // [[6, 5]]
+const B = Matrix.of([[5, 5]])
+B.add(B) // [[10, 10]]
+ +
+ +
+ +
@@ -3164,7 +3261,7 @@

(static) apSource:
@@ -3354,7 +3451,7 @@

(static) comb
Source:
@@ -3512,7 +3609,7 @@

(static) conca
Source:
@@ -3706,7 +3803,7 @@

(static) diagSource:
@@ -3873,7 +3970,7 @@

(static)
Source:
@@ -4040,7 +4137,7 @@

(static) dotSource:
@@ -4204,7 +4301,7 @@

(static) empty<
Source:
@@ -4386,7 +4483,7 @@

(static) foldSource:
@@ -4579,7 +4676,7 @@

(static) ide
Source:
@@ -4691,7 +4788,7 @@

(static) kr
Source:
@@ -4873,7 +4970,7 @@

(static) mapSource:
@@ -5066,7 +5163,7 @@

(static) ofSource:
@@ -5232,7 +5329,7 @@

(static) onesSource:
@@ -5422,7 +5519,7 @@

(static) rando
Source:
@@ -5630,7 +5727,7 @@

(static) sumSource:
@@ -5797,7 +5894,7 @@

(static) tr
Source:
@@ -5965,7 +6062,7 @@

(static) zeros<
Source:
@@ -6124,7 +6221,7 @@

Example

- Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
diff --git a/docs/global.html b/docs/global.html index 0416bd3..437a09b 100644 --- a/docs/global.html +++ b/docs/global.html @@ -24,7 +24,7 @@
@@ -1235,7 +1235,7 @@
Returns:

- Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
diff --git a/docs/index.html b/docs/index.html index 2793897..667efbf 100644 --- a/docs/index.html +++ b/docs/index.html @@ -24,7 +24,7 @@
@@ -51,7 +51,7 @@

funmatrix

Matrix applicative providing standard matrix operations Fork on Github

Build Status Code Climate GitHub file size in bytes Check bundle size on bundlephobia

Docs

The documentation is done using jsdocs and can be found in the /docs folder or at the url https://astuanax.github.io/funmatrix/

-

Install funmatrix.js

$ npm install @astuanax/funmatrix.js --save

+

Install funmatrix.js

$ npm install @astuanax/funmatrix --save

Example

// Create matrix
 const m = Matrix.of([[1, 2], [3, 4]])
 
@@ -113,7 +113,7 @@ 

Methods and properties


    - Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
    diff --git a/docs/matrix.js.html b/docs/matrix.js.html index 138820b..92b00d2 100644 --- a/docs/matrix.js.html +++ b/docs/matrix.js.html @@ -24,7 +24,7 @@
    @@ -43,12 +43,15 @@

    matrix.js

    import map from 'fun.js/src/map' import fold from 'fun.js/src/fold' import equals from 'fun.js/src/equals' -import concat from 'util/concat' -import empty from 'util/empty' -import dot from 'util/dot' -import identity from 'util/identity' -import transpose from 'util/transpose' -import generate from 'util/generate' +import concat from './util/concat' +import empty from './util/empty' +import dot from './util/dot' +import identity from './util/identity' +import transpose from './util/transpose' +import generate from './util/generate' +// import gpumap from 'util/gpumap' +// import gpufold from 'util/gpufold' +// import gpuproduct from 'util/gpuproduct' /** * @class Matrix @@ -65,6 +68,27 @@

    matrix.js

    this.__value = val } +/** + * @memberOf Matrix + * @static + * @function Matrix.of + * @desc Creates a Matrix object and flattens the Matrix + * @param val {array|function} An array of arrays + * @returns {Matrix} + * @example + * + * const m = Matrix.of([[1,2],[2,3],[4,5]]) + * + */ +Matrix.of = function (val) { + if (val instanceof Matrix) return val + if (this instanceof Matrix) { + this.__value = val + return this + } + return new Matrix(val) +} + /** * @memberOf Matrix * @property {string} type @@ -90,7 +114,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member setPrecision + * @member Matrix#setPrecision * @param precision {number} Set the number of decimals for rounding * @example * @@ -122,7 +146,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member isSquare + * @member Matrix#isSquare * @desc Boolean indicating whether this contains a square Matrix * @returns {boolean} * @example @@ -138,7 +162,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member isOrthogonal + * @member Matrix#isOrthogonal * @param M {Matrix|array} * @returns {boolean} * @example @@ -156,7 +180,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member getCols + * @member Matrix#getCols * @returns {Number} * @example * @@ -171,7 +195,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member equals + * @member Matrix#equals * @param M {Matrix|array} * @returns {Boolean} * @example @@ -188,7 +212,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member getRows + * @member Matrix#getRows * @returns {Number} * @example * @@ -202,7 +226,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member getShape + * @member Matrix#getShape * @returns {Array} * @example * @@ -213,31 +237,10 @@

    matrix.js

    return [this.getRows(), this.getCols()] } -/** - * @memberOf Matrix - * @static - * @function of - * @desc Creates a Matrix object and flattens the Matrix - * @param val {array|function} An array of arrays - * @returns {Matrix} - * @example - * - * const m = Matrix.of([[1,2],[2,3],[4,5]]) - * - */ -Matrix.of = function (val) { - if (val instanceof Matrix) return val - if (this instanceof Matrix) { - this.__value = val - return this - } - return new Matrix(val) -} - /** * @memberOf Matrix * @instance - * @member map + * @member Matrix#map * @description Maps over the rows of the matrix using a map function * @param f {function} An iterator function * @returns {Matrix} @@ -255,7 +258,7 @@

    matrix.js

    /** * @memberOf Matrix * @static - * @function map + * @function Matrix.map * @description Static function that maps over the rows of the matrix using a map function * @param f {function} An iterator function * @param M {Matrix|array} Matrix or array to map @@ -273,7 +276,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member fold + * @member Matrix#fold * @description Reduce the matrix rows using a reduce function * @param f {function} A reduce/fold function * @returns {Matrix} @@ -290,7 +293,7 @@

    matrix.js

    /** * @memberOf Matrix * @static - * @function fold + * @function Matrix.fold * @description Static function to reduce the matrix rows using a reduce function * @param f {function} A reduce/fold function * @param M {Matrix} The Matrix to reduce @@ -310,7 +313,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member ap + * @member Matrix#ap * @description Applies a Matrix to a function * @param M {Matrix} * @returns {Matrix} @@ -328,7 +331,7 @@

    matrix.js

    /** * @memberOf Matrix * @static - * @function ap + * @function Matrix.ap * @description Applies a Matrix to a function * @param f {function} * @param M {Matrix|array} @@ -346,7 +349,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member concat + * @member Matrix#concat * @description Concatenates 2 Matrices using a function as operator * @param M {Matrix} * @returns {Matrix} @@ -367,7 +370,7 @@

    matrix.js

    /** * @memberOf Matrix * @static - * @function concat + * @function Matrix.concat * @description Concatenates 2 Matrices using a function as operator * @param A {Matrix} * @param B {Matrix} @@ -389,7 +392,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member empty + * @member Matrix#empty * @description Return an empty Matrix from an existing Matrix * @returns {Matrix} */ @@ -400,7 +403,7 @@

    matrix.js

    /** * @memberOf Matrix * @static - * @function empty + * @function Matrix.empty * @description Return an empty Matrix from an existing Matrix * @param rows {number} * @param cols {number} @@ -416,7 +419,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member identity + * @member Matrix#identity * @desc Returns an identity matrix * @returns {Matrix} * @example @@ -426,7 +429,7 @@

    matrix.js

    * const Aidentity = A.identity() * // [[1, 0, 0], [0, 1, 0]] * -*/ + */ Matrix.prototype.identity = function () { return Matrix.of(identity).ap(this) } @@ -434,7 +437,7 @@

    matrix.js

    /** * @memberOf Matrix * @static - * @function identity + * @function Matrix.identity * @desc Returns an identity matrix * @returns {Matrix} * @example @@ -451,7 +454,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member combine + * @member Matrix#combine * @see Matrix.concat * @param M * @returns {Matrix} @@ -463,7 +466,7 @@

    matrix.js

    /** * @memberOf Matrix * @static - * @function combine + * @function Matrix.combine * @see Matrix.concat * @param M * @returns {Matrix} @@ -475,7 +478,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member dot + * @member Matrix#dot * @description Returns the dot product between 2 matrices * @param M * @param f @@ -500,7 +503,7 @@

    matrix.js

    /** * @memberOf Matrix * @static - * @function dot + * @function Matrix.dot * @description Returns the dot product between 2 matrices * @param M * @returns {Matrix} @@ -521,7 +524,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member fill + * @member Matrix#fill * @desc Fill up an empty matrix with the provided map function * @param f * @returns {Matrix} @@ -538,7 +541,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member zeros + * @member Matrix#zeros * @desc Fill up an empty matrix with zeros * @returns {Matrix} * @@ -554,7 +557,7 @@

    matrix.js

    /** * @memberOf Matrix - * @function zeros + * @function Matrix.zeros * @desc Fill up an empty matrix with zeros * @param rows {number} Defines the rows of the matrix * @param cols {number} Defines the columns of the matrix @@ -573,7 +576,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member ones + * @member Matrix#ones * @desc Fill up an empty matrix with ones * @returns {Matrix} * @example @@ -588,7 +591,7 @@

    matrix.js

    /** * @memberOf Matrix - * @function ones + * @function Matrix.ones * @desc Fill up an empty matrix with ones * @param rows {number} Defines the rows of the matrix * @param cols {number} Defines the columns of the matrix @@ -607,7 +610,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member random + * @member Matrix#random * @desc Fill up an empty matrix with random values * @param {function} [f = e => Math.random() * 2 - 1] * @returns {Matrix} @@ -618,7 +621,7 @@

    matrix.js

    /** * @memberOf Matrix - * @function random + * @function Matrix.random * @desc Fill up an empty matrix with random numbers * @param f {function} Function which returns random values. Default random values are between -1 and 1 * @param rows {number} Defines the rows of the matrix @@ -633,7 +636,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member toArray + * @member Matrix#toArray * @desc Returns the array from the matrix * @returns {Array} */ @@ -644,7 +647,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member clone + * @member Matrix#clone * @desc Returns a clone of the matrix * @returns {Matrix} */ @@ -655,7 +658,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member fromArray + * @member Matrix#fromArray * @desc Returns a Matrix from an array * @returns {Array} */ @@ -666,7 +669,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member transpose + * @member Matrix#transpose * @desc Returns a transposed Matrix * @returns {Matrix} * @example @@ -681,7 +684,7 @@

    matrix.js

    /** * @memberOf Matrix - * @function transpose + * @function Matrix.transpose * @desc Returns a transposed Matrix * @param M {Matrix|array} A Matrix or a matrix array * @returns {Matrix} @@ -697,7 +700,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member add + * @function Matrix.add * @instance * @param M {Matrix|number} Add a Matrix or a number * @returns {Matrix} @@ -722,7 +725,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member subtract + * @member Matrix#subtract * @instance * @param M {Matrix|number} Subtract a Matrix or a number * @returns {Matrix} @@ -747,7 +750,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member multiply + * @member Matrix#multiply * @instance * @desc Mutliply a scalar or a mtraix with a matrix. Throws an error if the multiplication is not possible. * @param M {Matrix|number} @@ -774,7 +777,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member additiveinverse + * @member Matrix#additiveinverse * @instance * @desc Function that returns the matrix obtained by changing the sign of every matrix element. The additive inverse of matrix A is written –A. * @returns {Matrix} @@ -790,7 +793,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member hadamard + * @member Matrix#hadamard * @instance * @see multiply * @param M @@ -810,7 +813,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member lu + * @member Matrix#lu * @desc Calculates LU decomposition of the current Matrix * @returns {Matrix[]} * @example @@ -849,7 +852,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member rref + * @member Matrix#rref * @returns {Matrix|array} * @example * @@ -900,7 +903,7 @@

    matrix.js

    /** * @memberOf Matrix * @instance - * @member solve + * @member Matrix#solve * @param b * @returns {Array} * @example @@ -945,7 +948,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member inverse + * @member Matrix#inverse * @instance * @returns {Matrix} * @example @@ -969,7 +972,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member rank + * @member Matrix#rank * @instance * @returns {Number} */ @@ -984,7 +987,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member dimension + * @member Matrix#dimension * @instance * @see rank * @returns {Number} @@ -995,7 +998,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member diag + * @member Matrix#diag * @instance * @desc Returns an array containing the values on the diagonal * @returns {Array} @@ -1016,7 +1019,7 @@

    matrix.js

    /** * @memberOf Matrix - * @function diag + * @function Matrix.diag * @desc Returns an array containing the values on the diagonal * @param M {Matrix|Array} Matrix from which to return the diagonal * @returns {Array} @@ -1032,7 +1035,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member diagproduct + * @member Matrix#diagproduct * @instance * @desc Returns the product of the values on the diagonal * @returns {Number} @@ -1054,7 +1057,7 @@

    matrix.js

    /** * @memberOf Matrix - * @function diagproduct + * @function Matrix.diagproduct * @desc Returns the product of the values on the diagonal * @param M {Matrix|Array} Matrix from which to return the diagonal * @returns {Number} @@ -1070,7 +1073,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member sum + * @member Matrix#sum * @instance * @desc Returns the sum of the values in the Matrix * @returns {Number} @@ -1092,7 +1095,7 @@

    matrix.js

    /** * @memberOf Matrix - * @function sum + * @function Matrix.sum * @desc Returns the sum of the values in the Matrix * @param M {Matrix|Array} Matrix from which to return the diagonal * @returns {Number} @@ -1108,7 +1111,7 @@

    matrix.js

    /** * @memberOf Matrix - * @member kronecker + * @member Matrix#kronecker * @instance * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix. * @param M {Matrix} The right side Matrix of the product (this ⊗ M) @@ -1125,21 +1128,22 @@

    matrix.js

    const frame = generate(m * p, n * q) - for (var i = 0; i < m; i++) { - for (var j = 0; j < n; j++) { - for (var k = 0; k < p; k++) { - for (var l = 0; l < q; l++) { + for (let i = 0; i < m; i++) { + for (let j = 0; j < n; j++) { + for (let k = 0; k < p; k++) { + for (let l = 0; l < q; l++) { frame[p * i + k][q * j + l] = left[i][j] * right[k][l] } } } } + return Matrix.of(frame) } /** * @memberOf Matrix - * @function kronecker + * @function Matrix.kronecker * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix. * @param A {Matrix} The left side Matrix of the product (A ⊗ B) * @param B {Matrix} The right side Matrix of the product (A ⊗ B) @@ -1162,7 +1166,7 @@

    matrix.js


    - Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
    diff --git a/docs/util_concat.js.html b/docs/util_concat.js.html index 692611d..5f6417b 100644 --- a/docs/util_concat.js.html +++ b/docs/util_concat.js.html @@ -24,7 +24,7 @@
    @@ -64,7 +64,7 @@

    util/concat.js


    - Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
    diff --git a/docs/util_dot.js.html b/docs/util_dot.js.html index dcd31e8..930cacb 100644 --- a/docs/util_dot.js.html +++ b/docs/util_dot.js.html @@ -24,7 +24,7 @@
    @@ -68,7 +68,7 @@

    util/dot.js


    - Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
    diff --git a/docs/util_generate.js.html b/docs/util_generate.js.html index 851dad0..ab5e9c0 100644 --- a/docs/util_generate.js.html +++ b/docs/util_generate.js.html @@ -24,7 +24,7 @@
    @@ -59,7 +59,7 @@

    util/generate.js


    - Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
    diff --git a/docs/util_identity.js.html b/docs/util_identity.js.html index fd7a879..44c3f79 100644 --- a/docs/util_identity.js.html +++ b/docs/util_identity.js.html @@ -24,7 +24,7 @@
    @@ -61,7 +61,7 @@

    util/identity.js


    - Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
    diff --git a/docs/util_round.js.html b/docs/util_round.js.html index daab8f4..e873035 100644 --- a/docs/util_round.js.html +++ b/docs/util_round.js.html @@ -24,7 +24,7 @@
    @@ -60,7 +60,7 @@

    util/round.js


    - Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
    diff --git a/docs/util_transpose.js.html b/docs/util_transpose.js.html index 510f805..391d9f9 100644 --- a/docs/util_transpose.js.html +++ b/docs/util_transpose.js.html @@ -24,7 +24,7 @@
    @@ -62,7 +62,7 @@

    util/transpose.js


    - Generated by JSDoc 3.5.5 on Sun May 12 2019 14:39:34 GMT+0200 (Central European Summer Time) using the Minami theme. + Generated by JSDoc 3.5.5 on Wed May 29 2019 20:43:29 GMT+0200 (Central European Summer Time) using the Minami theme.
    diff --git a/lib/@astuanax/funmatrix.js b/lib/@astuanax/funmatrix.js index 5f17b20..51a82d5 100644 --- a/lib/@astuanax/funmatrix.js +++ b/lib/@astuanax/funmatrix.js @@ -1234,20 +1234,24 @@ var _fold = _interopRequireDefault(__webpack_require__(/*! fun.js/src/fold */ ". var _equals = _interopRequireDefault(__webpack_require__(/*! fun.js/src/equals */ "./node_modules/fun.js/src/equals.js")); -var _concat = _interopRequireDefault(__webpack_require__(/*! util/concat */ "./src/util/concat.js")); +var _concat = _interopRequireDefault(__webpack_require__(/*! ./util/concat */ "./src/util/concat.js")); -var _empty = _interopRequireDefault(__webpack_require__(/*! util/empty */ "./src/util/empty.js")); +var _empty = _interopRequireDefault(__webpack_require__(/*! ./util/empty */ "./src/util/empty.js")); -var _dot = _interopRequireDefault(__webpack_require__(/*! util/dot */ "./src/util/dot.js")); +var _dot = _interopRequireDefault(__webpack_require__(/*! ./util/dot */ "./src/util/dot.js")); -var _identity = _interopRequireDefault(__webpack_require__(/*! util/identity */ "./src/util/identity.js")); +var _identity = _interopRequireDefault(__webpack_require__(/*! ./util/identity */ "./src/util/identity.js")); -var _transpose = _interopRequireDefault(__webpack_require__(/*! util/transpose */ "./src/util/transpose.js")); +var _transpose = _interopRequireDefault(__webpack_require__(/*! ./util/transpose */ "./src/util/transpose.js")); -var _generate = _interopRequireDefault(__webpack_require__(/*! util/generate */ "./src/util/generate.js")); +var _generate = _interopRequireDefault(__webpack_require__(/*! ./util/generate */ "./src/util/generate.js")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } +// import gpumap from 'util/gpumap' +// import gpufold from 'util/gpufold' +// import gpuproduct from 'util/gpuproduct' + /** * @class Matrix * @classdesc Matrix applicative providing standard matrix operations @@ -1262,6 +1266,30 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de var Matrix = function Matrix(val) { this.__value = val; }; +/** + * @memberOf Matrix + * @static + * @function Matrix.of + * @desc Creates a Matrix object and flattens the Matrix + * @param val {array|function} An array of arrays + * @returns {Matrix} + * @example + * + * const m = Matrix.of([[1,2],[2,3],[4,5]]) + * + */ + + +Matrix.of = function (val) { + if (val instanceof Matrix) return val; + + if (this instanceof Matrix) { + this.__value = val; + return this; + } + + return new Matrix(val); +}; /** * @memberOf Matrix * @property {string} type @@ -1288,7 +1316,7 @@ Matrix.prototype.precision = 4; /** * @memberOf Matrix * @instance - * @member setPrecision + * @member Matrix#setPrecision * @param precision {number} Set the number of decimals for rounding * @example * @@ -1323,7 +1351,7 @@ Matrix.prototype.isSymmetric = function () { /** * @memberOf Matrix * @instance - * @member isSquare + * @member Matrix#isSquare * @desc Boolean indicating whether this contains a square Matrix * @returns {boolean} * @example @@ -1340,7 +1368,7 @@ Matrix.prototype.isSquare = function () { /** * @memberOf Matrix * @instance - * @member isOrthogonal + * @member Matrix#isOrthogonal * @param M {Matrix|array} * @returns {boolean} * @example @@ -1359,7 +1387,7 @@ Matrix.prototype.isOrthogonal = function () { /** * @memberOf Matrix * @instance - * @member getCols + * @member Matrix#getCols * @returns {Number} * @example * @@ -1375,7 +1403,7 @@ Matrix.prototype.getCols = function () { /** * @memberOf Matrix * @instance - * @member equals + * @member Matrix#equals * @param M {Matrix|array} * @returns {Boolean} * @example @@ -1393,7 +1421,7 @@ Matrix.prototype.equals = function (M) { /** * @memberOf Matrix * @instance - * @member getRows + * @member Matrix#getRows * @returns {Number} * @example * @@ -1408,7 +1436,7 @@ Matrix.prototype.getRows = function () { /** * @memberOf Matrix * @instance - * @member getShape + * @member Matrix#getShape * @returns {Array} * @example * @@ -1420,34 +1448,10 @@ Matrix.prototype.getRows = function () { Matrix.prototype.getShape = function () { return [this.getRows(), this.getCols()]; }; -/** - * @memberOf Matrix - * @static - * @function of - * @desc Creates a Matrix object and flattens the Matrix - * @param val {array|function} An array of arrays - * @returns {Matrix} - * @example - * - * const m = Matrix.of([[1,2],[2,3],[4,5]]) - * - */ - - -Matrix.of = function (val) { - if (val instanceof Matrix) return val; - - if (this instanceof Matrix) { - this.__value = val; - return this; - } - - return new Matrix(val); -}; /** * @memberOf Matrix * @instance - * @member map + * @member Matrix#map * @description Maps over the rows of the matrix using a map function * @param f {function} An iterator function * @returns {Matrix} @@ -1466,7 +1470,7 @@ Matrix.prototype.map = function (f) { /** * @memberOf Matrix * @static - * @function map + * @function Matrix.map * @description Static function that maps over the rows of the matrix using a map function * @param f {function} An iterator function * @param M {Matrix|array} Matrix or array to map @@ -1485,7 +1489,7 @@ Matrix.map = (0, _curry.default)(function (f, M) { /** * @memberOf Matrix * @instance - * @member fold + * @member Matrix#fold * @description Reduce the matrix rows using a reduce function * @param f {function} A reduce/fold function * @returns {Matrix} @@ -1502,7 +1506,7 @@ Matrix.prototype.fold = function (f) { /** * @memberOf Matrix * @static - * @function fold + * @function Matrix.fold * @description Static function to reduce the matrix rows using a reduce function * @param f {function} A reduce/fold function * @param M {Matrix} The Matrix to reduce @@ -1523,7 +1527,7 @@ Matrix.fold = (0, _curry.default)(function (f, M) { /** * @memberOf Matrix * @instance - * @member ap + * @member Matrix#ap * @description Applies a Matrix to a function * @param M {Matrix} * @returns {Matrix} @@ -1541,7 +1545,7 @@ Matrix.prototype.ap = function (M) { /** * @memberOf Matrix * @static - * @function ap + * @function Matrix.ap * @description Applies a Matrix to a function * @param f {function} * @param M {Matrix|array} @@ -1560,7 +1564,7 @@ Matrix.ap = (0, _curry.default)(function (f, M) { /** * @memberOf Matrix * @instance - * @member concat + * @member Matrix#concat * @description Concatenates 2 Matrices using a function as operator * @param M {Matrix} * @returns {Matrix} @@ -1582,7 +1586,7 @@ Matrix.prototype.concat = function (M) { /** * @memberOf Matrix * @static - * @function concat + * @function Matrix.concat * @description Concatenates 2 Matrices using a function as operator * @param A {Matrix} * @param B {Matrix} @@ -1606,7 +1610,7 @@ Matrix.concat = (0, _curry.default)(function (A, B) { /** * @memberOf Matrix * @instance - * @member empty + * @member Matrix#empty * @description Return an empty Matrix from an existing Matrix * @returns {Matrix} */ @@ -1617,7 +1621,7 @@ Matrix.prototype.empty = function () { /** * @memberOf Matrix * @static - * @function empty + * @function Matrix.empty * @description Return an empty Matrix from an existing Matrix * @param rows {number} * @param cols {number} @@ -1636,7 +1640,7 @@ Matrix.empty = (0, _curry.default)(function () { /** * @memberOf Matrix * @instance - * @member identity + * @member Matrix#identity * @desc Returns an identity matrix * @returns {Matrix} * @example @@ -1646,7 +1650,7 @@ Matrix.empty = (0, _curry.default)(function () { * const Aidentity = A.identity() * // [[1, 0, 0], [0, 1, 0]] * -*/ + */ Matrix.prototype.identity = function () { return Matrix.of(_identity.default).ap(this); @@ -1654,7 +1658,7 @@ Matrix.prototype.identity = function () { /** * @memberOf Matrix * @static - * @function identity + * @function Matrix.identity * @desc Returns an identity matrix * @returns {Matrix} * @example @@ -1673,7 +1677,7 @@ Matrix.identity = function (rows, cols) { /** * @memberOf Matrix * @instance - * @member combine + * @member Matrix#combine * @see Matrix.concat * @param M * @returns {Matrix} @@ -1686,7 +1690,7 @@ Matrix.prototype.combine = function (M) { /** * @memberOf Matrix * @static - * @function combine + * @function Matrix.combine * @see Matrix.concat * @param M * @returns {Matrix} @@ -1699,7 +1703,7 @@ Matrix.combine = function (A, B) { /** * @memberOf Matrix * @instance - * @member dot + * @member Matrix#dot * @description Returns the dot product between 2 matrices * @param M * @param f @@ -1725,7 +1729,7 @@ Matrix.prototype.dot = function (M) { /** * @memberOf Matrix * @static - * @function dot + * @function Matrix.dot * @description Returns the dot product between 2 matrices * @param M * @returns {Matrix} @@ -1747,7 +1751,7 @@ Matrix.dot = function (A, B) { /** * @memberOf Matrix * @instance - * @member fill + * @member Matrix#fill * @desc Fill up an empty matrix with the provided map function * @param f * @returns {Matrix} @@ -1767,7 +1771,7 @@ Matrix.prototype.fill = function (f) { /** * @memberOf Matrix * @instance - * @member zeros + * @member Matrix#zeros * @desc Fill up an empty matrix with zeros * @returns {Matrix} * @@ -1786,7 +1790,7 @@ Matrix.prototype.zeros = function () { }; /** * @memberOf Matrix - * @function zeros + * @function Matrix.zeros * @desc Fill up an empty matrix with zeros * @param rows {number} Defines the rows of the matrix * @param cols {number} Defines the columns of the matrix @@ -1808,7 +1812,7 @@ Matrix.zeros = function (rows, cols) { /** * @memberOf Matrix * @instance - * @member ones + * @member Matrix#ones * @desc Fill up an empty matrix with ones * @returns {Matrix} * @example @@ -1826,7 +1830,7 @@ Matrix.prototype.ones = function () { }; /** * @memberOf Matrix - * @function ones + * @function Matrix.ones * @desc Fill up an empty matrix with ones * @param rows {number} Defines the rows of the matrix * @param cols {number} Defines the columns of the matrix @@ -1848,7 +1852,7 @@ Matrix.ones = function (rows, cols) { /** * @memberOf Matrix * @instance - * @member random + * @member Matrix#random * @desc Fill up an empty matrix with random values * @param {function} [f = e => Math.random() * 2 - 1] * @returns {Matrix} @@ -1863,7 +1867,7 @@ Matrix.prototype.random = function () { }; /** * @memberOf Matrix - * @function random + * @function Matrix.random * @desc Fill up an empty matrix with random numbers * @param f {function} Function which returns random values. Default random values are between -1 and 1 * @param rows {number} Defines the rows of the matrix @@ -1884,7 +1888,7 @@ Matrix.random = function () { /** * @memberOf Matrix * @instance - * @member toArray + * @member Matrix#toArray * @desc Returns the array from the matrix * @returns {Array} */ @@ -1900,7 +1904,7 @@ Matrix.prototype.toArray = function () { /** * @memberOf Matrix * @instance - * @member clone + * @member Matrix#clone * @desc Returns a clone of the matrix * @returns {Matrix} */ @@ -1912,7 +1916,7 @@ Matrix.prototype.clone = function () { /** * @memberOf Matrix * @instance - * @member fromArray + * @member Matrix#fromArray * @desc Returns a Matrix from an array * @returns {Array} */ @@ -1928,7 +1932,7 @@ Matrix.fromArray = function (arr) { /** * @memberOf Matrix * @instance - * @member transpose + * @member Matrix#transpose * @desc Returns a transposed Matrix * @returns {Matrix} * @example @@ -1944,7 +1948,7 @@ Matrix.prototype.transpose = function () { }; /** * @memberOf Matrix - * @function transpose + * @function Matrix.transpose * @desc Returns a transposed Matrix * @param M {Matrix|array} A Matrix or a matrix array * @returns {Matrix} @@ -1961,7 +1965,7 @@ Matrix.transpose = function (M) { }; /** * @memberOf Matrix - * @member add + * @function Matrix.add * @instance * @param M {Matrix|number} Add a Matrix or a number * @returns {Matrix} @@ -1994,7 +1998,7 @@ Matrix.prototype.add = function (M) { }; /** * @memberOf Matrix - * @member subtract + * @member Matrix#subtract * @instance * @param M {Matrix|number} Subtract a Matrix or a number * @returns {Matrix} @@ -2027,7 +2031,7 @@ Matrix.prototype.subtract = function (M) { }; /** * @memberOf Matrix - * @member multiply + * @member Matrix#multiply * @instance * @desc Mutliply a scalar or a mtraix with a matrix. Throws an error if the multiplication is not possible. * @param M {Matrix|number} @@ -2062,7 +2066,7 @@ Matrix.prototype.multiply = function (M) { }; /** * @memberOf Matrix - * @member additiveinverse + * @member Matrix#additiveinverse * @instance * @desc Function that returns the matrix obtained by changing the sign of every matrix element. The additive inverse of matrix A is written –A. * @returns {Matrix} @@ -2079,7 +2083,7 @@ Matrix.prototype.additiveinverse = function () { }; /** * @memberOf Matrix - * @member hadamard + * @member Matrix#hadamard * @instance * @see multiply * @param M @@ -2100,7 +2104,7 @@ Matrix.prototype.hadamard = function (M) { /** * @memberOf Matrix * @instance - * @member lu + * @member Matrix#lu * @desc Calculates LU decomposition of the current Matrix * @returns {Matrix[]} * @example @@ -2144,7 +2148,7 @@ Matrix.prototype.lu = function () { /** * @memberOf Matrix * @instance - * @member rref + * @member Matrix#rref * @returns {Matrix|array} * @example * @@ -2203,7 +2207,7 @@ Matrix.prototype.rref = function () { /** * @memberOf Matrix * @instance - * @member solve + * @member Matrix#solve * @param b * @returns {Array} * @example @@ -2254,7 +2258,7 @@ Matrix.prototype.solve = function (b) { }; /** * @memberOf Matrix - * @member inverse + * @member Matrix#inverse * @instance * @returns {Matrix} * @example @@ -2280,7 +2284,7 @@ Matrix.prototype.inverse = function () { }; /** * @memberOf Matrix - * @member rank + * @member Matrix#rank * @instance * @returns {Number} */ @@ -2298,7 +2302,7 @@ Matrix.prototype.rank = function () { }; /** * @memberOf Matrix - * @member dimension + * @member Matrix#dimension * @instance * @see rank * @returns {Number} @@ -2310,7 +2314,7 @@ Matrix.prototype.dimension = function () { }; /** * @memberOf Matrix - * @member diag + * @member Matrix#diag * @instance * @desc Returns an array containing the values on the diagonal * @returns {Array} @@ -2332,7 +2336,7 @@ Matrix.prototype.diag = function () { }; /** * @memberOf Matrix - * @function diag + * @function Matrix.diag * @desc Returns an array containing the values on the diagonal * @param M {Matrix|Array} Matrix from which to return the diagonal * @returns {Array} @@ -2349,7 +2353,7 @@ Matrix.diag = function (M) { }; /** * @memberOf Matrix - * @member diagproduct + * @member Matrix#diagproduct * @instance * @desc Returns the product of the values on the diagonal * @returns {Number} @@ -2372,7 +2376,7 @@ Matrix.prototype.diagproduct = function () { }; /** * @memberOf Matrix - * @function diagproduct + * @function Matrix.diagproduct * @desc Returns the product of the values on the diagonal * @param M {Matrix|Array} Matrix from which to return the diagonal * @returns {Number} @@ -2389,7 +2393,7 @@ Matrix.diagproduct = function (M) { }; /** * @memberOf Matrix - * @member sum + * @member Matrix#sum * @instance * @desc Returns the sum of the values in the Matrix * @returns {Number} @@ -2414,7 +2418,7 @@ Matrix.prototype.sum = function () { }; /** * @memberOf Matrix - * @function sum + * @function Matrix.sum * @desc Returns the sum of the values in the Matrix * @param M {Matrix|Array} Matrix from which to return the diagonal * @returns {Number} @@ -2431,7 +2435,7 @@ Matrix.sum = function (M) { }; /** * @memberOf Matrix - * @member kronecker + * @member Matrix#kronecker * @instance * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix. * @param M {Matrix} The right side Matrix of the product (this ⊗ M) @@ -2462,7 +2466,7 @@ Matrix.prototype.kronecker = function (M) { }; /** * @memberOf Matrix - * @function kronecker + * @function Matrix.kronecker * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix. * @param A {Matrix} The left side Matrix of the product (A ⊗ B) * @param B {Matrix} The right side Matrix of the product (A ⊗ B) @@ -2730,4 +2734,4 @@ module.exports = exports["default"]; /******/ }); }); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://@astuanax/funmatrix/webpack/universalModuleDefinition","webpack://@astuanax/funmatrix/webpack/bootstrap","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/_private/curry1.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/and.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/boolean/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/curry.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/date/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/empty.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/exists.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/identical.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/iterator/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/iterator/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/map/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/not.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/number/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/number/isNan.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/keys.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/or.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/type.js","webpack://@astuanax/funmatrix/./src/matrix.js","webpack://@astuanax/funmatrix/./src/util/concat.js","webpack://@astuanax/funmatrix/./src/util/dot.js","webpack://@astuanax/funmatrix/./src/util/empty.js","webpack://@astuanax/funmatrix/./src/util/generate.js","webpack://@astuanax/funmatrix/./src/util/identity.js","webpack://@astuanax/funmatrix/./src/util/round.js","webpack://@astuanax/funmatrix/./src/util/transpose.js"],"names":["Matrix","val","__value","prototype","type","precision","setPrecision","isSymmetric","a","b","transpose","isSquare","getCols","getRows","isOrthogonal","AxAt","dot","I","identity","length","equals","M","getShape","of","map","f","fold","ap","concat","A","B","empty","rows","cols","m","combine","fill","x","zeros","ones","random","e","Math","toArray","row","col","clone","fromArray","arr","add","Error","idx","jdx","subtract","multiply","console","log","additiveinverse","hadamard","lu","n","tol","L","U","k","abs","i","j","l","rref","lead","resultMatrix","r","tmp","solve","LU","s","c","t","inverse","Inv","result","reduce","half","push","slice","rank","dimension","diag","acc","diagproduct","sum","prev","next","kronecker","p","q","left","right","frame","decimals","item","Array","apply","round","value","Number"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;;;;;;AClFA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;;AAEe;AACf;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACbA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,EAAE;AACb,YAAY;AACZ;AAC2B;;AAEZ,qHAAK;AACpB;AACA,CAAC,CAAC;;;;;;;;;;;;;ACfF;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AAC4B;;AAEb,qHAAK;AACpB;AACA,CAAC,CAAC;;;;;;;;;;;;;ACXF;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,EAAE;AACb,YAAY;AACZ;AAC4B;AACJ;AACM;;AAEf,qHAAK;AACpB;AACA;AACA;AACA,iBAAiB,cAAc;AAC/B,QAAQ,oDAAG,CAAC,uDAAM;AAClB;AACA;AACA,CAAC,CAAC;;;;;;;;;;;;;ACpBF;AAAA;AAAA;AACA;AACA;AACA;AACA,WAAW,WAAW;AACtB,WAAW,EAAE;AACb,WAAW,MAAM;AACjB,YAAY;AACZ;AACA;AACA;AAC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","file":"@astuanax/funmatrix.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"@astuanax/funmatrix\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"@astuanax/funmatrix\"] = factory();\n\telse\n\t\troot[\"@astuanax/funmatrix\"] = factory();\n})(typeof self !== 'undefined' ? self : this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/matrix.js\");\n","/**\n * Returns a curried function with arity 1\n * @function curry1\n * @private\n * @since v1.0.2\n **/\n\nexport default function curry1 (fn) {\n  return function curried (a) {\n    return arguments.length === 0\n      ? this\n      : fn(a)\n  }\n}\n","/**\n * Checks if both predicates are true\n *\n * @function and\n * @description Checks if both predicates are true\n * @since v1.0.2\n * @sig (x, y) -> boolean\n * @param {*} x - A predicate\n * @param {*} y - A predicate\n * @return {boolean}\n **/\nimport curry from './curry'\n\nexport default curry(function and (x, y) {\n  return x && y\n})\n","/**\n * @private\n * @function arrayConcat\n * @param a1\n * @param a2\n * @returns {T[]}\n */\nimport curry from '../curry'\n\nexport default curry(function concat (a, b) {\n  return Array.prototype.concat(a, b)\n})\n","/**\n * @private\n * @function equalsArray\n * @description Autocurried function for deep comparison of arrays\n * @param {a} x - Object to compare of type a\n * @param {a} y - Object x to compare with object x\n * @return {boolean}\n */\nimport curry from '../curry'\nimport not from '../not'\nimport equals from '../equals'\n\nexport default curry(function equalsArray (x, y) {\n  if (x.length !== y.length) {\n    return false\n  }\n  for (let i = 0; i < x.length; i++) {\n    if (not(equals(x[i], y[i]))) return false\n  }\n  return true\n})\n","/**\n * @private\n * @function fold\n * @description Returns a single item by mapping over the provided array and calling an iterator function\n * @param {cbFunction} cb - Callback function to modify the item\n * @param {*} init - Initial value\n * @param {Array} a - Array with items to modify by the cb function\n * @return {Array}\n * @alias reduce\n * @since 1.0.2\n * @example\n *\n * const result = fold(add, 0, [1,1,1])\n * // result = 3\n */\n\n/**\n * @callback cbFunction\n * @param {*} r - Accumulator which accumulates the callback's return values\n * @param {*} item - the current element being processed\n * @param {number} index - the indey of the item being processed\n * @param {Array} a - The initial array\n * @return {*}\n */\nimport curry from '../curry'\n\nexport default curry(function fold (cb, init, a) {\n  let i = -1\n  const l = a.length\n  let r = init\n  while (++i < l) {\n    r = cb(r, a[i], i, a)\n  }\n  return r\n})\n","/**\n * Checks if the provided object is an array, autocurried function\n *\n * @private\n * @function isArray\n * @description Checks if the provided object is an array, autocurried function\n * @param {*} Object to verifiy\n * @return {boolean}\n * @since 1.0.2\n * @example\n *\n * const result = isArray([1,1,1])\n * // result = true\n */\n\nimport is from '../is'\n\nexport default is('Array')\n","/**\n * @function map\n * @description Maps over an array and applies a function\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n * @since v1.0.2\n * @example\n *\n *  const result = map(identity, [0,2,3])\n *  // result = [0,2,3]\n *  const add2 = add(2)\n *  const result = map(add2, [0,2,3])\n *  // result = [2,4,5]\n **/\nimport curry from '../curry'\n\nexport default curry(function map (cb, a) {\n  let i = -1\n  const l = a.length\n  const r = new Array(l)\n  while (++i < l) {\n    r[i] = cb(a[i], i, a)\n  }\n  return r\n})\n","/**\n * Curried function that verifies of the provided argument is a boolean\n *\n * @private\n * @function is\n * @description Curried function that verifies of the provided argument is a boolean\n * @since v1.0.2\n * @param {*} Item to verify\n * @return {boolean}\n **/\nimport is from '../is'\n\nexport default is('Boolean')\n","/**\n * Concatenates 2 items together\n *\n * @function concat\n * @description Concatenates 2 items together\n * @since v1.0.4\n * @param {a} a - Left side of the concatenation\n * @param {a} b - right side of the concatenation\n * @return {a} Concatenated item\n **/\n\nimport curry from './curry'\nimport arrayConcat from './array/concat'\nimport stringConcat from './string/concat'\nimport type from './type'\n\nexport default curry(function concat (a, b) {\n  const typeMap = {\n    'String': stringConcat,\n    'Array': arrayConcat\n  }\n  return typeMap[type(a)](a, b)\n})\n","/* eslint-disable no-use-before-define */\n/**\n * @function curry\n * @description Autocurries the provided function\n */\nexport default function curry (fun) {\n  const argslen = fun.length\n\n  if (argslen === 0) {\n    return fun\n  }\n  return createRecurser([])\n\n  function recurse (acc, args) {\n    const _acc = acc.concat(args)\n    return _acc.length < argslen\n      ? createRecurser(_acc)\n      : fun.apply(this, _acc)\n  }\n\n  function createRecurser (acc) {\n    return function () {\n      return recurse(acc, Array.prototype.slice.call(arguments))\n    }\n  }\n}\n","/**\n * Created by dierickx.len on 01/04/2017.\n */\n/**\n * Created by dierickx.len on 01/04/2017.\n */\nimport is from '../is'\n\nexport default is('Date')\n","/**\n\n * @function empty\n * @description Returns the empty equivalent of the first argument\n */\n\nexport default function empty (x) {\n  return new x.constructor()\n};\n","/**\n\n * @function equals\n * @description Autocurried function that checks for equality of 2 items\n * @param {*} x - Left side of the equality check\n * @param {*} y - Right side of the equality check\n * @return {boolean}\n * @example\n *\n * const nan = Number.NaN\n * equal(nan, nan) // returns true\n *\n * const arr1 = [0, 1, 2, 3]\n * const arr2 = [null, 1, 2, 3]\n * equals(arr1, arr2) // returns false\n *\n * equals(new Object({'a': 0, 'b': 1}), {'a': 0, 'b': 1}) // true\n *\n */\nimport curry from './curry'\nimport exists from './exists'\nimport identical from './identical'\nimport type from './type'\nimport not from './not'\nimport or from './or'\nimport isObject from './object/is'\nimport isArray from './array/is'\nimport isBoolean from './boolean/is'\nimport isNumber from './number/is'\nimport isString from './string/is'\nimport isDate from './date/is'\nimport equalsArray from './array/equals'\nimport equalsObject from './object/equals'\n\nexport default curry(function equals (x, y) {\n  if (identical(x, y)) return true\n\n  if (type(x) !== type(y)) return false\n\n  if (or(not(exists(x)), not(exists(y)))) return false\n\n  if (x.constructor !== y.constructor) return false\n\n  if (isString(x) || isBoolean(x) || isNumber(x) || isDate(x)) {\n    return identical(x.valueOf(), y.valueOf())\n  }\n  if (isArray(x)) {\n    return equalsArray(x, y)\n  } else if (isObject(x)) {\n    return equalsObject(x, y)\n  }\n  return false\n})\n","/**\n * @function exists\n */\nexport default function exists (x) {\n  return !(x == null)\n};\n","/**\n * Returns a single item by iterating over an array like object and call a function on each item\n *\n * @function fold\n * @description Returns a single item by iterating over an array like object and call a function on each item\n * @since v1.0.2\n * @sig ((a, b, c, a) → a) → a → [b] → a\n * @param {Function} cb receives 4 values: the accumulator, the item, the index, and the initial value.\n * @param {*} a is the initial value\n * @param {*} [b] the array like item to iterate over\n * @return {*} a is the accumulated value\n **/\n\nimport curry from './curry'\nimport arrayFold from './array/fold'\nimport objectFold from './object/fold'\nimport type from './type'\n\nexport default curry(function fold (cb, init, a) {\n  const typeMap = {\n    'Object': objectFold,\n    'Array': arrayFold\n  }\n  // if (a.next) {\n  //   return iterableFold(cb, init, a)\n  // }\n  // if (type(Symbol) !== 'undefined' && a[Symbol.iterator]) {\n  //   return iterableFold(cb, init, a[Symbol.iterator]())\n  // }\n  return typeMap[type(a)](cb, init, a)\n})\n\n// function iterableFold (cb, acc, gen) {\n//   let step = gen.next()\n//   while (!step.done) {\n//     acc = cb(acc, step.value)\n//     step = gen.next()\n//   }\n//   return acc\n// }\n","/**\n\n * @function identical\n * @description checks for identintical items\n */\nimport curry from './curry'\nimport isNan from './number/isNan'\n\nexport default curry(function identical (x, y) {\n  if (x === 0 && y === 0) {\n    return 1 / x === 1 / y\n  }\n  if (x === y) {\n    return true\n  }\n  return !!(isNan(x) && isNan(y))\n})\n","/**\n * @function is\n * @description Verifies the type of the provided argument\n *\n */\n\nimport curry from './curry'\nimport type from './type'\n\nexport default curry(function is (Ctor, val) {\n  return type(val) === Ctor\n})\n","/**\n * Created by dierickx.len on 01/04/2017.\n */\nimport is from '../is'\nconst isFunction = is('Function')\n\nexport default function isIter (iter) {\n  return isFunction(iter[Symbol.iterator])\n}\n","/**\n * Maps over an Iterator and applies a function\n *\n * @function\n * @since v1.0.3\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Iterator} a\n * @return {Iterator}\n **/\nimport curry from '../curry'\n\nexport default curry(function map (callback, iterator) {\n  let r = []\n  for (let nextValue = iterator.next(); nextValue.done !== true; nextValue = iterator.next()) {\n    r.push(callback(iterator.value()))\n  }\n  return r\n})\n","/**\n * Maps over an iterable and applies a function\n *\n * @function map\n * @description Autocurried function which maps over an iterable.\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> b -> b\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n **/\nimport curry from './curry'\nimport arrayMap from './array/map'\nimport objectMap from './object/map'\nimport mapMap from './map/map'\nimport stringMap from './string/map'\nimport iteratorMap from './iterator/map'\nimport type from './type'\nimport isIterator from './iterator/is'\n\nexport default curry(function map (cb, a) {\n  switch (type(a)) {\n    case 'Function':\n      return curry(function () {\n        return cb.call(this, a.apply(this, arguments))\n      })\n    case 'Object':\n      return objectMap(cb, a)\n    case 'String':\n      return stringMap(cb, a)\n    case 'Map':\n      return mapMap(cb, a)\n    case 'Array':\n      return arrayMap(cb, a)\n    default:\n      return isIterator(a)\n        ? iteratorMap(cb, a)\n        : arrayMap(cb, a)\n  }\n})\n","/**\n * Maps over a Map and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Map} a\n * @return {Map}\n **/\nimport curry from '../curry'\nimport empty from '../empty'\n\nexport default curry(function map (cb, a) {\n  const r = empty(a)\n  a.forEach((v, k, map) => {\n    r.set(k, cb(v, k, map))\n  })\n  return r\n})\n","/**\n * @function not\n */\nimport curry from './curry'\n\nexport default curry(function not (x) {\n  return !x\n})\n","/**\n * @private\n */\nimport is from '../is'\n\nexport default is('Number')\n","/**\n * @function isNaN\n * @description Checks if number is NAN\n\n */\nimport isNumber from './is'\nimport and from '../and'\n\nexport default function isNan (x) {\n  return and(isNumber(x), isNaN(x))\n};\n","/**\n\n * equals\n * checks for equality\n */\nimport curry from '../curry'\nimport exists from '../exists'\nimport not from '../not'\nimport equals from '../equals'\n\nexport default curry((x, y) => {\n  for (let keyX in x) {\n    // noinspection JSUnfilteredForInLoop\n    if (not(equals(x[keyX], y[keyX]))) return false\n  }\n\n  for (let keyY in y) {\n    if (not(exists(x[keyY])) && exists(y[keyY])) return false\n  }\n\n  return true\n})\n","/**\n * @function fold\n * @private\n *\n */\nimport curry from '../curry'\nimport keys from './keys'\n\nexport default curry(function fold (cb, init, o) {\n  const k = keys(o)\n  let i = -1\n  const l = k.length\n  let r = Object(init)\n  while (++i < l) {\n    r = cb(r, o[k[i]], k[i], o)\n  }\n  return r\n})\n","/**\n\n */\nimport is from '../is'\n\nexport default is('Object')\n","/**\n * Returns the own keys of an object as an Array\n *\n * @function\n * @since v1.0.2\n * @sig a -> [b]\n * @param {Object}\n * @return {Array}\n **/\nimport curry from '../curry'\n\nexport default curry(function keys (a) {\n  return Object.keys(Object(a))\n})\n","/**\n * Maps over an object and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Object} a\n * @return {Object}\n **/\nimport curry from '../curry'\nimport empty from '../empty'\nimport keys from './keys'\n\nexport default curry(function map (cb, a) {\n  const k = keys(a)\n  let i = -1\n  const l = k.length\n  const r = empty(a)\n  while (++i < l) {\n    r[k[i]] = cb(a[k[i]], k[i], a)\n  }\n  return r\n})\n","/**\n * @function or\n * @description Returns true if one or the other is true\n */\nimport curry from './curry'\n\nexport default curry(function or (x, y) {\n  return x || y\n})\n","/**\n * @private\n * @function stringConcat\n */\n\nexport default function concat (a, b) { // use function(), arrow function doesn't bind arguments\n  return String(a) + String(b)\n}\n","/**\n\n */\nimport is from '../is'\n\nexport default is('String')\n","/**\n * Maps over a string and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> [a] -> [a]\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n **/\nimport curry from '../curry'\n\nexport default curry(function map (cb, a) {\n  let i = -1\n  const l = a.length\n  let r = ''\n  while (++i < l) {\n    r += cb(a.charAt(i), i, a)\n  }\n  return r\n})\n","/**\n * @function type\n */\nimport curry1 from './_private/curry1'\n\nexport default curry1(function type (x) {\n  return Object.prototype.toString.call(x).slice(8, -1)\n})\n","import curry from 'fun.js/src/curry'\nimport map from 'fun.js/src/map'\nimport fold from 'fun.js/src/fold'\nimport equals from 'fun.js/src/equals'\nimport concat from 'util/concat'\nimport empty from 'util/empty'\nimport dot from 'util/dot'\nimport identity from 'util/identity'\nimport transpose from 'util/transpose'\nimport generate from 'util/generate'\n\n/**\n * @class Matrix\n * @classdesc Matrix applicative providing standard matrix operations\n * @summary The Matrix class should not be instantiated with the new keyword. Instead use the Matrix.of syntax to create a new Matrix. Unfortunatly jsdocs does not allow for the constructor to be hidden.\n * @hidecontructor\n * @see of\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n *\n */\nlet Matrix = function (val) {\n  this.__value = val\n}\n\n/**\n * @memberOf Matrix\n * @property {string} type\n * @type {string}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.type === 'Matrix'\n */\nMatrix.prototype.type = 'Matrix'\n\n/**\n * @memberOf Matrix\n * @property {number} precision\n * @type {number}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.precision === 4\n */\nMatrix.prototype.precision = 4\n\n/**\n * @memberOf Matrix\n * @instance\n * @member setPrecision\n * @param precision {number} Set the number of decimals for rounding\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.setPrecision(10)\n * m.precision === 10\n */\nMatrix.prototype.setPrecision = function (precision) {\n  this.precision = precision\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member isSymmetric\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSymmetric()\n *\n */\nMatrix.prototype.isSymmetric = function () {\n  const a = this.__value\n  const b = Matrix.transpose(this).__value\n  return equals(a, b)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member isSquare\n * @desc Boolean indicating whether this contains a square Matrix\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSquare()\n *\n */\nMatrix.prototype.isSquare = function () {\n  return equals(this.getCols(), this.getRows())\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member isOrthogonal\n * @param M {Matrix|array}\n * @returns {boolean}\n * @example\n *\n * const result = [[-0.3092, -0.9510], [-0.9510, 0.3092]]\n * const A = Matrix.fromArray(result)\n * true  === A.isOrthogonal()\n */\nMatrix.prototype.isOrthogonal = function () {\n  const AxAt = this.dot(this.transpose())\n  const I = this.identity()\n  return equals(AxAt, I)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member getCols\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getCols()  === 2\n *\n */\nMatrix.prototype.getCols = function () {\n  return this.__value[0].length\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member equals\n * @param M {Matrix|array}\n * @returns {Boolean}\n * @example\n *\n * var a = [[1, 1], [1, 1]]\n * var A = Matrix.of(a)\n * var B = Matrix.of(a)\n * true  === A.equals(B)\n */\nMatrix.prototype.equals = function (M) {\n  return equals(this.__value, M.__value || M)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member getRows\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getRows()  // 2\n */\nMatrix.prototype.getRows = function () {\n  return this.__value.length\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member getShape\n * @returns {Array}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getShape()  // [2, 2]\n */\nMatrix.prototype.getShape = function () {\n  return [this.getRows(), this.getCols()]\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function of\n * @desc Creates a Matrix object and flattens the Matrix\n * @param val {array|function} An array of arrays\n * @returns {Matrix}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n *\n */\nMatrix.of = function (val) {\n  if (val instanceof Matrix) return val\n  if (this instanceof Matrix) {\n    this.__value = val\n    return this\n  }\n  return new Matrix(val)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member map\n * @description Maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.of([[1, 1], [1, 1]])\n * m.map(x => x.map(y => y+ 1))\n * // [[2, 2], [2, 2]]\n *\n */\nMatrix.prototype.map = function (f) {\n  return Matrix.of(map(f)(this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function map\n * @description Static function that maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @param M {Matrix|array} Matrix or array to map\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.map(x= > x.map(y => y+ 1), [[1, 1], [1, 1]])\n * // [[2, 2], [2, 2]]\n *\n */\nMatrix.map = curry(function (f, M) {\n  return Matrix.of(M).map(f)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member fold\n * @description Reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @returns {Matrix}\n * @example\n *\n * // Flatten Matrix\n * Matrix.of([[1, 1], [1, 1]]).fold((prev, next) => prev.concat(next))\n * // [1, 1, 1, 1]\n */\nMatrix.prototype.fold = function (f) {\n  return Matrix.of(fold(f, [])(this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function fold\n * @description Static function to reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @param M {Matrix} The Matrix to reduce\n * @returns {Matrix}\n * @example\n\n * // Sum of all matrix values\n * const reducer = (prev, next) => Number(prev) + next.reduce((acc, x) => acc + x, 0)\n * const A = Matrix.of([[1, 1], [1, 1]]\n * Matrix.fold(reducer, A)\n * // 4\n */\nMatrix.fold = curry(function (f, M) {\n  return Matrix.of(M).fold(f)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member ap\n * @description Applies a Matrix to a function\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * const A = Matrix.of([[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * Matrix.of(f).ap(M)\n * // [[6], [15], [24]\n */\nMatrix.prototype.ap = function (M) {\n  return Matrix.of(M).map(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function ap\n * @description Applies a Matrix to a function\n * @param f {function}\n * @param M {Matrix|array}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * Matrix.ap(f, [[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * // [[6], [15], [24]\n */\nMatrix.ap = curry(function (f, M) {\n  return Matrix.of(f).ap(M)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = A.concat(B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */\nMatrix.prototype.concat = function (M, f = concat) {\n  return Matrix.of(this).map(f(M))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param A {Matrix}\n * @param B {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = Matrix.concat(A, B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */\nMatrix.concat = curry(function (A, B, f = concat) {\n  return Matrix.of(A).map(f(B))\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member empty\n * @description Return an empty Matrix from an existing Matrix\n * @returns {Matrix}\n */\nMatrix.prototype.empty = function () {\n  return Matrix.of(this).map(empty)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function empty\n * @description Return an empty Matrix from an existing Matrix\n * @param rows {number}\n * @param cols {number}\n * @returns {Matrix}\n */\nMatrix.empty = curry(function (rows = 0, cols = 0) {\n  const m = generate(rows, cols) // Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n  return Matrix.of(m).map(empty)\n})\n\n// #### #### #### //\n\n/**\n * @memberOf Matrix\n * @instance\n * @member identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const A = Matrix.of(a)\n * const Aidentity = A.identity()\n * // [[1, 0, 0], [0, 1, 0]]\n *\n*/\nMatrix.prototype.identity = function () {\n  return Matrix.of(identity).ap(this)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.identity(3, 2)\n * // [[1, 0, 0], [0, 1, 0]]\n *\n */\nMatrix.identity = function (rows, cols) {\n  const m = generate(rows, cols) // Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n  return Matrix.of(identity).ap(m)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */\nMatrix.prototype.combine = function (M) {\n  return Matrix.of(this).concat(Matrix.of(M), concat)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */\nMatrix.combine = function (A, B) {\n  return Matrix.of(A).concat(Matrix.of(B), concat)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @param f\n * @returns {Matrix}\n * @example\n *\n * // Create matrix\n * const m = Matrix.of([[1, 2], [3, 4]])\n *\n * // Generate identity matrix\n * const I  = m.identity() // [[1, 0], [0, 1]]\n *\n * if(m.dot(I).equals(m)) {\n *    console.log('Dot product with identity matrix returns the same matrix')\n * }\n *\n */\nMatrix.prototype.dot = function (M) {\n  return Matrix.of(this).concat(Matrix.of(M), dot(this.precision))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @returns {Matrix}\n * @example\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const b = [[7, 8], [9, 10], [11, 12]]\n *\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n *\n * Matrix.dot(A, B) // [[58, 64], [139, 154]]\n *\n */\nMatrix.dot = function (A, B) {\n  return Matrix.of(A).dot(Matrix.of(B))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member fill\n * @desc Fill up an empty matrix with the provided map function\n * @param f\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).fill(x => 42)\n * // [[42,42,42], [42,42,42], [42,42,42]]\n *\n */\nMatrix.prototype.fill = function (f) {\n  return Matrix.of(this).map(map(x => f(x)))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member zeros\n * @desc Fill up an empty matrix with zeros\n * @returns {Matrix}\n *\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).zeros()\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */\nMatrix.prototype.zeros = function () {\n  return Matrix.of(this).fill(x => 0)\n}\n\n/**\n * @memberOf Matrix\n * @function zeros\n * @desc Fill up an empty matrix with zeros\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.zeros(3, 3)\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */\nMatrix.zeros = function (rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(x => 0)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member ones\n * @desc Fill up an empty matrix with ones\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).ones()\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */\nMatrix.prototype.ones = function () {\n  return Matrix.of(this).fill(x => 1)\n}\n\n/**\n * @memberOf Matrix\n * @function ones\n * @desc Fill up an empty matrix with ones\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.ones(1, 1)\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */\nMatrix.ones = function (rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(x => 1)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member random\n * @desc Fill up an empty matrix with random values\n * @param {function} [f = e => Math.random() * 2 - 1]\n * @returns {Matrix}\n */\nMatrix.prototype.random = function (f = e => Math.random() * 2 - 1) {\n  return Matrix.of(this).fill(f)\n}\n\n/**\n * @memberOf Matrix\n * @function random\n * @desc Fill up an empty matrix with random numbers\n * @param f {function} Function which returns random values. Default random values are between -1 and 1\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n */\nMatrix.random = function (f = e => (Math.random() * 2 - 1), rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(f)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member toArray\n * @desc Returns the array from the matrix\n * @returns {Array}\n */\nMatrix.prototype.toArray = function () {\n  return this.__value.map(row => row.map(col => col))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member clone\n * @desc Returns a clone of the matrix\n * @returns {Matrix}\n */\nMatrix.prototype.clone = function () {\n  return Matrix.fromArray(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member fromArray\n * @desc Returns a Matrix from an array\n * @returns {Array}\n */\nMatrix.fromArray = function (arr) {\n  return Matrix.of(map(row => map(col => col)(row))(arr))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member transpose\n * @desc Returns a transposed Matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([-1, 2], [3, 4], [-8, 2])\n * const b = A.transpose().toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */\nMatrix.prototype.transpose = function () {\n  return Matrix.of(fold(transpose, [], this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @function transpose\n * @desc Returns a transposed Matrix\n * @param M {Matrix|array} A Matrix or a matrix array\n * @returns {Matrix}\n * @example\n *\n * const a = [-1, 2], [3, 4], [-8, 2]\n * const b = Matrix.transpose(a).toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */\nMatrix.transpose = function (M) {\n  return Matrix.of(M).transpose()\n}\n\n/**\n * @memberOf Matrix\n * @member add\n * @instance\n * @param M {Matrix|number} Add a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.add(1) // [[6, 5]]\n * const B = Matrix.of([[5, 5]])\n * B.add(B) // [[10, 10]]\n *\n */\nMatrix.prototype.add = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      throw new Error('Matrices do not match, cannot add')\n    }\n    return this.map((row, idx) => map((val, jdx) => val + M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x + M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member subtract\n * @instance\n * @param M {Matrix|number} Subtract a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.subtract(1) // [[4, 2]]\n * const B = Matrix.of([[5, 5]])\n * B.subtract(B) // [[0, 0]]\n *\n */\nMatrix.prototype.subtract = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      throw new Error('Matrices do not match, cannot subtract')\n    }\n    return this.map((row, idx) => map((val, jdx) => val - M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x - M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member multiply\n * @instance\n * @desc Mutliply a scalar or a mtraix with a matrix. Throws an error if the multiplication is not possible.\n * @param M {Matrix|number}\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.multiply(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.multiply(B) // [[25, 25]]\n *\n */\nMatrix.prototype.multiply = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      console.log('Use static method \\'dot\\' to do matrix multiplication')\n      throw new Error('Matrices do not match, cannot create hadamard product')\n    }\n    return this.map((row, idx) => map((col, jdx) => col * M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x * M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member additiveinverse\n * @instance\n * @desc Function that returns the matrix obtained by changing the sign of every matrix element. The additive inverse of matrix A is written –A.\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5,-5], [-4, 4]])\n * const minusA = A.additiveinverse()\n * // [[-5, 5], [4, -4]]\n */\nMatrix.prototype.additiveinverse = function () {\n  return Matrix.of(this).multiply(-1)\n}\n\n/**\n * @memberOf Matrix\n * @member hadamard\n * @instance\n * @see multiply\n * @param M\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.hadamard(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.hadamard(B) // [[25, 25]]\n\n */\nMatrix.prototype.hadamard = function (M) {\n  return Matrix.of(this).multiply(M)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member lu\n * @desc Calculates LU decomposition of the current Matrix\n * @returns {Matrix[]}\n * @example\n *\n * const result = [[3, -7, -2, 2], [-3, 5, 1, 0], [6, -4, 0, -5], [-9, 5, -5, 12]]\n * const A = Matrix.fromArray(result)\n * const lu = A.lu()\n * // L.__value = [ [ 1, 0, 0, 0 ], [ -1, 1, 0, 0 ], [ 2, -5, 1, 0 ], [ -3, 8, 3, 1 ] ]\n * // U.__value =  [ [ 3, -7, -2, 2 ], [ 0, -2, -1, 2 ], [ 0, 0, -1, 1 ], [ 0, 0, 0, -1 ] ]\n * Matrix.dot(lu[0], lu[1]) // returns clone of A\n *\n */\nMatrix.prototype.lu = function () {\n  const n = this.getRows()\n  const tol = 1e-6\n  const A = this.clone()\n  const L = this.zeros()\n  const U = this.zeros()\n\n  for (let k = 0; k < n; ++k) {\n    if (Math.abs(A.__value[k][k]) < tol) throw Error('Cannot proceed without a row exchange')\n    L.__value[k][k] = 1\n    for (let i = k + 1; i < n; ++i) {\n      L.__value[i][k] = A.__value[i][k] / A.__value[k][k]\n      for (let j = k + 1; j < n; ++j) {\n        A.__value[i][j] = A.__value[i][j] - L.__value[i][k] * A.__value[k][j]\n      }\n    }\n    for (let l = k; l < n; ++l) {\n      U.__value[k][l] = A.__value[k][l]\n    }\n  }\n  return [L, U]\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member rref\n * @returns {Matrix|array}\n * @example\n *\n * var A = Matrix.of([[-1, 1], [-1, 0], [0, -1], [-1, -2]])\n * A.rref() //  [ [ 1, 0 ], [ -0, 1 ], [ 0, 0 ], [ 0, 0 ] ]\n */\nMatrix.prototype.rref = function () {\n  let lead = 0\n  const resultMatrix = this.clone()\n\n  for (let r = 0; r < this.getRows(); ++r) {\n    if (this.getCols() <= lead) {\n      return resultMatrix\n    }\n    let i = r\n    while (resultMatrix.__value[i][lead] === 0) {\n      ++i\n      if (this.getRows() === i) {\n        i = r\n        ++lead\n        if (this.getCols() === lead) {\n          return resultMatrix\n        }\n      }\n    }\n\n    let tmp = resultMatrix.__value[i]\n    resultMatrix.__value[i] = resultMatrix.__value[r]\n    resultMatrix.__value[r] = tmp\n\n    let val = resultMatrix.__value[r][lead]\n    for (let j = 0; j < this.getCols(); ++j) {\n      resultMatrix.__value[r][j] /= val\n    }\n\n    for (let i = 0; i < this.getRows(); ++i) {\n      if (i === r) continue\n      val = resultMatrix.__value[i][lead]\n      for (let j = 0; j < this.getCols(); ++j) {\n        resultMatrix.__value[i][j] -= val * resultMatrix.__value[r][j]\n      }\n    }\n    lead++\n  }\n  return resultMatrix\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member solve\n * @param b\n * @returns {Array}\n * @example\n *\n * // Solve xA = b\n * // 5x + y  = 7\n * // 3x - 4y = 18\n * // Solution for x and y:\n * // x = 2\n * // y = -3\n *\n * const A = Matrix.of([[5, 1], [3, -4]])\n * const solveA = A.solve([7, 18]) // [2, -3]\n *\n */\nMatrix.prototype.solve = function (b) {\n  const A = this.clone()\n  const LU = A.lu()\n  const L = LU[0]\n  const U = LU[1]\n  const n = this.getRows()\n  let s = 0\n  const c = []\n  const x = []\n\n  for (let k = 0; k < n; ++k) {\n    for (let j = 0; j < k; ++j) {\n      s = s + L.__value[k][j] * c[j]\n    }\n    c[k] = b[k] - s\n    s = 0\n  }\n  for (let a = n - 1; a > -1; --a) {\n    let t = 0\n    for (let b = a + 1; b < n; ++b) {\n      t = t + U.__value[a][b] * x[b]\n    }\n    x[a] = (c[a] - t) / U.__value[a][a]\n  }\n  return x\n}\n\n/**\n * @memberOf Matrix\n * @member inverse\n * @instance\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1, 1], [2, 4]]).inverse()\n * // [ [ 2, -0.5 ], [ -1, 0.5 ] ]\n *\n */\nMatrix.prototype.inverse = function () {\n  const A = this.clone()\n  const I = A.identity()\n  const Inv = A.concat(I).rref()\n\n  const result = Inv.__value.reduce((result, x, idx) => {\n    const half = x.length / 2\n    result.push(x.slice(half, x.length))\n    return result\n  }, [])\n  return Matrix.of(result)\n}\n\n/**\n * @memberOf Matrix\n * @member rank\n * @instance\n * @returns {Number}\n */\nMatrix.prototype.rank = function () {\n  const rref = this.rref()\n  let result = 0\n  for (let i = 0; i < rref.getCols(); ++i) {\n    result += rref.__value[i][i]\n  }\n  return result\n}\n\n/**\n * @memberOf Matrix\n * @member dimension\n * @instance\n * @see rank\n * @returns {Number}\n */\nMatrix.prototype.dimension = function () {\n  return this.rank()\n}\n\n/**\n * @memberOf Matrix\n * @member diag\n * @instance\n * @desc Returns an array containing the values on the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diag()\n * // [1, 1, 1]\n *\n * const diag0 = Matrix.zeros(5, 5).diag()\n * // [0, 0, 0, 0, 0]\n *\n */\nMatrix.prototype.diag = function () {\n  return fold((acc, x, idx) => {\n    return acc.concat(x[idx])\n  })([])(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function diag\n * @desc Returns an array containing the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.diag([[2, 1], [1, 5]])\n * // [2, 5]\n *\n */\nMatrix.diag = function (M) {\n  return Matrix.of(M).diag()\n}\n\n/**\n * @memberOf Matrix\n * @member diagproduct\n * @instance\n * @desc Returns the product of the values on the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diagproduct()\n * // 1\n *\n * const diag0 = Matrix.zeros(5, 5).diagproduct()\n * // 0\n *\n */\nMatrix.prototype.diagproduct = function () {\n  return fold((acc, x, idx) => {\n    acc *= x[idx]\n    return acc\n  })(1)(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function diagproduct\n * @desc Returns the product of the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.diagproduct([[2, 1], [1, 5]])\n * // 10\n *\n */\nMatrix.diagproduct = function (M) {\n  return Matrix.of(M).diagproduct()\n}\n\n/**\n * @memberOf Matrix\n * @member sum\n * @instance\n * @desc Returns the sum of the values in the Matrix\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).sum()\n * // 9\n *\n * const diag0 = Matrix.zeros(5, 5).sum()\n * // 0\n *\n */\nMatrix.prototype.sum = function () {\n  return fold((acc, x) => {\n    acc += fold((prev, next) => prev + next)(0)(x)\n    return acc\n  })(0)(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function sum\n * @desc Returns the sum of the values in the Matrix\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.sum([[2, 1], [1, 5]])\n * // 9\n *\n */\nMatrix.sum = function (M) {\n  return Matrix.of(M).sum()\n}\n\n/**\n * @memberOf Matrix\n * @member kronecker\n * @instance\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param M {Matrix} The right side Matrix of the product (this ⊗ M)\n * @returns {Matrix}\n */\nMatrix.prototype.kronecker = function (M) {\n  const m = this.getRows()\n  const n = this.getCols()\n  const p = M.getRows()\n  const q = M.getCols()\n\n  const left = this.__value\n  const right = M.__value\n\n  const frame = generate(m * p, n * q)\n\n  for (var i = 0; i < m; i++) {\n    for (var j = 0; j < n; j++) {\n      for (var k = 0; k < p; k++) {\n        for (var l = 0; l < q; l++) {\n          frame[p * i + k][q * j + l] = left[i][j] * right[k][l]\n        }\n      }\n    }\n  }\n  return Matrix.of(frame)\n}\n\n/**\n * @memberOf Matrix\n * @function kronecker\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param A {Matrix} The left side Matrix of the product (A ⊗ B)\n * @param B {Matrix} The right side Matrix of the product (A ⊗ B)\n * @returns {Matrix}\n */\nMatrix.kronecker = function (A, B) {\n  return Matrix.of(A).kronecker(B)\n}\n\nexport default Matrix\n","import curry from 'fun.js/src/curry'\nimport concat from 'fun.js/src/concat'\n\n/**\n * @function concat\n * @param M {Matrix}\n * @param m {Array}\n * @param idx {number}\n * @returns {Array}\n */\nexport default curry(function (M, m, idx) {\n  return concat(m, M.__value[idx])\n})\n","import curry from 'fun.js/src/curry'\nimport fold from 'fun.js/src/fold'\nimport map from 'fun.js/src/map'\nimport round from './round'\n\n/**\n * @function dot\n * @param B {Matrix}\n * @param a {Array}\n * @returns {Array}\n */\nexport default curry((decimals, B, a) => map((item, i) => {\n  return fold((acc, x, j) => {\n    acc += round(x * B.__value[j][i], decimals)\n    return acc\n  }, 0)(a)\n})(B.__value[0]))\n","import curry from 'fun.js/src/curry'\n\nexport default curry(m => [])\n","/**\n * @function generate\n * @desc Generator function for a matrix array, values are set to undefined\n * @param rows {number}\n * @param cols {number}\n * @returns {any[][]}\n */\nexport default (rows, cols) => Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n","import map from 'fun.js/src/map'\n\n/**\n * @function identity\n * @desc Creates an identiy matrix from an empty array\n * @param m {Array}\n * @param idx {number}\n * @return {Matrix}\n */\nexport default (m, idx) => map((rows, jdx) => (idx === jdx) * 1)(m)\n","/**\n * @function round\n * @param value {number}\n * @param decimals {number}\n * @returns {Number}\n */\nexport default function round (value, decimals) {\n  return Number(Math.round(value + 'e' + decimals) + 'e-' + decimals)\n}\n","import map from 'fun.js/src/map'\nimport curry from 'fun.js/src/curry'\n\n/**\n * @function transpose\n * @desc Transposes a array of arrays using the Matrix.map function\n * @param m {Array}\n * @param idx {number}\n * @return {Matrix}\n */\nexport default curry((prev, next) => map((item, i) => (prev[i] || []).concat(next[i]))(next))\n"],"sourceRoot":""} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://@astuanax/funmatrix/webpack/universalModuleDefinition","webpack://@astuanax/funmatrix/webpack/bootstrap","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/_private/curry1.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/and.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/boolean/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/curry.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/date/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/empty.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/exists.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/identical.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/iterator/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/iterator/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/map/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/not.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/number/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/number/isNan.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/keys.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/or.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/type.js","webpack://@astuanax/funmatrix/./src/matrix.js","webpack://@astuanax/funmatrix/./src/util/concat.js","webpack://@astuanax/funmatrix/./src/util/dot.js","webpack://@astuanax/funmatrix/./src/util/empty.js","webpack://@astuanax/funmatrix/./src/util/generate.js","webpack://@astuanax/funmatrix/./src/util/identity.js","webpack://@astuanax/funmatrix/./src/util/round.js","webpack://@astuanax/funmatrix/./src/util/transpose.js"],"names":["Matrix","val","__value","of","prototype","type","precision","setPrecision","isSymmetric","a","b","transpose","isSquare","getCols","getRows","isOrthogonal","AxAt","dot","I","identity","length","equals","M","getShape","map","f","fold","ap","concat","A","B","empty","rows","cols","m","combine","fill","x","zeros","ones","random","e","Math","toArray","row","col","clone","fromArray","arr","add","Error","idx","jdx","subtract","multiply","console","log","additiveinverse","hadamard","lu","n","tol","L","U","k","abs","i","j","l","rref","lead","resultMatrix","r","tmp","solve","LU","s","c","t","inverse","Inv","result","reduce","half","push","slice","rank","dimension","diag","acc","diagproduct","sum","prev","next","kronecker","p","q","left","right","frame","decimals","item","Array","apply","round","value","Number"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;;;;;;AClFA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;;AAEe;AACf;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACbA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,EAAE;AACb,YAAY;AACZ;AAC2B;;AAEZ,qHAAK;AACpB;AACA,CAAC,CAAC;;;;;;;;;;;;;ACfF;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AAC4B;;AAEb,qHAAK;AACpB;AACA,CAAC,CAAC;;;;;;;;;;;;;ACXF;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA,WAAW,EAAE;AACb,WAAW,EAAE;AACb,YAAY;AACZ;AAC4B;AACJ;AACM;;AAEf,qHAAK;AACpB;AACA;AACA;AACA,iBAAiB,cAAc;AAC/B,QAAQ,oDAAG,CAAC,uDAAM;AAClB;AACA;AACA,CAAC,CAAC;;;;;;;;;;;;;ACpBF;AAAA;AAAA;AACA;AACA;AACA;AACA,WAAW,WAAW;AACtB,WAAW,EAAE;AACb,WAAW,MAAM;AACjB,YAAY;AACZ;AACA;AACA;AAC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","file":"@astuanax/funmatrix.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"@astuanax/funmatrix\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"@astuanax/funmatrix\"] = factory();\n\telse\n\t\troot[\"@astuanax/funmatrix\"] = factory();\n})(typeof self !== 'undefined' ? self : this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/matrix.js\");\n","/**\n * Returns a curried function with arity 1\n * @function curry1\n * @private\n * @since v1.0.2\n **/\n\nexport default function curry1 (fn) {\n  return function curried (a) {\n    return arguments.length === 0\n      ? this\n      : fn(a)\n  }\n}\n","/**\n * Checks if both predicates are true\n *\n * @function and\n * @description Checks if both predicates are true\n * @since v1.0.2\n * @sig (x, y) -> boolean\n * @param {*} x - A predicate\n * @param {*} y - A predicate\n * @return {boolean}\n **/\nimport curry from './curry'\n\nexport default curry(function and (x, y) {\n  return x && y\n})\n","/**\n * @private\n * @function arrayConcat\n * @param a1\n * @param a2\n * @returns {T[]}\n */\nimport curry from '../curry'\n\nexport default curry(function concat (a, b) {\n  return Array.prototype.concat(a, b)\n})\n","/**\n * @private\n * @function equalsArray\n * @description Autocurried function for deep comparison of arrays\n * @param {a} x - Object to compare of type a\n * @param {a} y - Object x to compare with object x\n * @return {boolean}\n */\nimport curry from '../curry'\nimport not from '../not'\nimport equals from '../equals'\n\nexport default curry(function equalsArray (x, y) {\n  if (x.length !== y.length) {\n    return false\n  }\n  for (let i = 0; i < x.length; i++) {\n    if (not(equals(x[i], y[i]))) return false\n  }\n  return true\n})\n","/**\n * @private\n * @function fold\n * @description Returns a single item by mapping over the provided array and calling an iterator function\n * @param {cbFunction} cb - Callback function to modify the item\n * @param {*} init - Initial value\n * @param {Array} a - Array with items to modify by the cb function\n * @return {Array}\n * @alias reduce\n * @since 1.0.2\n * @example\n *\n * const result = fold(add, 0, [1,1,1])\n * // result = 3\n */\n\n/**\n * @callback cbFunction\n * @param {*} r - Accumulator which accumulates the callback's return values\n * @param {*} item - the current element being processed\n * @param {number} index - the indey of the item being processed\n * @param {Array} a - The initial array\n * @return {*}\n */\nimport curry from '../curry'\n\nexport default curry(function fold (cb, init, a) {\n  let i = -1\n  const l = a.length\n  let r = init\n  while (++i < l) {\n    r = cb(r, a[i], i, a)\n  }\n  return r\n})\n","/**\n * Checks if the provided object is an array, autocurried function\n *\n * @private\n * @function isArray\n * @description Checks if the provided object is an array, autocurried function\n * @param {*} Object to verifiy\n * @return {boolean}\n * @since 1.0.2\n * @example\n *\n * const result = isArray([1,1,1])\n * // result = true\n */\n\nimport is from '../is'\n\nexport default is('Array')\n","/**\n * @function map\n * @description Maps over an array and applies a function\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n * @since v1.0.2\n * @example\n *\n *  const result = map(identity, [0,2,3])\n *  // result = [0,2,3]\n *  const add2 = add(2)\n *  const result = map(add2, [0,2,3])\n *  // result = [2,4,5]\n **/\nimport curry from '../curry'\n\nexport default curry(function map (cb, a) {\n  let i = -1\n  const l = a.length\n  const r = new Array(l)\n  while (++i < l) {\n    r[i] = cb(a[i], i, a)\n  }\n  return r\n})\n","/**\n * Curried function that verifies of the provided argument is a boolean\n *\n * @private\n * @function is\n * @description Curried function that verifies of the provided argument is a boolean\n * @since v1.0.2\n * @param {*} Item to verify\n * @return {boolean}\n **/\nimport is from '../is'\n\nexport default is('Boolean')\n","/**\n * Concatenates 2 items together\n *\n * @function concat\n * @description Concatenates 2 items together\n * @since v1.0.4\n * @param {a} a - Left side of the concatenation\n * @param {a} b - right side of the concatenation\n * @return {a} Concatenated item\n **/\n\nimport curry from './curry'\nimport arrayConcat from './array/concat'\nimport stringConcat from './string/concat'\nimport type from './type'\n\nexport default curry(function concat (a, b) {\n  const typeMap = {\n    'String': stringConcat,\n    'Array': arrayConcat\n  }\n  return typeMap[type(a)](a, b)\n})\n","/* eslint-disable no-use-before-define */\n/**\n * @function curry\n * @description Autocurries the provided function\n */\nexport default function curry (fun) {\n  const argslen = fun.length\n\n  if (argslen === 0) {\n    return fun\n  }\n  return createRecurser([])\n\n  function recurse (acc, args) {\n    const _acc = acc.concat(args)\n    return _acc.length < argslen\n      ? createRecurser(_acc)\n      : fun.apply(this, _acc)\n  }\n\n  function createRecurser (acc) {\n    return function () {\n      return recurse(acc, Array.prototype.slice.call(arguments))\n    }\n  }\n}\n","/**\n * Created by dierickx.len on 01/04/2017.\n */\n/**\n * Created by dierickx.len on 01/04/2017.\n */\nimport is from '../is'\n\nexport default is('Date')\n","/**\n\n * @function empty\n * @description Returns the empty equivalent of the first argument\n */\n\nexport default function empty (x) {\n  return new x.constructor()\n};\n","/**\n\n * @function equals\n * @description Autocurried function that checks for equality of 2 items\n * @param {*} x - Left side of the equality check\n * @param {*} y - Right side of the equality check\n * @return {boolean}\n * @example\n *\n * const nan = Number.NaN\n * equal(nan, nan) // returns true\n *\n * const arr1 = [0, 1, 2, 3]\n * const arr2 = [null, 1, 2, 3]\n * equals(arr1, arr2) // returns false\n *\n * equals(new Object({'a': 0, 'b': 1}), {'a': 0, 'b': 1}) // true\n *\n */\nimport curry from './curry'\nimport exists from './exists'\nimport identical from './identical'\nimport type from './type'\nimport not from './not'\nimport or from './or'\nimport isObject from './object/is'\nimport isArray from './array/is'\nimport isBoolean from './boolean/is'\nimport isNumber from './number/is'\nimport isString from './string/is'\nimport isDate from './date/is'\nimport equalsArray from './array/equals'\nimport equalsObject from './object/equals'\n\nexport default curry(function equals (x, y) {\n  if (identical(x, y)) return true\n\n  if (type(x) !== type(y)) return false\n\n  if (or(not(exists(x)), not(exists(y)))) return false\n\n  if (x.constructor !== y.constructor) return false\n\n  if (isString(x) || isBoolean(x) || isNumber(x) || isDate(x)) {\n    return identical(x.valueOf(), y.valueOf())\n  }\n  if (isArray(x)) {\n    return equalsArray(x, y)\n  } else if (isObject(x)) {\n    return equalsObject(x, y)\n  }\n  return false\n})\n","/**\n * @function exists\n */\nexport default function exists (x) {\n  return !(x == null)\n};\n","/**\n * Returns a single item by iterating over an array like object and call a function on each item\n *\n * @function fold\n * @description Returns a single item by iterating over an array like object and call a function on each item\n * @since v1.0.2\n * @sig ((a, b, c, a) → a) → a → [b] → a\n * @param {Function} cb receives 4 values: the accumulator, the item, the index, and the initial value.\n * @param {*} a is the initial value\n * @param {*} [b] the array like item to iterate over\n * @return {*} a is the accumulated value\n **/\n\nimport curry from './curry'\nimport arrayFold from './array/fold'\nimport objectFold from './object/fold'\nimport type from './type'\n\nexport default curry(function fold (cb, init, a) {\n  const typeMap = {\n    'Object': objectFold,\n    'Array': arrayFold\n  }\n  // if (a.next) {\n  //   return iterableFold(cb, init, a)\n  // }\n  // if (type(Symbol) !== 'undefined' && a[Symbol.iterator]) {\n  //   return iterableFold(cb, init, a[Symbol.iterator]())\n  // }\n  return typeMap[type(a)](cb, init, a)\n})\n\n// function iterableFold (cb, acc, gen) {\n//   let step = gen.next()\n//   while (!step.done) {\n//     acc = cb(acc, step.value)\n//     step = gen.next()\n//   }\n//   return acc\n// }\n","/**\n\n * @function identical\n * @description checks for identintical items\n */\nimport curry from './curry'\nimport isNan from './number/isNan'\n\nexport default curry(function identical (x, y) {\n  if (x === 0 && y === 0) {\n    return 1 / x === 1 / y\n  }\n  if (x === y) {\n    return true\n  }\n  return !!(isNan(x) && isNan(y))\n})\n","/**\n * @function is\n * @description Verifies the type of the provided argument\n *\n */\n\nimport curry from './curry'\nimport type from './type'\n\nexport default curry(function is (Ctor, val) {\n  return type(val) === Ctor\n})\n","/**\n * Created by dierickx.len on 01/04/2017.\n */\nimport is from '../is'\nconst isFunction = is('Function')\n\nexport default function isIter (iter) {\n  return isFunction(iter[Symbol.iterator])\n}\n","/**\n * Maps over an Iterator and applies a function\n *\n * @function\n * @since v1.0.3\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Iterator} a\n * @return {Iterator}\n **/\nimport curry from '../curry'\n\nexport default curry(function map (callback, iterator) {\n  let r = []\n  for (let nextValue = iterator.next(); nextValue.done !== true; nextValue = iterator.next()) {\n    r.push(callback(iterator.value()))\n  }\n  return r\n})\n","/**\n * Maps over an iterable and applies a function\n *\n * @function map\n * @description Autocurried function which maps over an iterable.\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> b -> b\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n **/\nimport curry from './curry'\nimport arrayMap from './array/map'\nimport objectMap from './object/map'\nimport mapMap from './map/map'\nimport stringMap from './string/map'\nimport iteratorMap from './iterator/map'\nimport type from './type'\nimport isIterator from './iterator/is'\n\nexport default curry(function map (cb, a) {\n  switch (type(a)) {\n    case 'Function':\n      return curry(function () {\n        return cb.call(this, a.apply(this, arguments))\n      })\n    case 'Object':\n      return objectMap(cb, a)\n    case 'String':\n      return stringMap(cb, a)\n    case 'Map':\n      return mapMap(cb, a)\n    case 'Array':\n      return arrayMap(cb, a)\n    default:\n      return isIterator(a)\n        ? iteratorMap(cb, a)\n        : arrayMap(cb, a)\n  }\n})\n","/**\n * Maps over a Map and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Map} a\n * @return {Map}\n **/\nimport curry from '../curry'\nimport empty from '../empty'\n\nexport default curry(function map (cb, a) {\n  const r = empty(a)\n  a.forEach((v, k, map) => {\n    r.set(k, cb(v, k, map))\n  })\n  return r\n})\n","/**\n * @function not\n */\nimport curry from './curry'\n\nexport default curry(function not (x) {\n  return !x\n})\n","/**\n * @private\n */\nimport is from '../is'\n\nexport default is('Number')\n","/**\n * @function isNaN\n * @description Checks if number is NAN\n\n */\nimport isNumber from './is'\nimport and from '../and'\n\nexport default function isNan (x) {\n  return and(isNumber(x), isNaN(x))\n};\n","/**\n\n * equals\n * checks for equality\n */\nimport curry from '../curry'\nimport exists from '../exists'\nimport not from '../not'\nimport equals from '../equals'\n\nexport default curry((x, y) => {\n  for (let keyX in x) {\n    // noinspection JSUnfilteredForInLoop\n    if (not(equals(x[keyX], y[keyX]))) return false\n  }\n\n  for (let keyY in y) {\n    if (not(exists(x[keyY])) && exists(y[keyY])) return false\n  }\n\n  return true\n})\n","/**\n * @function fold\n * @private\n *\n */\nimport curry from '../curry'\nimport keys from './keys'\n\nexport default curry(function fold (cb, init, o) {\n  const k = keys(o)\n  let i = -1\n  const l = k.length\n  let r = Object(init)\n  while (++i < l) {\n    r = cb(r, o[k[i]], k[i], o)\n  }\n  return r\n})\n","/**\n\n */\nimport is from '../is'\n\nexport default is('Object')\n","/**\n * Returns the own keys of an object as an Array\n *\n * @function\n * @since v1.0.2\n * @sig a -> [b]\n * @param {Object}\n * @return {Array}\n **/\nimport curry from '../curry'\n\nexport default curry(function keys (a) {\n  return Object.keys(Object(a))\n})\n","/**\n * Maps over an object and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Object} a\n * @return {Object}\n **/\nimport curry from '../curry'\nimport empty from '../empty'\nimport keys from './keys'\n\nexport default curry(function map (cb, a) {\n  const k = keys(a)\n  let i = -1\n  const l = k.length\n  const r = empty(a)\n  while (++i < l) {\n    r[k[i]] = cb(a[k[i]], k[i], a)\n  }\n  return r\n})\n","/**\n * @function or\n * @description Returns true if one or the other is true\n */\nimport curry from './curry'\n\nexport default curry(function or (x, y) {\n  return x || y\n})\n","/**\n * @private\n * @function stringConcat\n */\n\nexport default function concat (a, b) { // use function(), arrow function doesn't bind arguments\n  return String(a) + String(b)\n}\n","/**\n\n */\nimport is from '../is'\n\nexport default is('String')\n","/**\n * Maps over a string and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> [a] -> [a]\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n **/\nimport curry from '../curry'\n\nexport default curry(function map (cb, a) {\n  let i = -1\n  const l = a.length\n  let r = ''\n  while (++i < l) {\n    r += cb(a.charAt(i), i, a)\n  }\n  return r\n})\n","/**\n * @function type\n */\nimport curry1 from './_private/curry1'\n\nexport default curry1(function type (x) {\n  return Object.prototype.toString.call(x).slice(8, -1)\n})\n","import curry from 'fun.js/src/curry'\nimport map from 'fun.js/src/map'\nimport fold from 'fun.js/src/fold'\nimport equals from 'fun.js/src/equals'\nimport concat from './util/concat'\nimport empty from './util/empty'\nimport dot from './util/dot'\nimport identity from './util/identity'\nimport transpose from './util/transpose'\nimport generate from './util/generate'\n// import gpumap from 'util/gpumap'\n// import gpufold from 'util/gpufold'\n// import gpuproduct from 'util/gpuproduct'\n\n/**\n * @class Matrix\n * @classdesc Matrix applicative providing standard matrix operations\n * @summary The Matrix class should not be instantiated with the new keyword. Instead use the Matrix.of syntax to create a new Matrix. Unfortunatly jsdocs does not allow for the constructor to be hidden.\n * @hidecontructor\n * @see of\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n *\n */\nlet Matrix = function (val) {\n  this.__value = val\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.of\n * @desc Creates a Matrix object and flattens the Matrix\n * @param val {array|function} An array of arrays\n * @returns {Matrix}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n *\n */\nMatrix.of = function (val) {\n  if (val instanceof Matrix) return val\n  if (this instanceof Matrix) {\n    this.__value = val\n    return this\n  }\n  return new Matrix(val)\n}\n\n/**\n * @memberOf Matrix\n * @property {string} type\n * @type {string}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.type === 'Matrix'\n */\nMatrix.prototype.type = 'Matrix'\n\n/**\n * @memberOf Matrix\n * @property {number} precision\n * @type {number}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.precision === 4\n */\nMatrix.prototype.precision = 4\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#setPrecision\n * @param precision {number} Set the number of decimals for rounding\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.setPrecision(10)\n * m.precision === 10\n */\nMatrix.prototype.setPrecision = function (precision) {\n  this.precision = precision\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member isSymmetric\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSymmetric()\n *\n */\nMatrix.prototype.isSymmetric = function () {\n  const a = this.__value\n  const b = Matrix.transpose(this).__value\n  return equals(a, b)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#isSquare\n * @desc Boolean indicating whether this contains a square Matrix\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSquare()\n *\n */\nMatrix.prototype.isSquare = function () {\n  return equals(this.getCols(), this.getRows())\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#isOrthogonal\n * @param M {Matrix|array}\n * @returns {boolean}\n * @example\n *\n * const result = [[-0.3092, -0.9510], [-0.9510, 0.3092]]\n * const A = Matrix.fromArray(result)\n * true  === A.isOrthogonal()\n */\nMatrix.prototype.isOrthogonal = function () {\n  const AxAt = this.dot(this.transpose())\n  const I = this.identity()\n  return equals(AxAt, I)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#getCols\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getCols()  === 2\n *\n */\nMatrix.prototype.getCols = function () {\n  return this.__value[0].length\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#equals\n * @param M {Matrix|array}\n * @returns {Boolean}\n * @example\n *\n * var a = [[1, 1], [1, 1]]\n * var A = Matrix.of(a)\n * var B = Matrix.of(a)\n * true  === A.equals(B)\n */\nMatrix.prototype.equals = function (M) {\n  return equals(this.__value, M.__value || M)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#getRows\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getRows()  // 2\n */\nMatrix.prototype.getRows = function () {\n  return this.__value.length\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#getShape\n * @returns {Array}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getShape()  // [2, 2]\n */\nMatrix.prototype.getShape = function () {\n  return [this.getRows(), this.getCols()]\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#map\n * @description Maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.of([[1, 1], [1, 1]])\n * m.map(x => x.map(y => y+ 1))\n * // [[2, 2], [2, 2]]\n *\n */\nMatrix.prototype.map = function (f) {\n  return Matrix.of(map(f)(this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.map\n * @description Static function that maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @param M {Matrix|array} Matrix or array to map\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.map(x= > x.map(y => y+ 1), [[1, 1], [1, 1]])\n * // [[2, 2], [2, 2]]\n *\n */\nMatrix.map = curry(function (f, M) {\n  return Matrix.of(M).map(f)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#fold\n * @description Reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @returns {Matrix}\n * @example\n *\n * // Flatten Matrix\n * Matrix.of([[1, 1], [1, 1]]).fold((prev, next) => prev.concat(next))\n * // [1, 1, 1, 1]\n */\nMatrix.prototype.fold = function (f) {\n  return Matrix.of(fold(f, [])(this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.fold\n * @description Static function to reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @param M {Matrix} The Matrix to reduce\n * @returns {Matrix}\n * @example\n\n * // Sum of all matrix values\n * const reducer = (prev, next) => Number(prev) + next.reduce((acc, x) => acc + x, 0)\n * const A = Matrix.of([[1, 1], [1, 1]]\n * Matrix.fold(reducer, A)\n * // 4\n */\nMatrix.fold = curry(function (f, M) {\n  return Matrix.of(M).fold(f)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#ap\n * @description Applies a Matrix to a function\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * const A = Matrix.of([[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * Matrix.of(f).ap(M)\n * // [[6], [15], [24]\n */\nMatrix.prototype.ap = function (M) {\n  return Matrix.of(M).map(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.ap\n * @description Applies a Matrix to a function\n * @param f {function}\n * @param M {Matrix|array}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * Matrix.ap(f, [[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * // [[6], [15], [24]\n */\nMatrix.ap = curry(function (f, M) {\n  return Matrix.of(f).ap(M)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = A.concat(B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */\nMatrix.prototype.concat = function (M, f = concat) {\n  return Matrix.of(this).map(f(M))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param A {Matrix}\n * @param B {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = Matrix.concat(A, B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */\nMatrix.concat = curry(function (A, B, f = concat) {\n  return Matrix.of(A).map(f(B))\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#empty\n * @description Return an empty Matrix from an existing Matrix\n * @returns {Matrix}\n */\nMatrix.prototype.empty = function () {\n  return Matrix.of(this).map(empty)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.empty\n * @description Return an empty Matrix from an existing Matrix\n * @param rows {number}\n * @param cols {number}\n * @returns {Matrix}\n */\nMatrix.empty = curry(function (rows = 0, cols = 0) {\n  const m = generate(rows, cols) // Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n  return Matrix.of(m).map(empty)\n})\n\n// #### #### #### //\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const A = Matrix.of(a)\n * const Aidentity = A.identity()\n * // [[1, 0, 0], [0, 1, 0]]\n *\n */\nMatrix.prototype.identity = function () {\n  return Matrix.of(identity).ap(this)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.identity(3, 2)\n * // [[1, 0, 0], [0, 1, 0]]\n *\n */\nMatrix.identity = function (rows, cols) {\n  const m = generate(rows, cols) // Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n  return Matrix.of(identity).ap(m)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */\nMatrix.prototype.combine = function (M) {\n  return Matrix.of(this).concat(Matrix.of(M), concat)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */\nMatrix.combine = function (A, B) {\n  return Matrix.of(A).concat(Matrix.of(B), concat)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @param f\n * @returns {Matrix}\n * @example\n *\n * // Create matrix\n * const m = Matrix.of([[1, 2], [3, 4]])\n *\n * // Generate identity matrix\n * const I  = m.identity() // [[1, 0], [0, 1]]\n *\n * if(m.dot(I).equals(m)) {\n *    console.log('Dot product with identity matrix returns the same matrix')\n * }\n *\n */\nMatrix.prototype.dot = function (M) {\n  return Matrix.of(this).concat(Matrix.of(M), dot(this.precision))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @returns {Matrix}\n * @example\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const b = [[7, 8], [9, 10], [11, 12]]\n *\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n *\n * Matrix.dot(A, B) // [[58, 64], [139, 154]]\n *\n */\nMatrix.dot = function (A, B) {\n  return Matrix.of(A).dot(Matrix.of(B))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#fill\n * @desc Fill up an empty matrix with the provided map function\n * @param f\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).fill(x => 42)\n * // [[42,42,42], [42,42,42], [42,42,42]]\n *\n */\nMatrix.prototype.fill = function (f) {\n  return Matrix.of(this).map(map(x => f(x)))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#zeros\n * @desc Fill up an empty matrix with zeros\n * @returns {Matrix}\n *\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).zeros()\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */\nMatrix.prototype.zeros = function () {\n  return Matrix.of(this).fill(x => 0)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.zeros\n * @desc Fill up an empty matrix with zeros\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.zeros(3, 3)\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */\nMatrix.zeros = function (rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(x => 0)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#ones\n * @desc Fill up an empty matrix with ones\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).ones()\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */\nMatrix.prototype.ones = function () {\n  return Matrix.of(this).fill(x => 1)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.ones\n * @desc Fill up an empty matrix with ones\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.ones(1, 1)\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */\nMatrix.ones = function (rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(x => 1)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#random\n * @desc Fill up an empty matrix with random values\n * @param {function} [f = e => Math.random() * 2 - 1]\n * @returns {Matrix}\n */\nMatrix.prototype.random = function (f = e => Math.random() * 2 - 1) {\n  return Matrix.of(this).fill(f)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.random\n * @desc Fill up an empty matrix with random numbers\n * @param f {function} Function which returns random values. Default random values are between -1 and 1\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n */\nMatrix.random = function (f = e => (Math.random() * 2 - 1), rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(f)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#toArray\n * @desc Returns the array from the matrix\n * @returns {Array}\n */\nMatrix.prototype.toArray = function () {\n  return this.__value.map(row => row.map(col => col))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#clone\n * @desc Returns a clone of the matrix\n * @returns {Matrix}\n */\nMatrix.prototype.clone = function () {\n  return Matrix.fromArray(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#fromArray\n * @desc Returns a Matrix from an array\n * @returns {Array}\n */\nMatrix.fromArray = function (arr) {\n  return Matrix.of(map(row => map(col => col)(row))(arr))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#transpose\n * @desc Returns a transposed Matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([-1, 2], [3, 4], [-8, 2])\n * const b = A.transpose().toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */\nMatrix.prototype.transpose = function () {\n  return Matrix.of(fold(transpose, [], this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.transpose\n * @desc Returns a transposed Matrix\n * @param M {Matrix|array} A Matrix or a matrix array\n * @returns {Matrix}\n * @example\n *\n * const a = [-1, 2], [3, 4], [-8, 2]\n * const b = Matrix.transpose(a).toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */\nMatrix.transpose = function (M) {\n  return Matrix.of(M).transpose()\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.add\n * @instance\n * @param M {Matrix|number} Add a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.add(1) // [[6, 5]]\n * const B = Matrix.of([[5, 5]])\n * B.add(B) // [[10, 10]]\n *\n */\nMatrix.prototype.add = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      throw new Error('Matrices do not match, cannot add')\n    }\n    return this.map((row, idx) => map((val, jdx) => val + M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x + M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#subtract\n * @instance\n * @param M {Matrix|number} Subtract a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.subtract(1) // [[4, 2]]\n * const B = Matrix.of([[5, 5]])\n * B.subtract(B) // [[0, 0]]\n *\n */\nMatrix.prototype.subtract = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      throw new Error('Matrices do not match, cannot subtract')\n    }\n    return this.map((row, idx) => map((val, jdx) => val - M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x - M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#multiply\n * @instance\n * @desc Mutliply a scalar or a mtraix with a matrix. Throws an error if the multiplication is not possible.\n * @param M {Matrix|number}\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.multiply(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.multiply(B) // [[25, 25]]\n *\n */\nMatrix.prototype.multiply = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      console.log('Use static method \\'dot\\' to do matrix multiplication')\n      throw new Error('Matrices do not match, cannot create hadamard product')\n    }\n    return this.map((row, idx) => map((col, jdx) => col * M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x * M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#additiveinverse\n * @instance\n * @desc Function that returns the matrix obtained by changing the sign of every matrix element. The additive inverse of matrix A is written –A.\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5,-5], [-4, 4]])\n * const minusA = A.additiveinverse()\n * // [[-5, 5], [4, -4]]\n */\nMatrix.prototype.additiveinverse = function () {\n  return Matrix.of(this).multiply(-1)\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#hadamard\n * @instance\n * @see multiply\n * @param M\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.hadamard(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.hadamard(B) // [[25, 25]]\n\n */\nMatrix.prototype.hadamard = function (M) {\n  return Matrix.of(this).multiply(M)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#lu\n * @desc Calculates LU decomposition of the current Matrix\n * @returns {Matrix[]}\n * @example\n *\n * const result = [[3, -7, -2, 2], [-3, 5, 1, 0], [6, -4, 0, -5], [-9, 5, -5, 12]]\n * const A = Matrix.fromArray(result)\n * const lu = A.lu()\n * // L.__value = [ [ 1, 0, 0, 0 ], [ -1, 1, 0, 0 ], [ 2, -5, 1, 0 ], [ -3, 8, 3, 1 ] ]\n * // U.__value =  [ [ 3, -7, -2, 2 ], [ 0, -2, -1, 2 ], [ 0, 0, -1, 1 ], [ 0, 0, 0, -1 ] ]\n * Matrix.dot(lu[0], lu[1]) // returns clone of A\n *\n */\nMatrix.prototype.lu = function () {\n  const n = this.getRows()\n  const tol = 1e-6\n  const A = this.clone()\n  const L = this.zeros()\n  const U = this.zeros()\n\n  for (let k = 0; k < n; ++k) {\n    if (Math.abs(A.__value[k][k]) < tol) throw Error('Cannot proceed without a row exchange')\n    L.__value[k][k] = 1\n    for (let i = k + 1; i < n; ++i) {\n      L.__value[i][k] = A.__value[i][k] / A.__value[k][k]\n      for (let j = k + 1; j < n; ++j) {\n        A.__value[i][j] = A.__value[i][j] - L.__value[i][k] * A.__value[k][j]\n      }\n    }\n    for (let l = k; l < n; ++l) {\n      U.__value[k][l] = A.__value[k][l]\n    }\n  }\n  return [L, U]\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#rref\n * @returns {Matrix|array}\n * @example\n *\n * var A = Matrix.of([[-1, 1], [-1, 0], [0, -1], [-1, -2]])\n * A.rref() //  [ [ 1, 0 ], [ -0, 1 ], [ 0, 0 ], [ 0, 0 ] ]\n */\nMatrix.prototype.rref = function () {\n  let lead = 0\n  const resultMatrix = this.clone()\n\n  for (let r = 0; r < this.getRows(); ++r) {\n    if (this.getCols() <= lead) {\n      return resultMatrix\n    }\n    let i = r\n    while (resultMatrix.__value[i][lead] === 0) {\n      ++i\n      if (this.getRows() === i) {\n        i = r\n        ++lead\n        if (this.getCols() === lead) {\n          return resultMatrix\n        }\n      }\n    }\n\n    let tmp = resultMatrix.__value[i]\n    resultMatrix.__value[i] = resultMatrix.__value[r]\n    resultMatrix.__value[r] = tmp\n\n    let val = resultMatrix.__value[r][lead]\n    for (let j = 0; j < this.getCols(); ++j) {\n      resultMatrix.__value[r][j] /= val\n    }\n\n    for (let i = 0; i < this.getRows(); ++i) {\n      if (i === r) continue\n      val = resultMatrix.__value[i][lead]\n      for (let j = 0; j < this.getCols(); ++j) {\n        resultMatrix.__value[i][j] -= val * resultMatrix.__value[r][j]\n      }\n    }\n    lead++\n  }\n  return resultMatrix\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#solve\n * @param b\n * @returns {Array}\n * @example\n *\n * // Solve xA = b\n * // 5x + y  = 7\n * // 3x - 4y = 18\n * // Solution for x and y:\n * // x = 2\n * // y = -3\n *\n * const A = Matrix.of([[5, 1], [3, -4]])\n * const solveA = A.solve([7, 18]) // [2, -3]\n *\n */\nMatrix.prototype.solve = function (b) {\n  const A = this.clone()\n  const LU = A.lu()\n  const L = LU[0]\n  const U = LU[1]\n  const n = this.getRows()\n  let s = 0\n  const c = []\n  const x = []\n\n  for (let k = 0; k < n; ++k) {\n    for (let j = 0; j < k; ++j) {\n      s = s + L.__value[k][j] * c[j]\n    }\n    c[k] = b[k] - s\n    s = 0\n  }\n  for (let a = n - 1; a > -1; --a) {\n    let t = 0\n    for (let b = a + 1; b < n; ++b) {\n      t = t + U.__value[a][b] * x[b]\n    }\n    x[a] = (c[a] - t) / U.__value[a][a]\n  }\n  return x\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#inverse\n * @instance\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1, 1], [2, 4]]).inverse()\n * // [ [ 2, -0.5 ], [ -1, 0.5 ] ]\n *\n */\nMatrix.prototype.inverse = function () {\n  const A = this.clone()\n  const I = A.identity()\n  const Inv = A.concat(I).rref()\n\n  const result = Inv.__value.reduce((result, x, idx) => {\n    const half = x.length / 2\n    result.push(x.slice(half, x.length))\n    return result\n  }, [])\n  return Matrix.of(result)\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#rank\n * @instance\n * @returns {Number}\n */\nMatrix.prototype.rank = function () {\n  const rref = this.rref()\n  let result = 0\n  for (let i = 0; i < rref.getCols(); ++i) {\n    result += rref.__value[i][i]\n  }\n  return result\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#dimension\n * @instance\n * @see rank\n * @returns {Number}\n */\nMatrix.prototype.dimension = function () {\n  return this.rank()\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#diag\n * @instance\n * @desc Returns an array containing the values on the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diag()\n * // [1, 1, 1]\n *\n * const diag0 = Matrix.zeros(5, 5).diag()\n * // [0, 0, 0, 0, 0]\n *\n */\nMatrix.prototype.diag = function () {\n  return fold((acc, x, idx) => {\n    return acc.concat(x[idx])\n  })([])(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.diag\n * @desc Returns an array containing the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.diag([[2, 1], [1, 5]])\n * // [2, 5]\n *\n */\nMatrix.diag = function (M) {\n  return Matrix.of(M).diag()\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#diagproduct\n * @instance\n * @desc Returns the product of the values on the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diagproduct()\n * // 1\n *\n * const diag0 = Matrix.zeros(5, 5).diagproduct()\n * // 0\n *\n */\nMatrix.prototype.diagproduct = function () {\n  return fold((acc, x, idx) => {\n    acc *= x[idx]\n    return acc\n  })(1)(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.diagproduct\n * @desc Returns the product of the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.diagproduct([[2, 1], [1, 5]])\n * // 10\n *\n */\nMatrix.diagproduct = function (M) {\n  return Matrix.of(M).diagproduct()\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#sum\n * @instance\n * @desc Returns the sum of the values in the Matrix\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).sum()\n * // 9\n *\n * const diag0 = Matrix.zeros(5, 5).sum()\n * // 0\n *\n */\nMatrix.prototype.sum = function () {\n  return fold((acc, x) => {\n    acc += fold((prev, next) => prev + next)(0)(x)\n    return acc\n  })(0)(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.sum\n * @desc Returns the sum of the values in the Matrix\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.sum([[2, 1], [1, 5]])\n * // 9\n *\n */\nMatrix.sum = function (M) {\n  return Matrix.of(M).sum()\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#kronecker\n * @instance\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param M {Matrix} The right side Matrix of the product (this ⊗ M)\n * @returns {Matrix}\n */\nMatrix.prototype.kronecker = function (M) {\n  const m = this.getRows()\n  const n = this.getCols()\n  const p = M.getRows()\n  const q = M.getCols()\n\n  const left = this.__value\n  const right = M.__value\n\n  const frame = generate(m * p, n * q)\n\n  for (let i = 0; i < m; i++) {\n    for (let j = 0; j < n; j++) {\n      for (let k = 0; k < p; k++) {\n        for (let l = 0; l < q; l++) {\n          frame[p * i + k][q * j + l] = left[i][j] * right[k][l]\n        }\n      }\n    }\n  }\n\n  return Matrix.of(frame)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.kronecker\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param A {Matrix} The left side Matrix of the product (A ⊗ B)\n * @param B {Matrix} The right side Matrix of the product (A ⊗ B)\n * @returns {Matrix}\n */\nMatrix.kronecker = function (A, B) {\n  return Matrix.of(A).kronecker(B)\n}\n\nexport default Matrix\n","import curry from 'fun.js/src/curry'\nimport concat from 'fun.js/src/concat'\n\n/**\n * @function concat\n * @param M {Matrix}\n * @param m {Array}\n * @param idx {number}\n * @returns {Array}\n */\nexport default curry(function (M, m, idx) {\n  return concat(m, M.__value[idx])\n})\n","import curry from 'fun.js/src/curry'\nimport fold from 'fun.js/src/fold'\nimport map from 'fun.js/src/map'\nimport round from './round'\n\n/**\n * @function dot\n * @param B {Matrix}\n * @param a {Array}\n * @returns {Array}\n */\nexport default curry((decimals, B, a) => map((item, i) => {\n  return fold((acc, x, j) => {\n    acc += round(x * B.__value[j][i], decimals)\n    return acc\n  }, 0)(a)\n})(B.__value[0]))\n","import curry from 'fun.js/src/curry'\n\nexport default curry(m => [])\n","/**\n * @function generate\n * @desc Generator function for a matrix array, values are set to undefined\n * @param rows {number}\n * @param cols {number}\n * @returns {any[][]}\n */\nexport default (rows, cols) => Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n","import map from 'fun.js/src/map'\n\n/**\n * @function identity\n * @desc Creates an identiy matrix from an empty array\n * @param m {Array}\n * @param idx {number}\n * @return {Matrix}\n */\nexport default (m, idx) => map((rows, jdx) => (idx === jdx) * 1)(m)\n","/**\n * @function round\n * @param value {number}\n * @param decimals {number}\n * @returns {Number}\n */\nexport default function round (value, decimals) {\n  return Number(Math.round(value + 'e' + decimals) + 'e-' + decimals)\n}\n","import map from 'fun.js/src/map'\nimport curry from 'fun.js/src/curry'\n\n/**\n * @function transpose\n * @desc Transposes a array of arrays using the Matrix.map function\n * @param m {Array}\n * @param idx {number}\n * @return {Matrix}\n */\nexport default curry((prev, next) => map((item, i) => (prev[i] || []).concat(next[i]))(next))\n"],"sourceRoot":""} \ No newline at end of file diff --git a/lib/@astuanax/funmatrix.min.js b/lib/@astuanax/funmatrix.min.js index fbb103a..ce9a953 100644 --- a/lib/@astuanax/funmatrix.min.js +++ b/lib/@astuanax/funmatrix.min.js @@ -1,2 +1,2 @@ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define("@astuanax/funmatrix",[],e):"object"==typeof exports?exports["@astuanax/funmatrix"]=e():t["@astuanax/funmatrix"]=e()}("undefined"!=typeof self?self:this,function(){return function(t){var e={};function n(r){if(e[r])return e[r].exports;var u=e[r]={i:r,l:!1,exports:{}};return t[r].call(u.exports,u,u.exports,n),u.l=!0,u.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var u in t)n.d(r,u,function(e){return t[e]}.bind(null,u));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=6)}([function(t,e,n){"use strict";function r(t){const e=t.length;return 0===e?t:n([]);function n(r){return function(){return function(r,u){const o=r.concat(u);return o.length{n.set(r,t(e,r,u))}),n}),c=Object(r.default)(function(t,e){let n=-1;const r=e.length;let u="";for(;++n1&&void 0!==arguments[1]?arguments[1]:a.default;return v.of(this).map(e(t))},v.concat=(0,r.default)(function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:a.default;return v.of(t).map(n(e))}),v.prototype.empty=function(){return v.of(this).map(i.default)},v.empty=(0,r.default)(function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=(0,d.default)(t,e);return v.of(n).map(i.default)}),v.prototype.identity=function(){return v.of(l.default).ap(this)},v.identity=function(t,e){var n=(0,d.default)(t,e);return v.of(l.default).ap(n)},v.prototype.combine=function(t){return v.of(this).concat(v.of(t),a.default)},v.combine=function(t,e){return v.of(t).concat(v.of(e),a.default)},v.prototype.dot=function(t){return v.of(this).concat(v.of(t),(0,c.default)(this.precision))},v.dot=function(t,e){return v.of(t).dot(v.of(e))},v.prototype.fill=function(t){return v.of(this).map((0,u.default)(function(e){return t(e)}))},v.prototype.zeros=function(){return v.of(this).fill(function(t){return 0})},v.zeros=function(t,e){var n=(0,d.default)(t,e);return v.of(n).fill(function(t){return 0})},v.prototype.ones=function(){return v.of(this).fill(function(t){return 1})},v.ones=function(t,e){var n=(0,d.default)(t,e);return v.of(n).fill(function(t){return 1})},v.prototype.random=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:function(t){return 2*Math.random()-1};return v.of(this).fill(t)},v.random=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:function(t){return 2*Math.random()-1},e=arguments[1],n=arguments[2],r=(0,d.default)(e,n);return v.of(r).fill(t)},v.prototype.toArray=function(){return this.__value.map(function(t){return t.map(function(t){return t})})},v.prototype.clone=function(){return v.fromArray(this.__value)},v.fromArray=function(t){return v.of((0,u.default)(function(t){return(0,u.default)(function(t){return t})(t)})(t))},v.prototype.transpose=function(){return v.of((0,o.default)(s.default,[],this.__value))},v.transpose=function(t){return v.of(t).transpose()},v.prototype.add=function(t){if(t instanceof v){if(this.getCols()!==t.getCols()||this.getRows()!==t.getRows())throw new Error("Matrices do not match, cannot add");return this.map(function(e,n){return(0,u.default)(function(e,r){return e+t.__value[n][r]})(e)})}return this.map((0,u.default)(function(e){return e+t}))},v.prototype.subtract=function(t){if(t instanceof v){if(this.getCols()!==t.getCols()||this.getRows()!==t.getRows())throw new Error("Matrices do not match, cannot subtract");return this.map(function(e,n){return(0,u.default)(function(e,r){return e-t.__value[n][r]})(e)})}return this.map((0,u.default)(function(e){return e-t}))},v.prototype.multiply=function(t){if(t instanceof v){if(this.getCols()!==t.getCols()||this.getRows()!==t.getRows())throw console.log("Use static method 'dot' to do matrix multiplication"),new Error("Matrices do not match, cannot create hadamard product");return this.map(function(e,n){return(0,u.default)(function(e,r){return e*t.__value[n][r]})(e)})}return this.map((0,u.default)(function(e){return e*t}))},v.prototype.additiveinverse=function(){return v.of(this).multiply(-1)},v.prototype.hadamard=function(t){return v.of(this).multiply(t)},v.prototype.lu=function(){for(var t=this.getRows(),e=this.clone(),n=this.zeros(),r=this.zeros(),u=0;u-1;--l){for(var s=0,d=l+1;d{for(let n in t)if(s(j(t[n],e[n])))return!1;for(let n in e)if(s(u(t[n]))&&u(e[n]))return!1;return!0}),j=e.default=Object(r.default)(function(t,e){return!!c(t,e)||Object(l.a)(t)===Object(l.a)(e)&&(!d(s(u(t)),s(u(e)))&&(t.constructor===e.constructor&&(h(t)||_(t)||f(t)||y(t)?c(t.valueOf(),e.valueOf()):v(t)?b(t,e):!!p(t)&&g(t,e))))})},function(t,e,n){"use strict";n.r(e);var r=n(0),u=Object(r.default)(function(t,e){return Array.prototype.concat(t,e)});function o(t,e){return String(t)+String(e)}var f=n(2);e.default=Object(r.default)(function(t,e){return{String:o,Array:u}[Object(f.a)(t)](t,e)})}])}); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://@astuanax/funmatrix/webpack/universalModuleDefinition","webpack://@astuanax/funmatrix/webpack/bootstrap","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/curry.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/type.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/_private/curry1.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/empty.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/map/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/iterator/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/iterator/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/keys.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/fold.js","webpack://@astuanax/funmatrix/./src/matrix.js","webpack://@astuanax/funmatrix/./src/util/concat.js","webpack://@astuanax/funmatrix/./src/util/empty.js","webpack://@astuanax/funmatrix/./src/util/dot.js","webpack://@astuanax/funmatrix/./src/util/round.js","webpack://@astuanax/funmatrix/./src/util/identity.js","webpack://@astuanax/funmatrix/./src/util/transpose.js","webpack://@astuanax/funmatrix/./src/util/generate.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/exists.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/number/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/and.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/number/isNan.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/identical.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/not.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/or.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/boolean/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/date/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/concat.js"],"names":["root","factory","exports","module","define","amd","self","this","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","curry","fun","argslen","length","createRecurser","acc","args","_acc","concat","apply","recurse","Array","slice","arguments","__webpack_exports__","_curry__WEBPACK_IMPORTED_MODULE_0__","_type__WEBPACK_IMPORTED_MODULE_1__","Ctor","val","fn","x","toString","a","array_map","cb","empty","constructor","object_map","k","keys","map_map","forEach","v","map","set","string_map","charAt","iterator_map","callback","iterator","nextValue","next","done","push","isFunction","is","type","array_fold","init","object_fold","_curry","_interopRequireDefault","_map","_fold","_equals","_concat","_empty","_dot","_identity","_transpose","_generate","Matrix","__value","precision","setPrecision","isSymmetric","b","transpose","default","isSquare","getCols","getRows","isOrthogonal","AxAt","dot","I","identity","equals","M","getShape","of","f","fold","ap","undefined","A","B","rows","cols","combine","fill","zeros","ones","random","e","Math","toArray","row","col","clone","fromArray","arr","add","Error","idx","jdx","subtract","multiply","console","log","additiveinverse","hadamard","lu","L","U","abs","j","rref","lead","resultMatrix","tmp","solve","LU","inverse","result","reduce","half","rank","dimension","diag","diagproduct","sum","prev","kronecker","q","left","right","frame","_round","decimals","item","Number","round","exists","number_is","and","y","isNan","isNaN","src_identical","not","or","object_is","array_is","boolean_is","string_is","date_is","array_equals","src_equals","object_equals","keyX","keyY","valueOf","array_concat","concat_concat","String"],"mappings":"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","file":"@astuanax/funmatrix.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"@astuanax/funmatrix\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"@astuanax/funmatrix\"] = factory();\n\telse\n\t\troot[\"@astuanax/funmatrix\"] = factory();\n})(typeof self !== 'undefined' ? self : this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 6);\n","/* eslint-disable no-use-before-define */\n/**\n * @function curry\n * @description Autocurries the provided function\n */\nexport default function curry (fun) {\n  const argslen = fun.length\n\n  if (argslen === 0) {\n    return fun\n  }\n  return createRecurser([])\n\n  function recurse (acc, args) {\n    const _acc = acc.concat(args)\n    return _acc.length < argslen\n      ? createRecurser(_acc)\n      : fun.apply(this, _acc)\n  }\n\n  function createRecurser (acc) {\n    return function () {\n      return recurse(acc, Array.prototype.slice.call(arguments))\n    }\n  }\n}\n","/**\n * @function is\n * @description Verifies the type of the provided argument\n *\n */\n\nimport curry from './curry'\nimport type from './type'\n\nexport default curry(function is (Ctor, val) {\n  return type(val) === Ctor\n})\n","/**\n * @function type\n */\nimport curry1 from './_private/curry1'\n\nexport default curry1(function type (x) {\n  return Object.prototype.toString.call(x).slice(8, -1)\n})\n","/**\n * Returns a curried function with arity 1\n * @function curry1\n * @private\n * @since v1.0.2\n **/\n\nexport default function curry1 (fn) {\n  return function curried (a) {\n    return arguments.length === 0\n      ? this\n      : fn(a)\n  }\n}\n","/**\n * @function map\n * @description Maps over an array and applies a function\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n * @since v1.0.2\n * @example\n *\n *  const result = map(identity, [0,2,3])\n *  // result = [0,2,3]\n *  const add2 = add(2)\n *  const result = map(add2, [0,2,3])\n *  // result = [2,4,5]\n **/\nimport curry from '../curry'\n\nexport default curry(function map (cb, a) {\n  let i = -1\n  const l = a.length\n  const r = new Array(l)\n  while (++i < l) {\n    r[i] = cb(a[i], i, a)\n  }\n  return r\n})\n","/**\n\n * @function empty\n * @description Returns the empty equivalent of the first argument\n */\n\nexport default function empty (x) {\n  return new x.constructor()\n};\n","/**\n * Maps over an object and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Object} a\n * @return {Object}\n **/\nimport curry from '../curry'\nimport empty from '../empty'\nimport keys from './keys'\n\nexport default curry(function map (cb, a) {\n  const k = keys(a)\n  let i = -1\n  const l = k.length\n  const r = empty(a)\n  while (++i < l) {\n    r[k[i]] = cb(a[k[i]], k[i], a)\n  }\n  return r\n})\n","/**\n * Maps over a Map and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Map} a\n * @return {Map}\n **/\nimport curry from '../curry'\nimport empty from '../empty'\n\nexport default curry(function map (cb, a) {\n  const r = empty(a)\n  a.forEach((v, k, map) => {\n    r.set(k, cb(v, k, map))\n  })\n  return r\n})\n","/**\n * Maps over a string and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> [a] -> [a]\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n **/\nimport curry from '../curry'\n\nexport default curry(function map (cb, a) {\n  let i = -1\n  const l = a.length\n  let r = ''\n  while (++i < l) {\n    r += cb(a.charAt(i), i, a)\n  }\n  return r\n})\n","/**\n * Maps over an Iterator and applies a function\n *\n * @function\n * @since v1.0.3\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Iterator} a\n * @return {Iterator}\n **/\nimport curry from '../curry'\n\nexport default curry(function map (callback, iterator) {\n  let r = []\n  for (let nextValue = iterator.next(); nextValue.done !== true; nextValue = iterator.next()) {\n    r.push(callback(iterator.value()))\n  }\n  return r\n})\n","/**\n * Created by dierickx.len on 01/04/2017.\n */\nimport is from '../is'\nconst isFunction = is('Function')\n\nexport default function isIter (iter) {\n  return isFunction(iter[Symbol.iterator])\n}\n","/**\n * Maps over an iterable and applies a function\n *\n * @function map\n * @description Autocurried function which maps over an iterable.\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> b -> b\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n **/\nimport curry from './curry'\nimport arrayMap from './array/map'\nimport objectMap from './object/map'\nimport mapMap from './map/map'\nimport stringMap from './string/map'\nimport iteratorMap from './iterator/map'\nimport type from './type'\nimport isIterator from './iterator/is'\n\nexport default curry(function map (cb, a) {\n  switch (type(a)) {\n    case 'Function':\n      return curry(function () {\n        return cb.call(this, a.apply(this, arguments))\n      })\n    case 'Object':\n      return objectMap(cb, a)\n    case 'String':\n      return stringMap(cb, a)\n    case 'Map':\n      return mapMap(cb, a)\n    case 'Array':\n      return arrayMap(cb, a)\n    default:\n      return isIterator(a)\n        ? iteratorMap(cb, a)\n        : arrayMap(cb, a)\n  }\n})\n","/**\n * Returns the own keys of an object as an Array\n *\n * @function\n * @since v1.0.2\n * @sig a -> [b]\n * @param {Object}\n * @return {Array}\n **/\nimport curry from '../curry'\n\nexport default curry(function keys (a) {\n  return Object.keys(Object(a))\n})\n","/**\n * @private\n * @function fold\n * @description Returns a single item by mapping over the provided array and calling an iterator function\n * @param {cbFunction} cb - Callback function to modify the item\n * @param {*} init - Initial value\n * @param {Array} a - Array with items to modify by the cb function\n * @return {Array}\n * @alias reduce\n * @since 1.0.2\n * @example\n *\n * const result = fold(add, 0, [1,1,1])\n * // result = 3\n */\n\n/**\n * @callback cbFunction\n * @param {*} r - Accumulator which accumulates the callback's return values\n * @param {*} item - the current element being processed\n * @param {number} index - the indey of the item being processed\n * @param {Array} a - The initial array\n * @return {*}\n */\nimport curry from '../curry'\n\nexport default curry(function fold (cb, init, a) {\n  let i = -1\n  const l = a.length\n  let r = init\n  while (++i < l) {\n    r = cb(r, a[i], i, a)\n  }\n  return r\n})\n","/**\n * @function fold\n * @private\n *\n */\nimport curry from '../curry'\nimport keys from './keys'\n\nexport default curry(function fold (cb, init, o) {\n  const k = keys(o)\n  let i = -1\n  const l = k.length\n  let r = Object(init)\n  while (++i < l) {\n    r = cb(r, o[k[i]], k[i], o)\n  }\n  return r\n})\n","/**\n * Returns a single item by iterating over an array like object and call a function on each item\n *\n * @function fold\n * @description Returns a single item by iterating over an array like object and call a function on each item\n * @since v1.0.2\n * @sig ((a, b, c, a) → a) → a → [b] → a\n * @param {Function} cb receives 4 values: the accumulator, the item, the index, and the initial value.\n * @param {*} a is the initial value\n * @param {*} [b] the array like item to iterate over\n * @return {*} a is the accumulated value\n **/\n\nimport curry from './curry'\nimport arrayFold from './array/fold'\nimport objectFold from './object/fold'\nimport type from './type'\n\nexport default curry(function fold (cb, init, a) {\n  const typeMap = {\n    'Object': objectFold,\n    'Array': arrayFold\n  }\n  // if (a.next) {\n  //   return iterableFold(cb, init, a)\n  // }\n  // if (type(Symbol) !== 'undefined' && a[Symbol.iterator]) {\n  //   return iterableFold(cb, init, a[Symbol.iterator]())\n  // }\n  return typeMap[type(a)](cb, init, a)\n})\n\n// function iterableFold (cb, acc, gen) {\n//   let step = gen.next()\n//   while (!step.done) {\n//     acc = cb(acc, step.value)\n//     step = gen.next()\n//   }\n//   return acc\n// }\n","import curry from 'fun.js/src/curry'\nimport map from 'fun.js/src/map'\nimport fold from 'fun.js/src/fold'\nimport equals from 'fun.js/src/equals'\nimport concat from 'util/concat'\nimport empty from 'util/empty'\nimport dot from 'util/dot'\nimport identity from 'util/identity'\nimport transpose from 'util/transpose'\nimport generate from 'util/generate'\n\n/**\n * @class Matrix\n * @classdesc Matrix applicative providing standard matrix operations\n * @summary The Matrix class should not be instantiated with the new keyword. Instead use the Matrix.of syntax to create a new Matrix. Unfortunatly jsdocs does not allow for the constructor to be hidden.\n * @hidecontructor\n * @see of\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n *\n */\nlet Matrix = function (val) {\n  this.__value = val\n}\n\n/**\n * @memberOf Matrix\n * @property {string} type\n * @type {string}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.type === 'Matrix'\n */\nMatrix.prototype.type = 'Matrix'\n\n/**\n * @memberOf Matrix\n * @property {number} precision\n * @type {number}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.precision === 4\n */\nMatrix.prototype.precision = 4\n\n/**\n * @memberOf Matrix\n * @instance\n * @member setPrecision\n * @param precision {number} Set the number of decimals for rounding\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.setPrecision(10)\n * m.precision === 10\n */\nMatrix.prototype.setPrecision = function (precision) {\n  this.precision = precision\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member isSymmetric\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSymmetric()\n *\n */\nMatrix.prototype.isSymmetric = function () {\n  const a = this.__value\n  const b = Matrix.transpose(this).__value\n  return equals(a, b)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member isSquare\n * @desc Boolean indicating whether this contains a square Matrix\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSquare()\n *\n */\nMatrix.prototype.isSquare = function () {\n  return equals(this.getCols(), this.getRows())\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member isOrthogonal\n * @param M {Matrix|array}\n * @returns {boolean}\n * @example\n *\n * const result = [[-0.3092, -0.9510], [-0.9510, 0.3092]]\n * const A = Matrix.fromArray(result)\n * true  === A.isOrthogonal()\n */\nMatrix.prototype.isOrthogonal = function () {\n  const AxAt = this.dot(this.transpose())\n  const I = this.identity()\n  return equals(AxAt, I)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member getCols\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getCols()  === 2\n *\n */\nMatrix.prototype.getCols = function () {\n  return this.__value[0].length\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member equals\n * @param M {Matrix|array}\n * @returns {Boolean}\n * @example\n *\n * var a = [[1, 1], [1, 1]]\n * var A = Matrix.of(a)\n * var B = Matrix.of(a)\n * true  === A.equals(B)\n */\nMatrix.prototype.equals = function (M) {\n  return equals(this.__value, M.__value || M)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member getRows\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getRows()  // 2\n */\nMatrix.prototype.getRows = function () {\n  return this.__value.length\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member getShape\n * @returns {Array}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getShape()  // [2, 2]\n */\nMatrix.prototype.getShape = function () {\n  return [this.getRows(), this.getCols()]\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function of\n * @desc Creates a Matrix object and flattens the Matrix\n * @param val {array|function} An array of arrays\n * @returns {Matrix}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n *\n */\nMatrix.of = function (val) {\n  if (val instanceof Matrix) return val\n  if (this instanceof Matrix) {\n    this.__value = val\n    return this\n  }\n  return new Matrix(val)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member map\n * @description Maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.of([[1, 1], [1, 1]])\n * m.map(x => x.map(y => y+ 1))\n * // [[2, 2], [2, 2]]\n *\n */\nMatrix.prototype.map = function (f) {\n  return Matrix.of(map(f)(this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function map\n * @description Static function that maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @param M {Matrix|array} Matrix or array to map\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.map(x= > x.map(y => y+ 1), [[1, 1], [1, 1]])\n * // [[2, 2], [2, 2]]\n *\n */\nMatrix.map = curry(function (f, M) {\n  return Matrix.of(M).map(f)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member fold\n * @description Reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @returns {Matrix}\n * @example\n *\n * // Flatten Matrix\n * Matrix.of([[1, 1], [1, 1]]).fold((prev, next) => prev.concat(next))\n * // [1, 1, 1, 1]\n */\nMatrix.prototype.fold = function (f) {\n  return Matrix.of(fold(f, [])(this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function fold\n * @description Static function to reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @param M {Matrix} The Matrix to reduce\n * @returns {Matrix}\n * @example\n\n * // Sum of all matrix values\n * const reducer = (prev, next) => Number(prev) + next.reduce((acc, x) => acc + x, 0)\n * const A = Matrix.of([[1, 1], [1, 1]]\n * Matrix.fold(reducer, A)\n * // 4\n */\nMatrix.fold = curry(function (f, M) {\n  return Matrix.of(M).fold(f)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member ap\n * @description Applies a Matrix to a function\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * const A = Matrix.of([[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * Matrix.of(f).ap(M)\n * // [[6], [15], [24]\n */\nMatrix.prototype.ap = function (M) {\n  return Matrix.of(M).map(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function ap\n * @description Applies a Matrix to a function\n * @param f {function}\n * @param M {Matrix|array}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * Matrix.ap(f, [[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * // [[6], [15], [24]\n */\nMatrix.ap = curry(function (f, M) {\n  return Matrix.of(f).ap(M)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = A.concat(B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */\nMatrix.prototype.concat = function (M, f = concat) {\n  return Matrix.of(this).map(f(M))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param A {Matrix}\n * @param B {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = Matrix.concat(A, B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */\nMatrix.concat = curry(function (A, B, f = concat) {\n  return Matrix.of(A).map(f(B))\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member empty\n * @description Return an empty Matrix from an existing Matrix\n * @returns {Matrix}\n */\nMatrix.prototype.empty = function () {\n  return Matrix.of(this).map(empty)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function empty\n * @description Return an empty Matrix from an existing Matrix\n * @param rows {number}\n * @param cols {number}\n * @returns {Matrix}\n */\nMatrix.empty = curry(function (rows = 0, cols = 0) {\n  const m = generate(rows, cols) // Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n  return Matrix.of(m).map(empty)\n})\n\n// #### #### #### //\n\n/**\n * @memberOf Matrix\n * @instance\n * @member identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const A = Matrix.of(a)\n * const Aidentity = A.identity()\n * // [[1, 0, 0], [0, 1, 0]]\n *\n*/\nMatrix.prototype.identity = function () {\n  return Matrix.of(identity).ap(this)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.identity(3, 2)\n * // [[1, 0, 0], [0, 1, 0]]\n *\n */\nMatrix.identity = function (rows, cols) {\n  const m = generate(rows, cols) // Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n  return Matrix.of(identity).ap(m)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */\nMatrix.prototype.combine = function (M) {\n  return Matrix.of(this).concat(Matrix.of(M), concat)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */\nMatrix.combine = function (A, B) {\n  return Matrix.of(A).concat(Matrix.of(B), concat)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @param f\n * @returns {Matrix}\n * @example\n *\n * // Create matrix\n * const m = Matrix.of([[1, 2], [3, 4]])\n *\n * // Generate identity matrix\n * const I  = m.identity() // [[1, 0], [0, 1]]\n *\n * if(m.dot(I).equals(m)) {\n *    console.log('Dot product with identity matrix returns the same matrix')\n * }\n *\n */\nMatrix.prototype.dot = function (M) {\n  return Matrix.of(this).concat(Matrix.of(M), dot(this.precision))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @returns {Matrix}\n * @example\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const b = [[7, 8], [9, 10], [11, 12]]\n *\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n *\n * Matrix.dot(A, B) // [[58, 64], [139, 154]]\n *\n */\nMatrix.dot = function (A, B) {\n  return Matrix.of(A).dot(Matrix.of(B))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member fill\n * @desc Fill up an empty matrix with the provided map function\n * @param f\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).fill(x => 42)\n * // [[42,42,42], [42,42,42], [42,42,42]]\n *\n */\nMatrix.prototype.fill = function (f) {\n  return Matrix.of(this).map(map(x => f(x)))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member zeros\n * @desc Fill up an empty matrix with zeros\n * @returns {Matrix}\n *\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).zeros()\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */\nMatrix.prototype.zeros = function () {\n  return Matrix.of(this).fill(x => 0)\n}\n\n/**\n * @memberOf Matrix\n * @function zeros\n * @desc Fill up an empty matrix with zeros\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.zeros(3, 3)\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */\nMatrix.zeros = function (rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(x => 0)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member ones\n * @desc Fill up an empty matrix with ones\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).ones()\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */\nMatrix.prototype.ones = function () {\n  return Matrix.of(this).fill(x => 1)\n}\n\n/**\n * @memberOf Matrix\n * @function ones\n * @desc Fill up an empty matrix with ones\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.ones(1, 1)\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */\nMatrix.ones = function (rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(x => 1)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member random\n * @desc Fill up an empty matrix with random values\n * @param {function} [f = e => Math.random() * 2 - 1]\n * @returns {Matrix}\n */\nMatrix.prototype.random = function (f = e => Math.random() * 2 - 1) {\n  return Matrix.of(this).fill(f)\n}\n\n/**\n * @memberOf Matrix\n * @function random\n * @desc Fill up an empty matrix with random numbers\n * @param f {function} Function which returns random values. Default random values are between -1 and 1\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n */\nMatrix.random = function (f = e => (Math.random() * 2 - 1), rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(f)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member toArray\n * @desc Returns the array from the matrix\n * @returns {Array}\n */\nMatrix.prototype.toArray = function () {\n  return this.__value.map(row => row.map(col => col))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member clone\n * @desc Returns a clone of the matrix\n * @returns {Matrix}\n */\nMatrix.prototype.clone = function () {\n  return Matrix.fromArray(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member fromArray\n * @desc Returns a Matrix from an array\n * @returns {Array}\n */\nMatrix.fromArray = function (arr) {\n  return Matrix.of(map(row => map(col => col)(row))(arr))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member transpose\n * @desc Returns a transposed Matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([-1, 2], [3, 4], [-8, 2])\n * const b = A.transpose().toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */\nMatrix.prototype.transpose = function () {\n  return Matrix.of(fold(transpose, [], this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @function transpose\n * @desc Returns a transposed Matrix\n * @param M {Matrix|array} A Matrix or a matrix array\n * @returns {Matrix}\n * @example\n *\n * const a = [-1, 2], [3, 4], [-8, 2]\n * const b = Matrix.transpose(a).toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */\nMatrix.transpose = function (M) {\n  return Matrix.of(M).transpose()\n}\n\n/**\n * @memberOf Matrix\n * @member add\n * @instance\n * @param M {Matrix|number} Add a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.add(1) // [[6, 5]]\n * const B = Matrix.of([[5, 5]])\n * B.add(B) // [[10, 10]]\n *\n */\nMatrix.prototype.add = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      throw new Error('Matrices do not match, cannot add')\n    }\n    return this.map((row, idx) => map((val, jdx) => val + M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x + M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member subtract\n * @instance\n * @param M {Matrix|number} Subtract a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.subtract(1) // [[4, 2]]\n * const B = Matrix.of([[5, 5]])\n * B.subtract(B) // [[0, 0]]\n *\n */\nMatrix.prototype.subtract = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      throw new Error('Matrices do not match, cannot subtract')\n    }\n    return this.map((row, idx) => map((val, jdx) => val - M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x - M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member multiply\n * @instance\n * @desc Mutliply a scalar or a mtraix with a matrix. Throws an error if the multiplication is not possible.\n * @param M {Matrix|number}\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.multiply(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.multiply(B) // [[25, 25]]\n *\n */\nMatrix.prototype.multiply = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      console.log('Use static method \\'dot\\' to do matrix multiplication')\n      throw new Error('Matrices do not match, cannot create hadamard product')\n    }\n    return this.map((row, idx) => map((col, jdx) => col * M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x * M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member additiveinverse\n * @instance\n * @desc Function that returns the matrix obtained by changing the sign of every matrix element. The additive inverse of matrix A is written –A.\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5,-5], [-4, 4]])\n * const minusA = A.additiveinverse()\n * // [[-5, 5], [4, -4]]\n */\nMatrix.prototype.additiveinverse = function () {\n  return Matrix.of(this).multiply(-1)\n}\n\n/**\n * @memberOf Matrix\n * @member hadamard\n * @instance\n * @see multiply\n * @param M\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.hadamard(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.hadamard(B) // [[25, 25]]\n\n */\nMatrix.prototype.hadamard = function (M) {\n  return Matrix.of(this).multiply(M)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member lu\n * @desc Calculates LU decomposition of the current Matrix\n * @returns {Matrix[]}\n * @example\n *\n * const result = [[3, -7, -2, 2], [-3, 5, 1, 0], [6, -4, 0, -5], [-9, 5, -5, 12]]\n * const A = Matrix.fromArray(result)\n * const lu = A.lu()\n * // L.__value = [ [ 1, 0, 0, 0 ], [ -1, 1, 0, 0 ], [ 2, -5, 1, 0 ], [ -3, 8, 3, 1 ] ]\n * // U.__value =  [ [ 3, -7, -2, 2 ], [ 0, -2, -1, 2 ], [ 0, 0, -1, 1 ], [ 0, 0, 0, -1 ] ]\n * Matrix.dot(lu[0], lu[1]) // returns clone of A\n *\n */\nMatrix.prototype.lu = function () {\n  const n = this.getRows()\n  const tol = 1e-6\n  const A = this.clone()\n  const L = this.zeros()\n  const U = this.zeros()\n\n  for (let k = 0; k < n; ++k) {\n    if (Math.abs(A.__value[k][k]) < tol) throw Error('Cannot proceed without a row exchange')\n    L.__value[k][k] = 1\n    for (let i = k + 1; i < n; ++i) {\n      L.__value[i][k] = A.__value[i][k] / A.__value[k][k]\n      for (let j = k + 1; j < n; ++j) {\n        A.__value[i][j] = A.__value[i][j] - L.__value[i][k] * A.__value[k][j]\n      }\n    }\n    for (let l = k; l < n; ++l) {\n      U.__value[k][l] = A.__value[k][l]\n    }\n  }\n  return [L, U]\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member rref\n * @returns {Matrix|array}\n * @example\n *\n * var A = Matrix.of([[-1, 1], [-1, 0], [0, -1], [-1, -2]])\n * A.rref() //  [ [ 1, 0 ], [ -0, 1 ], [ 0, 0 ], [ 0, 0 ] ]\n */\nMatrix.prototype.rref = function () {\n  let lead = 0\n  const resultMatrix = this.clone()\n\n  for (let r = 0; r < this.getRows(); ++r) {\n    if (this.getCols() <= lead) {\n      return resultMatrix\n    }\n    let i = r\n    while (resultMatrix.__value[i][lead] === 0) {\n      ++i\n      if (this.getRows() === i) {\n        i = r\n        ++lead\n        if (this.getCols() === lead) {\n          return resultMatrix\n        }\n      }\n    }\n\n    let tmp = resultMatrix.__value[i]\n    resultMatrix.__value[i] = resultMatrix.__value[r]\n    resultMatrix.__value[r] = tmp\n\n    let val = resultMatrix.__value[r][lead]\n    for (let j = 0; j < this.getCols(); ++j) {\n      resultMatrix.__value[r][j] /= val\n    }\n\n    for (let i = 0; i < this.getRows(); ++i) {\n      if (i === r) continue\n      val = resultMatrix.__value[i][lead]\n      for (let j = 0; j < this.getCols(); ++j) {\n        resultMatrix.__value[i][j] -= val * resultMatrix.__value[r][j]\n      }\n    }\n    lead++\n  }\n  return resultMatrix\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member solve\n * @param b\n * @returns {Array}\n * @example\n *\n * // Solve xA = b\n * // 5x + y  = 7\n * // 3x - 4y = 18\n * // Solution for x and y:\n * // x = 2\n * // y = -3\n *\n * const A = Matrix.of([[5, 1], [3, -4]])\n * const solveA = A.solve([7, 18]) // [2, -3]\n *\n */\nMatrix.prototype.solve = function (b) {\n  const A = this.clone()\n  const LU = A.lu()\n  const L = LU[0]\n  const U = LU[1]\n  const n = this.getRows()\n  let s = 0\n  const c = []\n  const x = []\n\n  for (let k = 0; k < n; ++k) {\n    for (let j = 0; j < k; ++j) {\n      s = s + L.__value[k][j] * c[j]\n    }\n    c[k] = b[k] - s\n    s = 0\n  }\n  for (let a = n - 1; a > -1; --a) {\n    let t = 0\n    for (let b = a + 1; b < n; ++b) {\n      t = t + U.__value[a][b] * x[b]\n    }\n    x[a] = (c[a] - t) / U.__value[a][a]\n  }\n  return x\n}\n\n/**\n * @memberOf Matrix\n * @member inverse\n * @instance\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1, 1], [2, 4]]).inverse()\n * // [ [ 2, -0.5 ], [ -1, 0.5 ] ]\n *\n */\nMatrix.prototype.inverse = function () {\n  const A = this.clone()\n  const I = A.identity()\n  const Inv = A.concat(I).rref()\n\n  const result = Inv.__value.reduce((result, x, idx) => {\n    const half = x.length / 2\n    result.push(x.slice(half, x.length))\n    return result\n  }, [])\n  return Matrix.of(result)\n}\n\n/**\n * @memberOf Matrix\n * @member rank\n * @instance\n * @returns {Number}\n */\nMatrix.prototype.rank = function () {\n  const rref = this.rref()\n  let result = 0\n  for (let i = 0; i < rref.getCols(); ++i) {\n    result += rref.__value[i][i]\n  }\n  return result\n}\n\n/**\n * @memberOf Matrix\n * @member dimension\n * @instance\n * @see rank\n * @returns {Number}\n */\nMatrix.prototype.dimension = function () {\n  return this.rank()\n}\n\n/**\n * @memberOf Matrix\n * @member diag\n * @instance\n * @desc Returns an array containing the values on the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diag()\n * // [1, 1, 1]\n *\n * const diag0 = Matrix.zeros(5, 5).diag()\n * // [0, 0, 0, 0, 0]\n *\n */\nMatrix.prototype.diag = function () {\n  return fold((acc, x, idx) => {\n    return acc.concat(x[idx])\n  })([])(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function diag\n * @desc Returns an array containing the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.diag([[2, 1], [1, 5]])\n * // [2, 5]\n *\n */\nMatrix.diag = function (M) {\n  return Matrix.of(M).diag()\n}\n\n/**\n * @memberOf Matrix\n * @member diagproduct\n * @instance\n * @desc Returns the product of the values on the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diagproduct()\n * // 1\n *\n * const diag0 = Matrix.zeros(5, 5).diagproduct()\n * // 0\n *\n */\nMatrix.prototype.diagproduct = function () {\n  return fold((acc, x, idx) => {\n    acc *= x[idx]\n    return acc\n  })(1)(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function diagproduct\n * @desc Returns the product of the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.diagproduct([[2, 1], [1, 5]])\n * // 10\n *\n */\nMatrix.diagproduct = function (M) {\n  return Matrix.of(M).diagproduct()\n}\n\n/**\n * @memberOf Matrix\n * @member sum\n * @instance\n * @desc Returns the sum of the values in the Matrix\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).sum()\n * // 9\n *\n * const diag0 = Matrix.zeros(5, 5).sum()\n * // 0\n *\n */\nMatrix.prototype.sum = function () {\n  return fold((acc, x) => {\n    acc += fold((prev, next) => prev + next)(0)(x)\n    return acc\n  })(0)(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function sum\n * @desc Returns the sum of the values in the Matrix\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.sum([[2, 1], [1, 5]])\n * // 9\n *\n */\nMatrix.sum = function (M) {\n  return Matrix.of(M).sum()\n}\n\n/**\n * @memberOf Matrix\n * @member kronecker\n * @instance\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param M {Matrix} The right side Matrix of the product (this ⊗ M)\n * @returns {Matrix}\n */\nMatrix.prototype.kronecker = function (M) {\n  const m = this.getRows()\n  const n = this.getCols()\n  const p = M.getRows()\n  const q = M.getCols()\n\n  const left = this.__value\n  const right = M.__value\n\n  const frame = generate(m * p, n * q)\n\n  for (var i = 0; i < m; i++) {\n    for (var j = 0; j < n; j++) {\n      for (var k = 0; k < p; k++) {\n        for (var l = 0; l < q; l++) {\n          frame[p * i + k][q * j + l] = left[i][j] * right[k][l]\n        }\n      }\n    }\n  }\n  return Matrix.of(frame)\n}\n\n/**\n * @memberOf Matrix\n * @function kronecker\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param A {Matrix} The left side Matrix of the product (A ⊗ B)\n * @param B {Matrix} The right side Matrix of the product (A ⊗ B)\n * @returns {Matrix}\n */\nMatrix.kronecker = function (A, B) {\n  return Matrix.of(A).kronecker(B)\n}\n\nexport default Matrix\n","import curry from 'fun.js/src/curry'\nimport concat from 'fun.js/src/concat'\n\n/**\n * @function concat\n * @param M {Matrix}\n * @param m {Array}\n * @param idx {number}\n * @returns {Array}\n */\nexport default curry(function (M, m, idx) {\n  return concat(m, M.__value[idx])\n})\n","import curry from 'fun.js/src/curry'\n\nexport default curry(m => [])\n","import curry from 'fun.js/src/curry'\nimport fold from 'fun.js/src/fold'\nimport map from 'fun.js/src/map'\nimport round from './round'\n\n/**\n * @function dot\n * @param B {Matrix}\n * @param a {Array}\n * @returns {Array}\n */\nexport default curry((decimals, B, a) => map((item, i) => {\n  return fold((acc, x, j) => {\n    acc += round(x * B.__value[j][i], decimals)\n    return acc\n  }, 0)(a)\n})(B.__value[0]))\n","/**\n * @function round\n * @param value {number}\n * @param decimals {number}\n * @returns {Number}\n */\nexport default function round (value, decimals) {\n  return Number(Math.round(value + 'e' + decimals) + 'e-' + decimals)\n}\n","import map from 'fun.js/src/map'\n\n/**\n * @function identity\n * @desc Creates an identiy matrix from an empty array\n * @param m {Array}\n * @param idx {number}\n * @return {Matrix}\n */\nexport default (m, idx) => map((rows, jdx) => (idx === jdx) * 1)(m)\n","import map from 'fun.js/src/map'\nimport curry from 'fun.js/src/curry'\n\n/**\n * @function transpose\n * @desc Transposes a array of arrays using the Matrix.map function\n * @param m {Array}\n * @param idx {number}\n * @return {Matrix}\n */\nexport default curry((prev, next) => map((item, i) => (prev[i] || []).concat(next[i]))(next))\n","/**\n * @function generate\n * @desc Generator function for a matrix array, values are set to undefined\n * @param rows {number}\n * @param cols {number}\n * @returns {any[][]}\n */\nexport default (rows, cols) => Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n","/**\n * @function exists\n */\nexport default function exists (x) {\n  return !(x == null)\n};\n","/**\n * @private\n */\nimport is from '../is'\n\nexport default is('Number')\n","/**\n * Checks if both predicates are true\n *\n * @function and\n * @description Checks if both predicates are true\n * @since v1.0.2\n * @sig (x, y) -> boolean\n * @param {*} x - A predicate\n * @param {*} y - A predicate\n * @return {boolean}\n **/\nimport curry from './curry'\n\nexport default curry(function and (x, y) {\n  return x && y\n})\n","/**\n * @function isNaN\n * @description Checks if number is NAN\n\n */\nimport isNumber from './is'\nimport and from '../and'\n\nexport default function isNan (x) {\n  return and(isNumber(x), isNaN(x))\n};\n","/**\n\n * @function identical\n * @description checks for identintical items\n */\nimport curry from './curry'\nimport isNan from './number/isNan'\n\nexport default curry(function identical (x, y) {\n  if (x === 0 && y === 0) {\n    return 1 / x === 1 / y\n  }\n  if (x === y) {\n    return true\n  }\n  return !!(isNan(x) && isNan(y))\n})\n","/**\n * @function not\n */\nimport curry from './curry'\n\nexport default curry(function not (x) {\n  return !x\n})\n","/**\n * @function or\n * @description Returns true if one or the other is true\n */\nimport curry from './curry'\n\nexport default curry(function or (x, y) {\n  return x || y\n})\n","/**\n\n */\nimport is from '../is'\n\nexport default is('Object')\n","/**\n * Checks if the provided object is an array, autocurried function\n *\n * @private\n * @function isArray\n * @description Checks if the provided object is an array, autocurried function\n * @param {*} Object to verifiy\n * @return {boolean}\n * @since 1.0.2\n * @example\n *\n * const result = isArray([1,1,1])\n * // result = true\n */\n\nimport is from '../is'\n\nexport default is('Array')\n","/**\n * Curried function that verifies of the provided argument is a boolean\n *\n * @private\n * @function is\n * @description Curried function that verifies of the provided argument is a boolean\n * @since v1.0.2\n * @param {*} Item to verify\n * @return {boolean}\n **/\nimport is from '../is'\n\nexport default is('Boolean')\n","/**\n\n */\nimport is from '../is'\n\nexport default is('String')\n","/**\n * Created by dierickx.len on 01/04/2017.\n */\n/**\n * Created by dierickx.len on 01/04/2017.\n */\nimport is from '../is'\n\nexport default is('Date')\n","/**\n * @private\n * @function equalsArray\n * @description Autocurried function for deep comparison of arrays\n * @param {a} x - Object to compare of type a\n * @param {a} y - Object x to compare with object x\n * @return {boolean}\n */\nimport curry from '../curry'\nimport not from '../not'\nimport equals from '../equals'\n\nexport default curry(function equalsArray (x, y) {\n  if (x.length !== y.length) {\n    return false\n  }\n  for (let i = 0; i < x.length; i++) {\n    if (not(equals(x[i], y[i]))) return false\n  }\n  return true\n})\n","/**\n\n * equals\n * checks for equality\n */\nimport curry from '../curry'\nimport exists from '../exists'\nimport not from '../not'\nimport equals from '../equals'\n\nexport default curry((x, y) => {\n  for (let keyX in x) {\n    // noinspection JSUnfilteredForInLoop\n    if (not(equals(x[keyX], y[keyX]))) return false\n  }\n\n  for (let keyY in y) {\n    if (not(exists(x[keyY])) && exists(y[keyY])) return false\n  }\n\n  return true\n})\n","/**\n\n * @function equals\n * @description Autocurried function that checks for equality of 2 items\n * @param {*} x - Left side of the equality check\n * @param {*} y - Right side of the equality check\n * @return {boolean}\n * @example\n *\n * const nan = Number.NaN\n * equal(nan, nan) // returns true\n *\n * const arr1 = [0, 1, 2, 3]\n * const arr2 = [null, 1, 2, 3]\n * equals(arr1, arr2) // returns false\n *\n * equals(new Object({'a': 0, 'b': 1}), {'a': 0, 'b': 1}) // true\n *\n */\nimport curry from './curry'\nimport exists from './exists'\nimport identical from './identical'\nimport type from './type'\nimport not from './not'\nimport or from './or'\nimport isObject from './object/is'\nimport isArray from './array/is'\nimport isBoolean from './boolean/is'\nimport isNumber from './number/is'\nimport isString from './string/is'\nimport isDate from './date/is'\nimport equalsArray from './array/equals'\nimport equalsObject from './object/equals'\n\nexport default curry(function equals (x, y) {\n  if (identical(x, y)) return true\n\n  if (type(x) !== type(y)) return false\n\n  if (or(not(exists(x)), not(exists(y)))) return false\n\n  if (x.constructor !== y.constructor) return false\n\n  if (isString(x) || isBoolean(x) || isNumber(x) || isDate(x)) {\n    return identical(x.valueOf(), y.valueOf())\n  }\n  if (isArray(x)) {\n    return equalsArray(x, y)\n  } else if (isObject(x)) {\n    return equalsObject(x, y)\n  }\n  return false\n})\n","/**\n * @private\n * @function arrayConcat\n * @param a1\n * @param a2\n * @returns {T[]}\n */\nimport curry from '../curry'\n\nexport default curry(function concat (a, b) {\n  return Array.prototype.concat(a, b)\n})\n","/**\n * @private\n * @function stringConcat\n */\n\nexport default function concat (a, b) { // use function(), arrow function doesn't bind arguments\n  return String(a) + String(b)\n}\n","/**\n * Concatenates 2 items together\n *\n * @function concat\n * @description Concatenates 2 items together\n * @since v1.0.4\n * @param {a} a - Left side of the concatenation\n * @param {a} b - right side of the concatenation\n * @return {a} Concatenated item\n **/\n\nimport curry from './curry'\nimport arrayConcat from './array/concat'\nimport stringConcat from './string/concat'\nimport type from './type'\n\nexport default curry(function concat (a, b) {\n  const typeMap = {\n    'String': stringConcat,\n    'Array': arrayConcat\n  }\n  return typeMap[type(a)](a, b)\n})\n"],"sourceRoot":""} \ No newline at end of file +!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define("@astuanax/funmatrix",[],e):"object"==typeof exports?exports["@astuanax/funmatrix"]=e():t["@astuanax/funmatrix"]=e()}("undefined"!=typeof self?self:this,function(){return function(t){var e={};function n(r){if(e[r])return e[r].exports;var u=e[r]={i:r,l:!1,exports:{}};return t[r].call(u.exports,u,u.exports,n),u.l=!0,u.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var u in t)n.d(r,u,function(e){return t[e]}.bind(null,u));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=6)}([function(t,e,n){"use strict";function r(t){const e=t.length;return 0===e?t:n([]);function n(r){return function(){return function(r,u){const o=r.concat(u);return o.length{n.set(r,t(e,r,u))}),n}),c=Object(r.default)(function(t,e){let n=-1;const r=e.length;let u="";for(;++n1&&void 0!==arguments[1]?arguments[1]:a.default;return v.of(this).map(e(t))},v.concat=(0,r.default)(function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:a.default;return v.of(t).map(n(e))}),v.prototype.empty=function(){return v.of(this).map(i.default)},v.empty=(0,r.default)(function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0,e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=(0,d.default)(t,e);return v.of(n).map(i.default)}),v.prototype.identity=function(){return v.of(l.default).ap(this)},v.identity=function(t,e){var n=(0,d.default)(t,e);return v.of(l.default).ap(n)},v.prototype.combine=function(t){return v.of(this).concat(v.of(t),a.default)},v.combine=function(t,e){return v.of(t).concat(v.of(e),a.default)},v.prototype.dot=function(t){return v.of(this).concat(v.of(t),(0,c.default)(this.precision))},v.dot=function(t,e){return v.of(t).dot(v.of(e))},v.prototype.fill=function(t){return v.of(this).map((0,u.default)(function(e){return t(e)}))},v.prototype.zeros=function(){return v.of(this).fill(function(t){return 0})},v.zeros=function(t,e){var n=(0,d.default)(t,e);return v.of(n).fill(function(t){return 0})},v.prototype.ones=function(){return v.of(this).fill(function(t){return 1})},v.ones=function(t,e){var n=(0,d.default)(t,e);return v.of(n).fill(function(t){return 1})},v.prototype.random=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:function(t){return 2*Math.random()-1};return v.of(this).fill(t)},v.random=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:function(t){return 2*Math.random()-1},e=arguments[1],n=arguments[2],r=(0,d.default)(e,n);return v.of(r).fill(t)},v.prototype.toArray=function(){return this.__value.map(function(t){return t.map(function(t){return t})})},v.prototype.clone=function(){return v.fromArray(this.__value)},v.fromArray=function(t){return v.of((0,u.default)(function(t){return(0,u.default)(function(t){return t})(t)})(t))},v.prototype.transpose=function(){return v.of((0,o.default)(s.default,[],this.__value))},v.transpose=function(t){return v.of(t).transpose()},v.prototype.add=function(t){if(t instanceof v){if(this.getCols()!==t.getCols()||this.getRows()!==t.getRows())throw new Error("Matrices do not match, cannot add");return this.map(function(e,n){return(0,u.default)(function(e,r){return e+t.__value[n][r]})(e)})}return this.map((0,u.default)(function(e){return e+t}))},v.prototype.subtract=function(t){if(t instanceof v){if(this.getCols()!==t.getCols()||this.getRows()!==t.getRows())throw new Error("Matrices do not match, cannot subtract");return this.map(function(e,n){return(0,u.default)(function(e,r){return e-t.__value[n][r]})(e)})}return this.map((0,u.default)(function(e){return e-t}))},v.prototype.multiply=function(t){if(t instanceof v){if(this.getCols()!==t.getCols()||this.getRows()!==t.getRows())throw console.log("Use static method 'dot' to do matrix multiplication"),new Error("Matrices do not match, cannot create hadamard product");return this.map(function(e,n){return(0,u.default)(function(e,r){return e*t.__value[n][r]})(e)})}return this.map((0,u.default)(function(e){return e*t}))},v.prototype.additiveinverse=function(){return v.of(this).multiply(-1)},v.prototype.hadamard=function(t){return v.of(this).multiply(t)},v.prototype.lu=function(){for(var t=this.getRows(),e=this.clone(),n=this.zeros(),r=this.zeros(),u=0;u-1;--l){for(var s=0,d=l+1;d{for(let n in t)if(s(j(t[n],e[n])))return!1;for(let n in e)if(s(u(t[n]))&&u(e[n]))return!1;return!0}),j=e.default=Object(r.default)(function(t,e){return!!c(t,e)||Object(l.a)(t)===Object(l.a)(e)&&(!d(s(u(t)),s(u(e)))&&(t.constructor===e.constructor&&(h(t)||_(t)||f(t)||y(t)?c(t.valueOf(),e.valueOf()):v(t)?b(t,e):!!p(t)&&g(t,e))))})},function(t,e,n){"use strict";n.r(e);var r=n(0),u=Object(r.default)(function(t,e){return Array.prototype.concat(t,e)});function o(t,e){return String(t)+String(e)}var f=n(2);e.default=Object(r.default)(function(t,e){return{String:o,Array:u}[Object(f.a)(t)](t,e)})}])}); +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://@astuanax/funmatrix/webpack/universalModuleDefinition","webpack://@astuanax/funmatrix/webpack/bootstrap","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/curry.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/type.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/_private/curry1.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/empty.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/map/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/iterator/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/iterator/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/map.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/keys.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/fold.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/fold.js","webpack://@astuanax/funmatrix/./src/matrix.js","webpack://@astuanax/funmatrix/./src/util/concat.js","webpack://@astuanax/funmatrix/./src/util/empty.js","webpack://@astuanax/funmatrix/./src/util/dot.js","webpack://@astuanax/funmatrix/./src/util/round.js","webpack://@astuanax/funmatrix/./src/util/identity.js","webpack://@astuanax/funmatrix/./src/util/transpose.js","webpack://@astuanax/funmatrix/./src/util/generate.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/exists.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/number/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/and.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/number/isNan.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/identical.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/not.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/or.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/boolean/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/date/is.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/object/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/equals.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/array/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/string/concat.js","webpack://@astuanax/funmatrix/./node_modules/fun.js/src/concat.js"],"names":["root","factory","exports","module","define","amd","self","this","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","curry","fun","argslen","length","createRecurser","acc","args","_acc","concat","apply","recurse","Array","slice","arguments","__webpack_exports__","_curry__WEBPACK_IMPORTED_MODULE_0__","_type__WEBPACK_IMPORTED_MODULE_1__","Ctor","val","fn","x","toString","a","array_map","cb","empty","constructor","object_map","k","keys","map_map","forEach","v","map","set","string_map","charAt","iterator_map","callback","iterator","nextValue","next","done","push","isFunction","is","type","array_fold","init","object_fold","_curry","_interopRequireDefault","_map","_fold","_equals","_concat","_empty","_dot","_identity","_transpose","_generate","Matrix","__value","of","precision","setPrecision","isSymmetric","b","transpose","default","isSquare","getCols","getRows","isOrthogonal","AxAt","dot","I","identity","equals","M","getShape","f","fold","ap","undefined","A","B","rows","cols","combine","fill","zeros","ones","random","e","Math","toArray","row","col","clone","fromArray","arr","add","Error","idx","jdx","subtract","multiply","console","log","additiveinverse","hadamard","lu","L","U","abs","j","rref","lead","resultMatrix","tmp","solve","LU","inverse","result","reduce","half","rank","dimension","diag","diagproduct","sum","prev","kronecker","q","left","right","frame","_round","decimals","item","Number","round","exists","number_is","and","y","isNan","isNaN","src_identical","not","or","object_is","array_is","boolean_is","string_is","date_is","array_equals","src_equals","object_equals","keyX","keyY","valueOf","array_concat","concat_concat","String"],"mappings":"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","file":"@astuanax/funmatrix.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"@astuanax/funmatrix\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"@astuanax/funmatrix\"] = factory();\n\telse\n\t\troot[\"@astuanax/funmatrix\"] = factory();\n})(typeof self !== 'undefined' ? self : this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 6);\n","/* eslint-disable no-use-before-define */\n/**\n * @function curry\n * @description Autocurries the provided function\n */\nexport default function curry (fun) {\n  const argslen = fun.length\n\n  if (argslen === 0) {\n    return fun\n  }\n  return createRecurser([])\n\n  function recurse (acc, args) {\n    const _acc = acc.concat(args)\n    return _acc.length < argslen\n      ? createRecurser(_acc)\n      : fun.apply(this, _acc)\n  }\n\n  function createRecurser (acc) {\n    return function () {\n      return recurse(acc, Array.prototype.slice.call(arguments))\n    }\n  }\n}\n","/**\n * @function is\n * @description Verifies the type of the provided argument\n *\n */\n\nimport curry from './curry'\nimport type from './type'\n\nexport default curry(function is (Ctor, val) {\n  return type(val) === Ctor\n})\n","/**\n * @function type\n */\nimport curry1 from './_private/curry1'\n\nexport default curry1(function type (x) {\n  return Object.prototype.toString.call(x).slice(8, -1)\n})\n","/**\n * Returns a curried function with arity 1\n * @function curry1\n * @private\n * @since v1.0.2\n **/\n\nexport default function curry1 (fn) {\n  return function curried (a) {\n    return arguments.length === 0\n      ? this\n      : fn(a)\n  }\n}\n","/**\n * @function map\n * @description Maps over an array and applies a function\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n * @since v1.0.2\n * @example\n *\n *  const result = map(identity, [0,2,3])\n *  // result = [0,2,3]\n *  const add2 = add(2)\n *  const result = map(add2, [0,2,3])\n *  // result = [2,4,5]\n **/\nimport curry from '../curry'\n\nexport default curry(function map (cb, a) {\n  let i = -1\n  const l = a.length\n  const r = new Array(l)\n  while (++i < l) {\n    r[i] = cb(a[i], i, a)\n  }\n  return r\n})\n","/**\n\n * @function empty\n * @description Returns the empty equivalent of the first argument\n */\n\nexport default function empty (x) {\n  return new x.constructor()\n};\n","/**\n * Maps over an object and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Object} a\n * @return {Object}\n **/\nimport curry from '../curry'\nimport empty from '../empty'\nimport keys from './keys'\n\nexport default curry(function map (cb, a) {\n  const k = keys(a)\n  let i = -1\n  const l = k.length\n  const r = empty(a)\n  while (++i < l) {\n    r[k[i]] = cb(a[k[i]], k[i], a)\n  }\n  return r\n})\n","/**\n * Maps over a Map and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Map} a\n * @return {Map}\n **/\nimport curry from '../curry'\nimport empty from '../empty'\n\nexport default curry(function map (cb, a) {\n  const r = empty(a)\n  a.forEach((v, k, map) => {\n    r.set(k, cb(v, k, map))\n  })\n  return r\n})\n","/**\n * Maps over a string and applies a function\n *\n * @function\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> [a] -> [a]\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n **/\nimport curry from '../curry'\n\nexport default curry(function map (cb, a) {\n  let i = -1\n  const l = a.length\n  let r = ''\n  while (++i < l) {\n    r += cb(a.charAt(i), i, a)\n  }\n  return r\n})\n","/**\n * Maps over an Iterator and applies a function\n *\n * @function\n * @since v1.0.3\n * @sig (currentValue, idx, [a]) -> {b} -> [b]\n * @param {Function} cb\n * @param {Iterator} a\n * @return {Iterator}\n **/\nimport curry from '../curry'\n\nexport default curry(function map (callback, iterator) {\n  let r = []\n  for (let nextValue = iterator.next(); nextValue.done !== true; nextValue = iterator.next()) {\n    r.push(callback(iterator.value()))\n  }\n  return r\n})\n","/**\n * Created by dierickx.len on 01/04/2017.\n */\nimport is from '../is'\nconst isFunction = is('Function')\n\nexport default function isIter (iter) {\n  return isFunction(iter[Symbol.iterator])\n}\n","/**\n * Maps over an iterable and applies a function\n *\n * @function map\n * @description Autocurried function which maps over an iterable.\n * @since v1.0.2\n * @sig (currentValue, idx, [a]) -> b -> b\n * @param {Function} cb\n * @param {Iterable} a\n * @return {Iterable}\n **/\nimport curry from './curry'\nimport arrayMap from './array/map'\nimport objectMap from './object/map'\nimport mapMap from './map/map'\nimport stringMap from './string/map'\nimport iteratorMap from './iterator/map'\nimport type from './type'\nimport isIterator from './iterator/is'\n\nexport default curry(function map (cb, a) {\n  switch (type(a)) {\n    case 'Function':\n      return curry(function () {\n        return cb.call(this, a.apply(this, arguments))\n      })\n    case 'Object':\n      return objectMap(cb, a)\n    case 'String':\n      return stringMap(cb, a)\n    case 'Map':\n      return mapMap(cb, a)\n    case 'Array':\n      return arrayMap(cb, a)\n    default:\n      return isIterator(a)\n        ? iteratorMap(cb, a)\n        : arrayMap(cb, a)\n  }\n})\n","/**\n * Returns the own keys of an object as an Array\n *\n * @function\n * @since v1.0.2\n * @sig a -> [b]\n * @param {Object}\n * @return {Array}\n **/\nimport curry from '../curry'\n\nexport default curry(function keys (a) {\n  return Object.keys(Object(a))\n})\n","/**\n * @private\n * @function fold\n * @description Returns a single item by mapping over the provided array and calling an iterator function\n * @param {cbFunction} cb - Callback function to modify the item\n * @param {*} init - Initial value\n * @param {Array} a - Array with items to modify by the cb function\n * @return {Array}\n * @alias reduce\n * @since 1.0.2\n * @example\n *\n * const result = fold(add, 0, [1,1,1])\n * // result = 3\n */\n\n/**\n * @callback cbFunction\n * @param {*} r - Accumulator which accumulates the callback's return values\n * @param {*} item - the current element being processed\n * @param {number} index - the indey of the item being processed\n * @param {Array} a - The initial array\n * @return {*}\n */\nimport curry from '../curry'\n\nexport default curry(function fold (cb, init, a) {\n  let i = -1\n  const l = a.length\n  let r = init\n  while (++i < l) {\n    r = cb(r, a[i], i, a)\n  }\n  return r\n})\n","/**\n * @function fold\n * @private\n *\n */\nimport curry from '../curry'\nimport keys from './keys'\n\nexport default curry(function fold (cb, init, o) {\n  const k = keys(o)\n  let i = -1\n  const l = k.length\n  let r = Object(init)\n  while (++i < l) {\n    r = cb(r, o[k[i]], k[i], o)\n  }\n  return r\n})\n","/**\n * Returns a single item by iterating over an array like object and call a function on each item\n *\n * @function fold\n * @description Returns a single item by iterating over an array like object and call a function on each item\n * @since v1.0.2\n * @sig ((a, b, c, a) → a) → a → [b] → a\n * @param {Function} cb receives 4 values: the accumulator, the item, the index, and the initial value.\n * @param {*} a is the initial value\n * @param {*} [b] the array like item to iterate over\n * @return {*} a is the accumulated value\n **/\n\nimport curry from './curry'\nimport arrayFold from './array/fold'\nimport objectFold from './object/fold'\nimport type from './type'\n\nexport default curry(function fold (cb, init, a) {\n  const typeMap = {\n    'Object': objectFold,\n    'Array': arrayFold\n  }\n  // if (a.next) {\n  //   return iterableFold(cb, init, a)\n  // }\n  // if (type(Symbol) !== 'undefined' && a[Symbol.iterator]) {\n  //   return iterableFold(cb, init, a[Symbol.iterator]())\n  // }\n  return typeMap[type(a)](cb, init, a)\n})\n\n// function iterableFold (cb, acc, gen) {\n//   let step = gen.next()\n//   while (!step.done) {\n//     acc = cb(acc, step.value)\n//     step = gen.next()\n//   }\n//   return acc\n// }\n","import curry from 'fun.js/src/curry'\nimport map from 'fun.js/src/map'\nimport fold from 'fun.js/src/fold'\nimport equals from 'fun.js/src/equals'\nimport concat from './util/concat'\nimport empty from './util/empty'\nimport dot from './util/dot'\nimport identity from './util/identity'\nimport transpose from './util/transpose'\nimport generate from './util/generate'\n// import gpumap from 'util/gpumap'\n// import gpufold from 'util/gpufold'\n// import gpuproduct from 'util/gpuproduct'\n\n/**\n * @class Matrix\n * @classdesc Matrix applicative providing standard matrix operations\n * @summary The Matrix class should not be instantiated with the new keyword. Instead use the Matrix.of syntax to create a new Matrix. Unfortunatly jsdocs does not allow for the constructor to be hidden.\n * @hidecontructor\n * @see of\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n *\n */\nlet Matrix = function (val) {\n  this.__value = val\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.of\n * @desc Creates a Matrix object and flattens the Matrix\n * @param val {array|function} An array of arrays\n * @returns {Matrix}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n *\n */\nMatrix.of = function (val) {\n  if (val instanceof Matrix) return val\n  if (this instanceof Matrix) {\n    this.__value = val\n    return this\n  }\n  return new Matrix(val)\n}\n\n/**\n * @memberOf Matrix\n * @property {string} type\n * @type {string}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.type === 'Matrix'\n */\nMatrix.prototype.type = 'Matrix'\n\n/**\n * @memberOf Matrix\n * @property {number} precision\n * @type {number}\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.precision === 4\n */\nMatrix.prototype.precision = 4\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#setPrecision\n * @param precision {number} Set the number of decimals for rounding\n * @example\n *\n * const m =  Matrix.of([[1,2],[2,3],[4,5]])\n * m.setPrecision(10)\n * m.precision === 10\n */\nMatrix.prototype.setPrecision = function (precision) {\n  this.precision = precision\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member isSymmetric\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSymmetric()\n *\n */\nMatrix.prototype.isSymmetric = function () {\n  const a = this.__value\n  const b = Matrix.transpose(this).__value\n  return equals(a, b)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#isSquare\n * @desc Boolean indicating whether this contains a square Matrix\n * @returns {boolean}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * true === A.isSquare()\n *\n */\nMatrix.prototype.isSquare = function () {\n  return equals(this.getCols(), this.getRows())\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#isOrthogonal\n * @param M {Matrix|array}\n * @returns {boolean}\n * @example\n *\n * const result = [[-0.3092, -0.9510], [-0.9510, 0.3092]]\n * const A = Matrix.fromArray(result)\n * true  === A.isOrthogonal()\n */\nMatrix.prototype.isOrthogonal = function () {\n  const AxAt = this.dot(this.transpose())\n  const I = this.identity()\n  return equals(AxAt, I)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#getCols\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getCols()  === 2\n *\n */\nMatrix.prototype.getCols = function () {\n  return this.__value[0].length\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#equals\n * @param M {Matrix|array}\n * @returns {Boolean}\n * @example\n *\n * var a = [[1, 1], [1, 1]]\n * var A = Matrix.of(a)\n * var B = Matrix.of(a)\n * true  === A.equals(B)\n */\nMatrix.prototype.equals = function (M) {\n  return equals(this.__value, M.__value || M)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#getRows\n * @returns {Number}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getRows()  // 2\n */\nMatrix.prototype.getRows = function () {\n  return this.__value.length\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#getShape\n * @returns {Array}\n * @example\n *\n * const A = Matrix.of([[1, 1], [1, 1]])\n * A.getShape()  // [2, 2]\n */\nMatrix.prototype.getShape = function () {\n  return [this.getRows(), this.getCols()]\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#map\n * @description Maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.of([[1, 1], [1, 1]])\n * m.map(x => x.map(y => y+ 1))\n * // [[2, 2], [2, 2]]\n *\n */\nMatrix.prototype.map = function (f) {\n  return Matrix.of(map(f)(this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.map\n * @description Static function that maps over the rows of the matrix using a map function\n * @param f {function} An iterator function\n * @param M {Matrix|array} Matrix or array to map\n * @returns {Matrix}\n * @example\n *\n * const m = Matrix.map(x= > x.map(y => y+ 1), [[1, 1], [1, 1]])\n * // [[2, 2], [2, 2]]\n *\n */\nMatrix.map = curry(function (f, M) {\n  return Matrix.of(M).map(f)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#fold\n * @description Reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @returns {Matrix}\n * @example\n *\n * // Flatten Matrix\n * Matrix.of([[1, 1], [1, 1]]).fold((prev, next) => prev.concat(next))\n * // [1, 1, 1, 1]\n */\nMatrix.prototype.fold = function (f) {\n  return Matrix.of(fold(f, [])(this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.fold\n * @description Static function to reduce the matrix rows using a reduce function\n * @param f {function} A reduce/fold function\n * @param M {Matrix} The Matrix to reduce\n * @returns {Matrix}\n * @example\n\n * // Sum of all matrix values\n * const reducer = (prev, next) => Number(prev) + next.reduce((acc, x) => acc + x, 0)\n * const A = Matrix.of([[1, 1], [1, 1]]\n * Matrix.fold(reducer, A)\n * // 4\n */\nMatrix.fold = curry(function (f, M) {\n  return Matrix.of(M).fold(f)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#ap\n * @description Applies a Matrix to a function\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * const A = Matrix.of([[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * Matrix.of(f).ap(M)\n * // [[6], [15], [24]\n */\nMatrix.prototype.ap = function (M) {\n  return Matrix.of(M).map(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.ap\n * @description Applies a Matrix to a function\n * @param f {function}\n * @param M {Matrix|array}\n * @returns {Matrix}\n * @example\n *\n * const f = x => x.reduce((prev, next) => prev + next)\n * Matrix.ap(f, [[1, 2, 3], [4, 5, 6], [7, 8, 9]])\n * // [[6], [15], [24]\n */\nMatrix.ap = curry(function (f, M) {\n  return Matrix.of(f).ap(M)\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param M {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = A.concat(B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */\nMatrix.prototype.concat = function (M, f = concat) {\n  return Matrix.of(this).map(f(M))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.concat\n * @description Concatenates 2 Matrices using a function as operator\n * @param A {Matrix}\n * @param B {Matrix}\n * @returns {Matrix}\n * @example\n *\n * const a = [[0, 1, 1], [2, 3, 4]]\n * const b = [[2, 2, 2], [3, 3, 3]]\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n * const M = Matrix.concat(A, B)\n * // [[0, 1, 1, 2, 2, 2], [2, 3, 4, 3, 3, 3]]\n *\n */\nMatrix.concat = curry(function (A, B, f = concat) {\n  return Matrix.of(A).map(f(B))\n})\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#empty\n * @description Return an empty Matrix from an existing Matrix\n * @returns {Matrix}\n */\nMatrix.prototype.empty = function () {\n  return Matrix.of(this).map(empty)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.empty\n * @description Return an empty Matrix from an existing Matrix\n * @param rows {number}\n * @param cols {number}\n * @returns {Matrix}\n */\nMatrix.empty = curry(function (rows = 0, cols = 0) {\n  const m = generate(rows, cols) // Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n  return Matrix.of(m).map(empty)\n})\n\n// #### #### #### //\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const A = Matrix.of(a)\n * const Aidentity = A.identity()\n * // [[1, 0, 0], [0, 1, 0]]\n *\n */\nMatrix.prototype.identity = function () {\n  return Matrix.of(identity).ap(this)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.identity\n * @desc Returns an identity matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.identity(3, 2)\n * // [[1, 0, 0], [0, 1, 0]]\n *\n */\nMatrix.identity = function (rows, cols) {\n  const m = generate(rows, cols) // Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n  return Matrix.of(identity).ap(m)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */\nMatrix.prototype.combine = function (M) {\n  return Matrix.of(this).concat(Matrix.of(M), concat)\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.combine\n * @see Matrix.concat\n * @param M\n * @returns {Matrix}\n */\nMatrix.combine = function (A, B) {\n  return Matrix.of(A).concat(Matrix.of(B), concat)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @param f\n * @returns {Matrix}\n * @example\n *\n * // Create matrix\n * const m = Matrix.of([[1, 2], [3, 4]])\n *\n * // Generate identity matrix\n * const I  = m.identity() // [[1, 0], [0, 1]]\n *\n * if(m.dot(I).equals(m)) {\n *    console.log('Dot product with identity matrix returns the same matrix')\n * }\n *\n */\nMatrix.prototype.dot = function (M) {\n  return Matrix.of(this).concat(Matrix.of(M), dot(this.precision))\n}\n\n/**\n * @memberOf Matrix\n * @static\n * @function Matrix.dot\n * @description Returns the dot product between 2 matrices\n * @param M\n * @returns {Matrix}\n * @example\n * const a = [[1, 2, 3], [4, 5, 6]]\n * const b = [[7, 8], [9, 10], [11, 12]]\n *\n * const A = Matrix.of(a)\n * const B = Matrix.of(b)\n *\n * Matrix.dot(A, B) // [[58, 64], [139, 154]]\n *\n */\nMatrix.dot = function (A, B) {\n  return Matrix.of(A).dot(Matrix.of(B))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#fill\n * @desc Fill up an empty matrix with the provided map function\n * @param f\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).fill(x => 42)\n * // [[42,42,42], [42,42,42], [42,42,42]]\n *\n */\nMatrix.prototype.fill = function (f) {\n  return Matrix.of(this).map(map(x => f(x)))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#zeros\n * @desc Fill up an empty matrix with zeros\n * @returns {Matrix}\n *\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).zeros()\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */\nMatrix.prototype.zeros = function () {\n  return Matrix.of(this).fill(x => 0)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.zeros\n * @desc Fill up an empty matrix with zeros\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.zeros(3, 3)\n * // [[0,0,0], [0,0,0], [0,0,0]]\n *\n */\nMatrix.zeros = function (rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(x => 0)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#ones\n * @desc Fill up an empty matrix with ones\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1,2,3], [3,2,1], [4,5,6]]).ones()\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */\nMatrix.prototype.ones = function () {\n  return Matrix.of(this).fill(x => 1)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.ones\n * @desc Fill up an empty matrix with ones\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.ones(1, 1)\n * // [[1,1,1], [1,1,1], [1,1,1]]\n *\n */\nMatrix.ones = function (rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(x => 1)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#random\n * @desc Fill up an empty matrix with random values\n * @param {function} [f = e => Math.random() * 2 - 1]\n * @returns {Matrix}\n */\nMatrix.prototype.random = function (f = e => Math.random() * 2 - 1) {\n  return Matrix.of(this).fill(f)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.random\n * @desc Fill up an empty matrix with random numbers\n * @param f {function} Function which returns random values. Default random values are between -1 and 1\n * @param rows {number} Defines the rows of the matrix\n * @param cols {number} Defines the columns of the matrix\n * @returns {Matrix}\n */\nMatrix.random = function (f = e => (Math.random() * 2 - 1), rows, cols) {\n  const m = generate(rows, cols)\n  return Matrix.of(m).fill(f)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#toArray\n * @desc Returns the array from the matrix\n * @returns {Array}\n */\nMatrix.prototype.toArray = function () {\n  return this.__value.map(row => row.map(col => col))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#clone\n * @desc Returns a clone of the matrix\n * @returns {Matrix}\n */\nMatrix.prototype.clone = function () {\n  return Matrix.fromArray(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#fromArray\n * @desc Returns a Matrix from an array\n * @returns {Array}\n */\nMatrix.fromArray = function (arr) {\n  return Matrix.of(map(row => map(col => col)(row))(arr))\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#transpose\n * @desc Returns a transposed Matrix\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([-1, 2], [3, 4], [-8, 2])\n * const b = A.transpose().toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */\nMatrix.prototype.transpose = function () {\n  return Matrix.of(fold(transpose, [], this.__value))\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.transpose\n * @desc Returns a transposed Matrix\n * @param M {Matrix|array} A Matrix or a matrix array\n * @returns {Matrix}\n * @example\n *\n * const a = [-1, 2], [3, 4], [-8, 2]\n * const b = Matrix.transpose(a).toArray()\n * // returns [[-1, 3,-8], [2, 4, 2]]\n */\nMatrix.transpose = function (M) {\n  return Matrix.of(M).transpose()\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.add\n * @instance\n * @param M {Matrix|number} Add a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.add(1) // [[6, 5]]\n * const B = Matrix.of([[5, 5]])\n * B.add(B) // [[10, 10]]\n *\n */\nMatrix.prototype.add = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      throw new Error('Matrices do not match, cannot add')\n    }\n    return this.map((row, idx) => map((val, jdx) => val + M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x + M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#subtract\n * @instance\n * @param M {Matrix|number} Subtract a Matrix or a number\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.subtract(1) // [[4, 2]]\n * const B = Matrix.of([[5, 5]])\n * B.subtract(B) // [[0, 0]]\n *\n */\nMatrix.prototype.subtract = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      throw new Error('Matrices do not match, cannot subtract')\n    }\n    return this.map((row, idx) => map((val, jdx) => val - M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x - M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#multiply\n * @instance\n * @desc Mutliply a scalar or a mtraix with a matrix. Throws an error if the multiplication is not possible.\n * @param M {Matrix|number}\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.multiply(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.multiply(B) // [[25, 25]]\n *\n */\nMatrix.prototype.multiply = function (M) {\n  if (M instanceof Matrix) {\n    if (this.getCols() !== M.getCols() || this.getRows() !== M.getRows()) {\n      console.log('Use static method \\'dot\\' to do matrix multiplication')\n      throw new Error('Matrices do not match, cannot create hadamard product')\n    }\n    return this.map((row, idx) => map((col, jdx) => col * M.__value[idx][jdx])(row))\n  } else {\n    return this.map(map(x => x * M))\n  }\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#additiveinverse\n * @instance\n * @desc Function that returns the matrix obtained by changing the sign of every matrix element. The additive inverse of matrix A is written –A.\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5,-5], [-4, 4]])\n * const minusA = A.additiveinverse()\n * // [[-5, 5], [4, -4]]\n */\nMatrix.prototype.additiveinverse = function () {\n  return Matrix.of(this).multiply(-1)\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#hadamard\n * @instance\n * @see multiply\n * @param M\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[5, 4]])\n * A.hadamard(2) // [[10, 8]]\n * const B = Matrix.of([[5, 5]])\n * B.hadamard(B) // [[25, 25]]\n\n */\nMatrix.prototype.hadamard = function (M) {\n  return Matrix.of(this).multiply(M)\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#lu\n * @desc Calculates LU decomposition of the current Matrix\n * @returns {Matrix[]}\n * @example\n *\n * const result = [[3, -7, -2, 2], [-3, 5, 1, 0], [6, -4, 0, -5], [-9, 5, -5, 12]]\n * const A = Matrix.fromArray(result)\n * const lu = A.lu()\n * // L.__value = [ [ 1, 0, 0, 0 ], [ -1, 1, 0, 0 ], [ 2, -5, 1, 0 ], [ -3, 8, 3, 1 ] ]\n * // U.__value =  [ [ 3, -7, -2, 2 ], [ 0, -2, -1, 2 ], [ 0, 0, -1, 1 ], [ 0, 0, 0, -1 ] ]\n * Matrix.dot(lu[0], lu[1]) // returns clone of A\n *\n */\nMatrix.prototype.lu = function () {\n  const n = this.getRows()\n  const tol = 1e-6\n  const A = this.clone()\n  const L = this.zeros()\n  const U = this.zeros()\n\n  for (let k = 0; k < n; ++k) {\n    if (Math.abs(A.__value[k][k]) < tol) throw Error('Cannot proceed without a row exchange')\n    L.__value[k][k] = 1\n    for (let i = k + 1; i < n; ++i) {\n      L.__value[i][k] = A.__value[i][k] / A.__value[k][k]\n      for (let j = k + 1; j < n; ++j) {\n        A.__value[i][j] = A.__value[i][j] - L.__value[i][k] * A.__value[k][j]\n      }\n    }\n    for (let l = k; l < n; ++l) {\n      U.__value[k][l] = A.__value[k][l]\n    }\n  }\n  return [L, U]\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#rref\n * @returns {Matrix|array}\n * @example\n *\n * var A = Matrix.of([[-1, 1], [-1, 0], [0, -1], [-1, -2]])\n * A.rref() //  [ [ 1, 0 ], [ -0, 1 ], [ 0, 0 ], [ 0, 0 ] ]\n */\nMatrix.prototype.rref = function () {\n  let lead = 0\n  const resultMatrix = this.clone()\n\n  for (let r = 0; r < this.getRows(); ++r) {\n    if (this.getCols() <= lead) {\n      return resultMatrix\n    }\n    let i = r\n    while (resultMatrix.__value[i][lead] === 0) {\n      ++i\n      if (this.getRows() === i) {\n        i = r\n        ++lead\n        if (this.getCols() === lead) {\n          return resultMatrix\n        }\n      }\n    }\n\n    let tmp = resultMatrix.__value[i]\n    resultMatrix.__value[i] = resultMatrix.__value[r]\n    resultMatrix.__value[r] = tmp\n\n    let val = resultMatrix.__value[r][lead]\n    for (let j = 0; j < this.getCols(); ++j) {\n      resultMatrix.__value[r][j] /= val\n    }\n\n    for (let i = 0; i < this.getRows(); ++i) {\n      if (i === r) continue\n      val = resultMatrix.__value[i][lead]\n      for (let j = 0; j < this.getCols(); ++j) {\n        resultMatrix.__value[i][j] -= val * resultMatrix.__value[r][j]\n      }\n    }\n    lead++\n  }\n  return resultMatrix\n}\n\n/**\n * @memberOf Matrix\n * @instance\n * @member Matrix#solve\n * @param b\n * @returns {Array}\n * @example\n *\n * // Solve xA = b\n * // 5x + y  = 7\n * // 3x - 4y = 18\n * // Solution for x and y:\n * // x = 2\n * // y = -3\n *\n * const A = Matrix.of([[5, 1], [3, -4]])\n * const solveA = A.solve([7, 18]) // [2, -3]\n *\n */\nMatrix.prototype.solve = function (b) {\n  const A = this.clone()\n  const LU = A.lu()\n  const L = LU[0]\n  const U = LU[1]\n  const n = this.getRows()\n  let s = 0\n  const c = []\n  const x = []\n\n  for (let k = 0; k < n; ++k) {\n    for (let j = 0; j < k; ++j) {\n      s = s + L.__value[k][j] * c[j]\n    }\n    c[k] = b[k] - s\n    s = 0\n  }\n  for (let a = n - 1; a > -1; --a) {\n    let t = 0\n    for (let b = a + 1; b < n; ++b) {\n      t = t + U.__value[a][b] * x[b]\n    }\n    x[a] = (c[a] - t) / U.__value[a][a]\n  }\n  return x\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#inverse\n * @instance\n * @returns {Matrix}\n * @example\n *\n * const A = Matrix.of([[1, 1], [2, 4]]).inverse()\n * // [ [ 2, -0.5 ], [ -1, 0.5 ] ]\n *\n */\nMatrix.prototype.inverse = function () {\n  const A = this.clone()\n  const I = A.identity()\n  const Inv = A.concat(I).rref()\n\n  const result = Inv.__value.reduce((result, x, idx) => {\n    const half = x.length / 2\n    result.push(x.slice(half, x.length))\n    return result\n  }, [])\n  return Matrix.of(result)\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#rank\n * @instance\n * @returns {Number}\n */\nMatrix.prototype.rank = function () {\n  const rref = this.rref()\n  let result = 0\n  for (let i = 0; i < rref.getCols(); ++i) {\n    result += rref.__value[i][i]\n  }\n  return result\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#dimension\n * @instance\n * @see rank\n * @returns {Number}\n */\nMatrix.prototype.dimension = function () {\n  return this.rank()\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#diag\n * @instance\n * @desc Returns an array containing the values on the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diag()\n * // [1, 1, 1]\n *\n * const diag0 = Matrix.zeros(5, 5).diag()\n * // [0, 0, 0, 0, 0]\n *\n */\nMatrix.prototype.diag = function () {\n  return fold((acc, x, idx) => {\n    return acc.concat(x[idx])\n  })([])(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.diag\n * @desc Returns an array containing the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Array}\n * @example\n *\n * const diag1 = Matrix.diag([[2, 1], [1, 5]])\n * // [2, 5]\n *\n */\nMatrix.diag = function (M) {\n  return Matrix.of(M).diag()\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#diagproduct\n * @instance\n * @desc Returns the product of the values on the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).diagproduct()\n * // 1\n *\n * const diag0 = Matrix.zeros(5, 5).diagproduct()\n * // 0\n *\n */\nMatrix.prototype.diagproduct = function () {\n  return fold((acc, x, idx) => {\n    acc *= x[idx]\n    return acc\n  })(1)(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.diagproduct\n * @desc Returns the product of the values on the diagonal\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.diagproduct([[2, 1], [1, 5]])\n * // 10\n *\n */\nMatrix.diagproduct = function (M) {\n  return Matrix.of(M).diagproduct()\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#sum\n * @instance\n * @desc Returns the sum of the values in the Matrix\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.ones(3, 3).sum()\n * // 9\n *\n * const diag0 = Matrix.zeros(5, 5).sum()\n * // 0\n *\n */\nMatrix.prototype.sum = function () {\n  return fold((acc, x) => {\n    acc += fold((prev, next) => prev + next)(0)(x)\n    return acc\n  })(0)(this.__value)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.sum\n * @desc Returns the sum of the values in the Matrix\n * @param M {Matrix|Array} Matrix from which to return the diagonal\n * @returns {Number}\n * @example\n *\n * const diag1 = Matrix.sum([[2, 1], [1, 5]])\n * // 9\n *\n */\nMatrix.sum = function (M) {\n  return Matrix.of(M).sum()\n}\n\n/**\n * @memberOf Matrix\n * @member Matrix#kronecker\n * @instance\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param M {Matrix} The right side Matrix of the product (this ⊗ M)\n * @returns {Matrix}\n */\nMatrix.prototype.kronecker = function (M) {\n  const m = this.getRows()\n  const n = this.getCols()\n  const p = M.getRows()\n  const q = M.getCols()\n\n  const left = this.__value\n  const right = M.__value\n\n  const frame = generate(m * p, n * q)\n\n  for (let i = 0; i < m; i++) {\n    for (let j = 0; j < n; j++) {\n      for (let k = 0; k < p; k++) {\n        for (let l = 0; l < q; l++) {\n          frame[p * i + k][q * j + l] = left[i][j] * right[k][l]\n        }\n      }\n    }\n  }\n\n  return Matrix.of(frame)\n}\n\n/**\n * @memberOf Matrix\n * @function Matrix.kronecker\n * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix.\n * @param A {Matrix} The left side Matrix of the product (A ⊗ B)\n * @param B {Matrix} The right side Matrix of the product (A ⊗ B)\n * @returns {Matrix}\n */\nMatrix.kronecker = function (A, B) {\n  return Matrix.of(A).kronecker(B)\n}\n\nexport default Matrix\n","import curry from 'fun.js/src/curry'\nimport concat from 'fun.js/src/concat'\n\n/**\n * @function concat\n * @param M {Matrix}\n * @param m {Array}\n * @param idx {number}\n * @returns {Array}\n */\nexport default curry(function (M, m, idx) {\n  return concat(m, M.__value[idx])\n})\n","import curry from 'fun.js/src/curry'\n\nexport default curry(m => [])\n","import curry from 'fun.js/src/curry'\nimport fold from 'fun.js/src/fold'\nimport map from 'fun.js/src/map'\nimport round from './round'\n\n/**\n * @function dot\n * @param B {Matrix}\n * @param a {Array}\n * @returns {Array}\n */\nexport default curry((decimals, B, a) => map((item, i) => {\n  return fold((acc, x, j) => {\n    acc += round(x * B.__value[j][i], decimals)\n    return acc\n  }, 0)(a)\n})(B.__value[0]))\n","/**\n * @function round\n * @param value {number}\n * @param decimals {number}\n * @returns {Number}\n */\nexport default function round (value, decimals) {\n  return Number(Math.round(value + 'e' + decimals) + 'e-' + decimals)\n}\n","import map from 'fun.js/src/map'\n\n/**\n * @function identity\n * @desc Creates an identiy matrix from an empty array\n * @param m {Array}\n * @param idx {number}\n * @return {Matrix}\n */\nexport default (m, idx) => map((rows, jdx) => (idx === jdx) * 1)(m)\n","import map from 'fun.js/src/map'\nimport curry from 'fun.js/src/curry'\n\n/**\n * @function transpose\n * @desc Transposes a array of arrays using the Matrix.map function\n * @param m {Array}\n * @param idx {number}\n * @return {Matrix}\n */\nexport default curry((prev, next) => map((item, i) => (prev[i] || []).concat(next[i]))(next))\n","/**\n * @function generate\n * @desc Generator function for a matrix array, values are set to undefined\n * @param rows {number}\n * @param cols {number}\n * @returns {any[][]}\n */\nexport default (rows, cols) => Array.apply(null, Array(rows)).map(x => Array.apply(null, Array(cols)))\n","/**\n * @function exists\n */\nexport default function exists (x) {\n  return !(x == null)\n};\n","/**\n * @private\n */\nimport is from '../is'\n\nexport default is('Number')\n","/**\n * Checks if both predicates are true\n *\n * @function and\n * @description Checks if both predicates are true\n * @since v1.0.2\n * @sig (x, y) -> boolean\n * @param {*} x - A predicate\n * @param {*} y - A predicate\n * @return {boolean}\n **/\nimport curry from './curry'\n\nexport default curry(function and (x, y) {\n  return x && y\n})\n","/**\n * @function isNaN\n * @description Checks if number is NAN\n\n */\nimport isNumber from './is'\nimport and from '../and'\n\nexport default function isNan (x) {\n  return and(isNumber(x), isNaN(x))\n};\n","/**\n\n * @function identical\n * @description checks for identintical items\n */\nimport curry from './curry'\nimport isNan from './number/isNan'\n\nexport default curry(function identical (x, y) {\n  if (x === 0 && y === 0) {\n    return 1 / x === 1 / y\n  }\n  if (x === y) {\n    return true\n  }\n  return !!(isNan(x) && isNan(y))\n})\n","/**\n * @function not\n */\nimport curry from './curry'\n\nexport default curry(function not (x) {\n  return !x\n})\n","/**\n * @function or\n * @description Returns true if one or the other is true\n */\nimport curry from './curry'\n\nexport default curry(function or (x, y) {\n  return x || y\n})\n","/**\n\n */\nimport is from '../is'\n\nexport default is('Object')\n","/**\n * Checks if the provided object is an array, autocurried function\n *\n * @private\n * @function isArray\n * @description Checks if the provided object is an array, autocurried function\n * @param {*} Object to verifiy\n * @return {boolean}\n * @since 1.0.2\n * @example\n *\n * const result = isArray([1,1,1])\n * // result = true\n */\n\nimport is from '../is'\n\nexport default is('Array')\n","/**\n * Curried function that verifies of the provided argument is a boolean\n *\n * @private\n * @function is\n * @description Curried function that verifies of the provided argument is a boolean\n * @since v1.0.2\n * @param {*} Item to verify\n * @return {boolean}\n **/\nimport is from '../is'\n\nexport default is('Boolean')\n","/**\n\n */\nimport is from '../is'\n\nexport default is('String')\n","/**\n * Created by dierickx.len on 01/04/2017.\n */\n/**\n * Created by dierickx.len on 01/04/2017.\n */\nimport is from '../is'\n\nexport default is('Date')\n","/**\n * @private\n * @function equalsArray\n * @description Autocurried function for deep comparison of arrays\n * @param {a} x - Object to compare of type a\n * @param {a} y - Object x to compare with object x\n * @return {boolean}\n */\nimport curry from '../curry'\nimport not from '../not'\nimport equals from '../equals'\n\nexport default curry(function equalsArray (x, y) {\n  if (x.length !== y.length) {\n    return false\n  }\n  for (let i = 0; i < x.length; i++) {\n    if (not(equals(x[i], y[i]))) return false\n  }\n  return true\n})\n","/**\n\n * equals\n * checks for equality\n */\nimport curry from '../curry'\nimport exists from '../exists'\nimport not from '../not'\nimport equals from '../equals'\n\nexport default curry((x, y) => {\n  for (let keyX in x) {\n    // noinspection JSUnfilteredForInLoop\n    if (not(equals(x[keyX], y[keyX]))) return false\n  }\n\n  for (let keyY in y) {\n    if (not(exists(x[keyY])) && exists(y[keyY])) return false\n  }\n\n  return true\n})\n","/**\n\n * @function equals\n * @description Autocurried function that checks for equality of 2 items\n * @param {*} x - Left side of the equality check\n * @param {*} y - Right side of the equality check\n * @return {boolean}\n * @example\n *\n * const nan = Number.NaN\n * equal(nan, nan) // returns true\n *\n * const arr1 = [0, 1, 2, 3]\n * const arr2 = [null, 1, 2, 3]\n * equals(arr1, arr2) // returns false\n *\n * equals(new Object({'a': 0, 'b': 1}), {'a': 0, 'b': 1}) // true\n *\n */\nimport curry from './curry'\nimport exists from './exists'\nimport identical from './identical'\nimport type from './type'\nimport not from './not'\nimport or from './or'\nimport isObject from './object/is'\nimport isArray from './array/is'\nimport isBoolean from './boolean/is'\nimport isNumber from './number/is'\nimport isString from './string/is'\nimport isDate from './date/is'\nimport equalsArray from './array/equals'\nimport equalsObject from './object/equals'\n\nexport default curry(function equals (x, y) {\n  if (identical(x, y)) return true\n\n  if (type(x) !== type(y)) return false\n\n  if (or(not(exists(x)), not(exists(y)))) return false\n\n  if (x.constructor !== y.constructor) return false\n\n  if (isString(x) || isBoolean(x) || isNumber(x) || isDate(x)) {\n    return identical(x.valueOf(), y.valueOf())\n  }\n  if (isArray(x)) {\n    return equalsArray(x, y)\n  } else if (isObject(x)) {\n    return equalsObject(x, y)\n  }\n  return false\n})\n","/**\n * @private\n * @function arrayConcat\n * @param a1\n * @param a2\n * @returns {T[]}\n */\nimport curry from '../curry'\n\nexport default curry(function concat (a, b) {\n  return Array.prototype.concat(a, b)\n})\n","/**\n * @private\n * @function stringConcat\n */\n\nexport default function concat (a, b) { // use function(), arrow function doesn't bind arguments\n  return String(a) + String(b)\n}\n","/**\n * Concatenates 2 items together\n *\n * @function concat\n * @description Concatenates 2 items together\n * @since v1.0.4\n * @param {a} a - Left side of the concatenation\n * @param {a} b - right side of the concatenation\n * @return {a} Concatenated item\n **/\n\nimport curry from './curry'\nimport arrayConcat from './array/concat'\nimport stringConcat from './string/concat'\nimport type from './type'\n\nexport default curry(function concat (a, b) {\n  const typeMap = {\n    'String': stringConcat,\n    'Array': arrayConcat\n  }\n  return typeMap[type(a)](a, b)\n})\n"],"sourceRoot":""} \ No newline at end of file diff --git a/package.json b/package.json index e2af32c..7719252 100755 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "@astuanax/funmatrix", "sideEffects": false, - "version": "1.0.1", + "version": "1.0.2", "description": "Matrix monad", "main": "src/matrix.js", "scripts": { diff --git a/src/matrix.js b/src/matrix.js index 713f207..d89045c 100644 --- a/src/matrix.js +++ b/src/matrix.js @@ -2,12 +2,15 @@ import curry from 'fun.js/src/curry' import map from 'fun.js/src/map' import fold from 'fun.js/src/fold' import equals from 'fun.js/src/equals' -import concat from 'util/concat' -import empty from 'util/empty' -import dot from 'util/dot' -import identity from 'util/identity' -import transpose from 'util/transpose' -import generate from 'util/generate' +import concat from './util/concat' +import empty from './util/empty' +import dot from './util/dot' +import identity from './util/identity' +import transpose from './util/transpose' +import generate from './util/generate' +// import gpumap from 'util/gpumap' +// import gpufold from 'util/gpufold' +// import gpuproduct from 'util/gpuproduct' /** * @class Matrix @@ -24,6 +27,27 @@ let Matrix = function (val) { this.__value = val } +/** + * @memberOf Matrix + * @static + * @function Matrix.of + * @desc Creates a Matrix object and flattens the Matrix + * @param val {array|function} An array of arrays + * @returns {Matrix} + * @example + * + * const m = Matrix.of([[1,2],[2,3],[4,5]]) + * + */ +Matrix.of = function (val) { + if (val instanceof Matrix) return val + if (this instanceof Matrix) { + this.__value = val + return this + } + return new Matrix(val) +} + /** * @memberOf Matrix * @property {string} type @@ -49,7 +73,7 @@ Matrix.prototype.precision = 4 /** * @memberOf Matrix * @instance - * @member setPrecision + * @member Matrix#setPrecision * @param precision {number} Set the number of decimals for rounding * @example * @@ -81,7 +105,7 @@ Matrix.prototype.isSymmetric = function () { /** * @memberOf Matrix * @instance - * @member isSquare + * @member Matrix#isSquare * @desc Boolean indicating whether this contains a square Matrix * @returns {boolean} * @example @@ -97,7 +121,7 @@ Matrix.prototype.isSquare = function () { /** * @memberOf Matrix * @instance - * @member isOrthogonal + * @member Matrix#isOrthogonal * @param M {Matrix|array} * @returns {boolean} * @example @@ -115,7 +139,7 @@ Matrix.prototype.isOrthogonal = function () { /** * @memberOf Matrix * @instance - * @member getCols + * @member Matrix#getCols * @returns {Number} * @example * @@ -130,7 +154,7 @@ Matrix.prototype.getCols = function () { /** * @memberOf Matrix * @instance - * @member equals + * @member Matrix#equals * @param M {Matrix|array} * @returns {Boolean} * @example @@ -147,7 +171,7 @@ Matrix.prototype.equals = function (M) { /** * @memberOf Matrix * @instance - * @member getRows + * @member Matrix#getRows * @returns {Number} * @example * @@ -161,7 +185,7 @@ Matrix.prototype.getRows = function () { /** * @memberOf Matrix * @instance - * @member getShape + * @member Matrix#getShape * @returns {Array} * @example * @@ -172,31 +196,10 @@ Matrix.prototype.getShape = function () { return [this.getRows(), this.getCols()] } -/** - * @memberOf Matrix - * @static - * @function of - * @desc Creates a Matrix object and flattens the Matrix - * @param val {array|function} An array of arrays - * @returns {Matrix} - * @example - * - * const m = Matrix.of([[1,2],[2,3],[4,5]]) - * - */ -Matrix.of = function (val) { - if (val instanceof Matrix) return val - if (this instanceof Matrix) { - this.__value = val - return this - } - return new Matrix(val) -} - /** * @memberOf Matrix * @instance - * @member map + * @member Matrix#map * @description Maps over the rows of the matrix using a map function * @param f {function} An iterator function * @returns {Matrix} @@ -214,7 +217,7 @@ Matrix.prototype.map = function (f) { /** * @memberOf Matrix * @static - * @function map + * @function Matrix.map * @description Static function that maps over the rows of the matrix using a map function * @param f {function} An iterator function * @param M {Matrix|array} Matrix or array to map @@ -232,7 +235,7 @@ Matrix.map = curry(function (f, M) { /** * @memberOf Matrix * @instance - * @member fold + * @member Matrix#fold * @description Reduce the matrix rows using a reduce function * @param f {function} A reduce/fold function * @returns {Matrix} @@ -249,7 +252,7 @@ Matrix.prototype.fold = function (f) { /** * @memberOf Matrix * @static - * @function fold + * @function Matrix.fold * @description Static function to reduce the matrix rows using a reduce function * @param f {function} A reduce/fold function * @param M {Matrix} The Matrix to reduce @@ -269,7 +272,7 @@ Matrix.fold = curry(function (f, M) { /** * @memberOf Matrix * @instance - * @member ap + * @member Matrix#ap * @description Applies a Matrix to a function * @param M {Matrix} * @returns {Matrix} @@ -287,7 +290,7 @@ Matrix.prototype.ap = function (M) { /** * @memberOf Matrix * @static - * @function ap + * @function Matrix.ap * @description Applies a Matrix to a function * @param f {function} * @param M {Matrix|array} @@ -305,7 +308,7 @@ Matrix.ap = curry(function (f, M) { /** * @memberOf Matrix * @instance - * @member concat + * @member Matrix#concat * @description Concatenates 2 Matrices using a function as operator * @param M {Matrix} * @returns {Matrix} @@ -326,7 +329,7 @@ Matrix.prototype.concat = function (M, f = concat) { /** * @memberOf Matrix * @static - * @function concat + * @function Matrix.concat * @description Concatenates 2 Matrices using a function as operator * @param A {Matrix} * @param B {Matrix} @@ -348,7 +351,7 @@ Matrix.concat = curry(function (A, B, f = concat) { /** * @memberOf Matrix * @instance - * @member empty + * @member Matrix#empty * @description Return an empty Matrix from an existing Matrix * @returns {Matrix} */ @@ -359,7 +362,7 @@ Matrix.prototype.empty = function () { /** * @memberOf Matrix * @static - * @function empty + * @function Matrix.empty * @description Return an empty Matrix from an existing Matrix * @param rows {number} * @param cols {number} @@ -375,7 +378,7 @@ Matrix.empty = curry(function (rows = 0, cols = 0) { /** * @memberOf Matrix * @instance - * @member identity + * @member Matrix#identity * @desc Returns an identity matrix * @returns {Matrix} * @example @@ -385,7 +388,7 @@ Matrix.empty = curry(function (rows = 0, cols = 0) { * const Aidentity = A.identity() * // [[1, 0, 0], [0, 1, 0]] * -*/ + */ Matrix.prototype.identity = function () { return Matrix.of(identity).ap(this) } @@ -393,7 +396,7 @@ Matrix.prototype.identity = function () { /** * @memberOf Matrix * @static - * @function identity + * @function Matrix.identity * @desc Returns an identity matrix * @returns {Matrix} * @example @@ -410,7 +413,7 @@ Matrix.identity = function (rows, cols) { /** * @memberOf Matrix * @instance - * @member combine + * @member Matrix#combine * @see Matrix.concat * @param M * @returns {Matrix} @@ -422,7 +425,7 @@ Matrix.prototype.combine = function (M) { /** * @memberOf Matrix * @static - * @function combine + * @function Matrix.combine * @see Matrix.concat * @param M * @returns {Matrix} @@ -434,7 +437,7 @@ Matrix.combine = function (A, B) { /** * @memberOf Matrix * @instance - * @member dot + * @member Matrix#dot * @description Returns the dot product between 2 matrices * @param M * @param f @@ -459,7 +462,7 @@ Matrix.prototype.dot = function (M) { /** * @memberOf Matrix * @static - * @function dot + * @function Matrix.dot * @description Returns the dot product between 2 matrices * @param M * @returns {Matrix} @@ -480,7 +483,7 @@ Matrix.dot = function (A, B) { /** * @memberOf Matrix * @instance - * @member fill + * @member Matrix#fill * @desc Fill up an empty matrix with the provided map function * @param f * @returns {Matrix} @@ -497,7 +500,7 @@ Matrix.prototype.fill = function (f) { /** * @memberOf Matrix * @instance - * @member zeros + * @member Matrix#zeros * @desc Fill up an empty matrix with zeros * @returns {Matrix} * @@ -513,7 +516,7 @@ Matrix.prototype.zeros = function () { /** * @memberOf Matrix - * @function zeros + * @function Matrix.zeros * @desc Fill up an empty matrix with zeros * @param rows {number} Defines the rows of the matrix * @param cols {number} Defines the columns of the matrix @@ -532,7 +535,7 @@ Matrix.zeros = function (rows, cols) { /** * @memberOf Matrix * @instance - * @member ones + * @member Matrix#ones * @desc Fill up an empty matrix with ones * @returns {Matrix} * @example @@ -547,7 +550,7 @@ Matrix.prototype.ones = function () { /** * @memberOf Matrix - * @function ones + * @function Matrix.ones * @desc Fill up an empty matrix with ones * @param rows {number} Defines the rows of the matrix * @param cols {number} Defines the columns of the matrix @@ -566,7 +569,7 @@ Matrix.ones = function (rows, cols) { /** * @memberOf Matrix * @instance - * @member random + * @member Matrix#random * @desc Fill up an empty matrix with random values * @param {function} [f = e => Math.random() * 2 - 1] * @returns {Matrix} @@ -577,7 +580,7 @@ Matrix.prototype.random = function (f = e => Math.random() * 2 - 1) { /** * @memberOf Matrix - * @function random + * @function Matrix.random * @desc Fill up an empty matrix with random numbers * @param f {function} Function which returns random values. Default random values are between -1 and 1 * @param rows {number} Defines the rows of the matrix @@ -592,7 +595,7 @@ Matrix.random = function (f = e => (Math.random() * 2 - 1), rows, cols) { /** * @memberOf Matrix * @instance - * @member toArray + * @member Matrix#toArray * @desc Returns the array from the matrix * @returns {Array} */ @@ -603,7 +606,7 @@ Matrix.prototype.toArray = function () { /** * @memberOf Matrix * @instance - * @member clone + * @member Matrix#clone * @desc Returns a clone of the matrix * @returns {Matrix} */ @@ -614,7 +617,7 @@ Matrix.prototype.clone = function () { /** * @memberOf Matrix * @instance - * @member fromArray + * @member Matrix#fromArray * @desc Returns a Matrix from an array * @returns {Array} */ @@ -625,7 +628,7 @@ Matrix.fromArray = function (arr) { /** * @memberOf Matrix * @instance - * @member transpose + * @member Matrix#transpose * @desc Returns a transposed Matrix * @returns {Matrix} * @example @@ -640,7 +643,7 @@ Matrix.prototype.transpose = function () { /** * @memberOf Matrix - * @function transpose + * @function Matrix.transpose * @desc Returns a transposed Matrix * @param M {Matrix|array} A Matrix or a matrix array * @returns {Matrix} @@ -656,7 +659,7 @@ Matrix.transpose = function (M) { /** * @memberOf Matrix - * @member add + * @function Matrix.add * @instance * @param M {Matrix|number} Add a Matrix or a number * @returns {Matrix} @@ -681,7 +684,7 @@ Matrix.prototype.add = function (M) { /** * @memberOf Matrix - * @member subtract + * @member Matrix#subtract * @instance * @param M {Matrix|number} Subtract a Matrix or a number * @returns {Matrix} @@ -706,7 +709,7 @@ Matrix.prototype.subtract = function (M) { /** * @memberOf Matrix - * @member multiply + * @member Matrix#multiply * @instance * @desc Mutliply a scalar or a mtraix with a matrix. Throws an error if the multiplication is not possible. * @param M {Matrix|number} @@ -733,7 +736,7 @@ Matrix.prototype.multiply = function (M) { /** * @memberOf Matrix - * @member additiveinverse + * @member Matrix#additiveinverse * @instance * @desc Function that returns the matrix obtained by changing the sign of every matrix element. The additive inverse of matrix A is written –A. * @returns {Matrix} @@ -749,7 +752,7 @@ Matrix.prototype.additiveinverse = function () { /** * @memberOf Matrix - * @member hadamard + * @member Matrix#hadamard * @instance * @see multiply * @param M @@ -769,7 +772,7 @@ Matrix.prototype.hadamard = function (M) { /** * @memberOf Matrix * @instance - * @member lu + * @member Matrix#lu * @desc Calculates LU decomposition of the current Matrix * @returns {Matrix[]} * @example @@ -808,7 +811,7 @@ Matrix.prototype.lu = function () { /** * @memberOf Matrix * @instance - * @member rref + * @member Matrix#rref * @returns {Matrix|array} * @example * @@ -859,7 +862,7 @@ Matrix.prototype.rref = function () { /** * @memberOf Matrix * @instance - * @member solve + * @member Matrix#solve * @param b * @returns {Array} * @example @@ -904,7 +907,7 @@ Matrix.prototype.solve = function (b) { /** * @memberOf Matrix - * @member inverse + * @member Matrix#inverse * @instance * @returns {Matrix} * @example @@ -928,7 +931,7 @@ Matrix.prototype.inverse = function () { /** * @memberOf Matrix - * @member rank + * @member Matrix#rank * @instance * @returns {Number} */ @@ -943,7 +946,7 @@ Matrix.prototype.rank = function () { /** * @memberOf Matrix - * @member dimension + * @member Matrix#dimension * @instance * @see rank * @returns {Number} @@ -954,7 +957,7 @@ Matrix.prototype.dimension = function () { /** * @memberOf Matrix - * @member diag + * @member Matrix#diag * @instance * @desc Returns an array containing the values on the diagonal * @returns {Array} @@ -975,7 +978,7 @@ Matrix.prototype.diag = function () { /** * @memberOf Matrix - * @function diag + * @function Matrix.diag * @desc Returns an array containing the values on the diagonal * @param M {Matrix|Array} Matrix from which to return the diagonal * @returns {Array} @@ -991,7 +994,7 @@ Matrix.diag = function (M) { /** * @memberOf Matrix - * @member diagproduct + * @member Matrix#diagproduct * @instance * @desc Returns the product of the values on the diagonal * @returns {Number} @@ -1013,7 +1016,7 @@ Matrix.prototype.diagproduct = function () { /** * @memberOf Matrix - * @function diagproduct + * @function Matrix.diagproduct * @desc Returns the product of the values on the diagonal * @param M {Matrix|Array} Matrix from which to return the diagonal * @returns {Number} @@ -1029,7 +1032,7 @@ Matrix.diagproduct = function (M) { /** * @memberOf Matrix - * @member sum + * @member Matrix#sum * @instance * @desc Returns the sum of the values in the Matrix * @returns {Number} @@ -1051,7 +1054,7 @@ Matrix.prototype.sum = function () { /** * @memberOf Matrix - * @function sum + * @function Matrix.sum * @desc Returns the sum of the values in the Matrix * @param M {Matrix|Array} Matrix from which to return the diagonal * @returns {Number} @@ -1067,7 +1070,7 @@ Matrix.sum = function (M) { /** * @memberOf Matrix - * @member kronecker + * @member Matrix#kronecker * @instance * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix. * @param M {Matrix} The right side Matrix of the product (this ⊗ M) @@ -1084,21 +1087,22 @@ Matrix.prototype.kronecker = function (M) { const frame = generate(m * p, n * q) - for (var i = 0; i < m; i++) { - for (var j = 0; j < n; j++) { - for (var k = 0; k < p; k++) { - for (var l = 0; l < q; l++) { + for (let i = 0; i < m; i++) { + for (let j = 0; j < n; j++) { + for (let k = 0; k < p; k++) { + for (let l = 0; l < q; l++) { frame[p * i + k][q * j + l] = left[i][j] * right[k][l] } } } } + return Matrix.of(frame) } /** * @memberOf Matrix - * @function kronecker + * @function Matrix.kronecker * @desc The Kronecker product is an operation on two matrices of arbitrary size resulting in a block matrix. * @param A {Matrix} The left side Matrix of the product (A ⊗ B) * @param B {Matrix} The right side Matrix of the product (A ⊗ B)