feat:node-modules
This commit is contained in:
121
node_modules/mathjs/lib/cjs/function/algebra/solver/utils/solveValidation.js
generated
vendored
Normal file
121
node_modules/mathjs/lib/cjs/function/algebra/solver/utils/solveValidation.js
generated
vendored
Normal file
@@ -0,0 +1,121 @@
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.createSolveValidation = createSolveValidation;
|
||||
var _is = require("../../../../utils/is.js");
|
||||
var _array = require("../../../../utils/array.js");
|
||||
var _string = require("../../../../utils/string.js");
|
||||
function createSolveValidation(_ref) {
|
||||
let {
|
||||
DenseMatrix
|
||||
} = _ref;
|
||||
/**
|
||||
* Validates matrix and column vector b for backward/forward substitution algorithms.
|
||||
*
|
||||
* @param {Matrix} m An N x N matrix
|
||||
* @param {Array | Matrix} b A column vector
|
||||
* @param {Boolean} copy Return a copy of vector b
|
||||
*
|
||||
* @return {DenseMatrix} Dense column vector b
|
||||
*/
|
||||
return function solveValidation(m, b, copy) {
|
||||
const mSize = m.size();
|
||||
if (mSize.length !== 2) {
|
||||
throw new RangeError('Matrix must be two dimensional (size: ' + (0, _string.format)(mSize) + ')');
|
||||
}
|
||||
const rows = mSize[0];
|
||||
const columns = mSize[1];
|
||||
if (rows !== columns) {
|
||||
throw new RangeError('Matrix must be square (size: ' + (0, _string.format)(mSize) + ')');
|
||||
}
|
||||
let data = [];
|
||||
if ((0, _is.isMatrix)(b)) {
|
||||
const bSize = b.size();
|
||||
const bdata = b._data;
|
||||
|
||||
// 1-dim vector
|
||||
if (bSize.length === 1) {
|
||||
if (bSize[0] !== rows) {
|
||||
throw new RangeError('Dimension mismatch. Matrix columns must match vector length.');
|
||||
}
|
||||
for (let i = 0; i < rows; i++) {
|
||||
data[i] = [bdata[i]];
|
||||
}
|
||||
return new DenseMatrix({
|
||||
data,
|
||||
size: [rows, 1],
|
||||
datatype: b._datatype
|
||||
});
|
||||
}
|
||||
|
||||
// 2-dim column
|
||||
if (bSize.length === 2) {
|
||||
if (bSize[0] !== rows || bSize[1] !== 1) {
|
||||
throw new RangeError('Dimension mismatch. Matrix columns must match vector length.');
|
||||
}
|
||||
if ((0, _is.isDenseMatrix)(b)) {
|
||||
if (copy) {
|
||||
data = [];
|
||||
for (let i = 0; i < rows; i++) {
|
||||
data[i] = [bdata[i][0]];
|
||||
}
|
||||
return new DenseMatrix({
|
||||
data,
|
||||
size: [rows, 1],
|
||||
datatype: b._datatype
|
||||
});
|
||||
}
|
||||
return b;
|
||||
}
|
||||
if ((0, _is.isSparseMatrix)(b)) {
|
||||
for (let i = 0; i < rows; i++) {
|
||||
data[i] = [0];
|
||||
}
|
||||
const values = b._values;
|
||||
const index = b._index;
|
||||
const ptr = b._ptr;
|
||||
for (let k1 = ptr[1], k = ptr[0]; k < k1; k++) {
|
||||
const i = index[k];
|
||||
data[i][0] = values[k];
|
||||
}
|
||||
return new DenseMatrix({
|
||||
data,
|
||||
size: [rows, 1],
|
||||
datatype: b._datatype
|
||||
});
|
||||
}
|
||||
}
|
||||
throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.');
|
||||
}
|
||||
if ((0, _is.isArray)(b)) {
|
||||
const bsize = (0, _array.arraySize)(b);
|
||||
if (bsize.length === 1) {
|
||||
if (bsize[0] !== rows) {
|
||||
throw new RangeError('Dimension mismatch. Matrix columns must match vector length.');
|
||||
}
|
||||
for (let i = 0; i < rows; i++) {
|
||||
data[i] = [b[i]];
|
||||
}
|
||||
return new DenseMatrix({
|
||||
data,
|
||||
size: [rows, 1]
|
||||
});
|
||||
}
|
||||
if (bsize.length === 2) {
|
||||
if (bsize[0] !== rows || bsize[1] !== 1) {
|
||||
throw new RangeError('Dimension mismatch. Matrix columns must match vector length.');
|
||||
}
|
||||
for (let i = 0; i < rows; i++) {
|
||||
data[i] = [b[i][0]];
|
||||
}
|
||||
return new DenseMatrix({
|
||||
data,
|
||||
size: [rows, 1]
|
||||
});
|
||||
}
|
||||
throw new RangeError('Dimension mismatch. The right side has to be either 1- or 2-dimensional vector.');
|
||||
}
|
||||
};
|
||||
}
|
||||
Reference in New Issue
Block a user