{"version":3,"file":"ml-gsd.esm.js","sources":["../node_modules/is-any-array/lib-esm/index.js","../node_modules/ml-savitzky-golay-generalized/lib-esm/index.js","../node_modules/ml-spectra-processing/lib/x/xMedian.js","../node_modules/ml-spectra-processing/lib/x/xCheck.js","../node_modules/ml-spectra-processing/lib/x/xFindClosestIndex.js","../node_modules/ml-spectra-processing/lib/x/xGetFromToIndex.js","../node_modules/ml-array-max/lib-es6/index.js","../node_modules/ml-array-min/lib-es6/index.js","../node_modules/ml-array-rescale/lib-es6/index.js","../node_modules/ml-matrix/matrix.js","../node_modules/ml-matrix/matrix.mjs","../node_modules/ml-spectra-processing/lib/x/xMaxValue.js","../node_modules/ml-spectra-processing/lib/x/xMinValue.js","../node_modules/ml-spectra-processing/lib/x/xIsEquallySpaced.js","../node_modules/ml-spectra-processing/lib/x/xIsMonotonic.js","../node_modules/ml-spectra-processing/lib/x/xMedianAbsoluteDeviation.js","../node_modules/ml-spectra-processing/lib/x/xMinMaxValues.js","../node_modules/ml-spectra-processing/lib/x/xNoiseStandardDeviation.js","../node_modules/ml-spectra-processing/lib/x/xNorm.js","../lib/algorithms/getMinMaxIntervals.js","../lib/algorithms/tryMatchOneIntervalWithMinData.js","../lib/algorithms/autoAlgorithm.js","../lib/algorithms/getPeaksFromIntervals.js","../lib/algorithms/xGetCrossZeroPoints.js","../lib/algorithms/firstDerivative.js","../lib/algorithms/secondDerivative.js","../lib/utils/optimizeTop.js","../lib/gsd.js","../node_modules/ml-peak-shape-generator/lib-esm/util/constants.js","../node_modules/ml-peak-shape-generator/lib-esm/util/erfinv.js","../node_modules/ml-peak-shape-generator/lib-esm/shapes/1d/gaussian/Gaussian.js","../node_modules/ml-peak-shape-generator/lib-esm/shapes/1d/lorentzian/Lorentzian.js","../node_modules/ml-peak-shape-generator/lib-esm/shapes/1d/lorentzianDispersive/LorentzianDispersive.js","../node_modules/ml-peak-shape-generator/lib-esm/shapes/1d/pseudoVoigt/PseudoVoigt.js","../node_modules/ml-peak-shape-generator/lib-esm/shapes/1d/generalizedLorentzian/GeneralizedLorentzian.js","../node_modules/ml-peak-shape-generator/lib-esm/shapes/1d/getShape1D.js","../node_modules/ml-spectra-fitting/lib/shapes/getSumOfShapes.js","../node_modules/ml-spectra-fitting/lib/util/assert.js","../node_modules/ml-spectra-fitting/lib/util/internalPeaks/DefaultParameters.js","../node_modules/ml-spectra-fitting/lib/util/internalPeaks/getInternalPeaks.js","../node_modules/ml-levenberg-marquardt/lib/check_options.js","../node_modules/ml-levenberg-marquardt/lib/error_calculation.js","../node_modules/ml-levenberg-marquardt/lib/gradient_function.js","../node_modules/ml-levenberg-marquardt/lib/step.js","../node_modules/ml-levenberg-marquardt/lib/levenberg_marquardt.js","../node_modules/ml-direct/src/util/antiLowerConvexHull.js","../node_modules/ml-direct/src/index.js","../node_modules/ml-spectra-fitting/lib/util/wrappers/directOptimization.js","../node_modules/ml-spectra-fitting/lib/util/selectMethod.js","../node_modules/ml-spectra-fitting/lib/index.js","../lib/utils/addMissingShape.js","../lib/utils/groupPeaks.js","../lib/post/optimizePeaksWithLogs.js","../lib/post/optimizePeaks.js","../lib/utils/addMissingIDs.js","../lib/post/joinBroadPeaks.js","../lib/post/broadenPeaks.js","../lib/utils/setShape.js"],"sourcesContent":["// eslint-disable-next-line @typescript-eslint/unbound-method\nconst toString = Object.prototype.toString;\n/**\n * Checks if an object is an instance of an Array (array or typed array, except those that contain bigint values).\n *\n * @param value - Object to check.\n * @returns True if the object is an array or a typed array.\n */\nexport function isAnyArray(value) {\n    const tag = toString.call(value);\n    return tag.endsWith('Array]') && !tag.includes('Big');\n}\n//# sourceMappingURL=index.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * Apply Savitzky Golay algorithm\n * @param [ys] Array of y values\n * @param [xs] Array of X or deltaX\n * @return  Array containing the new ys (same length)\n */\nexport function sgg(ys, xs, options = {}) {\n    const { windowSize = 9, derivative = 0, polynomial = 3 } = options;\n    if (windowSize % 2 === 0 || windowSize < 5 || !Number.isInteger(windowSize)) {\n        throw new RangeError('Invalid window size (should be odd and at least 5 integer number)');\n    }\n    if (!isAnyArray(ys)) {\n        throw new TypeError('Y values must be an array');\n    }\n    if (typeof xs === 'undefined') {\n        throw new TypeError('X must be defined');\n    }\n    if (windowSize > ys.length) {\n        throw new RangeError(`Window size is higher than the data length ${windowSize}>${ys.length}`);\n    }\n    if (derivative < 0 || !Number.isInteger(derivative)) {\n        throw new RangeError('Derivative should be a positive integer');\n    }\n    if (polynomial < 1 || !Number.isInteger(polynomial)) {\n        throw new RangeError('Polynomial should be a positive integer');\n    }\n    if (polynomial >= 6) {\n        // eslint-disable-next-line no-console\n        console.warn('You should not use polynomial grade higher than 5 if you are' +\n            ' not sure that your data arises from such a model. Possible polynomial oscillation problems');\n    }\n    const half = Math.floor(windowSize / 2);\n    const np = ys.length;\n    const ans = new Float64Array(np);\n    const weights = fullWeights(windowSize, polynomial, derivative);\n    let hs = 0;\n    let constantH = true;\n    if (isAnyArray(xs)) {\n        constantH = false;\n    }\n    else {\n        hs = xs ** derivative;\n    }\n    //For the borders\n    for (let i = 0; i < half; i++) {\n        const wg1 = weights[half - i - 1];\n        const wg2 = weights[half + i + 1];\n        let d1 = 0;\n        let d2 = 0;\n        for (let l = 0; l < windowSize; l++) {\n            d1 += wg1[l] * ys[l];\n            d2 += wg2[l] * ys[np - windowSize + l];\n        }\n        if (constantH) {\n            ans[half - i - 1] = d1 / hs;\n            ans[np - half + i] = d2 / hs;\n        }\n        else {\n            hs = getHs(xs, half - i - 1, half, derivative);\n            ans[half - i - 1] = d1 / hs;\n            hs = getHs(xs, np - half + i, half, derivative);\n            ans[np - half + i] = d2 / hs;\n        }\n    }\n    //For the internal points\n    const wg = weights[half];\n    for (let i = windowSize; i <= np; i++) {\n        let d = 0;\n        for (let l = 0; l < windowSize; l++)\n            d += wg[l] * ys[l + i - windowSize];\n        if (!constantH) {\n            hs = getHs(xs, i - half - 1, half, derivative);\n        }\n        ans[i - half - 1] = d / hs;\n    }\n    return ans;\n}\nfunction getHs(h, center, half, derivative) {\n    let hs = 0;\n    let count = 0;\n    for (let i = center - half; i < center + half; i++) {\n        if (i >= 0 && i < h.length - 1) {\n            hs += h[i + 1] - h[i];\n            count++;\n        }\n    }\n    return (hs / count) ** derivative;\n}\nfunction gramPoly(i, m, k, s) {\n    let Grampoly = 0;\n    if (k > 0) {\n        Grampoly =\n            ((4 * k - 2) / (k * (2 * m - k + 1))) *\n                (i * gramPoly(i, m, k - 1, s) + s * gramPoly(i, m, k - 1, s - 1)) -\n                (((k - 1) * (2 * m + k)) / (k * (2 * m - k + 1))) *\n                    gramPoly(i, m, k - 2, s);\n    }\n    else if (k === 0 && s === 0) {\n        Grampoly = 1;\n    }\n    else {\n        Grampoly = 0;\n    }\n    return Grampoly;\n}\nfunction genFact(a, b) {\n    let gf = 1;\n    if (a >= b) {\n        for (let j = a - b + 1; j <= a; j++) {\n            gf *= j;\n        }\n    }\n    return gf;\n}\nfunction weight(i, t, m, n, s) {\n    let sum = 0;\n    for (let k = 0; k <= n; k++) {\n        sum +=\n            (2 * k + 1) *\n                (genFact(2 * m, k) / genFact(2 * m + k + 1, k + 1)) *\n                gramPoly(i, m, k, 0) *\n                gramPoly(t, m, k, s);\n    }\n    return sum;\n}\n/**\n * @private\n * @param m  Number of points\n * @param n  Polynomial grade\n * @param s  Derivative\n */\nfunction fullWeights(m, n, s) {\n    const weights = new Array(m);\n    const np = Math.floor(m / 2);\n    for (let t = -np; t <= np; t++) {\n        weights[t + np] = new Float64Array(m);\n        for (let j = -np; j <= np; j++) {\n            weights[t + np][j + np] = weight(j, t, np, n, s);\n        }\n    }\n    return weights;\n}\n//# sourceMappingURL=index.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * Calculates the median of an array.\n * @param input - Array containing values\n * @param options\n * @returns - median\n */\nexport function xMedian(input, options = {}) {\n    if (!isAnyArray(input)) {\n        throw new TypeError('input must be an array');\n    }\n    if (input.length === 0) {\n        throw new TypeError('input must not be empty');\n    }\n    const { exact = false } = options || {};\n    const array = input.slice();\n    const middleIndex = calcMiddle(0, array.length - 1);\n    const median = quickSelect(array, middleIndex);\n    if (array.length % 2 === 1 || !exact) {\n        return median;\n    }\n    const medianNext = quickSelect(array, middleIndex + 1);\n    return (median + medianNext) / 2;\n}\nfunction quickSelect(array, middleIndex) {\n    let low = 0;\n    let high = array.length - 1;\n    let middle = 0;\n    let currentLow = 0;\n    let currentHigh = 0;\n    while (true) {\n        if (high <= low) {\n            return array[middleIndex];\n        }\n        if (high === low + 1) {\n            if (array[low] > array[high]) {\n                swap(array, low, high);\n            }\n            return array[middleIndex];\n        }\n        // Find median of low, middle and high items; swap into position low\n        middle = calcMiddle(low, high);\n        if (array[middle] > array[high])\n            swap(array, middle, high);\n        if (array[low] > array[high])\n            swap(array, low, high);\n        if (array[middle] > array[low])\n            swap(array, middle, low);\n        // Swap low item (now in position middle) into position (low+1)\n        swap(array, middle, low + 1);\n        // Nibble from each end towards middle, swapping items when stuck\n        currentLow = low + 1;\n        currentHigh = high;\n        while (true) {\n            do\n                currentLow++;\n            while (array[low] > array[currentLow]);\n            do\n                currentHigh--;\n            while (array[currentHigh] > array[low]);\n            if (currentHigh < currentLow) {\n                break;\n            }\n            swap(array, currentLow, currentHigh);\n        }\n        // Swap middle item (in position low) back into correct position\n        swap(array, low, currentHigh);\n        // Re-set active partition\n        if (currentHigh <= middleIndex) {\n            low = currentLow;\n        }\n        if (currentHigh >= middleIndex) {\n            high = currentHigh - 1;\n        }\n    }\n}\nfunction swap(array, i, j) {\n    const temp = array[j];\n    array[j] = array[i];\n    array[i] = temp;\n}\nfunction calcMiddle(i, j) {\n    return Math.floor((i + j) / 2);\n}\n//# sourceMappingURL=xMedian.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * Checks if the input is a non-empty array of numbers.\n * Only checks the first element.\n * @param input - Array to check.\n * @param options - Additional checks.\n */\nexport function xCheck(input, options = {}) {\n    const { minLength } = options;\n    if (!isAnyArray(input)) {\n        throw new TypeError('input must be an array');\n    }\n    if (input.length === 0) {\n        throw new TypeError('input must not be empty');\n    }\n    if (typeof input[0] !== 'number') {\n        throw new TypeError('input must contain numbers');\n    }\n    if (minLength && input.length < minLength) {\n        throw new Error(`input must have a length of at least ${minLength}`);\n    }\n}\n//# sourceMappingURL=xCheck.js.map","/**\n * Returns the closest index of a `target`\n * @param array - array of numbers\n * @param target - target\n * @param options\n * @returns - closest index\n */\nexport function xFindClosestIndex(array, target, options = {}) {\n    const { sorted = true } = options;\n    if (sorted) {\n        let low = 0;\n        let high = array.length - 1;\n        let middle = 0;\n        while (high - low > 1) {\n            middle = low + ((high - low) >> 1);\n            if (array[middle] < target) {\n                low = middle;\n            }\n            else if (array[middle] > target) {\n                high = middle;\n            }\n            else {\n                return middle;\n            }\n        }\n        if (low < array.length - 1) {\n            if (Math.abs(target - array[low]) < Math.abs(array[low + 1] - target)) {\n                return low;\n            }\n            else {\n                return low + 1;\n            }\n        }\n        else {\n            return low;\n        }\n    }\n    else {\n        let index = 0;\n        let diff = Number.POSITIVE_INFINITY;\n        for (let i = 0; i < array.length; i++) {\n            const currentDiff = Math.abs(array[i] - target);\n            if (currentDiff < diff) {\n                diff = currentDiff;\n                index = i;\n            }\n        }\n        return index;\n    }\n}\n//# sourceMappingURL=xFindClosestIndex.js.map","import { xFindClosestIndex } from \"./xFindClosestIndex.js\";\n/**\n * Returns an object with {fromIndex, toIndex} for a specific from / to\n * @param x - array of numbers\n * @param options - Options\n */\nexport function xGetFromToIndex(x, options = {}) {\n    let { fromIndex, toIndex } = options;\n    const { from, to } = options;\n    if (fromIndex === undefined) {\n        if (from !== undefined) {\n            fromIndex = xFindClosestIndex(x, from);\n        }\n        else {\n            fromIndex = 0;\n        }\n    }\n    if (toIndex === undefined) {\n        if (to !== undefined) {\n            toIndex = xFindClosestIndex(x, to);\n        }\n        else {\n            toIndex = x.length - 1;\n        }\n    }\n    if (fromIndex < 0)\n        fromIndex = 0;\n    if (toIndex < 0)\n        toIndex = 0;\n    if (fromIndex >= x.length)\n        fromIndex = x.length - 1;\n    if (toIndex >= x.length)\n        toIndex = x.length - 1;\n    if (fromIndex > toIndex)\n        [fromIndex, toIndex] = [toIndex, fromIndex];\n    return { fromIndex, toIndex };\n}\n//# sourceMappingURL=xGetFromToIndex.js.map","import { isAnyArray } from 'is-any-array';\n\nfunction max(input) {\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  }\n\n  if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  var _options$fromIndex = options.fromIndex,\n      fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n      _options$toIndex = options.toIndex,\n      toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n  if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n    throw new Error('fromIndex must be a positive integer smaller than length');\n  }\n\n  if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n    throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n  }\n\n  var maxValue = input[fromIndex];\n\n  for (var i = fromIndex + 1; i < toIndex; i++) {\n    if (input[i] > maxValue) maxValue = input[i];\n  }\n\n  return maxValue;\n}\n\nexport { max as default };\n","import { isAnyArray } from 'is-any-array';\n\nfunction min(input) {\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  }\n\n  if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  var _options$fromIndex = options.fromIndex,\n      fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n      _options$toIndex = options.toIndex,\n      toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n  if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n    throw new Error('fromIndex must be a positive integer smaller than length');\n  }\n\n  if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n    throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n  }\n\n  var minValue = input[fromIndex];\n\n  for (var i = fromIndex + 1; i < toIndex; i++) {\n    if (input[i] < minValue) minValue = input[i];\n  }\n\n  return minValue;\n}\n\nexport { min as default };\n","import { isAnyArray } from 'is-any-array';\nimport max from 'ml-array-max';\nimport min from 'ml-array-min';\n\nfunction rescale(input) {\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  } else if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  var output;\n\n  if (options.output !== undefined) {\n    if (!isAnyArray(options.output)) {\n      throw new TypeError('output option must be an array if specified');\n    }\n\n    output = options.output;\n  } else {\n    output = new Array(input.length);\n  }\n\n  var currentMin = min(input);\n  var currentMax = max(input);\n\n  if (currentMin === currentMax) {\n    throw new RangeError('minimum and maximum input values are equal. Cannot rescale a constant array');\n  }\n\n  var _options$min = options.min,\n      minValue = _options$min === void 0 ? options.autoMinMax ? currentMin : 0 : _options$min,\n      _options$max = options.max,\n      maxValue = _options$max === void 0 ? options.autoMinMax ? currentMax : 1 : _options$max;\n\n  if (minValue >= maxValue) {\n    throw new RangeError('min option must be smaller than max option');\n  }\n\n  var factor = (maxValue - minValue) / (currentMax - currentMin);\n\n  for (var i = 0; i < input.length; i++) {\n    output[i] = (input[i] - currentMin) * factor + minValue;\n  }\n\n  return output;\n}\n\nexport { rescale as default };\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar isAnyArray = require('is-any-array');\nvar rescale = require('ml-array-rescale');\n\nconst indent = ' '.repeat(2);\nconst indentData = ' '.repeat(4);\n\n/**\n * @this {Matrix}\n * @returns {string}\n */\nfunction inspectMatrix() {\n  return inspectMatrixWithOptions(this);\n}\n\nfunction inspectMatrixWithOptions(matrix, options = {}) {\n  const {\n    maxRows = 15,\n    maxColumns = 10,\n    maxNumSize = 8,\n    padMinus = 'auto',\n  } = options;\n  return `${matrix.constructor.name} {\n${indent}[\n${indentData}${inspectData(matrix, maxRows, maxColumns, maxNumSize, padMinus)}\n${indent}]\n${indent}rows: ${matrix.rows}\n${indent}columns: ${matrix.columns}\n}`;\n}\n\nfunction inspectData(matrix, maxRows, maxColumns, maxNumSize, padMinus) {\n  const { rows, columns } = matrix;\n  const maxI = Math.min(rows, maxRows);\n  const maxJ = Math.min(columns, maxColumns);\n  const result = [];\n\n  if (padMinus === 'auto') {\n    padMinus = false;\n    loop: for (let i = 0; i < maxI; i++) {\n      for (let j = 0; j < maxJ; j++) {\n        if (matrix.get(i, j) < 0) {\n          padMinus = true;\n          break loop;\n        }\n      }\n    }\n  }\n\n  for (let i = 0; i < maxI; i++) {\n    let line = [];\n    for (let j = 0; j < maxJ; j++) {\n      line.push(formatNumber(matrix.get(i, j), maxNumSize, padMinus));\n    }\n    result.push(`${line.join(' ')}`);\n  }\n  if (maxJ !== columns) {\n    result[result.length - 1] += ` ... ${columns - maxColumns} more columns`;\n  }\n  if (maxI !== rows) {\n    result.push(`... ${rows - maxRows} more rows`);\n  }\n  return result.join(`\\n${indentData}`);\n}\n\nfunction formatNumber(num, maxNumSize, padMinus) {\n  return (\n    num >= 0 && padMinus\n      ? ` ${formatNumber2(num, maxNumSize - 1)}`\n      : formatNumber2(num, maxNumSize)\n  ).padEnd(maxNumSize);\n}\n\nfunction formatNumber2(num, len) {\n  // small.length numbers should be as is\n  let str = num.toString();\n  if (str.length <= len) return str;\n\n  // (7)'0.00123' is better then (7)'1.23e-2'\n  // (8)'0.000123' is worse then (7)'1.23e-3',\n  let fix = num.toFixed(len);\n  if (fix.length > len) {\n    fix = num.toFixed(Math.max(0, len - (fix.length - len)));\n  }\n  if (\n    fix.length <= len &&\n    !fix.startsWith('0.000') &&\n    !fix.startsWith('-0.000')\n  ) {\n    return fix;\n  }\n\n  // well, if it's still too long the user should've used longer numbers\n  let exp = num.toExponential(len);\n  if (exp.length > len) {\n    exp = num.toExponential(Math.max(0, len - (exp.length - len)));\n  }\n  return exp.slice(0);\n}\n\nfunction installMathOperations(AbstractMatrix, Matrix) {\n  AbstractMatrix.prototype.add = function add(value) {\n    if (typeof value === 'number') return this.addS(value);\n    return this.addM(value);\n  };\n\n  AbstractMatrix.prototype.addS = function addS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.addM = function addM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.add = function add(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.add(value);\n  };\n\n  AbstractMatrix.prototype.sub = function sub(value) {\n    if (typeof value === 'number') return this.subS(value);\n    return this.subM(value);\n  };\n\n  AbstractMatrix.prototype.subS = function subS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.subM = function subM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sub = function sub(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sub(value);\n  };\n  AbstractMatrix.prototype.subtract = AbstractMatrix.prototype.sub;\n  AbstractMatrix.prototype.subtractS = AbstractMatrix.prototype.subS;\n  AbstractMatrix.prototype.subtractM = AbstractMatrix.prototype.subM;\n  AbstractMatrix.subtract = AbstractMatrix.sub;\n\n  AbstractMatrix.prototype.mul = function mul(value) {\n    if (typeof value === 'number') return this.mulS(value);\n    return this.mulM(value);\n  };\n\n  AbstractMatrix.prototype.mulS = function mulS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.mulM = function mulM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.mul = function mul(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.mul(value);\n  };\n  AbstractMatrix.prototype.multiply = AbstractMatrix.prototype.mul;\n  AbstractMatrix.prototype.multiplyS = AbstractMatrix.prototype.mulS;\n  AbstractMatrix.prototype.multiplyM = AbstractMatrix.prototype.mulM;\n  AbstractMatrix.multiply = AbstractMatrix.mul;\n\n  AbstractMatrix.prototype.div = function div(value) {\n    if (typeof value === 'number') return this.divS(value);\n    return this.divM(value);\n  };\n\n  AbstractMatrix.prototype.divS = function divS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.divM = function divM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.div = function div(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.div(value);\n  };\n  AbstractMatrix.prototype.divide = AbstractMatrix.prototype.div;\n  AbstractMatrix.prototype.divideS = AbstractMatrix.prototype.divS;\n  AbstractMatrix.prototype.divideM = AbstractMatrix.prototype.divM;\n  AbstractMatrix.divide = AbstractMatrix.div;\n\n  AbstractMatrix.prototype.mod = function mod(value) {\n    if (typeof value === 'number') return this.modS(value);\n    return this.modM(value);\n  };\n\n  AbstractMatrix.prototype.modS = function modS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) % value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.modM = function modM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) % matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.mod = function mod(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.mod(value);\n  };\n  AbstractMatrix.prototype.modulus = AbstractMatrix.prototype.mod;\n  AbstractMatrix.prototype.modulusS = AbstractMatrix.prototype.modS;\n  AbstractMatrix.prototype.modulusM = AbstractMatrix.prototype.modM;\n  AbstractMatrix.modulus = AbstractMatrix.mod;\n\n  AbstractMatrix.prototype.and = function and(value) {\n    if (typeof value === 'number') return this.andS(value);\n    return this.andM(value);\n  };\n\n  AbstractMatrix.prototype.andS = function andS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) & value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.andM = function andM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) & matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.and = function and(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.and(value);\n  };\n\n  AbstractMatrix.prototype.or = function or(value) {\n    if (typeof value === 'number') return this.orS(value);\n    return this.orM(value);\n  };\n\n  AbstractMatrix.prototype.orS = function orS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) | value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.orM = function orM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) | matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.or = function or(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.or(value);\n  };\n\n  AbstractMatrix.prototype.xor = function xor(value) {\n    if (typeof value === 'number') return this.xorS(value);\n    return this.xorM(value);\n  };\n\n  AbstractMatrix.prototype.xorS = function xorS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ^ value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.xorM = function xorM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ^ matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.xor = function xor(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.xor(value);\n  };\n\n  AbstractMatrix.prototype.leftShift = function leftShift(value) {\n    if (typeof value === 'number') return this.leftShiftS(value);\n    return this.leftShiftM(value);\n  };\n\n  AbstractMatrix.prototype.leftShiftS = function leftShiftS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) << value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.leftShiftM = function leftShiftM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) << matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.leftShift = function leftShift(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.leftShift(value);\n  };\n\n  AbstractMatrix.prototype.signPropagatingRightShift = function signPropagatingRightShift(value) {\n    if (typeof value === 'number') return this.signPropagatingRightShiftS(value);\n    return this.signPropagatingRightShiftM(value);\n  };\n\n  AbstractMatrix.prototype.signPropagatingRightShiftS = function signPropagatingRightShiftS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >> value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.signPropagatingRightShiftM = function signPropagatingRightShiftM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >> matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.signPropagatingRightShift = function signPropagatingRightShift(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.signPropagatingRightShift(value);\n  };\n\n  AbstractMatrix.prototype.rightShift = function rightShift(value) {\n    if (typeof value === 'number') return this.rightShiftS(value);\n    return this.rightShiftM(value);\n  };\n\n  AbstractMatrix.prototype.rightShiftS = function rightShiftS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >>> value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.rightShiftM = function rightShiftM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >>> matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.rightShift = function rightShift(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.rightShift(value);\n  };\n  AbstractMatrix.prototype.zeroFillRightShift = AbstractMatrix.prototype.rightShift;\n  AbstractMatrix.prototype.zeroFillRightShiftS = AbstractMatrix.prototype.rightShiftS;\n  AbstractMatrix.prototype.zeroFillRightShiftM = AbstractMatrix.prototype.rightShiftM;\n  AbstractMatrix.zeroFillRightShift = AbstractMatrix.rightShift;\n\n  AbstractMatrix.prototype.not = function not() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, ~(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.not = function not(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.not();\n  };\n\n  AbstractMatrix.prototype.abs = function abs() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.abs(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.abs = function abs(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.abs();\n  };\n\n  AbstractMatrix.prototype.acos = function acos() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.acos(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.acos = function acos(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.acos();\n  };\n\n  AbstractMatrix.prototype.acosh = function acosh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.acosh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.acosh = function acosh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.acosh();\n  };\n\n  AbstractMatrix.prototype.asin = function asin() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.asin(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.asin = function asin(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.asin();\n  };\n\n  AbstractMatrix.prototype.asinh = function asinh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.asinh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.asinh = function asinh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.asinh();\n  };\n\n  AbstractMatrix.prototype.atan = function atan() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.atan(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.atan = function atan(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.atan();\n  };\n\n  AbstractMatrix.prototype.atanh = function atanh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.atanh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.atanh = function atanh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.atanh();\n  };\n\n  AbstractMatrix.prototype.cbrt = function cbrt() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.cbrt(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.cbrt = function cbrt(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.cbrt();\n  };\n\n  AbstractMatrix.prototype.ceil = function ceil() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.ceil(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.ceil = function ceil(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.ceil();\n  };\n\n  AbstractMatrix.prototype.clz32 = function clz32() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.clz32(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.clz32 = function clz32(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.clz32();\n  };\n\n  AbstractMatrix.prototype.cos = function cos() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.cos(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.cos = function cos(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.cos();\n  };\n\n  AbstractMatrix.prototype.cosh = function cosh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.cosh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.cosh = function cosh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.cosh();\n  };\n\n  AbstractMatrix.prototype.exp = function exp() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.exp(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.exp = function exp(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.exp();\n  };\n\n  AbstractMatrix.prototype.expm1 = function expm1() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.expm1(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.expm1 = function expm1(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.expm1();\n  };\n\n  AbstractMatrix.prototype.floor = function floor() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.floor(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.floor = function floor(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.floor();\n  };\n\n  AbstractMatrix.prototype.fround = function fround() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.fround(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.fround = function fround(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.fround();\n  };\n\n  AbstractMatrix.prototype.log = function log() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log = function log(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log();\n  };\n\n  AbstractMatrix.prototype.log1p = function log1p() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log1p(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log1p = function log1p(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log1p();\n  };\n\n  AbstractMatrix.prototype.log10 = function log10() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log10(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log10 = function log10(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log10();\n  };\n\n  AbstractMatrix.prototype.log2 = function log2() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log2(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log2 = function log2(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log2();\n  };\n\n  AbstractMatrix.prototype.round = function round() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.round(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.round = function round(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.round();\n  };\n\n  AbstractMatrix.prototype.sign = function sign() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sign(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sign = function sign(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sign();\n  };\n\n  AbstractMatrix.prototype.sin = function sin() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sin(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sin = function sin(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sin();\n  };\n\n  AbstractMatrix.prototype.sinh = function sinh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sinh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sinh = function sinh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sinh();\n  };\n\n  AbstractMatrix.prototype.sqrt = function sqrt() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sqrt(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sqrt = function sqrt(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sqrt();\n  };\n\n  AbstractMatrix.prototype.tan = function tan() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.tan(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.tan = function tan(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.tan();\n  };\n\n  AbstractMatrix.prototype.tanh = function tanh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.tanh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.tanh = function tanh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.tanh();\n  };\n\n  AbstractMatrix.prototype.trunc = function trunc() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.trunc(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.trunc = function trunc(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.trunc();\n  };\n\n  AbstractMatrix.pow = function pow(matrix, arg0) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.pow(arg0);\n  };\n\n  AbstractMatrix.prototype.pow = function pow(value) {\n    if (typeof value === 'number') return this.powS(value);\n    return this.powM(value);\n  };\n\n  AbstractMatrix.prototype.powS = function powS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ** value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.powM = function powM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ** matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n}\n\n/**\n * @private\n * Check that a row index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nfunction checkRowIndex(matrix, index, outer) {\n  let max = outer ? matrix.rows : matrix.rows - 1;\n  if (index < 0 || index > max) {\n    throw new RangeError('Row index out of range');\n  }\n}\n\n/**\n * @private\n * Check that a column index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nfunction checkColumnIndex(matrix, index, outer) {\n  let max = outer ? matrix.columns : matrix.columns - 1;\n  if (index < 0 || index > max) {\n    throw new RangeError('Column index out of range');\n  }\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nfunction checkRowVector(matrix, vector) {\n  if (vector.to1DArray) {\n    vector = vector.to1DArray();\n  }\n  if (vector.length !== matrix.columns) {\n    throw new RangeError(\n      'vector size must be the same as the number of columns',\n    );\n  }\n  return vector;\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nfunction checkColumnVector(matrix, vector) {\n  if (vector.to1DArray) {\n    vector = vector.to1DArray();\n  }\n  if (vector.length !== matrix.rows) {\n    throw new RangeError('vector size must be the same as the number of rows');\n  }\n  return vector;\n}\n\nfunction checkRowIndices(matrix, rowIndices) {\n  if (!isAnyArray.isAnyArray(rowIndices)) {\n    throw new TypeError('row indices must be an array');\n  }\n\n  for (let i = 0; i < rowIndices.length; i++) {\n    if (rowIndices[i] < 0 || rowIndices[i] >= matrix.rows) {\n      throw new RangeError('row indices are out of range');\n    }\n  }\n}\n\nfunction checkColumnIndices(matrix, columnIndices) {\n  if (!isAnyArray.isAnyArray(columnIndices)) {\n    throw new TypeError('column indices must be an array');\n  }\n\n  for (let i = 0; i < columnIndices.length; i++) {\n    if (columnIndices[i] < 0 || columnIndices[i] >= matrix.columns) {\n      throw new RangeError('column indices are out of range');\n    }\n  }\n}\n\nfunction checkRange(matrix, startRow, endRow, startColumn, endColumn) {\n  if (arguments.length !== 5) {\n    throw new RangeError('expected 4 arguments');\n  }\n  checkNumber('startRow', startRow);\n  checkNumber('endRow', endRow);\n  checkNumber('startColumn', startColumn);\n  checkNumber('endColumn', endColumn);\n  if (\n    startRow > endRow ||\n    startColumn > endColumn ||\n    startRow < 0 ||\n    startRow >= matrix.rows ||\n    endRow < 0 ||\n    endRow >= matrix.rows ||\n    startColumn < 0 ||\n    startColumn >= matrix.columns ||\n    endColumn < 0 ||\n    endColumn >= matrix.columns\n  ) {\n    throw new RangeError('Submatrix indices are out of range');\n  }\n}\n\nfunction newArray(length, value = 0) {\n  let array = [];\n  for (let i = 0; i < length; i++) {\n    array.push(value);\n  }\n  return array;\n}\n\nfunction checkNumber(name, value) {\n  if (typeof value !== 'number') {\n    throw new TypeError(`${name} must be a number`);\n  }\n}\n\nfunction checkNonEmpty(matrix) {\n  if (matrix.isEmpty()) {\n    throw new Error('Empty matrix has no elements to index');\n  }\n}\n\nfunction sumByRow(matrix) {\n  let sum = newArray(matrix.rows);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[i] += matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nfunction sumByColumn(matrix) {\n  let sum = newArray(matrix.columns);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[j] += matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nfunction sumAll(matrix) {\n  let v = 0;\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      v += matrix.get(i, j);\n    }\n  }\n  return v;\n}\n\nfunction productByRow(matrix) {\n  let sum = newArray(matrix.rows, 1);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[i] *= matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nfunction productByColumn(matrix) {\n  let sum = newArray(matrix.columns, 1);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[j] *= matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nfunction productAll(matrix) {\n  let v = 1;\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      v *= matrix.get(i, j);\n    }\n  }\n  return v;\n}\n\nfunction varianceByRow(matrix, unbiased, mean) {\n  const rows = matrix.rows;\n  const cols = matrix.columns;\n  const variance = [];\n\n  for (let i = 0; i < rows; i++) {\n    let sum1 = 0;\n    let sum2 = 0;\n    let x = 0;\n    for (let j = 0; j < cols; j++) {\n      x = matrix.get(i, j) - mean[i];\n      sum1 += x;\n      sum2 += x * x;\n    }\n    if (unbiased) {\n      variance.push((sum2 - (sum1 * sum1) / cols) / (cols - 1));\n    } else {\n      variance.push((sum2 - (sum1 * sum1) / cols) / cols);\n    }\n  }\n  return variance;\n}\n\nfunction varianceByColumn(matrix, unbiased, mean) {\n  const rows = matrix.rows;\n  const cols = matrix.columns;\n  const variance = [];\n\n  for (let j = 0; j < cols; j++) {\n    let sum1 = 0;\n    let sum2 = 0;\n    let x = 0;\n    for (let i = 0; i < rows; i++) {\n      x = matrix.get(i, j) - mean[j];\n      sum1 += x;\n      sum2 += x * x;\n    }\n    if (unbiased) {\n      variance.push((sum2 - (sum1 * sum1) / rows) / (rows - 1));\n    } else {\n      variance.push((sum2 - (sum1 * sum1) / rows) / rows);\n    }\n  }\n  return variance;\n}\n\nfunction varianceAll(matrix, unbiased, mean) {\n  const rows = matrix.rows;\n  const cols = matrix.columns;\n  const size = rows * cols;\n\n  let sum1 = 0;\n  let sum2 = 0;\n  let x = 0;\n  for (let i = 0; i < rows; i++) {\n    for (let j = 0; j < cols; j++) {\n      x = matrix.get(i, j) - mean;\n      sum1 += x;\n      sum2 += x * x;\n    }\n  }\n  if (unbiased) {\n    return (sum2 - (sum1 * sum1) / size) / (size - 1);\n  } else {\n    return (sum2 - (sum1 * sum1) / size) / size;\n  }\n}\n\nfunction centerByRow(matrix, mean) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) - mean[i]);\n    }\n  }\n}\n\nfunction centerByColumn(matrix, mean) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) - mean[j]);\n    }\n  }\n}\n\nfunction centerAll(matrix, mean) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) - mean);\n    }\n  }\n}\n\nfunction getScaleByRow(matrix) {\n  const scale = [];\n  for (let i = 0; i < matrix.rows; i++) {\n    let sum = 0;\n    for (let j = 0; j < matrix.columns; j++) {\n      sum += matrix.get(i, j) ** 2 / (matrix.columns - 1);\n    }\n    scale.push(Math.sqrt(sum));\n  }\n  return scale;\n}\n\nfunction scaleByRow(matrix, scale) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) / scale[i]);\n    }\n  }\n}\n\nfunction getScaleByColumn(matrix) {\n  const scale = [];\n  for (let j = 0; j < matrix.columns; j++) {\n    let sum = 0;\n    for (let i = 0; i < matrix.rows; i++) {\n      sum += matrix.get(i, j) ** 2 / (matrix.rows - 1);\n    }\n    scale.push(Math.sqrt(sum));\n  }\n  return scale;\n}\n\nfunction scaleByColumn(matrix, scale) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) / scale[j]);\n    }\n  }\n}\n\nfunction getScaleAll(matrix) {\n  const divider = matrix.size - 1;\n  let sum = 0;\n  for (let j = 0; j < matrix.columns; j++) {\n    for (let i = 0; i < matrix.rows; i++) {\n      sum += matrix.get(i, j) ** 2 / divider;\n    }\n  }\n  return Math.sqrt(sum);\n}\n\nfunction scaleAll(matrix, scale) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) / scale);\n    }\n  }\n}\n\nclass AbstractMatrix {\n  static from1DArray(newRows, newColumns, newData) {\n    let length = newRows * newColumns;\n    if (length !== newData.length) {\n      throw new RangeError('data length does not match given dimensions');\n    }\n    let newMatrix = new Matrix(newRows, newColumns);\n    for (let row = 0; row < newRows; row++) {\n      for (let column = 0; column < newColumns; column++) {\n        newMatrix.set(row, column, newData[row * newColumns + column]);\n      }\n    }\n    return newMatrix;\n  }\n\n  static rowVector(newData) {\n    let vector = new Matrix(1, newData.length);\n    for (let i = 0; i < newData.length; i++) {\n      vector.set(0, i, newData[i]);\n    }\n    return vector;\n  }\n\n  static columnVector(newData) {\n    let vector = new Matrix(newData.length, 1);\n    for (let i = 0; i < newData.length; i++) {\n      vector.set(i, 0, newData[i]);\n    }\n    return vector;\n  }\n\n  static zeros(rows, columns) {\n    return new Matrix(rows, columns);\n  }\n\n  static ones(rows, columns) {\n    return new Matrix(rows, columns).fill(1);\n  }\n\n  static rand(rows, columns, options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { random = Math.random } = options;\n    let matrix = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        matrix.set(i, j, random());\n      }\n    }\n    return matrix;\n  }\n\n  static randInt(rows, columns, options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { min = 0, max = 1000, random = Math.random } = options;\n    if (!Number.isInteger(min)) throw new TypeError('min must be an integer');\n    if (!Number.isInteger(max)) throw new TypeError('max must be an integer');\n    if (min >= max) throw new RangeError('min must be smaller than max');\n    let interval = max - min;\n    let matrix = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        let value = min + Math.round(random() * interval);\n        matrix.set(i, j, value);\n      }\n    }\n    return matrix;\n  }\n\n  static eye(rows, columns, value) {\n    if (columns === undefined) columns = rows;\n    if (value === undefined) value = 1;\n    let min = Math.min(rows, columns);\n    let matrix = this.zeros(rows, columns);\n    for (let i = 0; i < min; i++) {\n      matrix.set(i, i, value);\n    }\n    return matrix;\n  }\n\n  static diag(data, rows, columns) {\n    let l = data.length;\n    if (rows === undefined) rows = l;\n    if (columns === undefined) columns = rows;\n    let min = Math.min(l, rows, columns);\n    let matrix = this.zeros(rows, columns);\n    for (let i = 0; i < min; i++) {\n      matrix.set(i, i, data[i]);\n    }\n    return matrix;\n  }\n\n  static min(matrix1, matrix2) {\n    matrix1 = this.checkMatrix(matrix1);\n    matrix2 = this.checkMatrix(matrix2);\n    let rows = matrix1.rows;\n    let columns = matrix1.columns;\n    let result = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        result.set(i, j, Math.min(matrix1.get(i, j), matrix2.get(i, j)));\n      }\n    }\n    return result;\n  }\n\n  static max(matrix1, matrix2) {\n    matrix1 = this.checkMatrix(matrix1);\n    matrix2 = this.checkMatrix(matrix2);\n    let rows = matrix1.rows;\n    let columns = matrix1.columns;\n    let result = new this(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        result.set(i, j, Math.max(matrix1.get(i, j), matrix2.get(i, j)));\n      }\n    }\n    return result;\n  }\n\n  static checkMatrix(value) {\n    return AbstractMatrix.isMatrix(value) ? value : new Matrix(value);\n  }\n\n  static isMatrix(value) {\n    return value != null && value.klass === 'Matrix';\n  }\n\n  get size() {\n    return this.rows * this.columns;\n  }\n\n  apply(callback) {\n    if (typeof callback !== 'function') {\n      throw new TypeError('callback must be a function');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        callback.call(this, i, j);\n      }\n    }\n    return this;\n  }\n\n  to1DArray() {\n    let array = [];\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        array.push(this.get(i, j));\n      }\n    }\n    return array;\n  }\n\n  to2DArray() {\n    let copy = [];\n    for (let i = 0; i < this.rows; i++) {\n      copy.push([]);\n      for (let j = 0; j < this.columns; j++) {\n        copy[i].push(this.get(i, j));\n      }\n    }\n    return copy;\n  }\n\n  toJSON() {\n    return this.to2DArray();\n  }\n\n  isRowVector() {\n    return this.rows === 1;\n  }\n\n  isColumnVector() {\n    return this.columns === 1;\n  }\n\n  isVector() {\n    return this.rows === 1 || this.columns === 1;\n  }\n\n  isSquare() {\n    return this.rows === this.columns;\n  }\n\n  isEmpty() {\n    return this.rows === 0 || this.columns === 0;\n  }\n\n  isSymmetric() {\n    if (this.isSquare()) {\n      for (let i = 0; i < this.rows; i++) {\n        for (let j = 0; j <= i; j++) {\n          if (this.get(i, j) !== this.get(j, i)) {\n            return false;\n          }\n        }\n      }\n      return true;\n    }\n    return false;\n  }\n\n  isDistance() {\n    if (!this.isSymmetric()) return false;\n\n    for (let i = 0; i < this.rows; i++) {\n      if (this.get(i, i) !== 0) return false;\n    }\n\n    return true;\n  }\n\n  isEchelonForm() {\n    let i = 0;\n    let j = 0;\n    let previousColumn = -1;\n    let isEchelonForm = true;\n    let checked = false;\n    while (i < this.rows && isEchelonForm) {\n      j = 0;\n      checked = false;\n      while (j < this.columns && checked === false) {\n        if (this.get(i, j) === 0) {\n          j++;\n        } else if (this.get(i, j) === 1 && j > previousColumn) {\n          checked = true;\n          previousColumn = j;\n        } else {\n          isEchelonForm = false;\n          checked = true;\n        }\n      }\n      i++;\n    }\n    return isEchelonForm;\n  }\n\n  isReducedEchelonForm() {\n    let i = 0;\n    let j = 0;\n    let previousColumn = -1;\n    let isReducedEchelonForm = true;\n    let checked = false;\n    while (i < this.rows && isReducedEchelonForm) {\n      j = 0;\n      checked = false;\n      while (j < this.columns && checked === false) {\n        if (this.get(i, j) === 0) {\n          j++;\n        } else if (this.get(i, j) === 1 && j > previousColumn) {\n          checked = true;\n          previousColumn = j;\n        } else {\n          isReducedEchelonForm = false;\n          checked = true;\n        }\n      }\n      for (let k = j + 1; k < this.rows; k++) {\n        if (this.get(i, k) !== 0) {\n          isReducedEchelonForm = false;\n        }\n      }\n      i++;\n    }\n    return isReducedEchelonForm;\n  }\n\n  echelonForm() {\n    let result = this.clone();\n    let h = 0;\n    let k = 0;\n    while (h < result.rows && k < result.columns) {\n      let iMax = h;\n      for (let i = h; i < result.rows; i++) {\n        if (result.get(i, k) > result.get(iMax, k)) {\n          iMax = i;\n        }\n      }\n      if (result.get(iMax, k) === 0) {\n        k++;\n      } else {\n        result.swapRows(h, iMax);\n        let tmp = result.get(h, k);\n        for (let j = k; j < result.columns; j++) {\n          result.set(h, j, result.get(h, j) / tmp);\n        }\n        for (let i = h + 1; i < result.rows; i++) {\n          let factor = result.get(i, k) / result.get(h, k);\n          result.set(i, k, 0);\n          for (let j = k + 1; j < result.columns; j++) {\n            result.set(i, j, result.get(i, j) - result.get(h, j) * factor);\n          }\n        }\n        h++;\n        k++;\n      }\n    }\n    return result;\n  }\n\n  reducedEchelonForm() {\n    let result = this.echelonForm();\n    let m = result.columns;\n    let n = result.rows;\n    let h = n - 1;\n    while (h >= 0) {\n      if (result.maxRow(h) === 0) {\n        h--;\n      } else {\n        let p = 0;\n        let pivot = false;\n        while (p < n && pivot === false) {\n          if (result.get(h, p) === 1) {\n            pivot = true;\n          } else {\n            p++;\n          }\n        }\n        for (let i = 0; i < h; i++) {\n          let factor = result.get(i, p);\n          for (let j = p; j < m; j++) {\n            let tmp = result.get(i, j) - factor * result.get(h, j);\n            result.set(i, j, tmp);\n          }\n        }\n        h--;\n      }\n    }\n    return result;\n  }\n\n  set() {\n    throw new Error('set method is unimplemented');\n  }\n\n  get() {\n    throw new Error('get method is unimplemented');\n  }\n\n  repeat(options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { rows = 1, columns = 1 } = options;\n    if (!Number.isInteger(rows) || rows <= 0) {\n      throw new TypeError('rows must be a positive integer');\n    }\n    if (!Number.isInteger(columns) || columns <= 0) {\n      throw new TypeError('columns must be a positive integer');\n    }\n    let matrix = new Matrix(this.rows * rows, this.columns * columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        matrix.setSubMatrix(this, this.rows * i, this.columns * j);\n      }\n    }\n    return matrix;\n  }\n\n  fill(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, value);\n      }\n    }\n    return this;\n  }\n\n  neg() {\n    return this.mulS(-1);\n  }\n\n  getRow(index) {\n    checkRowIndex(this, index);\n    let row = [];\n    for (let i = 0; i < this.columns; i++) {\n      row.push(this.get(index, i));\n    }\n    return row;\n  }\n\n  getRowVector(index) {\n    return Matrix.rowVector(this.getRow(index));\n  }\n\n  setRow(index, array) {\n    checkRowIndex(this, index);\n    array = checkRowVector(this, array);\n    for (let i = 0; i < this.columns; i++) {\n      this.set(index, i, array[i]);\n    }\n    return this;\n  }\n\n  swapRows(row1, row2) {\n    checkRowIndex(this, row1);\n    checkRowIndex(this, row2);\n    for (let i = 0; i < this.columns; i++) {\n      let temp = this.get(row1, i);\n      this.set(row1, i, this.get(row2, i));\n      this.set(row2, i, temp);\n    }\n    return this;\n  }\n\n  getColumn(index) {\n    checkColumnIndex(this, index);\n    let column = [];\n    for (let i = 0; i < this.rows; i++) {\n      column.push(this.get(i, index));\n    }\n    return column;\n  }\n\n  getColumnVector(index) {\n    return Matrix.columnVector(this.getColumn(index));\n  }\n\n  setColumn(index, array) {\n    checkColumnIndex(this, index);\n    array = checkColumnVector(this, array);\n    for (let i = 0; i < this.rows; i++) {\n      this.set(i, index, array[i]);\n    }\n    return this;\n  }\n\n  swapColumns(column1, column2) {\n    checkColumnIndex(this, column1);\n    checkColumnIndex(this, column2);\n    for (let i = 0; i < this.rows; i++) {\n      let temp = this.get(i, column1);\n      this.set(i, column1, this.get(i, column2));\n      this.set(i, column2, temp);\n    }\n    return this;\n  }\n\n  addRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + vector[j]);\n      }\n    }\n    return this;\n  }\n\n  subRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - vector[j]);\n      }\n    }\n    return this;\n  }\n\n  mulRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * vector[j]);\n      }\n    }\n    return this;\n  }\n\n  divRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / vector[j]);\n      }\n    }\n    return this;\n  }\n\n  addColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + vector[i]);\n      }\n    }\n    return this;\n  }\n\n  subColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - vector[i]);\n      }\n    }\n    return this;\n  }\n\n  mulColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * vector[i]);\n      }\n    }\n    return this;\n  }\n\n  divColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / vector[i]);\n      }\n    }\n    return this;\n  }\n\n  mulRow(index, value) {\n    checkRowIndex(this, index);\n    for (let i = 0; i < this.columns; i++) {\n      this.set(index, i, this.get(index, i) * value);\n    }\n    return this;\n  }\n\n  mulColumn(index, value) {\n    checkColumnIndex(this, index);\n    for (let i = 0; i < this.rows; i++) {\n      this.set(i, index, this.get(i, index) * value);\n    }\n    return this;\n  }\n\n  max(by) {\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    switch (by) {\n      case 'row': {\n        const max = new Array(this.rows).fill(Number.NEGATIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) > max[row]) {\n              max[row] = this.get(row, column);\n            }\n          }\n        }\n        return max;\n      }\n      case 'column': {\n        const max = new Array(this.columns).fill(Number.NEGATIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) > max[column]) {\n              max[column] = this.get(row, column);\n            }\n          }\n        }\n        return max;\n      }\n      case undefined: {\n        let max = this.get(0, 0);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) > max) {\n              max = this.get(row, column);\n            }\n          }\n        }\n        return max;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  maxIndex() {\n    checkNonEmpty(this);\n    let v = this.get(0, 0);\n    let idx = [0, 0];\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        if (this.get(i, j) > v) {\n          v = this.get(i, j);\n          idx[0] = i;\n          idx[1] = j;\n        }\n      }\n    }\n    return idx;\n  }\n\n  min(by) {\n    if (this.isEmpty()) {\n      return NaN;\n    }\n\n    switch (by) {\n      case 'row': {\n        const min = new Array(this.rows).fill(Number.POSITIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) < min[row]) {\n              min[row] = this.get(row, column);\n            }\n          }\n        }\n        return min;\n      }\n      case 'column': {\n        const min = new Array(this.columns).fill(Number.POSITIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) < min[column]) {\n              min[column] = this.get(row, column);\n            }\n          }\n        }\n        return min;\n      }\n      case undefined: {\n        let min = this.get(0, 0);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) < min) {\n              min = this.get(row, column);\n            }\n          }\n        }\n        return min;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  minIndex() {\n    checkNonEmpty(this);\n    let v = this.get(0, 0);\n    let idx = [0, 0];\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        if (this.get(i, j) < v) {\n          v = this.get(i, j);\n          idx[0] = i;\n          idx[1] = j;\n        }\n      }\n    }\n    return idx;\n  }\n\n  maxRow(row) {\n    checkRowIndex(this, row);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(row, 0);\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) > v) {\n        v = this.get(row, i);\n      }\n    }\n    return v;\n  }\n\n  maxRowIndex(row) {\n    checkRowIndex(this, row);\n    checkNonEmpty(this);\n    let v = this.get(row, 0);\n    let idx = [row, 0];\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) > v) {\n        v = this.get(row, i);\n        idx[1] = i;\n      }\n    }\n    return idx;\n  }\n\n  minRow(row) {\n    checkRowIndex(this, row);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(row, 0);\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) < v) {\n        v = this.get(row, i);\n      }\n    }\n    return v;\n  }\n\n  minRowIndex(row) {\n    checkRowIndex(this, row);\n    checkNonEmpty(this);\n    let v = this.get(row, 0);\n    let idx = [row, 0];\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) < v) {\n        v = this.get(row, i);\n        idx[1] = i;\n      }\n    }\n    return idx;\n  }\n\n  maxColumn(column) {\n    checkColumnIndex(this, column);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(0, column);\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) > v) {\n        v = this.get(i, column);\n      }\n    }\n    return v;\n  }\n\n  maxColumnIndex(column) {\n    checkColumnIndex(this, column);\n    checkNonEmpty(this);\n    let v = this.get(0, column);\n    let idx = [0, column];\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) > v) {\n        v = this.get(i, column);\n        idx[0] = i;\n      }\n    }\n    return idx;\n  }\n\n  minColumn(column) {\n    checkColumnIndex(this, column);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(0, column);\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) < v) {\n        v = this.get(i, column);\n      }\n    }\n    return v;\n  }\n\n  minColumnIndex(column) {\n    checkColumnIndex(this, column);\n    checkNonEmpty(this);\n    let v = this.get(0, column);\n    let idx = [0, column];\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) < v) {\n        v = this.get(i, column);\n        idx[0] = i;\n      }\n    }\n    return idx;\n  }\n\n  diag() {\n    let min = Math.min(this.rows, this.columns);\n    let diag = [];\n    for (let i = 0; i < min; i++) {\n      diag.push(this.get(i, i));\n    }\n    return diag;\n  }\n\n  norm(type = 'frobenius') {\n    switch (type) {\n      case 'max':\n        return this.max();\n      case 'frobenius':\n        return Math.sqrt(this.dot(this));\n      default:\n        throw new RangeError(`unknown norm type: ${type}`);\n    }\n  }\n\n  cumulativeSum() {\n    let sum = 0;\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        sum += this.get(i, j);\n        this.set(i, j, sum);\n      }\n    }\n    return this;\n  }\n\n  dot(vector2) {\n    if (AbstractMatrix.isMatrix(vector2)) vector2 = vector2.to1DArray();\n    let vector1 = this.to1DArray();\n    if (vector1.length !== vector2.length) {\n      throw new RangeError('vectors do not have the same size');\n    }\n    let dot = 0;\n    for (let i = 0; i < vector1.length; i++) {\n      dot += vector1[i] * vector2[i];\n    }\n    return dot;\n  }\n\n  mmul(other) {\n    other = Matrix.checkMatrix(other);\n\n    let m = this.rows;\n    let n = this.columns;\n    let p = other.columns;\n\n    let result = new Matrix(m, p);\n\n    let Bcolj = new Float64Array(n);\n    for (let j = 0; j < p; j++) {\n      for (let k = 0; k < n; k++) {\n        Bcolj[k] = other.get(k, j);\n      }\n\n      for (let i = 0; i < m; i++) {\n        let s = 0;\n        for (let k = 0; k < n; k++) {\n          s += this.get(i, k) * Bcolj[k];\n        }\n\n        result.set(i, j, s);\n      }\n    }\n    return result;\n  }\n\n  mpow(scalar) {\n    if (!this.isSquare()) {\n      throw new RangeError('Matrix must be square');\n    }\n    if (!Number.isInteger(scalar) || scalar < 0) {\n      throw new RangeError('Exponent must be a non-negative integer');\n    }\n    // Russian Peasant exponentiation, i.e. exponentiation by squaring\n    let result = Matrix.eye(this.rows);\n    let bb = this;\n    // Note: Don't bit shift. In JS, that would truncate at 32 bits\n    for (let e = scalar; e >= 1; e /= 2) {\n      if ((e & 1) !== 0) {\n        result = result.mmul(bb);\n      }\n      bb = bb.mmul(bb);\n    }\n    return result;\n  }\n\n  strassen2x2(other) {\n    other = Matrix.checkMatrix(other);\n    let result = new Matrix(2, 2);\n    const a11 = this.get(0, 0);\n    const b11 = other.get(0, 0);\n    const a12 = this.get(0, 1);\n    const b12 = other.get(0, 1);\n    const a21 = this.get(1, 0);\n    const b21 = other.get(1, 0);\n    const a22 = this.get(1, 1);\n    const b22 = other.get(1, 1);\n\n    // Compute intermediate values.\n    const m1 = (a11 + a22) * (b11 + b22);\n    const m2 = (a21 + a22) * b11;\n    const m3 = a11 * (b12 - b22);\n    const m4 = a22 * (b21 - b11);\n    const m5 = (a11 + a12) * b22;\n    const m6 = (a21 - a11) * (b11 + b12);\n    const m7 = (a12 - a22) * (b21 + b22);\n\n    // Combine intermediate values into the output.\n    const c00 = m1 + m4 - m5 + m7;\n    const c01 = m3 + m5;\n    const c10 = m2 + m4;\n    const c11 = m1 - m2 + m3 + m6;\n\n    result.set(0, 0, c00);\n    result.set(0, 1, c01);\n    result.set(1, 0, c10);\n    result.set(1, 1, c11);\n    return result;\n  }\n\n  strassen3x3(other) {\n    other = Matrix.checkMatrix(other);\n    let result = new Matrix(3, 3);\n\n    const a00 = this.get(0, 0);\n    const a01 = this.get(0, 1);\n    const a02 = this.get(0, 2);\n    const a10 = this.get(1, 0);\n    const a11 = this.get(1, 1);\n    const a12 = this.get(1, 2);\n    const a20 = this.get(2, 0);\n    const a21 = this.get(2, 1);\n    const a22 = this.get(2, 2);\n\n    const b00 = other.get(0, 0);\n    const b01 = other.get(0, 1);\n    const b02 = other.get(0, 2);\n    const b10 = other.get(1, 0);\n    const b11 = other.get(1, 1);\n    const b12 = other.get(1, 2);\n    const b20 = other.get(2, 0);\n    const b21 = other.get(2, 1);\n    const b22 = other.get(2, 2);\n\n    const m1 = (a00 + a01 + a02 - a10 - a11 - a21 - a22) * b11;\n    const m2 = (a00 - a10) * (-b01 + b11);\n    const m3 = a11 * (-b00 + b01 + b10 - b11 - b12 - b20 + b22);\n    const m4 = (-a00 + a10 + a11) * (b00 - b01 + b11);\n    const m5 = (a10 + a11) * (-b00 + b01);\n    const m6 = a00 * b00;\n    const m7 = (-a00 + a20 + a21) * (b00 - b02 + b12);\n    const m8 = (-a00 + a20) * (b02 - b12);\n    const m9 = (a20 + a21) * (-b00 + b02);\n    const m10 = (a00 + a01 + a02 - a11 - a12 - a20 - a21) * b12;\n    const m11 = a21 * (-b00 + b02 + b10 - b11 - b12 - b20 + b21);\n    const m12 = (-a02 + a21 + a22) * (b11 + b20 - b21);\n    const m13 = (a02 - a22) * (b11 - b21);\n    const m14 = a02 * b20;\n    const m15 = (a21 + a22) * (-b20 + b21);\n    const m16 = (-a02 + a11 + a12) * (b12 + b20 - b22);\n    const m17 = (a02 - a12) * (b12 - b22);\n    const m18 = (a11 + a12) * (-b20 + b22);\n    const m19 = a01 * b10;\n    const m20 = a12 * b21;\n    const m21 = a10 * b02;\n    const m22 = a20 * b01;\n    const m23 = a22 * b22;\n\n    const c00 = m6 + m14 + m19;\n    const c01 = m1 + m4 + m5 + m6 + m12 + m14 + m15;\n    const c02 = m6 + m7 + m9 + m10 + m14 + m16 + m18;\n    const c10 = m2 + m3 + m4 + m6 + m14 + m16 + m17;\n    const c11 = m2 + m4 + m5 + m6 + m20;\n    const c12 = m14 + m16 + m17 + m18 + m21;\n    const c20 = m6 + m7 + m8 + m11 + m12 + m13 + m14;\n    const c21 = m12 + m13 + m14 + m15 + m22;\n    const c22 = m6 + m7 + m8 + m9 + m23;\n\n    result.set(0, 0, c00);\n    result.set(0, 1, c01);\n    result.set(0, 2, c02);\n    result.set(1, 0, c10);\n    result.set(1, 1, c11);\n    result.set(1, 2, c12);\n    result.set(2, 0, c20);\n    result.set(2, 1, c21);\n    result.set(2, 2, c22);\n    return result;\n  }\n\n  mmulStrassen(y) {\n    y = Matrix.checkMatrix(y);\n    let x = this.clone();\n    let r1 = x.rows;\n    let c1 = x.columns;\n    let r2 = y.rows;\n    let c2 = y.columns;\n    if (c1 !== r2) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        `Multiplying ${r1} x ${c1} and ${r2} x ${c2} matrix: dimensions do not match.`,\n      );\n    }\n\n    // Put a matrix into the top left of a matrix of zeros.\n    // `rows` and `cols` are the dimensions of the output matrix.\n    function embed(mat, rows, cols) {\n      let r = mat.rows;\n      let c = mat.columns;\n      if (r === rows && c === cols) {\n        return mat;\n      } else {\n        let resultat = AbstractMatrix.zeros(rows, cols);\n        resultat = resultat.setSubMatrix(mat, 0, 0);\n        return resultat;\n      }\n    }\n\n    // Make sure both matrices are the same size.\n    // This is exclusively for simplicity:\n    // this algorithm can be implemented with matrices of different sizes.\n\n    let r = Math.max(r1, r2);\n    let c = Math.max(c1, c2);\n    x = embed(x, r, c);\n    y = embed(y, r, c);\n\n    // Our recursive multiplication function.\n    function blockMult(a, b, rows, cols) {\n      // For small matrices, resort to naive multiplication.\n      if (rows <= 512 || cols <= 512) {\n        return a.mmul(b); // a is equivalent to this\n      }\n\n      // Apply dynamic padding.\n      if (rows % 2 === 1 && cols % 2 === 1) {\n        a = embed(a, rows + 1, cols + 1);\n        b = embed(b, rows + 1, cols + 1);\n      } else if (rows % 2 === 1) {\n        a = embed(a, rows + 1, cols);\n        b = embed(b, rows + 1, cols);\n      } else if (cols % 2 === 1) {\n        a = embed(a, rows, cols + 1);\n        b = embed(b, rows, cols + 1);\n      }\n\n      let halfRows = parseInt(a.rows / 2, 10);\n      let halfCols = parseInt(a.columns / 2, 10);\n      // Subdivide input matrices.\n      let a11 = a.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n      let b11 = b.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n\n      let a12 = a.subMatrix(0, halfRows - 1, halfCols, a.columns - 1);\n      let b12 = b.subMatrix(0, halfRows - 1, halfCols, b.columns - 1);\n\n      let a21 = a.subMatrix(halfRows, a.rows - 1, 0, halfCols - 1);\n      let b21 = b.subMatrix(halfRows, b.rows - 1, 0, halfCols - 1);\n\n      let a22 = a.subMatrix(halfRows, a.rows - 1, halfCols, a.columns - 1);\n      let b22 = b.subMatrix(halfRows, b.rows - 1, halfCols, b.columns - 1);\n\n      // Compute intermediate values.\n      let m1 = blockMult(\n        AbstractMatrix.add(a11, a22),\n        AbstractMatrix.add(b11, b22),\n        halfRows,\n        halfCols,\n      );\n      let m2 = blockMult(AbstractMatrix.add(a21, a22), b11, halfRows, halfCols);\n      let m3 = blockMult(a11, AbstractMatrix.sub(b12, b22), halfRows, halfCols);\n      let m4 = blockMult(a22, AbstractMatrix.sub(b21, b11), halfRows, halfCols);\n      let m5 = blockMult(AbstractMatrix.add(a11, a12), b22, halfRows, halfCols);\n      let m6 = blockMult(\n        AbstractMatrix.sub(a21, a11),\n        AbstractMatrix.add(b11, b12),\n        halfRows,\n        halfCols,\n      );\n      let m7 = blockMult(\n        AbstractMatrix.sub(a12, a22),\n        AbstractMatrix.add(b21, b22),\n        halfRows,\n        halfCols,\n      );\n\n      // Combine intermediate values into the output.\n      let c11 = AbstractMatrix.add(m1, m4);\n      c11.sub(m5);\n      c11.add(m7);\n      let c12 = AbstractMatrix.add(m3, m5);\n      let c21 = AbstractMatrix.add(m2, m4);\n      let c22 = AbstractMatrix.sub(m1, m2);\n      c22.add(m3);\n      c22.add(m6);\n\n      // Crop output to the desired size (undo dynamic padding).\n      let result = AbstractMatrix.zeros(2 * c11.rows, 2 * c11.columns);\n      result = result.setSubMatrix(c11, 0, 0);\n      result = result.setSubMatrix(c12, c11.rows, 0);\n      result = result.setSubMatrix(c21, 0, c11.columns);\n      result = result.setSubMatrix(c22, c11.rows, c11.columns);\n      return result.subMatrix(0, rows - 1, 0, cols - 1);\n    }\n\n    return blockMult(x, y, r, c);\n  }\n\n  scaleRows(options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { min = 0, max = 1 } = options;\n    if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n    if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n    if (min >= max) throw new RangeError('min must be smaller than max');\n    let newMatrix = new Matrix(this.rows, this.columns);\n    for (let i = 0; i < this.rows; i++) {\n      const row = this.getRow(i);\n      if (row.length > 0) {\n        rescale(row, { min, max, output: row });\n      }\n      newMatrix.setRow(i, row);\n    }\n    return newMatrix;\n  }\n\n  scaleColumns(options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { min = 0, max = 1 } = options;\n    if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n    if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n    if (min >= max) throw new RangeError('min must be smaller than max');\n    let newMatrix = new Matrix(this.rows, this.columns);\n    for (let i = 0; i < this.columns; i++) {\n      const column = this.getColumn(i);\n      if (column.length) {\n        rescale(column, {\n          min,\n          max,\n          output: column,\n        });\n      }\n      newMatrix.setColumn(i, column);\n    }\n    return newMatrix;\n  }\n\n  flipRows() {\n    const middle = Math.ceil(this.columns / 2);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < middle; j++) {\n        let first = this.get(i, j);\n        let last = this.get(i, this.columns - 1 - j);\n        this.set(i, j, last);\n        this.set(i, this.columns - 1 - j, first);\n      }\n    }\n    return this;\n  }\n\n  flipColumns() {\n    const middle = Math.ceil(this.rows / 2);\n    for (let j = 0; j < this.columns; j++) {\n      for (let i = 0; i < middle; i++) {\n        let first = this.get(i, j);\n        let last = this.get(this.rows - 1 - i, j);\n        this.set(i, j, last);\n        this.set(this.rows - 1 - i, j, first);\n      }\n    }\n    return this;\n  }\n\n  kroneckerProduct(other) {\n    other = Matrix.checkMatrix(other);\n\n    let m = this.rows;\n    let n = this.columns;\n    let p = other.rows;\n    let q = other.columns;\n\n    let result = new Matrix(m * p, n * q);\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            result.set(p * i + k, q * j + l, this.get(i, j) * other.get(k, l));\n          }\n        }\n      }\n    }\n    return result;\n  }\n\n  kroneckerSum(other) {\n    other = Matrix.checkMatrix(other);\n    if (!this.isSquare() || !other.isSquare()) {\n      throw new Error('Kronecker Sum needs two Square Matrices');\n    }\n    let m = this.rows;\n    let n = other.rows;\n    let AxI = this.kroneckerProduct(Matrix.eye(n, n));\n    let IxB = Matrix.eye(m, m).kroneckerProduct(other);\n    return AxI.add(IxB);\n  }\n\n  transpose() {\n    let result = new Matrix(this.columns, this.rows);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        result.set(j, i, this.get(i, j));\n      }\n    }\n    return result;\n  }\n\n  sortRows(compareFunction = compareNumbers) {\n    for (let i = 0; i < this.rows; i++) {\n      this.setRow(i, this.getRow(i).sort(compareFunction));\n    }\n    return this;\n  }\n\n  sortColumns(compareFunction = compareNumbers) {\n    for (let i = 0; i < this.columns; i++) {\n      this.setColumn(i, this.getColumn(i).sort(compareFunction));\n    }\n    return this;\n  }\n\n  subMatrix(startRow, endRow, startColumn, endColumn) {\n    checkRange(this, startRow, endRow, startColumn, endColumn);\n    let newMatrix = new Matrix(\n      endRow - startRow + 1,\n      endColumn - startColumn + 1,\n    );\n    for (let i = startRow; i <= endRow; i++) {\n      for (let j = startColumn; j <= endColumn; j++) {\n        newMatrix.set(i - startRow, j - startColumn, this.get(i, j));\n      }\n    }\n    return newMatrix;\n  }\n\n  subMatrixRow(indices, startColumn, endColumn) {\n    if (startColumn === undefined) startColumn = 0;\n    if (endColumn === undefined) endColumn = this.columns - 1;\n    if (\n      startColumn > endColumn ||\n      startColumn < 0 ||\n      startColumn >= this.columns ||\n      endColumn < 0 ||\n      endColumn >= this.columns\n    ) {\n      throw new RangeError('Argument out of range');\n    }\n\n    let newMatrix = new Matrix(indices.length, endColumn - startColumn + 1);\n    for (let i = 0; i < indices.length; i++) {\n      for (let j = startColumn; j <= endColumn; j++) {\n        if (indices[i] < 0 || indices[i] >= this.rows) {\n          throw new RangeError(`Row index out of range: ${indices[i]}`);\n        }\n        newMatrix.set(i, j - startColumn, this.get(indices[i], j));\n      }\n    }\n    return newMatrix;\n  }\n\n  subMatrixColumn(indices, startRow, endRow) {\n    if (startRow === undefined) startRow = 0;\n    if (endRow === undefined) endRow = this.rows - 1;\n    if (\n      startRow > endRow ||\n      startRow < 0 ||\n      startRow >= this.rows ||\n      endRow < 0 ||\n      endRow >= this.rows\n    ) {\n      throw new RangeError('Argument out of range');\n    }\n\n    let newMatrix = new Matrix(endRow - startRow + 1, indices.length);\n    for (let i = 0; i < indices.length; i++) {\n      for (let j = startRow; j <= endRow; j++) {\n        if (indices[i] < 0 || indices[i] >= this.columns) {\n          throw new RangeError(`Column index out of range: ${indices[i]}`);\n        }\n        newMatrix.set(j - startRow, i, this.get(j, indices[i]));\n      }\n    }\n    return newMatrix;\n  }\n\n  setSubMatrix(matrix, startRow, startColumn) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (matrix.isEmpty()) {\n      return this;\n    }\n    let endRow = startRow + matrix.rows - 1;\n    let endColumn = startColumn + matrix.columns - 1;\n    checkRange(this, startRow, endRow, startColumn, endColumn);\n    for (let i = 0; i < matrix.rows; i++) {\n      for (let j = 0; j < matrix.columns; j++) {\n        this.set(startRow + i, startColumn + j, matrix.get(i, j));\n      }\n    }\n    return this;\n  }\n\n  selection(rowIndices, columnIndices) {\n    checkRowIndices(this, rowIndices);\n    checkColumnIndices(this, columnIndices);\n    let newMatrix = new Matrix(rowIndices.length, columnIndices.length);\n    for (let i = 0; i < rowIndices.length; i++) {\n      let rowIndex = rowIndices[i];\n      for (let j = 0; j < columnIndices.length; j++) {\n        let columnIndex = columnIndices[j];\n        newMatrix.set(i, j, this.get(rowIndex, columnIndex));\n      }\n    }\n    return newMatrix;\n  }\n\n  trace() {\n    let min = Math.min(this.rows, this.columns);\n    let trace = 0;\n    for (let i = 0; i < min; i++) {\n      trace += this.get(i, i);\n    }\n    return trace;\n  }\n\n  clone() {\n    return this.constructor.copy(this, new Matrix(this.rows, this.columns));\n  }\n\n  /**\n   * @template {AbstractMatrix} M\n   * @param {AbstractMatrix} from\n   * @param {M} to\n   * @return {M}\n   */\n  static copy(from, to) {\n    for (const [row, column, value] of from.entries()) {\n      to.set(row, column, value);\n    }\n\n    return to;\n  }\n\n  sum(by) {\n    switch (by) {\n      case 'row':\n        return sumByRow(this);\n      case 'column':\n        return sumByColumn(this);\n      case undefined:\n        return sumAll(this);\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  product(by) {\n    switch (by) {\n      case 'row':\n        return productByRow(this);\n      case 'column':\n        return productByColumn(this);\n      case undefined:\n        return productAll(this);\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  mean(by) {\n    const sum = this.sum(by);\n    switch (by) {\n      case 'row': {\n        for (let i = 0; i < this.rows; i++) {\n          sum[i] /= this.columns;\n        }\n        return sum;\n      }\n      case 'column': {\n        for (let i = 0; i < this.columns; i++) {\n          sum[i] /= this.rows;\n        }\n        return sum;\n      }\n      case undefined:\n        return sum / this.size;\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  variance(by, options = {}) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { unbiased = true, mean = this.mean(by) } = options;\n    if (typeof unbiased !== 'boolean') {\n      throw new TypeError('unbiased must be a boolean');\n    }\n    switch (by) {\n      case 'row': {\n        if (!isAnyArray.isAnyArray(mean)) {\n          throw new TypeError('mean must be an array');\n        }\n        return varianceByRow(this, unbiased, mean);\n      }\n      case 'column': {\n        if (!isAnyArray.isAnyArray(mean)) {\n          throw new TypeError('mean must be an array');\n        }\n        return varianceByColumn(this, unbiased, mean);\n      }\n      case undefined: {\n        if (typeof mean !== 'number') {\n          throw new TypeError('mean must be a number');\n        }\n        return varianceAll(this, unbiased, mean);\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  standardDeviation(by, options) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    const variance = this.variance(by, options);\n    if (by === undefined) {\n      return Math.sqrt(variance);\n    } else {\n      for (let i = 0; i < variance.length; i++) {\n        variance[i] = Math.sqrt(variance[i]);\n      }\n      return variance;\n    }\n  }\n\n  center(by, options = {}) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { center = this.mean(by) } = options;\n    switch (by) {\n      case 'row': {\n        if (!isAnyArray.isAnyArray(center)) {\n          throw new TypeError('center must be an array');\n        }\n        centerByRow(this, center);\n        return this;\n      }\n      case 'column': {\n        if (!isAnyArray.isAnyArray(center)) {\n          throw new TypeError('center must be an array');\n        }\n        centerByColumn(this, center);\n        return this;\n      }\n      case undefined: {\n        if (typeof center !== 'number') {\n          throw new TypeError('center must be a number');\n        }\n        centerAll(this, center);\n        return this;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  scale(by, options = {}) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    let scale = options.scale;\n    switch (by) {\n      case 'row': {\n        if (scale === undefined) {\n          scale = getScaleByRow(this);\n        } else if (!isAnyArray.isAnyArray(scale)) {\n          throw new TypeError('scale must be an array');\n        }\n        scaleByRow(this, scale);\n        return this;\n      }\n      case 'column': {\n        if (scale === undefined) {\n          scale = getScaleByColumn(this);\n        } else if (!isAnyArray.isAnyArray(scale)) {\n          throw new TypeError('scale must be an array');\n        }\n        scaleByColumn(this, scale);\n        return this;\n      }\n      case undefined: {\n        if (scale === undefined) {\n          scale = getScaleAll(this);\n        } else if (typeof scale !== 'number') {\n          throw new TypeError('scale must be a number');\n        }\n        scaleAll(this, scale);\n        return this;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  toString(options) {\n    return inspectMatrixWithOptions(this, options);\n  }\n\n  [Symbol.iterator]() {\n    return this.entries();\n  }\n\n  /**\n   * iterator from left to right, from top to bottom\n   * yield [row, column, value]\n   * @returns {Generator<[number, number, number], void, void>}\n   */\n  *entries() {\n    for (let row = 0; row < this.rows; row++) {\n      for (let col = 0; col < this.columns; col++) {\n        yield [row, col, this.get(row, col)];\n      }\n    }\n  }\n\n  /**\n   * iterator from left to right, from top to bottom\n   * yield value\n   * @returns {Generator<number, void, void>}\n   */\n  *values() {\n    for (let row = 0; row < this.rows; row++) {\n      for (let col = 0; col < this.columns; col++) {\n        yield this.get(row, col);\n      }\n    }\n  }\n}\n\nAbstractMatrix.prototype.klass = 'Matrix';\nif (typeof Symbol !== 'undefined') {\n  AbstractMatrix.prototype[Symbol.for('nodejs.util.inspect.custom')] =\n    inspectMatrix;\n}\n\nfunction compareNumbers(a, b) {\n  return a - b;\n}\n\nfunction isArrayOfNumbers(array) {\n  return array.every((element) => {\n    return typeof element === 'number';\n  });\n}\n\n// Synonyms\nAbstractMatrix.random = AbstractMatrix.rand;\nAbstractMatrix.randomInt = AbstractMatrix.randInt;\nAbstractMatrix.diagonal = AbstractMatrix.diag;\nAbstractMatrix.prototype.diagonal = AbstractMatrix.prototype.diag;\nAbstractMatrix.identity = AbstractMatrix.eye;\nAbstractMatrix.prototype.negate = AbstractMatrix.prototype.neg;\nAbstractMatrix.prototype.tensorProduct =\n  AbstractMatrix.prototype.kroneckerProduct;\n\nclass Matrix extends AbstractMatrix {\n  /**\n   * @type {Float64Array[]}\n   */\n  data;\n\n  /**\n   * Init an empty matrix\n   * @param {number} nRows\n   * @param {number} nColumns\n   */\n  #initData(nRows, nColumns) {\n    this.data = [];\n\n    if (Number.isInteger(nColumns) && nColumns >= 0) {\n      for (let i = 0; i < nRows; i++) {\n        this.data.push(new Float64Array(nColumns));\n      }\n    } else {\n      throw new TypeError('nColumns must be a positive integer');\n    }\n\n    this.rows = nRows;\n    this.columns = nColumns;\n  }\n\n  constructor(nRows, nColumns) {\n    super();\n    if (Matrix.isMatrix(nRows)) {\n      this.#initData(nRows.rows, nRows.columns);\n      Matrix.copy(nRows, this);\n    } else if (Number.isInteger(nRows) && nRows >= 0) {\n      this.#initData(nRows, nColumns);\n    } else if (isAnyArray.isAnyArray(nRows)) {\n      // Copy the values from the 2D array\n      const arrayData = nRows;\n      nRows = arrayData.length;\n      nColumns = nRows ? arrayData[0].length : 0;\n      if (typeof nColumns !== 'number') {\n        throw new TypeError(\n          'Data must be a 2D array with at least one element',\n        );\n      }\n      this.data = [];\n\n      for (let i = 0; i < nRows; i++) {\n        if (arrayData[i].length !== nColumns) {\n          throw new RangeError('Inconsistent array dimensions');\n        }\n        if (!isArrayOfNumbers(arrayData[i])) {\n          throw new TypeError('Input data contains non-numeric values');\n        }\n        this.data.push(Float64Array.from(arrayData[i]));\n      }\n\n      this.rows = nRows;\n      this.columns = nColumns;\n    } else {\n      throw new TypeError(\n        'First argument must be a positive number or an array',\n      );\n    }\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.data[rowIndex][columnIndex] = value;\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.data[rowIndex][columnIndex];\n  }\n\n  removeRow(index) {\n    checkRowIndex(this, index);\n    this.data.splice(index, 1);\n    this.rows -= 1;\n    return this;\n  }\n\n  addRow(index, array) {\n    if (array === undefined) {\n      array = index;\n      index = this.rows;\n    }\n    checkRowIndex(this, index, true);\n    array = Float64Array.from(checkRowVector(this, array));\n    this.data.splice(index, 0, array);\n    this.rows += 1;\n    return this;\n  }\n\n  removeColumn(index) {\n    checkColumnIndex(this, index);\n    for (let i = 0; i < this.rows; i++) {\n      const newRow = new Float64Array(this.columns - 1);\n      for (let j = 0; j < index; j++) {\n        newRow[j] = this.data[i][j];\n      }\n      for (let j = index + 1; j < this.columns; j++) {\n        newRow[j - 1] = this.data[i][j];\n      }\n      this.data[i] = newRow;\n    }\n    this.columns -= 1;\n    return this;\n  }\n\n  addColumn(index, array) {\n    if (typeof array === 'undefined') {\n      array = index;\n      index = this.columns;\n    }\n    checkColumnIndex(this, index, true);\n    array = checkColumnVector(this, array);\n    for (let i = 0; i < this.rows; i++) {\n      const newRow = new Float64Array(this.columns + 1);\n      let j = 0;\n      for (; j < index; j++) {\n        newRow[j] = this.data[i][j];\n      }\n      newRow[j++] = array[i];\n      for (; j < this.columns + 1; j++) {\n        newRow[j] = this.data[i][j - 1];\n      }\n      this.data[i] = newRow;\n    }\n    this.columns += 1;\n    return this;\n  }\n}\n\ninstallMathOperations(AbstractMatrix, Matrix);\n\n/**\n * @typedef {0 | 1 | number | boolean} Mask\n */\n\nclass SymmetricMatrix extends AbstractMatrix {\n  /** @type {Matrix} */\n  #matrix;\n\n  get size() {\n    return this.#matrix.size;\n  }\n\n  get rows() {\n    return this.#matrix.rows;\n  }\n\n  get columns() {\n    return this.#matrix.columns;\n  }\n\n  get diagonalSize() {\n    return this.rows;\n  }\n\n  /**\n   * not the same as matrix.isSymmetric()\n   * Here is to check if it's instanceof SymmetricMatrix without bundling issues\n   *\n   * @param value\n   * @returns {boolean}\n   */\n  static isSymmetricMatrix(value) {\n    return Matrix.isMatrix(value) && value.klassType === 'SymmetricMatrix';\n  }\n\n  /**\n   * @param diagonalSize\n   * @return {SymmetricMatrix}\n   */\n  static zeros(diagonalSize) {\n    return new this(diagonalSize);\n  }\n\n  /**\n   * @param diagonalSize\n   * @return {SymmetricMatrix}\n   */\n  static ones(diagonalSize) {\n    return new this(diagonalSize).fill(1);\n  }\n\n  /**\n   * @param {number | AbstractMatrix | ArrayLike<ArrayLike<number>>} diagonalSize\n   * @return {this}\n   */\n  constructor(diagonalSize) {\n    super();\n\n    if (Matrix.isMatrix(diagonalSize)) {\n      if (!diagonalSize.isSymmetric()) {\n        throw new TypeError('not symmetric data');\n      }\n\n      this.#matrix = Matrix.copy(\n        diagonalSize,\n        new Matrix(diagonalSize.rows, diagonalSize.rows),\n      );\n    } else if (Number.isInteger(diagonalSize) && diagonalSize >= 0) {\n      this.#matrix = new Matrix(diagonalSize, diagonalSize);\n    } else {\n      this.#matrix = new Matrix(diagonalSize);\n\n      if (!this.isSymmetric()) {\n        throw new TypeError('not symmetric data');\n      }\n    }\n  }\n\n  clone() {\n    const matrix = new SymmetricMatrix(this.diagonalSize);\n\n    for (const [row, col, value] of this.upperRightEntries()) {\n      matrix.set(row, col, value);\n    }\n\n    return matrix;\n  }\n\n  toMatrix() {\n    return new Matrix(this);\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.#matrix.get(rowIndex, columnIndex);\n  }\n  set(rowIndex, columnIndex, value) {\n    // symmetric set\n    this.#matrix.set(rowIndex, columnIndex, value);\n    this.#matrix.set(columnIndex, rowIndex, value);\n\n    return this;\n  }\n\n  removeCross(index) {\n    // symmetric remove side\n    this.#matrix.removeRow(index);\n    this.#matrix.removeColumn(index);\n\n    return this;\n  }\n\n  addCross(index, array) {\n    if (array === undefined) {\n      array = index;\n      index = this.diagonalSize;\n    }\n\n    const row = array.slice();\n    row.splice(index, 1);\n\n    this.#matrix.addRow(index, row);\n    this.#matrix.addColumn(index, array);\n\n    return this;\n  }\n\n  /**\n   * @param {Mask[]} mask\n   */\n  applyMask(mask) {\n    if (mask.length !== this.diagonalSize) {\n      throw new RangeError('Mask size do not match with matrix size');\n    }\n\n    // prepare sides to remove from matrix from mask\n    /** @type {number[]} */\n    const sidesToRemove = [];\n    for (const [index, passthroughs] of mask.entries()) {\n      if (passthroughs) continue;\n      sidesToRemove.push(index);\n    }\n    // to remove from highest to lowest for no mutation shifting\n    sidesToRemove.reverse();\n\n    // remove sides\n    for (const sideIndex of sidesToRemove) {\n      this.removeCross(sideIndex);\n    }\n\n    return this;\n  }\n\n  /**\n   * Compact format upper-right corner of matrix\n   * iterate from left to right, from top to bottom.\n   *\n   * ```\n   *   A B C D\n   * A 1 2 3 4\n   * B 2 5 6 7\n   * C 3 6 8 9\n   * D 4 7 9 10\n   * ```\n   *\n   * will return compact 1D array `[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]`\n   *\n   * length is S(i=0, n=sideSize) => 10 for a 4 sideSized matrix\n   *\n   * @returns {number[]}\n   */\n  toCompact() {\n    const { diagonalSize } = this;\n\n    /** @type {number[]} */\n    const compact = new Array((diagonalSize * (diagonalSize + 1)) / 2);\n    for (let col = 0, row = 0, index = 0; index < compact.length; index++) {\n      compact[index] = this.get(row, col);\n\n      if (++col >= diagonalSize) col = ++row;\n    }\n\n    return compact;\n  }\n\n  /**\n   * @param {number[]} compact\n   * @return {SymmetricMatrix}\n   */\n  static fromCompact(compact) {\n    const compactSize = compact.length;\n    // compactSize = (sideSize * (sideSize + 1)) / 2\n    // https://mathsolver.microsoft.com/fr/solve-problem/y%20%3D%20%20x%20%60cdot%20%20%20%60frac%7B%20%20%60left(%20x%2B1%20%20%60right)%20%20%20%20%7D%7B%202%20%20%7D\n    // sideSize = (Sqrt(8 × compactSize + 1) - 1) / 2\n    const diagonalSize = (Math.sqrt(8 * compactSize + 1) - 1) / 2;\n\n    if (!Number.isInteger(diagonalSize)) {\n      throw new TypeError(\n        `This array is not a compact representation of a Symmetric Matrix, ${JSON.stringify(\n          compact,\n        )}`,\n      );\n    }\n\n    const matrix = new SymmetricMatrix(diagonalSize);\n    for (let col = 0, row = 0, index = 0; index < compactSize; index++) {\n      matrix.set(col, row, compact[index]);\n      if (++col >= diagonalSize) col = ++row;\n    }\n\n    return matrix;\n  }\n\n  /**\n   * half iterator upper-right-corner from left to right, from top to bottom\n   * yield [row, column, value]\n   *\n   * @returns {Generator<[number, number, number], void, void>}\n   */\n  *upperRightEntries() {\n    for (let row = 0, col = 0; row < this.diagonalSize; void 0) {\n      const value = this.get(row, col);\n\n      yield [row, col, value];\n\n      // at the end of row, move cursor to next row at diagonal position\n      if (++col >= this.diagonalSize) col = ++row;\n    }\n  }\n\n  /**\n   * half iterator upper-right-corner from left to right, from top to bottom\n   * yield value\n   *\n   * @returns {Generator<[number, number, number], void, void>}\n   */\n  *upperRightValues() {\n    for (let row = 0, col = 0; row < this.diagonalSize; void 0) {\n      const value = this.get(row, col);\n\n      yield value;\n\n      // at the end of row, move cursor to next row at diagonal position\n      if (++col >= this.diagonalSize) col = ++row;\n    }\n  }\n}\nSymmetricMatrix.prototype.klassType = 'SymmetricMatrix';\n\nclass DistanceMatrix extends SymmetricMatrix {\n  /**\n   * not the same as matrix.isSymmetric()\n   * Here is to check if it's instanceof SymmetricMatrix without bundling issues\n   *\n   * @param value\n   * @returns {boolean}\n   */\n  static isDistanceMatrix(value) {\n    return (\n      SymmetricMatrix.isSymmetricMatrix(value) &&\n      value.klassSubType === 'DistanceMatrix'\n    );\n  }\n\n  constructor(sideSize) {\n    super(sideSize);\n\n    if (!this.isDistance()) {\n      throw new TypeError('Provided arguments do no produce a distance matrix');\n    }\n  }\n\n  set(rowIndex, columnIndex, value) {\n    // distance matrix diagonal is 0\n    if (rowIndex === columnIndex) value = 0;\n\n    return super.set(rowIndex, columnIndex, value);\n  }\n\n  addCross(index, array) {\n    if (array === undefined) {\n      array = index;\n      index = this.diagonalSize;\n    }\n\n    // ensure distance\n    array = array.slice();\n    array[index] = 0;\n\n    return super.addCross(index, array);\n  }\n\n  toSymmetricMatrix() {\n    return new SymmetricMatrix(this);\n  }\n\n  clone() {\n    const matrix = new DistanceMatrix(this.diagonalSize);\n\n    for (const [row, col, value] of this.upperRightEntries()) {\n      if (row === col) continue;\n      matrix.set(row, col, value);\n    }\n\n    return matrix;\n  }\n\n  /**\n   * Compact format upper-right corner of matrix\n   * no diagonal (only zeros)\n   * iterable from left to right, from top to bottom.\n   *\n   * ```\n   *   A B C D\n   * A 0 1 2 3\n   * B 1 0 4 5\n   * C 2 4 0 6\n   * D 3 5 6 0\n   * ```\n   *\n   * will return compact 1D array `[1, 2, 3, 4, 5, 6]`\n   *\n   * length is S(i=0, n=sideSize-1) => 6 for a 4 side sized matrix\n   *\n   * @returns {number[]}\n   */\n  toCompact() {\n    const { diagonalSize } = this;\n    const compactLength = ((diagonalSize - 1) * diagonalSize) / 2;\n\n    /** @type {number[]} */\n    const compact = new Array(compactLength);\n    for (let col = 1, row = 0, index = 0; index < compact.length; index++) {\n      compact[index] = this.get(row, col);\n\n      if (++col >= diagonalSize) col = ++row + 1;\n    }\n\n    return compact;\n  }\n\n  /**\n   * @param {number[]} compact\n   */\n  static fromCompact(compact) {\n    const compactSize = compact.length;\n\n    if (compactSize === 0) {\n      return new this(0);\n    }\n\n    // compactSize in Natural integer range ]0;∞]\n    // compactSize = (sideSize * (sideSize - 1)) / 2\n    // sideSize = (Sqrt(8 × compactSize + 1) + 1) / 2\n    const diagonalSize = (Math.sqrt(8 * compactSize + 1) + 1) / 2;\n\n    if (!Number.isInteger(diagonalSize)) {\n      throw new TypeError(\n        `This array is not a compact representation of a DistanceMatrix, ${JSON.stringify(\n          compact,\n        )}`,\n      );\n    }\n\n    const matrix = new this(diagonalSize);\n    for (let col = 1, row = 0, index = 0; index < compactSize; index++) {\n      matrix.set(col, row, compact[index]);\n      if (++col >= diagonalSize) col = ++row + 1;\n    }\n\n    return matrix;\n  }\n}\nDistanceMatrix.prototype.klassSubType = 'DistanceMatrix';\n\nclass BaseView extends AbstractMatrix {\n  constructor(matrix, rows, columns) {\n    super();\n    this.matrix = matrix;\n    this.rows = rows;\n    this.columns = columns;\n  }\n}\n\nclass MatrixColumnView extends BaseView {\n  constructor(matrix, column) {\n    checkColumnIndex(matrix, column);\n    super(matrix, matrix.rows, 1);\n    this.column = column;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(rowIndex, this.column, value);\n    return this;\n  }\n\n  get(rowIndex) {\n    return this.matrix.get(rowIndex, this.column);\n  }\n}\n\nclass MatrixColumnSelectionView extends BaseView {\n  constructor(matrix, columnIndices) {\n    checkColumnIndices(matrix, columnIndices);\n    super(matrix, matrix.rows, columnIndices.length);\n    this.columnIndices = columnIndices;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(rowIndex, this.columnIndices[columnIndex], value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(rowIndex, this.columnIndices[columnIndex]);\n  }\n}\n\nclass MatrixFlipColumnView extends BaseView {\n  constructor(matrix) {\n    super(matrix, matrix.rows, matrix.columns);\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(rowIndex, this.columns - columnIndex - 1, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(rowIndex, this.columns - columnIndex - 1);\n  }\n}\n\nclass MatrixFlipRowView extends BaseView {\n  constructor(matrix) {\n    super(matrix, matrix.rows, matrix.columns);\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(this.rows - rowIndex - 1, columnIndex, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(this.rows - rowIndex - 1, columnIndex);\n  }\n}\n\nclass MatrixRowView extends BaseView {\n  constructor(matrix, row) {\n    checkRowIndex(matrix, row);\n    super(matrix, 1, matrix.columns);\n    this.row = row;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(this.row, columnIndex, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(this.row, columnIndex);\n  }\n}\n\nclass MatrixRowSelectionView extends BaseView {\n  constructor(matrix, rowIndices) {\n    checkRowIndices(matrix, rowIndices);\n    super(matrix, rowIndices.length, matrix.columns);\n    this.rowIndices = rowIndices;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(this.rowIndices[rowIndex], columnIndex, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(this.rowIndices[rowIndex], columnIndex);\n  }\n}\n\nclass MatrixSelectionView extends BaseView {\n  constructor(matrix, rowIndices, columnIndices) {\n    checkRowIndices(matrix, rowIndices);\n    checkColumnIndices(matrix, columnIndices);\n    super(matrix, rowIndices.length, columnIndices.length);\n    this.rowIndices = rowIndices;\n    this.columnIndices = columnIndices;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(\n      this.rowIndices[rowIndex],\n      this.columnIndices[columnIndex],\n      value,\n    );\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(\n      this.rowIndices[rowIndex],\n      this.columnIndices[columnIndex],\n    );\n  }\n}\n\nclass MatrixSubView extends BaseView {\n  constructor(matrix, startRow, endRow, startColumn, endColumn) {\n    checkRange(matrix, startRow, endRow, startColumn, endColumn);\n    super(matrix, endRow - startRow + 1, endColumn - startColumn + 1);\n    this.startRow = startRow;\n    this.startColumn = startColumn;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(\n      this.startRow + rowIndex,\n      this.startColumn + columnIndex,\n      value,\n    );\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(\n      this.startRow + rowIndex,\n      this.startColumn + columnIndex,\n    );\n  }\n}\n\nclass MatrixTransposeView extends BaseView {\n  constructor(matrix) {\n    super(matrix, matrix.columns, matrix.rows);\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(columnIndex, rowIndex, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(columnIndex, rowIndex);\n  }\n}\n\nclass WrapperMatrix1D extends AbstractMatrix {\n  constructor(data, options = {}) {\n    const { rows = 1 } = options;\n\n    if (data.length % rows !== 0) {\n      throw new Error('the data length is not divisible by the number of rows');\n    }\n    super();\n    this.rows = rows;\n    this.columns = data.length / rows;\n    this.data = data;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    let index = this._calculateIndex(rowIndex, columnIndex);\n    this.data[index] = value;\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    let index = this._calculateIndex(rowIndex, columnIndex);\n    return this.data[index];\n  }\n\n  _calculateIndex(row, column) {\n    return row * this.columns + column;\n  }\n}\n\nclass WrapperMatrix2D extends AbstractMatrix {\n  constructor(data) {\n    super();\n    this.data = data;\n    this.rows = data.length;\n    this.columns = data[0].length;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.data[rowIndex][columnIndex] = value;\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.data[rowIndex][columnIndex];\n  }\n}\n\nfunction wrap(array, options) {\n  if (isAnyArray.isAnyArray(array)) {\n    if (array[0] && isAnyArray.isAnyArray(array[0])) {\n      return new WrapperMatrix2D(array);\n    } else {\n      return new WrapperMatrix1D(array, options);\n    }\n  } else {\n    throw new Error('the argument is not an array');\n  }\n}\n\nclass LuDecomposition {\n  constructor(matrix) {\n    matrix = WrapperMatrix2D.checkMatrix(matrix);\n\n    let lu = matrix.clone();\n    let rows = lu.rows;\n    let columns = lu.columns;\n    let pivotVector = new Float64Array(rows);\n    let pivotSign = 1;\n    let i, j, k, p, s, t, v;\n    let LUcolj, kmax;\n\n    for (i = 0; i < rows; i++) {\n      pivotVector[i] = i;\n    }\n\n    LUcolj = new Float64Array(rows);\n\n    for (j = 0; j < columns; j++) {\n      for (i = 0; i < rows; i++) {\n        LUcolj[i] = lu.get(i, j);\n      }\n\n      for (i = 0; i < rows; i++) {\n        kmax = Math.min(i, j);\n        s = 0;\n        for (k = 0; k < kmax; k++) {\n          s += lu.get(i, k) * LUcolj[k];\n        }\n        LUcolj[i] -= s;\n        lu.set(i, j, LUcolj[i]);\n      }\n\n      p = j;\n      for (i = j + 1; i < rows; i++) {\n        if (Math.abs(LUcolj[i]) > Math.abs(LUcolj[p])) {\n          p = i;\n        }\n      }\n\n      if (p !== j) {\n        for (k = 0; k < columns; k++) {\n          t = lu.get(p, k);\n          lu.set(p, k, lu.get(j, k));\n          lu.set(j, k, t);\n        }\n\n        v = pivotVector[p];\n        pivotVector[p] = pivotVector[j];\n        pivotVector[j] = v;\n\n        pivotSign = -pivotSign;\n      }\n\n      if (j < rows && lu.get(j, j) !== 0) {\n        for (i = j + 1; i < rows; i++) {\n          lu.set(i, j, lu.get(i, j) / lu.get(j, j));\n        }\n      }\n    }\n\n    this.LU = lu;\n    this.pivotVector = pivotVector;\n    this.pivotSign = pivotSign;\n  }\n\n  isSingular() {\n    let data = this.LU;\n    let col = data.columns;\n    for (let j = 0; j < col; j++) {\n      if (data.get(j, j) === 0) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  solve(value) {\n    value = Matrix.checkMatrix(value);\n\n    let lu = this.LU;\n    let rows = lu.rows;\n\n    if (rows !== value.rows) {\n      throw new Error('Invalid matrix dimensions');\n    }\n    if (this.isSingular()) {\n      throw new Error('LU matrix is singular');\n    }\n\n    let count = value.columns;\n    let X = value.subMatrixRow(this.pivotVector, 0, count - 1);\n    let columns = lu.columns;\n    let i, j, k;\n\n    for (k = 0; k < columns; k++) {\n      for (i = k + 1; i < columns; i++) {\n        for (j = 0; j < count; j++) {\n          X.set(i, j, X.get(i, j) - X.get(k, j) * lu.get(i, k));\n        }\n      }\n    }\n    for (k = columns - 1; k >= 0; k--) {\n      for (j = 0; j < count; j++) {\n        X.set(k, j, X.get(k, j) / lu.get(k, k));\n      }\n      for (i = 0; i < k; i++) {\n        for (j = 0; j < count; j++) {\n          X.set(i, j, X.get(i, j) - X.get(k, j) * lu.get(i, k));\n        }\n      }\n    }\n    return X;\n  }\n\n  get determinant() {\n    let data = this.LU;\n    if (!data.isSquare()) {\n      throw new Error('Matrix must be square');\n    }\n    let determinant = this.pivotSign;\n    let col = data.columns;\n    for (let j = 0; j < col; j++) {\n      determinant *= data.get(j, j);\n    }\n    return determinant;\n  }\n\n  get lowerTriangularMatrix() {\n    let data = this.LU;\n    let rows = data.rows;\n    let columns = data.columns;\n    let X = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        if (i > j) {\n          X.set(i, j, data.get(i, j));\n        } else if (i === j) {\n          X.set(i, j, 1);\n        } else {\n          X.set(i, j, 0);\n        }\n      }\n    }\n    return X;\n  }\n\n  get upperTriangularMatrix() {\n    let data = this.LU;\n    let rows = data.rows;\n    let columns = data.columns;\n    let X = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        if (i <= j) {\n          X.set(i, j, data.get(i, j));\n        } else {\n          X.set(i, j, 0);\n        }\n      }\n    }\n    return X;\n  }\n\n  get pivotPermutationVector() {\n    return Array.from(this.pivotVector);\n  }\n}\n\nfunction hypotenuse(a, b) {\n  let r = 0;\n  if (Math.abs(a) > Math.abs(b)) {\n    r = b / a;\n    return Math.abs(a) * Math.sqrt(1 + r * r);\n  }\n  if (b !== 0) {\n    r = a / b;\n    return Math.abs(b) * Math.sqrt(1 + r * r);\n  }\n  return 0;\n}\n\nclass QrDecomposition {\n  constructor(value) {\n    value = WrapperMatrix2D.checkMatrix(value);\n\n    let qr = value.clone();\n    let m = value.rows;\n    let n = value.columns;\n    let rdiag = new Float64Array(n);\n    let i, j, k, s;\n\n    for (k = 0; k < n; k++) {\n      let nrm = 0;\n      for (i = k; i < m; i++) {\n        nrm = hypotenuse(nrm, qr.get(i, k));\n      }\n      if (nrm !== 0) {\n        if (qr.get(k, k) < 0) {\n          nrm = -nrm;\n        }\n        for (i = k; i < m; i++) {\n          qr.set(i, k, qr.get(i, k) / nrm);\n        }\n        qr.set(k, k, qr.get(k, k) + 1);\n        for (j = k + 1; j < n; j++) {\n          s = 0;\n          for (i = k; i < m; i++) {\n            s += qr.get(i, k) * qr.get(i, j);\n          }\n          s = -s / qr.get(k, k);\n          for (i = k; i < m; i++) {\n            qr.set(i, j, qr.get(i, j) + s * qr.get(i, k));\n          }\n        }\n      }\n      rdiag[k] = -nrm;\n    }\n\n    this.QR = qr;\n    this.Rdiag = rdiag;\n  }\n\n  solve(value) {\n    value = Matrix.checkMatrix(value);\n\n    let qr = this.QR;\n    let m = qr.rows;\n\n    if (value.rows !== m) {\n      throw new Error('Matrix row dimensions must agree');\n    }\n    if (!this.isFullRank()) {\n      throw new Error('Matrix is rank deficient');\n    }\n\n    let count = value.columns;\n    let X = value.clone();\n    let n = qr.columns;\n    let i, j, k, s;\n\n    for (k = 0; k < n; k++) {\n      for (j = 0; j < count; j++) {\n        s = 0;\n        for (i = k; i < m; i++) {\n          s += qr.get(i, k) * X.get(i, j);\n        }\n        s = -s / qr.get(k, k);\n        for (i = k; i < m; i++) {\n          X.set(i, j, X.get(i, j) + s * qr.get(i, k));\n        }\n      }\n    }\n    for (k = n - 1; k >= 0; k--) {\n      for (j = 0; j < count; j++) {\n        X.set(k, j, X.get(k, j) / this.Rdiag[k]);\n      }\n      for (i = 0; i < k; i++) {\n        for (j = 0; j < count; j++) {\n          X.set(i, j, X.get(i, j) - X.get(k, j) * qr.get(i, k));\n        }\n      }\n    }\n\n    return X.subMatrix(0, n - 1, 0, count - 1);\n  }\n\n  isFullRank() {\n    let columns = this.QR.columns;\n    for (let i = 0; i < columns; i++) {\n      if (this.Rdiag[i] === 0) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  get upperTriangularMatrix() {\n    let qr = this.QR;\n    let n = qr.columns;\n    let X = new Matrix(n, n);\n    let i, j;\n    for (i = 0; i < n; i++) {\n      for (j = 0; j < n; j++) {\n        if (i < j) {\n          X.set(i, j, qr.get(i, j));\n        } else if (i === j) {\n          X.set(i, j, this.Rdiag[i]);\n        } else {\n          X.set(i, j, 0);\n        }\n      }\n    }\n    return X;\n  }\n\n  get orthogonalMatrix() {\n    let qr = this.QR;\n    let rows = qr.rows;\n    let columns = qr.columns;\n    let X = new Matrix(rows, columns);\n    let i, j, k, s;\n\n    for (k = columns - 1; k >= 0; k--) {\n      for (i = 0; i < rows; i++) {\n        X.set(i, k, 0);\n      }\n      X.set(k, k, 1);\n      for (j = k; j < columns; j++) {\n        if (qr.get(k, k) !== 0) {\n          s = 0;\n          for (i = k; i < rows; i++) {\n            s += qr.get(i, k) * X.get(i, j);\n          }\n\n          s = -s / qr.get(k, k);\n\n          for (i = k; i < rows; i++) {\n            X.set(i, j, X.get(i, j) + s * qr.get(i, k));\n          }\n        }\n      }\n    }\n    return X;\n  }\n}\n\nclass SingularValueDecomposition {\n  constructor(value, options = {}) {\n    value = WrapperMatrix2D.checkMatrix(value);\n\n    if (value.isEmpty()) {\n      throw new Error('Matrix must be non-empty');\n    }\n\n    let m = value.rows;\n    let n = value.columns;\n\n    const {\n      computeLeftSingularVectors = true,\n      computeRightSingularVectors = true,\n      autoTranspose = false,\n    } = options;\n\n    let wantu = Boolean(computeLeftSingularVectors);\n    let wantv = Boolean(computeRightSingularVectors);\n\n    let swapped = false;\n    let a;\n    if (m < n) {\n      if (!autoTranspose) {\n        a = value.clone();\n        // eslint-disable-next-line no-console\n        console.warn(\n          'Computing SVD on a matrix with more columns than rows. Consider enabling autoTranspose',\n        );\n      } else {\n        a = value.transpose();\n        m = a.rows;\n        n = a.columns;\n        swapped = true;\n        let aux = wantu;\n        wantu = wantv;\n        wantv = aux;\n      }\n    } else {\n      a = value.clone();\n    }\n\n    let nu = Math.min(m, n);\n    let ni = Math.min(m + 1, n);\n    let s = new Float64Array(ni);\n    let U = new Matrix(m, nu);\n    let V = new Matrix(n, n);\n\n    let e = new Float64Array(n);\n    let work = new Float64Array(m);\n\n    let si = new Float64Array(ni);\n    for (let i = 0; i < ni; i++) si[i] = i;\n\n    let nct = Math.min(m - 1, n);\n    let nrt = Math.max(0, Math.min(n - 2, m));\n    let mrc = Math.max(nct, nrt);\n\n    for (let k = 0; k < mrc; k++) {\n      if (k < nct) {\n        s[k] = 0;\n        for (let i = k; i < m; i++) {\n          s[k] = hypotenuse(s[k], a.get(i, k));\n        }\n        if (s[k] !== 0) {\n          if (a.get(k, k) < 0) {\n            s[k] = -s[k];\n          }\n          for (let i = k; i < m; i++) {\n            a.set(i, k, a.get(i, k) / s[k]);\n          }\n          a.set(k, k, a.get(k, k) + 1);\n        }\n        s[k] = -s[k];\n      }\n\n      for (let j = k + 1; j < n; j++) {\n        if (k < nct && s[k] !== 0) {\n          let t = 0;\n          for (let i = k; i < m; i++) {\n            t += a.get(i, k) * a.get(i, j);\n          }\n          t = -t / a.get(k, k);\n          for (let i = k; i < m; i++) {\n            a.set(i, j, a.get(i, j) + t * a.get(i, k));\n          }\n        }\n        e[j] = a.get(k, j);\n      }\n\n      if (wantu && k < nct) {\n        for (let i = k; i < m; i++) {\n          U.set(i, k, a.get(i, k));\n        }\n      }\n\n      if (k < nrt) {\n        e[k] = 0;\n        for (let i = k + 1; i < n; i++) {\n          e[k] = hypotenuse(e[k], e[i]);\n        }\n        if (e[k] !== 0) {\n          if (e[k + 1] < 0) {\n            e[k] = 0 - e[k];\n          }\n          for (let i = k + 1; i < n; i++) {\n            e[i] /= e[k];\n          }\n          e[k + 1] += 1;\n        }\n        e[k] = -e[k];\n        if (k + 1 < m && e[k] !== 0) {\n          for (let i = k + 1; i < m; i++) {\n            work[i] = 0;\n          }\n          for (let i = k + 1; i < m; i++) {\n            for (let j = k + 1; j < n; j++) {\n              work[i] += e[j] * a.get(i, j);\n            }\n          }\n          for (let j = k + 1; j < n; j++) {\n            let t = -e[j] / e[k + 1];\n            for (let i = k + 1; i < m; i++) {\n              a.set(i, j, a.get(i, j) + t * work[i]);\n            }\n          }\n        }\n        if (wantv) {\n          for (let i = k + 1; i < n; i++) {\n            V.set(i, k, e[i]);\n          }\n        }\n      }\n    }\n\n    let p = Math.min(n, m + 1);\n    if (nct < n) {\n      s[nct] = a.get(nct, nct);\n    }\n    if (m < p) {\n      s[p - 1] = 0;\n    }\n    if (nrt + 1 < p) {\n      e[nrt] = a.get(nrt, p - 1);\n    }\n    e[p - 1] = 0;\n\n    if (wantu) {\n      for (let j = nct; j < nu; j++) {\n        for (let i = 0; i < m; i++) {\n          U.set(i, j, 0);\n        }\n        U.set(j, j, 1);\n      }\n      for (let k = nct - 1; k >= 0; k--) {\n        if (s[k] !== 0) {\n          for (let j = k + 1; j < nu; j++) {\n            let t = 0;\n            for (let i = k; i < m; i++) {\n              t += U.get(i, k) * U.get(i, j);\n            }\n            t = -t / U.get(k, k);\n            for (let i = k; i < m; i++) {\n              U.set(i, j, U.get(i, j) + t * U.get(i, k));\n            }\n          }\n          for (let i = k; i < m; i++) {\n            U.set(i, k, -U.get(i, k));\n          }\n          U.set(k, k, 1 + U.get(k, k));\n          for (let i = 0; i < k - 1; i++) {\n            U.set(i, k, 0);\n          }\n        } else {\n          for (let i = 0; i < m; i++) {\n            U.set(i, k, 0);\n          }\n          U.set(k, k, 1);\n        }\n      }\n    }\n\n    if (wantv) {\n      for (let k = n - 1; k >= 0; k--) {\n        if (k < nrt && e[k] !== 0) {\n          for (let j = k + 1; j < n; j++) {\n            let t = 0;\n            for (let i = k + 1; i < n; i++) {\n              t += V.get(i, k) * V.get(i, j);\n            }\n            t = -t / V.get(k + 1, k);\n            for (let i = k + 1; i < n; i++) {\n              V.set(i, j, V.get(i, j) + t * V.get(i, k));\n            }\n          }\n        }\n        for (let i = 0; i < n; i++) {\n          V.set(i, k, 0);\n        }\n        V.set(k, k, 1);\n      }\n    }\n\n    let pp = p - 1;\n    let eps = Number.EPSILON;\n    while (p > 0) {\n      let k, kase;\n      for (k = p - 2; k >= -1; k--) {\n        if (k === -1) {\n          break;\n        }\n        const alpha =\n          Number.MIN_VALUE + eps * Math.abs(s[k] + Math.abs(s[k + 1]));\n        if (Math.abs(e[k]) <= alpha || Number.isNaN(e[k])) {\n          e[k] = 0;\n          break;\n        }\n      }\n      if (k === p - 2) {\n        kase = 4;\n      } else {\n        let ks;\n        for (ks = p - 1; ks >= k; ks--) {\n          if (ks === k) {\n            break;\n          }\n          let t =\n            (ks !== p ? Math.abs(e[ks]) : 0) +\n            (ks !== k + 1 ? Math.abs(e[ks - 1]) : 0);\n          if (Math.abs(s[ks]) <= eps * t) {\n            s[ks] = 0;\n            break;\n          }\n        }\n        if (ks === k) {\n          kase = 3;\n        } else if (ks === p - 1) {\n          kase = 1;\n        } else {\n          kase = 2;\n          k = ks;\n        }\n      }\n\n      k++;\n\n      switch (kase) {\n        case 1: {\n          let f = e[p - 2];\n          e[p - 2] = 0;\n          for (let j = p - 2; j >= k; j--) {\n            let t = hypotenuse(s[j], f);\n            let cs = s[j] / t;\n            let sn = f / t;\n            s[j] = t;\n            if (j !== k) {\n              f = -sn * e[j - 1];\n              e[j - 1] = cs * e[j - 1];\n            }\n            if (wantv) {\n              for (let i = 0; i < n; i++) {\n                t = cs * V.get(i, j) + sn * V.get(i, p - 1);\n                V.set(i, p - 1, -sn * V.get(i, j) + cs * V.get(i, p - 1));\n                V.set(i, j, t);\n              }\n            }\n          }\n          break;\n        }\n        case 2: {\n          let f = e[k - 1];\n          e[k - 1] = 0;\n          for (let j = k; j < p; j++) {\n            let t = hypotenuse(s[j], f);\n            let cs = s[j] / t;\n            let sn = f / t;\n            s[j] = t;\n            f = -sn * e[j];\n            e[j] = cs * e[j];\n            if (wantu) {\n              for (let i = 0; i < m; i++) {\n                t = cs * U.get(i, j) + sn * U.get(i, k - 1);\n                U.set(i, k - 1, -sn * U.get(i, j) + cs * U.get(i, k - 1));\n                U.set(i, j, t);\n              }\n            }\n          }\n          break;\n        }\n        case 3: {\n          const scale = Math.max(\n            Math.abs(s[p - 1]),\n            Math.abs(s[p - 2]),\n            Math.abs(e[p - 2]),\n            Math.abs(s[k]),\n            Math.abs(e[k]),\n          );\n          const sp = s[p - 1] / scale;\n          const spm1 = s[p - 2] / scale;\n          const epm1 = e[p - 2] / scale;\n          const sk = s[k] / scale;\n          const ek = e[k] / scale;\n          const b = ((spm1 + sp) * (spm1 - sp) + epm1 * epm1) / 2;\n          const c = sp * epm1 * (sp * epm1);\n          let shift = 0;\n          if (b !== 0 || c !== 0) {\n            if (b < 0) {\n              shift = 0 - Math.sqrt(b * b + c);\n            } else {\n              shift = Math.sqrt(b * b + c);\n            }\n            shift = c / (b + shift);\n          }\n          let f = (sk + sp) * (sk - sp) + shift;\n          let g = sk * ek;\n          for (let j = k; j < p - 1; j++) {\n            let t = hypotenuse(f, g);\n            if (t === 0) t = Number.MIN_VALUE;\n            let cs = f / t;\n            let sn = g / t;\n            if (j !== k) {\n              e[j - 1] = t;\n            }\n            f = cs * s[j] + sn * e[j];\n            e[j] = cs * e[j] - sn * s[j];\n            g = sn * s[j + 1];\n            s[j + 1] = cs * s[j + 1];\n            if (wantv) {\n              for (let i = 0; i < n; i++) {\n                t = cs * V.get(i, j) + sn * V.get(i, j + 1);\n                V.set(i, j + 1, -sn * V.get(i, j) + cs * V.get(i, j + 1));\n                V.set(i, j, t);\n              }\n            }\n            t = hypotenuse(f, g);\n            if (t === 0) t = Number.MIN_VALUE;\n            cs = f / t;\n            sn = g / t;\n            s[j] = t;\n            f = cs * e[j] + sn * s[j + 1];\n            s[j + 1] = -sn * e[j] + cs * s[j + 1];\n            g = sn * e[j + 1];\n            e[j + 1] = cs * e[j + 1];\n            if (wantu && j < m - 1) {\n              for (let i = 0; i < m; i++) {\n                t = cs * U.get(i, j) + sn * U.get(i, j + 1);\n                U.set(i, j + 1, -sn * U.get(i, j) + cs * U.get(i, j + 1));\n                U.set(i, j, t);\n              }\n            }\n          }\n          e[p - 2] = f;\n          break;\n        }\n        case 4: {\n          if (s[k] <= 0) {\n            s[k] = s[k] < 0 ? -s[k] : 0;\n            if (wantv) {\n              for (let i = 0; i <= pp; i++) {\n                V.set(i, k, -V.get(i, k));\n              }\n            }\n          }\n          while (k < pp) {\n            if (s[k] >= s[k + 1]) {\n              break;\n            }\n            let t = s[k];\n            s[k] = s[k + 1];\n            s[k + 1] = t;\n            if (wantv && k < n - 1) {\n              for (let i = 0; i < n; i++) {\n                t = V.get(i, k + 1);\n                V.set(i, k + 1, V.get(i, k));\n                V.set(i, k, t);\n              }\n            }\n            if (wantu && k < m - 1) {\n              for (let i = 0; i < m; i++) {\n                t = U.get(i, k + 1);\n                U.set(i, k + 1, U.get(i, k));\n                U.set(i, k, t);\n              }\n            }\n            k++;\n          }\n          p--;\n          break;\n        }\n        // no default\n      }\n    }\n\n    if (swapped) {\n      let tmp = V;\n      V = U;\n      U = tmp;\n    }\n\n    this.m = m;\n    this.n = n;\n    this.s = s;\n    this.U = U;\n    this.V = V;\n  }\n\n  solve(value) {\n    let Y = value;\n    let e = this.threshold;\n    let scols = this.s.length;\n    let Ls = Matrix.zeros(scols, scols);\n\n    for (let i = 0; i < scols; i++) {\n      if (Math.abs(this.s[i]) <= e) {\n        Ls.set(i, i, 0);\n      } else {\n        Ls.set(i, i, 1 / this.s[i]);\n      }\n    }\n\n    let U = this.U;\n    let V = this.rightSingularVectors;\n\n    let VL = V.mmul(Ls);\n    let vrows = V.rows;\n    let urows = U.rows;\n    let VLU = Matrix.zeros(vrows, urows);\n\n    for (let i = 0; i < vrows; i++) {\n      for (let j = 0; j < urows; j++) {\n        let sum = 0;\n        for (let k = 0; k < scols; k++) {\n          sum += VL.get(i, k) * U.get(j, k);\n        }\n        VLU.set(i, j, sum);\n      }\n    }\n\n    return VLU.mmul(Y);\n  }\n\n  solveForDiagonal(value) {\n    return this.solve(Matrix.diag(value));\n  }\n\n  inverse() {\n    let V = this.V;\n    let e = this.threshold;\n    let vrows = V.rows;\n    let vcols = V.columns;\n    let X = new Matrix(vrows, this.s.length);\n\n    for (let i = 0; i < vrows; i++) {\n      for (let j = 0; j < vcols; j++) {\n        if (Math.abs(this.s[j]) > e) {\n          X.set(i, j, V.get(i, j) / this.s[j]);\n        }\n      }\n    }\n\n    let U = this.U;\n\n    let urows = U.rows;\n    let ucols = U.columns;\n    let Y = new Matrix(vrows, urows);\n\n    for (let i = 0; i < vrows; i++) {\n      for (let j = 0; j < urows; j++) {\n        let sum = 0;\n        for (let k = 0; k < ucols; k++) {\n          sum += X.get(i, k) * U.get(j, k);\n        }\n        Y.set(i, j, sum);\n      }\n    }\n\n    return Y;\n  }\n\n  get condition() {\n    return this.s[0] / this.s[Math.min(this.m, this.n) - 1];\n  }\n\n  get norm2() {\n    return this.s[0];\n  }\n\n  get rank() {\n    let tol = Math.max(this.m, this.n) * this.s[0] * Number.EPSILON;\n    let r = 0;\n    let s = this.s;\n    for (let i = 0, ii = s.length; i < ii; i++) {\n      if (s[i] > tol) {\n        r++;\n      }\n    }\n    return r;\n  }\n\n  get diagonal() {\n    return Array.from(this.s);\n  }\n\n  get threshold() {\n    return (Number.EPSILON / 2) * Math.max(this.m, this.n) * this.s[0];\n  }\n\n  get leftSingularVectors() {\n    return this.U;\n  }\n\n  get rightSingularVectors() {\n    return this.V;\n  }\n\n  get diagonalMatrix() {\n    return Matrix.diag(this.s);\n  }\n}\n\nfunction inverse(matrix, useSVD = false) {\n  matrix = WrapperMatrix2D.checkMatrix(matrix);\n  if (useSVD) {\n    return new SingularValueDecomposition(matrix).inverse();\n  } else {\n    return solve(matrix, Matrix.eye(matrix.rows));\n  }\n}\n\nfunction solve(leftHandSide, rightHandSide, useSVD = false) {\n  leftHandSide = WrapperMatrix2D.checkMatrix(leftHandSide);\n  rightHandSide = WrapperMatrix2D.checkMatrix(rightHandSide);\n  if (useSVD) {\n    return new SingularValueDecomposition(leftHandSide).solve(rightHandSide);\n  } else {\n    return leftHandSide.isSquare()\n      ? new LuDecomposition(leftHandSide).solve(rightHandSide)\n      : new QrDecomposition(leftHandSide).solve(rightHandSide);\n  }\n}\n\nfunction determinant(matrix) {\n  matrix = Matrix.checkMatrix(matrix);\n  if (matrix.isSquare()) {\n    if (matrix.columns === 0) {\n      return 1;\n    }\n\n    let a, b, c, d;\n    if (matrix.columns === 2) {\n      // 2 x 2 matrix\n      a = matrix.get(0, 0);\n      b = matrix.get(0, 1);\n      c = matrix.get(1, 0);\n      d = matrix.get(1, 1);\n\n      return a * d - b * c;\n    } else if (matrix.columns === 3) {\n      // 3 x 3 matrix\n      let subMatrix0, subMatrix1, subMatrix2;\n      subMatrix0 = new MatrixSelectionView(matrix, [1, 2], [1, 2]);\n      subMatrix1 = new MatrixSelectionView(matrix, [1, 2], [0, 2]);\n      subMatrix2 = new MatrixSelectionView(matrix, [1, 2], [0, 1]);\n      a = matrix.get(0, 0);\n      b = matrix.get(0, 1);\n      c = matrix.get(0, 2);\n\n      return (\n        a * determinant(subMatrix0) -\n        b * determinant(subMatrix1) +\n        c * determinant(subMatrix2)\n      );\n    } else {\n      // general purpose determinant using the LU decomposition\n      return new LuDecomposition(matrix).determinant;\n    }\n  } else {\n    throw Error('determinant can only be calculated for a square matrix');\n  }\n}\n\nfunction xrange(n, exception) {\n  let range = [];\n  for (let i = 0; i < n; i++) {\n    if (i !== exception) {\n      range.push(i);\n    }\n  }\n  return range;\n}\n\nfunction dependenciesOneRow(\n  error,\n  matrix,\n  index,\n  thresholdValue = 10e-10,\n  thresholdError = 10e-10,\n) {\n  if (error > thresholdError) {\n    return new Array(matrix.rows + 1).fill(0);\n  } else {\n    let returnArray = matrix.addRow(index, [0]);\n    for (let i = 0; i < returnArray.rows; i++) {\n      if (Math.abs(returnArray.get(i, 0)) < thresholdValue) {\n        returnArray.set(i, 0, 0);\n      }\n    }\n    return returnArray.to1DArray();\n  }\n}\n\nfunction linearDependencies(matrix, options = {}) {\n  const { thresholdValue = 10e-10, thresholdError = 10e-10 } = options;\n  matrix = Matrix.checkMatrix(matrix);\n\n  let n = matrix.rows;\n  let results = new Matrix(n, n);\n\n  for (let i = 0; i < n; i++) {\n    let b = Matrix.columnVector(matrix.getRow(i));\n    let Abis = matrix.subMatrixRow(xrange(n, i)).transpose();\n    let svd = new SingularValueDecomposition(Abis);\n    let x = svd.solve(b);\n    let error = Matrix.sub(b, Abis.mmul(x)).abs().max();\n    results.setRow(\n      i,\n      dependenciesOneRow(error, x, i, thresholdValue, thresholdError),\n    );\n  }\n  return results;\n}\n\nfunction pseudoInverse(matrix, threshold = Number.EPSILON) {\n  matrix = Matrix.checkMatrix(matrix);\n  if (matrix.isEmpty()) {\n    // with a zero dimension, the pseudo-inverse is the transpose, since all 0xn and nx0 matrices are singular\n    // (0xn)*(nx0)*(0xn) = 0xn\n    // (nx0)*(0xn)*(nx0) = nx0\n    return matrix.transpose();\n  }\n  let svdSolution = new SingularValueDecomposition(matrix, { autoTranspose: true });\n\n  let U = svdSolution.leftSingularVectors;\n  let V = svdSolution.rightSingularVectors;\n  let s = svdSolution.diagonal;\n\n  for (let i = 0; i < s.length; i++) {\n    if (Math.abs(s[i]) > threshold) {\n      s[i] = 1.0 / s[i];\n    } else {\n      s[i] = 0.0;\n    }\n  }\n\n  return V.mmul(Matrix.diag(s).mmul(U.transpose()));\n}\n\nfunction covariance(xMatrix, yMatrix = xMatrix, options = {}) {\n  xMatrix = new Matrix(xMatrix);\n  let yIsSame = false;\n  if (\n    typeof yMatrix === 'object' &&\n    !Matrix.isMatrix(yMatrix) &&\n    !isAnyArray.isAnyArray(yMatrix)\n  ) {\n    options = yMatrix;\n    yMatrix = xMatrix;\n    yIsSame = true;\n  } else {\n    yMatrix = new Matrix(yMatrix);\n  }\n  if (xMatrix.rows !== yMatrix.rows) {\n    throw new TypeError('Both matrices must have the same number of rows');\n  }\n  const { center = true } = options;\n  if (center) {\n    xMatrix = xMatrix.center('column');\n    if (!yIsSame) {\n      yMatrix = yMatrix.center('column');\n    }\n  }\n  const cov = xMatrix.transpose().mmul(yMatrix);\n  for (let i = 0; i < cov.rows; i++) {\n    for (let j = 0; j < cov.columns; j++) {\n      cov.set(i, j, cov.get(i, j) * (1 / (xMatrix.rows - 1)));\n    }\n  }\n  return cov;\n}\n\nfunction correlation(xMatrix, yMatrix = xMatrix, options = {}) {\n  xMatrix = new Matrix(xMatrix);\n  let yIsSame = false;\n  if (\n    typeof yMatrix === 'object' &&\n    !Matrix.isMatrix(yMatrix) &&\n    !isAnyArray.isAnyArray(yMatrix)\n  ) {\n    options = yMatrix;\n    yMatrix = xMatrix;\n    yIsSame = true;\n  } else {\n    yMatrix = new Matrix(yMatrix);\n  }\n  if (xMatrix.rows !== yMatrix.rows) {\n    throw new TypeError('Both matrices must have the same number of rows');\n  }\n\n  const { center = true, scale = true } = options;\n  if (center) {\n    xMatrix.center('column');\n    if (!yIsSame) {\n      yMatrix.center('column');\n    }\n  }\n  if (scale) {\n    xMatrix.scale('column');\n    if (!yIsSame) {\n      yMatrix.scale('column');\n    }\n  }\n\n  const sdx = xMatrix.standardDeviation('column', { unbiased: true });\n  const sdy = yIsSame\n    ? sdx\n    : yMatrix.standardDeviation('column', { unbiased: true });\n\n  const corr = xMatrix.transpose().mmul(yMatrix);\n  for (let i = 0; i < corr.rows; i++) {\n    for (let j = 0; j < corr.columns; j++) {\n      corr.set(\n        i,\n        j,\n        corr.get(i, j) * (1 / (sdx[i] * sdy[j])) * (1 / (xMatrix.rows - 1)),\n      );\n    }\n  }\n  return corr;\n}\n\nclass EigenvalueDecomposition {\n  constructor(matrix, options = {}) {\n    const { assumeSymmetric = false } = options;\n\n    matrix = WrapperMatrix2D.checkMatrix(matrix);\n    if (!matrix.isSquare()) {\n      throw new Error('Matrix is not a square matrix');\n    }\n\n    if (matrix.isEmpty()) {\n      throw new Error('Matrix must be non-empty');\n    }\n\n    let n = matrix.columns;\n    let V = new Matrix(n, n);\n    let d = new Float64Array(n);\n    let e = new Float64Array(n);\n    let value = matrix;\n    let i, j;\n\n    let isSymmetric = false;\n    if (assumeSymmetric) {\n      isSymmetric = true;\n    } else {\n      isSymmetric = matrix.isSymmetric();\n    }\n\n    if (isSymmetric) {\n      for (i = 0; i < n; i++) {\n        for (j = 0; j < n; j++) {\n          V.set(i, j, value.get(i, j));\n        }\n      }\n      tred2(n, e, d, V);\n      tql2(n, e, d, V);\n    } else {\n      let H = new Matrix(n, n);\n      let ort = new Float64Array(n);\n      for (j = 0; j < n; j++) {\n        for (i = 0; i < n; i++) {\n          H.set(i, j, value.get(i, j));\n        }\n      }\n      orthes(n, H, ort, V);\n      hqr2(n, e, d, V, H);\n    }\n\n    this.n = n;\n    this.e = e;\n    this.d = d;\n    this.V = V;\n  }\n\n  get realEigenvalues() {\n    return Array.from(this.d);\n  }\n\n  get imaginaryEigenvalues() {\n    return Array.from(this.e);\n  }\n\n  get eigenvectorMatrix() {\n    return this.V;\n  }\n\n  get diagonalMatrix() {\n    let n = this.n;\n    let e = this.e;\n    let d = this.d;\n    let X = new Matrix(n, n);\n    let i, j;\n    for (i = 0; i < n; i++) {\n      for (j = 0; j < n; j++) {\n        X.set(i, j, 0);\n      }\n      X.set(i, i, d[i]);\n      if (e[i] > 0) {\n        X.set(i, i + 1, e[i]);\n      } else if (e[i] < 0) {\n        X.set(i, i - 1, e[i]);\n      }\n    }\n    return X;\n  }\n}\n\nfunction tred2(n, e, d, V) {\n  let f, g, h, i, j, k, hh, scale;\n\n  for (j = 0; j < n; j++) {\n    d[j] = V.get(n - 1, j);\n  }\n\n  for (i = n - 1; i > 0; i--) {\n    scale = 0;\n    h = 0;\n    for (k = 0; k < i; k++) {\n      scale = scale + Math.abs(d[k]);\n    }\n\n    if (scale === 0) {\n      e[i] = d[i - 1];\n      for (j = 0; j < i; j++) {\n        d[j] = V.get(i - 1, j);\n        V.set(i, j, 0);\n        V.set(j, i, 0);\n      }\n    } else {\n      for (k = 0; k < i; k++) {\n        d[k] /= scale;\n        h += d[k] * d[k];\n      }\n\n      f = d[i - 1];\n      g = Math.sqrt(h);\n      if (f > 0) {\n        g = -g;\n      }\n\n      e[i] = scale * g;\n      h = h - f * g;\n      d[i - 1] = f - g;\n      for (j = 0; j < i; j++) {\n        e[j] = 0;\n      }\n\n      for (j = 0; j < i; j++) {\n        f = d[j];\n        V.set(j, i, f);\n        g = e[j] + V.get(j, j) * f;\n        for (k = j + 1; k <= i - 1; k++) {\n          g += V.get(k, j) * d[k];\n          e[k] += V.get(k, j) * f;\n        }\n        e[j] = g;\n      }\n\n      f = 0;\n      for (j = 0; j < i; j++) {\n        e[j] /= h;\n        f += e[j] * d[j];\n      }\n\n      hh = f / (h + h);\n      for (j = 0; j < i; j++) {\n        e[j] -= hh * d[j];\n      }\n\n      for (j = 0; j < i; j++) {\n        f = d[j];\n        g = e[j];\n        for (k = j; k <= i - 1; k++) {\n          V.set(k, j, V.get(k, j) - (f * e[k] + g * d[k]));\n        }\n        d[j] = V.get(i - 1, j);\n        V.set(i, j, 0);\n      }\n    }\n    d[i] = h;\n  }\n\n  for (i = 0; i < n - 1; i++) {\n    V.set(n - 1, i, V.get(i, i));\n    V.set(i, i, 1);\n    h = d[i + 1];\n    if (h !== 0) {\n      for (k = 0; k <= i; k++) {\n        d[k] = V.get(k, i + 1) / h;\n      }\n\n      for (j = 0; j <= i; j++) {\n        g = 0;\n        for (k = 0; k <= i; k++) {\n          g += V.get(k, i + 1) * V.get(k, j);\n        }\n        for (k = 0; k <= i; k++) {\n          V.set(k, j, V.get(k, j) - g * d[k]);\n        }\n      }\n    }\n\n    for (k = 0; k <= i; k++) {\n      V.set(k, i + 1, 0);\n    }\n  }\n\n  for (j = 0; j < n; j++) {\n    d[j] = V.get(n - 1, j);\n    V.set(n - 1, j, 0);\n  }\n\n  V.set(n - 1, n - 1, 1);\n  e[0] = 0;\n}\n\nfunction tql2(n, e, d, V) {\n  let g, h, i, j, k, l, m, p, r, dl1, c, c2, c3, el1, s, s2;\n\n  for (i = 1; i < n; i++) {\n    e[i - 1] = e[i];\n  }\n\n  e[n - 1] = 0;\n\n  let f = 0;\n  let tst1 = 0;\n  let eps = Number.EPSILON;\n\n  for (l = 0; l < n; l++) {\n    tst1 = Math.max(tst1, Math.abs(d[l]) + Math.abs(e[l]));\n    m = l;\n    while (m < n) {\n      if (Math.abs(e[m]) <= eps * tst1) {\n        break;\n      }\n      m++;\n    }\n\n    if (m > l) {\n      do {\n\n        g = d[l];\n        p = (d[l + 1] - g) / (2 * e[l]);\n        r = hypotenuse(p, 1);\n        if (p < 0) {\n          r = -r;\n        }\n\n        d[l] = e[l] / (p + r);\n        d[l + 1] = e[l] * (p + r);\n        dl1 = d[l + 1];\n        h = g - d[l];\n        for (i = l + 2; i < n; i++) {\n          d[i] -= h;\n        }\n\n        f = f + h;\n\n        p = d[m];\n        c = 1;\n        c2 = c;\n        c3 = c;\n        el1 = e[l + 1];\n        s = 0;\n        s2 = 0;\n        for (i = m - 1; i >= l; i--) {\n          c3 = c2;\n          c2 = c;\n          s2 = s;\n          g = c * e[i];\n          h = c * p;\n          r = hypotenuse(p, e[i]);\n          e[i + 1] = s * r;\n          s = e[i] / r;\n          c = p / r;\n          p = c * d[i] - s * g;\n          d[i + 1] = h + s * (c * g + s * d[i]);\n\n          for (k = 0; k < n; k++) {\n            h = V.get(k, i + 1);\n            V.set(k, i + 1, s * V.get(k, i) + c * h);\n            V.set(k, i, c * V.get(k, i) - s * h);\n          }\n        }\n\n        p = (-s * s2 * c3 * el1 * e[l]) / dl1;\n        e[l] = s * p;\n        d[l] = c * p;\n      } while (Math.abs(e[l]) > eps * tst1);\n    }\n    d[l] = d[l] + f;\n    e[l] = 0;\n  }\n\n  for (i = 0; i < n - 1; i++) {\n    k = i;\n    p = d[i];\n    for (j = i + 1; j < n; j++) {\n      if (d[j] < p) {\n        k = j;\n        p = d[j];\n      }\n    }\n\n    if (k !== i) {\n      d[k] = d[i];\n      d[i] = p;\n      for (j = 0; j < n; j++) {\n        p = V.get(j, i);\n        V.set(j, i, V.get(j, k));\n        V.set(j, k, p);\n      }\n    }\n  }\n}\n\nfunction orthes(n, H, ort, V) {\n  let low = 0;\n  let high = n - 1;\n  let f, g, h, i, j, m;\n  let scale;\n\n  for (m = low + 1; m <= high - 1; m++) {\n    scale = 0;\n    for (i = m; i <= high; i++) {\n      scale = scale + Math.abs(H.get(i, m - 1));\n    }\n\n    if (scale !== 0) {\n      h = 0;\n      for (i = high; i >= m; i--) {\n        ort[i] = H.get(i, m - 1) / scale;\n        h += ort[i] * ort[i];\n      }\n\n      g = Math.sqrt(h);\n      if (ort[m] > 0) {\n        g = -g;\n      }\n\n      h = h - ort[m] * g;\n      ort[m] = ort[m] - g;\n\n      for (j = m; j < n; j++) {\n        f = 0;\n        for (i = high; i >= m; i--) {\n          f += ort[i] * H.get(i, j);\n        }\n\n        f = f / h;\n        for (i = m; i <= high; i++) {\n          H.set(i, j, H.get(i, j) - f * ort[i]);\n        }\n      }\n\n      for (i = 0; i <= high; i++) {\n        f = 0;\n        for (j = high; j >= m; j--) {\n          f += ort[j] * H.get(i, j);\n        }\n\n        f = f / h;\n        for (j = m; j <= high; j++) {\n          H.set(i, j, H.get(i, j) - f * ort[j]);\n        }\n      }\n\n      ort[m] = scale * ort[m];\n      H.set(m, m - 1, scale * g);\n    }\n  }\n\n  for (i = 0; i < n; i++) {\n    for (j = 0; j < n; j++) {\n      V.set(i, j, i === j ? 1 : 0);\n    }\n  }\n\n  for (m = high - 1; m >= low + 1; m--) {\n    if (H.get(m, m - 1) !== 0) {\n      for (i = m + 1; i <= high; i++) {\n        ort[i] = H.get(i, m - 1);\n      }\n\n      for (j = m; j <= high; j++) {\n        g = 0;\n        for (i = m; i <= high; i++) {\n          g += ort[i] * V.get(i, j);\n        }\n\n        g = g / ort[m] / H.get(m, m - 1);\n        for (i = m; i <= high; i++) {\n          V.set(i, j, V.get(i, j) + g * ort[i]);\n        }\n      }\n    }\n  }\n}\n\nfunction hqr2(nn, e, d, V, H) {\n  let n = nn - 1;\n  let low = 0;\n  let high = nn - 1;\n  let eps = Number.EPSILON;\n  let exshift = 0;\n  let norm = 0;\n  let p = 0;\n  let q = 0;\n  let r = 0;\n  let s = 0;\n  let z = 0;\n  let iter = 0;\n  let i, j, k, l, m, t, w, x, y;\n  let ra, sa, vr, vi;\n  let notlast, cdivres;\n\n  for (i = 0; i < nn; i++) {\n    if (i < low || i > high) {\n      d[i] = H.get(i, i);\n      e[i] = 0;\n    }\n\n    for (j = Math.max(i - 1, 0); j < nn; j++) {\n      norm = norm + Math.abs(H.get(i, j));\n    }\n  }\n\n  while (n >= low) {\n    l = n;\n    while (l > low) {\n      s = Math.abs(H.get(l - 1, l - 1)) + Math.abs(H.get(l, l));\n      if (s === 0) {\n        s = norm;\n      }\n      if (Math.abs(H.get(l, l - 1)) < eps * s) {\n        break;\n      }\n      l--;\n    }\n\n    if (l === n) {\n      H.set(n, n, H.get(n, n) + exshift);\n      d[n] = H.get(n, n);\n      e[n] = 0;\n      n--;\n      iter = 0;\n    } else if (l === n - 1) {\n      w = H.get(n, n - 1) * H.get(n - 1, n);\n      p = (H.get(n - 1, n - 1) - H.get(n, n)) / 2;\n      q = p * p + w;\n      z = Math.sqrt(Math.abs(q));\n      H.set(n, n, H.get(n, n) + exshift);\n      H.set(n - 1, n - 1, H.get(n - 1, n - 1) + exshift);\n      x = H.get(n, n);\n\n      if (q >= 0) {\n        z = p >= 0 ? p + z : p - z;\n        d[n - 1] = x + z;\n        d[n] = d[n - 1];\n        if (z !== 0) {\n          d[n] = x - w / z;\n        }\n        e[n - 1] = 0;\n        e[n] = 0;\n        x = H.get(n, n - 1);\n        s = Math.abs(x) + Math.abs(z);\n        p = x / s;\n        q = z / s;\n        r = Math.sqrt(p * p + q * q);\n        p = p / r;\n        q = q / r;\n\n        for (j = n - 1; j < nn; j++) {\n          z = H.get(n - 1, j);\n          H.set(n - 1, j, q * z + p * H.get(n, j));\n          H.set(n, j, q * H.get(n, j) - p * z);\n        }\n\n        for (i = 0; i <= n; i++) {\n          z = H.get(i, n - 1);\n          H.set(i, n - 1, q * z + p * H.get(i, n));\n          H.set(i, n, q * H.get(i, n) - p * z);\n        }\n\n        for (i = low; i <= high; i++) {\n          z = V.get(i, n - 1);\n          V.set(i, n - 1, q * z + p * V.get(i, n));\n          V.set(i, n, q * V.get(i, n) - p * z);\n        }\n      } else {\n        d[n - 1] = x + p;\n        d[n] = x + p;\n        e[n - 1] = z;\n        e[n] = -z;\n      }\n\n      n = n - 2;\n      iter = 0;\n    } else {\n      x = H.get(n, n);\n      y = 0;\n      w = 0;\n      if (l < n) {\n        y = H.get(n - 1, n - 1);\n        w = H.get(n, n - 1) * H.get(n - 1, n);\n      }\n\n      if (iter === 10) {\n        exshift += x;\n        for (i = low; i <= n; i++) {\n          H.set(i, i, H.get(i, i) - x);\n        }\n        s = Math.abs(H.get(n, n - 1)) + Math.abs(H.get(n - 1, n - 2));\n        // eslint-disable-next-line no-multi-assign\n        x = y = 0.75 * s;\n        w = -0.4375 * s * s;\n      }\n\n      if (iter === 30) {\n        s = (y - x) / 2;\n        s = s * s + w;\n        if (s > 0) {\n          s = Math.sqrt(s);\n          if (y < x) {\n            s = -s;\n          }\n          s = x - w / ((y - x) / 2 + s);\n          for (i = low; i <= n; i++) {\n            H.set(i, i, H.get(i, i) - s);\n          }\n          exshift += s;\n          // eslint-disable-next-line no-multi-assign\n          x = y = w = 0.964;\n        }\n      }\n\n      iter = iter + 1;\n\n      m = n - 2;\n      while (m >= l) {\n        z = H.get(m, m);\n        r = x - z;\n        s = y - z;\n        p = (r * s - w) / H.get(m + 1, m) + H.get(m, m + 1);\n        q = H.get(m + 1, m + 1) - z - r - s;\n        r = H.get(m + 2, m + 1);\n        s = Math.abs(p) + Math.abs(q) + Math.abs(r);\n        p = p / s;\n        q = q / s;\n        r = r / s;\n        if (m === l) {\n          break;\n        }\n        if (\n          Math.abs(H.get(m, m - 1)) * (Math.abs(q) + Math.abs(r)) <\n          eps *\n            (Math.abs(p) *\n              (Math.abs(H.get(m - 1, m - 1)) +\n                Math.abs(z) +\n                Math.abs(H.get(m + 1, m + 1))))\n        ) {\n          break;\n        }\n        m--;\n      }\n\n      for (i = m + 2; i <= n; i++) {\n        H.set(i, i - 2, 0);\n        if (i > m + 2) {\n          H.set(i, i - 3, 0);\n        }\n      }\n\n      for (k = m; k <= n - 1; k++) {\n        notlast = k !== n - 1;\n        if (k !== m) {\n          p = H.get(k, k - 1);\n          q = H.get(k + 1, k - 1);\n          r = notlast ? H.get(k + 2, k - 1) : 0;\n          x = Math.abs(p) + Math.abs(q) + Math.abs(r);\n          if (x !== 0) {\n            p = p / x;\n            q = q / x;\n            r = r / x;\n          }\n        }\n\n        if (x === 0) {\n          break;\n        }\n\n        s = Math.sqrt(p * p + q * q + r * r);\n        if (p < 0) {\n          s = -s;\n        }\n\n        if (s !== 0) {\n          if (k !== m) {\n            H.set(k, k - 1, -s * x);\n          } else if (l !== m) {\n            H.set(k, k - 1, -H.get(k, k - 1));\n          }\n\n          p = p + s;\n          x = p / s;\n          y = q / s;\n          z = r / s;\n          q = q / p;\n          r = r / p;\n\n          for (j = k; j < nn; j++) {\n            p = H.get(k, j) + q * H.get(k + 1, j);\n            if (notlast) {\n              p = p + r * H.get(k + 2, j);\n              H.set(k + 2, j, H.get(k + 2, j) - p * z);\n            }\n\n            H.set(k, j, H.get(k, j) - p * x);\n            H.set(k + 1, j, H.get(k + 1, j) - p * y);\n          }\n\n          for (i = 0; i <= Math.min(n, k + 3); i++) {\n            p = x * H.get(i, k) + y * H.get(i, k + 1);\n            if (notlast) {\n              p = p + z * H.get(i, k + 2);\n              H.set(i, k + 2, H.get(i, k + 2) - p * r);\n            }\n\n            H.set(i, k, H.get(i, k) - p);\n            H.set(i, k + 1, H.get(i, k + 1) - p * q);\n          }\n\n          for (i = low; i <= high; i++) {\n            p = x * V.get(i, k) + y * V.get(i, k + 1);\n            if (notlast) {\n              p = p + z * V.get(i, k + 2);\n              V.set(i, k + 2, V.get(i, k + 2) - p * r);\n            }\n\n            V.set(i, k, V.get(i, k) - p);\n            V.set(i, k + 1, V.get(i, k + 1) - p * q);\n          }\n        }\n      }\n    }\n  }\n\n  if (norm === 0) {\n    return;\n  }\n\n  for (n = nn - 1; n >= 0; n--) {\n    p = d[n];\n    q = e[n];\n\n    if (q === 0) {\n      l = n;\n      H.set(n, n, 1);\n      for (i = n - 1; i >= 0; i--) {\n        w = H.get(i, i) - p;\n        r = 0;\n        for (j = l; j <= n; j++) {\n          r = r + H.get(i, j) * H.get(j, n);\n        }\n\n        if (e[i] < 0) {\n          z = w;\n          s = r;\n        } else {\n          l = i;\n          if (e[i] === 0) {\n            H.set(i, n, w !== 0 ? -r / w : -r / (eps * norm));\n          } else {\n            x = H.get(i, i + 1);\n            y = H.get(i + 1, i);\n            q = (d[i] - p) * (d[i] - p) + e[i] * e[i];\n            t = (x * s - z * r) / q;\n            H.set(i, n, t);\n            H.set(\n              i + 1,\n              n,\n              Math.abs(x) > Math.abs(z) ? (-r - w * t) / x : (-s - y * t) / z,\n            );\n          }\n\n          t = Math.abs(H.get(i, n));\n          if (eps * t * t > 1) {\n            for (j = i; j <= n; j++) {\n              H.set(j, n, H.get(j, n) / t);\n            }\n          }\n        }\n      }\n    } else if (q < 0) {\n      l = n - 1;\n\n      if (Math.abs(H.get(n, n - 1)) > Math.abs(H.get(n - 1, n))) {\n        H.set(n - 1, n - 1, q / H.get(n, n - 1));\n        H.set(n - 1, n, -(H.get(n, n) - p) / H.get(n, n - 1));\n      } else {\n        cdivres = cdiv(0, -H.get(n - 1, n), H.get(n - 1, n - 1) - p, q);\n        H.set(n - 1, n - 1, cdivres[0]);\n        H.set(n - 1, n, cdivres[1]);\n      }\n\n      H.set(n, n - 1, 0);\n      H.set(n, n, 1);\n      for (i = n - 2; i >= 0; i--) {\n        ra = 0;\n        sa = 0;\n        for (j = l; j <= n; j++) {\n          ra = ra + H.get(i, j) * H.get(j, n - 1);\n          sa = sa + H.get(i, j) * H.get(j, n);\n        }\n\n        w = H.get(i, i) - p;\n\n        if (e[i] < 0) {\n          z = w;\n          r = ra;\n          s = sa;\n        } else {\n          l = i;\n          if (e[i] === 0) {\n            cdivres = cdiv(-ra, -sa, w, q);\n            H.set(i, n - 1, cdivres[0]);\n            H.set(i, n, cdivres[1]);\n          } else {\n            x = H.get(i, i + 1);\n            y = H.get(i + 1, i);\n            vr = (d[i] - p) * (d[i] - p) + e[i] * e[i] - q * q;\n            vi = (d[i] - p) * 2 * q;\n            if (vr === 0 && vi === 0) {\n              vr =\n                eps *\n                norm *\n                (Math.abs(w) +\n                  Math.abs(q) +\n                  Math.abs(x) +\n                  Math.abs(y) +\n                  Math.abs(z));\n            }\n            cdivres = cdiv(\n              x * r - z * ra + q * sa,\n              x * s - z * sa - q * ra,\n              vr,\n              vi,\n            );\n            H.set(i, n - 1, cdivres[0]);\n            H.set(i, n, cdivres[1]);\n            if (Math.abs(x) > Math.abs(z) + Math.abs(q)) {\n              H.set(\n                i + 1,\n                n - 1,\n                (-ra - w * H.get(i, n - 1) + q * H.get(i, n)) / x,\n              );\n              H.set(\n                i + 1,\n                n,\n                (-sa - w * H.get(i, n) - q * H.get(i, n - 1)) / x,\n              );\n            } else {\n              cdivres = cdiv(\n                -r - y * H.get(i, n - 1),\n                -s - y * H.get(i, n),\n                z,\n                q,\n              );\n              H.set(i + 1, n - 1, cdivres[0]);\n              H.set(i + 1, n, cdivres[1]);\n            }\n          }\n\n          t = Math.max(Math.abs(H.get(i, n - 1)), Math.abs(H.get(i, n)));\n          if (eps * t * t > 1) {\n            for (j = i; j <= n; j++) {\n              H.set(j, n - 1, H.get(j, n - 1) / t);\n              H.set(j, n, H.get(j, n) / t);\n            }\n          }\n        }\n      }\n    }\n  }\n\n  for (i = 0; i < nn; i++) {\n    if (i < low || i > high) {\n      for (j = i; j < nn; j++) {\n        V.set(i, j, H.get(i, j));\n      }\n    }\n  }\n\n  for (j = nn - 1; j >= low; j--) {\n    for (i = low; i <= high; i++) {\n      z = 0;\n      for (k = low; k <= Math.min(j, high); k++) {\n        z = z + V.get(i, k) * H.get(k, j);\n      }\n      V.set(i, j, z);\n    }\n  }\n}\n\nfunction cdiv(xr, xi, yr, yi) {\n  let r, d;\n  if (Math.abs(yr) > Math.abs(yi)) {\n    r = yi / yr;\n    d = yr + r * yi;\n    return [(xr + r * xi) / d, (xi - r * xr) / d];\n  } else {\n    r = yr / yi;\n    d = yi + r * yr;\n    return [(r * xr + xi) / d, (r * xi - xr) / d];\n  }\n}\n\nclass CholeskyDecomposition {\n  constructor(value) {\n    value = WrapperMatrix2D.checkMatrix(value);\n    if (!value.isSymmetric()) {\n      throw new Error('Matrix is not symmetric');\n    }\n\n    let a = value;\n    let dimension = a.rows;\n    let l = new Matrix(dimension, dimension);\n    let positiveDefinite = true;\n    let i, j, k;\n\n    for (j = 0; j < dimension; j++) {\n      let d = 0;\n      for (k = 0; k < j; k++) {\n        let s = 0;\n        for (i = 0; i < k; i++) {\n          s += l.get(k, i) * l.get(j, i);\n        }\n        s = (a.get(j, k) - s) / l.get(k, k);\n        l.set(j, k, s);\n        d = d + s * s;\n      }\n\n      d = a.get(j, j) - d;\n\n      positiveDefinite &&= d > 0;\n      l.set(j, j, Math.sqrt(Math.max(d, 0)));\n      for (k = j + 1; k < dimension; k++) {\n        l.set(j, k, 0);\n      }\n    }\n\n    this.L = l;\n    this.positiveDefinite = positiveDefinite;\n  }\n\n  isPositiveDefinite() {\n    return this.positiveDefinite;\n  }\n\n  solve(value) {\n    value = WrapperMatrix2D.checkMatrix(value);\n\n    let l = this.L;\n    let dimension = l.rows;\n\n    if (value.rows !== dimension) {\n      throw new Error('Matrix dimensions do not match');\n    }\n    if (this.isPositiveDefinite() === false) {\n      throw new Error('Matrix is not positive definite');\n    }\n\n    let count = value.columns;\n    let B = value.clone();\n    let i, j, k;\n\n    for (k = 0; k < dimension; k++) {\n      for (j = 0; j < count; j++) {\n        for (i = 0; i < k; i++) {\n          B.set(k, j, B.get(k, j) - B.get(i, j) * l.get(k, i));\n        }\n        B.set(k, j, B.get(k, j) / l.get(k, k));\n      }\n    }\n\n    for (k = dimension - 1; k >= 0; k--) {\n      for (j = 0; j < count; j++) {\n        for (i = k + 1; i < dimension; i++) {\n          B.set(k, j, B.get(k, j) - B.get(i, j) * l.get(i, k));\n        }\n        B.set(k, j, B.get(k, j) / l.get(k, k));\n      }\n    }\n\n    return B;\n  }\n\n  get lowerTriangularMatrix() {\n    return this.L;\n  }\n}\n\nclass nipals {\n  constructor(X, options = {}) {\n    X = WrapperMatrix2D.checkMatrix(X);\n    let { Y } = options;\n    const {\n      scaleScores = false,\n      maxIterations = 1000,\n      terminationCriteria = 1e-10,\n    } = options;\n\n    let u;\n    if (Y) {\n      if (isAnyArray.isAnyArray(Y) && typeof Y[0] === 'number') {\n        Y = Matrix.columnVector(Y);\n      } else {\n        Y = WrapperMatrix2D.checkMatrix(Y);\n      }\n      if (Y.rows !== X.rows) {\n        throw new Error('Y should have the same number of rows as X');\n      }\n      u = Y.getColumnVector(0);\n    } else {\n      u = X.getColumnVector(0);\n    }\n\n    let diff = 1;\n    let t, q, w, tOld;\n\n    for (\n      let counter = 0;\n      counter < maxIterations && diff > terminationCriteria;\n      counter++\n    ) {\n      w = X.transpose().mmul(u).div(u.transpose().mmul(u).get(0, 0));\n      w = w.div(w.norm());\n\n      t = X.mmul(w).div(w.transpose().mmul(w).get(0, 0));\n\n      if (counter > 0) {\n        diff = t.clone().sub(tOld).pow(2).sum();\n      }\n      tOld = t.clone();\n\n      if (Y) {\n        q = Y.transpose().mmul(t).div(t.transpose().mmul(t).get(0, 0));\n        q = q.div(q.norm());\n\n        u = Y.mmul(q).div(q.transpose().mmul(q).get(0, 0));\n      } else {\n        u = t;\n      }\n    }\n\n    if (Y) {\n      let p = X.transpose().mmul(t).div(t.transpose().mmul(t).get(0, 0));\n      p = p.div(p.norm());\n      let xResidual = X.clone().sub(t.clone().mmul(p.transpose()));\n      let residual = u.transpose().mmul(t).div(t.transpose().mmul(t).get(0, 0));\n      let yResidual = Y.clone().sub(\n        t.clone().mulS(residual.get(0, 0)).mmul(q.transpose()),\n      );\n\n      this.t = t;\n      this.p = p.transpose();\n      this.w = w.transpose();\n      this.q = q;\n      this.u = u;\n      this.s = t.transpose().mmul(t);\n      this.xResidual = xResidual;\n      this.yResidual = yResidual;\n      this.betas = residual;\n    } else {\n      this.w = w.transpose();\n      this.s = t.transpose().mmul(t).sqrt();\n      if (scaleScores) {\n        this.t = t.clone().div(this.s.get(0, 0));\n      } else {\n        this.t = t;\n      }\n      this.xResidual = X.sub(t.mmul(w.transpose()));\n    }\n  }\n}\n\nexports.AbstractMatrix = AbstractMatrix;\nexports.CHO = CholeskyDecomposition;\nexports.CholeskyDecomposition = CholeskyDecomposition;\nexports.DistanceMatrix = DistanceMatrix;\nexports.EVD = EigenvalueDecomposition;\nexports.EigenvalueDecomposition = EigenvalueDecomposition;\nexports.LU = LuDecomposition;\nexports.LuDecomposition = LuDecomposition;\nexports.Matrix = Matrix;\nexports.MatrixColumnSelectionView = MatrixColumnSelectionView;\nexports.MatrixColumnView = MatrixColumnView;\nexports.MatrixFlipColumnView = MatrixFlipColumnView;\nexports.MatrixFlipRowView = MatrixFlipRowView;\nexports.MatrixRowSelectionView = MatrixRowSelectionView;\nexports.MatrixRowView = MatrixRowView;\nexports.MatrixSelectionView = MatrixSelectionView;\nexports.MatrixSubView = MatrixSubView;\nexports.MatrixTransposeView = MatrixTransposeView;\nexports.NIPALS = nipals;\nexports.Nipals = nipals;\nexports.QR = QrDecomposition;\nexports.QrDecomposition = QrDecomposition;\nexports.SVD = SingularValueDecomposition;\nexports.SingularValueDecomposition = SingularValueDecomposition;\nexports.SymmetricMatrix = SymmetricMatrix;\nexports.WrapperMatrix1D = WrapperMatrix1D;\nexports.WrapperMatrix2D = WrapperMatrix2D;\nexports.correlation = correlation;\nexports.covariance = covariance;\nexports.default = Matrix;\nexports.determinant = determinant;\nexports.inverse = inverse;\nexports.linearDependencies = linearDependencies;\nexports.pseudoInverse = pseudoInverse;\nexports.solve = solve;\nexports.wrap = wrap;\n","import * as matrix from './matrix.js';\n\nexport const AbstractMatrix = matrix.AbstractMatrix;\nexport const CHO = matrix.CHO;\nexport const CholeskyDecomposition = matrix.CholeskyDecomposition;\nexport const DistanceMatrix = matrix.DistanceMatrix;\nexport const EVD = matrix.EVD;\nexport const EigenvalueDecomposition = matrix.EigenvalueDecomposition;\nexport const LU = matrix.LU;\nexport const LuDecomposition = matrix.LuDecomposition;\nexport const Matrix = matrix.Matrix;\nexport const MatrixColumnSelectionView = matrix.MatrixColumnSelectionView;\nexport const MatrixColumnView = matrix.MatrixColumnView;\nexport const MatrixFlipColumnView = matrix.MatrixFlipColumnView;\nexport const MatrixFlipRowView = matrix.MatrixFlipRowView;\nexport const MatrixRowSelectionView = matrix.MatrixRowSelectionView;\nexport const MatrixRowView = matrix.MatrixRowView;\nexport const MatrixSelectionView = matrix.MatrixSelectionView;\nexport const MatrixSubView = matrix.MatrixSubView;\nexport const MatrixTransposeView = matrix.MatrixTransposeView;\nexport const NIPALS = matrix.NIPALS;\nexport const Nipals = matrix.Nipals;\nexport const QR = matrix.QR;\nexport const QrDecomposition = matrix.QrDecomposition;\nexport const SVD = matrix.SVD;\nexport const SingularValueDecomposition = matrix.SingularValueDecomposition;\nexport const SymmetricMatrix = matrix.SymmetricMatrix;\nexport const WrapperMatrix1D = matrix.WrapperMatrix1D;\nexport const WrapperMatrix2D = matrix.WrapperMatrix2D;\nexport const correlation = matrix.correlation;\nexport const covariance = matrix.covariance;\nexport default matrix.default.Matrix ? matrix.default.Matrix : matrix.Matrix;\nexport const determinant = matrix.determinant;\nexport const inverse = matrix.inverse;\nexport const linearDependencies = matrix.linearDependencies;\nexport const pseudoInverse = matrix.pseudoInverse;\nexport const solve = matrix.solve;\nexport const wrap = matrix.wrap;\n","import { xCheck } from \"./xCheck.js\";\nimport { xGetFromToIndex } from \"./xGetFromToIndex.js\";\n/**\n * Computes the maximal value of an array of values\n * @param array - array of numbers\n * @param options - options\n */\nexport function xMaxValue(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let maxValue = array[fromIndex];\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        if (array[i] > maxValue) {\n            maxValue = array[i];\n        }\n    }\n    return maxValue;\n}\n//# sourceMappingURL=xMaxValue.js.map","import { xCheck } from \"./xCheck.js\";\nimport { xGetFromToIndex } from \"./xGetFromToIndex.js\";\n/**\n * Computes the minimal value of an array of values.\n * @param array - array of numbers\n * @param options - options\n */\nexport function xMinValue(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let minValue = array[fromIndex];\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        if (array[i] < minValue) {\n            minValue = array[i];\n        }\n    }\n    return minValue;\n}\n//# sourceMappingURL=xMinValue.js.map","/**\n * Check if the values are separated always by the same difference\n * @param array - Monotone growing array of number\n * @param options\n */\nexport function xIsEquallySpaced(array, options = {}) {\n    if (array.length < 3)\n        return true;\n    const { tolerance = 0.05 } = options;\n    let maxDx = 0;\n    let minDx = Number.MAX_SAFE_INTEGER;\n    for (let i = 0; i < array.length - 1; ++i) {\n        const absoluteDifference = array[i + 1] - array[i];\n        if (absoluteDifference < minDx) {\n            minDx = absoluteDifference;\n        }\n        if (absoluteDifference > maxDx) {\n            maxDx = absoluteDifference;\n        }\n    }\n    return (maxDx - minDx) / maxDx < tolerance;\n}\n//# sourceMappingURL=xIsEquallySpaced.js.map","/**\n * Returns true if x is monotonic.\n * @param array - array of numbers.\n * @returns 1 if monotonic increasing, -1 if monotonic decreasing, 0 if not monotonic.\n */\nexport function xIsMonotonic(array) {\n    if (array.length <= 2) {\n        return 1;\n    }\n    if (array[0] === array[1]) {\n        // maybe a constant series\n        for (let i = 1; i < array.length - 1; i++) {\n            if (array[i] !== array[i + 1])\n                return 0;\n        }\n        return 1;\n    }\n    if (array[0] < array.at(-1)) {\n        for (let i = 0; i < array.length - 1; i++) {\n            if (array[i] >= array[i + 1])\n                return 0;\n        }\n        return 1;\n    }\n    else {\n        for (let i = 0; i < array.length - 1; i++) {\n            if (array[i] <= array[i + 1])\n                return 0;\n        }\n        return -1;\n    }\n}\n//# sourceMappingURL=xIsMonotonic.js.map","import { xMedian } from \"./xMedian.js\";\n/**\n * This function calculates the median absolute deviation (MAD).\n * https://en.wikipedia.org/wiki/Median_absolute_deviation\n * @param array\n */\nexport function xMedianAbsoluteDeviation(array) {\n    const median = xMedian(array);\n    const averageDeviations = new Float64Array(array.length);\n    for (let i = 0; i < array.length; i++) {\n        averageDeviations[i] = Math.abs(array[i] - median);\n    }\n    return {\n        median,\n        mad: xMedian(averageDeviations),\n    };\n}\n//# sourceMappingURL=xMedianAbsoluteDeviation.js.map","import { xCheck } from \"./xCheck.js\";\n/**\n * Return min and max values of an array.\n * @param array - array of number\n * @returns - Object with 2 properties, min and max.\n */\nexport function xMinMaxValues(array) {\n    xCheck(array);\n    let min = array[0];\n    let max = array[0];\n    for (const value of array) {\n        if (value < min)\n            min = value;\n        if (value > max)\n            max = value;\n    }\n    return { min, max };\n}\n//# sourceMappingURL=xMinMaxValues.js.map","import { xMedianAbsoluteDeviation } from \"./xMedianAbsoluteDeviation.js\";\n/**\n * Determine noise level using MAD https://en.wikipedia.org/wiki/Median_absolute_deviation\n * Constant to convert mad to sd calculated using https://www.wolframalpha.com/input?i=sqrt%282%29+inverse+erf%280.5%29\n * This assumes a gaussian distribution of the noise\n * @param array\n * @returns noise level corresponding to one standard deviation\n */\nexport function xNoiseStandardDeviation(array) {\n    const { mad, median } = xMedianAbsoluteDeviation(array);\n    return { sd: mad / 0.6744897501960817, mad, median };\n}\n//# sourceMappingURL=xNoiseStandardDeviation.js.map","/**\n * This function calculate the norm of a vector.\n * @example xNorm([3, 4]) -> 5\n * @param array - array\n * @returns - calculated norm\n */\nexport function xNorm(array) {\n    let result = 0;\n    for (const element of array) {\n        result += element ** 2;\n    }\n    return Math.sqrt(result);\n}\n//# sourceMappingURL=xNorm.js.map","export function getMinMaxIntervalsDy(y, x, dY, dX) {\n    let lastMax = null;\n    let lastMin = null;\n    const intervalL = [];\n    const intervalR = [];\n    for (let i = 1; i < y.length - 1; ++i) {\n        if ((dY[i] < dY[i - 1] && dY[i] <= dY[i + 1]) ||\n            (dY[i] <= dY[i - 1] && dY[i] < dY[i + 1])) {\n            lastMin = {\n                x: x[i],\n                index: i,\n            };\n            if (dX > 0 && lastMax !== null) {\n                intervalL.push(lastMax);\n                intervalR.push(lastMin);\n            }\n        }\n        // Maximum in first derivative\n        if ((dY[i] >= dY[i - 1] && dY[i] > dY[i + 1]) ||\n            (dY[i] > dY[i - 1] && dY[i] >= dY[i + 1])) {\n            lastMax = {\n                x: x[i],\n                index: i,\n            };\n            if (dX < 0 && lastMin !== null) {\n                intervalL.push(lastMax);\n                intervalR.push(lastMin);\n            }\n        }\n    }\n    return { intervalL, intervalR };\n}\n//# sourceMappingURL=getMinMaxIntervals.js.map","export function tryMatchOneIntervalWithMinData(options) {\n    const { x, lastK, minData, yThreshold, intervalWidth, intervalCenter, yData, } = options;\n    let minDistance = Number.POSITIVE_INFINITY;\n    let possible = -1;\n    let newLastIndex = lastK;\n    for (let k = newLastIndex + 1; k < minData.length; k++) {\n        const centerIndex = minData[k];\n        if (yData[centerIndex] <= yThreshold) {\n            continue;\n        }\n        const deltaX = x[centerIndex];\n        const currentDistance = Math.abs(deltaX - intervalCenter);\n        if (currentDistance < intervalWidth) {\n            if (currentDistance < minDistance) {\n                possible = k;\n            }\n            newLastIndex = k;\n        }\n        if (currentDistance >= minDistance)\n            break;\n        minDistance = currentDistance;\n    }\n    return { lastIndex: newLastIndex, possible };\n}\n//# sourceMappingURL=tryMatchOneIntervalWithMinData.js.map","import { getMinMaxIntervalsDy } from \"./getMinMaxIntervals.js\";\nimport { tryMatchOneIntervalWithMinData } from \"./tryMatchOneIntervalWithMinData.js\";\nexport function autoAlgorithm(input) {\n    const { x, y, yData, dY, ddY, dX, yThreshold } = input;\n    const minddY = [];\n    const crossDy = [];\n    const { intervalL, intervalR } = getMinMaxIntervalsDy(y, x, dY, dX);\n    for (let i = 1; i < y.length - 1; ++i) {\n        if ((dY[i] < 0 && dY[i + 1] > 0) || (dY[i] > 0 && dY[i + 1] < 0)) {\n            // push the index of the element closer to zero\n            crossDy.push(Math.abs(dY[i]) < Math.abs(dY[i + 1]) ? i : i + 1);\n        }\n        // Handle exact zero\n        if (dY[i] === 0 &&\n            dY[i] < Math.abs(dY[i + 1]) &&\n            dY[i] < Math.abs(dY[i - 1])) {\n            crossDy.push(i);\n        }\n        // Minimum in second derivative\n        if (ddY[i] < ddY[i - 1] && ddY[i] < ddY[i + 1]) {\n            minddY.push(i);\n        }\n    }\n    const peaks = [];\n    let [lastK, lastJ] = [-1, -1];\n    for (let i = 0; i < intervalL.length; i++) {\n        const intervalWidth = (intervalR[i].x - intervalL[i].x) / 2;\n        const intervalCenter = (intervalR[i].x + intervalL[i].x) / 2;\n        let yIndex = -1;\n        let match = tryMatchOneIntervalWithMinData({\n            x,\n            yData,\n            lastK,\n            yThreshold,\n            intervalWidth,\n            intervalCenter,\n            minData: crossDy,\n        });\n        lastK = match.lastIndex;\n        if (match.possible !== -1) {\n            yIndex = crossDy[match.possible];\n        }\n        else {\n            match = tryMatchOneIntervalWithMinData({\n                x,\n                yData,\n                yThreshold,\n                lastK: lastJ,\n                intervalWidth,\n                intervalCenter,\n                minData: minddY,\n            });\n            if (match.possible !== -1) {\n                yIndex = minddY[match.possible];\n            }\n            lastJ = match.lastIndex;\n        }\n        if (yIndex !== -1) {\n            const width = Math.abs(intervalR[i].x - intervalL[i].x);\n            peaks.push({\n                id: crypto.randomUUID(),\n                x: x[yIndex],\n                y: y[yIndex],\n                width,\n                index: yIndex,\n                ddY: ddY[yIndex],\n                inflectionPoints: {\n                    from: intervalL[i],\n                    to: intervalR[i],\n                },\n            });\n        }\n    }\n    return peaks;\n}\n//# sourceMappingURL=autoAlgorithm.js.map","import { tryMatchOneIntervalWithMinData } from \"./tryMatchOneIntervalWithMinData.js\";\nexport function getPeakFromIntervals(options) {\n    let lastK = -1;\n    const peaks = [];\n    const { x, ddY, yData, yThreshold, intervalR, intervalL, minData } = options;\n    for (let i = 0; i < intervalL.length; i++) {\n        const intervalWidth = (intervalR[i].x - intervalL[i].x) / 2;\n        const intervalCenter = (intervalR[i].x + intervalL[i].x) / 2;\n        const { possible = -1, lastIndex } = tryMatchOneIntervalWithMinData({\n            x,\n            lastK,\n            minData,\n            yThreshold,\n            intervalWidth,\n            intervalCenter,\n            yData,\n        });\n        if (possible !== -1) {\n            const centerIndex = minData[possible];\n            const width = Math.abs(intervalR[i].x - intervalL[i].x);\n            peaks.push({\n                id: crypto.randomUUID(),\n                x: x[centerIndex],\n                y: yData[centerIndex],\n                width,\n                index: centerIndex,\n                ddY: ddY[centerIndex],\n                inflectionPoints: {\n                    from: intervalL[i],\n                    to: intervalR[i],\n                },\n            });\n        }\n        lastK = lastIndex;\n    }\n    return peaks;\n}\n//# sourceMappingURL=getPeaksFromIntervals.js.map","/**\n * Finds the indices where the first derivative crosses zero (sign change),\n * which are potential peak positions. This function does not detect zero-crossings\n * in regions with consecutive zero values in the derivative (flat regions).\n *\n * @param input - Object containing the y values and their first derivative (dY).\n * @returns Array of indices where the first derivative crosses zero (excluding consecutive zeros).\n */\nexport function xGetCrossZeroPoints(input) {\n    const { y, dY } = input;\n    const crossDy = [];\n    for (let i = 1; i < y.length - 1; ++i) {\n        if (isLessAndGreaterThanZero(dY[i], dY[i + 1])) {\n            // push the index of the element closer to zero\n            crossDy.push(Math.abs(dY[i]) < Math.abs(dY[i + 1]) ? i : i + 1);\n        }\n        else if (\n        // Handle exact zero\n        dY[i] === 0 &&\n            isLessAndGreaterThanZero(dY[i - 1], dY[i + 1])) {\n            crossDy.push(i);\n        }\n    }\n    return crossDy;\n}\nfunction isLessAndGreaterThanZero(back, next) {\n    return (back < 0 && next > 0) || (back > 0 && next < 0);\n}\n//# sourceMappingURL=xGetCrossZeroPoints.js.map","import { getMinMaxIntervalsDy } from \"./getMinMaxIntervals.js\";\nimport { getPeakFromIntervals } from \"./getPeaksFromIntervals.js\";\nimport { xGetCrossZeroPoints } from \"./xGetCrossZeroPoints.js\";\nexport function firstDerivative(input) {\n    const { y, x, dY, dX, yData, yThreshold, ddY } = input;\n    const crossDy = xGetCrossZeroPoints(input);\n    const { intervalL, intervalR } = getMinMaxIntervalsDy(y, x, dY, dX);\n    return getPeakFromIntervals({\n        minData: crossDy,\n        intervalL,\n        intervalR,\n        x,\n        yData,\n        yThreshold,\n        ddY,\n    });\n}\n//# sourceMappingURL=firstDerivative.js.map","import { getMinMaxIntervalsDy } from \"./getMinMaxIntervals.js\";\nimport { getPeakFromIntervals } from \"./getPeaksFromIntervals.js\";\nexport function secondDerivative(input) {\n    const { x, y, yData, dY, ddY, dX, yThreshold } = input;\n    const minddY = [];\n    const { intervalL, intervalR } = getMinMaxIntervalsDy(y, x, dY, dX);\n    // By the intermediate value theorem We cannot find 2 consecutive maximum or minimum\n    for (let i = 1; i < y.length - 1; ++i) {\n        // Minimum in second derivative\n        if (ddY[i] < ddY[i - 1] && ddY[i] < ddY[i + 1]) {\n            minddY.push(i);\n        }\n    }\n    return getPeakFromIntervals({\n        minData: minddY,\n        intervalL,\n        intervalR,\n        x,\n        yData,\n        yThreshold,\n        ddY,\n    });\n}\n//# sourceMappingURL=secondDerivative.js.map","/**\n * Correction of the x and y coordinates using a quadratic optimizations with the peak and its 3 closest neighbors to determine the true x,y values of the peak.\n * This process is done in place and is very fast.\n * @param data\n * @param peaks\n */\nexport function optimizeTop(data, peaks) {\n    const { x, y } = data;\n    for (const peak of peaks) {\n        let currentIndex = peak.index;\n        // The detected peak could be moved 1 or 2 units to left or right.\n        if (y[currentIndex - 1] >= y[currentIndex - 2] &&\n            y[currentIndex - 1] >= y[currentIndex]) {\n            currentIndex--;\n        }\n        else if (y[currentIndex + 1] >= y[currentIndex] &&\n            y[currentIndex + 1] >= y[currentIndex + 2]) {\n            currentIndex++;\n        }\n        else if (y[currentIndex - 2] >= y[currentIndex - 3] &&\n            y[currentIndex - 2] >= y[currentIndex - 1]) {\n            currentIndex -= 2;\n        }\n        else if (y[currentIndex + 2] >= y[currentIndex + 1] &&\n            y[currentIndex + 2] >= y[currentIndex + 3]) {\n            currentIndex += 2;\n        }\n        // interpolation to a sin() function\n        if (y[currentIndex - 1] > 0 &&\n            y[currentIndex + 1] > 0 &&\n            y[currentIndex] >= y[currentIndex - 1] &&\n            y[currentIndex] >= y[currentIndex + 1] &&\n            (y[currentIndex] !== y[currentIndex - 1] ||\n                y[currentIndex] !== y[currentIndex + 1])) {\n            const alpha = 20 * Math.log10(y[currentIndex - 1]);\n            const beta = 20 * Math.log10(y[currentIndex]);\n            const gamma = 20 * Math.log10(y[currentIndex + 1]);\n            const p = (0.5 * (alpha - gamma)) / (alpha - 2 * beta + gamma);\n            const xCurrent = x[currentIndex];\n            const xPrevious = x[currentIndex - 1];\n            peak.x = xCurrent + (xCurrent - xPrevious) * p;\n            peak.y =\n                y[currentIndex] -\n                    0.25 * (y[currentIndex - 1] - y[currentIndex + 1]) * p;\n        }\n    }\n}\n//# sourceMappingURL=optimizeTop.js.map","import { sgg } from 'ml-savitzky-golay-generalized';\nimport { xIsEquallySpaced, xIsMonotonic, xMinMaxValues, xNoiseStandardDeviation, } from 'ml-spectra-processing';\nimport { autoAlgorithm } from \"./algorithms/autoAlgorithm.js\";\nimport { firstDerivative } from \"./algorithms/firstDerivative.js\";\nimport { secondDerivative } from \"./algorithms/secondDerivative.js\";\nimport { optimizeTop } from \"./utils/optimizeTop.js\";\n/**\n * Global spectra deconvolution\n * @param  data - Object data with x and y arrays. Values in x has to be growing\n * @param options\n * @param {number} [options.broadRatio = 0.00] - If `broadRatio` is higher than 0, then all the peaks which second derivative\n * smaller than `broadRatio * maxAbsSecondDerivative` will be marked with the soft mask equal to true.\n */\nexport function gsd(data, options = {}) {\n    let { noiseLevel } = options;\n    const { sgOptions = {\n        windowSize: 9,\n        polynomial: 3,\n    }, smoothY = false, maxCriteria = true, minMaxRatio = 0.00025, realTopDetection = false, peakDetectionAlgorithm = 'second', } = options;\n    const { x } = data;\n    let { y } = data;\n    if (xIsMonotonic(x) !== 1) {\n        throw new Error('GSD only accepts monotone increasing x values');\n    }\n    //rescale;\n    y = y.slice();\n    // If the max difference between delta x is less than 5%, then,\n    // we can assume it to be equally spaced variable\n    const isEquallySpaced = xIsEquallySpaced(x);\n    if (noiseLevel === undefined) {\n        if (isEquallySpaced) {\n            const noiseInfo = xNoiseStandardDeviation(y);\n            if (maxCriteria) {\n                noiseLevel = noiseInfo.median + 1.5 * noiseInfo.sd;\n            }\n            else {\n                noiseLevel = -noiseInfo.median + 1.5 * noiseInfo.sd;\n            }\n        }\n        else {\n            noiseLevel = 0;\n        }\n    }\n    else if (!maxCriteria) {\n        noiseLevel *= -1;\n    }\n    if (!maxCriteria) {\n        for (let i = 0; i < y.length; i++) {\n            y[i] *= -1;\n        }\n    }\n    if (noiseLevel !== undefined) {\n        for (let i = 0; i < y.length; i++) {\n            if (y[i] < noiseLevel) {\n                y[i] = noiseLevel;\n            }\n        }\n    }\n    const xValue = isEquallySpaced ? x[1] - x[0] : x;\n    const yData = smoothY\n        ? sgg(y, xValue, {\n            ...sgOptions,\n            derivative: 0,\n        })\n        : y;\n    const { min: minY, max: maxY } = xMinMaxValues(yData);\n    if (minY > maxY || minY === maxY)\n        return [];\n    const dY = sgg(y, xValue, {\n        ...sgOptions,\n        derivative: 1,\n    });\n    const ddY = sgg(y, xValue, {\n        ...sgOptions,\n        derivative: 2,\n    });\n    const yThreshold = Math.max(noiseLevel, minY + (maxY - minY) * minMaxRatio);\n    const dX = x[1] - x[0];\n    const peakData = { x, y, yData, dY, ddY, dX, yThreshold };\n    let peaks = [];\n    if (peakDetectionAlgorithm === 'first') {\n        peaks = firstDerivative(peakData);\n    }\n    else if (peakDetectionAlgorithm === 'second') {\n        peaks = secondDerivative(peakData);\n    }\n    else {\n        peaks = autoAlgorithm(peakData);\n    }\n    if (realTopDetection) {\n        optimizeTop({ x, y: yData }, peaks);\n    }\n    peaks.forEach((peak) => {\n        if (!maxCriteria) {\n            peak.y *= -1;\n            peak.ddY = peak.ddY * -1;\n        }\n    });\n    peaks.sort((a, b) => {\n        return a.x - b.x;\n    });\n    return peaks;\n}\n//# sourceMappingURL=gsd.js.map","export const GAUSSIAN_EXP_FACTOR = -4 * Math.LN2;\nexport const ROOT_PI_OVER_LN2 = Math.sqrt(Math.PI / Math.LN2);\nexport const ROOT_THREE = Math.sqrt(3);\nexport const ROOT_2LN2 = Math.sqrt(2 * Math.LN2);\nexport const ROOT_2LN2_MINUS_ONE = Math.sqrt(2 * Math.LN2) - 1;\n//# sourceMappingURL=constants.js.map","// https://en.wikipedia.org/wiki/Error_function#Inverse_functions\n// This code yields to a good approximation\n// If needed a better implementation using polynomial can be found on https://en.wikipedia.org/wiki/Error_function#Inverse_functions\nexport default function erfinv(x) {\n    let a = 0.147;\n    if (x === 0)\n        return 0;\n    let ln1MinusXSqrd = Math.log(1 - x * x);\n    let lnEtcBy2Plus2 = ln1MinusXSqrd / 2 + 2 / (Math.PI * a);\n    let firstSqrt = Math.sqrt(lnEtcBy2Plus2 ** 2 - ln1MinusXSqrd / a);\n    let secondSqrt = Math.sqrt(firstSqrt - lnEtcBy2Plus2);\n    return secondSqrt * (x > 0 ? 1 : -1);\n}\n//# sourceMappingURL=erfinv.js.map","import { ROOT_2LN2, GAUSSIAN_EXP_FACTOR, ROOT_PI_OVER_LN2, } from '../../../util/constants';\nimport erfinv from '../../../util/erfinv';\nexport class Gaussian {\n    constructor(options = {}) {\n        const { fwhm = 500, sd } = options;\n        this.fwhm = sd ? gaussianWidthToFWHM(2 * sd) : fwhm;\n    }\n    fwhmToWidth(fwhm = this.fwhm) {\n        return gaussianFwhmToWidth(fwhm);\n    }\n    widthToFWHM(width) {\n        return gaussianWidthToFWHM(width);\n    }\n    fct(x) {\n        return gaussianFct(x, this.fwhm);\n    }\n    getArea(height = calculateGaussianHeight({ fwhm: this.fwhm })) {\n        return getGaussianArea({ fwhm: this.fwhm, height });\n    }\n    getFactor(area) {\n        return getGaussianFactor(area);\n    }\n    getData(options = {}) {\n        return getGaussianData(this, options);\n    }\n    calculateHeight(area = 1) {\n        return calculateGaussianHeight({ fwhm: this.fwhm, area });\n    }\n    getParameters() {\n        return ['fwhm'];\n    }\n}\nexport function calculateGaussianHeight(options) {\n    let { fwhm = 500, area = 1, sd } = options;\n    if (sd)\n        fwhm = gaussianWidthToFWHM(2 * sd);\n    return (2 * area) / ROOT_PI_OVER_LN2 / fwhm;\n}\n/**\n * Calculate the height of the gaussian function of a specific width (fwhm) at a speicifc\n * x position (the gaussian is centered on x=0)\n * @param x\n * @param fwhm\n * @returns y\n */\nexport function gaussianFct(x, fwhm) {\n    return Math.exp(GAUSSIAN_EXP_FACTOR * Math.pow(x / fwhm, 2));\n}\nexport function gaussianWidthToFWHM(width) {\n    return width * ROOT_2LN2;\n}\nexport function gaussianFwhmToWidth(fwhm) {\n    return fwhm / ROOT_2LN2;\n}\nexport function getGaussianArea(options) {\n    let { fwhm = 500, sd, height = 1 } = options;\n    if (sd)\n        fwhm = gaussianWidthToFWHM(2 * sd);\n    return (height * ROOT_PI_OVER_LN2 * fwhm) / 2;\n}\nexport function getGaussianFactor(area = 0.9999) {\n    return Math.sqrt(2) * erfinv(area);\n}\nexport function getGaussianData(shape = {}, options = {}) {\n    let { fwhm = 500, sd } = shape;\n    if (sd)\n        fwhm = gaussianWidthToFWHM(2 * sd);\n    let { length, factor = getGaussianFactor(), height = calculateGaussianHeight({ fwhm }), } = options;\n    if (!length) {\n        length = Math.min(Math.ceil(fwhm * factor), Math.pow(2, 25) - 1);\n        if (length % 2 === 0)\n            length++;\n    }\n    const center = (length - 1) / 2;\n    const data = new Float64Array(length);\n    for (let i = 0; i <= center; i++) {\n        data[i] = gaussianFct(i - center, fwhm) * height;\n        data[length - 1 - i] = data[i];\n    }\n    return data;\n}\n//# sourceMappingURL=Gaussian.js.map","import { ROOT_THREE } from '../../../util/constants';\nexport class Lorentzian {\n    constructor(options = {}) {\n        const { fwhm = 500 } = options;\n        this.fwhm = fwhm;\n    }\n    fwhmToWidth(fwhm = this.fwhm) {\n        return lorentzianFwhmToWidth(fwhm);\n    }\n    widthToFWHM(width) {\n        return lorentzianWidthToFWHM(width);\n    }\n    fct(x) {\n        return lorentzianFct(x, this.fwhm);\n    }\n    getArea(height = 1) {\n        return getLorentzianArea({ fwhm: this.fwhm, height });\n    }\n    getFactor(area) {\n        return getLorentzianFactor(area);\n    }\n    getData(options = {}) {\n        return getLorentzianData(this, options);\n    }\n    calculateHeight(area = 1) {\n        return calculateLorentzianHeight({ fwhm: this.fwhm, area });\n    }\n    getParameters() {\n        return ['fwhm'];\n    }\n}\nexport const calculateLorentzianHeight = ({ fwhm = 1, area = 1 }) => {\n    return (2 * area) / Math.PI / fwhm;\n};\nexport const getLorentzianArea = (options) => {\n    const { fwhm = 500, height = 1 } = options;\n    return (height * Math.PI * fwhm) / 2;\n};\nexport const lorentzianFct = (x, fwhm) => {\n    return fwhm ** 2 / (4 * x ** 2 + fwhm ** 2);\n};\nexport const lorentzianWidthToFWHM = (width) => {\n    return width * ROOT_THREE;\n};\nexport const lorentzianFwhmToWidth = (fwhm) => {\n    return fwhm / ROOT_THREE;\n};\nexport const getLorentzianFactor = (area = 0.9999) => {\n    if (area >= 1) {\n        throw new Error('area should be (0 - 1)');\n    }\n    const halfResidual = (1 - area) * 0.5;\n    const quantileFunction = (p) => Math.tan(Math.PI * (p - 0.5));\n    return ((quantileFunction(1 - halfResidual) - quantileFunction(halfResidual)) / 2);\n};\nexport const getLorentzianData = (shape = {}, options = {}) => {\n    let { fwhm = 500 } = shape;\n    let { length, factor = getLorentzianFactor(), height = calculateLorentzianHeight({ fwhm, area: 1 }), } = options;\n    if (!length) {\n        length = Math.min(Math.ceil(fwhm * factor), Math.pow(2, 25) - 1);\n        if (length % 2 === 0)\n            length++;\n    }\n    const center = (length - 1) / 2;\n    const data = new Float64Array(length);\n    for (let i = 0; i <= center; i++) {\n        data[i] = lorentzianFct(i - center, fwhm) * height;\n        data[length - 1 - i] = data[i];\n    }\n    return data;\n};\n//# sourceMappingURL=Lorentzian.js.map","import { calculateLorentzianHeight, getLorentzianFactor, lorentzianFwhmToWidth, lorentzianWidthToFWHM, } from '../lorentzian/Lorentzian';\nexport class LorentzianDispersive {\n    constructor(options = {}) {\n        const { fwhm = 500 } = options;\n        this.fwhm = fwhm;\n    }\n    fwhmToWidth(fwhm = this.fwhm) {\n        return lorentzianFwhmToWidth(fwhm);\n    }\n    widthToFWHM(width) {\n        return lorentzianWidthToFWHM(width);\n    }\n    fct(x) {\n        return lorentzianDispersiveFct(x, this.fwhm);\n    }\n    //eslint-disable-next-line\n    getArea(_height) {\n        return 0;\n    }\n    getFactor(area) {\n        return getLorentzianFactor(area);\n    }\n    getData(options = {}) {\n        return getLorentzianDispersiveData(this, options);\n    }\n    calculateHeight(area = 1) {\n        return calculateLorentzianHeight({ fwhm: this.fwhm, area });\n    }\n    getParameters() {\n        return ['fwhm'];\n    }\n}\nexport const lorentzianDispersiveFct = (x, fwhm) => {\n    return (2 * fwhm * x) / (4 * x ** 2 + fwhm ** 2);\n};\nexport const getLorentzianDispersiveData = (shape = {}, options = {}) => {\n    let { fwhm = 500 } = shape;\n    let { length, factor = getLorentzianFactor(), height = calculateLorentzianHeight({ fwhm, area: 1 }), } = options;\n    if (!length) {\n        length = Math.min(Math.ceil(fwhm * factor), Math.pow(2, 25) - 1);\n        if (length % 2 === 0)\n            length++;\n    }\n    const center = (length - 1) / 2;\n    const data = new Float64Array(length);\n    for (let i = 0; i <= center; i++) {\n        data[i] = lorentzianDispersiveFct(i - center, fwhm) * height;\n        data[length - 1 - i] = -data[i];\n    }\n    return data;\n};\n//# sourceMappingURL=LorentzianDispersive.js.map","import { GAUSSIAN_EXP_FACTOR, ROOT_2LN2_MINUS_ONE, ROOT_PI_OVER_LN2, } from '../../../util/constants';\nimport { gaussianFct, getGaussianFactor } from '../gaussian/Gaussian';\nimport { lorentzianFct, getLorentzianFactor } from '../lorentzian/Lorentzian';\nexport class PseudoVoigt {\n    constructor(options = {}) {\n        const { fwhm = 500, mu = 0.5 } = options;\n        this.mu = mu;\n        this.fwhm = fwhm;\n    }\n    fwhmToWidth(fwhm = this.fwhm, mu = this.mu) {\n        return pseudoVoigtFwhmToWidth(fwhm, mu);\n    }\n    widthToFWHM(width, mu = this.mu) {\n        return pseudoVoigtWidthToFWHM(width, mu);\n    }\n    fct(x) {\n        return pseudoVoigtFct(x, this.fwhm, this.mu);\n    }\n    getArea(height = 1) {\n        return getPseudoVoigtArea({ fwhm: this.fwhm, height, mu: this.mu });\n    }\n    getFactor(area) {\n        return getPseudoVoigtFactor(area);\n    }\n    getData(options = {}) {\n        const { length, factor, height = calculatePseudoVoigtHeight({\n            fwhm: this.fwhm,\n            mu: this.mu,\n            area: 1,\n        }), } = options;\n        return getPseudoVoigtData(this, { factor, length, height });\n    }\n    calculateHeight(area = 1) {\n        return calculatePseudoVoigtHeight({ fwhm: this.fwhm, mu: this.mu, area });\n    }\n    getParameters() {\n        return ['fwhm', 'mu'];\n    }\n}\nexport const calculatePseudoVoigtHeight = (options = {}) => {\n    let { fwhm = 1, mu = 0.5, area = 1 } = options;\n    return (2 * area) / (fwhm * (mu * ROOT_PI_OVER_LN2 + (1 - mu) * Math.PI));\n};\nexport const pseudoVoigtFct = (x, fwhm, mu) => {\n    return (1 - mu) * lorentzianFct(x, fwhm) + mu * gaussianFct(x, fwhm);\n};\nexport const pseudoVoigtWidthToFWHM = (width, mu = 0.5) => {\n    return width * (mu * ROOT_2LN2_MINUS_ONE + 1);\n};\nexport const pseudoVoigtFwhmToWidth = (fwhm, mu = 0.5) => {\n    return fwhm / (mu * ROOT_2LN2_MINUS_ONE + 1);\n};\nexport const getPseudoVoigtArea = (options) => {\n    const { fwhm = 500, height = 1, mu = 0.5 } = options;\n    return (fwhm * height * (mu * ROOT_PI_OVER_LN2 + (1 - mu) * Math.PI)) / 2;\n};\nexport const getPseudoVoigtFactor = (area = 0.9999, mu = 0.5) => {\n    return mu < 1 ? getLorentzianFactor(area) : getGaussianFactor(area);\n};\nexport const getPseudoVoigtData = (shape = {}, options = {}) => {\n    let { fwhm = 500, mu = 0.5 } = shape;\n    let { length, factor = getPseudoVoigtFactor(0.999, mu), height = calculatePseudoVoigtHeight({ fwhm, mu, area: 1 }), } = options;\n    if (!height) {\n        height =\n            1 /\n                ((mu / Math.sqrt(-GAUSSIAN_EXP_FACTOR / Math.PI)) * fwhm +\n                    ((1 - mu) * fwhm * Math.PI) / 2);\n    }\n    if (!length) {\n        length = Math.min(Math.ceil(fwhm * factor), Math.pow(2, 25) - 1);\n        if (length % 2 === 0)\n            length++;\n    }\n    const center = (length - 1) / 2;\n    const data = new Float64Array(length);\n    for (let i = 0; i <= center; i++) {\n        data[i] = pseudoVoigtFct(i - center, fwhm, mu) * height;\n        data[length - 1 - i] = data[i];\n    }\n    return data;\n};\n//# sourceMappingURL=PseudoVoigt.js.map","import { ROOT_THREE } from '../../../util/constants';\n/**\n * This shape is a linear combination of rational function (n|n+2), for n = 0 (lorentzian function) and n = 2\n * the parameter that combines those two functions is `gamma` and it is called the kurtosis parameter, it is an\n * implementation of generalized lorentzian shape published by Stanislav Sykora in the SMASH 2010. DOI:10.3247/SL3nmr10.006\n * @link http://www.ebyte.it/stan/Talk_ML_UserMeeting_SMASH_2010_GeneralizedLorentzian.html\n */\nexport class GeneralizedLorentzian {\n    constructor(options = {}) {\n        const { fwhm = 500, gamma = 0.5 } = options;\n        this.fwhm = fwhm;\n        this.gamma = gamma;\n    }\n    fwhmToWidth(fwhm = this.fwhm) {\n        return generalizedLorentzianFwhmToWidth(fwhm);\n    }\n    widthToFWHM(width) {\n        return generalizedLorentzianWidthToFWHM(width);\n    }\n    fct(x) {\n        return generalizedLorentzianFct(x, this.fwhm, this.gamma);\n    }\n    getArea(height = 1) {\n        return getGeneralizedLorentzianArea({\n            fwhm: this.fwhm,\n            height,\n            gamma: this.gamma,\n        });\n    }\n    getFactor(area) {\n        return getGeneralizedLorentzianFactor(area);\n    }\n    getData(options = {}) {\n        return getGeneralizedLorentzianData(this, options);\n    }\n    calculateHeight(area = 1) {\n        const { gamma, fwhm } = this;\n        return calculateGeneralizedLorentzianHeight({ fwhm, area, gamma });\n    }\n    getParameters() {\n        return ['fwhm', 'gamma'];\n    }\n}\nexport const calculateGeneralizedLorentzianHeight = ({ fwhm = 1, gamma = 1, area = 1, }) => {\n    return (area / fwhm / (3.14159 - 0.420894 * gamma)) * 2;\n};\n/**\n * expression of integral generated by Mathematica of the function\n */\nexport const getGeneralizedLorentzianArea = (options) => {\n    const { fwhm = 500, height = 1, gamma = 1 } = options;\n    return (height * fwhm * (3.14159 - 0.420894 * gamma)) / 2;\n};\nexport const generalizedLorentzianFct = (x, fwhm, gamma) => {\n    const u = ((2 * x) / fwhm) ** 2;\n    return (1 - gamma) / (1 + u) + (gamma * (1 + u / 2)) / (1 + u + u ** 2);\n};\nexport const generalizedLorentzianWidthToFWHM = (width) => {\n    return width * ROOT_THREE;\n};\nexport const generalizedLorentzianFwhmToWidth = (fwhm) => {\n    return fwhm / ROOT_THREE;\n};\nexport const getGeneralizedLorentzianFactor = (area = 0.9999) => {\n    if (area >= 1) {\n        throw new Error('area should be (0 - 1)');\n    }\n    const halfResidual = (1 - area) * 0.5;\n    const quantileFunction = (p) => Math.tan(Math.PI * (p - 0.5));\n    return ((quantileFunction(1 - halfResidual) - quantileFunction(halfResidual)) / 2);\n};\nexport const getGeneralizedLorentzianData = (shape = {}, options = {}) => {\n    let { fwhm = 500, gamma = 1 } = shape;\n    let { length, factor = getGeneralizedLorentzianFactor(), height = calculateGeneralizedLorentzianHeight({ fwhm, area: 1, gamma }), } = options;\n    if (!length) {\n        length = Math.min(Math.ceil(fwhm * factor), Math.pow(2, 25) - 1);\n        if (length % 2 === 0)\n            length++;\n    }\n    const center = (length - 1) / 2;\n    const data = new Float64Array(length);\n    for (let i = 0; i <= center; i++) {\n        data[i] = generalizedLorentzianFct(i - center, fwhm, gamma) * height;\n        data[length - 1 - i] = data[i];\n    }\n    return data;\n};\n//# sourceMappingURL=GeneralizedLorentzian.js.map","import { Gaussian } from './gaussian/Gaussian';\nimport { GeneralizedLorentzian } from './generalizedLorentzian/GeneralizedLorentzian';\nimport { Lorentzian } from './lorentzian/Lorentzian';\nimport { LorentzianDispersive } from './lorentzianDispersive/LorentzianDispersive';\nimport { PseudoVoigt } from './pseudoVoigt/PseudoVoigt';\n/**\n * Generate a instance of a specific kind of shape.\n */\nexport function getShape1D(shape) {\n    const { kind } = shape;\n    switch (kind) {\n        case 'gaussian':\n            return new Gaussian(shape);\n        case 'lorentzian':\n            return new Lorentzian(shape);\n        case 'pseudoVoigt':\n            return new PseudoVoigt(shape);\n        case 'lorentzianDispersive':\n            return new LorentzianDispersive(shape);\n        case 'generalizedLorentzian':\n            return new GeneralizedLorentzian(shape);\n        default: {\n            throw Error(`Unknown distribution ${kind}`);\n        }\n    }\n}\n//# sourceMappingURL=getShape1D.js.map","/**\n * This function returns the sumOfShapes function\n * This function gives sumOfShapes access to the peak list and the associated data\n * @param internalPeaks\n */\nexport function getSumOfShapes(internalPeaks) {\n    return function sumOfShapes(parameters) {\n        return (x) => {\n            let totalY = 0;\n            for (const peak of internalPeaks) {\n                const peakX = parameters[peak.fromIndex];\n                const y = parameters[peak.fromIndex + 1];\n                for (let i = 2; i < parameters.length; i++) {\n                    const shapeFctKey = peak.parameters[i];\n                    peak.shapeFct[shapeFctKey] = parameters[peak.fromIndex + i];\n                }\n                totalY += y * peak.shapeFct.fct(x - peakX);\n            }\n            return totalY;\n        };\n    };\n}\n//# sourceMappingURL=getSumOfShapes.js.map","/**\n * Asserts that value is truthy.\n *\n * @param value - Value to check.\n * @param message - Optional error message to throw.\n */\nexport function assert(value, message) {\n    if (!value) {\n        throw new Error(message ? message : 'unreachable');\n    }\n}\n//# sourceMappingURL=assert.js.map","export const DefaultParameters = {\n    x: {\n        init: (peak) => peak.x,\n        min: (peak, peakShape) => peak.x - peakShape.fwhm * 2,\n        max: (peak, peakShape) => peak.x + peakShape.fwhm * 2,\n        gradientDifference: (peak, peakShape) => peakShape.fwhm * 2e-3,\n    },\n    y: {\n        init: (peak) => peak.y,\n        min: (peak) => (peak.y < 0 ? -1.1 : 0),\n        max: (peak) => (peak.y < 0 ? 0 : 1.1),\n        gradientDifference: () => 1e-3,\n    },\n    fwhm: {\n        init: (peak, peakShape) => peakShape.fwhm,\n        min: (peak, peakShape) => peakShape.fwhm * 0.25,\n        max: (peak, peakShape) => peakShape.fwhm * 4,\n        gradientDifference: (peak, peakShape) => peakShape.fwhm * 2e-3,\n    },\n    mu: {\n        init: (peak, peakShape) => peakShape.mu,\n        min: () => 0,\n        max: () => 1,\n        gradientDifference: () => 0.01,\n    },\n    gamma: {\n        init: (peak, peakShape) => peakShape.gamma || 0.5,\n        min: () => -1,\n        max: () => 2,\n        gradientDifference: () => 0.01,\n    },\n};\n//# sourceMappingURL=DefaultParameters.js.map","import { getShape1D } from 'ml-peak-shape-generator';\nimport { assert } from \"../assert.js\";\nimport { DefaultParameters } from \"./DefaultParameters.js\";\nconst properties = ['init', 'min', 'max', 'gradientDifference'];\n/**\n * Return an array of internalPeaks that contains the exact init, min, max values based on the options\n * @param peaks\n * @param minMaxY\n * @param options\n * @returns\n */\nexport function getInternalPeaks(peaks, minMaxY, options = {}) {\n    let index = 0;\n    const internalPeaks = [];\n    const { baseline: shiftValue = minMaxY.min } = options;\n    const normalizedPeaks = peaks.map((peak) => {\n        return {\n            ...peak,\n            y: (peak.y - shiftValue) / minMaxY.range,\n        };\n    });\n    for (const peak of normalizedPeaks) {\n        const { id, shape = options.shape ? options.shape : { kind: 'gaussian' } } = peak;\n        const shapeFct = getShape1D(shape);\n        const parameters = ['x', 'y', ...shapeFct.getParameters()];\n        const propertiesValues = {\n            min: [],\n            max: [],\n            init: [],\n            gradientDifference: [],\n        };\n        for (const parameter of parameters) {\n            for (const property of properties) {\n                // check if the property is specified in the peak\n                let propertyValue = peak?.parameters?.[parameter]?.[property];\n                if (propertyValue) {\n                    propertyValue = getNormalizedValue(propertyValue, parameter, property, minMaxY, options.baseline);\n                    propertiesValues[property].push(propertyValue);\n                    continue;\n                }\n                // check if there are some global option, it could be a number or a callback\n                let generalParameterValue = options?.parameters?.[parameter]?.[property];\n                if (generalParameterValue) {\n                    if (typeof generalParameterValue === 'number') {\n                        generalParameterValue = getNormalizedValue(generalParameterValue, parameter, property, minMaxY, options.baseline);\n                        propertiesValues[property].push(generalParameterValue);\n                        continue;\n                    }\n                    else {\n                        let value = generalParameterValue(peak);\n                        value = getNormalizedValue(value, parameter, property, minMaxY, options.baseline);\n                        propertiesValues[property].push(value);\n                        continue;\n                    }\n                }\n                // we just need to take the default parameters\n                assert(DefaultParameters[parameter], `No default parameter for ${parameter}`);\n                const defaultParameterValues = DefaultParameters[parameter][property];\n                //@ts-expect-error should never happen\n                propertiesValues[property].push(defaultParameterValues(peak, shapeFct));\n            }\n        }\n        const fromIndex = index;\n        const toIndex = fromIndex + parameters.length - 1;\n        index += toIndex - fromIndex + 1;\n        internalPeaks.push({\n            id,\n            shape,\n            shapeFct,\n            parameters,\n            propertiesValues,\n            fromIndex,\n            toIndex,\n        });\n    }\n    return internalPeaks;\n}\nfunction getNormalizedValue(value, parameter, property, minMaxY, baseline) {\n    if (parameter === 'y') {\n        if (property === 'gradientDifference') {\n            return value;\n        }\n        else {\n            return baseline !== undefined\n                ? (value - baseline) / minMaxY.range\n                : (value - minMaxY.min) / minMaxY.range;\n        }\n    }\n    return value;\n}\n//# sourceMappingURL=getInternalPeaks.js.map","import { isAnyArray } from 'is-any-array';\nexport default function checkOptions(data, options) {\n    const { timeout, initialValues, weights = 1, damping = 1e-2, dampingStepUp = 11, dampingStepDown = 9, maxIterations = 100, errorTolerance = 1e-7, centralDifference = false, gradientDifference = 10e-2, improvementThreshold = 1e-3, } = options;\n    let { minValues, maxValues } = options;\n    if (damping <= 0) {\n        throw new Error('The damping option must be a positive number');\n    }\n    else if (!data.x || !data.y) {\n        throw new Error('The data parameter must have x and y elements');\n    }\n    else if (!isAnyArray(data.x) ||\n        data.x.length < 2 ||\n        !isAnyArray(data.y) ||\n        data.y.length < 2) {\n        throw new Error('The data parameter elements must be an array with more than 2 points');\n    }\n    else if (data.x.length !== data.y.length) {\n        throw new Error('The data parameter elements must have the same size');\n    }\n    if (!(initialValues && initialValues.length > 0)) {\n        throw new Error('The initialValues option is mandatory and must be an array');\n    }\n    const parameters = Array.from(initialValues);\n    const parLen = parameters.length;\n    maxValues = maxValues || new Array(parLen).fill(Number.MAX_SAFE_INTEGER);\n    minValues = minValues || new Array(parLen).fill(Number.MIN_SAFE_INTEGER);\n    if (maxValues.length !== minValues.length) {\n        throw new Error('minValues and maxValues must be the same size');\n    }\n    const gradientDifferenceArray = getGradientDifferenceArray(gradientDifference, parameters);\n    const filler = getFiller(weights, data.x.length);\n    const checkTimeout = getCheckTimeout(timeout);\n    const weightSquare = Array.from({ length: data.x.length }, (_, i) => filler(i));\n    return {\n        checkTimeout,\n        minValues,\n        maxValues,\n        parameters,\n        weightSquare,\n        damping,\n        dampingStepUp,\n        dampingStepDown,\n        maxIterations,\n        errorTolerance,\n        centralDifference,\n        gradientDifference: gradientDifferenceArray,\n        improvementThreshold,\n    };\n}\nfunction getGradientDifferenceArray(gradientDifference, parameters) {\n    if (typeof gradientDifference === 'number') {\n        return new Array(parameters.length).fill(gradientDifference);\n    }\n    else if (isAnyArray(gradientDifference)) {\n        const parLen = parameters.length;\n        if (gradientDifference.length !== parLen) {\n            return new Array(parLen).fill(gradientDifference[0]);\n        }\n        return Array.from(gradientDifference);\n    }\n    throw new Error('gradientDifference should be a number or array with length equal to the number of parameters');\n}\nfunction getFiller(weights, dataLength) {\n    if (typeof weights === 'number') {\n        const value = 1 / weights ** 2;\n        return () => value;\n    }\n    else if (isAnyArray(weights)) {\n        if (weights.length < dataLength) {\n            const value = 1 / weights[0] ** 2;\n            return () => value;\n        }\n        return (i) => 1 / weights[i] ** 2;\n    }\n    throw new Error('weights should be a number or array with length equal to the number of data points');\n}\nfunction getCheckTimeout(timeout) {\n    if (timeout !== undefined) {\n        if (typeof timeout !== 'number') {\n            throw new Error('timeout should be a number');\n        }\n        const endTime = Date.now() + timeout * 1000;\n        return () => Date.now() > endTime;\n    }\n    else {\n        return () => false;\n    }\n}\n//# sourceMappingURL=check_options.js.map","/**\n * the sum of the weighted squares of the errors (or weighted residuals) between the data.y\n * and the curve-fit function.\n *\n * @param data - Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param parameters - Array of current parameter values\n * @param parameterizedFunction - The parameters and returns a function with the independent variable as a parameter\n * @param weightSquare - Square of weights (must be same length as data.x)\n */\nexport default function errorCalculation(data, parameters, parameterizedFunction, weightSquare) {\n    let error = 0;\n    const func = parameterizedFunction(parameters);\n    for (let i = 0; i < data.x.length; i++) {\n        error += (data.y[i] - func(data.x[i])) ** 2 / weightSquare[i];\n    }\n    return error;\n}\n//# sourceMappingURL=error_calculation.js.map","import { Matrix } from 'ml-matrix';\n/**\n * Difference of the matrix function over the parameters\n * @param data Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param evaluatedData - Array of previous evaluated function values\n * @param params - Array of previous parameter values\n * @param gradientDifference - The step size to approximate the jacobian matrix\n * @param centralDifference - If true the jacobian matrix is approximated by central differences otherwise by forward differences\n * @param paramFunction - The parameters and returns a function with the independent variable as a parameter\n */\nexport default function gradientFunction(data, evaluatedData, params, gradientDifference, paramFunction, centralDifference) {\n    const nbParams = params.length;\n    const nbPoints = data.x.length;\n    const ans = Matrix.zeros(nbParams, nbPoints);\n    let rowIndex = 0;\n    for (let param = 0; param < nbParams; param++) {\n        if (gradientDifference[param] === 0)\n            continue;\n        let delta = gradientDifference[param];\n        let auxParams = params.slice();\n        auxParams[param] += delta;\n        const funcParam = paramFunction(auxParams);\n        if (!centralDifference) {\n            for (let point = 0; point < nbPoints; point++) {\n                ans.set(rowIndex, point, (evaluatedData[point] - funcParam(data.x[point])) / delta);\n            }\n        }\n        else {\n            auxParams = params.slice();\n            auxParams[param] -= delta;\n            delta *= 2;\n            const funcParam2 = paramFunction(auxParams);\n            for (let point = 0; point < nbPoints; point++) {\n                ans.set(rowIndex, point, (funcParam2(data.x[point]) - funcParam(data.x[point])) / delta);\n            }\n        }\n        rowIndex++;\n    }\n    return ans;\n}\n//# sourceMappingURL=gradient_function.js.map","import { inverse, Matrix } from 'ml-matrix';\nimport gradientFunction from \"./gradient_function.js\";\n/**\n * Matrix function over the samples\n *\n * @param data - Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param evaluatedData - Array of previous evaluated function values\n */\nfunction matrixFunction(data, evaluatedData) {\n    const m = data.x.length;\n    const ans = new Matrix(m, 1);\n    for (let point = 0; point < m; point++) {\n        ans.set(point, 0, data.y[point] - evaluatedData[point]);\n    }\n    return ans;\n}\n/**\n * Iteration for Levenberg-Marquardt\n *\n * @param data - Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param params - Array of previous parameter values\n * @param damping - Levenberg-Marquardt parameter\n * @param gradientDifference - The step size to approximate the jacobian matrix\n * @param centralDifference - If true the jacobian matrix is approximated by central differences otherwise by forward differences\n * @param parameterizedFunction - The parameters and returns a function with the independent variable as a parameter\n * @param weights - scale the gradient and residual error by weights\n */\nexport default function step(data, params, damping, gradientDifference, parameterizedFunction, centralDifference, weights) {\n    const identity = Matrix.eye(params.length, params.length, damping);\n    const func = parameterizedFunction(params);\n    const evaluatedData = new Float64Array(data.x.length);\n    for (let i = 0; i < data.x.length; i++) {\n        evaluatedData[i] = func(data.x[i]);\n    }\n    const gradientFunc = gradientFunction(data, evaluatedData, params, gradientDifference, parameterizedFunction, centralDifference);\n    const residualError = matrixFunction(data, evaluatedData);\n    const inverseMatrix = inverse(identity.add(gradientFunc.mmul(gradientFunc.transpose().scale('row', { scale: weights }))));\n    const jacobianWeightResidualError = gradientFunc.mmul(residualError.scale('row', { scale: weights }));\n    const perturbations = inverseMatrix.mmul(jacobianWeightResidualError);\n    return {\n        perturbations,\n        jacobianWeightResidualError,\n    };\n}\n//# sourceMappingURL=step.js.map","import checkOptions from \"./check_options.js\";\nimport errorCalculation from \"./error_calculation.js\";\nimport step from \"./step.js\";\n/**\n * Curve fitting algorithm\n * @param data - Array of points to fit in the format [x1, x2, ... ], [y1, y2, ... ]\n * @param parameterizedFunction - Takes an array of parameters and returns a function with the independent variable as its sole argument\n * @param options - Options object\n */\nexport function levenbergMarquardt(data, parameterizedFunction, options) {\n    const checkedOptions = checkOptions(data, options);\n    const { checkTimeout, minValues, maxValues, parameters, weightSquare, dampingStepUp, dampingStepDown, maxIterations, errorTolerance, centralDifference, gradientDifference, improvementThreshold, } = checkedOptions;\n    let damping = checkedOptions.damping;\n    let error = errorCalculation(data, parameters, parameterizedFunction, weightSquare);\n    let optimalError = error;\n    let optimalParameters = parameters.slice();\n    let converged = error <= errorTolerance;\n    let iteration = 0;\n    for (; iteration < maxIterations && !converged; iteration++) {\n        const previousError = error;\n        const { perturbations, jacobianWeightResidualError } = step(data, parameters, damping, gradientDifference, parameterizedFunction, centralDifference, weightSquare);\n        for (let k = 0; k < parameters.length; k++) {\n            parameters[k] = Math.min(Math.max(minValues[k], parameters[k] - perturbations.get(k, 0)), maxValues[k]);\n        }\n        error = errorCalculation(data, parameters, parameterizedFunction, weightSquare);\n        if (isNaN(error))\n            break;\n        if (error < optimalError - errorTolerance) {\n            optimalError = error;\n            optimalParameters = parameters.slice();\n        }\n        const improvementMetric = (previousError - error) /\n            perturbations\n                .transpose()\n                .mmul(perturbations.mul(damping).add(jacobianWeightResidualError))\n                .get(0, 0);\n        if (improvementMetric > improvementThreshold) {\n            damping = Math.max(damping / dampingStepDown, 1e-7);\n        }\n        else {\n            damping = Math.min(damping * dampingStepUp, 1e7);\n        }\n        if (checkTimeout()) {\n            throw new Error(`The execution time is over to ${options.timeout} seconds`);\n        }\n        converged = error <= errorTolerance;\n    }\n    return {\n        parameterValues: optimalParameters,\n        parameterError: optimalError,\n        iterations: iteration,\n    };\n}\n//# sourceMappingURL=levenberg_marquardt.js.map","/**\n * Preparata, F. P., & Shamos, M. I. (2012). Computational geometry: an introduction. Springer Science & Business Media.\n * @param {Array} x - The array with x coordinates of the points.\n * @param {Array} y - The array with y coordinates of the points.\n * @return {Array} The indices of the points of anticlockwise lower convex hull\n * @private\n */\nexport default function antiLowerConvexHull(x, y) {\n  if (x.length !== y.length) {\n    throw new RangeError('X and Y vectors has different dimensions');\n  }\n\n  const nbPoints = x.length - 1;\n  if (nbPoints === 0) return [0];\n  if (nbPoints === 1) return [0, 1];\n\n  let currentPoint = 0;\n  let result = new Array(x.length).fill(true);\n  while (true) {\n    const a = currentPoint;\n    const b = moveOn(currentPoint, nbPoints, result);\n    const c = moveOn(moveOn(currentPoint, nbPoints, result), nbPoints, result);\n\n    const det =\n      x[c] * (y[a] - y[b]) + x[a] * (y[b] - y[c]) + x[b] * (y[c] - y[a]);\n\n    const leftTurn = det >= 0;\n\n    if (leftTurn) {\n      currentPoint = b;\n    } else {\n      result[b] = false;\n      currentPoint = moveBack(currentPoint, nbPoints, result);\n    }\n    if (c === nbPoints) break;\n  }\n\n  return result\n    .map((item, index) => (item === false ? false : index))\n    .filter((item) => item !== false);\n}\n\n/**\n * @param {number} currentPoint - The index of the current point to make the move\n * @param {number} nbPoints - The total number of points in the array\n * @param {Array} vector - The array with the points\n * @return {number} the index of the point after the move\n * @private\n */\n\nfunction moveBack(currentPoint, nbPoints, vector) {\n  let counter = currentPoint - 1;\n  while (vector[counter] === false) counter--;\n  return currentPoint === 0 ? nbPoints : counter;\n}\n\nfunction moveOn(currentPoint, nbPoints, vector) {\n  let counter = currentPoint + 1;\n  while (vector[counter] === false) counter++;\n  return currentPoint === nbPoints ? 0 : counter;\n}\n","import { xNorm, xMaxValue, xMinValue } from 'ml-spectra-processing';\n\nimport antiLowerConvexHull from './util/antiLowerConvexHull';\n\n/**\n * Performs a global optimization of required parameters\n * It will return an object containing:\n * - `minFunctionValue`: The minimum value found for the objetive function\n * - `optima`: Array of Array of values for all the variables where the function reach its minimum value\n * - `iterations`: Number of iterations performed in the process\n * - `finalState`: Internal state allowing to continue optimization (initialState)\n * @param {function} objectiveFunction Function to evaluate. It should accept an array of variables\n * @param {Array} lowerBoundaries Array containing for each variable the lower boundary\n * @param {Array} upperBoundaries Array containing for each variable the higher boundary\n * @param {Object} [options={}]\n * @param {number} [options.iterations] - Number of iterations.\n * @param {number} [options.epsilon] - Tolerance to choose best current value.\n * @param {number} [options.tolerance] - Minimum tollerance of the function.\n * @param {number} [options.tolerance2] - Minimum tollerance of the function.\n * @param {Object} [options.initialState={}}] - finalState of previous optimization.\n * @return {Object} {finalState, iterations, minFunctionValue}\n * */\n\nexport default function direct(\n  objectiveFunction,\n  lowerBoundaries,\n  upperBoundaries,\n  options = {},\n) {\n  const {\n    iterations = 50,\n    epsilon = 1e-4,\n    tolerance = 1e-16,\n    tolerance2 = 1e-12,\n    initialState = {},\n  } = options;\n\n  if (\n    objectiveFunction === undefined ||\n    lowerBoundaries === undefined ||\n    upperBoundaries === undefined\n  ) {\n    throw new RangeError('There is something undefined');\n  }\n\n  lowerBoundaries = new Float64Array(lowerBoundaries);\n  upperBoundaries = new Float64Array(upperBoundaries);\n\n  if (lowerBoundaries.length !== upperBoundaries.length) {\n    throw new Error(\n      'Lower bounds and Upper bounds for x are not of the same length',\n    );\n  }\n\n  //-------------------------------------------------------------------------\n  //                        STEP 1. Initialization\n  //-------------------------------------------------------------------------\n  let n = lowerBoundaries.length;\n  let diffBorders = upperBoundaries.map((x, i) => x - lowerBoundaries[i]);\n\n  let {\n    numberOfRectangles = 0,\n    totalIterations = 0,\n    unitaryCoordinates = [new Float64Array(n).fill(0.5)],\n    middlePoint = new Float64Array(n).map((value, index) => {\n      return (\n        lowerBoundaries[index] +\n        unitaryCoordinates[0][index] * diffBorders[index]\n      );\n    }),\n    bestCurrentValue = objectiveFunction(middlePoint),\n    fCalls = 1,\n    smallerDistance = 0,\n    edgeSizes = [new Float64Array(n).fill(0.5)],\n    diagonalDistances = [Math.sqrt(n * 0.5 ** 2)],\n    functionValues = [bestCurrentValue],\n    differentDistances = diagonalDistances,\n    smallerValuesByDistance = [bestCurrentValue],\n    choiceLimit = undefined,\n  } = initialState;\n  if (\n    initialState.originalCoordinates &&\n    initialState.originalCoordinates.length > 0\n  ) {\n    bestCurrentValue = xMinValue(functionValues);\n    choiceLimit =\n      epsilon * Math.abs(bestCurrentValue) > 1e-8\n        ? epsilon * Math.abs(bestCurrentValue)\n        : 1e-8;\n\n    smallerDistance = getMinIndex(\n      functionValues,\n      diagonalDistances,\n      choiceLimit,\n      bestCurrentValue,\n    );\n\n    unitaryCoordinates = initialState.originalCoordinates.slice();\n    for (let j = 0; j < unitaryCoordinates.length; j++) {\n      for (let i = 0; i < lowerBoundaries.length; i++) {\n        unitaryCoordinates[j][i] =\n          (unitaryCoordinates[j][i] - lowerBoundaries[i]) / diffBorders[i];\n      }\n    }\n  }\n\n  let iteration = 0;\n  //-------------------------------------------------------------------------\n  //                          Iteration loop\n  //-------------------------------------------------------------------------\n\n  while (iteration < iterations) {\n    //----------------------------------------------------------------------\n    //  STEP 2. Identify the set S of all potentially optimal rectangles\n    //----------------------------------------------------------------------\n\n    let S1 = [];\n    let idx = differentDistances.findIndex(\n      // eslint-disable-next-line no-loop-func\n      (e) => e === diagonalDistances[smallerDistance],\n    );\n    let counter = 0;\n    for (let i = idx; i < differentDistances.length; i++) {\n      for (let f = 0; f < functionValues.length; f++) {\n        if (\n          (functionValues[f] === smallerValuesByDistance[i]) &\n          (diagonalDistances[f] === differentDistances[i])\n        ) {\n          S1[counter++] = f;\n        }\n      }\n    }\n\n    let optimumValuesIndex, S3;\n    if (differentDistances.length - idx > 1) {\n      let a1 = diagonalDistances[smallerDistance];\n      let b1 = functionValues[smallerDistance];\n      let a2 = differentDistances[differentDistances.length - 1];\n      let b2 = smallerValuesByDistance[differentDistances.length - 1];\n      let slope = (b2 - b1) / (a2 - a1);\n      let constant = b1 - slope * a1;\n      let S2 = new Uint32Array(counter);\n      counter = 0;\n      for (let i = 0; i < S2.length; i++) {\n        let j = S1[i];\n        if (\n          functionValues[j] <=\n          slope * diagonalDistances[j] + constant + tolerance2\n        ) {\n          S2[counter++] = j;\n        }\n      }\n\n      let xHull = [];\n      let yHull = [];\n      for (let i = 0; i < counter; i++) {\n        xHull.push(diagonalDistances[S2[i]]);\n        yHull.push(functionValues[S2[i]]);\n      }\n\n      let lowerIndexHull = antiLowerConvexHull(xHull, yHull);\n\n      S3 = [];\n      for (let i = 0; i < lowerIndexHull.length; i++) {\n        S3.push(S2[lowerIndexHull[i]]);\n      }\n    } else {\n      S3 = S1.slice(0, counter);\n    }\n    optimumValuesIndex = S3;\n    //--------------------------------------------------------------\n    // STEPS 3,5: Select any rectangle j in S\n    //--------------------------------------------------------------\n    for (let k = 0; k < optimumValuesIndex.length; k++) {\n      let j = optimumValuesIndex[k];\n      let largerSide = xMaxValue(edgeSizes[j]);\n      let largeSidesIndex = new Uint32Array(edgeSizes[j].length);\n      counter = 0;\n      for (let i = 0; i < edgeSizes[j].length; i++) {\n        if (Math.abs(edgeSizes[j][i] - largerSide) < tolerance) {\n          largeSidesIndex[counter++] = i;\n        }\n      }\n      let delta = (2 * largerSide) / 3;\n      let bestFunctionValues = [];\n      for (let r = 0; r < counter; r++) {\n        let i = largeSidesIndex[r];\n        let firstMiddleCenter = unitaryCoordinates[j].slice();\n        let secondMiddleCenter = unitaryCoordinates[j].slice();\n        firstMiddleCenter[i] += delta;\n        secondMiddleCenter[i] -= delta;\n        let firstMiddleValue = new Float64Array(firstMiddleCenter.length);\n        let secondMiddleValue = new Float64Array(secondMiddleCenter.length);\n        for (let i = 0; i < firstMiddleCenter.length; i++) {\n          firstMiddleValue[i] =\n            lowerBoundaries[i] + firstMiddleCenter[i] * diffBorders[i];\n          secondMiddleValue[i] =\n            lowerBoundaries[i] + secondMiddleCenter[i] * diffBorders[i];\n        }\n        let firstMinValue = objectiveFunction(firstMiddleValue);\n        let secondMinValue = objectiveFunction(secondMiddleValue);\n        fCalls += 2;\n        bestFunctionValues.push({\n          minValue: Math.min(firstMinValue, secondMinValue),\n          index: r,\n        });\n        // [Math.min(firstMinValue, secondMinValue), r];\n        unitaryCoordinates.push(firstMiddleCenter, secondMiddleCenter);\n        functionValues.push(firstMinValue, secondMinValue);\n      }\n\n      let b = bestFunctionValues.sort((a, b) => a.minValue - b.minValue);\n      for (let r = 0; r < counter; r++) {\n        let u = largeSidesIndex[b[r].index];\n        let ix1 = numberOfRectangles + 2 * (b[r].index + 1) - 1;\n        let ix2 = numberOfRectangles + 2 * (b[r].index + 1);\n        edgeSizes[j][u] = delta / 2;\n        edgeSizes[ix1] = edgeSizes[j].slice();\n        edgeSizes[ix2] = edgeSizes[j].slice();\n        diagonalDistances[j] = xNorm(edgeSizes[j]);\n        diagonalDistances[ix1] = diagonalDistances[j];\n        diagonalDistances[ix2] = diagonalDistances[j];\n      }\n      numberOfRectangles += 2 * counter;\n    }\n\n    //--------------------------------------------------------------\n    //                  Update\n    //--------------------------------------------------------------\n\n    bestCurrentValue = xMinValue(functionValues);\n\n    choiceLimit =\n      epsilon * Math.abs(bestCurrentValue) > 1e-8\n        ? epsilon * Math.abs(bestCurrentValue)\n        : 1e-8;\n\n    smallerDistance = getMinIndex(\n      functionValues,\n      diagonalDistances,\n      choiceLimit,\n      bestCurrentValue,\n      iteration,\n    );\n\n    differentDistances = Array.from(new Set(diagonalDistances));\n    differentDistances = differentDistances.sort((a, b) => a - b);\n\n    smallerValuesByDistance = [];\n    for (let i = 0; i < differentDistances.length; i++) {\n      let minIndex;\n      let minValue = Number.POSITIVE_INFINITY;\n      for (let k = 0; k < diagonalDistances.length; k++) {\n        if (diagonalDistances[k] === differentDistances[i]) {\n          if (functionValues[k] < minValue) {\n            minValue = functionValues[k];\n            minIndex = k;\n          }\n        }\n      }\n      smallerValuesByDistance.push(functionValues[minIndex]);\n    }\n\n    let currentMin = [];\n    for (let j = 0; j < functionValues.length; j++) {\n      if (functionValues[j] === bestCurrentValue) {\n        let temp = [];\n        for (let i = 0; i < lowerBoundaries.length; i++) {\n          temp.push(\n            lowerBoundaries[i] + unitaryCoordinates[j][i] * diffBorders[i],\n          );\n        }\n        currentMin.push(temp);\n      }\n    }\n    iteration += 1;\n  }\n  //--------------------------------------------------------------\n  //                  Saving results\n  //--------------------------------------------------------------\n\n  let result = {};\n  result.minFunctionValue = bestCurrentValue;\n  result.iterations = iteration;\n  let originalCoordinates = [];\n  for (let j = 0; j < numberOfRectangles + 1; j++) {\n    let pair = [];\n    for (let i = 0; i < lowerBoundaries.length; i++) {\n      pair.push(lowerBoundaries[i] + unitaryCoordinates[j][i] * diffBorders[i]);\n    }\n    originalCoordinates.push(pair);\n  }\n\n  result.finalState = {\n    numberOfRectangles,\n    totalIterations: (totalIterations += iterations),\n    originalCoordinates,\n    middlePoint,\n    fCalls,\n    smallerDistance,\n    edgeSizes,\n    diagonalDistances,\n    functionValues,\n    differentDistances,\n    smallerValuesByDistance,\n    choiceLimit,\n  };\n\n  let minimizer = [];\n  for (let i = 0; i < functionValues.length; i++) {\n    if (functionValues[i] === bestCurrentValue) {\n      minimizer.push(originalCoordinates[i]);\n    }\n  }\n\n  result.optima = minimizer;\n  return result;\n}\n\nfunction getMinIndex(\n  functionValues,\n  diagonalDistances,\n  choiceLimit,\n  bestCurrentValue,\n) {\n  let item = [];\n  for (let i = 0; i < functionValues.length; i++) {\n    item[i] =\n      Math.abs(functionValues[i] - (bestCurrentValue + choiceLimit)) /\n      diagonalDistances[i];\n  }\n  const min = xMinValue(item);\n  let result = item.findIndex((x) => x === min);\n  return result;\n}\n","import direct from 'ml-direct';\nexport function directOptimization(data, sumOfShapes, options) {\n    const { minValues, maxValues, maxIterations, epsilon, tolerance, tolerance2, initialState, } = options;\n    const objectiveFunction = getObjectiveFunction(data, sumOfShapes);\n    const result = direct(objectiveFunction, \n    // direct internally converts ArrayLike to Float64Array,\n    // so we can safely cast minValues and maxValues to number[]\n    minValues, maxValues, {\n        iterations: maxIterations,\n        epsilon,\n        tolerance,\n        tolerance2,\n        initialState,\n    });\n    const { optima } = result;\n    return {\n        parameterError: result.minFunctionValue,\n        iterations: result.iterations,\n        parameterValues: optima[0],\n    };\n}\nfunction getObjectiveFunction(data, sumOfShapes) {\n    const { x, y } = data;\n    const nbPoints = x.length;\n    return (parameters) => {\n        const fct = sumOfShapes(parameters);\n        let error = 0;\n        for (let i = 0; i < nbPoints; i++) {\n            error += (y[i] - fct(x[i])) ** 2;\n        }\n        return error;\n    };\n}\n//# sourceMappingURL=directOptimization.js.map","import { levenbergMarquardt } from 'ml-levenberg-marquardt';\nimport { directOptimization } from \"./wrappers/directOptimization.js\";\n/** Algorithm to select the method.\n * @param optimizationOptions - Optimization options\n * @returns - The algorithm and optimization options\n */\nexport function selectMethod(optimizationOptions = {}) {\n    const { kind = 'lm', options } = optimizationOptions;\n    switch (kind) {\n        case 'lm':\n        case 'levenbergMarquardt':\n            return {\n                algorithm: levenbergMarquardt,\n                optimizationOptions: {\n                    damping: 1.5,\n                    maxIterations: 100,\n                    errorTolerance: 1e-8,\n                    ...options,\n                },\n            };\n        case 'direct': {\n            return {\n                algorithm: directOptimization,\n                optimizationOptions: {\n                    iterations: 20,\n                    epsilon: 1e-4,\n                    tolerance: 1e-16,\n                    tolerance2: 1e-12,\n                    initialState: {},\n                    ...options,\n                },\n            };\n        }\n        default:\n            throw new Error(`Unknown fitting algorithm`);\n    }\n}\n//# sourceMappingURL=selectMethod.js.map","import { xMinMaxValues } from 'ml-spectra-processing';\nimport { getSumOfShapes } from \"./shapes/getSumOfShapes.js\";\nimport { getInternalPeaks } from \"./util/internalPeaks/getInternalPeaks.js\";\nimport { selectMethod } from \"./util/selectMethod.js\";\n/**\n * Fits a set of points to the sum of a set of bell functions.\n *\n * @param data - An object containing the x and y data to be fitted.\n * @param peaks - A list of initial parameters to be optimized. e.g. coming from a peak picking [{x, y, width}].\n * @param options - Options for optimize\n * @returns - An object with fitting error and the list of optimized parameters { parameters: [ {x, y, width} ], error } if the kind of shape is pseudoVoigt mu parameter is optimized.\n */\nexport function optimize(data, peaks, options = {}) {\n    // rescale data\n    const temp = xMinMaxValues(data.y);\n    const minMaxY = { ...temp, range: temp.max - temp.min };\n    const internalPeaks = getInternalPeaks(peaks, minMaxY, options);\n    // need to rescale what is related to Y\n    const { baseline: shiftValue = minMaxY.min } = options;\n    const normalizedY = new Float64Array(data.y.length);\n    for (let i = 0; i < data.y.length; i++) {\n        normalizedY[i] = (data.y[i] - shiftValue) / minMaxY.range;\n    }\n    const nbParams = internalPeaks[internalPeaks.length - 1].toIndex + 1;\n    const minValues = new Float64Array(nbParams);\n    const maxValues = new Float64Array(nbParams);\n    const initialValues = new Float64Array(nbParams);\n    const gradientDifferences = new Float64Array(nbParams);\n    let index = 0;\n    for (const peak of internalPeaks) {\n        for (let i = 0; i < peak.parameters.length; i++) {\n            minValues[index] = peak.propertiesValues.min[i];\n            maxValues[index] = peak.propertiesValues.max[i];\n            initialValues[index] = peak.propertiesValues.init[i];\n            gradientDifferences[index] = peak.propertiesValues.gradientDifference[i];\n            index++;\n        }\n    }\n    const { algorithm, optimizationOptions } = selectMethod(options.optimization);\n    const sumOfShapes = getSumOfShapes(internalPeaks);\n    const fitted = algorithm({ x: data.x, y: normalizedY }, sumOfShapes, {\n        minValues,\n        maxValues,\n        initialValues,\n        gradientDifference: gradientDifferences,\n        ...optimizationOptions,\n    });\n    const fittedValues = fitted.parameterValues;\n    const newPeaks = [];\n    for (const peak of internalPeaks) {\n        const { id, shape, parameters, fromIndex } = peak;\n        let newPeak = { x: 0, y: 0, shape };\n        if (id) {\n            newPeak = { ...newPeak, id };\n        }\n        newPeak.x = fittedValues[fromIndex];\n        newPeak.y = fittedValues[fromIndex + 1] * minMaxY.range + shiftValue;\n        for (let i = 2; i < parameters.length; i++) {\n            //@ts-expect-error should be fixed once\n            newPeak.shape[parameters[i]] = fittedValues[fromIndex + i];\n        }\n        newPeaks.push(newPeak);\n    }\n    return {\n        error: fitted.parameterError,\n        iterations: fitted.iterations,\n        peaks: newPeaks,\n    };\n}\n//# sourceMappingURL=index.js.map","import { getShape1D } from 'ml-peak-shape-generator';\n/**\n * add missing property if it does not exist in the peak,\n * if shape exists but fwhm doesn't, it will be calculated from peak.width\n */\nexport function addMissingShape(peaks, options = {}) {\n    const { shape = { kind: 'gaussian' }, output = structuredClone(peaks) } = options;\n    const shapeInstance = getShape1D(shape);\n    return output.map((peak) => {\n        if (hasShape(peak)) {\n            if (!('fwhm' in peak.shape)) {\n                const shapeInstance = getShape1D(peak.shape);\n                peak.shape.fwhm = shapeInstance.widthToFWHM(peak.width);\n            }\n            return peak;\n        }\n        return {\n            ...peak,\n            shape: { fwhm: shapeInstance.widthToFWHM(peak.width), ...shape },\n        };\n    });\n}\nfunction hasShape(peak) {\n    return 'shape' in peak;\n}\n//# sourceMappingURL=addMissingShape.js.map","/**\n * Group peaks based on factor\n * In order to group peaks we only need the x and width value. This means that\n * in the current implementation we don't take into account the asymmetry of peaks\n */\nexport function groupPeaks(peaks, options = {}) {\n    if (peaks?.length === 0)\n        return [];\n    const { factor = 1 } = options;\n    peaks = JSON.parse(JSON.stringify(peaks));\n    peaks.sort((a, b) => a.x - b.x);\n    let previousPeak = peaks[0];\n    let currentGroup = [previousPeak];\n    const groups = [currentGroup];\n    for (let i = 1; i < peaks.length; i++) {\n        const peak = peaks[i];\n        if ((peak.x - previousPeak.x) / ((peak.width + previousPeak.width) / 2) <=\n            factor) {\n            currentGroup.push(peak);\n        }\n        else {\n            currentGroup = [peak];\n            groups.push(currentGroup);\n        }\n        previousPeak = peak;\n    }\n    return groups;\n}\n//# sourceMappingURL=groupPeaks.js.map","import { getShape1D } from 'ml-peak-shape-generator';\nimport { optimize } from 'ml-spectra-fitting';\nimport { xGetFromToIndex } from 'ml-spectra-processing';\nimport { addMissingShape } from \"../utils/addMissingShape.js\";\nimport { groupPeaks } from \"../utils/groupPeaks.js\";\n/**\n * Optimize the position (x), max intensity (y), full width at half maximum (fwhm)\n * and the ratio of gaussian contribution (mu) if it's required. It currently supports three kind of shapes: gaussian, lorentzian and pseudovoigt\n * @param data - An object containing the x and y data to be fitted.\n * @param peakList - A list of initial parameters to be optimized. e.g. coming from a peak picking [{x, y, width}].\n */\nexport function optimizePeaksWithLogs(data, peakList, options = {}) {\n    const { fromTo = {}, baseline, shape = { kind: 'gaussian' }, groupingFactor = 1, factorLimits = 2, optimization = {\n        kind: 'lm',\n        options: {\n            timeout: 10,\n        },\n    }, } = options;\n    /*\n    The optimization algorithm will take some group of peaks.\n    We can not simply optimize everything because there would be too many variables to optimize\n    and it would be too time consuming.\n  */\n    const groups = groupPeaks(peakList, { factor: groupingFactor });\n    const logs = [];\n    const results = [];\n    groups.forEach((peakGroup) => {\n        const start = Date.now();\n        // In order to make optimization we will add fwhm and shape on all the peaks\n        const peaks = addMissingShape(peakGroup, { shape });\n        const firstPeak = peaks[0];\n        const lastPeak = peaks[peaks.length - 1];\n        const { from = firstPeak.x - firstPeak.width * factorLimits, to = lastPeak.x + lastPeak.width * factorLimits, } = fromTo;\n        const { fromIndex, toIndex } = xGetFromToIndex(data.x, { from, to });\n        const x = data.x instanceof Float64Array\n            ? data.x.subarray(fromIndex, toIndex)\n            : data.x.slice(fromIndex, toIndex);\n        const y = data.y instanceof Float64Array\n            ? data.y.subarray(fromIndex, toIndex)\n            : data.y.slice(fromIndex, toIndex);\n        const log = {\n            range: { from, to },\n            parameters: optimization,\n            groupSize: peakGroup.length,\n            time: Date.now() - start,\n        };\n        if (x.length > 5) {\n            const { iterations, error, peaks: optimizedPeaks, } = optimize({ x, y }, peaks, {\n                shape,\n                baseline,\n                optimization,\n            });\n            for (let i = 0; i < peaks.length; i++) {\n                results.push({\n                    ...optimizedPeaks[i],\n                    width: getShape1D(peaks[i].shape).fwhmToWidth(optimizedPeaks[i].shape.fwhm),\n                });\n            }\n            logs.push({\n                ...log,\n                iterations,\n                error,\n                message: 'optimization successful',\n            });\n        }\n        else {\n            results.push(...peaks);\n            logs.push({\n                ...log,\n                iterations: 0,\n                message: 'x length too small for optimization',\n            });\n        }\n    });\n    return { logs, optimizedPeaks: results };\n}\n//# sourceMappingURL=optimizePeaksWithLogs.js.map","import { optimizePeaksWithLogs } from \"./optimizePeaksWithLogs.js\";\n/**\n * Optimize the position (x), max intensity (y), full width at half maximum (fwhm)\n * and the ratio of gaussian contribution (mu) if it's required. It currently supports three kind of shapes: gaussian, lorentzian and pseudovoigt\n * @param data - An object containing the x and y data to be fitted.\n * @param peakList - A list of initial parameters to be optimized. e.g. coming from a peak picking [{x, y, width}].\n */\nexport function optimizePeaks(data, peakList, options = {}) {\n    return optimizePeaksWithLogs(data, peakList, options).optimizedPeaks;\n}\n//# sourceMappingURL=optimizePeaks.js.map","export function addMissingIDs(peaks, options = {}) {\n    const { output = structuredClone(peaks) } = options;\n    for (const peak of output) {\n        if (!('id' in peak)) {\n            peak.id = crypto.randomUUID();\n        }\n    }\n    return output;\n}\n//# sourceMappingURL=addMissingIDs.js.map","import { addMissingIDs } from \"../utils/addMissingIDs.js\";\nimport { addMissingShape } from \"../utils/addMissingShape.js\";\nimport { optimizePeaksWithLogs } from \"./optimizePeaksWithLogs.js\";\nexport function joinBroadPeaks(peakList, options = {}) {\n    const { shape = { kind: 'gaussian' }, optimization = { kind: 'lm', options: { timeout: 10 } }, broadWidth = 0.25, broadRatio = 0.0025, } = options;\n    let max = 0;\n    let maxI = 0;\n    let count = 1;\n    const broadLines = [];\n    if (peakList.length < 2) {\n        return addMissingIDs(addMissingShape(peakList.map(getGSDPeakOptimizedStructure), { shape }));\n    }\n    let maxDdy = peakList[0].ddY;\n    for (let i = 1; i < peakList.length; i++) {\n        if (Math.abs(peakList[i].ddY) > maxDdy)\n            maxDdy = Math.abs(peakList[i].ddY);\n    }\n    const newPeaks = [];\n    for (const peak of peakList) {\n        if (Math.abs(peak.ddY) <= broadRatio * maxDdy) {\n            broadLines.push(peak);\n        }\n        else {\n            newPeaks.push(getGSDPeakOptimizedStructure(peak));\n        }\n    }\n    //@ts-expect-error Push a feke peak\n    broadLines.push({ x: Number.MAX_VALUE, y: 0 });\n    let candidates = {\n        x: [broadLines[0].x],\n        y: [broadLines[0].y],\n    };\n    let indexes = [0];\n    for (let i = 1; i < broadLines.length; i++) {\n        if (Math.abs(broadLines[i - 1].x - broadLines[i].x) < broadWidth) {\n            candidates.x.push(broadLines[i].x);\n            candidates.y.push(broadLines[i].y);\n            if (broadLines[i].y > max) {\n                max = broadLines[i].y;\n                maxI = i;\n            }\n            indexes.push(i);\n            count++;\n        }\n        else {\n            if (count > 2) {\n                const initialWidth = Math.abs(candidates.x[candidates.x.length - 1] - candidates.x[0]);\n                const { logs, optimizedPeaks } = optimizePeaksWithLogs(candidates, [\n                    {\n                        id: crypto.randomUUID(),\n                        x: broadLines[maxI].x,\n                        y: max,\n                        width: initialWidth,\n                        parameters: {\n                            width: { max: initialWidth * 4, min: initialWidth * 0.8 },\n                        },\n                    },\n                ], { shape: { kind: 'pseudoVoigt' }, optimization });\n                [max, maxI] = [0, 0];\n                const log = logs.find((l) => l.message === 'optimization successful');\n                if (log) {\n                    const { error } = log;\n                    if (error < 0.2) {\n                        newPeaks.push(optimizedPeaks[0]);\n                    }\n                    else {\n                        pushBackPeaks(broadLines, indexes, newPeaks);\n                    }\n                }\n                else {\n                    pushBackPeaks(broadLines, indexes, newPeaks);\n                }\n            }\n            else {\n                pushBackPeaks(broadLines, indexes, newPeaks);\n            }\n            candidates = { x: [broadLines[i].x], y: [broadLines[i].y] };\n            indexes = [i];\n            max = broadLines[i].y;\n            maxI = i;\n            count = 1;\n        }\n    }\n    newPeaks.sort((a, b) => {\n        return a.x - b.x;\n    });\n    return addMissingIDs(newPeaks, { output: newPeaks });\n}\nfunction pushBackPeaks(broadLines, indexes, peaks) {\n    for (const index of indexes) {\n        peaks.push(getGSDPeakOptimizedStructure(broadLines[index]));\n    }\n}\nfunction getGSDPeakOptimizedStructure(peak) {\n    const { id, shape, x, y, width } = peak;\n    const newPeak = {\n        x,\n        y,\n        width,\n        shape,\n    };\n    if (id)\n        newPeak.id = id;\n    return newPeak;\n}\n//# sourceMappingURL=joinBroadPeaks.js.map","import { getShape1D } from 'ml-peak-shape-generator';\n/**\n * This method will allow to enlarge peaks while preventing overlap between peaks\n * A typical application in chromatography peak picking.\n * We should not make the hypothesis that x is equidistant\n * Because peaks may not be symmetric after we add 2 properties, from and to.\n * @return {Array} peakList\n */\nexport function broadenPeaks(peakList, options = {}) {\n    const { factor = 2, overlap = false } = options;\n    const peaks = mapPeaks(peakList, factor);\n    if (!overlap) {\n        for (let i = 0; i < peaks.length - 1; i++) {\n            const peak = peaks[i];\n            const nextPeak = peaks[i + 1];\n            if (peak.to.x > nextPeak.from.x) {\n                // we do it proportional to the width of the peaks\n                peak.to.x =\n                    (peak.width / (nextPeak.width + peak.width)) * (nextPeak.x - peak.x) +\n                        peak.x;\n                nextPeak.from.x = peak.to.x;\n            }\n        }\n    }\n    for (const peak of peaks) {\n        peak.width = peak.to.x - peak.from.x;\n        if (peak.shape) {\n            const { shape, width } = peak;\n            if (shape.fwhm !== undefined) {\n                const shapeFct = getShape1D(shape);\n                peak.shape.fwhm = shapeFct.widthToFWHM(width);\n            }\n        }\n    }\n    return peaks;\n}\nfunction mapPeaks(peaks, factor) {\n    return peaks.map((peak) => {\n        const { id, shape } = peak;\n        const xFrom = peak.x - (peak.x - peak.inflectionPoints.from.x) * factor;\n        const xTo = peak.x + (peak.inflectionPoints.to.x - peak.x) * factor;\n        let result = {\n            x: peak.x,\n            y: peak.y,\n            index: peak.index,\n            width: xTo - xFrom,\n            from: { x: xFrom },\n            to: { x: xTo },\n        };\n        if (id) {\n            result = { ...result, id };\n        }\n        if (shape) {\n            result = { ...result, shape };\n        }\n        return result;\n    });\n}\n//# sourceMappingURL=broadenPeaks.js.map","import { getShape1D } from 'ml-peak-shape-generator';\nconst { parse, stringify } = JSON;\n/**\n * Append 2 properties to the peaks, shape and fwhm\n */\nexport function setShape(peaks, options = {}) {\n    const { shape = { kind: 'gaussian' }, output = parse(stringify(peaks)), } = options;\n    const shapeInstance = getShape1D(shape);\n    return output.map((peak) => ({\n        ...peak,\n        shape: { fwhm: shapeInstance.widthToFWHM(peak.width), ...shape },\n    }));\n}\n//# sourceMappingURL=setShape.js.map"],"names":["toString","Object","prototype","isAnyArray","value","tag","call","endsWith","includes","sgg","ys","xs","options","windowSize","derivative","polynomial","Number","isInteger","RangeError","TypeError","length","console","warn","half","Math","floor","np","ans","Float64Array","weights","fullWeights","hs","constantH","i","wg1","wg2","d1","d2","l","getHs","wg","d","h","center","count","gramPoly","m","k","s","Grampoly","genFact","a","b","gf","j","weight","t","n","sum","Array","xMedian","input","exact","array","slice","middleIndex","calcMiddle","median","quickSelect","medianNext","low","high","middle","currentLow","currentHigh","swap","temp","xCheck","minLength","Error","xFindClosestIndex","target","sorted","abs","index","diff","POSITIVE_INFINITY","currentDiff","xGetFromToIndex","x","fromIndex","toIndex","from","to","undefined","max","arguments","_options$fromIndex","_options$toIndex","maxValue","min","minValue","rescale","output","currentMin","currentMax","_options$min","autoMinMax","_options$max","factor","defineProperty","matrix","require$$0","require$$1","indent","repeat","indentData","inspectMatrix","inspectMatrixWithOptions","maxRows","maxColumns","maxNumSize","padMinus","constructor","name","inspectData","rows","columns","maxI","maxJ","result","loop","get","line","push","formatNumber","join","num","formatNumber2","padEnd","len","str","fix","toFixed","startsWith","exp","toExponential","installMathOperations","AbstractMatrix","Matrix","add","addS","addM","set","checkMatrix","newMatrix","sub","subS","subM","subtract","subtractS","subtractM","mul","mulS","mulM","multiply","multiplyS","multiplyM","div","divS","divM","divide","divideS","divideM","mod","modS","modM","modulus","modulusS","modulusM","and","andS","andM","or","orS","orM","xor","xorS","xorM","leftShift","leftShiftS","leftShiftM","signPropagatingRightShift","signPropagatingRightShiftS","signPropagatingRightShiftM","rightShift","rightShiftS","rightShiftM","zeroFillRightShift","zeroFillRightShiftS","zeroFillRightShiftM","not","acos","acosh","asin","asinh","atan","atanh","cbrt","ceil","clz32","cos","cosh","expm1","fround","log","log1p","log10","log2","round","sign","sin","sinh","sqrt","tan","tanh","trunc","pow","arg0","powS","powM","checkRowIndex","outer","checkColumnIndex","checkRowVector","vector","to1DArray","checkColumnVector","checkRowIndices","rowIndices","checkColumnIndices","columnIndices","checkRange","startRow","endRow","startColumn","endColumn","checkNumber","newArray","checkNonEmpty","isEmpty","sumByRow","sumByColumn","sumAll","v","productByRow","productByColumn","productAll","varianceByRow","unbiased","mean","cols","variance","sum1","sum2","varianceByColumn","varianceAll","size","centerByRow","centerByColumn","centerAll","getScaleByRow","scale","scaleByRow","getScaleByColumn","scaleByColumn","getScaleAll","divider","scaleAll","from1DArray","newRows","newColumns","newData","row","column","rowVector","columnVector","zeros","ones","fill","rand","random","randInt","interval","eye","diag","data","matrix1","matrix2","isMatrix","klass","apply","callback","to2DArray","copy","toJSON","isRowVector","isColumnVector","isVector","isSquare","isSymmetric","isDistance","isEchelonForm","previousColumn","checked","isReducedEchelonForm","echelonForm","clone","iMax","swapRows","tmp","reducedEchelonForm","maxRow","p","pivot","setSubMatrix","neg","getRow","getRowVector","setRow","row1","row2","getColumn","getColumnVector","setColumn","swapColumns","column1","column2","addRowVector","subRowVector","mulRowVector","divRowVector","addColumnVector","subColumnVector","mulColumnVector","divColumnVector","mulRow","mulColumn","by","NaN","NEGATIVE_INFINITY","maxIndex","idx","minIndex","maxRowIndex","minRow","minRowIndex","maxColumn","maxColumnIndex","minColumn","minColumnIndex","norm","type","dot","cumulativeSum","vector2","vector1","mmul","other","Bcolj","mpow","scalar","bb","e","strassen2x2","a11","b11","a12","b12","a21","b21","a22","b22","m1","m2","m3","m4","m5","m6","m7","c00","c01","c10","c11","strassen3x3","a00","a01","a02","a10","a20","b00","b01","b02","b10","b20","m8","m9","m10","m11","m12","m13","m14","m15","m16","m17","m18","m19","m20","m21","m22","m23","c02","c12","c20","c21","c22","mmulStrassen","y","r1","c1","r2","c2","embed","mat","r","c","resultat","blockMult","halfRows","parseInt","halfCols","subMatrix","scaleRows","isFinite","scaleColumns","flipRows","first","last","flipColumns","kroneckerProduct","q","kroneckerSum","AxI","IxB","transpose","sortRows","compareFunction","compareNumbers","sort","sortColumns","subMatrixRow","indices","subMatrixColumn","selection","rowIndex","columnIndex","trace","entries","product","standardDeviation","Symbol","iterator","col","values","for","isArrayOfNumbers","every","element","randomInt","diagonal","identity","negate","tensorProduct","#initData","nRows","nColumns","arrayData","removeRow","splice","addRow","removeColumn","newRow","addColumn","SymmetricMatrix","diagonalSize","isSymmetricMatrix","klassType","upperRightEntries","toMatrix","removeCross","addCross","applyMask","mask","sidesToRemove","passthroughs","reverse","sideIndex","toCompact","compact","fromCompact","compactSize","JSON","stringify","upperRightValues","DistanceMatrix","isDistanceMatrix","klassSubType","sideSize","toSymmetricMatrix","compactLength","BaseView","MatrixColumnView","MatrixColumnSelectionView","MatrixFlipColumnView","MatrixFlipRowView","MatrixRowView","MatrixRowSelectionView","MatrixSelectionView","MatrixSubView","MatrixTransposeView","WrapperMatrix1D","_calculateIndex","WrapperMatrix2D","wrap","LuDecomposition","lu","pivotVector","pivotSign","LUcolj","kmax","LU","isSingular","solve","X","determinant","lowerTriangularMatrix","upperTriangularMatrix","pivotPermutationVector","hypotenuse","QrDecomposition","qr","rdiag","nrm","QR","Rdiag","isFullRank","orthogonalMatrix","SingularValueDecomposition","computeLeftSingularVectors","computeRightSingularVectors","autoTranspose","wantu","Boolean","wantv","swapped","aux","nu","ni","U","V","work","si","nct","nrt","mrc","pp","eps","EPSILON","kase","alpha","MIN_VALUE","isNaN","ks","f","cs","sn","sp","spm1","epm1","sk","ek","shift","g","Y","threshold","scols","Ls","rightSingularVectors","VL","vrows","urows","VLU","solveForDiagonal","inverse","vcols","ucols","condition","norm2","rank","tol","ii","leftSingularVectors","diagonalMatrix","useSVD","leftHandSide","rightHandSide","subMatrix0","subMatrix1","subMatrix2","xrange","exception","range","dependenciesOneRow","error","thresholdValue","thresholdError","returnArray","linearDependencies","results","Abis","svd","pseudoInverse","svdSolution","covariance","xMatrix","yMatrix","yIsSame","cov","correlation","sdx","sdy","corr","EigenvalueDecomposition","assumeSymmetric","tred2","tql2","H","ort","orthes","hqr2","realEigenvalues","imaginaryEigenvalues","eigenvectorMatrix","hh","dl1","c3","el1","s2","tst1","nn","exshift","z","iter","w","ra","sa","vr","vi","notlast","cdivres","cdiv","xr","xi","yr","yi","CholeskyDecomposition","dimension","positiveDefinite","L","isPositiveDefinite","B","nipals","scaleScores","maxIterations","terminationCriteria","u","tOld","counter","xResidual","residual","yResidual","betas","CHO","EVD","Matrix_1","NIPALS","Nipals","SVD","_default","default","inverse_1","xMaxValue","xMinValue","xIsEquallySpaced","tolerance","maxDx","minDx","MAX_SAFE_INTEGER","absoluteDifference","xIsMonotonic","at","xMedianAbsoluteDeviation","averageDeviations","mad","xMinMaxValues","xNoiseStandardDeviation","sd","xNorm","getMinMaxIntervalsDy","dY","dX","lastMax","lastMin","intervalL","intervalR","tryMatchOneIntervalWithMinData","lastK","minData","yThreshold","intervalWidth","intervalCenter","yData","minDistance","possible","newLastIndex","centerIndex","deltaX","currentDistance","lastIndex","autoAlgorithm","ddY","minddY","crossDy","peaks","lastJ","yIndex","match","width","id","crypto","randomUUID","inflectionPoints","getPeakFromIntervals","xGetCrossZeroPoints","isLessAndGreaterThanZero","back","next","firstDerivative","secondDerivative","optimizeTop","peak","currentIndex","beta","gamma","xCurrent","xPrevious","gsd","noiseLevel","sgOptions","smoothY","maxCriteria","minMaxRatio","realTopDetection","peakDetectionAlgorithm","isEquallySpaced","noiseInfo","xValue","minY","maxY","peakData","forEach","GAUSSIAN_EXP_FACTOR","LN2","ROOT_PI_OVER_LN2","PI","ROOT_THREE","ROOT_2LN2","ROOT_2LN2_MINUS_ONE","erfinv","ln1MinusXSqrd","lnEtcBy2Plus2","firstSqrt","secondSqrt","Gaussian","fwhm","gaussianWidthToFWHM","fwhmToWidth","gaussianFwhmToWidth","widthToFWHM","fct","gaussianFct","getArea","height","calculateGaussianHeight","getGaussianArea","getFactor","area","getGaussianFactor","getData","getGaussianData","calculateHeight","getParameters","shape","Lorentzian","lorentzianFwhmToWidth","lorentzianWidthToFWHM","lorentzianFct","getLorentzianArea","getLorentzianFactor","getLorentzianData","calculateLorentzianHeight","halfResidual","quantileFunction","LorentzianDispersive","lorentzianDispersiveFct","_height","getLorentzianDispersiveData","PseudoVoigt","mu","pseudoVoigtFwhmToWidth","pseudoVoigtWidthToFWHM","pseudoVoigtFct","getPseudoVoigtArea","getPseudoVoigtFactor","calculatePseudoVoigtHeight","getPseudoVoigtData","GeneralizedLorentzian","generalizedLorentzianFwhmToWidth","generalizedLorentzianWidthToFWHM","generalizedLorentzianFct","getGeneralizedLorentzianArea","getGeneralizedLorentzianFactor","getGeneralizedLorentzianData","calculateGeneralizedLorentzianHeight","getShape1D","kind","getSumOfShapes","internalPeaks","sumOfShapes","parameters","totalY","peakX","shapeFctKey","shapeFct","assert","message","DefaultParameters","init","peakShape","gradientDifference","properties","getInternalPeaks","minMaxY","baseline","shiftValue","normalizedPeaks","map","propertiesValues","parameter","property","propertyValue","getNormalizedValue","generalParameterValue","defaultParameterValues","checkOptions","timeout","initialValues","damping","dampingStepUp","dampingStepDown","errorTolerance","centralDifference","improvementThreshold","minValues","maxValues","parLen","MIN_SAFE_INTEGER","gradientDifferenceArray","getGradientDifferenceArray","filler","getFiller","checkTimeout","getCheckTimeout","weightSquare","_","dataLength","endTime","Date","now","errorCalculation","parameterizedFunction","func","gradientFunction","evaluatedData","params","paramFunction","nbParams","nbPoints","param","delta","auxParams","funcParam","point","funcParam2","matrixFunction","step","gradientFunc","residualError","inverseMatrix","jacobianWeightResidualError","perturbations","levenbergMarquardt","checkedOptions","optimalError","optimalParameters","converged","iteration","previousError","improvementMetric","parameterValues","parameterError","iterations","antiLowerConvexHull","currentPoint","moveOn","det","leftTurn","moveBack","item","filter","direct","objectiveFunction","lowerBoundaries","upperBoundaries","epsilon","tolerance2","initialState","diffBorders","numberOfRectangles","totalIterations","unitaryCoordinates","middlePoint","bestCurrentValue","fCalls","smallerDistance","edgeSizes","diagonalDistances","functionValues","differentDistances","smallerValuesByDistance","choiceLimit","originalCoordinates","getMinIndex","S1","findIndex","optimumValuesIndex","S3","a1","b1","a2","b2","slope","constant","S2","Uint32Array","xHull","yHull","lowerIndexHull","largerSide","largeSidesIndex","bestFunctionValues","firstMiddleCenter","secondMiddleCenter","firstMiddleValue","secondMiddleValue","firstMinValue","secondMinValue","ix1","ix2","Set","minFunctionValue","pair","finalState","minimizer","optima","directOptimization","getObjectiveFunction","selectMethod","optimizationOptions","algorithm","optimize","normalizedY","gradientDifferences","optimization","fitted","fittedValues","newPeaks","newPeak","addMissingShape","structuredClone","shapeInstance","hasShape","groupPeaks","parse","previousPeak","currentGroup","groups","optimizePeaksWithLogs","peakList","fromTo","groupingFactor","factorLimits","logs","peakGroup","start","firstPeak","lastPeak","subarray","groupSize","time","optimizedPeaks","optimizePeaks","addMissingIDs","joinBroadPeaks","broadWidth","broadRatio","broadLines","getGSDPeakOptimizedStructure","maxDdy","MAX_VALUE","candidates","indexes","initialWidth","find","pushBackPeaks","broadenPeaks","overlap","mapPeaks","nextPeak","xFrom","xTo","setShape"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49]}