mathjs 11.11.2 → 11.12.0
Sign up to get free protection for your applications and to get access to all the features.
- package/HISTORY.md +11 -0
- package/lib/browser/math.js +1 -1
- package/lib/browser/math.js.LICENSE.txt +2 -2
- package/lib/browser/math.js.map +1 -1
- package/lib/cjs/core/create.js +2 -2
- package/lib/cjs/defaultInstance.js +2 -2
- package/lib/cjs/entry/allFactoriesAny.js +2 -2
- package/lib/cjs/entry/allFactoriesNumber.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesDet.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesDistance.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesLsolve.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesLsolveAll.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesLup.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesQr.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesStirlingS2.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesSubtract.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesSubtractScalar.generated.js +17 -0
- package/lib/cjs/entry/dependenciesAny/dependenciesUnitClass.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesUsolve.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny/dependenciesUsolveAll.generated.js +2 -2
- package/lib/cjs/entry/dependenciesAny.generated.js +7 -0
- package/lib/cjs/entry/dependenciesNumber/dependenciesStirlingS2.generated.js +2 -2
- package/lib/cjs/entry/dependenciesNumber/dependenciesSubtractScalar.generated.js +17 -0
- package/lib/cjs/entry/dependenciesNumber.generated.js +7 -0
- package/lib/cjs/entry/impureFunctionsAny.generated.js +4 -3
- package/lib/cjs/entry/impureFunctionsNumber.generated.js +2 -1
- package/lib/cjs/entry/pureFunctionsAny.generated.js +41 -37
- package/lib/cjs/entry/pureFunctionsNumber.generated.js +16 -13
- package/lib/cjs/expression/parse.js +50 -69
- package/lib/cjs/factoriesAny.js +7 -0
- package/lib/cjs/factoriesNumber.js +2 -1
- package/lib/cjs/function/algebra/decomposition/lup.js +3 -3
- package/lib/cjs/function/algebra/decomposition/qr.js +5 -5
- package/lib/cjs/function/algebra/solver/lsolve.js +4 -4
- package/lib/cjs/function/algebra/solver/lsolveAll.js +6 -6
- package/lib/cjs/function/algebra/solver/usolve.js +4 -4
- package/lib/cjs/function/algebra/solver/usolveAll.js +6 -6
- package/lib/cjs/function/arithmetic/subtract.js +7 -37
- package/lib/cjs/function/arithmetic/subtractScalar.js +52 -0
- package/lib/cjs/function/combinatorics/stirlingS2.js +2 -2
- package/lib/cjs/function/geometry/distance.js +10 -10
- package/lib/cjs/function/matrix/det.js +4 -4
- package/lib/cjs/header.js +2 -2
- package/lib/cjs/type/unit/Unit.js +5 -5
- package/lib/cjs/utils/object.js +4 -2
- package/lib/cjs/utils/snapshot.js +3 -3
- package/lib/cjs/utils/string.js +12 -16
- package/lib/cjs/version.js +1 -1
- package/lib/esm/entry/dependenciesAny/dependenciesDet.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesDistance.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesLsolve.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesLsolveAll.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesLup.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesQr.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesStirlingS2.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesSubtract.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesSubtractScalar.generated.js +10 -0
- package/lib/esm/entry/dependenciesAny/dependenciesUnitClass.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesUsolve.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny/dependenciesUsolveAll.generated.js +2 -2
- package/lib/esm/entry/dependenciesAny.generated.js +1 -0
- package/lib/esm/entry/dependenciesNumber/dependenciesStirlingS2.generated.js +2 -2
- package/lib/esm/entry/dependenciesNumber/dependenciesSubtractScalar.generated.js +10 -0
- package/lib/esm/entry/dependenciesNumber.generated.js +1 -0
- package/lib/esm/entry/impureFunctionsAny.generated.js +5 -4
- package/lib/esm/entry/impureFunctionsNumber.generated.js +3 -2
- package/lib/esm/entry/pureFunctionsAny.generated.js +40 -37
- package/lib/esm/entry/pureFunctionsNumber.generated.js +16 -13
- package/lib/esm/expression/parse.js +50 -69
- package/lib/esm/factoriesAny.js +1 -0
- package/lib/esm/factoriesNumber.js +1 -0
- package/lib/esm/function/algebra/decomposition/lup.js +3 -3
- package/lib/esm/function/algebra/decomposition/qr.js +5 -5
- package/lib/esm/function/algebra/solver/lsolve.js +4 -4
- package/lib/esm/function/algebra/solver/lsolveAll.js +6 -6
- package/lib/esm/function/algebra/solver/usolve.js +4 -4
- package/lib/esm/function/algebra/solver/usolveAll.js +6 -6
- package/lib/esm/function/arithmetic/subtract.js +7 -27
- package/lib/esm/function/arithmetic/subtractScalar.js +46 -0
- package/lib/esm/function/combinatorics/stirlingS2.js +2 -2
- package/lib/esm/function/geometry/distance.js +10 -10
- package/lib/esm/function/matrix/det.js +4 -4
- package/lib/esm/type/unit/Unit.js +5 -5
- package/lib/esm/utils/object.js +5 -3
- package/lib/esm/utils/snapshot.js +1 -1
- package/lib/esm/utils/string.js +12 -16
- package/lib/esm/version.js +1 -1
- package/package.json +13 -13
- package/types/index.d.ts +31 -0
@@ -9,13 +9,13 @@ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers
|
|
9
9
|
var _factory = require("../../../utils/factory.js");
|
10
10
|
var _solveValidation = require("./utils/solveValidation.js");
|
11
11
|
var name = 'usolveAll';
|
12
|
-
var dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', '
|
12
|
+
var dependencies = ['typed', 'matrix', 'divideScalar', 'multiplyScalar', 'subtractScalar', 'equalScalar', 'DenseMatrix'];
|
13
13
|
var createUsolveAll = exports.createUsolveAll = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
|
14
14
|
var typed = _ref.typed,
|
15
15
|
matrix = _ref.matrix,
|
16
16
|
divideScalar = _ref.divideScalar,
|
17
17
|
multiplyScalar = _ref.multiplyScalar,
|
18
|
-
|
18
|
+
subtractScalar = _ref.subtractScalar,
|
19
19
|
equalScalar = _ref.equalScalar,
|
20
20
|
DenseMatrix = _ref.DenseMatrix;
|
21
21
|
var solveValidation = (0, _solveValidation.createSolveValidation)({
|
@@ -86,7 +86,7 @@ var createUsolveAll = exports.createUsolveAll = /* #__PURE__ */(0, _factory.fact
|
|
86
86
|
b[i] = divideScalar(b[i], M[i][i]);
|
87
87
|
for (var j = i - 1; j >= 0; j--) {
|
88
88
|
// b[j] -= b[i] * M[j,i]
|
89
|
-
b[j] =
|
89
|
+
b[j] = subtractScalar(b[j], multiplyScalar(b[i], M[j][i]));
|
90
90
|
}
|
91
91
|
} else if (!equalScalar(b[i], 0)) {
|
92
92
|
// singular row, nonzero RHS
|
@@ -106,7 +106,7 @@ var createUsolveAll = exports.createUsolveAll = /* #__PURE__ */(0, _factory.fact
|
|
106
106
|
var bNew = (0, _toConsumableArray2["default"])(b);
|
107
107
|
bNew[i] = 1;
|
108
108
|
for (var _j = i - 1; _j >= 0; _j--) {
|
109
|
-
bNew[_j] =
|
109
|
+
bNew[_j] = subtractScalar(bNew[_j], M[_j][i]);
|
110
110
|
}
|
111
111
|
B.push(bNew);
|
112
112
|
}
|
@@ -169,7 +169,7 @@ var createUsolveAll = exports.createUsolveAll = /* #__PURE__ */(0, _factory.fact
|
|
169
169
|
// loop upper triangular
|
170
170
|
for (var _j2 = 0, _lastIndex = iIndices.length; _j2 < _lastIndex; _j2++) {
|
171
171
|
var _J = iIndices[_j2];
|
172
|
-
b[_J] =
|
172
|
+
b[_J] = subtractScalar(b[_J], multiplyScalar(b[i], iValues[_j2]));
|
173
173
|
}
|
174
174
|
} else if (!equalScalar(b[i], 0)) {
|
175
175
|
// singular row, nonzero RHS
|
@@ -192,7 +192,7 @@ var createUsolveAll = exports.createUsolveAll = /* #__PURE__ */(0, _factory.fact
|
|
192
192
|
// loop upper triangular
|
193
193
|
for (var _j3 = 0, _lastIndex2 = iIndices.length; _j3 < _lastIndex2; _j3++) {
|
194
194
|
var _J2 = iIndices[_j3];
|
195
|
-
bNew[_J2] =
|
195
|
+
bNew[_J2] = subtractScalar(bNew[_J2], iValues[_j3]);
|
196
196
|
}
|
197
197
|
B.push(bNew);
|
198
198
|
}
|
@@ -12,12 +12,12 @@ var _matAlgo10xSids = require("../../type/matrix/utils/matAlgo10xSids.js");
|
|
12
12
|
var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js");
|
13
13
|
var _matrixAlgorithmSuite = require("../../type/matrix/utils/matrixAlgorithmSuite.js");
|
14
14
|
var name = 'subtract';
|
15
|
-
var dependencies = ['typed', 'matrix', 'equalScalar', '
|
15
|
+
var dependencies = ['typed', 'matrix', 'equalScalar', 'subtractScalar', 'unaryMinus', 'DenseMatrix', 'concat'];
|
16
16
|
var createSubtract = exports.createSubtract = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
|
17
17
|
var typed = _ref.typed,
|
18
18
|
matrix = _ref.matrix,
|
19
19
|
equalScalar = _ref.equalScalar,
|
20
|
-
|
20
|
+
subtractScalar = _ref.subtractScalar,
|
21
21
|
unaryMinus = _ref.unaryMinus,
|
22
22
|
DenseMatrix = _ref.DenseMatrix,
|
23
23
|
concat = _ref.concat;
|
@@ -73,44 +73,14 @@ var createSubtract = exports.createSubtract = /* #__PURE__ */(0, _factory.factor
|
|
73
73
|
*
|
74
74
|
* add
|
75
75
|
*
|
76
|
-
* @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x
|
77
|
-
*
|
78
|
-
* @
|
79
|
-
* Value to subtract from `x`
|
80
|
-
* @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix}
|
81
|
-
* Subtraction of `x` and `y`
|
76
|
+
* @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} x Initial value
|
77
|
+
* @param {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} y Value to subtract from `x`
|
78
|
+
* @return {number | BigNumber | Fraction | Complex | Unit | Array | Matrix} Subtraction of `x` and `y`
|
82
79
|
*/
|
83
80
|
return typed(name, {
|
84
|
-
'
|
85
|
-
return x - y;
|
86
|
-
},
|
87
|
-
'Complex, Complex': function ComplexComplex(x, y) {
|
88
|
-
return x.sub(y);
|
89
|
-
},
|
90
|
-
'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {
|
91
|
-
return x.minus(y);
|
92
|
-
},
|
93
|
-
'Fraction, Fraction': function FractionFraction(x, y) {
|
94
|
-
return x.sub(y);
|
95
|
-
},
|
96
|
-
'Unit, Unit': typed.referToSelf(function (self) {
|
97
|
-
return function (x, y) {
|
98
|
-
if (x.value === null) {
|
99
|
-
throw new Error('Parameter x contains a unit with undefined value');
|
100
|
-
}
|
101
|
-
if (y.value === null) {
|
102
|
-
throw new Error('Parameter y contains a unit with undefined value');
|
103
|
-
}
|
104
|
-
if (!x.equalBase(y)) {
|
105
|
-
throw new Error('Units do not match');
|
106
|
-
}
|
107
|
-
var res = x.clone();
|
108
|
-
res.value = typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value);
|
109
|
-
res.fixPrefix = false;
|
110
|
-
return res;
|
111
|
-
};
|
112
|
-
})
|
81
|
+
'any, any': subtractScalar
|
113
82
|
}, matrixAlgorithmSuite({
|
83
|
+
elop: subtractScalar,
|
114
84
|
SS: matAlgo05xSfSf,
|
115
85
|
DS: matAlgo01xDSid,
|
116
86
|
SD: matAlgo03xDSf,
|
@@ -0,0 +1,52 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
exports.createSubtractScalar = void 0;
|
7
|
+
var _factory = require("../../utils/factory.js");
|
8
|
+
var _index = require("../../plain/number/index.js");
|
9
|
+
var name = 'subtractScalar';
|
10
|
+
var dependencies = ['typed'];
|
11
|
+
var createSubtractScalar = exports.createSubtractScalar = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
|
12
|
+
var typed = _ref.typed;
|
13
|
+
/**
|
14
|
+
* Subtract two scalar values, `x - y`.
|
15
|
+
* This function is meant for internal use: it is used by the public function
|
16
|
+
* `subtract`
|
17
|
+
*
|
18
|
+
* This function does not support collections (Array or Matrix).
|
19
|
+
*
|
20
|
+
* @param {number | BigNumber | Fraction | Complex | Unit} x First value
|
21
|
+
* @param {number | BigNumber | Fraction | Complex} y Second value to be subtracted from `x`
|
22
|
+
* @return {number | BigNumber | Fraction | Complex | Unit} Difference of `x` and `y`
|
23
|
+
* @private
|
24
|
+
*/
|
25
|
+
return typed(name, {
|
26
|
+
'number, number': _index.subtractNumber,
|
27
|
+
'Complex, Complex': function ComplexComplex(x, y) {
|
28
|
+
return x.sub(y);
|
29
|
+
},
|
30
|
+
'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {
|
31
|
+
return x.minus(y);
|
32
|
+
},
|
33
|
+
'Fraction, Fraction': function FractionFraction(x, y) {
|
34
|
+
return x.sub(y);
|
35
|
+
},
|
36
|
+
'Unit, Unit': typed.referToSelf(function (self) {
|
37
|
+
return function (x, y) {
|
38
|
+
if (x.value === null || x.value === undefined) {
|
39
|
+
throw new Error('Parameter x contains a unit with undefined value');
|
40
|
+
}
|
41
|
+
if (y.value === null || y.value === undefined) {
|
42
|
+
throw new Error('Parameter y contains a unit with undefined value');
|
43
|
+
}
|
44
|
+
if (!x.equalBase(y)) throw new Error('Units do not match');
|
45
|
+
var res = x.clone();
|
46
|
+
res.value = typed.find(self, [res.valueType(), y.valueType()])(res.value, y.value);
|
47
|
+
res.fixPrefix = false;
|
48
|
+
return res;
|
49
|
+
};
|
50
|
+
})
|
51
|
+
});
|
52
|
+
});
|
@@ -7,11 +7,11 @@ exports.createStirlingS2 = void 0;
|
|
7
7
|
var _factory = require("../../utils/factory.js");
|
8
8
|
var _is = require("../../utils/is.js");
|
9
9
|
var name = 'stirlingS2';
|
10
|
-
var dependencies = ['typed', 'addScalar', '
|
10
|
+
var dependencies = ['typed', 'addScalar', 'subtractScalar', 'multiplyScalar', 'divideScalar', 'pow', 'factorial', 'combinations', 'isNegative', 'isInteger', 'number', '?bignumber', 'larger'];
|
11
11
|
var createStirlingS2 = exports.createStirlingS2 = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
|
12
12
|
var typed = _ref.typed,
|
13
13
|
addScalar = _ref.addScalar,
|
14
|
-
|
14
|
+
subtractScalar = _ref.subtractScalar,
|
15
15
|
multiplyScalar = _ref.multiplyScalar,
|
16
16
|
divideScalar = _ref.divideScalar,
|
17
17
|
pow = _ref.pow,
|
@@ -7,11 +7,11 @@ exports.createDistance = void 0;
|
|
7
7
|
var _is = require("../../utils/is.js");
|
8
8
|
var _factory = require("../../utils/factory.js");
|
9
9
|
var name = 'distance';
|
10
|
-
var dependencies = ['typed', 'addScalar', '
|
10
|
+
var dependencies = ['typed', 'addScalar', 'subtractScalar', 'divideScalar', 'multiplyScalar', 'deepEqual', 'sqrt', 'abs'];
|
11
11
|
var createDistance = exports.createDistance = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
|
12
12
|
var typed = _ref.typed,
|
13
13
|
addScalar = _ref.addScalar,
|
14
|
-
|
14
|
+
subtractScalar = _ref.subtractScalar,
|
15
15
|
multiplyScalar = _ref.multiplyScalar,
|
16
16
|
divideScalar = _ref.divideScalar,
|
17
17
|
deepEqual = _ref.deepEqual,
|
@@ -84,9 +84,9 @@ var createDistance = exports.createDistance = /* #__PURE__ */(0, _factory.factor
|
|
84
84
|
if (deepEqual(y, z)) {
|
85
85
|
throw new TypeError('LinePoint1 should not be same with LinePoint2');
|
86
86
|
}
|
87
|
-
var xCoeff =
|
88
|
-
var yCoeff =
|
89
|
-
var constant =
|
87
|
+
var xCoeff = subtractScalar(z[1], y[1]);
|
88
|
+
var yCoeff = subtractScalar(y[0], z[0]);
|
89
|
+
var constant = subtractScalar(multiplyScalar(z[0], y[1]), multiplyScalar(y[0], z[1]));
|
90
90
|
return _distancePointLine2D(x[0], x[1], xCoeff, yCoeff, constant);
|
91
91
|
} else {
|
92
92
|
throw new TypeError('Invalid Arguments: Try again');
|
@@ -107,9 +107,9 @@ var createDistance = exports.createDistance = /* #__PURE__ */(0, _factory.factor
|
|
107
107
|
throw new TypeError('LinePoint1 should not be same with LinePoint2');
|
108
108
|
}
|
109
109
|
if ('pointX' in x && 'pointY' in x && 'lineOnePtX' in y && 'lineOnePtY' in y && 'lineTwoPtX' in z && 'lineTwoPtY' in z) {
|
110
|
-
var xCoeff =
|
111
|
-
var yCoeff =
|
112
|
-
var constant =
|
110
|
+
var xCoeff = subtractScalar(z.lineTwoPtY, y.lineOnePtY);
|
111
|
+
var yCoeff = subtractScalar(y.lineOnePtX, z.lineTwoPtX);
|
112
|
+
var constant = subtractScalar(multiplyScalar(z.lineTwoPtX, y.lineOnePtY), multiplyScalar(y.lineOnePtX, z.lineTwoPtY));
|
113
113
|
return _distancePointLine2D(x.pointX, x.pointY, xCoeff, yCoeff, constant);
|
114
114
|
} else {
|
115
115
|
throw new TypeError('Key names do not match');
|
@@ -277,7 +277,7 @@ var createDistance = exports.createDistance = /* #__PURE__ */(0, _factory.factor
|
|
277
277
|
return divideScalar(num, den);
|
278
278
|
}
|
279
279
|
function _distancePointLine3D(x, y, z, x0, y0, z0, a, b, c) {
|
280
|
-
var num = [
|
280
|
+
var num = [subtractScalar(multiplyScalar(subtractScalar(y0, y), c), multiplyScalar(subtractScalar(z0, z), b)), subtractScalar(multiplyScalar(subtractScalar(z0, z), a), multiplyScalar(subtractScalar(x0, x), c)), subtractScalar(multiplyScalar(subtractScalar(x0, x), b), multiplyScalar(subtractScalar(y0, y), a))];
|
281
281
|
num = sqrt(addScalar(addScalar(multiplyScalar(num[0], num[0]), multiplyScalar(num[1], num[1])), multiplyScalar(num[2], num[2])));
|
282
282
|
var den = sqrt(addScalar(addScalar(multiplyScalar(a, a), multiplyScalar(b, b)), multiplyScalar(c, c)));
|
283
283
|
return divideScalar(num, den);
|
@@ -287,7 +287,7 @@ var createDistance = exports.createDistance = /* #__PURE__ */(0, _factory.factor
|
|
287
287
|
var result = 0;
|
288
288
|
var diff = 0;
|
289
289
|
for (var i = 0; i < vectorSize; i++) {
|
290
|
-
diff =
|
290
|
+
diff = subtractScalar(x[i], y[i]);
|
291
291
|
result = addScalar(multiplyScalar(diff, diff), result);
|
292
292
|
}
|
293
293
|
return sqrt(result);
|
@@ -9,11 +9,11 @@ var _object = require("../../utils/object.js");
|
|
9
9
|
var _string = require("../../utils/string.js");
|
10
10
|
var _factory = require("../../utils/factory.js");
|
11
11
|
var name = 'det';
|
12
|
-
var dependencies = ['typed', 'matrix', '
|
12
|
+
var dependencies = ['typed', 'matrix', 'subtractScalar', 'multiply', 'divideScalar', 'isZero', 'unaryMinus'];
|
13
13
|
var createDet = exports.createDet = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
|
14
14
|
var typed = _ref.typed,
|
15
15
|
matrix = _ref.matrix,
|
16
|
-
|
16
|
+
subtractScalar = _ref.subtractScalar,
|
17
17
|
multiply = _ref.multiply,
|
18
18
|
divideScalar = _ref.divideScalar,
|
19
19
|
isZero = _ref.isZero,
|
@@ -108,7 +108,7 @@ var createDet = exports.createDet = /* #__PURE__ */(0, _factory.factory)(name, d
|
|
108
108
|
} else if (rows === 2) {
|
109
109
|
// this is a 2 x 2 matrix
|
110
110
|
// the determinant of [a11,a12;a21,a22] is det = a11*a22-a21*a12
|
111
|
-
return
|
111
|
+
return subtractScalar(multiply(matrix[0][0], matrix[1][1]), multiply(matrix[1][0], matrix[0][1]));
|
112
112
|
} else {
|
113
113
|
// Bareiss algorithm
|
114
114
|
// this algorithm have same complexity as LUP decomposition (O(n^3))
|
@@ -138,7 +138,7 @@ var createDet = exports.createDet = /* #__PURE__ */(0, _factory.factory)(name, d
|
|
138
138
|
for (var i = k + 1; i < rows; i++) {
|
139
139
|
var i_ = rowIndices[i];
|
140
140
|
for (var j = k + 1; j < rows; j++) {
|
141
|
-
matrix[i_][j] = divideScalar(
|
141
|
+
matrix[i_][j] = divideScalar(subtractScalar(multiply(matrix[i_][j], piv), multiply(matrix[i_][k], matrix[k_][j])), piv_);
|
142
142
|
}
|
143
143
|
}
|
144
144
|
}
|
package/lib/cjs/header.js
CHANGED
@@ -6,8 +6,8 @@
|
|
6
6
|
* It features real and complex numbers, units, matrices, a large set of
|
7
7
|
* mathematical functions, and a flexible expression parser.
|
8
8
|
*
|
9
|
-
* @version 11.
|
10
|
-
* @date 2023-10-
|
9
|
+
* @version 11.12.0
|
10
|
+
* @date 2023-10-26
|
11
11
|
*
|
12
12
|
* @license
|
13
13
|
* Copyright (C) 2013-2023 Jos de Jong <wjosdejong@gmail.com>
|
@@ -17,12 +17,12 @@ var _constants = require("../../utils/bignumber/constants.js");
|
|
17
17
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
18
18
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
19
19
|
var name = 'Unit';
|
20
|
-
var dependencies = ['?on', 'config', 'addScalar', '
|
20
|
+
var dependencies = ['?on', 'config', 'addScalar', 'subtractScalar', 'multiplyScalar', 'divideScalar', 'pow', 'abs', 'fix', 'round', 'equal', 'isNumeric', 'format', 'number', 'Complex', 'BigNumber', 'Fraction'];
|
21
21
|
var createUnitClass = exports.createUnitClass = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
|
22
22
|
var on = _ref.on,
|
23
23
|
config = _ref.config,
|
24
24
|
addScalar = _ref.addScalar,
|
25
|
-
|
25
|
+
subtractScalar = _ref.subtractScalar,
|
26
26
|
multiplyScalar = _ref.multiplyScalar,
|
27
27
|
divideScalar = _ref.divideScalar,
|
28
28
|
pow = _ref.pow,
|
@@ -753,7 +753,7 @@ var createUnitClass = exports.createUnitClass = /* #__PURE__ */(0, _factory.fact
|
|
753
753
|
var unitValue = convert(ret.units[0].unit.value);
|
754
754
|
var nominalOffset = convert(ret.units[0].unit.offset);
|
755
755
|
var unitOffset = multiplyScalar(unitValue, nominalOffset);
|
756
|
-
ret.value =
|
756
|
+
ret.value = subtractScalar(abs(addScalar(ret.value, unitOffset)), unitOffset);
|
757
757
|
}
|
758
758
|
}
|
759
759
|
for (var i in ret.units) {
|
@@ -798,7 +798,7 @@ var createUnitClass = exports.createUnitClass = /* #__PURE__ */(0, _factory.fact
|
|
798
798
|
var otherUnitValue = other.units[0].unit.value;
|
799
799
|
var otherNominalOffset = other.units[0].unit.offset;
|
800
800
|
var otherUnitOffset = multiplyScalar(otherUnitValue, otherNominalOffset);
|
801
|
-
other.value = addScalar(value, convert(
|
801
|
+
other.value = addScalar(value, convert(subtractScalar(thisUnitOffset, otherUnitOffset)));
|
802
802
|
}
|
803
803
|
other.fixPrefix = true;
|
804
804
|
other.skipAutomaticSimplification = true;
|
@@ -1174,7 +1174,7 @@ var createUnitClass = exports.createUnitClass = /* #__PURE__ */(0, _factory.fact
|
|
1174
1174
|
}
|
1175
1175
|
var y = new Unit(xFixed, parts[i].toString());
|
1176
1176
|
ret.push(y);
|
1177
|
-
x =
|
1177
|
+
x = subtractScalar(x, y);
|
1178
1178
|
}
|
1179
1179
|
|
1180
1180
|
// This little bit fixes a bug where the remainder should be 0 but is a little bit off.
|
package/lib/cjs/utils/object.js
CHANGED
@@ -54,10 +54,12 @@ function clone(x) {
|
|
54
54
|
}
|
55
55
|
if (x instanceof Date) return new Date(x.valueOf());
|
56
56
|
if ((0, _is.isBigNumber)(x)) return x; // bignumbers are immutable
|
57
|
-
if (x instanceof RegExp) throw new TypeError('Cannot clone ' + x); // TODO: clone a RegExp
|
58
57
|
|
59
58
|
// object
|
60
|
-
|
59
|
+
if ((0, _is.isObject)(x)) {
|
60
|
+
return mapObject(x, clone);
|
61
|
+
}
|
62
|
+
throw new TypeError("Cannot clone: unknown type of value (value: ".concat(x, ")"));
|
61
63
|
}
|
62
64
|
|
63
65
|
/**
|
@@ -14,8 +14,8 @@ var _assert = _interopRequireDefault(require("assert"));
|
|
14
14
|
var allIsFunctions = _interopRequireWildcard(require("./is.js"));
|
15
15
|
var _create = require("../core/create.js");
|
16
16
|
var _string = require("./string.js");
|
17
|
-
function _getRequireWildcardCache(
|
18
|
-
function _interopRequireWildcard(
|
17
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
18
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
19
19
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
20
20
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /**
|
21
21
|
* This file contains helper methods to create expected snapshot structures
|
@@ -141,7 +141,7 @@ function createSnapshotFromFactories(factories) {
|
|
141
141
|
embeddedDocs[name] = 'Object';
|
142
142
|
}
|
143
143
|
});
|
144
|
-
embeddedDocs = exclude(embeddedDocs, ['equalScalar', 'apply', 'addScalar', 'multiplyScalar', 'print', 'divideScalar', 'parse', 'compile', 'parser', 'chain', 'reviver', 'replacer']);
|
144
|
+
embeddedDocs = exclude(embeddedDocs, ['equalScalar', 'apply', 'addScalar', 'subtractScalar', 'multiplyScalar', 'print', 'divideScalar', 'parse', 'compile', 'parser', 'chain', 'reviver', 'replacer']);
|
145
145
|
var allTypeChecks = {};
|
146
146
|
Object.keys(allIsFunctions).forEach(function (name) {
|
147
147
|
if (name.indexOf('is') === 0) {
|
package/lib/cjs/utils/string.js
CHANGED
@@ -92,7 +92,7 @@ function _format(value, options) {
|
|
92
92
|
return formatArray(value, options);
|
93
93
|
}
|
94
94
|
if ((0, _is.isString)(value)) {
|
95
|
-
return
|
95
|
+
return stringify(value);
|
96
96
|
}
|
97
97
|
if (typeof value === 'function') {
|
98
98
|
return value.syntax ? String(value.syntax) : 'function';
|
@@ -105,7 +105,7 @@ function _format(value, options) {
|
|
105
105
|
return value.toString(options);
|
106
106
|
} else {
|
107
107
|
var entries = Object.keys(value).map(function (key) {
|
108
|
-
return
|
108
|
+
return stringify(key) + ': ' + format(value[key], options);
|
109
109
|
});
|
110
110
|
return '{' + entries.join(', ') + '}';
|
111
111
|
}
|
@@ -125,24 +125,20 @@ function stringify(value) {
|
|
125
125
|
var i = 0;
|
126
126
|
while (i < text.length) {
|
127
127
|
var c = text.charAt(i);
|
128
|
-
|
129
|
-
escaped += c;
|
130
|
-
i++;
|
131
|
-
c = text.charAt(i);
|
132
|
-
if (c === '' || '"\\/bfnrtu'.indexOf(c) === -1) {
|
133
|
-
escaped += '\\'; // no valid escape character -> escape it
|
134
|
-
}
|
135
|
-
|
136
|
-
escaped += c;
|
137
|
-
} else if (c === '"') {
|
138
|
-
escaped += '\\"';
|
139
|
-
} else {
|
140
|
-
escaped += c;
|
141
|
-
}
|
128
|
+
escaped += c in controlCharacters ? controlCharacters[c] : c;
|
142
129
|
i++;
|
143
130
|
}
|
144
131
|
return '"' + escaped + '"';
|
145
132
|
}
|
133
|
+
var controlCharacters = {
|
134
|
+
'"': '\\"',
|
135
|
+
'\\': '\\\\',
|
136
|
+
'\b': '\\b',
|
137
|
+
'\f': '\\f',
|
138
|
+
'\n': '\\n',
|
139
|
+
'\r': '\\r',
|
140
|
+
'\t': '\\t'
|
141
|
+
};
|
146
142
|
|
147
143
|
/**
|
148
144
|
* Escape special HTML characters
|
package/lib/cjs/version.js
CHANGED
@@ -4,6 +4,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
5
5
|
});
|
6
6
|
exports.version = void 0;
|
7
|
-
var version = exports.version = '11.
|
7
|
+
var version = exports.version = '11.12.0';
|
8
8
|
// Note: This file is automatically generated when building math.js.
|
9
9
|
// Changes made in this file will be overwritten.
|
@@ -6,7 +6,7 @@ import { divideScalarDependencies } from './dependenciesDivideScalar.generated.j
|
|
6
6
|
import { isZeroDependencies } from './dependenciesIsZero.generated.js';
|
7
7
|
import { matrixDependencies } from './dependenciesMatrix.generated.js';
|
8
8
|
import { multiplyDependencies } from './dependenciesMultiply.generated.js';
|
9
|
-
import {
|
9
|
+
import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js';
|
10
10
|
import { typedDependencies } from './dependenciesTyped.generated.js';
|
11
11
|
import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js';
|
12
12
|
import { createDet } from '../../factoriesAny.js';
|
@@ -15,7 +15,7 @@ export var detDependencies = {
|
|
15
15
|
isZeroDependencies,
|
16
16
|
matrixDependencies,
|
17
17
|
multiplyDependencies,
|
18
|
-
|
18
|
+
subtractScalarDependencies,
|
19
19
|
typedDependencies,
|
20
20
|
unaryMinusDependencies,
|
21
21
|
createDet
|
@@ -8,7 +8,7 @@ import { deepEqualDependencies } from './dependenciesDeepEqual.generated.js';
|
|
8
8
|
import { divideScalarDependencies } from './dependenciesDivideScalar.generated.js';
|
9
9
|
import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js';
|
10
10
|
import { sqrtDependencies } from './dependenciesSqrt.generated.js';
|
11
|
-
import {
|
11
|
+
import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js';
|
12
12
|
import { typedDependencies } from './dependenciesTyped.generated.js';
|
13
13
|
import { createDistance } from '../../factoriesAny.js';
|
14
14
|
export var distanceDependencies = {
|
@@ -18,7 +18,7 @@ export var distanceDependencies = {
|
|
18
18
|
divideScalarDependencies,
|
19
19
|
multiplyScalarDependencies,
|
20
20
|
sqrtDependencies,
|
21
|
-
|
21
|
+
subtractScalarDependencies,
|
22
22
|
typedDependencies,
|
23
23
|
createDistance
|
24
24
|
};
|
@@ -7,7 +7,7 @@ import { divideScalarDependencies } from './dependenciesDivideScalar.generated.j
|
|
7
7
|
import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js';
|
8
8
|
import { matrixDependencies } from './dependenciesMatrix.generated.js';
|
9
9
|
import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js';
|
10
|
-
import {
|
10
|
+
import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js';
|
11
11
|
import { typedDependencies } from './dependenciesTyped.generated.js';
|
12
12
|
import { createLsolve } from '../../factoriesAny.js';
|
13
13
|
export var lsolveDependencies = {
|
@@ -16,7 +16,7 @@ export var lsolveDependencies = {
|
|
16
16
|
equalScalarDependencies,
|
17
17
|
matrixDependencies,
|
18
18
|
multiplyScalarDependencies,
|
19
|
-
|
19
|
+
subtractScalarDependencies,
|
20
20
|
typedDependencies,
|
21
21
|
createLsolve
|
22
22
|
};
|
@@ -7,7 +7,7 @@ import { divideScalarDependencies } from './dependenciesDivideScalar.generated.j
|
|
7
7
|
import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js';
|
8
8
|
import { matrixDependencies } from './dependenciesMatrix.generated.js';
|
9
9
|
import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js';
|
10
|
-
import {
|
10
|
+
import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js';
|
11
11
|
import { typedDependencies } from './dependenciesTyped.generated.js';
|
12
12
|
import { createLsolveAll } from '../../factoriesAny.js';
|
13
13
|
export var lsolveAllDependencies = {
|
@@ -16,7 +16,7 @@ export var lsolveAllDependencies = {
|
|
16
16
|
equalScalarDependencies,
|
17
17
|
matrixDependencies,
|
18
18
|
multiplyScalarDependencies,
|
19
|
-
|
19
|
+
subtractScalarDependencies,
|
20
20
|
typedDependencies,
|
21
21
|
createLsolveAll
|
22
22
|
};
|
@@ -12,7 +12,7 @@ import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js'
|
|
12
12
|
import { largerDependencies } from './dependenciesLarger.generated.js';
|
13
13
|
import { matrixDependencies } from './dependenciesMatrix.generated.js';
|
14
14
|
import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js';
|
15
|
-
import {
|
15
|
+
import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js';
|
16
16
|
import { typedDependencies } from './dependenciesTyped.generated.js';
|
17
17
|
import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js';
|
18
18
|
import { createLup } from '../../factoriesAny.js';
|
@@ -27,7 +27,7 @@ export var lupDependencies = {
|
|
27
27
|
largerDependencies,
|
28
28
|
matrixDependencies,
|
29
29
|
multiplyScalarDependencies,
|
30
|
-
|
30
|
+
subtractScalarDependencies,
|
31
31
|
typedDependencies,
|
32
32
|
unaryMinusDependencies,
|
33
33
|
createLup
|
@@ -13,7 +13,7 @@ import { matrixDependencies } from './dependenciesMatrix.generated.js';
|
|
13
13
|
import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js';
|
14
14
|
import { signDependencies } from './dependenciesSign.generated.js';
|
15
15
|
import { sqrtDependencies } from './dependenciesSqrt.generated.js';
|
16
|
-
import {
|
16
|
+
import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js';
|
17
17
|
import { typedDependencies } from './dependenciesTyped.generated.js';
|
18
18
|
import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js';
|
19
19
|
import { zerosDependencies } from './dependenciesZeros.generated.js';
|
@@ -30,7 +30,7 @@ export var qrDependencies = {
|
|
30
30
|
multiplyScalarDependencies,
|
31
31
|
signDependencies,
|
32
32
|
sqrtDependencies,
|
33
|
-
|
33
|
+
subtractScalarDependencies,
|
34
34
|
typedDependencies,
|
35
35
|
unaryMinusDependencies,
|
36
36
|
zerosDependencies,
|
@@ -13,7 +13,7 @@ import { largerDependencies } from './dependenciesLarger.generated.js';
|
|
13
13
|
import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generated.js';
|
14
14
|
import { numberDependencies } from './dependenciesNumber.generated.js';
|
15
15
|
import { powDependencies } from './dependenciesPow.generated.js';
|
16
|
-
import {
|
16
|
+
import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js';
|
17
17
|
import { typedDependencies } from './dependenciesTyped.generated.js';
|
18
18
|
import { createStirlingS2 } from '../../factoriesAny.js';
|
19
19
|
export var stirlingS2Dependencies = {
|
@@ -28,7 +28,7 @@ export var stirlingS2Dependencies = {
|
|
28
28
|
multiplyScalarDependencies,
|
29
29
|
numberDependencies,
|
30
30
|
powDependencies,
|
31
|
-
|
31
|
+
subtractScalarDependencies,
|
32
32
|
typedDependencies,
|
33
33
|
createStirlingS2
|
34
34
|
};
|
@@ -3,19 +3,19 @@
|
|
3
3
|
* DON'T MAKE CHANGES HERE
|
4
4
|
*/
|
5
5
|
import { DenseMatrixDependencies } from './dependenciesDenseMatrixClass.generated.js';
|
6
|
-
import { addScalarDependencies } from './dependenciesAddScalar.generated.js';
|
7
6
|
import { concatDependencies } from './dependenciesConcat.generated.js';
|
8
7
|
import { equalScalarDependencies } from './dependenciesEqualScalar.generated.js';
|
9
8
|
import { matrixDependencies } from './dependenciesMatrix.generated.js';
|
9
|
+
import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js';
|
10
10
|
import { typedDependencies } from './dependenciesTyped.generated.js';
|
11
11
|
import { unaryMinusDependencies } from './dependenciesUnaryMinus.generated.js';
|
12
12
|
import { createSubtract } from '../../factoriesAny.js';
|
13
13
|
export var subtractDependencies = {
|
14
14
|
DenseMatrixDependencies,
|
15
|
-
addScalarDependencies,
|
16
15
|
concatDependencies,
|
17
16
|
equalScalarDependencies,
|
18
17
|
matrixDependencies,
|
18
|
+
subtractScalarDependencies,
|
19
19
|
typedDependencies,
|
20
20
|
unaryMinusDependencies,
|
21
21
|
createSubtract
|
@@ -0,0 +1,10 @@
|
|
1
|
+
/**
|
2
|
+
* THIS FILE IS AUTO-GENERATED
|
3
|
+
* DON'T MAKE CHANGES HERE
|
4
|
+
*/
|
5
|
+
import { typedDependencies } from './dependenciesTyped.generated.js';
|
6
|
+
import { createSubtractScalar } from '../../factoriesAny.js';
|
7
|
+
export var subtractScalarDependencies = {
|
8
|
+
typedDependencies,
|
9
|
+
createSubtractScalar
|
10
|
+
};
|
@@ -16,7 +16,7 @@ import { multiplyScalarDependencies } from './dependenciesMultiplyScalar.generat
|
|
16
16
|
import { numberDependencies } from './dependenciesNumber.generated.js';
|
17
17
|
import { powDependencies } from './dependenciesPow.generated.js';
|
18
18
|
import { roundDependencies } from './dependenciesRound.generated.js';
|
19
|
-
import {
|
19
|
+
import { subtractScalarDependencies } from './dependenciesSubtractScalar.generated.js';
|
20
20
|
import { createUnitClass } from '../../factoriesAny.js';
|
21
21
|
export var UnitDependencies = {
|
22
22
|
BigNumberDependencies,
|
@@ -33,6 +33,6 @@ export var UnitDependencies = {
|
|
33
33
|
numberDependencies,
|
34
34
|
powDependencies,
|
35
35
|
roundDependencies,
|
36
|
-
|
36
|
+
subtractScalarDependencies,
|
37
37
|
createUnitClass
|
38
38
|
};
|