{"version":3,"file":"mass-spectrum.min.js","sources":["../node_modules/ml-spectra-processing/lib-esm/reim/reimAbsolute.js","../node_modules/is-any-array/lib-esm/index.js","../node_modules/ml-spectra-processing/lib-esm/x/getOutputArray.js","../node_modules/ml-spectra-processing/lib-esm/x/xAbsolute.js","../node_modules/ml-spectra-processing/lib-esm/x/xMedian.js","../node_modules/ml-spectra-processing/lib-esm/x/xCheck.js","../node_modules/ml-spectra-processing/lib-esm/x/xFindClosestIndex.js","../node_modules/ml-spectra-processing/lib-esm/x/xGetFromToIndex.js","../node_modules/ml-spectra-processing/lib-esm/x/xAbsoluteSum.js","../node_modules/ml-spectra-processing/lib-esm/x/xAdd.js","../node_modules/ml-spectra-processing/lib-esm/x/xApplyFunctionStr.js","../node_modules/ml-spectra-processing/lib-esm/x/xMultiply.js","../node_modules/ml-spectra-processing/lib-esm/x/xDotProduct.js","../node_modules/ml-spectra-processing/lib-esm/x/xCrossCorrelation.js","../node_modules/ml-spectra-processing/lib-esm/x/xBoxPlot.js","../node_modules/ml-spectra-processing/lib-esm/x/xBoxPlotWithOutliers.js","../node_modules/ml-spectra-processing/lib-esm/x/xCheckLengths.js","../node_modules/ml-spectra-processing/lib-esm/x/xCorrelation.js","../node_modules/ml-array-rescale/lib-es6/index.js","../node_modules/ml-array-min/lib-es6/index.js","../node_modules/ml-array-max/lib-es6/index.js","../node_modules/ml-matrix/matrix.js","../node_modules/ml-matrix/matrix.mjs","../node_modules/ml-spectra-processing/lib-esm/x/xCostMatrix.js","../node_modules/ml-spectra-processing/lib-esm/x/xCumulative.js","../node_modules/ml-spectra-processing/lib-esm/x/xMean.js","../node_modules/ml-spectra-processing/lib-esm/x/xVariance.js","../node_modules/ml-spectra-processing/lib-esm/x/xStandardDeviation.js","../node_modules/ml-spectra-processing/lib-esm/x/xDivide.js","../node_modules/ml-spectra-processing/lib-esm/x/xEnsureFloat64.js","../node_modules/ml-spectra-processing/lib-esm/x/xGetTargetIndex.js","../node_modules/fft.js/lib/fft.js","../node_modules/ml-spectra-processing/lib-esm/utils/createArray.js","../node_modules/ml-spectra-processing/lib-esm/utils/createFromToArray.js","../node_modules/ml-xsadd/lib-esm/XSadd.js","../node_modules/ml-spectra-processing/lib-esm/utils/createRandomArray.js","../node_modules/ml-spectra-processing/lib-esm/utils/isPowerOfTwo.js","../node_modules/ml-spectra-processing/lib-esm/utils/nextPowerOfTwo.js","../node_modules/ml-spectra-processing/lib-esm/utils/recursiveResolve.js","../node_modules/ml-spectra-processing/lib-esm/utils/recursiveUntypeArrays.js","../node_modules/ml-spectra-processing/lib-esm/utils/stringify.js","../node_modules/ml-spectra-processing/lib-esm/x/xSubtract.js","../node_modules/ml-spectra-processing/lib-esm/utils/calculateAdaptiveWeights.js","../node_modules/ml-spectra-processing/lib-esm/x/xHilbertTransform.js","../node_modules/ml-spectra-processing/lib-esm/x/xMaxValue.js","../node_modules/ml-spectra-processing/lib-esm/x/xMinValue.js","../node_modules/ml-spectra-processing/lib-esm/x/xHistogram.js","../node_modules/ml-spectra-processing/lib-esm/x/xIsEquallySpaced.js","../node_modules/ml-spectra-processing/lib-esm/x/xIsMonotonic.js","../node_modules/ml-spectra-processing/lib-esm/x/xMassCenterVectorSimilarity.js","../node_modules/ml-spectra-processing/lib-esm/x/xMedianAbsoluteDeviation.js","../node_modules/ml-spectra-processing/lib-esm/x/xMinMaxValues.js","../node_modules/ml-spectra-processing/lib-esm/x/utils/erfcinv.js","../node_modules/ml-spectra-processing/lib-esm/x/utils/simpleNormInv.js","../node_modules/ml-spectra-processing/lib-esm/x/xNoiseSanPlot.js","../node_modules/ml-spectra-processing/lib-esm/x/xNoiseStandardDeviation.js","../node_modules/ml-spectra-processing/lib-esm/x/xNorm.js","../node_modules/ml-spectra-processing/lib-esm/x/xSum.js","../node_modules/ml-spectra-processing/lib-esm/x/xNormed.js","../node_modules/ml-spectra-processing/lib-esm/x/xPadding.js","../node_modules/ml-spectra-processing/lib-esm/x/xParetoNormalization.js","../node_modules/ml-spectra-processing/lib-esm/x/xRescale.js","../node_modules/ml-spectra-processing/lib-esm/x/xRolling.js","../node_modules/ml-spectra-processing/lib-esm/x/xRollingAverage.js","../node_modules/ml-spectra-processing/lib-esm/x/xRollingMedian.js","../node_modules/ml-spectra-processing/lib-esm/x/xRotate.js","../node_modules/ml-spectra-processing/lib-esm/x/xSequentialFillFromStep.js","../node_modules/ml-spectra-processing/lib-esm/x/xSortDescending.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixCholeskySolver.js","../node_modules/ml-spectra-processing/lib-esm/utils/addWeights.js","../node_modules/ml-spectra-processing/lib-esm/x/xWhittakerSmoother.js","../node_modules/ml-spectra-processing/lib-esm/utils/createSystemMatrix.js","../node_modules/ml-spectra-processing/lib-esm/reim/reimPhaseCorrection.js","../node_modules/ml-spectra-processing/lib-esm/reim/reimAutoPhaseCorrection.js","../node_modules/ml-spectra-processing/lib-esm/reim/reimFFT.js","../node_modules/ml-spectra-processing/lib-esm/reim/reimZeroFilling.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyCheck.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMaxYPoint.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyCumulativeDistributionStatistics.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyEnsureGrowingX.js","../node_modules/ml-spectra-processing/lib-esm/zones/zonesNormalize.js","../node_modules/ml-spectra-processing/lib-esm/zones/zonesWithPoints.js","../node_modules/ml-spectra-processing/lib-esm/xy/utils/integral.js","../node_modules/ml-spectra-processing/lib-esm/xy/utils/equallySpacedSmooth.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyEquallySpaced.js","../node_modules/ml-spectra-processing/lib-esm/xy/utils/equallySpacedSlot.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyFilterX.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyFilterXPositive.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyGrowingX.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyJoinX.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyReduce.js","../node_modules/ml-spectra-processing/lib-esm/xy/xySortX.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyUniqueX.js","../node_modules/ml-spectra-processing/lib-esm/xyArray/utils/getSlots.js","../node_modules/ml-spectra-processing/lib-esm/xyArray/xyArrayWeightedMerge.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectCheck.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectMaxXPoint.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectMinXPoint.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixCreateEmpty.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixCheck.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixClone.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixCheckRanges.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixMinMaxAbsoluteZ.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixMinMaxZ.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixMaxAbsoluteZ.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixToArray.js","../node_modules/ml-spectra-processing/lib-esm/utils/createStepArray.js","../node_modules/ml-spectra-processing/lib-esm/utils/getRescaler.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixAbsoluteMedian.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixApplyNumericalEncoding.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixAutoCorrelation.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixBoxPlot.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixCenterZMean.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixColumnsCorrelation.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixCuthillMckee.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixGetSubMatrix.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixHistogram.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixMedian.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixNoiseStandardDeviation.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixNumericalDecoding.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixNumericalEncoding.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixPQN.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixSetSubMatrix.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixTranspose.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixZPivotRescale.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixZRescale.js","../node_modules/ml-spectra-processing/lib-esm/matrix/matrixZRescalePerColumn.js","../node_modules/ml-spectra-processing/lib-esm/x/xAbsoluteMedian.js","../node_modules/ml-spectra-processing/lib-esm/x/xAutoCorrelation.js","../node_modules/ml-spectra-processing/lib-esm/x/xDistributionStats.js","../node_modules/ml-spectra-processing/lib-esm/x/xMaxAbsoluteValue.js","../node_modules/ml-spectra-processing/lib-esm/x/xMaxIndex.js","../node_modules/ml-spectra-processing/lib-esm/x/xMeanAbsoluteError.js","../node_modules/ml-spectra-processing/lib-esm/x/xMeanSquaredError.js","../node_modules/ml-spectra-processing/lib-esm/x/xMeanWeighted.js","../node_modules/ml-spectra-processing/lib-esm/x/xMinIndex.js","../node_modules/ml-spectra-processing/lib-esm/x/xMinMaxDelta.js","../node_modules/ml-spectra-processing/lib-esm/x/xMode.js","../node_modules/ml-spectra-processing/lib-esm/x/xRemoveOutliersIQR.js","../node_modules/ml-spectra-processing/lib-esm/x/xRobustDistributionStats.js","../node_modules/ml-spectra-processing/lib-esm/x/xRollingMax.js","../node_modules/ml-spectra-processing/lib-esm/x/xRollingMin.js","../node_modules/ml-spectra-processing/lib-esm/x/xSampling.js","../node_modules/ml-spectra-processing/lib-esm/x/xSequentialFillFromTo.js","../node_modules/ml-spectra-processing/lib-esm/x/xSortAscending.js","../node_modules/ml-spectra-processing/lib-esm/x/xUniqueSorted.js","../node_modules/ml-spectra-processing/lib-esm/xreim/xreimSortX.js","../node_modules/ml-spectra-processing/lib-esm/xreim/xreimZeroFilling.js","../node_modules/ml-spectra-processing/lib-esm/xy2/xy2ToXY.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyAlign.js","../node_modules/ml-spectra-processing/lib-esm/xyArray/xyArrayAlign.js","../node_modules/ml-spectra-processing/lib-esm/xyArray/xyArrayAlignToFirst.js","../node_modules/ml-spectra-processing/lib-esm/xyArray/utils/getSlotsToFirst.js","../node_modules/ml-spectra-processing/lib-esm/xyArray/xyArrayMerge.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyCovariance.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyEnsureFloat64.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyExtract.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyFilter.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyFilterMinYValue.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyFilterTopYValues.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyFindClosestPoint.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyGetNMaxY.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyIntegral.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyIntegration.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMassCenter.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMassCenterVector.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMaxClosestYPoint.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMaxMerge.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMaxY.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMaximaY.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMedian.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMergeByCentroids.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMinClosestYPoint.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMinYPoint.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyMinimaY.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectBestPoints.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectJoinX.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectMaxYPoint.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectMinMaxValues.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectMinYPoint.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectNormedY.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectSlotX.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectSortX.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectSumY.js","../node_modules/ml-spectra-processing/lib-esm/xyObject/xyObjectToXY.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyPeakInfo.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyRealMaxYPoint.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyRealMinYPoint.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyReduceNonContinuous.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyRolling.js","../node_modules/ml-spectra-processing/lib-esm/xy/xySetYValue.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyToXYArray.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyToXYObject.js","../node_modules/ml-spectra-processing/lib-esm/xy/xyWeightedMerge.js","../node_modules/common-spectrum/lib/jsgraph/addStyle.js","../node_modules/common-spectrum/lib/jsgraph/colors.js","../node_modules/ml-airpls/src/choleskySolver.js","../node_modules/cuthill-mckee/cuthill-mckee.js","../node_modules/ml-airpls/src/utils.js","../node_modules/ml-airpls/src/index.js","../node_modules/ml-array-sequential-fill/lib-es6/index.js","../node_modules/ml-regression-base/lib-esm/checkArrayLength.js","../node_modules/ml-regression-base/lib-esm/BaseRegression.js","../node_modules/ml-regression-base/lib-esm/maybeToPrecision.js","../node_modules/ml-regression-polynomial/lib-esm/index.js","../node_modules/baselines/src/iterativePolynomial.js","../node_modules/ml-baseline-correction-regression/src/index.js","../node_modules/baselines/src/rollingBall.js","../node_modules/ml-rolling-ball-baseline/lib-esm/rollingBall.js","../node_modules/ml-savitzky-golay-generalized/lib-esm/index.js","../node_modules/ml-gsd/lib/gsd.js","../node_modules/ml-gsd/lib/utils/optimizeTop.js","../node_modules/ml-peak-shape-generator/lib-esm/util/constants.js","../node_modules/ml-peak-shape-generator/lib-esm/shapes/1d/gaussian/Gaussian.js","../node_modules/ml-peak-shape-generator/lib-esm/util/erfinv.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/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/step.js","../node_modules/ml-levenberg-marquardt/lib/gradient_function.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/index.js","../node_modules/ml-spectra-fitting/lib/util/selectMethod.js","../node_modules/ml-spectra-fitting/lib/shapes/getSumOfShapes.js","../node_modules/ml-gsd/lib/utils/addMissingShape.js","../node_modules/ml-gsd/lib/post/optimizePeaksWithLogs.js","../node_modules/ml-gsd/lib/utils/groupPeaks.js","../node_modules/ml-gsd/lib/utils/addMissingIDs.js","../node_modules/ml-gsd/lib/post/joinBroadPeaks.js","../node_modules/ml-gsd/lib/utils/setShape.js","../node_modules/ml-gsd/lib/post/broadenPeaks.js","../node_modules/ml-gsd/lib/post/optimizePeaks.js","../node_modules/ml-signal-processing/lib/filters/baseline/airPLSBaseline.js","../node_modules/baselines/src/airPLS.js","../node_modules/ml-signal-processing/lib/filters/x/calibrateX.js","../node_modules/ml-signal-processing/lib/filters/scaling/centerMean.js","../node_modules/ml-signal-processing/lib/filters/scaling/centerMedian.js","../node_modules/ml-signal-processing/lib/filters/scaling/divideBySD.js","../node_modules/ml-signal-processing/lib/filters/x/ensureGrowing.js","../node_modules/ml-signal-processing/lib/filters/x/equallySpaced.js","../node_modules/ml-signal-processing/lib/filters/x/filterX.js","../node_modules/ml-signal-processing/lib/filters/sg/firstDerivative.js","../node_modules/ml-signal-processing/lib/filters/x/fromTo.js","../node_modules/ml-signal-processing/lib/filters/baseline/iterativePolynomialBaseline.js","../node_modules/ml-signal-processing/lib/filters/scaling/normed.js","../node_modules/ml-signal-processing/lib/filters/scaling/paretoNormalization.js","../node_modules/ml-signal-processing/lib/filters/scaling/rescale.js","../node_modules/ml-signal-processing/lib/filters/x/reverseIfNeeded.js","../node_modules/ml-signal-processing/lib/filters/baseline/rollingAverageBaseline.js","../node_modules/baselines/src/rollingAverage.js","../node_modules/ml-signal-processing/lib/filters/baseline/rollingBallBaseline.js","../node_modules/ml-signal-processing/lib/filters/baseline/rollingMedianBaseline.js","../node_modules/baselines/src/rollingMedian.js","../node_modules/ml-signal-processing/lib/filters/sg/savitzkyGolay.js","../node_modules/ml-signal-processing/lib/filters/sg/secondDerivative.js","../node_modules/ml-signal-processing/lib/filters/x/setMaxX.js","../node_modules/ml-signal-processing/lib/filters/y/setMaxY.js","../node_modules/ml-signal-processing/lib/filters/x/setMinX.js","../node_modules/ml-signal-processing/lib/filters/y/setMinY.js","../node_modules/ml-signal-processing/lib/filters/sg/thirdDerivative.js","../node_modules/ml-signal-processing/lib/filters/x/xFunction.js","../node_modules/ml-signal-processing/lib/filters/scaling/yFunction.js","../node_modules/common-spectrum/lib/util/getNormalizedSpectrum.js","../node_modules/ml-signal-processing/lib/filterXY.js","../node_modules/js-quantities/build/quantities.js","../node_modules/common-spectrum/lib/util/convertUnit.js","../node_modules/common-spectrum/lib/util/ensureRegexp.js","../node_modules/common-spectrum/lib/util/getConvertedVariable.js","../node_modules/common-spectrum/lib/util/getXYSpectra.js","../node_modules/common-spectrum/lib/Analysis.js","../node_modules/common-spectrum/lib/util/getXYSpectrum.js","../node_modules/common-spectrum/lib/util/appendDistinctParameter.js","../node_modules/common-spectrum/lib/util/appendDistinctValue.js","../node_modules/common-spectrum/lib/AnalysesManager.js","../node_modules/ensure-string/lib-esm/index.js","../node_modules/isutf8/dist/index.esm.js","../node_modules/dynamic-typing/lib-esm/parseString.js","../node_modules/gyromagnetic-ratio/lib-esm/getGyromagneticRatio.js","../node_modules/gyromagnetic-ratio/lib-esm/getGyromagneticNucleus.js","../node_modules/gyromagnetic-ratio/lib-esm/index.js","../node_modules/gyromagnetic-ratio/lib-esm/gyromagneticRatioMHzT.js","../node_modules/median-quickselect/lib/median-quickselect.min.js","../node_modules/ml-array-median/lib-es6/index.js","../node_modules/jcampconverter/dist/jcampconverter.js","../node_modules/common-spectrum/lib/from/fromJcamp.js","../node_modules/xy-parser/lib-esm/parse.js","../node_modules/xy-parser/lib-esm/index.js","../node_modules/convert-to-jcamp/lib-esm/utils/addInfoData.js","../node_modules/convert-to-jcamp/lib-esm/utils/checkNumberOrArray.js","../node_modules/convert-to-jcamp/lib-esm/utils/getExtremeValues.js","../node_modules/convert-to-jcamp/lib-esm/utils/checkMatrix.js","../node_modules/convert-to-jcamp/lib-esm/utils/getBestFactor.js","../node_modules/convert-to-jcamp/lib-esm/utils/getFactorNumber.js","../node_modules/convert-to-jcamp/lib-esm/utils/getNumber.js","../node_modules/convert-to-jcamp/lib-esm/utils/vectorEncoder.js","../node_modules/convert-to-jcamp/lib-esm/utils/xyDataCreator.js","../node_modules/convert-to-jcamp/lib-esm/utils/rescaleAndEnsureInteger.js","../node_modules/convert-to-jcamp/lib-esm/fromJSON.js","../node_modules/convert-to-jcamp/lib-esm/utils/peakTableCreator.js","../node_modules/convert-to-jcamp/lib-esm/fromVariables.js","../node_modules/convert-to-jcamp/lib-esm/creatorNtuples.js","../node_modules/common-spectrum/lib/to/toJcamps.js","../node_modules/common-spectrum/lib/index.js","../node_modules/common-spectrum/lib/jsgraph/getJSGraph.js","../node_modules/common-spectrum/lib/jsgraph/getNormalizationAnnotations.js","../node_modules/ms-spectrum/lib/src/getBestPeaks.js","../node_modules/atom-sorter/lib/src/index.js","../node_modules/chemical-elements/lib/src/elementsAndIsotopes.js","../node_modules/chemical-elements/lib/src/elements.js","../node_modules/chemical-elements/lib/src/elementsAndIsotopesObject.js","../node_modules/chemical-elements/lib/src/elementsAndStableIsotopes.js","../node_modules/chemical-elements/lib/src/elementsAndStableIsotopesObject.js","../node_modules/chemical-elements/lib/src/elementsObject.js","../node_modules/chemical-elements/lib/src/isotopesObject.js","../node_modules/chemical-elements/lib/src/stableIsotopesObject.js","../node_modules/chemical-elements/lib/src/unsaturationsObject.js","../node_modules/chemical-groups/lib/src/groupsObject.js","../node_modules/chemical-groups/lib/src/groupsToSequence.js","../node_modules/mf-parser/lib/src/Kind.js","../node_modules/mf-parser/lib/src/util/parseCharge.js","../node_modules/mf-parser/lib/src/parse.js","../node_modules/mf-parser/lib/src/util/subSuperscript.js","../node_modules/mf-parser/lib/src/Format.js","../node_modules/mf-parser/lib/src/util/formatCharge.js","../node_modules/mf-parser/lib/src/util/improveLinesForDisplay.js","../node_modules/mf-parser/lib/src/util/toDisplay.js","../node_modules/mf-parser/lib/src/util/isMF.js","../node_modules/mf-parser/lib/src/Style.js","../node_modules/mf-parser/lib/src/util/toHtml.js","../node_modules/mf-parser/lib/src/ensureCase.js","../node_modules/mf-parser/lib/src/util/flatten.js","../node_modules/mf-parser/lib/src/util/getIsotopeRatioInfo.js","../node_modules/mf-parser/lib/src/util/getEA.js","../node_modules/mf-parser/lib/src/util/getElements.js","../node_modules/mf-parser/lib/src/util/getNumberOfIsotopologues.js","../node_modules/mf-parser/lib/src/util/partToAtoms.js","../node_modules/mf-parser/lib/src/util/partToMF.js","../node_modules/mf-parser/lib/src/util/getInfoInternal.js","../node_modules/mf-parser/lib/src/util/getIsotopesInfo.js","../node_modules/mf-parser/lib/src/util/partsToDisplay.js","../node_modules/mf-parser/lib/src/util/partsToMF.js","../node_modules/mf-parser/lib/src/util/toParts.js","../node_modules/mf-parser/lib/src/util/toText.js","../node_modules/mf-parser/lib/src/MFInternal.js","../node_modules/mf-parser/lib/src/MF.js","../node_modules/mf-parser/lib/src/parseToHtml.js","../node_modules/mf-matcher/lib/src/unsaturationMatcher.js","../node_modules/mf-matcher/lib/src/generalMatcher.js","../node_modules/mf-utilities/lib/src/ensureUppercaseSequence.js","../node_modules/mf-utilities/lib/src/getEutrophicationPotential.js","../node_modules/mf-utilities/lib/src/getMsem.js","../node_modules/mf-utilities/lib/src/getMsInfo.js","../node_modules/mf-utilities/lib/src/getRangesForFragment.js","../node_modules/mf-utilities/lib/src/MFRange.js","../node_modules/mf-utilities/lib/src/mfDiff.js","../node_modules/mf-utilities/lib/src/preprocessIonizations.js","../node_modules/mf-utilities/lib/src/preprocessRanges.js","../node_modules/mf-matcher/lib/src/msemMatcher.js","../node_modules/mf-finder/lib/src/TargetMassCache.js","../node_modules/mf-finder/lib/src/findMFsSync.js","../node_modules/mf-finder/lib/src/findMFs.js","../node_modules/mf-finder/lib/src/mfIncluded.js","../node_modules/ms-spectrum/lib/src/from/fromMonoisotopicMass.js","../node_modules/ms-spectrum/lib/src/getPeaks.js","../node_modules/ms-spectrum/lib/src/getFragmentPeaks.js","../node_modules/ms-spectrum/lib/src/getMassRemainder.js","../node_modules/peaks-similarity/lib-esm/calculateOverlapFromDiff.js","../node_modules/peaks-similarity/lib-esm/checkPeaks.js","../node_modules/peaks-similarity/lib-esm/extract.js","../node_modules/peaks-similarity/lib-esm/getCommonArray.js","../node_modules/ml-stat/array.js","../node_modules/ml-stat/index.js","../node_modules/peaks-similarity/lib-esm/normalize.js","../node_modules/peaks-similarity/lib-esm/commonExtractAndNormalize.js","../node_modules/peaks-similarity/lib-esm/extractAndNormalize.js","../node_modules/peaks-similarity/lib-esm/getIntersection.js","../node_modules/peaks-similarity/lib-esm/index.js","../node_modules/ms-spectrum/lib/src/getPeakChargeBySimilarity.js","../node_modules/ms-spectrum/lib/src/getPeaksWithCharge.js","../node_modules/ms-spectrum/lib/src/isContinuous.js","../node_modules/ms-spectrum/lib/src/peakPicking.js","../node_modules/ml-regression-simple-linear/lib-esm/index.js","../node_modules/ml-regression-power/src/index.js","../node_modules/ms-spectrum/lib/src/peaksWidth.js","../node_modules/ms-spectrum/lib/src/Spectrum.js","../node_modules/ms-spectrum/lib/src/MSComparator.js","../node_modules/ms-spectrum/lib/src/jsgraph/getPeaksAnnotation.js","../node_modules/ms-spectrum/lib/src/jsgraph/index.js","../lib/from/utils/spectrumCallback.js","../lib/index.js","../lib/jsgraph/getAnnotations.js","../lib/from/fromJcamp.js","../lib/from/fromText.js","../node_modules/common-spectrum/lib/util/peakPicking.js","../node_modules/common-spectrum/lib/to/toJcamp.js"],"sourcesContent":["/**\n * Calculates reimAbsolute value of a complex spectrum.\n * @param data - complex spectrum\n * @returns - reimAbsolute value\n */\nexport function reimAbsolute(data) {\n    const length = data.re.length;\n    const re = data.re;\n    const im = data.im;\n    const newArray = new Float64Array(length);\n    for (let i = 0; i < length; i++) {\n        newArray[i] = Math.hypot(re[i], im[i]);\n    }\n    return newArray;\n}\n//# sourceMappingURL=reimAbsolute.js.map","// 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 * This function\n * @param output - undefined or a new array\n * @param length - length of the output array\n * @returns\n */\nexport function getOutputArray(output, length) {\n    if (output !== undefined) {\n        if (!isAnyArray(output)) {\n            throw new TypeError('output option must be an array if specified');\n        }\n        if (output.length !== length) {\n            throw new TypeError('the output array does not have the correct length');\n        }\n        return output;\n    }\n    else {\n        return new Float64Array(length);\n    }\n}\n//# sourceMappingURL=getOutputArray.js.map","/**\n * This function returns an array with absolute values.\n * @param array - array of data\n * @returns - array with absolute values\n */\nexport function xAbsolute(array) {\n    const tmpArray = array.slice();\n    for (let i = 0; i < tmpArray.length; i++) {\n        if (tmpArray[i] < 0)\n            tmpArray[i] *= -1;\n    }\n    return tmpArray;\n}\n//# sourceMappingURL=xAbsolute.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';\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 { xCheck } from './xCheck';\nimport { xGetFromToIndex } from './xGetFromToIndex';\nexport function xAbsoluteSum(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let sum = 0;\n    for (let i = fromIndex; i <= toIndex; i++) {\n        sum += Math.abs(array[i]);\n    }\n    return sum;\n}\n//# sourceMappingURL=xAbsoluteSum.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * This function xAdd the first array by the second array or a constant value to each element of the first array\n * @param array1 - the first array\n * @param array2 - the second array or number\n * @returns the result of the addition\n */\nexport function xAdd(array1, array2) {\n    let isConstant = false;\n    let constant = 0;\n    if (isAnyArray(array2)) {\n        if (array1.length !== array2.length) {\n            throw new Error('size of array1 and array2 must be identical');\n        }\n    }\n    else {\n        isConstant = true;\n        constant = array2;\n    }\n    const array3 = new Float64Array(array1.length);\n    if (isConstant) {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] + constant;\n        }\n    }\n    else {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] + array2[i];\n        }\n    }\n    return array3;\n}\n//# sourceMappingURL=xAdd.js.map","/**\n * Will apply a function on each element of the array described as a string\n * By default we will use as variable 'x'\n * In front of sequence of lowercase we will add 'Math.'. This allows to write\n * `sin(x) + cos(x)` and it will be replace internally by (x) => (Math.sin(x) + Math.cos(x))\n * @param array\n * @param options\n * @returns\n */\nexport function xApplyFunctionStr(array, options = {}) {\n    const { variableLabel = 'x', fctString = variableLabel } = options;\n    const fct = new Function(variableLabel, `return Number(${fctString\n        .replaceAll(/(?<before>^|\\W)(?<after>[\\da-z]{2,}\\()/g, '$<before>Math.$<after>')\n        .replaceAll('Math.Math', 'Math')})`);\n    const toReturn = Float64Array.from(array);\n    for (let i = 0; i < array.length; i++) {\n        toReturn[i] = fct(array[i]);\n        if (Number.isNaN(toReturn[i])) {\n            throw new Error(`The callback ${fctString} does not return a number: ${array[i]}`);\n        }\n    }\n    return toReturn;\n}\n//# sourceMappingURL=xApplyFunctionStr.js.map","import { isAnyArray } from 'is-any-array';\nimport { getOutputArray } from './getOutputArray';\n/**\n * This function xMultiply the first array by the second array or a constant value to each element of the first array\n * @param array1 - first array\n * @param array2 - second array\n * @param options - options\n */\nexport function xMultiply(array1, array2, options = {}) {\n    let isConstant = false;\n    let constant = 0;\n    if (isAnyArray(array2)) {\n        if (array1.length !== array2.length) {\n            throw new Error('size of array1 and array2 must be identical');\n        }\n    }\n    else {\n        isConstant = true;\n        constant = array2;\n    }\n    const array3 = getOutputArray(options.output, array1.length);\n    if (isConstant) {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] * constant;\n        }\n    }\n    else {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] * array2[i];\n        }\n    }\n    return array3;\n}\n//# sourceMappingURL=xMultiply.js.map","import { xMultiply } from './xMultiply';\n/**\n * Dot product between two arrays.\n * @param A - First array.\n * @param B - Second array.\n */\nexport function xDotProduct(A, B) {\n    const g = xMultiply(A, B);\n    let result = 0;\n    for (let i = 0; i < A.length; i++) {\n        result += g[i];\n    }\n    return result;\n}\n//# sourceMappingURL=xDotProduct.js.map","import { xDotProduct } from './xDotProduct';\n/**\n * Calculates the cross-correlation between 2 arrays\n * @param A - fixed array\n * @param B - sweeping array\n * @param options - Options\n */\nexport function xCrossCorrelation(A, B, options = {}) {\n    const { tau = 1, lag = A.length - 1 } = options;\n    const result = new Float64Array(1 + (2 * lag) / tau);\n    if (A.length === B.length) {\n        const n = B.length;\n        const g = new Float64Array(2 * n);\n        const q = new Float64Array(2 * n);\n        for (let i = 0; i < n; i++) {\n            q[n + i] = B[i];\n        }\n        for (let i = n * 2 - (tau - 1); i > 0; i -= tau) {\n            let k = 0;\n            for (let j = i; j < n * 2; j++) {\n                g[k] = q[j];\n                k++;\n            }\n            const w = [];\n            for (let l = 0; l < n; l++) {\n                w[l] = g[l];\n            }\n            result[(k - (n - lag)) / tau] = xDotProduct(A, w);\n        }\n    }\n    return result;\n}\n//# sourceMappingURL=xCrossCorrelation.js.map","import { xCheck } from './xCheck';\n/**\n * Calculating the box plot of the array\n * This function will interpolate the values and use the inclusive algorithm\n * @param array - data\n * @param options\n * @returns - q1, median, q3, min, max\n */\nexport function xBoxPlot(array) {\n    xCheck(array);\n    // duplicate the array to avoid modifying the original one\n    // and sort typed array that is much faster than sorting a normal array\n    array = Float64Array.from(array).sort();\n    const posQ1 = (array.length - 1) / 4;\n    const posQ3 = (array.length - 1) * (3 / 4);\n    const medianPos = (array.length - 1) / 2;\n    const q1MinProportion = posQ1 % 1;\n    const q3MinProportion = posQ3 % 1;\n    const medianMinProportion = medianPos % 1;\n    return {\n        min: array[0],\n        q1: q1MinProportion === 0\n            ? array[posQ1]\n            : array[posQ1 >> 0] * (1 - q1MinProportion) +\n                array[(posQ1 >> 0) + 1] * q1MinProportion,\n        median: medianMinProportion === 0\n            ? array[medianPos]\n            : array[medianPos >> 0] * (1 - medianMinProportion) +\n                array[(medianPos >> 0) + 1] * medianMinProportion,\n        q3: q3MinProportion === 0\n            ? array[posQ3]\n            : array[posQ3 >> 0] * (1 - q3MinProportion) +\n                array[(posQ3 >> 0) + 1] * q3MinProportion,\n        max: array.at(-1),\n    };\n}\n//# sourceMappingURL=xBoxPlot.js.map","import { xBoxPlot } from './xBoxPlot';\n/**\n * Calculating the box plot of the array with outliers\n * Values are outliers if they are below Q1 - 1.5 * IQR or above Q3 + 1.5 * IQR\n * @param array - data\n * @returns - q1, median, q3, min, max, outliers\n */\nexport function xBoxPlotWithOutliers(array) {\n    const boxPlot = xBoxPlot(array);\n    const iqr = boxPlot.q3 - boxPlot.q1;\n    const lowerWhisker = boxPlot.q1 - 1.5 * iqr;\n    const upperWhisker = boxPlot.q3 + 1.5 * iqr;\n    const outliers = [];\n    let minWhisker = boxPlot.median;\n    let maxWhisker = boxPlot.median;\n    for (const value of array) {\n        if (value < lowerWhisker || value > upperWhisker) {\n            outliers.push(value);\n        }\n        else {\n            if (value < minWhisker)\n                minWhisker = value;\n            if (value > maxWhisker)\n                maxWhisker = value;\n        }\n    }\n    const info = {\n        ...boxPlot,\n        lowerWhisker,\n        upperWhisker,\n        minWhisker,\n        maxWhisker,\n        iqr,\n        outliers,\n    };\n    return info;\n}\n//# sourceMappingURL=xBoxPlotWithOutliers.js.map","/**\n * Check that two arrays have the same length.\n * @param array1 - First array.\n * @param array2 - Second array.\n */\nexport function xCheckLengths(array1, array2) {\n    if (array1.length !== array2.length) {\n        throw new TypeError('length of array1 and array2 must be identical');\n    }\n}\n//# sourceMappingURL=xCheckLengths.js.map","/**\n * Calculates the correlation between 2 vectors\n * https://en.wikipedia.org/wiki/Correlation_and_dependence\n * @param A - first array\n * @param B - sencond array\n */\nexport function xCorrelation(A, B) {\n    const n = A.length;\n    let sumA = 0;\n    let sumA2 = 0;\n    let sumB = 0;\n    let sumB2 = 0;\n    let sumAB = 0;\n    for (let i = 0; i < n; i++) {\n        const a = A[i];\n        const b = B[i];\n        sumA += a;\n        sumA2 += a ** 2;\n        sumB += b;\n        sumB2 += b ** 2;\n        sumAB += a * b;\n    }\n    return ((n * sumAB - sumA * sumB) /\n        (Math.sqrt(n * sumA2 - sumA ** 2) * Math.sqrt(n * sumB2 - sumB ** 2)));\n}\n//# sourceMappingURL=xCorrelation.js.map","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","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';\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","'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 { Matrix } from 'ml-matrix';\nconst absDiff = (a, b) => Math.abs(a - b);\n/**\n * Generate a cost matrix from two set of values using the function passed. by default it\n * generate the cost matrix of absolute value of differences.\n * @param rowsArray - Array of values that will represent the rows of the cost matrix.\n * @param columnsArray - Array of values that will represent the columns of the cost matrix.\n * @param options\n * @returns - A matrix instance with dimensions rowsArray.length x columnsArray.length\n */\nexport function xCostMatrix(rowsArray, columnsArray, options = {}) {\n    const { fct = absDiff } = options;\n    const nbRows = rowsArray.length;\n    const nbColumns = columnsArray.length;\n    const result = new Matrix(nbRows, nbColumns);\n    for (let r = 0; r < nbRows; r++) {\n        for (let c = 0; c < nbColumns; c++) {\n            result.set(r, c, fct(rowsArray[r], columnsArray[c]));\n        }\n    }\n    return result;\n}\n//# sourceMappingURL=xCostMatrix.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * Calculate an array of the same size that is the cumulative values\n * @param array - initial array\n */\nexport function xCumulative(array) {\n    if (!isAnyArray(array)) {\n        throw new TypeError('input must be an array');\n    }\n    const newArray = new Float64Array(array.length);\n    if (array.length === 0)\n        return newArray;\n    newArray[0] = array[0];\n    for (let i = 1; i < array.length; i++) {\n        newArray[i] = newArray[i - 1] + array[i];\n    }\n    return newArray;\n}\n//# sourceMappingURL=xCumulative.js.map","import { xCheck } from './xCheck';\nimport { xGetFromToIndex } from './xGetFromToIndex';\n/**\n * Computes the mean value of an array of values.\n * @param array - array of numbers\n * @param options - options\n */\nexport function xMean(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let sumValue = array[fromIndex];\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        sumValue += array[i];\n    }\n    return sumValue / (toIndex - fromIndex + 1);\n}\n//# sourceMappingURL=xMean.js.map","import { isAnyArray } from 'is-any-array';\nimport { xMean } from './xMean';\n/**\n * Finds the variance of the data\n * @param values - the values of the array\n * @param options - options\n * @returns variance\n */\nexport function xVariance(values, options = {}) {\n    if (!isAnyArray(values)) {\n        throw new TypeError('input must be an array');\n    }\n    const { unbiased = true, mean = xMean(values) } = options;\n    let sqrError = 0;\n    for (let i = 0; i < values.length; i++) {\n        const x = values[i] - mean;\n        sqrError += x * x;\n    }\n    if (unbiased) {\n        return sqrError / (values.length - 1);\n    }\n    else {\n        return sqrError / values.length;\n    }\n}\n//# sourceMappingURL=xVariance.js.map","import { xVariance } from './xVariance';\n/**\n * Finds the standard deviation for the data at hand\n * @param values - values in the data\n * @param options - options\n * @returns standard deviation\n */\nexport function xStandardDeviation(values, options = {}) {\n    return Math.sqrt(xVariance(values, options));\n}\n//# sourceMappingURL=xStandardDeviation.js.map","import { isAnyArray } from 'is-any-array';\nimport { getOutputArray } from './getOutputArray';\n/**\n * This function divide the first array by the second array or a constant value to each element of the first array\n * @param array1 - first array\n * @param array2 - second array or number\n * @param options - options\n */\nexport function xDivide(array1, array2, options = {}) {\n    let isConstant = false;\n    let constant = 0;\n    if (isAnyArray(array2)) {\n        if (array1.length !== array2.length) {\n            throw new RangeError('size of array1 and array2 must be identical');\n        }\n    }\n    else {\n        isConstant = true;\n        constant = array2;\n    }\n    const array3 = getOutputArray(options.output, array1.length);\n    if (isConstant) {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] / constant;\n        }\n    }\n    else {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] / array2[i];\n        }\n    }\n    return array3;\n}\n//# sourceMappingURL=xDivide.js.map","import { xCheck } from './xCheck';\n/**\n * Returns a copy of the data as a Float64Array.\n * @param array - array of numbers\n */\nexport function xEnsureFloat64(array) {\n    xCheck(array);\n    if (array instanceof Float64Array) {\n        return array.slice(0);\n    }\n    return Float64Array.from(array);\n}\n//# sourceMappingURL=xEnsureFloat64.js.map","import { xFindClosestIndex } from './xFindClosestIndex';\n/**\n *  Returns the targetIndex\n * @param x - array of numbers\n * @param options - options\n */\nexport function xGetTargetIndex(x, options = {}) {\n    const { target, targetIndex } = options;\n    if (targetIndex === undefined) {\n        if (target !== undefined) {\n            return xFindClosestIndex(x, target);\n        }\n        else {\n            return 0;\n        }\n    }\n    return targetIndex;\n}\n//# sourceMappingURL=xGetTargetIndex.js.map","'use strict';\n\nfunction FFT(size) {\n  this.size = size | 0;\n  if (this.size <= 1 || (this.size & (this.size - 1)) !== 0)\n    throw new Error('FFT size must be a power of two and bigger than 1');\n\n  this._csize = size << 1;\n\n  // NOTE: Use of `var` is intentional for old V8 versions\n  var table = new Array(this.size * 2);\n  for (var i = 0; i < table.length; i += 2) {\n    const angle = Math.PI * i / this.size;\n    table[i] = Math.cos(angle);\n    table[i + 1] = -Math.sin(angle);\n  }\n  this.table = table;\n\n  // Find size's power of two\n  var power = 0;\n  for (var t = 1; this.size > t; t <<= 1)\n    power++;\n\n  // Calculate initial step's width:\n  //   * If we are full radix-4 - it is 2x smaller to give inital len=8\n  //   * Otherwise it is the same as `power` to give len=4\n  this._width = power % 2 === 0 ? power - 1 : power;\n\n  // Pre-compute bit-reversal patterns\n  this._bitrev = new Array(1 << this._width);\n  for (var j = 0; j < this._bitrev.length; j++) {\n    this._bitrev[j] = 0;\n    for (var shift = 0; shift < this._width; shift += 2) {\n      var revShift = this._width - shift - 2;\n      this._bitrev[j] |= ((j >>> shift) & 3) << revShift;\n    }\n  }\n\n  this._out = null;\n  this._data = null;\n  this._inv = 0;\n}\nmodule.exports = FFT;\n\nFFT.prototype.fromComplexArray = function fromComplexArray(complex, storage) {\n  var res = storage || new Array(complex.length >>> 1);\n  for (var i = 0; i < complex.length; i += 2)\n    res[i >>> 1] = complex[i];\n  return res;\n};\n\nFFT.prototype.createComplexArray = function createComplexArray() {\n  const res = new Array(this._csize);\n  for (var i = 0; i < res.length; i++)\n    res[i] = 0;\n  return res;\n};\n\nFFT.prototype.toComplexArray = function toComplexArray(input, storage) {\n  var res = storage || this.createComplexArray();\n  for (var i = 0; i < res.length; i += 2) {\n    res[i] = input[i >>> 1];\n    res[i + 1] = 0;\n  }\n  return res;\n};\n\nFFT.prototype.completeSpectrum = function completeSpectrum(spectrum) {\n  var size = this._csize;\n  var half = size >>> 1;\n  for (var i = 2; i < half; i += 2) {\n    spectrum[size - i] = spectrum[i];\n    spectrum[size - i + 1] = -spectrum[i + 1];\n  }\n};\n\nFFT.prototype.transform = function transform(out, data) {\n  if (out === data)\n    throw new Error('Input and output buffers must be different');\n\n  this._out = out;\n  this._data = data;\n  this._inv = 0;\n  this._transform4();\n  this._out = null;\n  this._data = null;\n};\n\nFFT.prototype.realTransform = function realTransform(out, data) {\n  if (out === data)\n    throw new Error('Input and output buffers must be different');\n\n  this._out = out;\n  this._data = data;\n  this._inv = 0;\n  this._realTransform4();\n  this._out = null;\n  this._data = null;\n};\n\nFFT.prototype.inverseTransform = function inverseTransform(out, data) {\n  if (out === data)\n    throw new Error('Input and output buffers must be different');\n\n  this._out = out;\n  this._data = data;\n  this._inv = 1;\n  this._transform4();\n  for (var i = 0; i < out.length; i++)\n    out[i] /= this.size;\n  this._out = null;\n  this._data = null;\n};\n\n// radix-4 implementation\n//\n// NOTE: Uses of `var` are intentional for older V8 version that do not\n// support both `let compound assignments` and `const phi`\nFFT.prototype._transform4 = function _transform4() {\n  var out = this._out;\n  var size = this._csize;\n\n  // Initial step (permute and transform)\n  var width = this._width;\n  var step = 1 << width;\n  var len = (size / step) << 1;\n\n  var outOff;\n  var t;\n  var bitrev = this._bitrev;\n  if (len === 4) {\n    for (outOff = 0, t = 0; outOff < size; outOff += len, t++) {\n      const off = bitrev[t];\n      this._singleTransform2(outOff, off, step);\n    }\n  } else {\n    // len === 8\n    for (outOff = 0, t = 0; outOff < size; outOff += len, t++) {\n      const off = bitrev[t];\n      this._singleTransform4(outOff, off, step);\n    }\n  }\n\n  // Loop through steps in decreasing order\n  var inv = this._inv ? -1 : 1;\n  var table = this.table;\n  for (step >>= 2; step >= 2; step >>= 2) {\n    len = (size / step) << 1;\n    var quarterLen = len >>> 2;\n\n    // Loop through offsets in the data\n    for (outOff = 0; outOff < size; outOff += len) {\n      // Full case\n      var limit = outOff + quarterLen;\n      for (var i = outOff, k = 0; i < limit; i += 2, k += step) {\n        const A = i;\n        const B = A + quarterLen;\n        const C = B + quarterLen;\n        const D = C + quarterLen;\n\n        // Original values\n        const Ar = out[A];\n        const Ai = out[A + 1];\n        const Br = out[B];\n        const Bi = out[B + 1];\n        const Cr = out[C];\n        const Ci = out[C + 1];\n        const Dr = out[D];\n        const Di = out[D + 1];\n\n        // Middle values\n        const MAr = Ar;\n        const MAi = Ai;\n\n        const tableBr = table[k];\n        const tableBi = inv * table[k + 1];\n        const MBr = Br * tableBr - Bi * tableBi;\n        const MBi = Br * tableBi + Bi * tableBr;\n\n        const tableCr = table[2 * k];\n        const tableCi = inv * table[2 * k + 1];\n        const MCr = Cr * tableCr - Ci * tableCi;\n        const MCi = Cr * tableCi + Ci * tableCr;\n\n        const tableDr = table[3 * k];\n        const tableDi = inv * table[3 * k + 1];\n        const MDr = Dr * tableDr - Di * tableDi;\n        const MDi = Dr * tableDi + Di * tableDr;\n\n        // Pre-Final values\n        const T0r = MAr + MCr;\n        const T0i = MAi + MCi;\n        const T1r = MAr - MCr;\n        const T1i = MAi - MCi;\n        const T2r = MBr + MDr;\n        const T2i = MBi + MDi;\n        const T3r = inv * (MBr - MDr);\n        const T3i = inv * (MBi - MDi);\n\n        // Final values\n        const FAr = T0r + T2r;\n        const FAi = T0i + T2i;\n\n        const FCr = T0r - T2r;\n        const FCi = T0i - T2i;\n\n        const FBr = T1r + T3i;\n        const FBi = T1i - T3r;\n\n        const FDr = T1r - T3i;\n        const FDi = T1i + T3r;\n\n        out[A] = FAr;\n        out[A + 1] = FAi;\n        out[B] = FBr;\n        out[B + 1] = FBi;\n        out[C] = FCr;\n        out[C + 1] = FCi;\n        out[D] = FDr;\n        out[D + 1] = FDi;\n      }\n    }\n  }\n};\n\n// radix-2 implementation\n//\n// NOTE: Only called for len=4\nFFT.prototype._singleTransform2 = function _singleTransform2(outOff, off,\n                                                             step) {\n  const out = this._out;\n  const data = this._data;\n\n  const evenR = data[off];\n  const evenI = data[off + 1];\n  const oddR = data[off + step];\n  const oddI = data[off + step + 1];\n\n  const leftR = evenR + oddR;\n  const leftI = evenI + oddI;\n  const rightR = evenR - oddR;\n  const rightI = evenI - oddI;\n\n  out[outOff] = leftR;\n  out[outOff + 1] = leftI;\n  out[outOff + 2] = rightR;\n  out[outOff + 3] = rightI;\n};\n\n// radix-4\n//\n// NOTE: Only called for len=8\nFFT.prototype._singleTransform4 = function _singleTransform4(outOff, off,\n                                                             step) {\n  const out = this._out;\n  const data = this._data;\n  const inv = this._inv ? -1 : 1;\n  const step2 = step * 2;\n  const step3 = step * 3;\n\n  // Original values\n  const Ar = data[off];\n  const Ai = data[off + 1];\n  const Br = data[off + step];\n  const Bi = data[off + step + 1];\n  const Cr = data[off + step2];\n  const Ci = data[off + step2 + 1];\n  const Dr = data[off + step3];\n  const Di = data[off + step3 + 1];\n\n  // Pre-Final values\n  const T0r = Ar + Cr;\n  const T0i = Ai + Ci;\n  const T1r = Ar - Cr;\n  const T1i = Ai - Ci;\n  const T2r = Br + Dr;\n  const T2i = Bi + Di;\n  const T3r = inv * (Br - Dr);\n  const T3i = inv * (Bi - Di);\n\n  // Final values\n  const FAr = T0r + T2r;\n  const FAi = T0i + T2i;\n\n  const FBr = T1r + T3i;\n  const FBi = T1i - T3r;\n\n  const FCr = T0r - T2r;\n  const FCi = T0i - T2i;\n\n  const FDr = T1r - T3i;\n  const FDi = T1i + T3r;\n\n  out[outOff] = FAr;\n  out[outOff + 1] = FAi;\n  out[outOff + 2] = FBr;\n  out[outOff + 3] = FBi;\n  out[outOff + 4] = FCr;\n  out[outOff + 5] = FCi;\n  out[outOff + 6] = FDr;\n  out[outOff + 7] = FDi;\n};\n\n// Real input radix-4 implementation\nFFT.prototype._realTransform4 = function _realTransform4() {\n  var out = this._out;\n  var size = this._csize;\n\n  // Initial step (permute and transform)\n  var width = this._width;\n  var step = 1 << width;\n  var len = (size / step) << 1;\n\n  var outOff;\n  var t;\n  var bitrev = this._bitrev;\n  if (len === 4) {\n    for (outOff = 0, t = 0; outOff < size; outOff += len, t++) {\n      const off = bitrev[t];\n      this._singleRealTransform2(outOff, off >>> 1, step >>> 1);\n    }\n  } else {\n    // len === 8\n    for (outOff = 0, t = 0; outOff < size; outOff += len, t++) {\n      const off = bitrev[t];\n      this._singleRealTransform4(outOff, off >>> 1, step >>> 1);\n    }\n  }\n\n  // Loop through steps in decreasing order\n  var inv = this._inv ? -1 : 1;\n  var table = this.table;\n  for (step >>= 2; step >= 2; step >>= 2) {\n    len = (size / step) << 1;\n    var halfLen = len >>> 1;\n    var quarterLen = halfLen >>> 1;\n    var hquarterLen = quarterLen >>> 1;\n\n    // Loop through offsets in the data\n    for (outOff = 0; outOff < size; outOff += len) {\n      for (var i = 0, k = 0; i <= hquarterLen; i += 2, k += step) {\n        var A = outOff + i;\n        var B = A + quarterLen;\n        var C = B + quarterLen;\n        var D = C + quarterLen;\n\n        // Original values\n        var Ar = out[A];\n        var Ai = out[A + 1];\n        var Br = out[B];\n        var Bi = out[B + 1];\n        var Cr = out[C];\n        var Ci = out[C + 1];\n        var Dr = out[D];\n        var Di = out[D + 1];\n\n        // Middle values\n        var MAr = Ar;\n        var MAi = Ai;\n\n        var tableBr = table[k];\n        var tableBi = inv * table[k + 1];\n        var MBr = Br * tableBr - Bi * tableBi;\n        var MBi = Br * tableBi + Bi * tableBr;\n\n        var tableCr = table[2 * k];\n        var tableCi = inv * table[2 * k + 1];\n        var MCr = Cr * tableCr - Ci * tableCi;\n        var MCi = Cr * tableCi + Ci * tableCr;\n\n        var tableDr = table[3 * k];\n        var tableDi = inv * table[3 * k + 1];\n        var MDr = Dr * tableDr - Di * tableDi;\n        var MDi = Dr * tableDi + Di * tableDr;\n\n        // Pre-Final values\n        var T0r = MAr + MCr;\n        var T0i = MAi + MCi;\n        var T1r = MAr - MCr;\n        var T1i = MAi - MCi;\n        var T2r = MBr + MDr;\n        var T2i = MBi + MDi;\n        var T3r = inv * (MBr - MDr);\n        var T3i = inv * (MBi - MDi);\n\n        // Final values\n        var FAr = T0r + T2r;\n        var FAi = T0i + T2i;\n\n        var FBr = T1r + T3i;\n        var FBi = T1i - T3r;\n\n        out[A] = FAr;\n        out[A + 1] = FAi;\n        out[B] = FBr;\n        out[B + 1] = FBi;\n\n        // Output final middle point\n        if (i === 0) {\n          var FCr = T0r - T2r;\n          var FCi = T0i - T2i;\n          out[C] = FCr;\n          out[C + 1] = FCi;\n          continue;\n        }\n\n        // Do not overwrite ourselves\n        if (i === hquarterLen)\n          continue;\n\n        // In the flipped case:\n        // MAi = -MAi\n        // MBr=-MBi, MBi=-MBr\n        // MCr=-MCr\n        // MDr=MDi, MDi=MDr\n        var ST0r = T1r;\n        var ST0i = -T1i;\n        var ST1r = T0r;\n        var ST1i = -T0i;\n        var ST2r = -inv * T3i;\n        var ST2i = -inv * T3r;\n        var ST3r = -inv * T2i;\n        var ST3i = -inv * T2r;\n\n        var SFAr = ST0r + ST2r;\n        var SFAi = ST0i + ST2i;\n\n        var SFBr = ST1r + ST3i;\n        var SFBi = ST1i - ST3r;\n\n        var SA = outOff + quarterLen - i;\n        var SB = outOff + halfLen - i;\n\n        out[SA] = SFAr;\n        out[SA + 1] = SFAi;\n        out[SB] = SFBr;\n        out[SB + 1] = SFBi;\n      }\n    }\n  }\n};\n\n// radix-2 implementation\n//\n// NOTE: Only called for len=4\nFFT.prototype._singleRealTransform2 = function _singleRealTransform2(outOff,\n                                                                     off,\n                                                                     step) {\n  const out = this._out;\n  const data = this._data;\n\n  const evenR = data[off];\n  const oddR = data[off + step];\n\n  const leftR = evenR + oddR;\n  const rightR = evenR - oddR;\n\n  out[outOff] = leftR;\n  out[outOff + 1] = 0;\n  out[outOff + 2] = rightR;\n  out[outOff + 3] = 0;\n};\n\n// radix-4\n//\n// NOTE: Only called for len=8\nFFT.prototype._singleRealTransform4 = function _singleRealTransform4(outOff,\n                                                                     off,\n                                                                     step) {\n  const out = this._out;\n  const data = this._data;\n  const inv = this._inv ? -1 : 1;\n  const step2 = step * 2;\n  const step3 = step * 3;\n\n  // Original values\n  const Ar = data[off];\n  const Br = data[off + step];\n  const Cr = data[off + step2];\n  const Dr = data[off + step3];\n\n  // Pre-Final values\n  const T0r = Ar + Cr;\n  const T1r = Ar - Cr;\n  const T2r = Br + Dr;\n  const T3r = inv * (Br - Dr);\n\n  // Final values\n  const FAr = T0r + T2r;\n\n  const FBr = T1r;\n  const FBi = -T3r;\n\n  const FCr = T0r - T2r;\n\n  const FDr = T1r;\n  const FDi = T3r;\n\n  out[outOff] = FAr;\n  out[outOff + 1] = 0;\n  out[outOff + 2] = FBr;\n  out[outOff + 3] = FBi;\n  out[outOff + 4] = FCr;\n  out[outOff + 5] = 0;\n  out[outOff + 6] = FDr;\n  out[outOff + 7] = FDi;\n};\n","export function createNumberArray(ArrayConstructor, length) {\n    if (ArrayConstructor === Array) {\n        return new ArrayConstructor(length).fill(0);\n    }\n    else {\n        return new ArrayConstructor(length);\n    }\n}\nexport function createDoubleArray(ArrayConstructor, length) {\n    if (ArrayConstructor === Array) {\n        return new ArrayConstructor(length).fill(0);\n    }\n    else {\n        return new ArrayConstructor(length);\n    }\n}\n//# sourceMappingURL=createArray.js.map","/**\n * Create an array with numbers between \"from\" and \"to\" of length \"length\"\n * @param options - options\n * @returns - array of distributed numbers between \"from\" and \"to\"\n */\nexport function createFromToArray(options = {}) {\n    const { from = 0, to = 1, length = 1000, includeFrom = true, includeTo = true, distribution = 'uniform', } = options;\n    const array = new Float64Array(length);\n    let div = length;\n    if (includeFrom && includeTo) {\n        div = length - 1;\n    }\n    else if ((!includeFrom && includeTo) || (includeFrom && !includeTo)) {\n        div = length;\n    }\n    else if (!includeFrom && !includeTo) {\n        div = length + 1;\n    }\n    const delta = (to - from) / div;\n    if (distribution === 'uniform') {\n        if (includeFrom) {\n            let index = 0;\n            while (index < length) {\n                array[index] = from + delta * index;\n                index++;\n            }\n        }\n        else {\n            let index = 0;\n            while (index < length) {\n                array[index] = from + delta * (index + 1);\n                index++;\n            }\n        }\n    }\n    else if (distribution === 'log') {\n        const base = (to / from) ** (1 / div);\n        const firstExponent = Math.log(from) / Math.log(base);\n        if (includeFrom) {\n            let index = 0;\n            while (index < length) {\n                array[index] = base ** (firstExponent + index);\n                index++;\n            }\n        }\n        else {\n            let index = 0;\n            while (index < length) {\n                array[index] = base ** (firstExponent + index + 1);\n                index++;\n            }\n        }\n    }\n    else {\n        throw new Error('distribution must be uniform or log');\n    }\n    return array;\n}\n//# sourceMappingURL=createFromToArray.js.map","const LOOP = 8;\nconst FLOAT_MUL = 1 / 16777216;\nconst sh1 = 15;\nconst sh2 = 18;\nconst sh3 = 11;\nfunction multiplyUint32(n, m) {\n    n >>>= 0;\n    m >>>= 0;\n    const nlo = n & 0xffff;\n    const nhi = n - nlo;\n    return (((nhi * m) >>> 0) + nlo * m) >>> 0;\n}\nexport class XSadd {\n    random;\n    state;\n    /**\n     * create an instance of XSadd with the specified seed\n     * @param [seed=Date.now()]\n     */\n    constructor(seed = Date.now()) {\n        this.state = new Uint32Array(4);\n        this.init(seed);\n        this.random = this.getFloat.bind(this);\n    }\n    /**\n     * Returns a 32-bit integer r (0 <= r < 2^32)\n     */\n    getUint32() {\n        this.nextState();\n        return (this.state[3] + this.state[2]) >>> 0;\n    }\n    /**\n     * Returns a floating point number r (0.0 <= r < 1.0)\n     */\n    getFloat() {\n        return (this.getUint32() >>> 8) * FLOAT_MUL;\n    }\n    init(seed) {\n        if (!Number.isInteger(seed)) {\n            throw new TypeError(\"seed must be an integer\");\n        }\n        this.state[0] = seed;\n        this.state[1] = 0;\n        this.state[2] = 0;\n        this.state[3] = 0;\n        for (let i = 1; i < LOOP; i++) {\n            this.state[i & 3] ^=\n                (i +\n                    multiplyUint32(1812433253, this.state[(i - 1) & 3] ^ ((this.state[(i - 1) & 3] >>> 30) >>> 0))) >>>\n                    0;\n        }\n        this.periodCertification();\n        for (let i = 0; i < LOOP; i++) {\n            this.nextState();\n        }\n    }\n    periodCertification() {\n        if (this.state[0] === 0 &&\n            this.state[1] === 0 &&\n            this.state[2] === 0 &&\n            this.state[3] === 0) {\n            this.state[0] = 88; // X\n            this.state[1] = 83; // S\n            this.state[2] = 65; // A\n            this.state[3] = 68; // D\n        }\n    }\n    nextState() {\n        let t = this.state[0];\n        t ^= t << sh1;\n        t ^= t >>> sh2;\n        t ^= this.state[3] << sh3;\n        this.state[0] = this.state[1];\n        this.state[1] = this.state[2];\n        this.state[2] = this.state[3];\n        this.state[3] = t;\n    }\n}\n//# sourceMappingURL=XSadd.js.map","import { XSadd } from 'ml-xsadd';\n/**\n * Create a random array of numbers of a specific length.\n * @param options\n * @returns - array of random floats normally distributed\n */\nexport function createRandomArray(options = {}) {\n    const { mean = 0, standardDeviation = 1, length = 1000, range = 1, seed, distribution = 'normal', } = options;\n    const generator = new XSadd(seed);\n    const returnArray = new Float64Array(length);\n    switch (distribution) {\n        case 'normal': {\n            const gaussianGenerator = new GaussianGenerator(mean, standardDeviation, generator);\n            for (let i = 0; i < length; i++) {\n                returnArray[i] = gaussianGenerator.generateGaussian();\n            }\n            break;\n        }\n        case 'uniform': {\n            for (let i = 0; i < length; i++) {\n                returnArray[i] = (generator.random() - 0.5) * range + mean;\n            }\n            break;\n        }\n        default: {\n            throw new Error(`unknown distribution: ${String(distribution)}`);\n        }\n    }\n    return returnArray;\n}\nclass GaussianGenerator {\n    #spare = 0;\n    #hasSpare = false;\n    #mean;\n    #standardDeviation;\n    #generator;\n    constructor(mean, standardDeviation, generator) {\n        this.#mean = mean;\n        this.#standardDeviation = standardDeviation;\n        this.#generator = generator;\n    }\n    generateGaussian() {\n        let val, u, v, s;\n        if (this.#hasSpare) {\n            this.#hasSpare = false;\n            val = this.#spare * this.#standardDeviation + this.#mean;\n        }\n        else {\n            do {\n                u = this.#generator.random() * 2 - 1;\n                v = this.#generator.random() * 2 - 1;\n                s = u * u + v * v;\n            } while (s >= 1 || s === 0);\n            s = Math.sqrt((-2 * Math.log(s)) / s);\n            this.#spare = v * s;\n            this.#hasSpare = true;\n            val = this.#mean + this.#standardDeviation * u * s;\n        }\n        return val;\n    }\n}\n//# sourceMappingURL=createRandomArray.js.map","/**\n * Check if a number is a power of two.\n * @param n\n */\nexport function isPowerOfTwo(n) {\n    return n !== 0 && (n & (n - 1)) === 0;\n}\n//# sourceMappingURL=isPowerOfTwo.js.map","/**\n * Get the size of the next power of two.\n * @param n\n */\nexport function nextPowerOfTwo(n) {\n    if (n === 0)\n        return 1;\n    n--;\n    n |= n >> 1;\n    n |= n >> 2;\n    n |= n >> 4;\n    n |= n >> 8;\n    n |= n >> 16;\n    return n + 1;\n}\n//# sourceMappingURL=nextPowerOfTwo.js.map","/**\n * Resolves all promises in an object recursively. The promise with be replaced by the resolved value.\n * The changes are therefore done in-place !\n * @param object\n * @returns\n */\nexport async function recursiveResolve(object) {\n    if (typeof object !== 'object')\n        return object;\n    const promises = [];\n    await appendPromises(object, promises);\n    await Promise.all(promises);\n    return object;\n}\nfunction appendPromises(object, promises) {\n    if (typeof object !== 'object')\n        return object;\n    for (const key in object) {\n        if (typeof object[key].then === 'function') {\n            promises.push(object[key].then((value) => (object[key] = value)));\n        }\n        else if (typeof object[key] === 'object') {\n            appendPromises(object[key], promises);\n        }\n    }\n    return object;\n}\n//# sourceMappingURL=recursiveResolve.js.map","/**\n * Recursively change the typed arrays to normal arrays\n * The changes are done in-place !\n * @param object\n * @returns\n */\nexport function recursiveUntypeArrays(object) {\n    if (typeof object !== 'object')\n        return object;\n    object = modifier(object);\n    return object;\n}\nfunction modifier(object) {\n    if (typeof object !== 'object')\n        return object;\n    if (ArrayBuffer.isView(object)) {\n        return Array.from(object);\n    }\n    for (const key in object) {\n        if (ArrayBuffer.isView(object[key])) {\n            object[key] = Array.from(object[key]);\n        }\n        else if (typeof object[key] === 'object') {\n            modifier(object[key]);\n        }\n    }\n    return object;\n}\n//# sourceMappingURL=recursiveUntypeArrays.js.map","/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Stringify an object and convert all typed arrays to arrays\n * @param object\n * @param replacer\n * @param space\n * @returns\n */\nexport function stringify(object, replacer, space) {\n    const internalReplacer = (key, value) => {\n        if (ArrayBuffer.isView(value)) {\n            value = Array.from(value);\n        }\n        if (replacer) {\n            return replacer(key, value);\n        }\n        return value;\n    };\n    return JSON.stringify(object, internalReplacer, space);\n}\n//# sourceMappingURL=stringify.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * This function xSubtract the first array by the second array or a constant value from each element of the first array\n * @param array1 - the array that will be rotated\n * @param array2 - second array or number\n * @returns array after subtraction\n */\nexport function xSubtract(array1, array2) {\n    let isConstant = false;\n    let constant = 0;\n    if (isAnyArray(array2)) {\n        if (array1.length !== array2.length) {\n            throw new Error('size of array1 and array2 must be identical');\n        }\n    }\n    else {\n        isConstant = true;\n        constant = array2;\n    }\n    const array3 = new Float64Array(array1.length);\n    if (isConstant) {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] - constant;\n        }\n    }\n    else {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] - array2[i];\n        }\n    }\n    return array3;\n}\n//# sourceMappingURL=xSubtract.js.map","import { xAbsolute } from '../x/xAbsolute';\nimport { xMedian } from '../x/xMedian';\nimport { xSubtract } from '../x/xSubtract';\n/**\n * Calculate the weights based on the control points and the MAD between the original data and the new baseline.\n * MAD (Median Absolute Deviation) is more robust to outliers and\n * the factor (1.4826) makes MAD scaled to be equivalent to the standard deviation for\n * normal distributions. {@link https://en.m.wikipedia.org/wiki/Median_absolute_deviation}.\n * @param yData - The original data.\n * @param baseline - The new baseline calculated.\n * @param weights - The current weights to be updated.\n * @param options - Options for updating weights.\n * @returns new array of weights.\n */\nexport function calculateAdaptiveWeights(yData, baseline, weights, options) {\n    const { controlPoints, factorStd = 3, learningRate = 0.5, minWeight = 0.01, } = options;\n    const absResiduals = xAbsolute(xSubtract(yData, baseline));\n    const medAbsRes = xMedian(absResiduals);\n    const mad = 1.4826 * medAbsRes;\n    const threshold = factorStd * mad;\n    const rawWeights = new Float64Array(absResiduals.length);\n    for (let i = 0; i < absResiduals.length; i++) {\n        rawWeights[i] = Math.exp(-((absResiduals[i] / threshold) ** 2));\n    }\n    let maxWeight = Number.MIN_SAFE_INTEGER;\n    const newWeights = Float64Array.from(weights);\n    const oneMinusLearningRate = 1 - learningRate;\n    for (let i = 0; i < newWeights.length; i++) {\n        if (controlPoints && controlPoints[i] > 0)\n            continue;\n        const weight = Math.max(minWeight, oneMinusLearningRate * weights[i] + learningRate * rawWeights[i]);\n        newWeights[i] = weight;\n        maxWeight = Math.max(maxWeight, weight);\n    }\n    newWeights[0] = maxWeight;\n    newWeights[weights.length - 1] = maxWeight;\n    return newWeights;\n}\n//# sourceMappingURL=calculateAdaptiveWeights.js.map","import FFT from 'fft.js';\nimport { isPowerOfTwo, nextPowerOfTwo } from '../utils';\nimport { xCheck } from './xCheck';\n/**\n * Performs the Hilbert transform\n * @link https://en.wikipedia.org/wiki/Hilbert_transform\n * @param array - Array containing values\n * @param options\n * @returns A new vector with 90 degree shift regarding the phase of the original function\n */\nexport function xHilbertTransform(array, options = {}) {\n    xCheck(array);\n    const { forceFFT = false } = options;\n    const length = array.length;\n    if (isPowerOfTwo(length)) {\n        return hilbertTransformWithFFT(array);\n    }\n    else if (forceFFT) {\n        return resampling(hilbertTransformWithFFT(resampling(array, nextPowerOfTwo(length))), length);\n    }\n    else {\n        return hilbertTransform(array);\n    }\n}\n/**\n * Performs the discrete Hilbert transform using fast Fourier transform\n * @param array - Array containing values\n * @returns A new vector with 90 degree shift regarding the phase of the original function\n * @see DOI: 10.1109/TAU.1970.1162139 \"Discrete Hilbert transform\"\n */\nfunction hilbertTransformWithFFT(array) {\n    const length = array.length;\n    const fft = new FFT(length);\n    const fftResult = new Float64Array(length * 2);\n    fft.realTransform(fftResult, array);\n    fft.completeSpectrum(fftResult);\n    const multiplier = new Float64Array(length);\n    for (let i = 1; i < length; i++) {\n        multiplier[i] = Math.sign(length / 2 - i);\n    }\n    for (let i = 0; i < length; i++) {\n        fftResult[i * 2] *= multiplier[i];\n        fftResult[i * 2 + 1] *= multiplier[i];\n    }\n    const hilbertSignal = new Float64Array(length * 2);\n    fft.inverseTransform(hilbertSignal, fftResult);\n    const result = new Float64Array(length);\n    for (let i = 0; i < length; i++) {\n        result[i] = hilbertSignal[i * 2 + 1];\n    }\n    return result;\n}\n/**\n * Performs the discrete Hilbert transform\n * @param array - Array containing values\n * @param options\n * @param options.inClockwise\n * @returns A new vector with 90 degree shift regarding the phase of the original function\n */\nfunction hilbertTransform(array, options = {}) {\n    const { inClockwise = true } = options;\n    const input = [0, ...array, 0];\n    const result = new Float64Array(array.length);\n    for (let k = 1; k < input.length - 1; k++) {\n        let aSum = 0;\n        for (let i = 0; i < k - 1; i++) {\n            const log = Math.log((k - i) / (k - i - 1));\n            aSum += input[i] * log + (input[i + 1] - input[i]) * (-1 + (k - i) * log);\n        }\n        const b = input[k - 1] - input[k + 1];\n        let cSum = 0;\n        for (let i = k + 1; i < input.length - 1; i++) {\n            const log = Math.log((i - k) / (i - k + 1));\n            cSum += input[i] * log + (input[i - 1] - input[i]) * (1 + (i - k) * log);\n        }\n        result[k - 1] = ((inClockwise ? 1 : -1) * (aSum + b + cSum)) / Math.PI;\n    }\n    return result;\n}\n/**\n * Performs resampling of an input array to the desired length employing linear interpolation.\n * @param array - Array containing values.\n * @param length - The length of the resulting array.\n * @returns It returns a new array of the desired length.\n * @link https://en.wikipedia.org/wiki/Sample-rate_conversion\n */\nfunction resampling(array, length) {\n    xCheck(array);\n    const oldLength = array.length;\n    const ratio = (oldLength - 1) / (length - 1);\n    const result = new Float64Array(length);\n    let currentIndex = 0;\n    let floor = Math.floor(currentIndex);\n    let ceil = Math.min(Math.ceil(currentIndex), oldLength - 1);\n    let diff = currentIndex - floor;\n    for (let i = 0; i < length; i++) {\n        result[i] = array[floor] * (1 - diff) + array[ceil] * diff;\n        currentIndex += ratio;\n        floor = Math.floor(currentIndex);\n        ceil = Math.min(Math.ceil(currentIndex), oldLength - 1);\n        diff = currentIndex - floor;\n    }\n    return result;\n}\n//# sourceMappingURL=xHilbertTransform.js.map","import { xCheck } from './xCheck';\nimport { xGetFromToIndex } from './xGetFromToIndex';\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';\nimport { xGetFromToIndex } from './xGetFromToIndex';\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","import { createFromToArray } from '../utils';\nimport { xAbsolute } from './xAbsolute';\nimport { xCheck } from './xCheck';\nimport { xMaxValue } from './xMaxValue';\nimport { xMinValue } from './xMinValue';\n/**\n * Calculates a histogram of defined number of slots\n * @param array - Array containing values\n * @param options - options\n * @returns - result of the histogram\n */\nexport function xHistogram(array, options = {}) {\n    xCheck(array);\n    const histogram = options.histogram;\n    const { centerX = true, nbSlots = histogram === undefined ? 256 : histogram.x.length, logBaseX, logBaseY, absolute = false, } = options;\n    if (absolute) {\n        array = xAbsolute(array);\n    }\n    if (logBaseX) {\n        array = array.slice();\n        const logOfBase = Math.log10(logBaseX);\n        for (let i = 0; i < array.length; i++) {\n            array[i] = Math.log10(array[i]) / logOfBase;\n        }\n    }\n    const { min = xMinValue(array), max = xMaxValue(array) } = options;\n    const slotSize = (max - min) / (nbSlots + Number.EPSILON);\n    const y = histogram === undefined ? new Float64Array(nbSlots) : histogram.y;\n    const x = histogram === undefined\n        ? Array.from(createFromToArray({\n            from: min + (centerX ? slotSize / 2 : 0),\n            to: max - (centerX ? slotSize / 2 : 0),\n            length: nbSlots,\n        }))\n        : histogram.x;\n    for (const element of array) {\n        const index = Math.max(Math.min(Math.floor((element - min - Number.EPSILON) / slotSize), nbSlots - 1), 0);\n        y[index]++;\n    }\n    if (logBaseY) {\n        const logOfBase = Math.log10(logBaseY);\n        for (let i = 0; i < y.length; i++) {\n            y[i] = Math.log10(y[i] + 1) / logOfBase;\n        }\n    }\n    return { x, y };\n}\n//# sourceMappingURL=xHistogram.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","/**\n * Check the similarity between array created by xyMassCenterVector\n * @param array1\n * @param array2\n * @param options\n * @returns\n */\nexport function xMassCenterVectorSimilarity(array1, array2, options = {}) {\n    const { recenter = true, similarityFct = (a, b) => (a === b ? 1 : 0), } = options;\n    const depth1 = getDepth(array1);\n    const depth2 = getDepth(array2);\n    const depth = Math.min(depth1, depth2);\n    // need to copy the array because we shift the data in place if recenter is true\n    if (recenter) {\n        array1 = array1.slice();\n    }\n    let similarity = 0;\n    // we will compare level by level\n    // and recenter the array at each level\n    for (let level = 0; level < depth; level++) {\n        const maxSimilarity = 1 / depth / (1 << level);\n        for (let slot = 0; slot < 1 << level; slot++) {\n            const index = (1 << level) - 1 + slot;\n            const value1 = array1[index];\n            const value2 = array2[index];\n            similarity += similarityFct(value1, value2) * maxSimilarity;\n            if (recenter) {\n                shiftSubTree(array1, depth, level, slot, value2 - value1);\n            }\n        }\n    }\n    return similarity;\n}\nfunction shiftSubTree(array, depth, level, slot, shift) {\n    for (let currentLevel = level; currentLevel < depth; currentLevel++) {\n        const levelSlotShift = slot * (1 << (currentLevel - level));\n        const levelShift = (1 << currentLevel) - 1;\n        const levelSlotSize = 1 << (currentLevel - level);\n        for (let slotIndex = levelSlotShift; slotIndex < levelSlotShift + levelSlotSize; slotIndex++) {\n            const index = levelShift + slotIndex;\n            array[index] += shift;\n        }\n    }\n}\nfunction getDepth(array) {\n    const depth = Math.log2(array.length + 1);\n    if (depth % 1 !== 0) {\n        throw new Error('the array length is not a power of 2 minus 1');\n    }\n    return depth;\n}\n//# sourceMappingURL=xMassCenterVectorSimilarity.js.map","import { xMedian } from './xMedian';\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';\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","/*\nAdapted from: https://github.com/compute-io/erfcinv/blob/aa116e23883839359e310ad41a7c42f72815fc1e/lib/number.js\n\nThe MIT License (MIT)\n\nCopyright (c) 2014-2015 The Compute.io Authors. All rights reserved.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n\nBoost Software License - Version 1.0 - August 17th, 2003\n\nPermission is hereby granted, free of charge, to any person or organization obtaining a copy of the software and accompanying documentation covered by this license (the \"Software\") to use, reproduce, display, distribute, execute, and transmit the Software, and to prepare derivative works of the Software, and to permit third-parties to whom the Software is furnished to do so, all subject to the following:\n\nThe copyright notices in the Software and this entire statement, including the above license grant, this restriction and the following disclaimer, must be included in all copies of the Software, in whole or in part, and all derivative works of the Software, unless such copies or derivative works are solely in the form of machine-executable object code generated by a source language processor.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n*/\n// Coefficients for erfcinv on [0, 0.5]:\nconst Y1 = 8.91314744949340820313e-2;\nconst P1 = [\n    -5.38772965071242932965e-3, 8.22687874676915743155e-3,\n    2.19878681111168899165e-2, -3.65637971411762664006e-2,\n    -1.26926147662974029034e-2, 3.34806625409744615033e-2,\n    -8.36874819741736770379e-3, -5.08781949658280665617e-4,\n];\nconst Q1 = [\n    8.86216390456424707504e-4, -2.33393759374190016776e-3,\n    7.95283687341571680018e-2, -5.27396382340099713954e-2,\n    -7.1228902341542847553e-1, 6.62328840472002992063e-1, 1.56221558398423026363,\n    -1.56574558234175846809, -9.70005043303290640362e-1, 1,\n];\n// Coefficients for erfcinv for 0.5 > 1-x >= 0:\nconst Y2 = 2.249481201171875;\nconst P2 = [\n    -3.67192254707729348546, 2.11294655448340526258e1, 1.7445385985570866523e1,\n    -4.46382324441786960818e1, -1.88510648058714251895e1,\n    1.76447298408374015486e1, 8.37050328343119927838, 1.05264680699391713268e-1,\n    -2.02433508355938759655e-1,\n];\nconst Q2 = [\n    1.72114765761200282724, -2.26436933413139721736e1, 1.08268667355460159008e1,\n    4.85609213108739935468e1, -2.01432634680485188801e1,\n    -2.86608180499800029974e1, 3.9713437953343869095, 6.24264124854247537712, 1,\n];\n// Coefficients for erfcinv for sqrt( -log(1-x)):\nconst Y3 = 8.07220458984375e-1;\nconst P3 = [\n    -6.81149956853776992068e-10, 2.85225331782217055858e-8,\n    -6.79465575181126350155e-7, 2.14558995388805277169e-3,\n    2.90157910005329060432e-2, 1.42869534408157156766e-1,\n    3.37785538912035898924e-1, 3.87079738972604337464e-1,\n    1.17030156341995252019e-1, -1.63794047193317060787e-1,\n    -1.31102781679951906451e-1,\n];\nconst Q3 = [\n    1.105924229346489121e-2, 1.52264338295331783612e-1, 8.48854343457902036425e-1,\n    2.59301921623620271374, 4.77846592945843778382, 5.38168345707006855425,\n    3.46625407242567245975, 1,\n];\nconst Y4 = 9.3995571136474609375e-1;\nconst P4 = [\n    2.66339227425782031962e-12, -2.30404776911882601748e-10,\n    4.60469890584317994083e-6, 1.57544617424960554631e-4,\n    1.87123492819559223345e-3, 9.50804701325919603619e-3,\n    1.85573306514231072324e-2, -2.22426529213447927281e-3,\n    -3.50353787183177984712e-2,\n];\nconst Q4 = [\n    7.64675292302794483503e-5, 2.63861676657015992959e-3,\n    3.41589143670947727934e-2, 2.20091105764131249824e-1,\n    7.62059164553623404043e-1, 1.3653349817554063097, 1,\n];\nconst Y5 = 9.8362827301025390625e-1;\nconst P5 = [\n    9.9055709973310326855e-17, -2.81128735628831791805e-14,\n    4.62596163522878599135e-9, 4.49696789927706453732e-7,\n    1.49624783758342370182e-5, 2.09386317487588078668e-4,\n    1.05628862152492910091e-3, -1.12951438745580278863e-3,\n    -1.67431005076633737133e-2,\n];\nconst Q5 = [\n    2.82243172016108031869e-7, 2.75335474764726041141e-5,\n    9.64011807005165528527e-4, 1.60746087093676504695e-2,\n    1.38151865749083321638e-1, 5.91429344886417493481e-1, 1,\n];\n/**\n * Polyval.\n * @param c - Array of Number.\n * @param x - Number.\n * @returns Number.\n */\nfunction polyval(c, x) {\n    let p = 0;\n    for (const coef of c) {\n        p = p * x + coef;\n    }\n    return p;\n}\n/**\n * Calculates a rational approximation.\n * @private\n * @param x - Number.\n * @param v - Number.\n * @param P - Array of polynomial coefficients.\n * @param Q - Array of polynomial coefficients.\n * @param Y - Number.\n * @returns Rational approximation.\n */\nfunction calc(x, v, P, Q, Y) {\n    const s = x - v;\n    const r = polyval(P, s) / polyval(Q, s);\n    return Y * x + r * x;\n}\n/**\n * Evaluates the complementary inverse error function for an input value.\n * @private\n * @param x - Input value.\n * @returns Evaluated complementary inverse error function.\n */\nexport default function erfcinv(x) {\n    let sign = false;\n    let val;\n    let q;\n    let g;\n    let r;\n    // [1] Special cases...\n    // NaN:\n    if (Number.isNaN(x)) {\n        return Number.NaN;\n    }\n    // x not on the interval: [0,2]\n    if (x < 0 || x > 2) {\n        throw new RangeError(`erfcinv()::invalid input argument. Value must be on the interval [0,2]. Value: \\`${x}\\`.`);\n    }\n    if (x === 0) {\n        return Number.POSITIVE_INFINITY;\n    }\n    if (x === 2) {\n        return Number.NEGATIVE_INFINITY;\n    }\n    if (x === 1) {\n        return 0;\n    }\n    // [2] Get the sign and make use of `erfc` reflection formula: `erfc(-z)=2 - erfc(z)`...\n    if (x > 1) {\n        q = 2 - x;\n        x = 1 - q;\n        sign = true;\n    }\n    else {\n        q = x;\n        x = 1 - x;\n    }\n    // [3] |x| <= 0.5\n    if (x <= 0.5) {\n        g = x * (x + 10);\n        r = polyval(P1, x) / polyval(Q1, x);\n        val = g * Y1 + g * r;\n        return sign ? -val : val;\n    }\n    // [4] 1-|x| >= 0.25\n    if (q >= 0.25) {\n        g = Math.sqrt(-2 * Math.log(q));\n        q = q - 0.25;\n        r = polyval(P2, q) / polyval(Q2, q);\n        val = g / (Y2 + r);\n        return sign ? -val : val;\n    }\n    q = Math.sqrt(-Math.log(q));\n    // [5] q < 3\n    if (q < 3) {\n        return calc(q, 1.125, P3, Q3, Y3);\n    }\n    // [6] q < 6\n    if (q < 6) {\n        return calc(q, 3, P4, Q4, Y4);\n    }\n    // Note that the smallest number in JavaScript is 5e-324. Math.sqrt( -Math.log( 5e-324 ) ) ~27.2844\n    return calc(q, 6, P5, Q5, Y5);\n    // Note that in the boost library, they are able to go to much smaller values, as 128 bit long doubles support ~1e-5000; something which JavaScript does not natively support.\n}\n//# sourceMappingURL=erfcinv.js.map","import erfcinv from './erfcinv';\n/**\n * Applies a simple normalization inverse transformation to the input data.\n * @param data - The input array of numbers to be transformed.\n * @param options - Optional parameters for the transformation.\n * @returns A new Float64Array containing the transformed data.\n */\nexport function simpleNormInv(data, options = {}) {\n    const { magnitudeMode = false } = options;\n    const result = new Float64Array(data.length);\n    if (magnitudeMode) {\n        for (let i = 0; i < result.length; i++) {\n            result[i] = -Math.sqrt(-2 * Math.log(1 - data[i]));\n        }\n    }\n    else {\n        for (let i = 0; i < result.length; i++) {\n            result[i] = -1 * Math.SQRT2 * erfcinv(2 * data[i]);\n        }\n    }\n    return result;\n}\n/**\n * Convenience wrapper for single number processing by simpleNormInv function.\n * @param data - The number to be normalized.\n * @param options - The options for the normalization process.\n * @returns The normalized number.\n */\nexport function simpleNormInvNumber(data, options = {}) {\n    return simpleNormInv([data], options)[0];\n}\n//# sourceMappingURL=simpleNormInv.js.map","import { isAnyArray } from 'is-any-array';\nimport { createFromToArray } from '../utils';\nimport { simpleNormInvNumber } from './utils/simpleNormInv';\nimport { xEnsureFloat64 } from './xEnsureFloat64';\n/**\n * Determine noise level by san plot methodology (https://doi.org/10.1002/mrc.4882)\n * @param array - real or magnitude spectra data.\n * @param options - options\n * @returns noise level\n */\nexport function xNoiseSanPlot(array, options = {}) {\n    const { mask, cutOff, refine = true, magnitudeMode = false, scaleFactor = 1, factorStd = 5, fixOffset = true, } = options;\n    const input = prepareData(array, { scaleFactor, mask });\n    if (fixOffset && !magnitudeMode) {\n        const medianIndex = Math.floor(input.length / 2);\n        const median = input.length % 2 === 0\n            ? 0.5 * (input[medianIndex - 1] + input[medianIndex])\n            : input[medianIndex];\n        for (let i = 0; i < input.length; i++) {\n            input[i] -= median;\n        }\n    }\n    const firstNegativeValueIndex = input.at(-1) >= 0\n        ? input.length\n        : input.findIndex((e) => e < 0);\n    let lastPositiveValueIndex = firstNegativeValueIndex - 1;\n    for (let i = lastPositiveValueIndex; i >= 0; i--) {\n        if (input[i] > 0) {\n            lastPositiveValueIndex = i;\n            break;\n        }\n    }\n    const signPositive = input.slice(0, lastPositiveValueIndex + 1);\n    const signNegative = input.slice(firstNegativeValueIndex);\n    const cutOffDist = cutOff || determineCutOff(signPositive, { magnitudeMode });\n    const pIndex = Math.floor(signPositive.length * cutOffDist);\n    const initialNoiseLevelPositive = signPositive[pIndex];\n    const skyPoint = signPositive[0];\n    let initialNoiseLevelNegative;\n    if (signNegative.length > 0) {\n        const nIndex = Math.floor(signNegative.length * (1 - cutOffDist));\n        initialNoiseLevelNegative = -1 * signNegative[nIndex];\n    }\n    else {\n        initialNoiseLevelNegative = 0;\n    }\n    let noiseLevelPositive = initialNoiseLevelPositive;\n    let noiseLevelNegative = initialNoiseLevelNegative;\n    let cloneSignPositive = signPositive.slice();\n    let cloneSignNegative = signNegative.slice();\n    let cutOffSignalsIndexPlus = 0;\n    let cutOffSignalsIndexNeg = 2;\n    if (refine) {\n        let cutOffSignals = noiseLevelPositive * factorStd;\n        cutOffSignalsIndexPlus = signPositive.findIndex((e) => e < cutOffSignals);\n        if (cutOffSignalsIndexPlus > -1) {\n            cloneSignPositive = signPositive.slice(cutOffSignalsIndexPlus);\n            noiseLevelPositive =\n                cloneSignPositive[Math.floor(cloneSignPositive.length * cutOffDist)];\n        }\n        cutOffSignals = noiseLevelNegative * factorStd;\n        cutOffSignalsIndexNeg = signNegative.findIndex((e) => e < cutOffSignals);\n        if (cutOffSignalsIndexNeg > -1) {\n            cloneSignNegative = signNegative.slice(cutOffSignalsIndexNeg);\n            noiseLevelNegative =\n                cloneSignPositive[Math.floor(cloneSignNegative.length * (1 - cutOffDist))];\n        }\n    }\n    const correctionFactor = -simpleNormInvNumber(cutOffDist / 2, {\n        magnitudeMode,\n    });\n    let effectiveCutOffDist, refinedCorrectionFactor;\n    if (refine && cutOffSignalsIndexPlus > -1) {\n        effectiveCutOffDist =\n            (cutOffDist * cloneSignPositive.length + cutOffSignalsIndexPlus) /\n                (cloneSignPositive.length + cutOffSignalsIndexPlus);\n        refinedCorrectionFactor =\n            -1 * simpleNormInvNumber(effectiveCutOffDist / 2, { magnitudeMode });\n        noiseLevelPositive /= refinedCorrectionFactor;\n        if (cutOffSignalsIndexNeg > -1) {\n            effectiveCutOffDist =\n                (cutOffDist * cloneSignNegative.length + cutOffSignalsIndexNeg) /\n                    (cloneSignNegative.length + cutOffSignalsIndexNeg);\n            refinedCorrectionFactor =\n                -1 * simpleNormInvNumber(effectiveCutOffDist / 2, { magnitudeMode });\n            if (noiseLevelNegative !== 0) {\n                noiseLevelNegative /= refinedCorrectionFactor;\n            }\n        }\n    }\n    else {\n        noiseLevelPositive /= correctionFactor;\n        noiseLevelNegative /= correctionFactor;\n    }\n    return {\n        positive: noiseLevelPositive,\n        negative: noiseLevelNegative,\n        snr: skyPoint / noiseLevelPositive,\n        sanplot: generateSanPlot(input, {\n            fromTo: {\n                positive: { from: 0, to: lastPositiveValueIndex },\n                negative: { from: firstNegativeValueIndex, to: input.length },\n            },\n        }),\n    };\n}\n/**\n * Determines the optimal cut-off point for a given array of positive numbers.\n * @param signPositive - An array of positive numbers.\n * @param options - Optional parameters to configure the cut-off determination.\n * @param options.magnitudeMode - If true, uses magnitude mode for normalization. Default is false.\n * @param options.considerList - An object specifying the range and step for consideration.\n * @param options.considerList.from - The starting point of the range. Default is 0.5.\n * @param options.considerList.step - The step size for the range. Default is 0.1.\n * @param options.considerList.to - The ending point of the range. Default is 0.9.\n * @returns The optimal cut-off point as a number.\n */\nfunction determineCutOff(signPositive, options = {}) {\n    const { magnitudeMode = false, considerList = { from: 0.5, step: 0.1, to: 0.9 }, } = options;\n    //generate a list of values for\n    const cutOff = [];\n    const indexMax = signPositive.length - 1;\n    for (let i = 0.01; i <= 0.99; i += 0.01) {\n        const index = Math.round(indexMax * i);\n        const value = -signPositive[index] / simpleNormInvNumber(i / 2, { magnitudeMode });\n        cutOff.push([i, value]);\n    }\n    let minKi = Number.MAX_SAFE_INTEGER;\n    const { from, to, step } = considerList;\n    const delta = step / 2;\n    let whereToCutStat = 0.5;\n    for (let i = from; i <= to; i += step) {\n        const floor = i - delta;\n        const top = i + delta;\n        const elementsOfCutOff = cutOff.filter((e) => e[0] < top && e[0] > floor);\n        let averageValue = 0;\n        for (const element of elementsOfCutOff) {\n            averageValue += Math.abs(element[1]);\n        }\n        let kiSqrt = 0;\n        for (const element of elementsOfCutOff) {\n            kiSqrt += (element[1] - averageValue) ** 2;\n        }\n        if (kiSqrt < minKi) {\n            minKi = kiSqrt;\n            whereToCutStat = i;\n        }\n    }\n    return whereToCutStat;\n}\n/**\n * Generates a SAN plot from the given array based on the specified options.\n * @param array - The input array of numbers to be processed.\n * @param options - An optional object containing configuration options.\n * @param options.logBaseY - The logarithmic base for the Y-axis. Defaults to 2.\n * @param options.fromTo - An object specifying the range for each key. Each key maps to an object with `from` and `to` properties.\n * @returns An object where each key maps to a DataXY object containing the processed data.\n */\nfunction generateSanPlot(array, options = {}) {\n    const { fromTo, logBaseY = 2 } = options;\n    const sanplot = {};\n    for (const key in fromTo) {\n        const { from, to } = fromTo[key];\n        sanplot[key] =\n            from !== to\n                ? scale(array.slice(from, to), {\n                    logBaseY,\n                })\n                : { x: [], y: [] };\n        if (key === 'negative') {\n            sanplot[key].y.reverse();\n        }\n    }\n    return sanplot;\n}\n/**\n * Scales the input array based on the provided options.\n * @param array - The input array to be scaled.\n * @param options - An optional object containing scaling options.\n * @param options.logBaseY - If provided, the array values will be scaled using the logarithm of this base.\n * @returns An object containing the scaled x and y arrays.\n */\nfunction scale(array, options = {}) {\n    const { log10, abs } = Math;\n    const { logBaseY } = options;\n    if (logBaseY) {\n        array = array.slice(0);\n        const logOfBase = log10(logBaseY);\n        for (let i = 0; i < array.length; i++) {\n            array[i] = log10(abs(array[i])) / logOfBase;\n        }\n    }\n    const xAxis = createFromToArray({\n        from: 0,\n        to: array.length - 1,\n        length: array.length,\n    });\n    return { x: xAxis, y: array };\n}\n/**\n * Prepares and processes the input data array based on the provided options.\n * @param array - The input array of numbers to be processed.\n * @param options - An object containing the following properties:\n *   - scaleFactor: A number by which to scale each element of the array.\n *   - mask: An optional array of the same length as the input array, where\n *           elements corresponding to `true` values will be excluded from processing.\n * @param options.scaleFactor\n * @param options.mask\n * @returns A new Float64Array containing the processed data, scaled by the\n *          scaleFactor and sorted in descending order.\n */\nfunction prepareData(array, options) {\n    const { scaleFactor, mask } = options;\n    const input = xEnsureFloat64(isAnyArray(mask) && mask.length === array.length\n        ? array.filter((_e, i) => !mask[i])\n        : array);\n    if (scaleFactor > 1) {\n        for (let i = 0; i < input.length; i++) {\n            input[i] *= scaleFactor;\n        }\n    }\n    return input.sort().reverse();\n}\n//# sourceMappingURL=xNoiseSanPlot.js.map","import { xMedianAbsoluteDeviation } from './xMedianAbsoluteDeviation';\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","import { xCheck } from './xCheck';\nimport { xGetFromToIndex } from './xGetFromToIndex';\n/**\n * Calculate the sum of the values\n * @param array - Object that contains property x (an ordered increasing array) and y (an array).\n * @param options - Options.\n * @returns XSum value on the specified range.\n */\nexport function xSum(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let sumValue = array[fromIndex];\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        sumValue += array[i];\n    }\n    return sumValue;\n}\n//# sourceMappingURL=xSum.js.map","import { getOutputArray } from './getOutputArray';\nimport { xCheck } from './xCheck';\nimport { xMaxValue } from './xMaxValue';\nimport { xSum } from './xSum';\n/**\n * Divides the data with either the sum, the absolute sum or the maximum of the data\n * @param input - Array containing values\n * @param options - options\n * @returns - normalized data\n */\nexport function xNormed(input, options = {}) {\n    const { algorithm = 'absolute', value = 1 } = options;\n    xCheck(input);\n    const output = getOutputArray(options.output, input.length);\n    if (input.length === 0) {\n        throw new Error('input must not be empty');\n    }\n    switch (algorithm) {\n        case 'absolute': {\n            const absoluteSumValue = absoluteSum(input) / value;\n            if (absoluteSumValue === 0) {\n                throw new Error('trying to divide by 0');\n            }\n            for (let i = 0; i < input.length; i++) {\n                output[i] = input[i] / absoluteSumValue;\n            }\n            return output;\n        }\n        case 'max': {\n            const currentMaxValue = xMaxValue(input);\n            if (currentMaxValue === 0) {\n                throw new Error('trying to divide by 0');\n            }\n            const factor = value / currentMaxValue;\n            for (let i = 0; i < input.length; i++) {\n                output[i] = input[i] * factor;\n            }\n            return output;\n        }\n        case 'sum': {\n            const sumFactor = xSum(input) / value;\n            if (sumFactor === 0) {\n                throw new Error('trying to divide by 0');\n            }\n            for (let i = 0; i < input.length; i++) {\n                output[i] = input[i] / sumFactor;\n            }\n            return output;\n        }\n        default:\n            throw new Error(`unknown algorithm: ${String(algorithm)}`);\n    }\n}\nfunction absoluteSum(input) {\n    let sumValue = 0;\n    for (let i = 0; i < input.length; i++) {\n        sumValue += Math.abs(input[i]);\n    }\n    return sumValue;\n}\n//# sourceMappingURL=xNormed.js.map","import { xCheck } from './xCheck';\nimport { xEnsureFloat64 } from './xEnsureFloat64';\n/**\n * This function pads an array\n *s\n * @param array - the array that will be padded\n * @param options - options\n */\nexport function xPadding(array, options = {}) {\n    const { size = 0, value = 0, algorithm } = options;\n    xCheck(array);\n    if (!algorithm) {\n        return xEnsureFloat64(array);\n    }\n    const result = new Float64Array(array.length + size * 2);\n    for (let i = 0; i < array.length; i++) {\n        result[i + size] = array[i];\n    }\n    const fromEnd = size + array.length;\n    const toEnd = 2 * size + array.length;\n    switch (algorithm) {\n        case 'value':\n            for (let i = 0; i < size; i++) {\n                result[i] = value;\n            }\n            for (let i = fromEnd; i < toEnd; i++) {\n                result[i] = value;\n            }\n            break;\n        case 'duplicate':\n            for (let i = 0; i < size; i++) {\n                result[i] = array[0];\n            }\n            for (let i = fromEnd; i < toEnd; i++) {\n                result[i] = array.at(-1);\n            }\n            break;\n        case 'circular':\n            for (let i = 0; i < size; i++) {\n                result[i] =\n                    array[(array.length - (size % array.length) + i) % array.length];\n            }\n            for (let i = 0; i < size; i++) {\n                result[i + fromEnd] = array[i % array.length];\n            }\n            break;\n        default:\n            throw new Error(`unknown algorithm ${String(algorithm)}`);\n    }\n    return result;\n}\n//# sourceMappingURL=xPadding.js.map","import { xCheck } from './xCheck';\nimport { xStandardDeviation } from './xStandardDeviation';\n/**\n * Pareto scaling, which uses the square root of standard deviation as the scaling factor, circumvents the amplification of noise by retaining a small portion of magnitude information.\n * Noda, I. (2008). Scaling techniques to enhance two-dimensional correlation spectra. Journal of Molecular Structure, 883, 216-227.\n * DOI: 10.1016/j.molstruc.2007.12.026\n * @param array - array of number\n */\nexport function xParetoNormalization(array) {\n    xCheck(array);\n    const result = new Float64Array(array.length);\n    const sqrtSD = Math.sqrt(xStandardDeviation(array));\n    for (let i = 0; i < array.length; i++) {\n        result[i] = array[i] / sqrtSD;\n    }\n    return result;\n}\n//# sourceMappingURL=xParetoNormalization.js.map","import { getOutputArray } from './getOutputArray';\nimport { xCheck } from './xCheck';\nimport { xMaxValue } from './xMaxValue';\nimport { xMinValue } from './xMinValue';\n/**\n * Function used to rescale data\n * @param input - input for the rescale\n * @param options - options\n * @returns rescaled data\n */\nexport function xRescale(input, options = {}) {\n    xCheck(input);\n    const output = getOutputArray(options.output, input.length);\n    const currentMin = xMinValue(input);\n    const currentMax = xMaxValue(input);\n    if (currentMin === currentMax) {\n        throw new RangeError('minimum and maximum input values are equal. Cannot rescale a constant array');\n    }\n    const { min = 0, max = 1 } = options;\n    if (min >= max) {\n        throw new RangeError('min option must be smaller than max option');\n    }\n    const factor = (max - min) / (currentMax - currentMin);\n    for (let i = 0; i < input.length; i++) {\n        output[i] = (input[i] - currentMin) * factor + min;\n    }\n    return output;\n}\n//# sourceMappingURL=xRescale.js.map","import { xCheck } from './xCheck';\nimport { xPadding } from './xPadding';\n/**\n * This function calculates a rolling average\n * @param array - array\n * @param fct - callback function that from an array returns a value\n * @param options - options\n */\nexport function xRolling(array, fct, options = {}) {\n    xCheck(array);\n    if (typeof fct !== 'function') {\n        throw new TypeError('fct must be a function');\n    }\n    const { window = 5, padding = {} } = options;\n    const { size = window - 1, algorithm, value } = padding;\n    const padded = xPadding(array, { size, algorithm, value }); // ensure we get a copy and it is float64\n    const newArray = [];\n    for (let i = 0; i < padded.length - window + 1; i++) {\n        // we will send a view to the original buffer\n        newArray.push(fct(padded.subarray(i, i + window)));\n    }\n    return newArray;\n}\n//# sourceMappingURL=xRolling.js.map","import { xMean } from './xMean';\nimport { xRolling } from './xRolling';\n/**\n * This function calculates a rolling average\n * @param array - array\n * @param options - option\n */\nexport function xRollingAverage(array, options = {}) {\n    return xRolling(array, xMean, options);\n}\n//# sourceMappingURL=xRollingAverage.js.map","import { xMedian } from './xMedian';\nimport { xRolling } from './xRolling';\n/**\n * This function calculates a rolling average\n * @param array - array\n * @param options - options\n */\nexport function xRollingMedian(array, options = {}) {\n    return xRolling(array, xMedian, options);\n}\n//# sourceMappingURL=xRollingMedian.js.map","/**\n * This function performs a circular shift to an array.\n * Positive values of shifts will shift to the right and negative values will do to the left.\n * @example xRotate([1,2,3,4],1) -> [4,1,2,3]\n * @example xRotate([1,2,3,4],-1) -> [2,3,4,1]\n * @param array - array\n * @param shift - shift\n * @returns - rotated array\n */\nexport function xRotate(array, shift) {\n    shift = shift % array.length;\n    if (shift < 0)\n        shift += array.length;\n    const result = new Float64Array(array.length);\n    result.set(array.slice(array.length - shift));\n    result.set(array.slice(0, array.length - shift), shift);\n    return result;\n}\n//# sourceMappingURL=xRotate.js.map","import { createNumberArray } from '../utils';\nexport function xSequentialFillFromStep(parameters, options = {}) {\n    const { from, step, size } = parameters;\n    const { ArrayConstructor = Float64Array } = options;\n    const result = createNumberArray(ArrayConstructor, size);\n    for (let i = 0; i < size; i++) {\n        result[i] = from + i * step;\n    }\n    return result;\n}\n//# sourceMappingURL=xSequentialFillFromStep.js.map","/**\n * Function that sorts arrays or Float64Arrays in descending order\n * @param array - array to sort\n * @returns sorted array\n */\nexport function xSortDescending(array) {\n    if (ArrayBuffer.isView(array)) {\n        return array.sort().reverse();\n    }\n    else if (Array.isArray(array)) {\n        return array.sort((a, b) => b - a);\n    }\n    throw new Error('trying to sort non array');\n}\n//# sourceMappingURL=xSortDescending.js.map","/*\nThe MIT License (MIT)\n\nCopyright (c) 2013 Eric Arnebäck\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n*/\n/**\n * Solves a system of linear equations using the Cholesky decomposition method.\n * It is a direct conversion to TS from {@link https://github.com/scijs/cholesky-solve}\n * @param nonZerosArray - The matrix in triplet form (array of arrays), where each sub-array contains three elements: row index, column index, and value.\n * @param dimension - The order of the matrix (number of rows/columns).\n * @param permutationEncoded - Optional permutation array. If provided, it will be used to permute the matrix.\n * @returns A function that takes a right-hand side vector `b` and returns the solution vector `x`, or `null` if the decomposition fails.\n */\nexport function matrixCholeskySolver(nonZerosArray, dimension, permutationEncoded) {\n    if (permutationEncoded) {\n        const pinv = new Array(dimension);\n        for (let k = 0; k < dimension; k++) {\n            pinv[permutationEncoded[k]] = k;\n        }\n        const mt = new Array(nonZerosArray.length);\n        for (let a = 0; a < nonZerosArray.length; ++a) {\n            const [r, c, value] = nonZerosArray[a];\n            const [ar, ac] = [pinv[r], pinv[c]];\n            mt[a] = ac < ar ? [ac, ar, value] : [ar, ac, value];\n        }\n        nonZerosArray = mt;\n    }\n    else {\n        permutationEncoded = [];\n        for (let i = 0; i < dimension; ++i) {\n            permutationEncoded[i] = i;\n        }\n    }\n    const ap = new Array(dimension + 1);\n    const ai = new Array(nonZerosArray.length);\n    const ax = new Array(nonZerosArray.length);\n    const lnz = [];\n    for (let i = 0; i < dimension; ++i) {\n        lnz[i] = 0;\n    }\n    for (const a of nonZerosArray) {\n        lnz[a[1]]++;\n    }\n    ap[0] = 0;\n    for (let i = 0; i < dimension; ++i) {\n        ap[i + 1] = ap[i] + lnz[i];\n    }\n    const colOffset = [];\n    for (let a = 0; a < dimension; ++a) {\n        colOffset[a] = 0;\n    }\n    for (const e of nonZerosArray) {\n        const col = e[1];\n        const adr = ap[col] + colOffset[col];\n        ai[adr] = e[0];\n        ax[adr] = e[2];\n        colOffset[col]++;\n    }\n    const d = new Array(dimension);\n    const y = new Array(dimension);\n    const lp = new Array(dimension + 1);\n    const parent = new Array(dimension);\n    const lnzArray = new Array(dimension);\n    const flag = new Array(dimension);\n    const pattern = new Array(dimension);\n    const bp1 = new Array(dimension);\n    const x = new Array(dimension);\n    ldlSymbolic(dimension, ap, ai, lp, parent, lnzArray, flag);\n    const lx = new Array(lp[dimension]);\n    const li = new Array(lp[dimension]);\n    const result = ldlNumeric(dimension, ap, ai, ax, lp, parent, lnzArray, li, lx, d, y, pattern, flag);\n    if (result === dimension) {\n        return (b) => {\n            ldlPerm(dimension, bp1, b, permutationEncoded);\n            ldlLsolve(dimension, bp1, lp, li, lx);\n            ldlDsolve(dimension, bp1, d);\n            ldlLTsolve(dimension, bp1, lp, li, lx);\n            ldlPermt(dimension, x, bp1, permutationEncoded);\n            return x;\n        };\n    }\n    else {\n        return null;\n    }\n}\nfunction ldlSymbolic(dimension, ap, ai, lp, parent, lnz, flag) {\n    for (let k = 0; k < dimension; k++) {\n        parent[k] = -1;\n        flag[k] = k;\n        lnz[k] = 0;\n        const kk = k;\n        const p2 = ap[kk + 1];\n        for (let permutationEncoded = ap[kk]; permutationEncoded < p2; permutationEncoded++) {\n            let i = ai[permutationEncoded];\n            if (i < k) {\n                for (; flag[i] !== k; i = parent[i]) {\n                    if (parent[i] === -1)\n                        parent[i] = k;\n                    lnz[i]++;\n                    flag[i] = k;\n                }\n            }\n        }\n    }\n    lp[0] = 0;\n    for (let k = 0; k < dimension; k++) {\n        lp[k + 1] = lp[k] + lnz[k];\n    }\n}\nfunction ldlNumeric(dimension, ap, ai, ax, lp, parent, lnz, li, lx, d, y, pattern, flag) {\n    let yi, lKi;\n    let i, k, permutationEncoded, kk, p2, len, top;\n    for (k = 0; k < dimension; k++) {\n        y[k] = 0;\n        top = dimension;\n        flag[k] = k;\n        lnz[k] = 0;\n        kk = k;\n        p2 = ap[kk + 1];\n        for (permutationEncoded = ap[kk]; permutationEncoded < p2; permutationEncoded++) {\n            i = ai[permutationEncoded];\n            if (i <= k) {\n                y[i] += ax[permutationEncoded];\n                for (len = 0; flag[i] !== k; i = parent[i]) {\n                    pattern[len++] = i;\n                    flag[i] = k;\n                }\n                while (len > 0)\n                    pattern[--top] = pattern[--len];\n            }\n        }\n        d[k] = y[k];\n        y[k] = 0;\n        for (; top < dimension; top++) {\n            i = pattern[top];\n            yi = y[i];\n            y[i] = 0;\n            p2 = lp[i] + lnz[i];\n            for (permutationEncoded = lp[i]; permutationEncoded < p2; permutationEncoded++) {\n                y[li[permutationEncoded]] -= lx[permutationEncoded] * yi;\n            }\n            lKi = yi / d[i];\n            d[k] -= lKi * yi;\n            li[permutationEncoded] = k;\n            lx[permutationEncoded] = lKi;\n            lnz[i]++;\n        }\n        if (d[k] === 0)\n            return k;\n    }\n    return dimension;\n}\nfunction ldlLsolve(dimension, x, lp, li, lx) {\n    let j, permutationEncoded, p2;\n    for (j = 0; j < dimension; j++) {\n        p2 = lp[j + 1];\n        for (permutationEncoded = lp[j]; permutationEncoded < p2; permutationEncoded++) {\n            x[li[permutationEncoded]] -= lx[permutationEncoded] * x[j];\n        }\n    }\n}\nfunction ldlDsolve(dimension, x, d) {\n    for (let j = 0; j < dimension; j++) {\n        x[j] /= d[j];\n    }\n}\nfunction ldlLTsolve(dimension, x, lp, li, lx) {\n    let j, permutationEncoded, p2;\n    for (j = dimension - 1; j >= 0; j--) {\n        p2 = lp[j + 1];\n        for (permutationEncoded = lp[j]; permutationEncoded < p2; permutationEncoded++) {\n            x[j] -= lx[permutationEncoded] * x[li[permutationEncoded]];\n        }\n    }\n}\nfunction ldlPerm(dimension, x, b, permutationEncoded) {\n    let j;\n    for (j = 0; j < dimension; j++) {\n        x[j] = b[permutationEncoded[j]];\n    }\n}\nfunction ldlPermt(dimension, x, b, permutationEncoded) {\n    let j;\n    for (j = 0; j < dimension; j++) {\n        x[permutationEncoded[j]] = b[j];\n    }\n}\n//# sourceMappingURL=matrixCholeskySolver.js.map","/**\n * add the provided weights to a particular given system matrix (lD'D) in the triplet form and y data. This function is not general\n * it assumes that diagonal coefficients are in the even indexes, it is the case of the matrix generated by createSystemMatrix function.\n * It simulates the matrix operation W + lD'D and Wy.\n * @param leftHandSide - The original system matrix to be updated, a lower triangular non-zeros of the system matrix (lambda D'D).\n * @param rightHandSide - The original vector to be updated.\n * @param weights - The weights to apply to the system matrix and vector.\n * @returns An object that contains the news left and right hand-side of the system.\n */\nexport function addWeights(leftHandSide, rightHandSide, weights) {\n    const nbPoints = rightHandSide.length;\n    const l = nbPoints - 1;\n    const newLeftHandSide = new Array(leftHandSide.length);\n    const newRightHandSide = new Float64Array(nbPoints);\n    for (let i = 0; i < l; i++) {\n        const w = weights[i];\n        const diag = i * 2;\n        const next = diag + 1;\n        newLeftHandSide[diag] = leftHandSide[diag].slice();\n        newLeftHandSide[next] = leftHandSide[next].slice();\n        newRightHandSide[i] = rightHandSide[i] * w;\n        newLeftHandSide[diag][2] += w;\n    }\n    newRightHandSide[l] = rightHandSide[l] * weights[l];\n    newLeftHandSide[l * 2] = leftHandSide[l * 2].slice();\n    newLeftHandSide[l * 2][2] += weights[l];\n    return {\n        leftHandSide: newLeftHandSide,\n        rightHandSide: newRightHandSide,\n    };\n}\n//# sourceMappingURL=addWeights.js.map","import { matrixCholeskySolver } from '../matrix/matrixCholeskySolver';\nimport { addWeights } from '../utils/addWeights';\nimport { calculateAdaptiveWeights } from '../utils/calculateAdaptiveWeights';\nimport { createSystemMatrix } from '../utils/createSystemMatrix';\nimport { xEnsureFloat64 } from './xEnsureFloat64';\nimport { xMultiply } from './xMultiply';\n/**\n * Computes the baseline points for the given data using an iterative smoothing algorithm.\n * @param yData - The input data array.\n * @param options - The options for baseline computation.\n * @returns - The computed baseline points.\n */\nexport function xWhittakerSmoother(yData, options = {}) {\n    const { lambda = 100, maxIterations = 100, tolerance = 1e-6, factorStd = 3, learningRate = 0.5, minWeight = 0.01, } = options;\n    const size = yData.length;\n    // eslint-disable-next-line prefer-const\n    let { controlPoints, weights } = getWeightsAndControlPoints(yData, options);\n    const prevBaseline = new Float64Array(size);\n    let iteration = 0;\n    let delta = Infinity;\n    let baseline = xEnsureFloat64(yData);\n    const upperTriangularNonZeros = createSystemMatrix(size, lambda);\n    while (iteration < maxIterations && delta > tolerance) {\n        const { leftHandSide, rightHandSide } = addWeights(upperTriangularNonZeros, yData, weights);\n        const cho = matrixCholeskySolver(leftHandSide, size);\n        if (!cho) {\n            return baseline;\n        }\n        const newBaseline = cho(rightHandSide);\n        weights = calculateAdaptiveWeights(yData, newBaseline, weights, {\n            controlPoints,\n            minWeight,\n            learningRate,\n            factorStd,\n        });\n        delta = calculateDelta(newBaseline, prevBaseline, size);\n        prevBaseline.set(newBaseline);\n        baseline = xEnsureFloat64(newBaseline);\n        iteration++;\n    }\n    return baseline;\n}\n/**\n * Calculates the delta between the current and previous baseline.\n * @param baseline - The current baseline array.\n * @param prevBaseline - The previous baseline array.\n * @param n - The length of the arrays.\n * @returns - The calculated delta value.\n */\nfunction calculateDelta(baseline, prevBaseline, n) {\n    let sum = 0;\n    for (let i = 0; i < n; i++) {\n        sum += (baseline[i] - prevBaseline[i]) ** 2;\n    }\n    return Math.sqrt(sum / n);\n}\n/**\n * Retrieves the control points and weights for the given data, the weights are modified multiplication of controlPoints if it exists.\n * @param  y - The input data array.\n * @param  options - The options for control points and weights.\n * @returns - The control points and modified weights.\n */\nfunction getWeightsAndControlPoints(y, options = {}) {\n    const { length } = y;\n    const { controlPoints } = options;\n    const { weights = Float64Array.from({ length }).fill(1) } = options;\n    if (controlPoints && controlPoints.length !== y.length) {\n        throw new RangeError('controlPoints should match the length with X');\n    }\n    else if (weights.length !== y.length) {\n        throw new RangeError('weights should match the length with X');\n    }\n    return {\n        weights: controlPoints ? xMultiply(weights, controlPoints) : weights,\n        controlPoints,\n    };\n}\n/**\n * @deprecated Use xWhittakerSmoother instead.\n * TODO: Remove in next major version.\n */\nexport const xWhitakerSmoother = xWhittakerSmoother;\n//# sourceMappingURL=xWhittakerSmoother.js.map","/**\n * Generates a lower triangular non-zeros of the first order smoother matrix (lambda D'D) where D is the derivate of the identity matrix\n * this function in combination with addWeights function can obtain (Q = W + lambda D'D) a penalized least square of Whittaker smoother,\n * it also generates a permutation encoded array.\n * @param dimension - The number of points in the matrix.\n * @param lambda - The factor of smoothness .\n * @returns An object containing the lower triangular non-zero elements of the matrix\n * and the permutation encoded array.\n * @property lowerTriangularNonZeros - The lower triangular non-zero elements of the matrix in triplet form.\n * @property permutationEncodedArray - The permutation encoded array generated using the Cuthill-McKee algorithm.\n */\nexport function createSystemMatrix(dimension, lambda) {\n    const upperTriangularNonZeros = [];\n    const last = dimension - 1;\n    for (let i = 0; i < last; i++) {\n        upperTriangularNonZeros.push([i, i, lambda * 2], [i, i + 1, -1 * lambda]);\n    }\n    upperTriangularNonZeros[0][2] = lambda;\n    upperTriangularNonZeros.push([last, last, lambda]);\n    return upperTriangularNonZeros;\n}\n//# sourceMappingURL=createSystemMatrix.js.map","/**\n * Phase correction filter.\n * @param data - complex spectrum\n * @param phi0 - Angle in radians for zero order phase correction\n * @param phi1 - Angle in radians for first order phase correction\n * @param options\n * @returns - returns a new object {re:[], im:[]}\n */\nexport function reimPhaseCorrection(data, phi0 = 0, phi1 = 0, options = {}) {\n    const { reverse = false } = options;\n    phi0 = Number.isFinite(phi0) ? phi0 : 0;\n    phi1 = Number.isFinite(phi1) ? phi1 : 0;\n    const re = data.re;\n    const im = data.im;\n    const length = data.re.length;\n    let firstAngle = phi0;\n    let delta = phi1 / length;\n    if (reverse) {\n        delta *= -1;\n        firstAngle += phi1;\n    }\n    const alpha = 2 * Math.sin(delta / 2) ** 2;\n    const beta = Math.sin(delta);\n    let cosTheta = Math.cos(firstAngle);\n    let sinTheta = Math.sin(firstAngle);\n    const newRe = new Float64Array(length);\n    const newIm = new Float64Array(length);\n    for (let i = 0; i < length; i++) {\n        newRe[i] = re[i] * cosTheta - im[i] * sinTheta;\n        newIm[i] = im[i] * cosTheta + re[i] * sinTheta;\n        // calculate angles i+1 from i\n        const newCosTheta = cosTheta - (alpha * cosTheta + beta * sinTheta);\n        const newSinTheta = sinTheta - (alpha * sinTheta - beta * cosTheta);\n        cosTheta = newCosTheta;\n        sinTheta = newSinTheta;\n    }\n    return { re: newRe, im: newIm };\n}\n//# sourceMappingURL=reimPhaseCorrection.js.map","import { xNoiseSanPlot } from '../x';\nimport { reimAbsolute } from './reimAbsolute';\nimport { reimPhaseCorrection } from './reimPhaseCorrection';\n/**\n * Implementation of the algorithm for automatic phase correction: A robust, general automatic phase\n * correction algorithm for high-resolution NMR data. 10.1002/mrc.4586\n * @param data - complex spectrum\n * @param options - options\n */\nexport function reimAutoPhaseCorrection(data, options = {}) {\n    const { magnitudeMode = true, minRegSize = 30, factorNoise = 3, maxDistanceToJoin = 256, reverse = false, } = options;\n    const finalPeaks = detectBaselineRegions(data, {\n        maxDistanceToJoin,\n        magnitudeMode,\n        factorNoise,\n    });\n    const { re, im } = data;\n    const length = re.length;\n    const indexMask = reverse ? (i) => length - 1 - i : (i) => i;\n    let x0 = 0;\n    let counter = -1;\n    const res = [];\n    while (counter < length) {\n        const reTmp = [];\n        const imTmp = [];\n        while (!finalPeaks[indexMask(++counter)] && counter < length) {\n            // Add some extra points(0.1 ppm) at rigth and left sides of the region.\n            x0 = counter;\n        }\n        for (; finalPeaks[indexMask(counter)] && counter < length; counter += 2) {\n            reTmp.push(re[indexMask(counter)]);\n            imTmp.push(im[indexMask(counter)]);\n        }\n        if (reTmp.length > minRegSize) {\n            res.push(autoPhaseRegion(reTmp, imTmp, x0));\n        }\n    }\n    const { ph1, ph0 } = determiningGlobalValues(res.map((r) => r.x0 / length), res.map((r) => r.ph0), res.map((r) => r.area / 1e11));\n    const phased = reimPhaseCorrection({ re, im }, toRadians(ph0), toRadians(ph1), { reverse });\n    return { data: phased, ph0, ph1 };\n}\nfunction determiningGlobalValues(x, ph0Values, weights) {\n    if (x.length === 0) {\n        return { ph0: 0, ph1: 0 };\n    }\n    else if (x.length === 1) {\n        return { ph0: ph0Values[0], ph1: 0 };\n    }\n    const [ph1, ph0] = weightedLinearRegression(x, ph0Values, weights);\n    let indexMax = -1;\n    let maxDiff = Number.MIN_SAFE_INTEGER;\n    for (let i = 0; i < x.length; i++) {\n        const predictedPh0 = x[i] * ph1 + ph0;\n        const diff = Math.abs(ph0Values[i] - predictedPh0);\n        if (diff > 34 && maxDiff < diff) {\n            indexMax = i;\n            maxDiff = diff;\n        }\n    }\n    if (indexMax > -1) {\n        x.splice(indexMax, 1);\n        ph0Values.splice(indexMax, 1);\n        weights.splice(indexMax, 1);\n        return determiningGlobalValues(x, ph0Values, weights);\n    }\n    return { ph0, ph1 };\n}\nfunction detectBaselineRegions(data, options) {\n    const magnitudeData = options.magnitudeMode ? reimAbsolute(data) : data.re;\n    const ds = holoborodko(magnitudeData);\n    const peaksDs = robustBaseLineRegionsDetection(ds, options);\n    const peaksSp = robustBaseLineRegionsDetection(magnitudeData, options);\n    return peaksSp.map((sp, i) => sp && peaksDs[i]);\n}\n/**\n * AutoPhaseRegion.\n * @param re - Array of Number.\n * @param im - Array of Number.\n * @param x0 - Number.\n * @returns Region.\n */\nfunction autoPhaseRegion(re, im, x0) {\n    let start = -180;\n    let stop = 180;\n    const nSteps = 6;\n    let maxSteps = 10;\n    let bestAng = 0;\n    let minArea = Number.MAX_SAFE_INTEGER;\n    while (maxSteps > 0) {\n        const dAng = (stop - start) / (nSteps + 1);\n        for (let i = start; i <= stop; i += dAng) {\n            const tmpPhased = reimPhaseCorrection({ re, im }, toRadians(i), 0);\n            const negArea = getNegArea(tmpPhased.re);\n            if (negArea < minArea) {\n                [minArea, bestAng] = [negArea, i];\n            }\n        }\n        start = bestAng - dAng;\n        stop = bestAng + dAng;\n        maxSteps--;\n    }\n    // Calculate the area for the best angle\n    const phased = reimPhaseCorrection({ re, im }, toRadians(bestAng), 0);\n    let area = 0;\n    let sumX = 0;\n    for (let j = 0; j < re.length; j++) {\n        area += phased.re[j];\n        sumX += phased.re[j] * (j + x0);\n    }\n    return { ph0: bestAng, area, x0: sumX / area };\n}\n/**\n * Holoborodko.\n * @param s - Array of float.\n * @returns Array of float.\n */\nfunction holoborodko(s) {\n    const dk = new Float64Array(s.length);\n    for (let i = 5; i < s.length - 5; i++) {\n        dk[i] =\n            (42 * (s[i + 1] - s[i - 1]) +\n                48 * (s[i + 2] - s[i - 2]) +\n                27 * (s[i + 3] + s[i - 3]) +\n                8 * (s[i + 4] - s[i - 4]) +\n                s[i + 5] -\n                s[i - 5]) /\n                512;\n    }\n    //Fill the borders\n    for (let i = 0; i < 5; i++) {\n        dk[i] = dk[5];\n        dk[s.length - i - 1] = dk[s.length - 6];\n    }\n    return dk;\n}\n/**\n * RobustBaseLineRegionsDetection.\n * @param s\n * @param options\n * @param options.magnitudeMode\n * @param options.maxDistanceToJoin\n * @param options.factorNoise\n */\nfunction robustBaseLineRegionsDetection(s, options) {\n    const { maxDistanceToJoin, magnitudeMode, factorNoise } = options;\n    const mask = new Uint8Array(s.length);\n    for (let i = 0; i < s.length; i++) {\n        mask[i] = 0;\n    }\n    let change = true;\n    while (change) {\n        const noiseLevel = xNoiseSanPlot(s, { magnitudeMode });\n        const cutOff = factorNoise * noiseLevel.positive;\n        change = false;\n        for (let i = 0; i < s.length; i++) {\n            if (Math.abs(s[i]) > cutOff && !mask[i]) {\n                change = true;\n                mask[i] = 1;\n            }\n        }\n    }\n    // Clean up mask by merging peaks blocks, separated by just a few points(4??).\n    let count = 0;\n    let prev = 0;\n    for (let i = 0; i < s.length; i++) {\n        if (!mask[i]) {\n            count++;\n        }\n        else {\n            if (count < maxDistanceToJoin) {\n                for (let j = 0; j <= count; j++) {\n                    mask[prev + j] = 1;\n                }\n            }\n            while (mask[++i] && i < s.length)\n                ;\n            prev = i;\n            count = 0;\n        }\n    }\n    return mask;\n}\n/**\n * WeightedLinearRegression.\n * @param x\n * @param y\n * @param w\n */\nfunction weightedLinearRegression(x, y, w) {\n    let sxtw = 0;\n    let swx = 0;\n    let sw = 0;\n    let sxtwy = 0;\n    let swy = 0;\n    for (let i = 0; i < x.length; i++) {\n        sxtw += x[i] * x[i] * w[i];\n        swx += x[i] * w[i];\n        sw += w[i];\n        sxtwy += x[i] * w[i] * y[i];\n        swy += w[i] * y[i];\n    }\n    /* Just to know what is the matrix system that we solve\n     let Mx=[[sxtw, swx], [swx, sw]];\n     let My=[[sxtwy], [swy]];\n    */\n    //Mx inverse\n    const detMx = sxtw * sw - swx * swx;\n    const inMx = [\n        [sw / detMx, -swx / detMx],\n        [-swx / detMx, sxtw / detMx],\n    ];\n    return [\n        inMx[0][0] * sxtwy + inMx[0][1] * swy,\n        inMx[1][0] * sxtwy + inMx[1][1] * swy,\n    ];\n}\nfunction toRadians(degree) {\n    return (degree * Math.PI) / 180;\n}\nfunction getNegArea(data) {\n    let area = 0;\n    for (const element of data) {\n        if (element < 0)\n            area -= element;\n    }\n    return area;\n}\n//# sourceMappingURL=reimAutoPhaseCorrection.js.map","import FFT from 'fft.js';\nimport { xRotate } from '../x';\n/**\n * ReimFFT.\n * @param data - complex spectrum\n * @param options - options.\n * @returns FFT of complex spectrum.\n */\nexport function reimFFT(data, options = {}) {\n    const { inverse = false, applyZeroShift = false } = options;\n    const { re, im } = data;\n    const size = re.length;\n    const csize = size << 1;\n    let complexArray = new Float64Array(csize);\n    for (let i = 0; i < csize; i += 2) {\n        complexArray[i] = re[i >>> 1];\n        complexArray[i + 1] = im[i >>> 1];\n    }\n    const fft = new FFT(size);\n    let output = new Float64Array(csize);\n    if (inverse) {\n        if (applyZeroShift)\n            complexArray = zeroShift(complexArray, true);\n        fft.inverseTransform(output, complexArray);\n    }\n    else {\n        fft.transform(output, complexArray);\n        if (applyZeroShift)\n            output = zeroShift(output);\n    }\n    const newRe = new Float64Array(size);\n    const newIm = new Float64Array(size);\n    for (let i = 0; i < csize; i += 2) {\n        newRe[i >>> 1] = output[i];\n        newIm[i >>> 1] = output[i + 1];\n    }\n    return { re: newRe, im: newIm };\n}\nfunction zeroShift(data, inverse) {\n    const middle = inverse\n        ? Math.ceil(data.length / 2)\n        : Math.floor(data.length / 2);\n    return xRotate(data, middle);\n}\n//# sourceMappingURL=reimFFT.js.map","/**\n * This function make a zero filling to re and im part.\n * @param data - object of kind {re:[], im:[]}\n * @param totalLength - final number of points\n * @returns - New DataReIm object with zero-filled,\n * truncated arrays if totalLength is smaller current length or\n * the same input if totalLength is equal that current length\n */\nexport function reimZeroFilling(data, totalLength) {\n    if (!Number.isInteger(totalLength) || totalLength < 0) {\n        throw new RangeError('totalLength must be a non-negative integer');\n    }\n    const { re, im } = data;\n    const length = re.length;\n    if (totalLength === 0 || length === totalLength)\n        return data;\n    if (length > totalLength) {\n        return {\n            re: re.slice(0, totalLength),\n            im: im.slice(0, totalLength),\n        };\n    }\n    const newRE = new Float64Array(totalLength);\n    const newIM = new Float64Array(totalLength);\n    newRE.set(re);\n    newIM.set(im);\n    return {\n        re: newRE,\n        im: newIM,\n    };\n}\n//# sourceMappingURL=reimZeroFilling.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * Verify that `data` is an object of x,y arrays.\n * Throws an error if it's not.\n * @param data\n * @param options\n * @param options.minLength\n */\nexport function xyCheck(data, options = {}) {\n    const { minLength } = options;\n    if (data === null ||\n        typeof data !== 'object' ||\n        // @ts-expect-error Typechecking\n        !isAnyArray(data.x) ||\n        // @ts-expect-error Typechecking\n        !isAnyArray(data.y)) {\n        throw new Error('data must be an object of x and y arrays');\n    }\n    // @ts-expect-error Typechecking\n    if (data.x.length !== data.y.length) {\n        throw new Error('the x and y arrays must have the same length');\n    }\n    // @ts-expect-error Typechecking\n    if (minLength && data.x.length < minLength) {\n        throw new Error(`data.x must have a length of at least ${minLength}`);\n    }\n}\n//# sourceMappingURL=xyCheck.js.map","import { xGetFromToIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Finds the max y value in a range and return a {x,y} point\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - Options\n */\nexport function xyMaxYPoint(data, options = {}) {\n    xyCheck(data, { minLength: 1 });\n    const { x, y } = data;\n    if (x.length === 1) {\n        return { x: x[0], y: y[0], index: 0 };\n    }\n    const { fromIndex, toIndex } = xGetFromToIndex(x, options);\n    let current = { x: x[fromIndex], y: y[fromIndex], index: fromIndex };\n    for (let i = fromIndex; i <= toIndex; i++) {\n        if (y[i] > current.y)\n            current = { x: x[i], y: y[i], index: i };\n    }\n    return current;\n}\n//# sourceMappingURL=xyMaxYPoint.js.map","import { xCumulative, xMaxValue } from '../x';\nimport { xyCheck } from './xyCheck';\nimport { xyMaxYPoint } from './xyMaxYPoint';\nconst STEPS = [0.25, 0.5, 0.75];\n/**\n * Cumulative Distribution Statistics\n * @param data - array of points {x,y}\n * @returns x0, x25, x50, x75, x100, xMode, xMean (x for maxY)\n */\nexport function xyCumulativeDistributionStatistics(data) {\n    xyCheck(data, { minLength: 1 });\n    const { x, y } = data;\n    const cumulativeSum = xCumulative(y);\n    const maxY = xMaxValue(cumulativeSum);\n    for (let i = 0; i < cumulativeSum.length; i++) {\n        cumulativeSum[i] /= maxY;\n    }\n    const result = {\n        x0: 0,\n        x25: 0,\n        x50: 0,\n        x75: 0,\n        x100: 0,\n        xMode: 0,\n        xMean: 0,\n    };\n    // need to find the x values closest to STEPS/100\n    result.x0 = x[0];\n    result.x100 = x.at(-1);\n    let currentStep = 0;\n    breakPoint: for (let i = 1; i < cumulativeSum.length; i++) {\n        while (STEPS[currentStep] < cumulativeSum[i]) {\n            // Key is computed dynamically with a multiplication. This cannot be type-safe, hence the \"as\" assertion.\n            const key = `x${STEPS[currentStep] * 100}`;\n            result[key] =\n                x[i - 1] +\n                    (x[i] - x[i - 1]) *\n                        ((STEPS[currentStep] - cumulativeSum[i - 1]) /\n                            (cumulativeSum[i] - cumulativeSum[i - 1]));\n            currentStep++;\n            if (currentStep === STEPS.length)\n                break breakPoint;\n        }\n    }\n    result.xMode = xyMaxYPoint(data).x;\n    let sumXY = 0;\n    let sumY = 0;\n    for (let i = 0; i < x.length; i++) {\n        sumXY += x[i] * y[i];\n        sumY += y[i];\n    }\n    result.xMean = sumXY / sumY;\n    return result;\n}\n//# sourceMappingURL=xyCumulativeDistributionStatistics.js.map","import { xIsMonotonic } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Filters x,y values to allow strictly growing values in x-axis.\n * @param data - Object that contains property x (an ordered increasing array) and y (an array).\n */\nexport function xyEnsureGrowingX(data) {\n    xyCheck(data);\n    if (xIsMonotonic(data.x) === 1)\n        return data;\n    const x = Array.from(data.x);\n    const y = Array.from(data.y);\n    let prevX = Number.NEGATIVE_INFINITY;\n    let currentIndex = 0;\n    for (let index = 0; index < x.length; index++) {\n        if (prevX < x[index]) {\n            if (currentIndex < index) {\n                x[currentIndex] = x[index];\n                y[currentIndex] = y[index];\n            }\n            currentIndex++;\n            prevX = x[index];\n        }\n    }\n    x.length = currentIndex;\n    y.length = currentIndex;\n    return { x, y };\n}\n//# sourceMappingURL=xyEnsureGrowingX.js.map","/**\n * Normalize an array of zones:\n * - ensure than from < to\n * - merge overlapping zones\n * - deal with exclusions zones\n * - if no zones is specified add one between -Infinity and +Infinity\n * @param zones - array of zones\n * @param options - options\n * @returns array of zones\n */\nexport function zonesNormalize(zones = [], options = {}) {\n    const { exclusions = [] } = options;\n    let { from = Number.NEGATIVE_INFINITY, to = Number.POSITIVE_INFINITY } = options;\n    if (from > to)\n        [from, to] = [to, from];\n    zones = zones\n        .map((zone) => zone.from > zone.to ? { from: zone.to, to: zone.from } : { ...zone })\n        .sort((a, b) => {\n        if (a.from !== b.from)\n            return a.from - b.from;\n        return a.to - b.to;\n    });\n    if (zones.length === 0) {\n        zones.push({ from, to });\n    }\n    for (const zone of zones) {\n        if (from > zone.from)\n            zone.from = from;\n        if (to < zone.to)\n            zone.to = to;\n    }\n    zones = zones.filter((zone) => zone.from <= zone.to);\n    if (zones.length === 0)\n        return [];\n    let currentZone = zones[0];\n    const beforeExclusionsZones = [currentZone];\n    for (let i = 1; i < zones.length; i++) {\n        const zone = zones[i];\n        if (zone.from <= currentZone.to) {\n            if (currentZone.to < zone.to) {\n                currentZone.to = zone.to;\n            }\n        }\n        else {\n            currentZone = zone;\n            beforeExclusionsZones.push(currentZone);\n        }\n    }\n    if (exclusions.length === 0)\n        return beforeExclusionsZones;\n    const normalizedExclusions = zonesNormalize(exclusions);\n    let currentExclusionIndex = 0;\n    const results = [];\n    for (let zoneIndex = 0; zoneIndex < beforeExclusionsZones.length; zoneIndex++) {\n        const zone = beforeExclusionsZones[zoneIndex];\n        if (currentExclusionIndex === normalizedExclusions.length) {\n            // we analysed all the exclusion zones\n            results.push(zone);\n            continue;\n        }\n        while (currentExclusionIndex < normalizedExclusions.length &&\n            normalizedExclusions[currentExclusionIndex].to <= zone.from) {\n            currentExclusionIndex++;\n        }\n        if (currentExclusionIndex === normalizedExclusions.length) {\n            // we analysed all the exclusion zones\n            results.push(zone);\n            continue;\n        }\n        if (zone.to < normalizedExclusions[currentExclusionIndex].from) {\n            // no problems, not yet in exclusion\n            results.push(zone);\n            continue;\n        }\n        if (normalizedExclusions[currentExclusionIndex].to >= zone.to) {\n            // could be totally excluded\n            if (normalizedExclusions[currentExclusionIndex].from <= zone.from) {\n                continue;\n            }\n            results.push({\n                from: normalizedExclusions[currentExclusionIndex].to,\n                to: zone.to,\n            });\n        }\n        // we cut in the middle, we need to create more zones, annoying !\n        if (normalizedExclusions[currentExclusionIndex].from > zone.from) {\n            results.push({\n                from: zone.from,\n                to: normalizedExclusions[currentExclusionIndex].from,\n            });\n        }\n        zone.from = normalizedExclusions[currentExclusionIndex].to;\n        zoneIndex--;\n    }\n    return results;\n}\n//# sourceMappingURL=zonesNormalize.js.map","import { zonesNormalize } from './zonesNormalize';\n/**\n * Add the number of points per zone to reach a specified total\n * @param zones - array of zones\n * @param numberOfPoints - total number of points to distribute between zones\n * @param options - options\n * @returns array of zones with points\n */\nexport function zonesWithPoints(zones = [], \n/**\n * total number of points to distribute between zones\n * @default 10\n */\nnumberOfPoints = 10, options = {}) {\n    if (zones.length === 0)\n        return [];\n    const normalizedZones = zonesNormalize(zones, options);\n    const zonesWithNumberOfPoints = [];\n    const totalSize = normalizedZones.reduce((previous, current) => {\n        return previous + (current.to - current.from);\n    }, 0);\n    const unitsPerPoint = totalSize / numberOfPoints;\n    let currentTotal = 0;\n    for (let i = 0; i < normalizedZones.length - 1; i++) {\n        const tempZone = normalizedZones[i];\n        const tempZoneNumberOfPoints = Math.min(Math.round((tempZone.to - tempZone.from) / unitsPerPoint), numberOfPoints - currentTotal);\n        zonesWithNumberOfPoints.push({\n            ...tempZone,\n            numberOfPoints: tempZoneNumberOfPoints,\n        });\n        currentTotal += tempZoneNumberOfPoints;\n    }\n    zonesWithNumberOfPoints.push({\n        ...normalizedZones.at(-1),\n        numberOfPoints: numberOfPoints - currentTotal,\n    });\n    return zonesWithNumberOfPoints;\n}\n//# sourceMappingURL=zonesWithPoints.js.map","/**\n * Function that calculates the integral of the line between two\n * x-coordinates, given the slope and intercept of the line.\n * @param x0\n * @param x1\n * @param slope\n * @param intercept\n * @returns integral value.\n */\nexport default function integral(\n/** first coordinate of point */\nx0, \n/** second coordinate of point */\nx1, \n/** slope of the line */\nslope, \n/** intercept of the line on the y axis */\nintercept) {\n    return (0.5 * slope * x1 * x1 +\n        intercept * x1 -\n        (0.5 * slope * x0 * x0 + intercept * x0));\n}\n//# sourceMappingURL=integral.js.map","import integral from './integral';\n/**\n * Function that retrieves the getEquallySpacedData with the variant \"smooth\".\n * @param x\n * @param y\n * @param from\n * @param to\n * @param numberOfPoints\n * @returns - Array of y's equally spaced with the variant \"smooth\"\n */\nexport default function equallySpacedSmooth(\n/** x coordinates */\nx, \n/** y coordinates */\ny, \n/** from value */\nfrom, \n/** to value */\nto, \n/** number of points */\nnumberOfPoints) {\n    const xLength = x.length;\n    const step = (to - from) / (numberOfPoints > 1 ? numberOfPoints - 1 : 1);\n    const halfStep = step / 2;\n    // Changed Array to Float64Array\n    const output = new Float64Array(numberOfPoints);\n    const initialOriginalStep = x[1] - x[0];\n    const lastOriginalStep = x[xLength - 1] - x[xLength - 2];\n    // Init main variables\n    let min = from - halfStep;\n    let max = from + halfStep;\n    let previousX = Number.MIN_SAFE_INTEGER;\n    let previousY = 0;\n    let nextX = x[0] - initialOriginalStep;\n    let nextY = 0;\n    let currentValue = 0;\n    let slope = 0;\n    let intercept = 0;\n    let sumAtMin = 0;\n    let sumAtMax = 0;\n    let i = 0; // index of input\n    let j = 0; // index of output\n    let add = 0;\n    main: while (true) {\n        if (previousX >= nextX)\n            throw new Error('x must be a growing series');\n        if (previousX <= min && min <= nextX) {\n            add = integral(0, min - previousX, slope, previousY);\n            sumAtMin = currentValue + add;\n        }\n        while (nextX - max >= 0) {\n            // no overlap with original point, just consume current value\n            add = integral(0, max - previousX, slope, previousY);\n            sumAtMax = currentValue + add;\n            output[j++] = (sumAtMax - sumAtMin) / step;\n            if (j === numberOfPoints) {\n                break main;\n            }\n            min = max;\n            max += step;\n            sumAtMin = sumAtMax;\n        }\n        currentValue += integral(previousX, nextX, slope, intercept);\n        previousX = nextX;\n        previousY = nextY;\n        if (i < xLength) {\n            nextX = x[i];\n            nextY = y[i];\n            i++;\n        }\n        else if (i === xLength) {\n            nextX += lastOriginalStep;\n            nextY = 0;\n        }\n        slope = getSlope(previousX, previousY, nextX, nextY);\n        intercept = -slope * previousX + previousY;\n    }\n    return output;\n}\nfunction getSlope(x0, y0, x1, y1) {\n    return (y1 - y0) / (x1 - x0);\n}\n//# sourceMappingURL=equallySpacedSmooth.js.map","import { createFromToArray } from '../utils';\nimport { zonesNormalize, zonesWithPoints } from '../zones';\nimport equallySpacedSlot from './utils/equallySpacedSlot';\nimport equallySpacedSmooth from './utils/equallySpacedSmooth';\nimport { xyCheck } from './xyCheck';\n/**\n * Function that returns a Number array of equally spaced numberOfPoints\n * containing a representation of intensities of the spectra arguments x\n * and y.\n *\n * The options parameter contains an object in the following form:\n * from: starting point\n * to: last point\n * numberOfPoints: number of points between from and to\n * variant: \"slot\" or \"smooth\" - smooth is the default option\n *\n * The slot variant consist that each point in an array is calculated\n * averaging the existing points between the slot that belongs to the current\n * value. The smooth variant is the same but takes the integral of the range\n * of the slot and divide by the step size between two points in an array.\n *\n * If exclusions zone are present, zones are ignored !\n * @param data - object containing 2 properties x and y\n * @param options - options\n * @returns new object with x / y array with the equally spaced data.\n */\nexport function xyEquallySpaced(data, options = {}) {\n    const { x, y } = data;\n    const xLength = x.length;\n    const { from = x[0], to = x[xLength - 1], variant = 'smooth', numberOfPoints = 100, exclusions = [], zones = [{ from, to }], } = options;\n    if (from > to) {\n        throw new RangeError('from should be larger than to');\n    }\n    xyCheck(data);\n    if (numberOfPoints < 2) {\n        throw new RangeError(\"'numberOfPoints' option must be greater than 1\");\n    }\n    const normalizedZones = zonesNormalize(zones, { from, to, exclusions });\n    const zonesWithPointsRes = zonesWithPoints(normalizedZones, numberOfPoints, {\n        from,\n        to,\n    }).filter((zone) => zone.numberOfPoints);\n    let xResult = [];\n    let yResult = [];\n    for (const zone of zonesWithPointsRes) {\n        if (!zone.numberOfPoints) {\n            zone.numberOfPoints = 0;\n        }\n        const zoneResult = processZone(Array.from(x), Array.from(y), zone.from, zone.to, zone.numberOfPoints, variant);\n        xResult = xResult.concat(zoneResult.x);\n        yResult = yResult.concat(zoneResult.y);\n    }\n    return { x: xResult, y: yResult };\n}\nfunction processZone(x, y, from, to, numberOfPoints, variant) {\n    if (numberOfPoints < 1) {\n        throw new RangeError('the number of points must be at least 1');\n    }\n    const output = variant === 'slot'\n        ? Array.from(equallySpacedSlot(x, y, from, to, numberOfPoints))\n        : Array.from(equallySpacedSmooth(x, y, from, to, numberOfPoints));\n    return {\n        x: Array.from(createFromToArray({\n            from,\n            to,\n            length: numberOfPoints,\n        })),\n        y: output,\n    };\n}\n//# sourceMappingURL=xyEquallySpaced.js.map","/**\n * Function that retrieves the getEquallySpacedData with the variant \"slot\".\n * @param x\n * @param y\n * @param from\n * @param to\n * @param numberOfPoints\n * @returns Array of y's equally spaced with the variant \"slot\"\n */\nexport default function equallySpacedSlot(\n/** x coordinates */\nx, \n/** y coordinates */\ny, \n/** from value */\nfrom, \n/** to value */\nto, \n/** number of points */\nnumberOfPoints) {\n    const xLength = x.length;\n    if (xLength < 2) {\n        return Float64Array.from(x);\n    }\n    const step = (to - from) / (numberOfPoints > 1 ? numberOfPoints - 1 : 1);\n    const halfStep = step / 2;\n    const lastStep = x.at(-1) - x.at(-2);\n    const start = from - halfStep;\n    // Changed Array to Float64Array\n    const output = new Float64Array(numberOfPoints);\n    // Init main variables\n    let min = start;\n    let max = start + step;\n    let previousX = -Number.MAX_VALUE;\n    let previousY = 0;\n    let nextX = x[0];\n    let nextY = y[0];\n    let frontOutsideSpectra = 0;\n    let backOutsideSpectra = true;\n    let currentValue = 0;\n    // for slot algorithm\n    let currentPoints = 0;\n    let i = 1; // index of input\n    let j = 0; // index of output\n    main: while (true) {\n        if (previousX >= nextX)\n            throw new Error('x must be a growing series');\n        while (previousX - max > 0) {\n            // no overlap with original point, just consume current value\n            if (backOutsideSpectra) {\n                currentPoints++;\n                backOutsideSpectra = false;\n            }\n            output[j] = currentPoints <= 0 ? 0 : currentValue / currentPoints;\n            j++;\n            if (j === numberOfPoints) {\n                break main;\n            }\n            min = max;\n            max += step;\n            currentValue = 0;\n            currentPoints = 0;\n        }\n        if (previousX > min) {\n            currentValue += previousY;\n            currentPoints++;\n        }\n        if (previousX === -Number.MAX_VALUE || frontOutsideSpectra > 1) {\n            currentPoints--;\n        }\n        previousX = nextX;\n        previousY = nextY;\n        if (i < xLength) {\n            nextX = x[i];\n            nextY = y[i];\n            i++;\n        }\n        else {\n            nextX += lastStep;\n            nextY = 0;\n            frontOutsideSpectra++;\n        }\n    }\n    return output;\n}\n//# sourceMappingURL=equallySpacedSlot.js.map","import { zonesNormalize } from '../zones';\n/**\n * Filter an array x/y based on various criteria x points are expected to be sorted\n * @param data - object containing 2 properties x and y\n * @param options - options\n * @returns filtered array\n */\nexport function xyFilterX(data, options = {}) {\n    const { x, y } = data;\n    if (x.length === 0) {\n        return {\n            x: Array.from(x),\n            y: Array.from(y),\n        };\n    }\n    const { from = x[0], to = x.at(-1), zones = [{ from, to }], exclusions = [], } = options;\n    const normalizedZones = zonesNormalize(zones, { from, to, exclusions });\n    let currentZoneIndex = 0;\n    const newX = [];\n    const newY = [];\n    let position = 0;\n    while (position < x.length) {\n        if (x[position] <= normalizedZones[currentZoneIndex].to &&\n            x[position] >= normalizedZones[currentZoneIndex].from) {\n            newX.push(x[position]);\n            newY.push(y[position]);\n        }\n        else if (x[position] > normalizedZones[currentZoneIndex].to) {\n            currentZoneIndex++;\n            if (!normalizedZones[currentZoneIndex])\n                break;\n        }\n        position++;\n    }\n    return {\n        x: newX,\n        y: newY,\n    };\n}\n//# sourceMappingURL=xyFilterX.js.map","import { xyCheck } from './xyCheck';\n/**\n * Filter out all the points for which x <= 0. Useful to display log scale data\n * @param data - data\n * @returns - An object with the filtered data\n */\nexport function xyFilterXPositive(data) {\n    xyCheck(data);\n    const { x, y } = data;\n    const newX = [];\n    const newY = [];\n    if (x === undefined || y === undefined) {\n        return { x: newX, y: newY };\n    }\n    for (let i = 0; i < x.length; i++) {\n        if (x[i] > 0) {\n            newX.push(x[i]);\n            newY.push(y[i]);\n        }\n    }\n    return { x: newX, y: newY };\n}\n//# sourceMappingURL=xyFilterXPositive.js.map","/**\n * Order object of array, x has to be monotone. Ensure x is growing\n * @param data - Object of kind {x:[], y:[]}.\n */\nexport function xyGrowingX(data) {\n    const { x, y } = data;\n    if (x.length !== y.length) {\n        throw new TypeError('length of x and y must be identical');\n    }\n    if (x.length < 2 || x[0] < x.at(-1))\n        return data;\n    return {\n        x: x.slice(0).reverse(),\n        y: y.slice(0).reverse(),\n    };\n}\n//# sourceMappingURL=xyGrowingX.js.map","import { xyCheck } from './xyCheck';\n/**\n * Join x / y values when difference in X is closer than delta.\n * When joining, y values are summed and x values are weighted average\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - Options\n * @returns - An object with the xyIntegration function\n */\nexport function xyJoinX(data, options = {}) {\n    xyCheck(data);\n    const { delta = 1 } = options;\n    const deltaIsFunction = typeof delta === 'function';\n    const x = Array.from(data.x);\n    const y = Array.from(data.y);\n    if (x.length < 2) {\n        return { x, y };\n    }\n    let position = 0;\n    for (let i = 1; i < x.length; i++) {\n        const difference = x[i] - x[i - 1];\n        const currentDelta = deltaIsFunction ? delta((x[i] + x[i - 1]) / 2) : delta;\n        if (difference <= currentDelta) {\n            // we join\n            if (y[position] !== 0 || y[i] !== 0) {\n                x[position] =\n                    (x[position] * y[position] + x[i] * y[i]) / (y[position] + y[i]);\n                y[position] += y[i];\n            }\n        }\n        else {\n            position++;\n            x[position] = x[i];\n            y[position] = y[i];\n        }\n    }\n    x.length = position + 1;\n    y.length = position + 1;\n    return { x, y };\n}\n//# sourceMappingURL=xyJoinX.js.map","import { xFindClosestIndex } from '../x';\nimport { zonesNormalize } from '../zones';\nimport { xyCheck } from './xyCheck';\n/**\n * Reduce the number of points while keeping visually the same noise. Practical to\n * display many spectra as SVG. If you want a similar looking spectrum you should still however\n * generate at least 4x the nbPoints that is being displayed.\n *\n * SHOULD NOT BE USED FOR DATA PROCESSING !!!\n * You should rather use ml-xy-equally-spaced to make further processing\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - options\n * @returns Object with x and y arrays\n */\nexport function xyReduce(data, options = {}) {\n    xyCheck(data);\n    // todo we should check that the single point is really in the range and the zones\n    if (data.x.length < 2) {\n        return {\n            x: Float64Array.from(data.x),\n            y: Float64Array.from(data.y),\n        };\n    }\n    const { x, y } = data;\n    const { from = x[0], to = x.at(-1), nbPoints = 4001, optimize = false, } = options;\n    let { zones = [] } = options;\n    zones = zonesNormalize(zones, { from, to });\n    if (zones.length === 0)\n        zones = [{ from, to }]; // we take everything\n    const { internalZones, totalPoints } = getInternalZones(zones, x);\n    // we calculate the number of points per zone that we should keep\n    if (totalPoints <= nbPoints) {\n        return notEnoughPoints(x, y, internalZones, totalPoints);\n    }\n    // need to xyReduce number of points\n    const ratio = nbPoints / totalPoints;\n    let currentTotal = 0;\n    for (let i = 0; i < internalZones.length - 1; i++) {\n        const zone = internalZones[i];\n        zone.nbPoints = Math.round(zone.nbPoints * ratio);\n        currentTotal += zone.nbPoints;\n    }\n    internalZones.at(-1).nbPoints = nbPoints - currentTotal;\n    const newX = [];\n    const newY = [];\n    for (const zone of internalZones) {\n        if (!zone.nbPoints)\n            continue;\n        appendFromTo(zone.fromIndex, zone.toIndex, zone.nbPoints);\n    }\n    return { x: newX, y: newY };\n    /**\n     * AppendFromTo.\n     * @param fromIndex - From.\n     * @param  toIndex - To.\n     * @param zoneNbPoints - NbPoints.\n     */\n    function appendFromTo(fromIndex, toIndex, zoneNbPoints) {\n        if (zoneNbPoints === 1) {\n            newX.push(x[Math.round((toIndex - fromIndex) / 2)]);\n            newY.push(y[Math.round((toIndex - fromIndex) / 2)]);\n            return;\n        }\n        if (zoneNbPoints === 2) {\n            newX.push(x[fromIndex], x[toIndex]);\n            newY.push(y[fromIndex], y[toIndex]);\n            return;\n        }\n        newX.push(x[fromIndex]);\n        newY.push(y[fromIndex]);\n        if (zoneNbPoints % 2 === 0) {\n            zoneNbPoints = zoneNbPoints / 2 + 1;\n        }\n        else {\n            zoneNbPoints = (zoneNbPoints - 1) / 2 + 1;\n        }\n        // we will need to make some kind of min / max because there are too many points\n        // we will always keep the first point and the last point\n        const slot = (x[toIndex] - x[fromIndex]) / (zoneNbPoints - 1);\n        let currentX = x[fromIndex] + slot;\n        let first = true;\n        let minY = Number.POSITIVE_INFINITY;\n        let xyMaxY = Number.NEGATIVE_INFINITY;\n        for (let i = fromIndex + 1; i <= toIndex; i++) {\n            if (first) {\n                minY = y[i];\n                xyMaxY = y[i];\n                first = false;\n            }\n            else {\n                if (y[i] < minY)\n                    minY = y[i];\n                if (y[i] > xyMaxY)\n                    xyMaxY = y[i];\n            }\n            if (x[i] >= currentX || i === toIndex) {\n                if (optimize) {\n                    if (minY > newY[newX.length - 1]) {\n                        // we can skip the intermediate value\n                    }\n                    else if (xyMaxY < newY[newX.length - 1]) {\n                        // we can skip the intermediate value\n                        xyMaxY = minY;\n                    }\n                    else {\n                        newX.push(currentX - slot / 2);\n                        newY.push(minY);\n                    }\n                }\n                else {\n                    newX.push(currentX - slot / 2);\n                    newY.push(minY);\n                }\n                newX.push(currentX);\n                newY.push(xyMaxY);\n                currentX += slot;\n                first = true;\n            }\n        }\n    }\n}\nexport function notEnoughPoints(x, y, internalZones, totalPoints) {\n    const newX = new Float64Array(totalPoints);\n    const newY = new Float64Array(totalPoints);\n    let index = 0;\n    for (const zone of internalZones) {\n        for (let i = zone.fromIndex; i < zone.toIndex + 1; i++) {\n            newX[index] = x[i];\n            newY[index] = y[i];\n            index++;\n        }\n    }\n    return {\n        x: newX,\n        y: newY,\n    };\n}\nexport function getInternalZones(zones, x) {\n    // for each zone we should know the first index, the last index and the number of points\n    const internalZones = [];\n    let totalPoints = 0;\n    for (const zone of zones) {\n        let fromIndex = xFindClosestIndex(x, zone.from);\n        let toIndex = xFindClosestIndex(x, zone.to);\n        if (fromIndex > 0 && x[fromIndex] > zone.from) {\n            fromIndex--;\n        }\n        if (toIndex < x.length - 1 && x[toIndex] < zone.to) {\n            toIndex++;\n        }\n        const nbPoints = toIndex - fromIndex + 1;\n        internalZones.push({\n            from: zone.from,\n            to: zone.to,\n            fromIndex,\n            toIndex,\n            nbPoints,\n        });\n        totalPoints += nbPoints;\n    }\n    return { internalZones, totalPoints };\n}\n//# sourceMappingURL=xyReduce.js.map","import { xIsMonotonic } from '../x';\n/**\n * This function performs a quick sort of the x array while transforming the y array to preserve the coordinates.\n * @param data - Object that contains property x (Array) and y (Array)\n */\nexport function xySortX(data) {\n    const { x, y } = data;\n    if (xIsMonotonic(x) && x.length > 1) {\n        if (x[0] < x[1]) {\n            return {\n                x: Float64Array.from(x),\n                y: Float64Array.from(y),\n            };\n        }\n        else {\n            return {\n                x: Float64Array.from(x).reverse(),\n                y: Float64Array.from(y).reverse(),\n            };\n        }\n    }\n    const xyObject = Array.from(x, (val, index) => ({\n        x: val,\n        y: y[index],\n    })).sort((a, b) => a.x - b.x);\n    const response = {\n        x: new Float64Array(x.length),\n        y: new Float64Array(y.length),\n    };\n    for (let i = 0; i < x.length; i++) {\n        response.x[i] = xyObject[i].x;\n        response.y[i] = xyObject[i].y;\n    }\n    return response;\n}\n//# sourceMappingURL=xySortX.js.map","import { xyCheck } from './xyCheck';\nimport { xySortX } from './xySortX';\n/**\n * Ensure x values are unique\n * @param data - Object that contains property x (Array) and y (Array)\n * @param options - Object containing a property algorithm (can be 'sum' or 'average', the latter being the default value), and a property isSorted (boolean indicating if the x-array is sorted).\n */\nexport function xyUniqueX(data, options = {}) {\n    xyCheck(data);\n    if (data.x.length === 0) {\n        return { x: [], y: [] };\n    }\n    const { algorithm = 'average', isSorted = true } = options;\n    if (!isSorted) {\n        data = xySortX(data);\n    }\n    switch (algorithm) {\n        case 'average':\n            return average(data);\n        case 'sum':\n            return sum(data);\n        default:\n            throw new Error(`unknown algorithm: ${String(algorithm)}`);\n    }\n}\n/**\n * Average.\n * @param data - Input.\n * @returns Result.\n */\nfunction average(data) {\n    const x = [];\n    const y = [];\n    let cumulativeY = data.y[0];\n    let divider = 1;\n    for (let i = 1; i < data.x.length; i++) {\n        if (!(data.x[i] === data.x[i - 1])) {\n            x.push(data.x[i - 1]);\n            y.push(cumulativeY / divider);\n            cumulativeY = 0;\n            divider = 0;\n        }\n        cumulativeY += data.y[i];\n        divider++;\n    }\n    x.push(data.x.at(-1));\n    y.push(cumulativeY / divider);\n    return { x, y };\n}\n/**\n * Sum.\n * @param data - Input.\n * @returns Result.\n */\nfunction sum(data) {\n    const x = [];\n    const y = [];\n    let cumulativeY = data.y[0];\n    for (let i = 1; i < data.x.length; i++) {\n        if (!(data.x[i] === data.x[i - 1])) {\n            x.push(data.x[i - 1]);\n            y.push(cumulativeY);\n            cumulativeY = 0;\n        }\n        cumulativeY += data.y[i];\n    }\n    x.push(data.x.at(-1));\n    y.push(cumulativeY);\n    return { x, y };\n}\n//# sourceMappingURL=xyUniqueX.js.map","/**\n * GetSlots.\n * @param data - data.\n * @param options - Options.\n */\nexport function getSlots(data, options = {}) {\n    const { delta = 1 } = options;\n    const deltaIsFunction = typeof delta === 'function';\n    const possibleXs = Float64Array.from(data.flatMap((spectrum) => spectrum.x)).sort();\n    if (possibleXs.length === 0) {\n        throw new Error('can not process empty arrays');\n    }\n    let currentSlot = {\n        from: possibleXs[0],\n        to: possibleXs[0],\n        average: possibleXs[0],\n        sum: possibleXs[0],\n        number: 1,\n    };\n    const slots = [currentSlot];\n    for (let i = 1; i < possibleXs.length; i++) {\n        const currentDelta = deltaIsFunction ? delta(possibleXs[i]) : delta;\n        if (possibleXs[i] - currentSlot.to <= currentDelta) {\n            currentSlot.to = possibleXs[i];\n            currentSlot.number++;\n            currentSlot.sum += possibleXs[i];\n            currentSlot.average = currentSlot.sum / currentSlot.number;\n        }\n        else {\n            currentSlot = {\n                from: possibleXs[i],\n                to: possibleXs[i],\n                average: possibleXs[i],\n                sum: possibleXs[i],\n                number: 1,\n            };\n            slots.push(currentSlot);\n        }\n    }\n    return slots;\n}\n//# sourceMappingURL=getSlots.js.map","/**\n * Merge DataXY\n * We have an array of DataXY and the goal is to merge all the values for which the deltaX is small or equal to delta.\n * X values are weighted average\n * @param data - data\n * @param options - Options\n */\nexport function xyArrayWeightedMerge(data, options = {}) {\n    let { delta = 1 } = options;\n    if (typeof delta === 'number') {\n        const deltaNumber = delta;\n        delta = () => deltaNumber;\n    }\n    data = data.filter((spectrum) => spectrum.x.length > 0);\n    if (data.length === 0)\n        return { x: [], y: [] };\n    const x = [];\n    const y = [];\n    const positions = new Array(data.length).fill(0);\n    const point = { x: 0, y: 0 };\n    nextValue(data, positions, point);\n    const slot = {\n        maxX: point.x + delta(point.x),\n        sumY: point.y,\n        sumXY: point.y * point.x,\n    };\n    while (data.length > 0) {\n        nextValue(data, positions, point);\n        const sameSlot = point.x <= slot.maxX;\n        if (!sameSlot) {\n            if (slot.sumY > 0) {\n                x.push(slot.sumXY / slot.sumY);\n                y.push(slot.sumY);\n            }\n            slot.sumY = 0;\n            slot.sumXY = 0;\n        }\n        slot.sumY += point.y;\n        slot.sumXY += point.x * point.y;\n        slot.maxX = point.x + delta(point.x);\n        if (data.length === 0 && slot.sumY > 0) {\n            x.push(slot.sumXY / slot.sumY);\n            y.push(slot.sumY);\n        }\n    }\n    return { x, y };\n}\n/**\n * NextValue.\n * @param data - data.\n * @param positions - Positions array.\n * @param point - Point.\n */\nfunction nextValue(data, positions, point) {\n    let minIndex = 0;\n    let minX = data[0].x[positions[0]];\n    for (let i = 1; i < data.length; i++) {\n        const currentX = data[i].x[positions[i]];\n        if (currentX < minX) {\n            minX = currentX;\n            minIndex = i;\n        }\n    }\n    point.x = minX;\n    point.y = data[minIndex].y[positions[minIndex]];\n    positions[minIndex]++;\n    if (positions[minIndex] === data[minIndex].x.length) {\n        positions.splice(minIndex, 1);\n        data.splice(minIndex, 1);\n    }\n}\n//# sourceMappingURL=xyArrayWeightedMerge.js.map","/**\n * Throws an error if it's not an array of x,y objects.\n * Only checks the first element.\n * @param points - List of points.\n * @param options - Additional checks.\n */\nexport function xyObjectCheck(points, options = {}) {\n    const { minLength = 0 } = options;\n    if (!Array.isArray(points)) {\n        throw new Error('points must be an array of {x,y} objects');\n    }\n    if (points.length > 0 &&\n        (typeof points[0].x !== 'number' || typeof points[0].y !== 'number')) {\n        throw new Error('points must be an array of {x,y} objects');\n    }\n    if (minLength && points.length < minLength) {\n        throw new Error(`points must have a length of at least ${minLength}`);\n    }\n}\n//# sourceMappingURL=xyObjectCheck.js.map","import { xyObjectCheck } from './xyObjectCheck';\n/**\n * Finds the max x value and return a {x,y,index} point\n * @param points - Object that contains property x (an ordered increasing array) and y (an array)\n */\nexport function xyObjectMaxXPoint(points = []) {\n    xyObjectCheck(points);\n    if (points.length === 0)\n        return { x: 0, y: 0 };\n    let current = {\n        x: points[0].x,\n        y: points[0].y,\n        index: 0,\n    };\n    for (let i = 1; i < points.length; i++) {\n        if (points[i].x > current.x) {\n            current = {\n                x: points[i].x,\n                y: points[i].y,\n                index: i,\n            };\n        }\n    }\n    return current;\n}\n//# sourceMappingURL=xyObjectMaxXPoint.js.map","import { xyObjectCheck } from './xyObjectCheck';\n/**\n * Finds the min x value and return a {x,y,index} point\n * @param points - Object that contains property x (an ordered increasing array) and y (an array)\n */\nexport function xyObjectMinXPoint(points = []) {\n    xyObjectCheck(points);\n    if (points.length === 0)\n        return { x: 0, y: 0 };\n    let current = {\n        x: points[0].x,\n        y: points[0].y,\n        index: 0,\n    };\n    for (let i = 1; i < points.length; i++) {\n        if (points[i].x < current.x) {\n            current = {\n                x: points[i].x,\n                y: points[i].y,\n                index: i,\n            };\n        }\n    }\n    return current;\n}\n//# sourceMappingURL=xyObjectMinXPoint.js.map","import { createNumberArray } from '../utils';\n/**\n * Create a new matrix based on the size of the current one or by using specific dimensions.\n * @param options\n */\nexport function matrixCreateEmpty(options) {\n    const { matrix, nbRows = matrix?.length || 1, nbColumns = matrix?.[0].length || 1, ArrayConstructor = Float64Array, } = options;\n    const newMatrix = [];\n    for (let row = 0; row < nbRows; row++) {\n        newMatrix.push(createNumberArray(ArrayConstructor, nbColumns));\n    }\n    return newMatrix;\n}\n//# sourceMappingURL=matrixCreateEmpty.js.map","export function matrixCheck(data) {\n    if (data.length === 0 || data[0].length === 0) {\n        throw new RangeError('matrix must contain data');\n    }\n    const firstLength = data[0].length;\n    for (let i = 1; i < data.length; i++) {\n        if (data[i].length !== firstLength) {\n            throw new RangeError('all rows must has the same length');\n        }\n    }\n}\n//# sourceMappingURL=matrixCheck.js.map","/**\n * Clone a matrix.\n * @param matrix\n */\nexport function matrixClone(matrix) {\n    return matrix.map((row) => row.slice(0));\n}\n//# sourceMappingURL=matrixClone.js.map","/**\n * Checks if the specified submatrix boundaries are within the valid range of the given matrix.\n * @param matrix - The matrix to check the boundaries against.\n * @param boundaries - The boundaries of the submatrix.\n * @throws {RangeError} If any of the specified boundaries are out of the matrix's range.\n */\nexport function matrixCheckRanges(matrix, boundaries) {\n    const { startRow, endRow, startColumn, endColumn } = boundaries;\n    if (startRow > endRow ||\n        startColumn > endColumn ||\n        startRow < 0 ||\n        startRow >= matrix.length ||\n        endRow < 0 ||\n        endRow >= matrix.length ||\n        startColumn < 0 ||\n        startColumn >= matrix[0].length ||\n        endColumn < 0 ||\n        endColumn >= matrix[0].length) {\n        throw new RangeError('submatrix indices are out of range');\n    }\n}\n//# sourceMappingURL=matrixCheckRanges.js.map","/**\n * Get min and max of the absolute values of Z.\n * @param matrix - matrix [rows][cols].\n */\nexport function matrixMinMaxAbsoluteZ(matrix) {\n    if (matrix.length === 0 || matrix[0].length === 0) {\n        throw new Error('matrixMinMaxAbsoluteZ requires at least 1 row and 1 column');\n    }\n    const nbRows = matrix.length;\n    const nbColumns = matrix[0].length;\n    let min = Number.POSITIVE_INFINITY;\n    let max = Number.NEGATIVE_INFINITY;\n    for (let column = 0; column < nbColumns; column++) {\n        for (let row = 0; row < nbRows; row++) {\n            let value = matrix[row][column];\n            if (value < 0)\n                value *= -1;\n            if (value < min)\n                min = value;\n            if (value > max)\n                max = value;\n        }\n    }\n    return { min, max };\n}\n//# sourceMappingURL=matrixMinMaxAbsoluteZ.js.map","import { matrixCheck } from './matrixCheck';\n/**\n * Get min and max Z.\n * @param matrix - matrix [rows][cols].\n */\nexport function matrixMinMaxZ(matrix) {\n    matrixCheck(matrix);\n    const nbRows = matrix.length;\n    const nbColumns = matrix[0].length;\n    let min = matrix[0][0];\n    let max = matrix[0][0];\n    for (let column = 0; column < nbColumns; column++) {\n        for (let row = 0; row < nbRows; row++) {\n            if (matrix[row][column] < min)\n                min = matrix[row][column];\n            if (matrix[row][column] > max)\n                max = matrix[row][column];\n        }\n    }\n    return { min, max };\n}\n//# sourceMappingURL=matrixMinMaxZ.js.map","/**\n * Returns the max absolute values of Z.\n * @param matrix - matrix [rows][cols].\n */\nexport function matrixMaxAbsoluteZ(matrix) {\n    if (matrix.length === 0 || matrix[0].length === 0) {\n        throw new Error('matrix must have at least 1 row and 1 column');\n    }\n    const nbRows = matrix.length;\n    const nbColumns = matrix[0].length;\n    let max = Number.NEGATIVE_INFINITY;\n    for (let column = 0; column < nbColumns; column++) {\n        for (let row = 0; row < nbRows; row++) {\n            const value = Math.abs(matrix[row][column]);\n            if (value > max)\n                max = value;\n        }\n    }\n    return max;\n}\n//# sourceMappingURL=matrixMaxAbsoluteZ.js.map","import { matrixCheck } from './matrixCheck';\n/**\n * Convert a matrix to a flat Float64Array.\n * @param matrix\n */\nexport function matrixToArray(matrix) {\n    matrixCheck(matrix);\n    const nbColumns = matrix[0].length;\n    const flatten = new Float64Array(matrix.length * nbColumns);\n    for (let row = 0; row < matrix.length; row++) {\n        const currentRow = row * nbColumns;\n        for (let column = 0; column < nbColumns; column++) {\n            flatten[currentRow + column] = matrix[row][column];\n        }\n    }\n    return flatten;\n}\n//# sourceMappingURL=matrixToArray.js.map","/**\n * Create an array with numbers starting from \"from\" with step \"step\" of length \"length\".\n * @param options - options\n * @returns - array of distributed numbers with step \"step\" from \"from\"\n */\nexport function createStepArray(options = {}) {\n    const { from = 0, step = 1, length = 1000 } = options;\n    const array = new Float64Array(length);\n    let index = 0;\n    while (index < length) {\n        array[index] = from + step * index;\n        index++;\n    }\n    return array;\n}\n//# sourceMappingURL=createStepArray.js.map","export function getRescaler(options = {}) {\n    const { targetMin = 0, targetMax = 1, clamp = true, algorithmOptions = {}, algorithm = 'linear', } = options;\n    let { originalMin = 0, originalMax = 1 } = options;\n    const convert = getDataConverter(algorithm, algorithmOptions);\n    originalMin = convert(originalMin);\n    originalMax = convert(originalMax);\n    const originalRange = originalMax - originalMin;\n    const targetRange = targetMax - targetMin;\n    return function rescaler(value) {\n        value = convert(value);\n        value = checkRange(value, originalMin, originalMax, clamp);\n        const valueScaled = (value - originalMin) / originalRange;\n        return targetMin + valueScaled * targetRange;\n    };\n}\nfunction getDataConverter(kind = 'linear', options = {}) {\n    return (value) => {\n        switch (kind) {\n            case 'linear':\n                return value;\n            case 'logarithmic':\n                return Math.log10(value);\n            case 'power':\n                return value ** (options.power || 2);\n            default:\n                throw new Error(`Unknown kind ${String(kind)}`);\n        }\n    };\n}\nfunction checkRange(value, min, max, clamp = true) {\n    if (value < min) {\n        if (clamp)\n            return min;\n        throw new RangeError(`Value ${value} is out of range [${min}, ${max}]`);\n    }\n    if (value > max) {\n        if (clamp)\n            return max;\n        throw new RangeError(`Value ${value} is out of range [${min}, ${max}]`);\n    }\n    return value;\n}\n//# sourceMappingURL=getRescaler.js.map","import { xMedian } from '../x';\n/**\n * Returns the median of the absolute matrix.\n * @param matrix\n */\nexport function matrixAbsoluteMedian(matrix) {\n    const nbColumns = matrix[0].length;\n    const flatten = new Float64Array(matrix.length * nbColumns);\n    for (let row = 0; row < matrix.length; row++) {\n        const currentRow = row * nbColumns;\n        for (let column = 0; column < nbColumns; column++) {\n            const value = matrix[row][column];\n            flatten[currentRow + column] = Math.abs(value);\n        }\n    }\n    return xMedian(flatten);\n}\n//# sourceMappingURL=matrixAbsoluteMedian.js.map","import { xMaxValue } from '../x';\nimport { matrixCreateEmpty } from './matrixCreateEmpty';\n/**\n * Numerically encodes the strings in the matrix with an encoding dictionary.\n * @param matrixInitial - Original matrix before encoding.\n * @param dictionary - Dictionary against which to do the encoding.\n * @returns - Encoded matrix.\n */\nexport function matrixApplyNumericalEncoding(matrixInitial, dictionary) {\n    const matrix = matrixCreateEmpty({\n        nbRows: matrixInitial.length,\n        nbColumns: matrixInitial[0].length,\n        ArrayConstructor: Array,\n    });\n    const arrayOfValues = [];\n    for (const key in dictionary) {\n        arrayOfValues.push(dictionary[key]);\n    }\n    let k = xMaxValue(arrayOfValues);\n    for (let i = 0; i < matrix.length; i++) {\n        for (let j = 0; j < matrix[0].length; j++) {\n            if (typeof matrix[i][j] === 'string') {\n                if (matrix[i][j] in dictionary) {\n                    matrix[i][j] = dictionary[matrix[i][j]];\n                }\n                else {\n                    k++;\n                    dictionary[matrix[i][j]] = k;\n                    matrix[i][j] = k;\n                }\n            }\n        }\n    }\n    return matrix;\n}\n//# sourceMappingURL=matrixApplyNumericalEncoding.js.map","import { xCorrelation } from '../x';\nexport function matrixAutoCorrelation(matrix, index = 0) {\n    const nbRows = matrix.length;\n    const nbColumns = matrix[0].length;\n    if (nbRows < 2) {\n        throw new Error('can not calculate info if matrix contains less than 2 rows');\n    }\n    const targetArray = new Float64Array(nbRows);\n    const sourceArray = new Float64Array(nbRows);\n    const result = new Float64Array(nbColumns);\n    for (let j = 0; j < nbRows; j++) {\n        targetArray[j] = matrix[j][index];\n    }\n    for (let i = 0; i < nbColumns; i++) {\n        for (let j = 0; j < nbRows; j++) {\n            sourceArray[j] = matrix[j][i];\n        }\n        result[i] = xCorrelation(targetArray, sourceArray);\n    }\n    return result;\n}\n//# sourceMappingURL=matrixAutoCorrelation.js.map","export function matrixBoxPlot(matrix) {\n    const nbRows = matrix.length;\n    const nbColumns = matrix[0].length;\n    if (nbRows < 5) {\n        throw new Error('can not calculate info if matrix contains less than 5 rows');\n    }\n    const info = {\n        q1: new Float64Array(nbColumns),\n        median: new Float64Array(nbColumns),\n        q3: new Float64Array(nbColumns),\n        min: Float64Array.from(matrix[0]),\n        max: Float64Array.from(matrix.at(-1)),\n    };\n    const columnArray = new Float64Array(matrix.length);\n    for (let column = 0; column < nbColumns; column++) {\n        for (let row = 0; row < nbRows; row++) {\n            columnArray[row] = matrix[row][column];\n        }\n        let q1max = 0;\n        let q3min = 0;\n        if (nbRows % 2 === 1) {\n            // odd\n            const middle = (nbRows - 1) / 2;\n            info.median[column] = columnArray[middle];\n            q1max = middle - 1;\n            q3min = middle + 1;\n        }\n        else {\n            // even\n            q3min = nbRows / 2;\n            q1max = q3min - 1;\n            info.median[column] = (columnArray[q1max] + columnArray[q3min]) / 2;\n        }\n        if (q1max % 2 === 0) {\n            info.q1[column] = columnArray[q1max / 2];\n            info.q3[column] = columnArray[(nbRows + q3min - 1) / 2];\n        }\n        else {\n            info.q1[column] =\n                (columnArray[(q1max + 1) / 2] + columnArray[(q1max - 1) / 2]) / 2;\n            const middleOver = (columnArray.length + q3min) / 2;\n            info.q3[column] =\n                (columnArray[middleOver] + columnArray[middleOver - 1]) / 2;\n        }\n    }\n    return info;\n}\n//# sourceMappingURL=matrixBoxPlot.js.map","import { matrixCreateEmpty } from './matrixCreateEmpty';\n/**\n * Center mean of matrix columns.\n * @param matrix - matrix [rows][cols]\n */\nexport function matrixCenterZMean(matrix) {\n    const nbColumns = matrix[0].length;\n    const nbRows = matrix.length;\n    const newMatrix = matrixCreateEmpty({ nbColumns, nbRows });\n    for (let column = 0; column < nbColumns; column++) {\n        let mean = 0;\n        for (let row = 0; row < nbRows; row++) {\n            mean += matrix[row][column];\n        }\n        mean /= nbRows;\n        for (let row = 0; row < nbRows; row++) {\n            newMatrix[row][column] = matrix[row][column] - mean;\n        }\n    }\n    return newMatrix;\n}\n//# sourceMappingURL=matrixCenterZMean.js.map","import { Matrix } from 'ml-matrix';\nimport { xCorrelation } from '../x';\n/**\n * Calculates a correlation matrix based on the columns of the initial matrix.\n * @param A - matrix [rows][cols]\n */\nexport function matrixColumnsCorrelation(A) {\n    const B = new Matrix(A).transpose();\n    const result = [];\n    for (let i = 0; i < B.rows; i++) {\n        result.push(new Float64Array(B.rows));\n    }\n    for (let i = 0; i < B.rows; i++) {\n        for (let j = i; j < B.rows; j++) {\n            const correlation = xCorrelation(B.getRow(i), B.getRow(j));\n            result[i][j] = correlation;\n            result[j][i] = correlation;\n        }\n    }\n    return result;\n}\n//# sourceMappingURL=matrixColumnsCorrelation.js.map","/**\n * The MIT License (MIT)\n *\n * Copyright (c) 2013 Mikola Lysenko\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\n/**\n * The reverse Cuthill-Mckee method is a fast and effective preconditioner for reducing the bandwidth of sparse linear systems.\n * When solving a positive semidefinite linear system using Cholesky factorization, it greatly reduces fill-in.\n * It is a direct conversion to TS from {@link github.com/mikolalysenko/cuthill-mckee}\n * @param list - lower triangular non zeros from a symmetric sparse matrix.\n * @param dimension - matrix dimension\n * @returns A Float64Array where the value at each index represents the new position of the node\n *          in the bandwidth-reduced ordering.\n */\nexport function matrixCuthillMckee(list, dimension) {\n    const adj = new Array(dimension);\n    const visited = new Array(dimension).fill(false);\n    for (let i = 0; i < dimension; ++i) {\n        adj[i] = [];\n    }\n    for (const l of list) {\n        adj[l[0]].push(l[1]);\n    }\n    const toVisit = new Float64Array(dimension);\n    let eol = 0;\n    let ptr = 0;\n    for (let i = 0; i < dimension; ++i) {\n        if (visited[i]) {\n            continue;\n        }\n        toVisit[eol++] = i;\n        visited[i] = true;\n        while (ptr < eol) {\n            const v = toVisit[ptr++];\n            const nbhd = Float64Array.from(adj[v]).sort();\n            for (const u of nbhd) {\n                if (visited[u]) {\n                    continue;\n                }\n                visited[u] = true;\n                toVisit[eol++] = u;\n            }\n        }\n    }\n    const result = new Float64Array(dimension);\n    for (let i = 0; i < dimension; ++i) {\n        result[toVisit[i]] = i;\n    }\n    return result;\n}\n//# sourceMappingURL=matrixCuthillMckee.js.map","import { matrixCheckRanges } from './matrixCheckRanges';\n/**\n * Get a subMatrix from matrix, the function checks if the subMatrix\n * lies within the dimensions of the matrix.\n * @param matrix - The original matrix from which the subMatrix will be extracted.\n * @param options - Options to define the subMatrix boundaries and duplication behavior.\n * @returns The subMatrix extracted from the original matrix.\n */\nexport function matrixGetSubMatrix(matrix, options) {\n    const { startRow = 0, endRow = matrix.length - 1, startColumn = 0, endColumn = matrix[0].length - 1, duplicate = true, } = options;\n    matrixCheckRanges(matrix, { startColumn, startRow, endColumn, endRow });\n    const nbRows = endRow - startRow + 1;\n    const subMatrix = [];\n    if (duplicate) {\n        for (let i = 0; i < nbRows; i++) {\n            subMatrix.push(matrix[startRow + i].slice(startColumn, endColumn + 1));\n        }\n    }\n    else {\n        for (let i = 0; i < nbRows; i++) {\n            subMatrix.push(matrix[startRow + i].subarray(startColumn, endColumn + 1));\n        }\n    }\n    return subMatrix;\n}\n//# sourceMappingURL=matrixGetSubMatrix.js.map","import { xHistogram } from '../x';\nimport { matrixMinMaxAbsoluteZ } from './matrixMinMaxAbsoluteZ';\nimport { matrixMinMaxZ } from './matrixMinMaxZ';\n/**\n * Calculates a histogram of defined number of slots.\n * @param matrix - matrix [rows][cols].\n * @param options - options\n * @returns - Result of the histogram.\n */\nexport function matrixHistogram(matrix, options = {}) {\n    let { min, max } = options;\n    const { absolute, logBaseX, logBaseY, histogram, nbSlots, centerX } = options;\n    if (matrix.length === 0 || matrix[0].length === 0) {\n        throw new Error('matrix must have at least one column and one row');\n    }\n    if (min === undefined || max === undefined) {\n        const minMax = absolute\n            ? matrixMinMaxAbsoluteZ(matrix)\n            : matrixMinMaxZ(matrix);\n        if (min === undefined) {\n            min =\n                logBaseX && minMax.min\n                    ? Math.log(minMax.min) / Math.log(logBaseX)\n                    : minMax.min;\n        }\n        if (max === undefined) {\n            max =\n                logBaseX && minMax.max\n                    ? Math.log(minMax.max) / Math.log(logBaseX)\n                    : minMax.max;\n        }\n    }\n    const xHistogramOptions = {\n        histogram,\n        nbSlots,\n        centerX,\n        absolute,\n        logBaseX,\n        // Skip logBaseY as it's handled below.\n        min,\n        max,\n    };\n    const finalHistogram = xHistogram(matrix[0], xHistogramOptions);\n    xHistogramOptions.histogram = finalHistogram;\n    const nbRows = matrix.length;\n    for (let row = 1; row < nbRows; row++) {\n        xHistogram(matrix[row], xHistogramOptions);\n    }\n    const y = finalHistogram.y;\n    if (logBaseY) {\n        const logOfBase = Math.log10(logBaseY);\n        for (let i = 0; i < y.length; i++) {\n            y[i] = Math.log10(y[i] + 1) / logOfBase;\n        }\n    }\n    return finalHistogram;\n}\n//# sourceMappingURL=matrixHistogram.js.map","import { xMedian } from '../x';\nimport { matrixToArray } from './matrixToArray';\n/**\n * Returns the median of the matrix.\n * @param matrix\n */\nexport function matrixMedian(matrix) {\n    return xMedian(matrixToArray(matrix));\n}\n//# sourceMappingURL=matrixMedian.js.map","import { xNoiseStandardDeviation } from '../x';\nimport { matrixToArray } from './matrixToArray';\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 matrix\n * @returns Noise level corresponding to one standard deviation.\n */\nexport function matrixNoiseStandardDeviation(matrix) {\n    return xNoiseStandardDeviation(matrixToArray(matrix));\n}\n//# sourceMappingURL=matrixNoiseStandardDeviation.js.map","import { matrixClone } from './matrixClone';\n/**\n * Numerically decodes the matrix using the dictionary.\n * @param matrixInitial\n * @param dictionary - dictionary against which to do the encoding\n * @returns - decoded matrix\n */\nexport function matrixNumericalDecoding(matrixInitial, dictionary) {\n    const matrix = matrixClone(matrixInitial);\n    const invertedDictionary = swap(dictionary);\n    for (let i = 0; i < matrix.length; i++) {\n        for (let j = 0; j < matrix[0].length; j++) {\n            const value = matrix[i][j];\n            if (typeof value === 'number' && value in invertedDictionary) {\n                matrix[i][j] = invertedDictionary[value];\n            }\n        }\n    }\n    return matrix;\n}\nfunction swap(dictionary) {\n    const ret = {};\n    for (const key in dictionary) {\n        ret[dictionary[key]] = key;\n    }\n    return ret;\n}\n//# sourceMappingURL=matrixNumericalDecoding.js.map","import { matrixClone } from './matrixClone';\n/**\n * Numerically encodes the strings in the matrix and returns an encoding dictionary which can be used to encode other matrices\n * @param matrixInitial - original matrix before encoding\n * @returns - dictionary from string to number\n */\nexport function matrixNumericalEncoding(matrixInitial) {\n    const matrix = matrixClone(matrixInitial);\n    const nRows = matrix.length;\n    const nColumns = matrix[0].length;\n    let k = 0;\n    for (let i = 0; i < nRows; i++) {\n        for (let j = 0; j < nColumns; j++) {\n            const value = matrix[i][j];\n            if (typeof value === 'number' && value > k) {\n                k = value;\n            }\n        }\n    }\n    const dictCategoricalToNumerical = {};\n    for (let i = 0; i < nRows; i++) {\n        for (let j = 0; j < nColumns; j++) {\n            const value = matrix[i][j];\n            if (typeof value === 'string') {\n                if (value in dictCategoricalToNumerical) {\n                    matrix[i][j] = dictCategoricalToNumerical[value];\n                }\n                else {\n                    k++;\n                    dictCategoricalToNumerical[value] = k;\n                    matrix[i][j] = k;\n                }\n            }\n        }\n    }\n    return { matrix: matrix, dictCategoricalToNumerical };\n}\n//# sourceMappingURL=matrixNumericalEncoding.js.map","import { Matrix } from 'ml-matrix';\nimport { xMedian } from '../x';\n/**\n * Performs a Probabilistic quotient normalization (PQN) over the dataset to account dilution based in median spectrum.\n * Dieterle, F., Ross, A., Schlotterbeck, G., & Senn, H. (2006). Probabilistic quotient normalization as robust method to account for dilution of complex biological mixtures. Application in 1H NMR metabonomics. Analytical chemistry, 78(13), 4281-4290.\n * DOI: 10.1021/ac051632c\n * @param matrix - matrix [rows][cols].\n * @param options - options\n * @returns - {data: Normalized dataset, medianOfQuotients: The median of quotients of each variables}\n */\nexport function matrixPQN(matrix, options = {}) {\n    const { max = 100 } = options;\n    const matrixB = new Matrix(matrix);\n    for (let i = 0; i < matrixB.rows; i++) {\n        const normalizationFactor = matrixB.getRowVector(i).norm('frobenius') / max;\n        const row = matrixB.getRowVector(i).div(normalizationFactor);\n        matrixB.setRow(i, row);\n    }\n    const referenceSpectrum = [];\n    for (let i = 0; i < matrixB.columns; i++) {\n        const currentVariable = matrixB.getColumn(i);\n        referenceSpectrum.push(xMedian(currentVariable));\n    }\n    const medianOfQuotients = [];\n    for (let i = 0; i < matrixB.columns; i++) {\n        const quotients = matrixB.getColumnVector(i).div(referenceSpectrum[i]);\n        medianOfQuotients.push(xMedian(quotients.getColumn(0)));\n    }\n    for (let i = 0; i < matrixB.rows; i++) {\n        matrixB.mulRow(i, 1 / medianOfQuotients[i]);\n    }\n    return {\n        data: matrixB.to2DArray(),\n        medianOfQuotients,\n    };\n}\n//# sourceMappingURL=matrixPQN.js.map","import { matrixCheckRanges } from './matrixCheckRanges';\n/**\n * Set in-place a subMatrix to matrix, the function check if the subMatrix\n * lies into the dimensions of matrix.\n * @param matrix - matrix that will receive the new element values.\n * @param subMatrix - matrix with equal or less size than matrix.\n * @param startRow - row index in matrix for the first row in subMatrix.\n * @param startColumn - column index in matrix for the first column in subMatrix.\n * @returns The modified `matrix`.\n */\nexport function matrixSetSubMatrix(matrix, subMatrix, startRow, startColumn) {\n    const endRow = startRow + subMatrix.length - 1;\n    const endColumn = startColumn + subMatrix[0].length - 1;\n    matrixCheckRanges(matrix, { startRow, endRow, startColumn, endColumn });\n    for (let i = 0; i < subMatrix.length; i++) {\n        for (let j = 0; j < subMatrix[0].length; j++) {\n            matrix[startRow + i][startColumn + j] = subMatrix[i][j];\n        }\n    }\n    return matrix;\n}\n//# sourceMappingURL=matrixSetSubMatrix.js.map","import { matrixCheck } from './matrixCheck';\nimport { matrixCreateEmpty } from './matrixCreateEmpty';\nexport function matrixTranspose(matrix, options = {}) {\n    matrixCheck(matrix);\n    const { ArrayConstructor } = options;\n    const nbRows = matrix.length;\n    const nbColumns = matrix[0].length;\n    // Create new matrix with swapped dimensions\n    const result = matrixCreateEmpty({\n        nbColumns: nbRows,\n        nbRows: nbColumns,\n        ArrayConstructor,\n    });\n    for (let i = 0; i < nbRows; i++) {\n        for (let j = 0; j < nbColumns; j++) {\n            result[j][i] = matrix[i][j];\n        }\n    }\n    return result;\n}\n//# sourceMappingURL=matrixTranspose.js.map","import { matrixCreateEmpty } from './matrixCreateEmpty';\nimport { matrixMaxAbsoluteZ } from './matrixMaxAbsoluteZ';\n/**\n * Rescale a matrix around 0 taking into account the absolute max value.\n * @param matrix - matrix [rows][cols].\n * @param options - Options.\n */\nexport function matrixZPivotRescale(matrix, options = {}) {\n    const { max = 1, ArrayConstructor } = options;\n    const nbColumns = matrix[0].length;\n    const nbRows = matrix.length;\n    const newMatrix = matrixCreateEmpty({ nbColumns, nbRows, ArrayConstructor });\n    const currentMax = matrixMaxAbsoluteZ(matrix);\n    for (let column = 0; column < nbColumns; column++) {\n        const factor = max / currentMax;\n        for (let row = 0; row < nbRows; row++) {\n            newMatrix[row][column] = matrix[row][column] * factor;\n        }\n    }\n    return newMatrix;\n}\n//# sourceMappingURL=matrixZPivotRescale.js.map","import { matrixCreateEmpty } from './matrixCreateEmpty';\nimport { matrixMinMaxZ } from './matrixMinMaxZ';\n/**\n * Rescale a matrix between min and max values.\n * @param matrix - matrix [rows][cols].\n * @param options - Options.\n */\nexport function matrixZRescale(matrix, options = {}) {\n    const { min = 0, max = 1, ArrayConstructor } = options;\n    const nbColumns = matrix[0].length;\n    const nbRows = matrix.length;\n    const newMatrix = matrixCreateEmpty({ nbColumns, nbRows, ArrayConstructor });\n    const { min: currentMin, max: currentMax } = matrixMinMaxZ(matrix);\n    const factor = (max - min) / (currentMax - currentMin);\n    for (let column = 0; column < nbColumns; column++) {\n        for (let row = 0; row < nbRows; row++) {\n            newMatrix[row][column] =\n                (matrix[row][column] - currentMin) * factor + min;\n        }\n    }\n    return newMatrix;\n}\n//# sourceMappingURL=matrixZRescale.js.map","import { matrixCreateEmpty } from './matrixCreateEmpty';\n/**\n * Rescale the matrix per column for which we get the min and max values.\n * @param matrix - matrix [rows][cols].\n * @param options - Options.\n */\nexport function matrixZRescalePerColumn(matrix, options = {}) {\n    const { min = 0, max = 1 } = options;\n    const nbColumns = matrix[0].length;\n    const nbRows = matrix.length;\n    const newMatrix = matrixCreateEmpty({ nbColumns, nbRows });\n    for (let column = 0; column < nbColumns; column++) {\n        let currentMin = matrix[0][column];\n        let currentMax = matrix[0][column];\n        for (let row = 1; row < nbRows; row++) {\n            if (matrix[row][column] < currentMin)\n                currentMin = matrix[row][column];\n            if (matrix[row][column] > currentMax)\n                currentMax = matrix[row][column];\n        }\n        const factor = (max - min) / (currentMax - currentMin);\n        for (let row = 0; row < nbRows; row++) {\n            newMatrix[row][column] =\n                (matrix[row][column] - currentMin) * factor + min;\n        }\n    }\n    return newMatrix;\n}\n//# sourceMappingURL=matrixZRescalePerColumn.js.map","import { xAbsolute } from './xAbsolute';\nimport { xMedian } from './xMedian';\n/**\n * This function calculates the median after taking the xAbsolute values of the points.\n * @param array - the array for which we want to calculate the absolute value\n * @returns - median\n */\nexport function xAbsoluteMedian(array) {\n    return xMedian(xAbsolute(array));\n}\n//# sourceMappingURL=xAbsoluteMedian.js.map","import { xCrossCorrelation } from './xCrossCorrelation';\n/**\n * Calculates the auto-correlation of an array\n * @param A - the array for which to calculate the auto-correlation\n * @param options - Options\n */\nexport function xAutoCorrelation(A, options = {}) {\n    return xCrossCorrelation(A, A, options);\n}\n//# sourceMappingURL=xAutoCorrelation.js.map","import { xBoxPlotWithOutliers } from './xBoxPlotWithOutliers';\nimport { xMean } from './xMean';\nimport { xStandardDeviation } from './xStandardDeviation';\n/**\n * Calculate distribution statistics of an array without providing options\n * This ensure that the statistics are calculated in the same way in all the packages\n * If the array is empty it will throw an error\n * If the array has a length of 1, sd will be NaN (unbiased calculation of sd)\n * @param array - data\n * @param options\n * @returns - q1, median, q3, min, max\n */\nexport function xDistributionStats(array) {\n    return {\n        ...xBoxPlotWithOutliers(array),\n        mean: xMean(array),\n        sd: xStandardDeviation(array),\n        nb: array.length,\n    };\n}\n//# sourceMappingURL=xDistributionStats.js.map","import { xCheck } from './xCheck';\nimport { xGetFromToIndex } from './xGetFromToIndex';\n/**\n * Computes the maximal value of an array of values\n * @param array - array of numbers\n * @param options - options\n */\nexport function xMaxAbsoluteValue(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] >= 0) {\n            if (array[i] > maxValue) {\n                maxValue = array[i];\n            }\n        }\n        else if (-array[i] > maxValue) {\n            maxValue = -array[i];\n        }\n    }\n    return maxValue;\n}\n//# sourceMappingURL=xMaxAbsoluteValue.js.map","import { xCheck } from './xCheck';\nimport { xGetFromToIndex } from './xGetFromToIndex';\n/**\n * Computes the index of the maximum of the given values\n * @param array - array of numbers\n * @param  options - options\n * @returns - index\n */\nexport function xMaxIndex(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let maxIndex = fromIndex;\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        if (array[i] > array[maxIndex]) {\n            maxIndex = i;\n        }\n    }\n    return maxIndex;\n}\n//# sourceMappingURL=xMaxIndex.js.map","import { xCheckLengths } from './xCheckLengths';\n/**\n * This function calculates the mean absolute error.\n * @param array1 - first array\n * @param array2 - second array\n */\nexport function xMeanAbsoluteError(array1, array2) {\n    xCheckLengths(array1, array2);\n    let sum = 0;\n    for (let i = 0; i < array1.length; i++) {\n        sum += Math.abs(array1[i] - array2[i]);\n    }\n    return sum / array1.length;\n}\n//# sourceMappingURL=xMeanAbsoluteError.js.map","import { xCheckLengths } from './xCheckLengths';\n/**\n * This function calculates the mean squared error.\n * @param array1 -first array\n * @param array2 - second array\n */\nexport function xMeanSquaredError(array1, array2) {\n    xCheckLengths(array1, array2);\n    let sum = 0;\n    for (let i = 0; i < array1.length; i++) {\n        sum += (array1[i] - array2[i]) ** 2;\n    }\n    return sum / array1.length;\n}\n//# sourceMappingURL=xMeanSquaredError.js.map","import { xCheck } from './xCheck';\nimport { xGetFromToIndex } from './xGetFromToIndex';\n/**\n * Computes the weighted mean value of an array of values.\n * @deprecated please use xyMassCenter\n * @param array - array of numbers\n * @param weights - array of weights\n * @param options - options\n */\nexport function xMeanWeighted(array, weights, options = {}) {\n    xCheck(array, { minLength: 1 });\n    xCheck(weights);\n    if (array.length !== weights.length) {\n        throw new Error('array and weights must have the same length');\n    }\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    // normalize weights\n    let sumWeights = 0;\n    let sumValue = array[fromIndex] * weights[fromIndex];\n    sumWeights += weights[fromIndex];\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        sumValue += array[i] * weights[i];\n        sumWeights += weights[i];\n    }\n    if (sumWeights === 0) {\n        // We throw because the case is not well defined\n        throw new Error('sum of weights must be > 0');\n    }\n    return sumValue / sumWeights;\n}\n//# sourceMappingURL=xMeanWeighted.js.map","import { xCheck } from './xCheck';\nimport { xGetFromToIndex } from './xGetFromToIndex';\n/**\n * Computes the index of the minimum of the given values.\n * @param array - array of numbers\n * @param options - options\n * @returns - index\n */\nexport function xMinIndex(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let minIndex = fromIndex;\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        if (array[i] < array[minIndex]) {\n            minIndex = i;\n        }\n    }\n    return minIndex;\n}\n//# sourceMappingURL=xMinIndex.js.map","import { xCheck } from './xCheck';\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 xMinMaxDelta(array) {\n    xCheck(array, {\n        minLength: 2,\n    });\n    let minDelta = array[1] - array[0];\n    let maxDelta = minDelta;\n    for (let i = 0; i < array.length - 1; i++) {\n        const delta = array[i + 1] - array[i];\n        if (delta < minDelta)\n            minDelta = delta;\n        if (delta > maxDelta)\n            maxDelta = delta;\n    }\n    return { min: minDelta, max: maxDelta };\n}\n//# sourceMappingURL=xMinMaxDelta.js.map","/**\n * Calculates the mode of an array\n * @param input - Array containing values\n * @returns - mode\n */\nexport function xMode(input) {\n    if (input.length === 0) {\n        throw new TypeError('input must not be empty');\n    }\n    let maxValue = 0;\n    let maxCount = 0;\n    let count = 0;\n    const counts = {};\n    for (let i = 0; i < input.length; ++i) {\n        const element = input[i];\n        count = counts[element];\n        if (count) {\n            counts[element]++;\n            count++;\n        }\n        else {\n            counts[element] = 1;\n            count = 1;\n        }\n        if (count > maxCount) {\n            maxCount = count;\n            maxValue = input[i];\n        }\n    }\n    return maxValue;\n}\n//# sourceMappingURL=xMode.js.map","import { isAnyArray } from 'is-any-array';\nimport { xBoxPlot } from './xBoxPlot';\n/**\n * Remove the outliers from the array\n * Based on 1.5 IQR\n * @param array - data\n * @returns - trimmed data\n */\nexport function xRemoveOutliersIQR(array) {\n    if (!isAnyArray(array)) {\n        throw new TypeError('input must be an array');\n    }\n    if (array.length === 0) {\n        return array;\n    }\n    const boxPlot = xBoxPlot(array);\n    const iqr = boxPlot.q3 - boxPlot.q1;\n    const lowerWhisker = boxPlot.q1 - 1.5 * iqr;\n    const higherWhisker = boxPlot.q3 + 1.5 * iqr;\n    if (boxPlot.min >= lowerWhisker && boxPlot.max <= higherWhisker) {\n        return array;\n    }\n    const filteredArray = [];\n    for (const element of array) {\n        if (element >= lowerWhisker && element <= higherWhisker) {\n            filteredArray.push(element);\n        }\n    }\n    return filteredArray;\n}\n//# sourceMappingURL=xRemoveOutliersIQR.js.map","import { xBoxPlotWithOutliers } from './xBoxPlotWithOutliers';\nimport { xMean } from './xMean';\nimport { xStandardDeviation } from './xStandardDeviation';\n/**\n * Calculate distribution statistics of an array without providing options. Statistics\n * like sd and mean are calculated after removing outliers.\n * This ensure that the statistics are calculated in the same way in all the packages\n * If the array is empty it will throw an error\n * If the array has a length of 1, sd will be NaN (unbiased calculation of sd)\n * @param array - data\n * @param options\n * @returns - q1, median, q3, min, max\n */\nexport function xRobustDistributionStats(array) {\n    const boxPlot = xBoxPlotWithOutliers(array);\n    let filteredArray;\n    if (boxPlot.outliers.length === 0) {\n        filteredArray = array;\n    }\n    else {\n        filteredArray = new Float64Array(array.length - boxPlot.outliers.length);\n        let j = 0;\n        for (const element of array) {\n            if (element >= boxPlot.min && element <= boxPlot.max) {\n                filteredArray[j++] = element;\n            }\n        }\n    }\n    return {\n        ...boxPlot,\n        mean: xMean(filteredArray),\n        sd: xStandardDeviation(filteredArray),\n        nb: filteredArray.length,\n    };\n}\n//# sourceMappingURL=xRobustDistributionStats.js.map","import { xMaxValue } from './xMaxValue';\nimport { xRolling } from './xRolling';\n/**\n * This function calculates a maximum within a rolling window\n * @param array - array\n * @param options - options\n */\nexport function xRollingMax(array, options = {}) {\n    return xRolling(array, xMaxValue, options);\n}\n//# sourceMappingURL=xRollingMax.js.map","import { xMinValue } from './xMinValue';\nimport { xRolling } from './xRolling';\n/**\n * This function calculates a minimum within a rolling window\n * @param array - array\n * @param options - options\n */\nexport function xRollingMin(array, options = {}) {\n    return xRolling(array, xMinValue, options);\n}\n//# sourceMappingURL=xRollingMin.js.map","import { xCheck } from './xCheck';\n/**\n * Sample within the array\n * @param array - array from which to sample\n * @param options - options\n * @returns - array with evenly spaced elements\n * @link https://en.wikipedia.org/wiki/Sampling_(signal_processing)\n */\nexport function xSampling(array, options = {}) {\n    const { length = 10 } = options;\n    xCheck(array);\n    if (length === array.length) {\n        return Float64Array.from(array);\n    }\n    else if (length > array.length) {\n        throw new RangeError('length must be smaller than the array length');\n    }\n    else {\n        return downSampling(array, length);\n    }\n}\n/**\n * Downsample within the array\n * @param array - array from which to sample\n * @param length\n * @returns - array with evenly spaced elements\n * @link https://en.wikipedia.org/wiki/Downsampling_(signal_processing)\n */\nfunction downSampling(array, length) {\n    const returnArray = new Float64Array(length);\n    const delta = (array.length - 1) / (length - 1);\n    for (let i = 0; i < length; i++) {\n        returnArray[i] = array[Math.round(i * delta)];\n    }\n    return returnArray;\n}\n//# sourceMappingURL=xSampling.js.map","import { xSequentialFillFromStep } from './xSequentialFillFromStep';\nexport function xSequentialFillFromTo(parameters, options = {}) {\n    const { from, to, size } = parameters;\n    const step = (to - from) / (size - 1);\n    return xSequentialFillFromStep({ from, step, size }, options);\n}\n//# sourceMappingURL=xSequentialFillFromTo.js.map","/**\n * Function that sorts arrays or Float64Arrays in ascending order in place !\n * This method is optimized for typed arrays.\n * @param array - array to sort\n * @returns sorted array\n */\nexport function xSortAscending(array) {\n    if (ArrayBuffer.isView(array)) {\n        return array.sort();\n    }\n    else if (Array.isArray(array)) {\n        return array.sort((a, b) => a - b);\n    }\n    throw new Error('trying to sort non array');\n}\n//# sourceMappingURL=xSortAscending.js.map","/**\n * XUniqueSorted.\n * @param array - array of numbers\n * @returns - sorted array\n */\nexport function xUniqueSorted(array) {\n    return Float64Array.from(new Set(array)).sort();\n}\n//# sourceMappingURL=xUniqueSorted.js.map","/**\n * Sort object of array, x has to be monotone.\n * @param data - object of kind {x:[], re:[], im:[]}\n * @returns - sorted array\n */\nexport function xreimSortX(data) {\n    const { x, re, im } = data;\n    if (x.length !== re.length || x.length !== im.length) {\n        throw new TypeError('length of x, re and im must be identical');\n    }\n    if (x.length < 2 || x[0] < x[1])\n        return data;\n    return {\n        x: x.slice(0).reverse(),\n        re: re.slice(0).reverse(),\n        im: im.slice(0).reverse(),\n    };\n}\n//# sourceMappingURL=xreimSortX.js.map","import { reimZeroFilling } from '../reim';\n/**\n * This function make a zero filling to re and im part.\n * @param data - object of kind {x:[], re:[], im:[]}\n * @param totalLength - final number of points\n * @returns - data.\n */\nexport function xreimZeroFilling(data, totalLength) {\n    const { x, re, im } = data;\n    const length = x.length;\n    if (totalLength === 0 || length === totalLength)\n        return data;\n    if (length > totalLength) {\n        return {\n            x: x.slice(0, totalLength),\n            re: re.slice(0, totalLength),\n            im: im.slice(0, totalLength),\n        };\n    }\n    const newX = new Float64Array(totalLength);\n    newX.set(x);\n    const deltaX = (x.at(-1) - x[0]) / (length - 1);\n    for (let i = length; i < totalLength; i++) {\n        newX[i] = newX[i - 1] + deltaX;\n    }\n    return {\n        x: newX,\n        ...reimZeroFilling({ re, im }, totalLength),\n    };\n}\n//# sourceMappingURL=xreimZeroFilling.js.map","/**\n * Convert an array of XY arrays to a DataXY object containing x,y arrays\n * @param data - array of arrays [[x,y],[x,y],...]\n */\nexport function xy2ToXY(data) {\n    const xy2 = { x: [], y: [] };\n    for (const xyValue of data) {\n        xy2.x.push(xyValue[0]);\n        xy2.y.push(xyValue[1]);\n    }\n    return xy2;\n}\n//# sourceMappingURL=xy2ToXY.js.map","/**\n * Align data of two spectra by verifying wether x values are in a certain range (`delta`).\n * The two spectra should not have two consecutive x values which difference is\n * smaller than `delta` to achieve good results!\n * @param data1 - First spectrum data\n * @param data2 - Second spectrum data\n * @param options - Options\n */\nexport function xyAlign(data1, data2, options = {}) {\n    const { delta = 1, common = true, x = 'x1' } = options;\n    const result = {\n        x: [],\n        y1: [],\n        y2: [],\n    };\n    let i = 0;\n    let j = 0;\n    const length1 = data1.x.length;\n    const length2 = data2.x.length;\n    while (i < length1 && j < length2) {\n        let maxDiff = 0;\n        if (typeof delta === 'function') {\n            const mean = (data1.x[i] + data2.x[j]) / 2; // is this a good thing to do?\n            maxDiff = delta(mean);\n        }\n        else {\n            maxDiff = delta;\n        }\n        const difference = data1.x[i] - data2.x[j];\n        if (Math.abs(difference) > maxDiff) {\n            if (difference > 0) {\n                if (!common) {\n                    result.x.push(data2.x[j]);\n                    result.y1.push(0);\n                    result.y2.push(data2.y[j]);\n                    if (j === length2 - 1) {\n                        while (i < length1) {\n                            result.x.push(data1.x[i]);\n                            result.y1.push(data1.y[i]);\n                            result.y2.push(0);\n                            i++;\n                        }\n                    }\n                }\n                j++;\n            }\n            else {\n                if (!common) {\n                    result.x.push(data1.x[i]);\n                    result.y1.push(data1.y[i]);\n                    result.y2.push(0);\n                    if (i === length1 - 1) {\n                        while (j < length2) {\n                            result.x.push(data2.x[j]);\n                            result.y1.push(0);\n                            result.y2.push(data2.y[j]);\n                            j++;\n                        }\n                    }\n                }\n                i++;\n            }\n        }\n        else {\n            const weightedX = (data1.x[i] * data1.y[i] + data2.x[j] * data2.y[j]) /\n                (data1.y[i] + data2.y[j]);\n            switch (x) {\n                case 'x1':\n                    result.x.push(data1.x[i]);\n                    break;\n                case 'x2':\n                    result.x.push(data2.x[j]);\n                    break;\n                case 'weighted':\n                    result.x.push(weightedX);\n                    break;\n                default:\n                    throw new Error(`unknown x option value: ${String(x)}`);\n            }\n            result.y1.push(data1.y[i]);\n            result.y2.push(data2.y[j]);\n            i++;\n            j++;\n        }\n    }\n    return result;\n}\n//# sourceMappingURL=xyAlign.js.map","import { xyJoinX } from '../xy';\nimport { getSlots } from './utils/getSlots';\n/**\n * Aligns data, can be used for spectra\n * @param data - data\n * @param options - Options\n */\nexport function xyArrayAlign(data, options = {}) {\n    const { delta = 1, requiredY = false } = options;\n    data = data.map((spectrum) => xyJoinX(spectrum, { delta }));\n    const slots = getSlots(data, { delta });\n    const x = Float64Array.from(slots.map((slot) => slot.average));\n    const ys = Array.from(data, () => new Float64Array(x.length));\n    const positions = new Uint32Array(data.length);\n    for (let i = 0; i < slots.length; i++) {\n        const slot = slots[i];\n        for (let j = 0; j < data.length; j++) {\n            const spectrum = data[j];\n            while (positions[j] < spectrum.x.length &&\n                spectrum.x[positions[j]] <= slot.to) {\n                ys[j][i] += spectrum.y[positions[j]];\n                positions[j]++;\n            }\n        }\n    }\n    if (requiredY)\n        return filterRequiredY(x, ys);\n    return { x, ys };\n}\nfunction filterRequiredY(x, ys) {\n    const newX = [];\n    const newYs = Array.from(ys, () => []);\n    for (let i = 0; i < x.length; i++) {\n        if (ys.every((y) => y[i] !== 0)) {\n            newX.push(x[i]);\n            for (let j = 0; j < ys.length; j++) {\n                newYs[j].push(ys[j][i]);\n            }\n        }\n    }\n    return { x: newX, ys: newYs };\n}\n//# sourceMappingURL=xyArrayAlign.js.map","import { getSlotsToFirst } from './utils/getSlotsToFirst';\n/**\n * We align all the data/spectra to the first array of X.\n * The alignment is based on the X values of the first spectrum and the `delta` error allowed.\n * If some x values are missing in the first spectrum we will add them\n * @param data - data\n * @param options - options\n */\nexport function xyArrayAlignToFirst(data, options = {}) {\n    const { delta = 1 } = options;\n    const slots = getSlotsToFirst(data, { delta });\n    const x = Float64Array.from(slots.map((slot) => slot.value));\n    const ys = Array.from(data, () => new Float64Array(x.length));\n    const positions = new Uint32Array(data.length);\n    for (let i = 0; i < slots.length; i++) {\n        const slot = slots[i];\n        for (let j = 0; j < data.length; j++) {\n            const spectrum = data[j];\n            while (positions[j] < spectrum.x.length &&\n                spectrum.x[positions[j]] < slot.to) {\n                ys[j][i] += spectrum.y[positions[j]];\n                positions[j]++;\n            }\n        }\n    }\n    return { x, ys };\n}\n//# sourceMappingURL=xyArrayAlignToFirst.js.map","import { xyArrayWeightedMerge } from '../xyArrayWeightedMerge';\n/**\n * GetSlotsToFirst.\n * @param data - data.\n * @param options - Options.\n */\nexport function getSlotsToFirst(data, options = {}) {\n    const { delta = 1 } = options;\n    const deltaIsFunction = typeof delta === 'function';\n    const firstXs = data[0].x;\n    const slots = [];\n    // we first create the slots based on the first spectrum\n    for (const element of firstXs) {\n        const currentDelta = deltaIsFunction ? delta(element) : delta;\n        slots.push({\n            from: element - currentDelta,\n            to: element + currentDelta,\n            value: element,\n        });\n    }\n    const otherXs = xyArrayWeightedMerge(data.slice(1), options).x;\n    let currentPosition = 0;\n    for (const slot of slots) {\n        while (otherXs[currentPosition] < slot.to &&\n            currentPosition < otherXs.length) {\n            if (otherXs[currentPosition] < slot.from) {\n                const currentDelta = deltaIsFunction\n                    ? delta(otherXs[currentPosition])\n                    : delta;\n                slots.push({\n                    from: otherXs[currentPosition] - currentDelta,\n                    to: otherXs[currentPosition] + currentDelta,\n                    value: otherXs[currentPosition],\n                });\n            }\n            currentPosition++;\n        }\n    }\n    for (let i = currentPosition; i < otherXs.length; i++) {\n        const currentDelta = deltaIsFunction ? delta(otherXs[i]) : delta;\n        slots.push({\n            from: otherXs[i] - currentDelta,\n            to: otherXs[i] + currentDelta,\n            value: otherXs[i],\n        });\n    }\n    slots.sort((a, b) => a.value - b.value);\n    // we prevent slots overlap in the first spectrum\n    for (let i = 0; i < slots.length - 1; i++) {\n        if (slots[i].to > slots[i + 1].from) {\n            const middle = (slots[i].value + slots[i + 1].value) / 2;\n            slots[i].to = middle;\n            slots[i + 1].from = middle;\n        }\n    }\n    return slots;\n}\n//# sourceMappingURL=getSlotsToFirst.js.map","import { xyJoinX } from '../xy';\nimport { getSlots } from './utils/getSlots';\n/**\n * Merge DataXY\n * We have an array of DataXY and the goal is to merge all the values that are the closest possible\n * @param data - data\n * @param options - Options\n */\nexport function xyArrayMerge(data, options = {}) {\n    const { delta = 1 } = options;\n    // We start by checking that the data/spectra don't have peaks too close and we simplify them.\n    data = data.map((spectrum) => xyJoinX(spectrum, { delta }));\n    // At first, we will calculate the X values (simple mean).\n    const slots = getSlots(data, { delta });\n    const x = Float64Array.from(slots.map((slot) => slot.average));\n    const y = new Float64Array(x.length);\n    const positions = new Uint32Array(data.length);\n    for (let i = 0; i < slots.length; i++) {\n        const slot = slots[i];\n        for (let j = 0; j < data.length; j++) {\n            const spectrum = data[j];\n            while (positions[j] < spectrum.x.length &&\n                spectrum.x[positions[j]] <= slot.to) {\n                y[i] += spectrum.y[positions[j]];\n                positions[j]++;\n            }\n        }\n    }\n    return { x, y };\n}\n//# sourceMappingURL=xyArrayMerge.js.map","import { xMean } from '../x';\n/**\n * Finds the covariance of the points.\n * @param data\n * @param options\n * @returns the covariance\n */\nexport function xyCovariance(data, options = {}) {\n    const { x, y } = data;\n    const { unbiased = true } = options;\n    const meanX = xMean(x);\n    const meanY = xMean(y);\n    let error = 0;\n    for (let i = 0; i < x.length; i++) {\n        error += (x[i] - meanX) * (y[i] - meanY);\n    }\n    if (unbiased) {\n        return error / (x.length - 1);\n    }\n    else {\n        return error / x.length;\n    }\n}\n//# sourceMappingURL=xyCovariance.js.map","import { xEnsureFloat64 } from '../x';\nexport function xyEnsureFloat64(data) {\n    return {\n        x: xEnsureFloat64(data.x),\n        y: xEnsureFloat64(data.y),\n    };\n}\n//# sourceMappingURL=xyEnsureFloat64.js.map","import { zonesNormalize } from '../zones';\nimport { xyCheck } from './xyCheck';\n/**\n * Extract zones from a XY data.\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - options\n * @returns - Array of points\n */\nexport function xyExtract(data, options = {}) {\n    xyCheck(data);\n    const { x, y } = data;\n    let { zones } = options;\n    zones = zonesNormalize(zones);\n    if (x === undefined ||\n        y === undefined ||\n        !Array.isArray(zones) ||\n        zones.length === 0) {\n        return data;\n    }\n    const newX = [];\n    const newY = [];\n    let currentZone = zones[0];\n    let position = 0;\n    loop: for (let i = 0; i < x.length; i++) {\n        while (currentZone.to < x[i]) {\n            position++;\n            currentZone = zones[position];\n            if (!currentZone) {\n                i = x.length;\n                break loop;\n            }\n        }\n        if (x[i] >= currentZone.from) {\n            newX.push(x[i]);\n            newY.push(y[i]);\n        }\n    }\n    return { x: newX, y: newY };\n}\n//# sourceMappingURL=xyExtract.js.map","/**\n * Filter an array x/y based on various criteria x points are expected to be sorted\n * @param data - object containing 2 properties x and y\n * @param options - options\n * @returns filtered array\n */\nexport function xyFilter(data, options = {}) {\n    const { x, y } = data;\n    const { filter } = options;\n    const newX = [];\n    const newY = [];\n    for (let i = 0; i < x.length; i++) {\n        if (!filter || filter(x[i], y[i])) {\n            newX.push(x[i]);\n            newY.push(y[i]);\n        }\n    }\n    return {\n        x: newX,\n        y: newY,\n    };\n}\n//# sourceMappingURL=xyFilter.js.map","import { xMinMaxValues } from '../x';\n/**\n * Filter an array x/y based on various criteria x points are expected to be sorted\n * @param data - object containing 2 properties x and y\n * @param minRelativeYValue - the minimum relative value compare to the Y max value\n * @returns filtered data\n */\nexport function xyFilterMinYValue(data, minRelativeYValue) {\n    if (minRelativeYValue === undefined)\n        return data;\n    const { x, y } = data;\n    const { min, max } = xMinMaxValues(y);\n    const threshold = max * minRelativeYValue;\n    if (min >= threshold)\n        return data;\n    const newX = [];\n    const newY = [];\n    for (let i = 0; i < x.length; i++) {\n        if (y[i] >= threshold) {\n            newX.push(x[i]);\n            newY.push(y[i]);\n        }\n    }\n    return {\n        x: newX,\n        y: newY,\n    };\n}\n//# sourceMappingURL=xyFilterMinYValue.js.map","import { xSortDescending } from '../x';\n/**\n * Filter an array x/y based on various criteria x points are expected to be sorted\n * @param data - object containing 2 properties x and y\n * @param nbPeaks\n * @returns filtered data\n */\nexport function xyFilterTopYValues(data, nbPeaks) {\n    if (nbPeaks === undefined)\n        return data;\n    if (nbPeaks > data.x.length)\n        return data;\n    const { x, y } = data;\n    const newX = [];\n    const newY = [];\n    const descending = xSortDescending(y.slice());\n    const threshold = descending[nbPeaks - 1];\n    let nbThreshold = 0;\n    for (let i = 0; i < nbPeaks; i++) {\n        if (descending[i] === threshold) {\n            nbThreshold++;\n        }\n    }\n    for (let i = 0; i < x.length; i++) {\n        if (y[i] > threshold) {\n            newX.push(x[i]);\n            newY.push(y[i]);\n        }\n        else if (y[i] === threshold) {\n            nbThreshold--;\n            if (nbThreshold >= 0) {\n                newX.push(x[i]);\n                newY.push(y[i]);\n            }\n        }\n    }\n    return {\n        x: newX,\n        y: newY,\n    };\n}\n//# sourceMappingURL=xyFilterTopYValues.js.map","import { xFindClosestIndex } from '../x';\n/**\n * Finds the closest point\n * @param data - x array should be sorted and ascending\n * @param target - target to search\n * @returns - closest point\n */\nexport function xyFindClosestPoint(\n/** points */\ndata, target) {\n    const { x, y } = data;\n    const index = xFindClosestIndex(x, target);\n    return {\n        x: x[index],\n        y: y[index],\n    };\n}\n//# sourceMappingURL=xyFindClosestPoint.js.map","import { xyCheck } from './xyCheck';\n/**\n * Returns the numberMaxPoints points with the bigger y.\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param numberMaxPoints - Number of points to keep\n * @returns - The points filtered to keep the `numberMaxPoints` most intense points of the input.\n */\nexport function xyGetNMaxY(data, numberMaxPoints) {\n    xyCheck(data);\n    if (data.x.length <= numberMaxPoints) {\n        return data;\n    }\n    else {\n        const newX = new Float64Array(numberMaxPoints);\n        const newY = new Float64Array(numberMaxPoints);\n        // slice() is used to make a copy of the array, because sort() is IPM\n        const threshold = Float64Array.from(data.y).sort().reverse()[numberMaxPoints - 1];\n        let index = 0;\n        for (let i = 0; i < data.x.length; i++) {\n            if (data.y[i] >= threshold) {\n                newX[index] = data.x[i];\n                newY[index] = data.y[i];\n                index++;\n            }\n            if (index === numberMaxPoints) {\n                return { x: newX, y: newY };\n            }\n        }\n        return data;\n    }\n}\n//# sourceMappingURL=xyGetNMaxY.js.map","import { xGetFromToIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Generate a X / Y of the xyIntegral\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - Options\n * @returns - An object with the xyIntegration function\n */\nexport function xyIntegral(data, options = {}) {\n    const { reverse = false } = options;\n    xyCheck(data, { minLength: 1 });\n    const { x, y } = data;\n    const { fromIndex, toIndex } = xGetFromToIndex(x, options);\n    let xyIntegration = 0;\n    const currentxyIntegral = {\n        x: new Float64Array(toIndex - fromIndex + 1),\n        y: new Float64Array(toIndex - fromIndex + 1),\n    };\n    let index = 0;\n    if (reverse) {\n        currentxyIntegral.y[index] = 0;\n        currentxyIntegral.x[index++] = x[toIndex];\n        for (let i = toIndex; i > fromIndex; i--) {\n            xyIntegration += ((x[i] - x[i - 1]) * (y[i - 1] + y[i])) / 2;\n            currentxyIntegral.x[index] = x[i - 1];\n            currentxyIntegral.y[index++] = xyIntegration;\n        }\n        currentxyIntegral.x.reverse();\n        currentxyIntegral.y.reverse();\n    }\n    else {\n        currentxyIntegral.y[index] = 0;\n        currentxyIntegral.x[index++] = x[fromIndex];\n        for (let i = fromIndex; i < toIndex; i++) {\n            xyIntegration += ((x[i + 1] - x[i]) * (y[i + 1] + y[i])) / 2;\n            currentxyIntegral.x[index] = x[i + 1];\n            currentxyIntegral.y[index++] = xyIntegration;\n        }\n    }\n    return currentxyIntegral;\n}\n//# sourceMappingURL=xyIntegral.js.map","import { xGetFromToIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Calculate integration\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - Options\n * @returns - xyIntegration value on the specified range\n */\nexport function xyIntegration(data, options = {}) {\n    xyCheck(data, { minLength: 1 });\n    const { x, y } = data;\n    if (x.length === 1)\n        return 0;\n    const { fromIndex, toIndex } = xGetFromToIndex(x, options);\n    let currentxyIntegration = 0;\n    for (let i = fromIndex; i < toIndex; i++) {\n        currentxyIntegration += ((x[i + 1] - x[i]) * (y[i + 1] + y[i])) / 2;\n    }\n    return currentxyIntegration;\n}\n//# sourceMappingURL=xyIntegration.js.map","import { xGetFromToIndex } from '../x/xGetFromToIndex';\nimport { xyCheck } from './xyCheck';\n/**\n * Computes the weighted mean value of an array of values.\n * @param data - array of DataXY\n * @param options - options\n */\nexport function xyMassCenter(data, options = {}) {\n    xyCheck(data, { minLength: 1 });\n    const { x, y } = data;\n    const { fromIndex, toIndex } = xGetFromToIndex(x, options);\n    let sumYs = 0;\n    let sumProducts = 0;\n    for (let i = fromIndex; i <= toIndex; i++) {\n        sumProducts += x[i] * y[i];\n        sumYs += y[i];\n    }\n    if (sumYs === 0) {\n        throw new Error('Sum of Ys can not be zero.');\n    }\n    return sumProducts / sumYs;\n}\n//# sourceMappingURL=xyMassCenter.js.map","import { xFindClosestIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * We will calculate a vector containing center of mass of DataXY as well as center of mass of both parts, etc.\n * This approach allows to efficiently represent spectra like XPS, NMR, etc. It should provide an extremely efficient\n * way to store and search similar spectra.\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options\n * @returns - Array of centers of mass\n */\nexport function xyMassCenterVector(data, options = {}) {\n    xyCheck(data, { minLength: 2 });\n    const { depth = 5 } = options;\n    const { weightedIntegral, integral } = getWeightedIntegral(data);\n    const results = new Float64Array((1 << depth) - 1);\n    const endIndexes = new Int32Array((1 << depth) - 1);\n    endIndexes[0] = data.x.length - 1;\n    const beginIndexes = new Int32Array((1 << depth) - 1);\n    beginIndexes[0] = -1;\n    let index = 0;\n    for (let i = 0; i < depth; i++) {\n        for (let j = 0; j < 1 << i; j++) {\n            const currentBeginIndex = beginIndexes[index];\n            const currentEndIndex = endIndexes[index];\n            const currentIntegration = currentBeginIndex === -1\n                ? integral[currentEndIndex]\n                : integral[currentEndIndex] - integral[currentBeginIndex];\n            // we need to solve the issue of null integration (rather in simulated spectra).\n            let x = 0;\n            if (currentIntegration !== 0) {\n                x =\n                    currentBeginIndex === -1\n                        ? weightedIntegral[currentEndIndex] / currentIntegration\n                        : (weightedIntegral[currentEndIndex] -\n                            weightedIntegral[currentBeginIndex]) /\n                            currentIntegration;\n            }\n            else {\n                x = (data.x[currentEndIndex] + data.x[currentBeginIndex]) / 2;\n            }\n            results[index++] = x;\n            // we can now prepare the next level\n            if (i < depth - 1) {\n                const nextIndex = (1 << (i + 1)) + j * 2 - 1;\n                let middleIndex = xFindClosestIndex(data.x, x);\n                if (middleIndex === currentBeginIndex) {\n                    middleIndex++;\n                }\n                beginIndexes[nextIndex] = currentBeginIndex;\n                endIndexes[nextIndex] = middleIndex;\n                if (middleIndex === currentEndIndex) {\n                    middleIndex--;\n                }\n                beginIndexes[nextIndex + 1] = middleIndex;\n                endIndexes[nextIndex + 1] = currentEndIndex;\n            }\n        }\n    }\n    return results;\n}\nfunction getWeightedIntegral(data) {\n    const { x, y } = data;\n    const weightedIntegral = new Float64Array(x.length);\n    const integral = new Float64Array(x.length);\n    // the first point, no points before\n    const firstIntegration = (x[1] - x[0]) * y[0];\n    let totalIntegration = firstIntegration;\n    integral[0] = totalIntegration;\n    let totalWeightedIntegral = firstIntegration * x[0];\n    weightedIntegral[0] = totalWeightedIntegral;\n    for (let i = 1; i < x.length - 1; i++) {\n        const currentIntegration = ((x[i + 1] - x[i - 1]) * y[i]) / 2;\n        const currentX = x[i];\n        totalIntegration += currentIntegration;\n        integral[i] = totalIntegration;\n        totalWeightedIntegral += currentIntegration * currentX;\n        weightedIntegral[i] = totalWeightedIntegral;\n    }\n    // the last point, no points after\n    const lastIntegration = (x.at(-1) - x.at(-2)) * y.at(-1);\n    totalIntegration += lastIntegration;\n    integral[x.length - 1] = totalIntegration;\n    totalWeightedIntegral += lastIntegration * x.at(-1);\n    weightedIntegral[x.length - 1] = totalWeightedIntegral;\n    return { integral, weightedIntegral };\n}\n//# sourceMappingURL=xyMassCenterVector.js.map","import { xFindClosestIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Find the closest maximum going up hill\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - options\n * @returns - An object with the x/y value\n */\nexport function xyMaxClosestYPoint(data, options = {}) {\n    xyCheck(data);\n    const { x, y } = data;\n    const { target } = options;\n    let { targetIndex } = options;\n    if (targetIndex === undefined) {\n        if (target !== undefined) {\n            targetIndex = xFindClosestIndex(x, target);\n        }\n        else {\n            targetIndex = 0;\n        }\n    }\n    let previousIndex = Number.MIN_SAFE_INTEGER;\n    let currentIndex = targetIndex;\n    let xyMaxY = y[targetIndex];\n    while (currentIndex !== previousIndex) {\n        previousIndex = currentIndex;\n        if (currentIndex > 0 && y[currentIndex - 1] > xyMaxY) {\n            currentIndex--;\n        }\n        else if (currentIndex < x.length - 1 && y[currentIndex + 1] > xyMaxY) {\n            currentIndex++;\n        }\n        xyMaxY = y[currentIndex];\n    }\n    return {\n        x: x[currentIndex],\n        y: y[currentIndex],\n        index: currentIndex,\n    };\n}\n//# sourceMappingURL=xyMaxClosestYPoint.js.map","/**\n * Merge abscissas values on similar ordinates and weight the group of abscissas\n * @param data - object containing 2 properties x and y\n * @param options - options\n * @returns array of merged and weighted points\n */\nexport function xyMaxMerge(data, options = {}) {\n    const { x, y } = data;\n    const { groupWidth = 0.001 } = options;\n    const merged = { x: [], y: [] };\n    const maxAbscissa = { x: [], y: [] };\n    let size = 0;\n    let index = 0;\n    while (index < x.length) {\n        if (size === 0 || x[index] - merged.x[size - 1] > groupWidth) {\n            maxAbscissa.x.push(x[index]);\n            maxAbscissa.y.push(y[index]);\n            merged.x.push(x[index]);\n            merged.y.push(y[index]);\n            index++;\n            size++;\n        }\n        else {\n            if (y[index] > maxAbscissa.y[size - 1]) {\n                maxAbscissa.x[size - 1] = x[index];\n                maxAbscissa.y[size - 1] = y[index];\n            }\n            merged.x[size - 1] = x[index];\n            merged.y[size - 1] += y[index];\n            index++;\n        }\n    }\n    merged.x = maxAbscissa.x.slice();\n    return merged;\n}\n//# sourceMappingURL=xyMaxMerge.js.map","import { xGetFromToIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Finds the max value in a zone\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - Options\n * @returns - Max y on the specified range\n */\nexport function xyMaxY(data, options = {}) {\n    xyCheck(data);\n    const { x, y } = data;\n    const { fromIndex, toIndex } = xGetFromToIndex(x, options);\n    let currentxyMaxY = y[fromIndex];\n    for (let i = fromIndex; i <= toIndex; i++) {\n        if (y[i] > currentxyMaxY)\n            currentxyMaxY = y[i];\n    }\n    return currentxyMaxY;\n}\n//# sourceMappingURL=xyMaxY.js.map","import { xGetFromToIndex } from '../x/xGetFromToIndex';\nimport { xyCheck } from './xyCheck';\n/**\n * Finds all the max values\n * If the values are equal the middle\n * of the equal part will be the position of the signal!\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - Object with from and to properties\n * @returns - Array of points\n */\nexport function xyMaximaY(data, options = {}) {\n    xyCheck(data, { minLength: 2 });\n    const { x, y } = data;\n    const { fromIndex, toIndex } = xGetFromToIndex(x, options);\n    const maxima = [];\n    let startEqualIndex = -1;\n    for (let i = fromIndex + 1; i < toIndex; i++) {\n        if (y[i - 1] < y[i] && y[i + 1] < y[i]) {\n            maxima.push({ x: x[i], y: y[i], index: i });\n        }\n        else if (y[i - 1] < y[i] && y[i + 1] === y[i]) {\n            startEqualIndex = i;\n        }\n        else if (y[i - 1] === y[i] && y[i + 1] < y[i]) {\n            const index = Math.floor((i + startEqualIndex) / 2);\n            maxima.push({ x: x[index], y: y[index], index });\n        }\n    }\n    return maxima;\n}\n//# sourceMappingURL=xyMaximaY.js.map","/**\n * Finds the median x value for an object with properties x and y (arrays of the same length)\n * @param data - x should be sorted in increasing order\n * @returns - the median of x values\n */\nexport function xyMedian(data) {\n    const { x, y } = data;\n    let sumY = 0;\n    let cumSumY = 0;\n    let i;\n    if (x.length === 0) {\n        return Number.NaN;\n    }\n    if (x.length === 1) {\n        return x[0];\n    }\n    for (i = 0; i < y.length; i++) {\n        sumY += y[i];\n    }\n    for (i = 0; i < y.length; i++) {\n        cumSumY += y[i];\n        if (cumSumY > sumY / 2) {\n            return x[i];\n        }\n        else if (cumSumY === sumY / 2) {\n            return 0.5 * (x[i] + x[i + 1]);\n        }\n    }\n    return Number.NaN;\n}\n//# sourceMappingURL=xyMedian.js.map","/**\n * Merge abscissa values if the ordinate value is in a list of centroids\n * @param data - object containing 2 properties x and y\n * @param centroids - centroids\n * @param options - options\n * @returns merged points\n */\nexport function xyMergeByCentroids(data, centroids, options = {}) {\n    const { window = 0.01 } = options;\n    const mergedPoints = {\n        x: Float64Array.from(centroids),\n        y: new Float64Array(centroids.length).fill(0),\n    };\n    let originalIndex = 0;\n    let mergedIndex = 0;\n    while (originalIndex < data.x.length && mergedIndex < centroids.length) {\n        const diff = data.x[originalIndex] - centroids[mergedIndex];\n        if (Math.abs(diff) < window) {\n            mergedPoints.y[mergedIndex] += data.y[originalIndex++];\n        }\n        else if (diff < 0) {\n            originalIndex++;\n        }\n        else {\n            mergedIndex++;\n        }\n    }\n    return mergedPoints;\n}\n//# sourceMappingURL=xyMergeByCentroids.js.map","import { xFindClosestIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Find the closest minimum going down hill\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - Options\n * @returns - An object with the x/y value\n */\nexport function xyMinClosestYPoint(data, options = {}) {\n    xyCheck(data);\n    const { x, y } = data;\n    const { target } = options;\n    let { targetIndex } = options;\n    if (targetIndex === undefined) {\n        if (target !== undefined) {\n            targetIndex = xFindClosestIndex(x, target);\n        }\n        else {\n            targetIndex = 0;\n        }\n    }\n    let previousIndex = Number.MIN_SAFE_INTEGER;\n    let currentIndex = targetIndex;\n    let minY = y[targetIndex];\n    while (currentIndex !== previousIndex) {\n        previousIndex = currentIndex;\n        if (currentIndex > 0 && y[currentIndex - 1] < minY) {\n            currentIndex--;\n        }\n        else if (currentIndex < x.length - 1 && y[currentIndex + 1] < minY) {\n            currentIndex++;\n        }\n        minY = y[currentIndex];\n    }\n    return {\n        x: x[currentIndex],\n        y: y[currentIndex],\n        index: currentIndex,\n    };\n}\n//# sourceMappingURL=xyMinClosestYPoint.js.map","import { xGetFromToIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Finds the min y value in a range and return a {x,y} point\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - Options\n */\nexport function xyMinYPoint(data, options = {}) {\n    xyCheck(data, { minLength: 1 });\n    const { x, y } = data;\n    if (x.length === 1)\n        return { x: x[0], y: y[0], index: 0 };\n    const { fromIndex, toIndex } = xGetFromToIndex(x, options);\n    let current = {\n        x: x[fromIndex],\n        y: y[fromIndex],\n        index: fromIndex,\n    };\n    for (let i = fromIndex; i <= toIndex; i++) {\n        if (y[i] < current.y)\n            current = { x: x[i], y: y[i], index: i };\n    }\n    return current;\n}\n//# sourceMappingURL=xyMinYPoint.js.map","import { xGetFromToIndex } from '../x/xGetFromToIndex';\nimport { xyCheck } from './xyCheck';\n/**\n * Finds all the min values\n * If the values are equal the middle\n * of the equal part will be the position of the signal!\n * @param data - Object that contains property X (an ordered increasing array) and y (an arraY)\n * @param options - Object with from and to properties\n * @returns - Array of points.\n */\nexport function xyMinimaY(data, options = {}) {\n    xyCheck(data, { minLength: 2 });\n    const { x, y } = data;\n    const { fromIndex, toIndex } = xGetFromToIndex(x, options);\n    const maxima = [];\n    let startEqualIndex = -1;\n    for (let i = fromIndex + 1; i < toIndex; i++) {\n        if (y[i - 1] > y[i] && y[i + 1] > y[i]) {\n            maxima.push({ x: x[i], y: y[i], index: i });\n        }\n        else if (y[i - 1] > y[i] && y[i + 1] === y[i]) {\n            startEqualIndex = i;\n        }\n        else if (y[i - 1] === y[i] && y[i + 1] > y[i]) {\n            const index = Math.floor((i + startEqualIndex) / 2);\n            maxima.push({ x: x[index], y: y[index], index });\n        }\n    }\n    return maxima;\n}\n//# sourceMappingURL=xyMinimaY.js.map","import { xyObjectMaxXPoint } from './xyObjectMaxXPoint';\nimport { xyObjectMinXPoint } from './xyObjectMinXPoint';\n/**\n * Filter the array by taking the higher points (max y value) and only.\n * Keep one per slot. There are 2 different slots, the smallest one will have the\n * new property `close` to true\n * @param points - array of all the points\n * @param options - Options\n * @returns - copy of points with 'close' property\n */\nexport function xyObjectBestPoints(points, options = {}) {\n    const { from = xyObjectMinXPoint(points).x, to = xyObjectMaxXPoint(points).x, limit = 20, threshold = 0.01, numberCloseSlots = 50, numberSlots = 10, } = options;\n    const slot = (to - from) / numberSlots;\n    const closeSlot = (to - from) / numberCloseSlots;\n    let selected = points\n        .filter((point) => point.x >= from && point.x <= to)\n        .map((point) => {\n        return {\n            point,\n            monoisotopic: false,\n        };\n    });\n    selected = selected.sort((a, b) => {\n        if (a.monoisotopic && !b.monoisotopic)\n            return -1;\n        if (b.monoisotopic && !a.monoisotopic)\n            return 1;\n        return b.point.y - a.point.y;\n    });\n    const toReturn = [];\n    if (selected.length === 0)\n        return [];\n    const minY = selected[0].point.y * threshold;\n    peakLoop: for (const item of selected) {\n        if (item.point.y < minY) {\n            if (item.monoisotopic) {\n                continue;\n            }\n            else {\n                break;\n            }\n        }\n        let close = false;\n        for (const existing of toReturn) {\n            if (Math.abs(existing.x - item.point.x) < closeSlot) {\n                continue peakLoop;\n            }\n            if (Math.abs(existing.x - item.point.x) < slot) {\n                close = true;\n            }\n        }\n        const newPeak = { ...item.point, close };\n        toReturn.push(newPeak);\n        if (toReturn.length === limit)\n            break;\n    }\n    return toReturn.sort((a, b) => a.x - b.x);\n}\n//# sourceMappingURL=xyObjectBestPoints.js.map","/**\n * xyObjectJoinX.\n * @param points - Array of growing points {x,y}.\n * @param options - Options.\n */\nexport function xyObjectJoinX(points, options = {}) {\n    const { xError = Number.EPSILON } = options;\n    // when we join we will use the center of mass\n    const result = [];\n    let current = {\n        x: Number.MIN_SAFE_INTEGER,\n        y: 0,\n    };\n    for (const point of points) {\n        if (point.x - current.x <= xError) {\n            // weighted sum\n            if (current.y !== 0 || point.y !== 0) {\n                current.x =\n                    (point.y / (current.y + point.y)) * (point.x - current.x) + current.x;\n                current.y += point.y;\n            }\n        }\n        else {\n            current = {\n                x: point.x,\n                y: point.y,\n            };\n            result.push(current);\n        }\n    }\n    return result;\n}\n//# sourceMappingURL=xyObjectJoinX.js.map","import { xyObjectCheck } from './xyObjectCheck';\n/**\n * Finds the max y value and return a {x,y,index} point\n * @param points - Object that contains property x (an ordered increasing array) and y (an array)\n * @returns max point\n */\nexport function xyObjectMaxYPoint(points = []) {\n    xyObjectCheck(points);\n    if (points.length === 0)\n        return { x: 0, y: 0 };\n    let current = {\n        x: points[0].x,\n        y: points[0].y,\n        index: 0,\n    };\n    for (let i = 1; i < points.length; i++) {\n        if (points[i].y > current.y) {\n            current = {\n                x: points[i].x,\n                y: points[i].y,\n                index: i,\n            };\n        }\n    }\n    return current;\n}\n//# sourceMappingURL=xyObjectMaxYPoint.js.map","import { xyObjectCheck } from './xyObjectCheck';\n/**\n * Returns all min and max values of an array of points.\n * @param points - Array of points {x,y}.\n * @returns - Object with the 4 extrema.\n */\nexport function xyObjectMinMaxValues(points) {\n    xyObjectCheck(points, { minLength: 1 });\n    let minX = points[0].x;\n    let maxX = minX;\n    let minY = points[0].y;\n    let maxY = minY;\n    for (const point of points) {\n        if (point.x < minX)\n            minX = point.x;\n        if (point.x > maxX)\n            maxX = point.x;\n        if (point.y < minY)\n            minY = point.y;\n        if (point.y > maxY)\n            maxY = point.y;\n    }\n    return { minX, maxX, minY, maxY };\n}\n//# sourceMappingURL=xyObjectMinMaxValues.js.map","import { xyObjectCheck } from './xyObjectCheck';\n/**\n * Finds the min y value and return a {x,y,index} point\n * @param points - Object that contains property x (an ordered increasing array) and y (an array)\n */\nexport function xyObjectMinYPoint(points = []) {\n    xyObjectCheck(points);\n    if (points.length === 0)\n        return { x: 0, y: 0 };\n    let current = {\n        x: points[0].x,\n        y: points[0].y,\n        index: 0,\n    };\n    for (let i = 1; i < points.length; i++) {\n        if (points[i].y < current.y) {\n            current = {\n                x: points[i].x,\n                y: points[i].y,\n                index: i,\n            };\n        }\n    }\n    return current;\n}\n//# sourceMappingURL=xyObjectMinYPoint.js.map","import { xNormed } from '../x/xNormed';\n/**\n * Resize the Y values of the points to be normalized.\n * @param points - array of points {x,y}\n * @param options\n * @returns - array of points {x,y} with normalized Y values\n */\nexport function xyObjectNormedY(points, options) {\n    points = structuredClone(points);\n    const ys = points.map((point) => point.y);\n    const normalizedYs = xNormed(ys, options);\n    for (let i = 0; i < points.length; i++) {\n        points[i].y = normalizedYs[i];\n    }\n    return points;\n}\n//# sourceMappingURL=xyObjectNormedY.js.map","/**\n * xyObjectSlotX\n * @param points - Array of growing points {x,y}.\n * @param options - Options.\n */\nexport function xyObjectSlotX(points, options = {}) {\n    const { slotWidth = 1 } = options;\n    const halfSlot = slotWidth / 2;\n    // when we join we will use the center of mass\n    const result = [];\n    let current = {\n        x: Number.NEGATIVE_INFINITY,\n        y: 0,\n    };\n    for (const point of points) {\n        const slot = point.x - ((point.x + halfSlot) % slotWidth) + halfSlot;\n        if (Math.abs(current.x - slot) > Number.EPSILON) {\n            current = {\n                x: slot,\n                y: 0,\n            };\n            result.push(current);\n        }\n        current.y += point.y;\n    }\n    return result;\n}\n//# sourceMappingURL=xyObjectSlotX.js.map","/**\n * Sorts an array of points in-place.\n * @param points - array of points {x,y}\n * @returns - sorted array of points {x,y}\n */\nexport function xyObjectSortX(points) {\n    return points.sort((a, b) => a.x - b.x);\n}\n//# sourceMappingURL=xyObjectSortX.js.map","import { xyObjectCheck } from './xyObjectCheck';\n/**\n * Calculate the sum of Y values.\n * @param points - Object that contains property x and y (an array)\n */\nexport function xyObjectSumY(points = []) {\n    xyObjectCheck(points);\n    let sum = 0;\n    for (const point of points) {\n        sum += point.y;\n    }\n    return sum;\n}\n//# sourceMappingURL=xyObjectSumY.js.map","/**\n * xyObjectToXY.\n * @param points - Array of points {x,y}.\n */\nexport function xyObjectToXY(points) {\n    return {\n        x: points.map((entry) => entry.x),\n        y: points.map((entry) => entry.y),\n    };\n}\n//# sourceMappingURL=xyObjectToXY.js.map","import { xFindClosestIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Returns an information about a signal.\n *\n *\n * We expect ordered data and equidistant X axis\n * You can use the method helper if required:\n * ML.ArrayPoints.uniqueX\n * ML.ArrayPoints.sortX\n * ML.ArrayPoints.equallySpaced\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - options\n * @returns - Information about signal\n */\nexport function xyPeakInfo(data, options = {}) {\n    xyCheck(data);\n    const { x, y } = data;\n    if (x === undefined || y === undefined || x.length < 3) {\n        return;\n    }\n    const { target } = options;\n    let { targetIndex } = options;\n    if (targetIndex === undefined && target !== undefined) {\n        targetIndex = xFindClosestIndex(x, target);\n    }\n    if (targetIndex === undefined) {\n        throw new Error('must specify target or targetIndex');\n    }\n    let i = targetIndex;\n    let currentDiff = y[i] - y[i + 1];\n    const multiplier = currentDiff < 0 ? -1 : 1;\n    currentDiff *= multiplier;\n    while (i < x.length - 1) {\n        i++;\n        const newDiff = (y[i] - y[i + 1]) * multiplier;\n        if (newDiff < currentDiff)\n            break;\n        currentDiff = newDiff;\n    }\n    const after = { x: x[i], y: y[i] };\n    i = targetIndex;\n    currentDiff = (y[i] - y[i - 1]) * multiplier;\n    while (i > 1) {\n        i--;\n        const newDiff = (y[i] - y[i - 1]) * multiplier;\n        if (newDiff < currentDiff)\n            break;\n        currentDiff = newDiff;\n    }\n    const before = { x: x[i], y: y[i] };\n    return {\n        inflectionBefore: before,\n        inflectionAfter: after,\n        extrema: { x: x[targetIndex], y: y[targetIndex] },\n        inflectionMiddle: {\n            x: (before.x + after.x) / 2,\n            y: (before.y + after.y) / 2,\n        },\n        width: Math.abs(before.x - after.x),\n    };\n}\n//# sourceMappingURL=xyPeakInfo.js.map","import { xGetTargetIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * Find the closest minimum going down hill\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - options\n * @returns - An object with the x/y value\n */\nexport function xyRealMaxYPoint(data, options = {}) {\n    xyCheck(data);\n    const { x, y } = data;\n    const targetIndex = xGetTargetIndex(x, options);\n    // interpolation to a sin() function\n    if (y[targetIndex - 1] > 0 &&\n        y[targetIndex + 1] > 0 &&\n        y[targetIndex] >= y[targetIndex - 1] &&\n        y[targetIndex] >= y[targetIndex + 1]) {\n        const alpha = 20 * Math.log10(y[targetIndex - 1]);\n        const beta = 20 * Math.log10(y[targetIndex]);\n        const gamma = 20 * Math.log10(y[targetIndex + 1]);\n        const p = (0.5 * (alpha - gamma)) / (alpha - 2 * beta + gamma);\n        return {\n            x: x[targetIndex] + (x[targetIndex] - x[targetIndex - 1]) * p,\n            y: y[targetIndex] - 0.25 * (y[targetIndex - 1] - y[targetIndex + 1]) * p,\n            index: targetIndex,\n        };\n    }\n    else {\n        return {\n            x: x[targetIndex],\n            y: y[targetIndex],\n            index: targetIndex,\n        };\n    }\n}\n//# sourceMappingURL=xyRealMaxYPoint.js.map","import { xGetTargetIndex } from '../x';\nimport { xyCheck } from './xyCheck';\n/**\n * xyRealMinYPoint.\n * @param data - Data.\n * @param options - Options.\n */\nexport function xyRealMinYPoint(data, options = {}) {\n    xyCheck(data);\n    const { x, y } = data;\n    const targetIndex = xGetTargetIndex(x, options);\n    // interpolation to a sin() function\n    if (y[targetIndex - 1] < 0 &&\n        y[targetIndex + 1] < 0 &&\n        y[targetIndex] <= y[targetIndex - 1] &&\n        y[targetIndex] <= y[targetIndex + 1]) {\n        const alpha = 20 * Math.log10(-y[targetIndex - 1]);\n        const beta = 20 * Math.log10(-y[targetIndex]);\n        const gamma = 20 * Math.log10(-y[targetIndex + 1]);\n        const p = (0.5 * (alpha - gamma)) / (alpha - 2 * beta + gamma);\n        return {\n            x: x[targetIndex] + (x[targetIndex] - x[targetIndex - 1]) * p,\n            y: y[targetIndex] - 0.25 * (y[targetIndex - 1] - y[targetIndex + 1]) * p,\n            index: targetIndex,\n        };\n    }\n    else {\n        return {\n            x: x[targetIndex],\n            y: y[targetIndex],\n            index: targetIndex,\n        };\n    }\n}\n//# sourceMappingURL=xyRealMinYPoint.js.map","import { zonesNormalize } from '../zones';\nimport { xyCheck } from './xyCheck';\nimport { getInternalZones, notEnoughPoints } from './xyReduce';\n/**\n * Reduce the number of points while keeping visually the same noise. Practical to\n * display many spectra as SVG. This algorithm is designed for non-continuous data.\n * We are expecting peaks to be only positive and the x values to be ordered.\n * SHOULD NOT BE USED FOR DATA PROCESSING !!!\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - options\n * @returns Object with x and y arrays\n */\nexport function xyReduceNonContinuous(data, options = {}) {\n    xyCheck(data);\n    if (data.x.length < 2) {\n        // todo we should check that the single point is really in the range and the zones\n        return {\n            x: Float64Array.from(data.x),\n            y: Float64Array.from(data.y),\n        };\n    }\n    const { x, y } = data;\n    const { from = x[0], to = x.at(-1), maxApproximateNbPoints = 4001, } = options;\n    let { zones = [] } = options;\n    zones = zonesNormalize(zones, { from, to });\n    if (zones.length === 0)\n        zones = [{ from, to }]; // we take everything\n    const { internalZones, totalPoints } = getInternalZones(zones, x);\n    // we calculate the number of points per zone that we should keep\n    if (totalPoints <= maxApproximateNbPoints) {\n        return notEnoughPoints(x, y, internalZones, totalPoints);\n    }\n    const deltaX = (to - from) / (maxApproximateNbPoints - 1);\n    const newX = [];\n    const newY = [];\n    for (const internalZone of internalZones) {\n        const maxNbPoints = Math.ceil((internalZone.to - internalZone.from) / deltaX) + 1;\n        const fromIndex = internalZone.fromIndex;\n        const toIndex = internalZone.toIndex;\n        if (toIndex - fromIndex + 1 <= maxNbPoints) {\n            // we keep all the points\n            for (let i = fromIndex; i <= toIndex; i++) {\n                newX.push(x[i]);\n                newY.push(y[i]);\n            }\n        }\n        else {\n            // we need to reduce the number of points\n            let currentX = x[fromIndex];\n            let currentY = y[fromIndex];\n            let lastX = currentX + deltaX;\n            newX.push(currentX);\n            newY.push(currentY);\n            for (let i = fromIndex; i <= toIndex; i++) {\n                if (x[i] > lastX) {\n                    // next slot\n                    currentX = x[i];\n                    currentY = y[i];\n                    newX.push(currentX);\n                    newY.push(currentY);\n                    lastX += deltaX;\n                }\n                if (y[i] > currentY) {\n                    currentY = y[i];\n                    newY[newY.length - 1] = currentY;\n                }\n            }\n        }\n    }\n    return {\n        x: newX,\n        y: newY,\n    };\n}\n//# sourceMappingURL=xyReduceNonContinuous.js.map","import { xRolling, xRollingAverage } from '../x';\n/**\n * This function calculates a rolling average.\n * This methods will recalculate the x values by using xRollingAverage\n * @param data - array of points {x,y}\n * @param fct - callback function that from an array returns a value.\n * @param options - options\n */\nexport function xyRolling(data, fct, options = {}) {\n    let { x, y } = data;\n    y = xRolling(y, fct, options);\n    if (x.length !== y.length) {\n        x = xRollingAverage(x, options);\n    }\n    return { x, y };\n}\n//# sourceMappingURL=xyRolling.js.map","import { zonesNormalize } from '../zones';\nimport { xyCheck } from './xyCheck';\n/**\n * Set a value (default 0) to specific zones.\n * @param data - Object that contains property x (an ordered increasing array) and y (an array)\n * @param options - options\n * @returns - Array of points\n */\nexport function xySetYValue(data, options = {}) {\n    xyCheck(data);\n    const { x, y } = data;\n    const { value = 0 } = options;\n    let { zones } = options;\n    if (!Array.isArray(zones) || zones.length === 0) {\n        return data;\n    }\n    zones = zonesNormalize(zones);\n    const newX = x.slice();\n    const newY = y.slice();\n    let currentZone = zones[0];\n    let position = 0;\n    loop: for (let i = 0; i < x.length; i++) {\n        while (currentZone.to < x[i]) {\n            position++;\n            currentZone = zones[position];\n            if (!currentZone) {\n                i = x.length;\n                break loop;\n            }\n        }\n        if (x[i] >= currentZone.from) {\n            newY[i] = value;\n        }\n    }\n    return { x: newX, y: newY };\n}\n//# sourceMappingURL=xySetYValue.js.map","import { xyCheck } from './xyCheck';\n/**\n * Convert a DataXY to an array of array containing x,y.\n * @param data - array of points {x,y}\n */\nexport function xyToXYArray(data) {\n    xyCheck(data);\n    const { x, y } = data;\n    const objectArray = [];\n    for (let i = 0; i < x.length; i++) {\n        objectArray.push([x[i], y[i]]);\n    }\n    return objectArray;\n}\n//# sourceMappingURL=xyToXYArray.js.map","import { xyCheck } from './xyCheck';\n/**\n * xyToXYObject.\n * @param data - Array of points {x,y}.\n */\nexport function xyToXYObject(data) {\n    xyCheck(data);\n    const { x, y } = data;\n    const objectArray = [];\n    for (let i = 0; i < x.length; i++) {\n        objectArray.push({ x: x[i], y: y[i] });\n    }\n    return objectArray;\n}\n//# sourceMappingURL=xyToXYObject.js.map","/**\n * Merge abscissas values on similar ordinates and weight the group of abscissas\n * @param data - object containing 2 properties x and y\n * @param options - options\n * @returns array of merged and weighted points\n */\nexport function xyWeightedMerge(data, options = {}) {\n    const { x, y } = data;\n    const { groupWidth = 0.001 } = options;\n    const merged = { x: [], y: [] };\n    const weightedAbscissa = { x: [], y: [] };\n    let size = 0;\n    let index = 0;\n    while (index < x.length) {\n        if (size === 0 || x[index] - merged.x[size - 1] > groupWidth) {\n            weightedAbscissa.x.push(x[index] * y[index]);\n            weightedAbscissa.y.push(y[index]);\n            merged.x.push(x[index]);\n            merged.y.push(y[index]);\n            index++;\n            size++;\n        }\n        else {\n            weightedAbscissa.x[size - 1] += x[index] * y[index];\n            weightedAbscissa.y[size - 1] += y[index];\n            merged.x[size - 1] = x[index];\n            merged.y[size - 1] += y[index];\n            index++;\n        }\n    }\n    for (let i = 0; i < merged.x.length; i++) {\n        merged.x[i] = weightedAbscissa.x[i] / weightedAbscissa.y[i];\n    }\n    return merged;\n}\n//# sourceMappingURL=xyWeightedMerge.js.map","export function addStyle(serie, spectrum, options = {}) {\n    let { color = '#A9A9A9' } = options;\n    const { opacity = 1, lineWidth = 1 } = options;\n    if (color.match(/#[\\da-f]{6}$/i)) {\n        color = (color + ((opacity * 255) >> 0).toString(16)).toUpperCase();\n    }\n    else {\n        color = color.replace(/rgb ?\\((.*)\\)/, `rgba($1,${opacity})`);\n    }\n    serie.style = [\n        {\n            name: 'unselected',\n            style: {\n                line: {\n                    color,\n                    width: lineWidth,\n                    dash: 1,\n                },\n            },\n        },\n        {\n            name: 'selected',\n            style: {\n                line: {\n                    color,\n                    width: lineWidth + 2,\n                    dash: 1,\n                },\n            },\n        },\n    ];\n    serie.name = spectrum.label || spectrum.id;\n}\n//# sourceMappingURL=addStyle.js.map","export const COLORS = [\n    '#FFB300',\n    '#803E75',\n    '#FF6800',\n    '#A6BDD7',\n    '#C10020',\n    '#CEA262',\n    '#817066',\n    '#007D34',\n    '#F6768E',\n    '#00538A',\n    '#FF7A5C',\n    '#53377A',\n    '#FF8E00',\n    '#B32851',\n    '#F4C800',\n    '#7F180D',\n    '#93AA00',\n    '#593315',\n    '#F13A13',\n    '#232C16',\n];\n//# sourceMappingURL=colors.js.map","// Based on https://github.com/scijs/cholesky-solve\n\n/*\nThe MIT License (MIT)\n\nCopyright (c) 2013 Eric Arnebäck\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n*/\n\nfunction ldlSymbolic(\n  n /* A and L are n-by-n, where n >= 0 */,\n  Ap /* input of size n + 1, not modified */,\n  Ai /* input of size nz=Ap[n], not modified */,\n  Lp /* output of size n + 1, not defined on input */,\n  Parent /* output of size n, not defined on input */,\n  Lnz /* output of size n, not defined on input */,\n  Flag /* workspace of size n, not defn. on input or output */,\n) {\n  let i, k, p, kk, p2;\n\n  for (k = 0; k < n; k++) {\n    /* L(k,:) pattern: all nodes reachable in etree from nz in A(0:k-1,k) */\n    Parent[k] = -1; /* parent of k is not yet known */\n    Flag[k] = k; /* mark node k as visited */\n    Lnz[k] = 0; /* count of nonzeros in column k of L */\n    kk = k; /* kth original, or permuted, column */\n    p2 = Ap[kk + 1];\n    for (p = Ap[kk]; p < p2; p++) {\n      /* A (i,k) is nonzero (original or permuted A) */\n      i = Ai[p];\n\n      if (i < k) {\n        /* follow path from i to root of etree, stop at flagged node */\n        for (; Flag[i] !== k; i = Parent[i]) {\n          /* find parent of i if not yet determined */\n          if (Parent[i] === -1) Parent[i] = k;\n          Lnz[i]++; /* L (k,i) is nonzero */\n          Flag[i] = k; /* mark i as visited */\n        }\n      }\n    }\n  }\n  /* construct Lp index array from Lnz column counts */\n  Lp[0] = 0;\n  for (k = 0; k < n; k++) {\n    Lp[k + 1] = Lp[k] + Lnz[k];\n  }\n}\n\nfunction ldlNumeric(\n  n /* A and L are n-by-n, where n >= 0 */,\n  Ap /* input of size n+1, not modified */,\n  Ai /* input of size nz=Ap[n], not modified */,\n  Ax /* input of size nz=Ap[n], not modified */,\n  Lp /* input of size n+1, not modified */,\n  Parent /* input of size n, not modified */,\n  Lnz /* output of size n, not defn. on input */,\n  Li /* output of size lnz=Lp[n], not defined on input */,\n  Lx /* output of size lnz=Lp[n], not defined on input */,\n  D /* output of size n, not defined on input */,\n  Y /* workspace of size n, not defn. on input or output */,\n  Pattern /* workspace of size n, not defn. on input or output */,\n  Flag /* workspace of size n, not defn. on input or output */,\n) {\n  let yi, lKi;\n  let i, k, p, kk, p2, len, top;\n  for (k = 0; k < n; k++) {\n    /* compute nonzero Pattern of kth row of L, in topological order */\n    Y[k] = 0.0; /* Y(0:k) is now all zero */\n    top = n; /* stack for pattern is empty */\n    Flag[k] = k; /* mark node k as visited */\n    Lnz[k] = 0; /* count of nonzeros in column k of L */\n    kk = k; /* kth original, or permuted, column */\n    p2 = Ap[kk + 1];\n    for (p = Ap[kk]; p < p2; p++) {\n      i = Ai[p]; /* get A(i,k) */\n      if (i <= k) {\n        Y[i] += Ax[p]; /* scatter A(i,k) into Y (sum duplicates) */\n        for (len = 0; Flag[i] !== k; i = Parent[i]) {\n          Pattern[len++] = i; /* L(k,i) is nonzero */\n          Flag[i] = k; /* mark i as visited */\n        }\n        while (len > 0) Pattern[--top] = Pattern[--len];\n      }\n    }\n    /* compute numerical values kth row of L (a sparse triangular solve) */\n    D[k] = Y[k]; /* get D(k,k) and clear Y(k) */\n    Y[k] = 0.0;\n    for (; top < n; top++) {\n      i = Pattern[top]; /* Pattern[top:n-1] is pattern of L(:,k) */\n      yi = Y[i]; /* get and clear Y(i) */\n      Y[i] = 0.0;\n      p2 = Lp[i] + Lnz[i];\n      for (p = Lp[i]; p < p2; p++) {\n        Y[Li[p]] -= Lx[p] * yi;\n      }\n      lKi = yi / D[i]; /* the nonzero entry L(k,i) */\n      D[k] -= lKi * yi;\n      Li[p] = k; /* store L(k,i) in column form of L */\n      Lx[p] = lKi;\n      Lnz[i]++; /* increment count of nonzeros in col i */\n    }\n\n    if (D[k] === 0.0) return k; /* failure, D(k,k) is zero */\n  }\n\n  return n; /* success, diagonal of D is all nonzero */\n}\n\nfunction ldlLsolve(\n  n /* L is n-by-n, where n >= 0 */,\n  X /* size n. right-hand-side on input, soln. on output */,\n  Lp /* input of size n+1, not modified */,\n  Li /* input of size lnz=Lp[n], not modified */,\n  Lx /* input of size lnz=Lp[n], not modified */,\n) {\n  let j, p, p2;\n  for (j = 0; j < n; j++) {\n    p2 = Lp[j + 1];\n    for (p = Lp[j]; p < p2; p++) {\n      X[Li[p]] -= Lx[p] * X[j];\n    }\n  }\n}\n\nfunction ldlDsolve(\n  n /* D is n-by-n, where n >= 0 */,\n  X /* size n. right-hand-side on input, soln. on output */,\n  D /* input of size n, not modified */,\n) {\n  let j;\n  for (j = 0; j < n; j++) {\n    X[j] /= D[j];\n  }\n}\n\nfunction ldlLTsolve(\n  n /* L is n-by-n, where n >= 0 */,\n  X /* size n. right-hand-side on input, soln. on output */,\n  Lp /* input of size n+1, not modified */,\n  Li /* input of size lnz=Lp[n], not modified */,\n  Lx /* input of size lnz=Lp[n], not modified */,\n) {\n  let j, p, p2;\n  for (j = n - 1; j >= 0; j--) {\n    p2 = Lp[j + 1];\n    for (p = Lp[j]; p < p2; p++) {\n      X[j] -= Lx[p] * X[Li[p]];\n    }\n  }\n}\n\nfunction ldlPerm(\n  n /* size of X, B, and P */,\n  X /* output of size n. */,\n  B /* input of size n. */,\n  P /* input permutation array of size n. */,\n) {\n  let j;\n  for (j = 0; j < n; j++) {\n    X[j] = B[P[j]];\n  }\n}\n\nfunction ldlPermt(\n  n /* size of X, B, and P */,\n  X /* output of size n. */,\n  B /* input of size n. */,\n  P /* input permutation array of size n. */,\n) {\n  let j;\n  for (j = 0; j < n; j++) {\n    X[P[j]] = B[j];\n  }\n}\n\nfunction prepare(M, n, P) {\n  // if a permutation was specified, apply it.\n  if (P) {\n    let Pinv = new Array(n);\n\n    for (let k = 0; k < n; k++) {\n      Pinv[P[k]] = k;\n    }\n\n    let Mt = []; // scratch memory\n    // Apply permutation. We make M into P*M*P^T\n    for (let a = 0; a < M.length; ++a) {\n      let ar = Pinv[M[a][0]];\n      let ac = Pinv[M[a][1]];\n\n      // we only store the upper-diagonal elements(since we assume matrix is symmetric, we only need to store these)\n      // if permuted element is below diagonal, we simply transpose it.\n      if (ac < ar) {\n        let t = ac;\n        ac = ar;\n        ar = t;\n      }\n\n      Mt[a] = [];\n      Mt[a][0] = ar;\n      Mt[a][1] = ac;\n      Mt[a][2] = M[a][2];\n    }\n\n    M = Mt; // copy scratch memory.\n  } else {\n    // if P argument is null, we just use an identity permutation.\n    P = [];\n    for (let i = 0; i < n; ++i) {\n      P[i] = i;\n    }\n  }\n\n  // The sparse matrix we are decomposing is A.\n  // Now we shall create A from M.\n  let Ap = new Array(n + 1);\n  let Ai = new Array(M.length);\n  let Ax = new Array(M.length);\n\n  // count number of non-zero elements in columns.\n  let LNZ = [];\n  for (let i = 0; i < n; ++i) {\n    LNZ[i] = 0;\n  }\n  for (let a = 0; a < M.length; ++a) {\n    LNZ[M[a][1]]++;\n  }\n\n  Ap[0] = 0;\n  for (let i = 0; i < n; ++i) {\n    Ap[i + 1] = Ap[i] + LNZ[i];\n  }\n\n  let coloffset = [];\n  for (let a = 0; a < n; ++a) {\n    coloffset[a] = 0;\n  }\n\n  // go through all elements in M, and add them to sparse matrix A.\n  for (let i = 0; i < M.length; ++i) {\n    let e = M[i];\n    let col = e[1];\n\n    let adr = Ap[col] + coloffset[col];\n    Ai[adr] = e[0];\n    Ax[adr] = e[2];\n\n    coloffset[col]++;\n  }\n\n  let D = new Array(n);\n  let Y = new Array(n);\n  let Lp = new Array(n + 1);\n  let Parent = new Array(n);\n  let Lnz = new Array(n);\n  let Flag = new Array(n);\n  let Pattern = new Array(n);\n  let bp1 = new Array(n);\n  let x = new Array(n);\n  let d;\n\n  ldlSymbolic(n, Ap, Ai, Lp, Parent, Lnz, Flag);\n\n  let Lx = new Array(Lp[n]);\n  let Li = new Array(Lp[n]);\n\n  d = ldlNumeric(n, Ap, Ai, Ax, Lp, Parent, Lnz, Li, Lx, D, Y, Pattern, Flag);\n\n  if (d === n) {\n    return (b) => {\n      ldlPerm(n, bp1, b, P);\n      ldlLsolve(n, bp1, Lp, Li, Lx);\n      ldlDsolve(n, bp1, D);\n      ldlLTsolve(n, bp1, Lp, Li, Lx);\n      ldlPermt(n, x, bp1, P);\n\n      return x;\n    };\n  } else {\n    return null;\n  }\n}\n\nexport { prepare as default };\n","'use strict'\n\nmodule.exports = cuthillMckee\n\nfunction compareNum(a, b) { return a - b }\n\nfunction cuthillMckee(list, n) {\n  var adj = new Array(n)\n  var visited = new Array(n)\n  for(var i=0; i<n; ++i) {\n    adj[i]     = []\n    visited[i] = false\n  }\n\n  for(var i=0; i<list.length; ++i) {\n    var l = list[i]\n    adj[l[0]].push(l[1])\n  }\n\n  var toVisit = new Array(n)\n  var eol = 0\n  var ptr = 0\n  for(var i=0; i<n; ++i) {\n    if(visited[i]) {\n      continue\n    }\n    toVisit[eol++] = i\n    visited[i] = true\n    while(ptr < eol) {\n      var v = toVisit[ptr++]\n      var nbhd = adj[v]\n      nbhd.sort(compareNum)\n      for(var j=0; j<nbhd.length; ++j) {\n        var u = nbhd[j]\n        if(visited[u]) {\n          continue\n        }\n        visited[u] = true\n        toVisit[eol++] = u\n      }\n    }\n  }\n\n  var result = new Array(n)\n  for(var i=0; i<n; ++i) {\n    result[toVisit[i]] = i\n  }\n\n  return result\n}\n","import cuthillMckee from 'cuthill-mckee';\n\nconst getClosestNumber = (array = [], goal = 0) => {\n  const closest = array.reduce((prev, curr) => {\n    return Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev;\n  });\n  return closest;\n};\n\nconst getCloseIndex = (array = [], goal = 0) => {\n  const closest = getClosestNumber(array, goal);\n  return array.indexOf(closest);\n};\n\nconst updateSystem = (matrix, y, weights) => {\n  let nbPoints = y.length;\n  let l = nbPoints - 1;\n  let newMatrix = new Array(matrix.length);\n  let newVector = new Float64Array(nbPoints);\n  for (let i = 0; i < l; i++) {\n    let w = weights[i];\n    let diag = i * 2;\n    let next = diag + 1;\n    newMatrix[diag] = matrix[diag].slice();\n    newMatrix[next] = matrix[next].slice();\n    if (w === 0) {\n      newVector[i] = 0;\n    } else {\n      newVector[i] = y[i] * w;\n      newMatrix[diag][2] += w;\n    }\n  }\n  newVector[l] = y[l] * weights[l];\n  newMatrix[l * 2] = matrix[l * 2].slice();\n  newMatrix[l * 2][2] += weights[l];\n\n  return [newMatrix, newVector];\n};\n\nconst getDeltaMatrix = (nbPoints, lambda) => {\n  let matrix = [];\n  let last = nbPoints - 1;\n  for (let i = 0; i < last; i++) {\n    matrix.push([i, i, lambda * 2]);\n    matrix.push([i + 1, i, -1 * lambda]);\n  }\n  matrix[0][2] = lambda;\n  matrix.push([last, last, lambda]);\n  return {\n    lowerTriangularNonZeros: matrix,\n    permutationEncodedArray: cuthillMckee(matrix, nbPoints),\n  };\n};\n\nexport { updateSystem, getDeltaMatrix, getCloseIndex, getClosestNumber };\n","import { xMultiply, xNoiseSanPlot, xAbsoluteSum } from 'ml-spectra-processing';\n\nimport cholesky from './choleskySolver';\nimport { updateSystem, getDeltaMatrix, getCloseIndex } from './utils';\n\nfunction getControlPoints(x, y, options = {}) {\n  const { length } = x;\n  let { controlPoints = Int8Array.from({ length }).fill(0) } = options;\n  const { zones = [], weights = Float64Array.from({ length }).fill(1) } =\n    options;\n\n  if (x.length !== y.length) {\n    throw new RangeError('Y should match the length with X');\n  } else if (controlPoints.length !== x.length) {\n    throw new RangeError('controlPoints should match the length with X');\n  } else if (weights.length !== x.length) {\n    throw new RangeError('weights should match the length with X');\n  }\n\n  zones.forEach((range) => {\n    let indexFrom = getCloseIndex(x, range.from);\n    let indexTo = getCloseIndex(x, range.to);\n    if (indexFrom > indexTo) [indexFrom, indexTo] = [indexTo, indexFrom];\n    for (let i = indexFrom; i < indexTo; i++) {\n      controlPoints[i] = 1;\n    }\n  });\n\n  return {\n    weights:\n      'controlPoints' in options || zones.length > 0\n        ? xMultiply(weights, controlPoints)\n        : weights,\n    controlPoints,\n  };\n}\n\n/**\n * Fit the baseline drift by iteratively changing weights of sum square error between the fitted baseline and original signals,\n * for further information about the parameters you can get the [paper of airPLS](https://github.com/zmzhang/airPLS/blob/main/airPLS_manuscript.pdf)\n * @param {Array<number>} x - x axis data useful when control points or zones are submitted\n * @param {Array<number>} y - Original data\n * @param {object} [options={}] - Options object\n * @param {number} [options.maxIterations = 100] - Maximal number of iterations if the method does not reach the stop criterion\n * @param {number} [options.tolerance = 0.001] - Factor of the sum of absolute value of original data, to compute stop criterion\n * @param {Array<number>} [options.weights = [1,1,...]] - Initial weights vector, default each point has the same weight\n * @param {number} [options.lambda = 100] - Factor of weights matrix in -> [I + lambda D'D]z = x\n * @param {Array<number>} [options.controlPoints = []] - Array of 0|1 to force the baseline cross those points.\n * @param {Array<number>} [options.zones = []] - Array of x axis values (as from - to), to force that baseline cross those zones.\n * @returns {{corrected: Array<number>, error: number, iteration: number, baseline: Array<number>}}\n */\n\nexport default function airPLS(x, y, options = {}) {\n  const { weights, controlPoints } = getControlPoints(x, y, options);\n  let { maxIterations = 100, lambda = 10, tolerance = 0.001 } = options;\n\n  let baseline, iteration;\n  let sumNegDifferences = Number.MAX_SAFE_INTEGER;\n  const corrected = Float64Array.from(y);\n  let stopCriterion = getStopCriterion(y, tolerance);\n\n  const { length } = y;\n  let { lowerTriangularNonZeros, permutationEncodedArray } = getDeltaMatrix(\n    length,\n    lambda,\n  );\n\n  let threshold = 1;\n  const l = length - 1;\n  let prevNegSum = Number.MAX_SAFE_INTEGER;\n  for (\n    iteration = 0;\n    iteration < maxIterations && Math.abs(sumNegDifferences) > stopCriterion;\n    iteration++\n  ) {\n    let [leftHandSide, rightHandSide] = updateSystem(\n      lowerTriangularNonZeros,\n      y,\n      weights,\n    );\n\n    let cho = cholesky(leftHandSide, length, permutationEncodedArray);\n\n    baseline = cho(rightHandSide);\n\n    sumNegDifferences = applyCorrection(y, baseline, corrected);\n    if (iteration === 1) {\n      const { positive } = xNoiseSanPlot(corrected);\n      threshold = positive;\n    } else {\n      const absChange = Math.abs(prevNegSum / sumNegDifferences);\n      if (absChange < 1.01 && absChange > 0.99) {\n        break;\n      }\n    }\n\n    prevNegSum = sumNegDifferences + 0;\n    for (let i = 1; i < l; i++) {\n      const diff = corrected[i];\n      if (controlPoints[i] < 1 && Math.abs(diff) > threshold) {\n        weights[i] = 0;\n      } else {\n        const factor = diff > 0 ? -1 : 1;\n        weights[i] = Math.exp(\n          (factor * (iteration * diff)) / Math.abs(sumNegDifferences),\n        );\n      }\n    }\n\n    weights[0] = 1;\n    weights[l] = 1;\n  }\n\n  return {\n    corrected,\n    baseline,\n    iteration,\n    error: sumNegDifferences,\n  };\n\n  function applyCorrection(y, baseline, corrected) {\n    let sumNegDifferences = 0;\n    for (let i = 0; i < y.length; i++) {\n      let diff = y[i] - baseline[i];\n      if (diff < 0) sumNegDifferences += diff;\n      corrected[i] = diff;\n    }\n\n    return sumNegDifferences;\n  }\n}\n\nfunction getStopCriterion(y, tolerance) {\n  let sum = xAbsoluteSum(y);\n  return tolerance * sum;\n}\n","import { isAnyArray } from 'is-any-array';\n\nfunction _typeof(obj) {\n  \"@babel/helpers - typeof\";\n\n  if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n    _typeof = function (obj) {\n      return typeof obj;\n    };\n  } else {\n    _typeof = function (obj) {\n      return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n    };\n  }\n\n  return _typeof(obj);\n}\n\n/**\n * Fill an array with sequential numbers\n * @param {Array<number>} [input] - optional destination array (if not provided a new array will be created)\n * @param {object} [options={}]\n * @param {number} [options.from=0] - first value in the array\n * @param {number} [options.to=10] - last value in the array\n * @param {number} [options.size=input.length] - size of the array (if not provided calculated from step)\n * @param {number} [options.step] - if not provided calculated from size\n * @return {Array<number>}\n */\n\nfunction sequentialFill() {\n  var input = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (_typeof(input) === 'object' && !isAnyArray(input)) {\n    options = input;\n    input = [];\n  }\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  }\n\n  var _options = options,\n      _options$from = _options.from,\n      from = _options$from === void 0 ? 0 : _options$from,\n      _options$to = _options.to,\n      to = _options$to === void 0 ? 10 : _options$to,\n      _options$size = _options.size,\n      size = _options$size === void 0 ? input.length : _options$size,\n      step = _options.step;\n\n  if (size !== 0 && step) {\n    throw new Error('step is defined by the array size');\n  }\n\n  if (!size) {\n    if (step) {\n      size = Math.floor((to - from) / step) + 1;\n    } else {\n      size = to - from + 1;\n    }\n  }\n\n  if (!step && size) {\n    step = (to - from) / (size - 1);\n  }\n\n  if (Array.isArray(input)) {\n    // only works with normal array\n    input.length = 0;\n\n    for (var i = 0; i < size; i++) {\n      input.push(from);\n      from += step;\n    }\n  } else {\n    if (input.length !== size) {\n      throw new Error('sequentialFill typed array must have the correct length');\n    }\n\n    for (var _i = 0; _i < size; _i++) {\n      input[_i] = from;\n      from += step;\n    }\n  }\n\n  return input;\n}\n\nexport { sequentialFill as default };\n","import { isAnyArray } from 'is-any-array';\n/**\n * Check that x and y are arrays with the same length.\n * @param x - first array\n * @param y - second array\n * @throws if x or y are not the same length, or if they are not arrays\n */\nexport function checkArrayLength(x, y) {\n    if (!isAnyArray(x) || !isAnyArray(y)) {\n        throw new TypeError('x and y must be arrays');\n    }\n    if (x.length !== y.length) {\n        throw new RangeError('x and y arrays must have the same length');\n    }\n}\n//# sourceMappingURL=checkArrayLength.js.map","import { isAnyArray } from 'is-any-array';\nimport { checkArrayLength } from './checkArrayLength';\nexport class BaseRegression {\n    constructor() {\n        if (new.target === BaseRegression) {\n            throw new Error('BaseRegression must be subclassed');\n        }\n    }\n    predict(x) {\n        if (typeof x === 'number') {\n            return this._predict(x);\n        }\n        else if (isAnyArray(x)) {\n            const y = [];\n            for (const xVal of x) {\n                y.push(this._predict(xVal));\n            }\n            return y;\n        }\n        else {\n            throw new TypeError('x must be a number or array');\n        }\n    }\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    _predict(x) {\n        throw new Error('_predict must be implemented');\n    }\n    train() {\n        // Do nothing for this package\n    }\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    toString(precision) {\n        return '';\n    }\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    toLaTeX(precision) {\n        return '';\n    }\n    /**\n     * Return the correlation coefficient of determination (r) and chi-square.\n     * @param x - explanatory variable\n     * @param y - response variable\n     * @return - Object with further statistics.\n     */\n    score(x, y) {\n        checkArrayLength(x, y);\n        const n = x.length;\n        const y2 = new Array(n);\n        for (let i = 0; i < n; i++) {\n            y2[i] = this._predict(x[i]);\n        }\n        let xSum = 0;\n        let ySum = 0;\n        let chi2 = 0;\n        let rmsd = 0;\n        let xSquared = 0;\n        let ySquared = 0;\n        let xY = 0;\n        for (let i = 0; i < n; i++) {\n            xSum += y2[i];\n            ySum += y[i];\n            xSquared += y2[i] * y2[i];\n            ySquared += y[i] * y[i];\n            xY += y2[i] * y[i];\n            if (y[i] !== 0) {\n                chi2 += ((y[i] - y2[i]) * (y[i] - y2[i])) / y[i];\n            }\n            rmsd += (y[i] - y2[i]) * (y[i] - y2[i]);\n        }\n        const r = (n * xY - xSum * ySum) /\n            Math.sqrt((n * xSquared - xSum * xSum) * (n * ySquared - ySum * ySum));\n        return {\n            r,\n            r2: r * r,\n            chi2,\n            rmsd: Math.sqrt(rmsd / n),\n        };\n    }\n}\n//# sourceMappingURL=BaseRegression.js.map","/**\n * Cast `number` to string. Optionally `digits` specifies significant figures.\n * @param number\n * @param figures\n * @returns - A string representation of `number`.\n */\nexport function maybeToPrecision(number, figures) {\n    if (number < 0) {\n        number = 0 - number;\n        if (typeof figures === 'number') {\n            return `- ${number.toPrecision(figures)}`;\n        }\n        else {\n            return `- ${number.toString()}`;\n        }\n    }\n    else if (typeof figures === 'number') {\n        return number.toPrecision(figures);\n    }\n    else {\n        return number.toString();\n    }\n}\n//# sourceMappingURL=maybeToPrecision.js.map","import { Matrix, MatrixTransposeView, solve } from 'ml-matrix';\nimport { BaseRegression, checkArrayLength, maybeToPrecision, } from 'ml-regression-base';\nexport class PolynomialRegression extends BaseRegression {\n    /**\n     * @param x - independent or explanatory variable\n     * @param y - dependent or response variable\n     * @param degree - degree of the polynomial regression, or array of powers to be used. When degree is an array, intercept at zero is forced to false/ignored.\n     * @example `new PolynomialRegression(x, y, 2)`, in this case, you can pass the option `interceptAtZero`, if you need it.\n     * @param options\n     * @example `new PolynomialRegression(x, y, [1, 3, 5])`\n     * Each of the degrees corresponds to a column, so if you have them switched, just do:\n     * @example `new PolynomialRegression(x, y, [3, 1, 5])`\n     * @param options.interceptAtZero - force the polynomial regression so that f(0) = 0\n     */\n    constructor(x, y, degree, options = {}) {\n        super();\n        // @ts-expect-error internal use only\n        if (x === true) {\n            // @ts-expect-error internal use only\n            this.degree = y.degree;\n            // @ts-expect-error internal use only\n            this.powers = y.powers;\n            // @ts-expect-error internal use only\n            this.coefficients = y.coefficients;\n        }\n        else {\n            checkArrayLength(x, y);\n            const result = regress(x, y, degree, options);\n            this.degree = result.degree;\n            this.powers = result.powers;\n            this.coefficients = result.coefficients;\n        }\n    }\n    _predict(x) {\n        let y = 0;\n        for (let k = 0; k < this.powers.length; k++) {\n            y += this.coefficients[k] * x ** this.powers[k];\n        }\n        return y;\n    }\n    toJSON() {\n        return {\n            name: 'polynomialRegression',\n            degree: this.degree,\n            powers: this.powers,\n            coefficients: this.coefficients,\n        };\n    }\n    toString(precision) {\n        return this._toFormula(precision, false);\n    }\n    toLaTeX(precision) {\n        return this._toFormula(precision, true);\n    }\n    _toFormula(precision, isLaTeX) {\n        let sup = '^';\n        let closeSup = '';\n        let times = ' * ';\n        if (isLaTeX) {\n            sup = '^{';\n            closeSup = '}';\n            times = '';\n        }\n        let fn = '';\n        let str = '';\n        for (let k = 0; k < this.coefficients.length; k++) {\n            str = '';\n            if (this.coefficients[k] !== 0) {\n                if (this.powers[k] === 0) {\n                    str = maybeToPrecision(this.coefficients[k], precision);\n                }\n                else if (this.powers[k] === 1) {\n                    str = `${maybeToPrecision(this.coefficients[k], precision) + times}x`;\n                }\n                else {\n                    str = `${maybeToPrecision(this.coefficients[k], precision) + times}x${sup}${this.powers[k]}${closeSup}`;\n                }\n                if (this.coefficients[k] > 0 && k !== this.coefficients.length - 1) {\n                    str = ` + ${str}`;\n                }\n                else if (k !== this.coefficients.length - 1) {\n                    str = ` ${str}`;\n                }\n            }\n            fn = str + fn;\n        }\n        if (fn.startsWith('+')) {\n            fn = fn.slice(1);\n        }\n        return `f(x) = ${fn}`;\n    }\n    static load(json) {\n        if (json.name !== 'polynomialRegression') {\n            throw new TypeError('not a polynomial regression model');\n        }\n        // @ts-expect-error internal use only\n        return new PolynomialRegression(true, json);\n    }\n}\n/**\n * Perform a polynomial regression on the given data set.\n * This is an internal function.\n * @param x - independent or explanatory variable\n * @param y - dependent or response variable\n * @param degree - degree of the polynomial regression\n * @param options.interceptAtZero - force the polynomial regression so that $f(0) = 0$\n * @param options\n */\nfunction regress(x, y, degree, options = {}) {\n    const n = x.length;\n    let { interceptAtZero = false } = options;\n    let powers = [];\n    if (Array.isArray(degree)) {\n        powers = degree;\n        interceptAtZero = false; //must be false in this case\n    }\n    else if (typeof degree === 'number') {\n        if (interceptAtZero) {\n            powers = new Array(degree);\n            for (let k = 0; k < degree; k++) {\n                powers[k] = k + 1;\n            }\n        }\n        else {\n            powers = new Array(degree + 1);\n            for (let k = 0; k <= degree; k++) {\n                powers[k] = k;\n            }\n        }\n    }\n    const nCoefficients = powers.length; //1 per power, in any case.\n    const F = new Matrix(n, nCoefficients);\n    const Y = new Matrix([y]);\n    for (let k = 0; k < nCoefficients; k++) {\n        for (let i = 0; i < n; i++) {\n            if (powers[k] === 0) {\n                F.set(i, k, 1);\n            }\n            else {\n                F.set(i, k, x[i] ** powers[k]);\n            }\n        }\n    }\n    const FT = new MatrixTransposeView(F);\n    const A = FT.mmul(F);\n    const B = FT.mmul(new MatrixTransposeView(Y));\n    return {\n        coefficients: solve(A, B).to1DArray(),\n        degree: Math.max(...powers),\n        powers,\n    };\n}\n//# sourceMappingURL=index.js.map","import sequentialFill from 'ml-array-sequential-fill';\nimport { baselineCorrectionRegression } from 'ml-baseline-correction-regression';\n\n/**\n * Iterative polynomial fitting [1]\n *\n * Implementation based on ml-baseline-correction-regression\n *\n * References:\n * [1] Gan, F.; Ruan, G.; Mo, J.\n * Baseline Correction by Improved Iterative Polynomial Fitting with Automatic Threshold.\n *  Chemometrics and Intelligent Laboratory Systems 2006, 82 (1), 59–65.\n * https://doi.org/10.1016/j.chemolab.2005.08.009.\n * @export\n * @param {Array<number>} ys\n * @param {object} [options] - Options object\n * @param {Array<number>} [options.x] Optional, Independent axis variable. If not specified, we use a linear grid\n * @param {Object} [options.regression]\n * @param {number} [options.regression.maxIterations = 100] - Maximum number of allowed iterations\n * @param {Object} [options.regression]\n * @param {function} [options.regression.Regression = PolynomialRegression] - Regression class with a predict method\n * @param {Object} [options.regression.regressionOptions] - Options for regressionFunction\n * @param {number} [options.regression.tolerance = 0.001] - Convergence error tolerance\n * @returns {BaselineOutput}\n */\nexport function iterativePolynomialBaseline(ys, options = {}) {\n  const numberPoints = ys.length;\n  let { x, regressionOptions } = options;\n  if (!x) {\n    x = sequentialFill({ from: 0, to: numberPoints - 1, size: numberPoints });\n  }\n\n  let output = baselineCorrectionRegression(x, ys, regressionOptions);\n\n  return { baseline: output.baseline, correctedSpectrum: output.corrected };\n}\n","import { PolynomialRegression } from 'ml-regression-polynomial';\n\n/**\n * Iterative regression-based baseline correction\n * @param {Array<number>} x - Independent axis variable\n * @param {Array<number>} y - Dependent axis variable\n * @param {object} [options] - Options object\n * @param {number} [options.maxIterations = 100] - Maximum number of allowed iterations\n * @param {function} [options.Regression = PolynomialRegression] - Regression class with a predict method\n * @param {*} [options.regressionOptions] - Options for regressionFunction\n * @param {number} [options.tolerance = 0.001] - Convergence error tolerance\n * @return {{corrected: Array<number>, delta: number, iteration: number, baseline: Array<number>}}\n */\nexport function baselineCorrectionRegression(x, y, options = {}) {\n  let {\n    maxIterations = 100,\n    Regression = PolynomialRegression,\n    regressionOptions,\n    tolerance = 0.001,\n  } = options;\n\n  if (!regressionOptions && Regression === PolynomialRegression) {\n    regressionOptions = 3;\n  }\n\n  let baseline = y.slice();\n  let fitting = y.slice();\n  let oldFitting = y;\n  let iteration = 0;\n  let delta;\n  let regression;\n  while (iteration < maxIterations) {\n    // Calculate the fitting result\n    regression = new Regression(x, baseline, regressionOptions);\n\n    delta = 0;\n    for (let i = 0; i < baseline.length; i++) {\n      fitting[i] = regression.predict(x[i]);\n      if (baseline[i] > fitting[i]) {\n        baseline[i] = fitting[i];\n      }\n\n      delta += Math.abs((fitting[i] - oldFitting[i]) / oldFitting[i]);\n    }\n\n    // Stop criterion\n    if (delta < tolerance) {\n      break;\n    } else {\n      oldFitting = fitting.slice();\n      iteration++;\n    }\n  }\n\n  // removes baseline\n  let corrected = new Array(baseline.length);\n  for (let j = 0; j < baseline.length; j++) {\n    corrected[j] = y[j] - baseline[j];\n  }\n\n  return {\n    corrected,\n    delta,\n    iteration,\n    baseline,\n    regression,\n  };\n}\n","import { rollingBall } from 'ml-rolling-ball-baseline';\n\n/**\n * Rolling ball baseline correction algorithm.\n * From the abstract of (1):\n * \"This algorithm behaves equivalently to traditional polynomial backgrounds in simple spectra,\n * [...] and is considerably more robust for multiple overlapping peaks, rapidly varying background [...]\n *\n * The baseline is the trace one gets by rolling a ball below a spectrum. Algorithm has three steps:\n * Finding the minima in each window, find maxima among minima and then smooth over them by averaging.\n *\n * Algorithm described in (1), but in the implementation here the window width does not change.\n *\n * Reference:\n * (1) Kneen, M. A.; Annegarn, H. J.\n *     Algorithm for Fitting XRF, SEM and PIXE X-Ray Spectra Backgrounds.\n *     Nuclear Instruments and Methods in Physics Research Section B: Beam Interactions with Materials and Atoms 1996, 109–110, 209–213.\n *     https://doi.org/10.1016/0168-583X(95)00908-6.\n * (2) Kristian Hovde Liland, Bjørn-Helge Mevik, Roberto Canteri: baseline.\n *     https://cran.r-project.org/web/packages/baseline/index.html\n *\n * @export\n * @param {Array<number>} ys\n * @param {Object} [options={}]\n * @param {Number} [options.windowM] - width of local window for minimization/maximization, defaults to 4% of the spectrum length\n * @param {Number} [options.windowS] - width of local window for smoothing, defaults to 8% of the specturm length\n * @returns {BaselineOutput}\n */\nexport function rollingBallBaseline(ys, options = {}) {\n  const baseline = rollingBall(ys, options);\n  let corrected = new Float64Array(ys.length);\n  for (let i = 0; i < corrected.length; i++) {\n    corrected[i] = ys[i] - baseline[i];\n  }\n\n  return { baseline, correctedSpectrum: corrected };\n}\n","import { isAnyArray } from 'is-any-array';\nimport { xMean, xMaxValue, xMinValue } from 'ml-spectra-processing';\nexport function rollingBall(spectrum, options = {}) {\n    if (!isAnyArray(spectrum)) {\n        throw new Error('Spectrum must be an array');\n    }\n    if (spectrum.length === 0) {\n        throw new TypeError('Spectrum must not be empty');\n    }\n    const numberPoints = spectrum.length;\n    const maxima = new Float64Array(numberPoints);\n    const minima = new Float64Array(numberPoints);\n    const baseline = new Float64Array(numberPoints);\n    // windowM 4 percent of spectrum length\n    // windowS 8 percent of spectrum length\n    const { windowM = Math.round(numberPoints * 0.04), windowS = Math.round(numberPoints * 0.08), } = options;\n    // fi(1) in original paper\n    for (let i = 0; i < spectrum.length; i++) {\n        const windowLeft = Math.max(0, i - windowM);\n        const windowRight = Math.min(i + windowM + 1, spectrum.length);\n        minima[i] = xMinValue(spectrum, {\n            fromIndex: windowLeft,\n            toIndex: windowRight,\n        });\n    }\n    // fi in original paper\n    for (let i = 0; i < minima.length; i++) {\n        const windowLeft = Math.max(0, i - windowM);\n        const windowRight = Math.min(i + windowM + 1, minima.length);\n        maxima[i] = xMaxValue(minima, {\n            fromIndex: windowLeft,\n            toIndex: windowRight,\n        });\n    }\n    for (let i = 0; i < minima.length; i++) {\n        const windowLeft = Math.max(0, i - windowS);\n        const windowRight = Math.min(i + windowS + 1, maxima.length);\n        baseline[i] = xMean(maxima.subarray(windowLeft, windowRight));\n    }\n    return baseline;\n}\n//# sourceMappingURL=rollingBall.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 { sgg } from 'ml-savitzky-golay-generalized';\nimport { xIsEquallySpaced, xIsMonotonic, xMinMaxValues, xNoiseStandardDeviation, } from 'ml-spectra-processing';\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, } = 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 equallySpaced = xIsEquallySpaced(x);\n    if (noiseLevel === undefined) {\n        if (equallySpaced) {\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 = equallySpaced ? x[1] - x[0] : x;\n    const yData = smoothY\n        ? sgg(y, xValue, {\n            ...sgOptions,\n            derivative: 0,\n        })\n        : y;\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 { min: minY, max: maxY } = xMinMaxValues(yData);\n    if (minY > maxY || minY === maxY)\n        return [];\n    const yThreshold = minY + (maxY - minY) * minMaxRatio;\n    const dX = x[1] - x[0];\n    let lastMax = null;\n    let lastMin = null;\n    const minddY = [];\n    const intervalL = [];\n    const intervalR = [];\n    // By the intermediate value theorem We cannot find 2 consecutive maximum or minimum\n    for (let i = 1; i < yData.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        // Minimum in second derivative\n        if (ddY[i] < ddY[i - 1] && ddY[i] < ddY[i + 1]) {\n            minddY.push(i);\n        }\n    }\n    let lastK = -1;\n    const peaks = [];\n    for (const minddYIndex of minddY) {\n        const deltaX = x[minddYIndex];\n        let possible = -1;\n        let k = lastK + 1;\n        let minDistance = Number.POSITIVE_INFINITY;\n        let currentDistance = 0;\n        while (possible === -1 && k < intervalL.length) {\n            currentDistance = Math.abs(deltaX - (intervalL[k].x + intervalR[k].x) / 2);\n            if (currentDistance < (intervalR[k].x - intervalL[k].x) / 2) {\n                possible = k;\n                lastK = k;\n            }\n            ++k;\n            // Not getting closer?\n            if (currentDistance >= minDistance) {\n                break;\n            }\n            minDistance = currentDistance;\n        }\n        if (possible !== -1) {\n            if (yData[minddYIndex] > yThreshold) {\n                const width = Math.abs(intervalR[possible].x - intervalL[possible].x);\n                peaks.push({\n                    id: crypto.randomUUID(),\n                    x: deltaX,\n                    y: yData[minddYIndex],\n                    width,\n                    index: minddYIndex,\n                    ddY: ddY[minddYIndex],\n                    inflectionPoints: {\n                        from: intervalL[possible],\n                        to: intervalR[possible],\n                    },\n                });\n            }\n        }\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","/**\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","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","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","// 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_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 * 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 { 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 { 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 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 { 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 { 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","/**\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","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","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","/**\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 && 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","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';\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","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 { 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","//@ts-expect-error no type definition for baselines\nimport { airPLSBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function airPLSBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=airPLSBaseline.js.map","import airpls from 'ml-airpls';\nimport sequentialFill from 'ml-array-sequential-fill';\n/**\n * Adaptive iteratively reweighted penalized least squares [1]\n *\n * This function calls ml-airpls\n *\n * References:\n * [1] Zhang, Z.-M.; Chen, S.; Liang, Y.-Z.\n * Baseline Correction Using Adaptive Iteratively Reweighted Penalized Least Squares.\n * Analyst 2010, 135 (5), 1138–1146. https://doi.org/10.1039/B922045C.\n * @export\n * @param {Array<number>} ys\n * @param {object} [options] - Options object\n * @param {Array<number>} [options.x] Optional, Independent axis variable. If not specified, we use a linear grid\n * @param {object} [options.regression] - Options for the regression\n * @param {number} [options.regression.maxIterations = 100] - Maximum number of allowed iterations\n * @param {function} [options.regression.§Regression = PolynomialRegression] - Regression class with a predict method\n * @param {*} [options.regression.regressionOptions] - Options for regressionFunction\n * @param {number} [options.regression.tolerance = 0.001] - Convergence error tolerance\n * @returns {BaselineOutput}\n */\nexport function airPLSBaseline(ys, options = {}) {\n  const numberPoints = ys.length;\n  let { x, regressionOptions } = options;\n  if (!x) {\n    x = sequentialFill({ from: 0, to: numberPoints - 1, size: numberPoints });\n  }\n  let output = airpls(x, ys, regressionOptions);\n\n  return { baseline: output.baseline, correctedSpectrum: output.corrected };\n}\n","import { gsd } from 'ml-gsd';\nimport { xFindClosestIndex, xMean, xAdd } from 'ml-spectra-processing';\n/**\n * Filter that allows to calibrateX the x axis based on the presence of peaks\n * @param data\n * @param options\n */\nexport function calibrateX(data, options = {}) {\n    const { targetX = 0, nbPeaks = 1, from = data.x[0], to = data.x.at(-1), gsd: gsdOptions = {\n        minMaxRatio: 0.1,\n        realTopDetection: true,\n        smoothY: true,\n        sgOptions: {\n            windowSize: 7,\n            polynomial: 3,\n        },\n    }, } = options;\n    const fromIndex = xFindClosestIndex(data.x, from);\n    const toIndex = xFindClosestIndex(data.x, to);\n    const peaks = gsd({\n        x: data.x.subarray(fromIndex, toIndex),\n        y: data.y.subarray(fromIndex, toIndex),\n    }, gsdOptions)\n        .sort((a, b) => b.y - a.y)\n        .slice(0, nbPeaks);\n    if (peaks.length < nbPeaks)\n        return { data };\n    const middle = xMean(peaks.map((peak) => peak.x));\n    return { data: { x: xAdd(data.x, targetX - middle), y: data.y } };\n}\n//# sourceMappingURL=calibrateX.js.map","import { xMean } from 'ml-spectra-processing';\n/**\n * Center the mean\n * @param data\n */\nexport function centerMean(data) {\n    const { y } = data;\n    const mean = xMean(y);\n    for (let i = 0; i < y.length; i++) {\n        y[i] -= mean;\n    }\n    return { data };\n}\n//# sourceMappingURL=centerMean.js.map","import { xMedian } from 'ml-spectra-processing';\n/**\n * Center the median\n * @param data\n */\nexport function centerMedian(data) {\n    const { y } = data;\n    const median = xMedian(y);\n    for (let i = 0; i < y.length; i++) {\n        y[i] -= median;\n    }\n    return { data };\n}\n//# sourceMappingURL=centerMedian.js.map","import { xStandardDeviation } from 'ml-spectra-processing';\n/**\n * Center the mean\n * @param data\n */\nexport function divideBySD(data) {\n    const { y } = data;\n    const sd = xStandardDeviation(y);\n    for (let i = 0; i < y.length; i++) {\n        y[i] /= sd;\n    }\n    return { data };\n}\n//# sourceMappingURL=divideBySD.js.map","import { xyEnsureGrowingX } from 'ml-spectra-processing';\n/**\n * Ensure X values are strictly monotonic increasing\n * http://www-groups.mcs.st-andrews.ac.uk/~john/analysis/Lectures/L8.html\n * @param data\n */\nexport function ensureGrowing(data) {\n    return { data: xyEnsureGrowingX(data) };\n}\n//# sourceMappingURL=ensureGrowing.js.map","import { xyEquallySpaced } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function equallySpaced(data, options = {}) {\n    return { data: xyEquallySpaced(data, options) };\n}\n//# sourceMappingURL=equallySpaced.js.map","import { xyFilterX } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function filterX(data, options = {}) {\n    return {\n        data: xyFilterX(data, options),\n    };\n}\n//# sourceMappingURL=filterX.js.map","import { sgg } from 'ml-savitzky-golay-generalized';\n/**\n * Calculate the first derivative using Savitzky–Golay filter.\n * @param data\n * @param options\n */\nexport function firstDerivative(data, options = {}) {\n    const { x, y } = data;\n    return { data: { x, y: sgg(y, x, { ...options, derivative: 1 }) } };\n}\n//# sourceMappingURL=firstDerivative.js.map","import { xGetFromToIndex } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function fromTo(data, options = {}) {\n    const { fromIndex, toIndex } = xGetFromToIndex(data.x, options);\n    return {\n        data: {\n            x: data.x.subarray(fromIndex, toIndex + 1),\n            y: data.y.subarray(fromIndex, toIndex + 1),\n        },\n    };\n}\n//# sourceMappingURL=fromTo.js.map","//@ts-expect-error no type definition for baselines\nimport { iterativePolynomialBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function iterativePolynomialBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=iterativePolynomialBaseline.js.map","import { xNormed } from 'ml-spectra-processing';\n/**\n * Norm the Y values\n * @param data\n * @param options\n */\nexport function normed(data, options = {}) {\n    xNormed(data.y, { ...options, output: data.y });\n    return { data };\n}\n//# sourceMappingURL=normed.js.map","import { xParetoNormalization } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n */\nexport function paretoNormalization(data) {\n    return {\n        data: {\n            x: data.x,\n            y: xParetoNormalization(data.y),\n        },\n    };\n}\n//# sourceMappingURL=paretoNormalization.js.map","import { xRescale } from 'ml-spectra-processing';\n/**\n * Center the mean\n * @param data\n * @param options\n */\nexport function rescale(data, options = {}) {\n    xRescale(data.y, { ...options, output: data.y });\n    return { data };\n}\n//# sourceMappingURL=rescale.js.map","import { xyGrowingX } from 'ml-spectra-processing';\n/**\n * Ensure X values are strictly monotonic increasing\n * http://www-groups.mcs.st-andrews.ac.uk/~john/analysis/Lectures/L8.html\n * @param data\n */\nexport function reverseIfNeeded(data) {\n    return { data: xyGrowingX(data) };\n}\n//# sourceMappingURL=reverseIfNeeded.js.map","//@ts-expect-error no type definition for baselines\nimport { rollingAverageBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function rollingAverageBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=rollingAverageBaseline.js.map","import { xRollingAverage } from 'ml-spectra-processing';\n\n/**\n\n *\n * @export\n * @param {Array<number>} ys\n * @param {Object} [options={}]\n * @param {number} [options.window] rolling window size, defaults to 10% of the length of the spectrum\n * @param {string} [options.padding.size=window-1] none, value, circular, duplicate\n * @param {string} [options.padding.algorithm='duplicate'] none, value, circular, duplicate\n * @param {number} [options.padding.value=0] value to use for padding (if algorithm='value')\n * @returns {BaselineOutput}\n */\nexport function rollingAverageBaseline(ys, options = {}) {\n  let window = Math.max(Math.round(ys.length * 0.1), 2);\n  let defaults = {\n    window,\n    padding: {\n      size: window - 1,\n      algorithm: 'duplicate',\n      value: 0,\n    },\n  };\n  let actualOptions = { ...defaults, ...options };\n  let baseline = xRollingAverage(ys, actualOptions);\n  let corrected = new Float64Array(ys.length);\n  for (let i = 0; i < corrected.length; i++) {\n    corrected[i] = ys[i] - baseline[i];\n  }\n\n  return { baseline, correctedSpectrum: corrected };\n}\n","//@ts-expect-error no type definition for baselines\nimport { rollingBallBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function rollingBallBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=rollingBallBaseline.js.map","//@ts-expect-error no type definition for baselines\nimport { rollingMedianBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function rollingMedianBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=rollingMedianBaseline.js.map","import { xRollingMedian } from 'ml-spectra-processing';\n\n/**\n\n *\n * @export\n * @param {Array<number>} ys\n * @param {Object} [options={}]\n * @param {number} [options.window] rolling window size, defaults to 10% of the length of the spectrum\n * @param {string} [options.padding.size=window-1] none, value, circular, duplicate\n * @param {string} [options.padding.algorithm='duplicate'] none, value, circular, duplicate\n * @param {number} [options.padding.value=0] value to use for padding (if algorithm='value')\n * @returns {BaselineOutput}\n */\nexport function rollingMedianBaseline(ys, options = {}) {\n  let window = Math.max(Math.round(ys.length * 0.1), 2);\n  let defaults = {\n    window,\n    padding: {\n      size: window - 1,\n      algorithm: 'duplicate',\n      value: 0,\n    },\n  };\n  let actualOptions = { ...defaults, ...options };\n  let baseline = xRollingMedian(ys, actualOptions);\n  let corrected = new Float64Array(ys.length);\n  for (let i = 0; i < corrected.length; i++) {\n    corrected[i] = ys[i] - baseline[i];\n  }\n\n  return { baseline, correctedSpectrum: corrected };\n}\n","import { sgg } from 'ml-savitzky-golay-generalized';\n/**\n * Apply the Savitzky Golay Generalized Filter\n * @param data\n * @param options\n */\nexport function savitzkyGolay(data, options = {}) {\n    const { x, y } = data;\n    return { data: { x, y: sgg(y, x, options) } };\n}\n//# sourceMappingURL=savitzkyGolay.js.map","import { sgg } from 'ml-savitzky-golay-generalized';\n/**\n * Calculate the second derivative using Savitzky–Golay filter.\n * @param data\n * @param options\n */\nexport function secondDerivative(data, options = {}) {\n    const { x, y } = data;\n    return { data: { x, y: sgg(y, x, { ...options, derivative: 2 }) } };\n}\n//# sourceMappingURL=secondDerivative.js.map","import { xAdd, xMaxValue } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function setMaxX(data, options = {}) {\n    const { max = 1 } = options;\n    const existingMax = xMaxValue(data.x);\n    if (existingMax === max) {\n        return { data };\n    }\n    return {\n        data: {\n            x: xAdd(data.x, max - existingMax),\n            y: data.y,\n        },\n    };\n}\n//# sourceMappingURL=setMaxX.js.map","import { xAdd, xMaxValue } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function setMaxY(data, options = {}) {\n    const { max = 1 } = options;\n    const existingMax = xMaxValue(data.y);\n    if (existingMax === max) {\n        return { data };\n    }\n    return {\n        data: {\n            x: data.x,\n            y: xAdd(data.y, max - existingMax),\n        },\n    };\n}\n//# sourceMappingURL=setMaxY.js.map","import { xAdd, xMinValue } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function setMinX(data, options = {}) {\n    const { min = 0 } = options;\n    const existingMin = xMinValue(data.x);\n    if (existingMin === min) {\n        return { data };\n    }\n    return {\n        data: {\n            x: xAdd(data.x, min - existingMin),\n            y: data.y,\n        },\n    };\n}\n//# sourceMappingURL=setMinX.js.map","import { xAdd, xMinValue } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function setMinY(data, options = {}) {\n    const { min = 0 } = options;\n    const existingMin = xMinValue(data.y);\n    if (existingMin === min) {\n        return { data };\n    }\n    return {\n        data: {\n            x: data.x,\n            y: xAdd(data.y, min - existingMin),\n        },\n    };\n}\n//# sourceMappingURL=setMinY.js.map","import { sgg } from 'ml-savitzky-golay-generalized';\n/**\n * Calculate the third derivative using Savitzky–Golay filter.\n * @param data\n * @param options\n */\nexport function thirdDerivative(data, options = {}) {\n    const { x, y } = data;\n    return { data: { x, y: sgg(y, x, { ...options, derivative: 3 }) } };\n}\n//# sourceMappingURL=thirdDerivative.js.map","import { xApplyFunctionStr } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function xFunction(data, options = {}) {\n    return {\n        data: {\n            x: xApplyFunctionStr(data.x, {\n                variableLabel: 'x',\n                fctString: options.function,\n            }),\n            y: data.y,\n        },\n    };\n}\n//# sourceMappingURL=xFunction.js.map","import { xApplyFunctionStr } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function yFunction(data, options = {}) {\n    return {\n        data: {\n            x: data.x,\n            y: xApplyFunctionStr(data.y, {\n                variableLabel: 'y',\n                fctString: options.function,\n            }),\n        },\n    };\n}\n//# sourceMappingURL=yFunction.js.map","import { filterXY } from 'ml-signal-processing';\nimport { xIsMonotonic, xMaxValue, xMinValue } from 'ml-spectra-processing';\nexport function getNormalizedSpectrum(spectrum, options = {}) {\n    const data = {\n        x: spectrum.variables.x.data,\n        y: spectrum.variables.y.data,\n    };\n    const newSpectrum = {\n        variables: {\n            x: {\n                data: spectrum.variables.x.data,\n                units: spectrum.variables.x.units,\n                label: spectrum.variables.x.label,\n            },\n            y: {\n                data: spectrum.variables.y.data,\n                units: spectrum.variables.y.units,\n                label: spectrum.variables.y.label,\n            },\n        },\n    };\n    if (spectrum.title)\n        newSpectrum.title = spectrum.title;\n    if (spectrum.dataType)\n        newSpectrum.dataType = spectrum.dataType;\n    if (spectrum.meta)\n        newSpectrum.meta = spectrum.meta;\n    if (spectrum.id)\n        newSpectrum.id = spectrum.id;\n    const { from = spectrum.variables.x.min, to = spectrum.variables.x.max, numberOfPoints, exclusions = [], zones = [], } = options;\n    let { filters = [] } = options;\n    filters = structuredClone(filters);\n    if (numberOfPoints) {\n        filters.push({\n            name: 'equallySpaced',\n            options: { from, to, exclusions, zones, numberOfPoints },\n        });\n    }\n    else {\n        filters.push({\n            name: 'filterX',\n            options: { from, to, exclusions, zones },\n        });\n    }\n    const { x, y } = filterXY(data, filters).data;\n    // filters change the y axis, we get rid of the units\n    // TODO we should deal correctly with this problem\n    if (filters.length > 1) {\n        newSpectrum.variables.y.units = '';\n        newSpectrum.variables.y.label = newSpectrum.variables.y.label?.replace(/\\s*\\[.*]/, '');\n    }\n    newSpectrum.variables.x.data = x;\n    newSpectrum.variables.x.min = xMinValue(x);\n    newSpectrum.variables.x.max = xMaxValue(x);\n    newSpectrum.variables.x.isMonotonic = xIsMonotonic(x);\n    newSpectrum.variables.y.data = y;\n    newSpectrum.variables.y.min = xMinValue(y);\n    newSpectrum.variables.y.max = xMaxValue(y);\n    newSpectrum.variables.y.isMonotonic = xIsMonotonic(y);\n    return newSpectrum;\n}\n//# sourceMappingURL=getNormalizedSpectrum.js.map","import { xEnsureFloat64, xyGrowingX } from 'ml-spectra-processing';\nimport * as Filters from \"./filters/filters.js\";\n/**\n * Apply filters on {x:[], y:[]}\n * @param data\n * @param filters\n * @returns A very important number\n */\nexport function filterXY(data, filters) {\n    let result = {\n        data: xyGrowingX({ x: xEnsureFloat64(data.x), y: xEnsureFloat64(data.y) }),\n    };\n    const logs = [];\n    for (const filter of filters) {\n        const start = Date.now();\n        const filterFct = Filters[filter.name];\n        if (!filterFct) {\n            throw new Error(`Unknown filter: ${filter.name}`);\n        }\n        // @ts-expect-error some method have options and some other ones don't have any options\n        result = filterFct(result.data, filter.options);\n        result.data = xyGrowingX(result.data);\n        logs.push({\n            name: filter.name,\n            time: Date.now() - start,\n        });\n    }\n    return { logs, data: result.data };\n}\n//# sourceMappingURL=filterXY.js.map","/*\nThe MIT License (MIT)\nCopyright © 2006-2007 Kevin C. Olbrich\nCopyright © 2010-2016 LIM SAS (http://lim.eu) - Julien Sanchez\n\nPermission is hereby granted, free of charge, to any person obtaining a copy of\nthis software and associated documentation files (the \"Software\"), to deal in\nthe Software without restriction, including without limitation the rights to\nuse, copy, modify, merge, publish, distribute, sublicense, and/or sell copies\nof the Software, and to permit persons to whom the Software is furnished to do\nso, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n*/\n(function (global, factory) {\n  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n  typeof define === 'function' && define.amd ? define(factory) :\n  (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.Qty = factory());\n})(this, (function () { 'use strict';\n\n  /**\n   * Tests if a value is a string\n   *\n   * @param {*} value - Value to test\n   *\n   * @returns {boolean} true if value is a string, false otherwise\n   */\n  function isString(value) {\n    return typeof value === \"string\" || value instanceof String;\n  }\n\n  /*\n   * Prefer stricter Number.isFinite if currently supported.\n   * To be dropped when ES6 is finalized. Obsolete browsers will\n   * have to use ES6 polyfills.\n   */\n  var isFiniteImpl = Number.isFinite || window.isFinite;\n  /**\n   * Tests if a value is a number\n   *\n   * @param {*} value - Value to test\n   *\n   * @returns {boolean} true if value is a number, false otherwise\n   */\n  function isNumber(value) {\n    // Number.isFinite allows not to consider NaN or '1' as numbers\n    return isFiniteImpl(value);\n  }\n\n  /*\n   * Identity function\n   */\n  function identity(value) {\n    return value;\n  }\n\n  /**\n   * Returns unique strings from list\n   *\n   * @param {string[]} strings - array of strings\n   *\n   *\n   * @returns {string[]} a new array of strings without duplicates\n   */\n  function uniq(strings) {\n    var seen = {};\n    return strings.filter(function(item) {\n      return seen.hasOwnProperty(item) ? false : (seen[item] = true);\n    });\n  }\n\n  function compareArray(array1, array2) {\n    if (array2.length !== array1.length) {\n      return false;\n    }\n    for (var i = 0; i < array1.length; i++) {\n      if (array2[i].compareArray) {\n        if (!array2[i].compareArray(array1[i])) {\n          return false;\n        }\n      }\n      if (array2[i] !== array1[i]) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  function assign(target, properties) {\n    Object.keys(properties).forEach(function(key) {\n      target[key] = properties[key];\n    });\n  }\n\n  /**\n   * Safely multiplies numbers while avoiding floating errors\n   * like 0.1 * 0.1 => 0.010000000000000002\n   *\n   * @param {...number} numbers - numbers to multiply\n   *\n   * @returns {number} result\n   */\n  function mulSafe() {\n    var result = 1, decimals = 0;\n    for (var i = 0; i < arguments.length; i++) {\n      var arg = arguments[i];\n      decimals = decimals + getFractional(arg);\n      result *= arg;\n    }\n\n    return decimals !== 0 ? round(result, decimals) : result;\n  }\n\n  /**\n   * Safely divides two numbers while avoiding floating errors\n   * like 0.3 / 0.05 => 5.999999999999999\n   *\n   * @returns {number} result\n   * @param {number} num Numerator\n   * @param {number} den Denominator\n   */\n  function divSafe(num, den) {\n    if (den === 0) {\n      throw new Error(\"Divide by zero\");\n    }\n\n    var factor = Math.pow(10, getFractional(den));\n    var invDen = factor / (factor * den);\n\n    return mulSafe(num, invDen);\n  }\n\n  /**\n   * Rounds value at the specified number of decimals\n   *\n   * @param {number} val - value to round\n   * @param {number} decimals - number of decimals\n   *\n   * @returns {number} rounded number\n   */\n  function round(val, decimals) {\n    return Math.round(val * Math.pow(10, decimals)) / Math.pow(10, decimals);\n  }\n\n  function getFractional(num) {\n    // Check for NaNs or Infinities\n    if (!isFinite(num)) {\n      return 0;\n    }\n\n    // Faster than parsing strings\n    // http://jsperf.com/count-decimals/2\n    var count = 0;\n    while (num % 1 !== 0) {\n      num *= 10;\n      count++;\n    }\n    return count;\n  }\n\n  /**\n   * Custom error type definition\n   * @constructor\n   */\n  function QtyError() {\n    var err;\n    if (!this) { // Allows to instantiate QtyError without new()\n      err = Object.create(QtyError.prototype);\n      QtyError.apply(err, arguments);\n      return err;\n    }\n    err = Error.apply(this, arguments);\n    this.name = \"QtyError\";\n    this.message = err.message;\n    this.stack = err.stack;\n  }\n  QtyError.prototype = Object.create(Error.prototype, {constructor: { value: QtyError }});\n\n  /*\n   * Throws incompatible units error\n   * @param {string} left - units\n   * @param {string} right - units incompatible with first argument\n   * @throws \"Incompatible units\" error\n   */\n  function throwIncompatibleUnits(left, right) {\n    throw new QtyError(\"Incompatible units: \" + left + \" and \" + right);\n  }\n\n  var UNITS = {\n    /* prefixes */\n    \"<googol>\" : [[\"googol\"], 1e100, \"prefix\"],\n    \"<kibi>\"  :  [[\"Ki\",\"Kibi\",\"kibi\"], Math.pow(2,10), \"prefix\"],\n    \"<mebi>\"  :  [[\"Mi\",\"Mebi\",\"mebi\"], Math.pow(2,20), \"prefix\"],\n    \"<gibi>\"  :  [[\"Gi\",\"Gibi\",\"gibi\"], Math.pow(2,30), \"prefix\"],\n    \"<tebi>\"  :  [[\"Ti\",\"Tebi\",\"tebi\"], Math.pow(2,40), \"prefix\"],\n    \"<pebi>\"  :  [[\"Pi\",\"Pebi\",\"pebi\"], Math.pow(2,50), \"prefix\"],\n    \"<exi>\"   :  [[\"Ei\",\"Exi\",\"exi\"], Math.pow(2,60), \"prefix\"],\n    \"<zebi>\"  :  [[\"Zi\",\"Zebi\",\"zebi\"], Math.pow(2,70), \"prefix\"],\n    \"<yebi>\"  :  [[\"Yi\",\"Yebi\",\"yebi\"], Math.pow(2,80), \"prefix\"],\n    \"<yotta>\" :  [[\"Y\",\"Yotta\",\"yotta\"], 1e24, \"prefix\"],\n    \"<zetta>\" :  [[\"Z\",\"Zetta\",\"zetta\"], 1e21, \"prefix\"],\n    \"<exa>\"   :  [[\"E\",\"Exa\",\"exa\"], 1e18, \"prefix\"],\n    \"<peta>\"  :  [[\"P\",\"Peta\",\"peta\"], 1e15, \"prefix\"],\n    \"<tera>\"  :  [[\"T\",\"Tera\",\"tera\"], 1e12, \"prefix\"],\n    \"<giga>\"  :  [[\"G\",\"Giga\",\"giga\"], 1e9, \"prefix\"],\n    \"<mega>\"  :  [[\"M\",\"Mega\",\"mega\"], 1e6, \"prefix\"],\n    \"<kilo>\"  :  [[\"k\",\"kilo\"], 1e3, \"prefix\"],\n    \"<hecto>\" :  [[\"h\",\"Hecto\",\"hecto\"], 1e2, \"prefix\"],\n    \"<deca>\"  :  [[\"da\",\"Deca\",\"deca\",\"deka\"], 1e1, \"prefix\"],\n    \"<deci>\"  :  [[\"d\",\"Deci\",\"deci\"], 1e-1, \"prefix\"],\n    \"<centi>\"  : [[\"c\",\"Centi\",\"centi\"], 1e-2, \"prefix\"],\n    \"<milli>\" :  [[\"m\",\"Milli\",\"milli\"], 1e-3, \"prefix\"],\n    \"<micro>\"  : [\n      [\"u\",\"\\u03BC\"/*µ as greek letter*/,\"\\u00B5\"/*µ as micro sign*/,\"Micro\",\"mc\",\"micro\"],\n      1e-6,\n      \"prefix\"\n    ],\n    \"<nano>\"  :  [[\"n\",\"Nano\",\"nano\"], 1e-9, \"prefix\"],\n    \"<pico>\"  :  [[\"p\",\"Pico\",\"pico\"], 1e-12, \"prefix\"],\n    \"<femto>\" :  [[\"f\",\"Femto\",\"femto\"], 1e-15, \"prefix\"],\n    \"<atto>\"  :  [[\"a\",\"Atto\",\"atto\"], 1e-18, \"prefix\"],\n    \"<zepto>\" :  [[\"z\",\"Zepto\",\"zepto\"], 1e-21, \"prefix\"],\n    \"<yocto>\" :  [[\"y\",\"Yocto\",\"yocto\"], 1e-24, \"prefix\"],\n\n    \"<1>\"     :  [[\"1\", \"<1>\"], 1, \"\"],\n    /* length units */\n    \"<meter>\" :  [[\"m\",\"meter\",\"meters\",\"metre\",\"metres\"], 1.0, \"length\", [\"<meter>\"] ],\n    \"<inch>\"  :  [[\"in\",\"inch\",\"inches\",\"\\\"\"], 0.0254, \"length\", [\"<meter>\"]],\n    \"<foot>\"  :  [[\"ft\",\"foot\",\"feet\",\"'\"], 0.3048, \"length\", [\"<meter>\"]],\n    \"<yard>\"  :  [[\"yd\",\"yard\",\"yards\"], 0.9144, \"length\", [\"<meter>\"]],\n    \"<mile>\"  :  [[\"mi\",\"mile\",\"miles\"], 1609.344, \"length\", [\"<meter>\"]],\n    \"<naut-mile>\" : [[\"nmi\",\"naut-mile\"], 1852, \"length\", [\"<meter>\"]],\n    \"<league>\":  [[\"league\",\"leagues\"], 4828, \"length\", [\"<meter>\"]],\n    \"<furlong>\": [[\"furlong\",\"furlongs\"], 201.2, \"length\", [\"<meter>\"]],\n    \"<rod>\"   :  [[\"rd\",\"rod\",\"rods\"], 5.029, \"length\", [\"<meter>\"]],\n    \"<mil>\"   :  [[\"mil\",\"mils\"], 0.0000254, \"length\", [\"<meter>\"]],\n    \"<angstrom>\"  :[[\"ang\",\"angstrom\",\"angstroms\"], 1e-10, \"length\", [\"<meter>\"]],\n    \"<fathom>\" : [[\"fathom\",\"fathoms\"], 1.829, \"length\", [\"<meter>\"]],\n    \"<pica>\"  : [[\"pica\",\"picas\"], 0.00423333333, \"length\", [\"<meter>\"]],\n    \"<point>\" : [[\"pt\",\"point\",\"points\"], 0.000352777778, \"length\", [\"<meter>\"]],\n    \"<redshift>\" : [[\"z\",\"red-shift\", \"redshift\"], 1.302773e26, \"length\", [\"<meter>\"]],\n    \"<AU>\"    : [[\"AU\",\"astronomical-unit\"], 149597900000, \"length\", [\"<meter>\"]],\n    \"<light-second>\":[[\"ls\",\"light-second\"], 299792500, \"length\", [\"<meter>\"]],\n    \"<light-minute>\":[[\"lmin\",\"light-minute\"], 17987550000, \"length\", [\"<meter>\"]],\n    \"<light-year>\" : [[\"ly\",\"light-year\"], 9460528000000000, \"length\", [\"<meter>\"]],\n    \"<parsec>\"  : [[\"pc\",\"parsec\",\"parsecs\"], 30856780000000000, \"length\", [\"<meter>\"]],\n    \"<datamile>\"  :  [[\"DM\",\"datamile\"], 1828.8, \"length\", [\"<meter>\"]],\n\n    /* mass */\n    \"<kilogram>\" : [[\"kg\",\"kilogram\",\"kilograms\"], 1.0, \"mass\", [\"<kilogram>\"]],\n    \"<AMU>\" : [[\"u\",\"AMU\",\"amu\"], 1.660538921e-27, \"mass\", [\"<kilogram>\"]],\n    \"<dalton>\" : [[\"Da\",\"Dalton\",\"Daltons\",\"dalton\",\"daltons\"], 1.660538921e-27, \"mass\", [\"<kilogram>\"]],\n    \"<slug>\" : [[\"slug\",\"slugs\"], 14.5939029, \"mass\", [\"<kilogram>\"]],\n    \"<short-ton>\" : [[\"tn\",\"ton\",\"short-ton\"], 907.18474, \"mass\", [\"<kilogram>\"]],\n    \"<metric-ton>\":[[\"t\",\"tonne\",\"metric-ton\"], 1000, \"mass\", [\"<kilogram>\"]],\n    \"<carat>\" : [[\"ct\",\"carat\",\"carats\"], 0.0002, \"mass\", [\"<kilogram>\"]],\n    \"<pound>\" : [[\"lbs\",\"lb\",\"pound\",\"pounds\",\"#\"], 0.45359237, \"mass\", [\"<kilogram>\"]],\n    \"<ounce>\" : [[\"oz\",\"ounce\",\"ounces\"], 0.0283495231, \"mass\", [\"<kilogram>\"]],\n    \"<gram>\"    :  [[\"g\",\"gram\",\"grams\",\"gramme\",\"grammes\"], 1e-3, \"mass\", [\"<kilogram>\"]],\n    \"<grain>\" : [[\"grain\",\"grains\",\"gr\"], 6.479891e-5, \"mass\", [\"<kilogram>\"]],\n    \"<dram>\"  : [[\"dram\",\"drams\",\"dr\"], 0.0017718452, \"mass\",[\"<kilogram>\"]],\n    \"<stone>\" : [[\"stone\",\"stones\",\"st\"],6.35029318, \"mass\",[\"<kilogram>\"]],\n\n    /* area */\n    \"<hectare>\":[[\"hectare\"], 10000, \"area\", [\"<meter>\",\"<meter>\"]],\n    \"<acre>\":[[\"acre\",\"acres\"], 4046.85642, \"area\", [\"<meter>\",\"<meter>\"]],\n    \"<sqft>\":[[\"sqft\"], 1, \"area\", [\"<foot>\",\"<foot>\"]],\n\n    /* volume */\n    \"<liter>\" : [[\"l\",\"L\",\"liter\",\"liters\",\"litre\",\"litres\"], 0.001, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<gallon>\":  [[\"gal\",\"gallon\",\"gallons\"], 0.0037854118, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<gallon-imp>\":  [[\"galimp\",\"gallon-imp\",\"gallons-imp\"], 0.0045460900, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<quart>\":  [[\"qt\",\"quart\",\"quarts\"], 0.00094635295, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<pint>\":  [[\"pt\",\"pint\",\"pints\"], 0.000473176475, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<pint-imp>\":  [[\"ptimp\",\"pint-imp\",\"pints-imp\"], 5.6826125e-4, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<cup>\":  [[\"cu\",\"cup\",\"cups\"], 0.000236588238, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<fluid-ounce>\":  [[\"floz\",\"fluid-ounce\",\"fluid-ounces\"], 2.95735297e-5, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<fluid-ounce-imp>\":  [[\"flozimp\", \"floz-imp\",\"fluid-ounce-imp\",\"fluid-ounces-imp\"], 2.84130625e-5, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<tablespoon>\":  [[\"tb\",\"tbsp\",\"tbs\",\"tablespoon\",\"tablespoons\"], 1.47867648e-5, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<teaspoon>\":  [[\"tsp\",\"teaspoon\",\"teaspoons\"], 4.92892161e-6, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<bushel>\":  [[\"bu\",\"bsh\",\"bushel\",\"bushels\"], 0.035239072, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<oilbarrel>\":  [[\"bbl\",\"oilbarrel\", \"oilbarrels\", \"oil-barrel\",\"oil-barrels\"], 0.158987294928, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<beerbarrel>\":  [[\"bl\",\"bl-us\",\"beerbarrel\", \"beerbarrels\", \"beer-barrel\",\"beer-barrels\"], 0.1173477658, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<beerbarrel-imp>\":  [[\"blimp\",\"bl-imp\",\"beerbarrel-imp\", \"beerbarrels-imp\", \"beer-barrel-imp\",\"beer-barrels-imp\"], 0.16365924, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n\n    /* speed */\n    \"<kph>\" : [[\"kph\"], 0.277777778, \"speed\", [\"<meter>\"], [\"<second>\"]],\n    \"<mph>\" : [[\"mph\"], 0.44704, \"speed\", [\"<meter>\"], [\"<second>\"]],\n    \"<knot>\" : [[\"kt\",\"kn\",\"kts\",\"knot\",\"knots\"], 0.514444444, \"speed\", [\"<meter>\"], [\"<second>\"]],\n    \"<fps>\"  : [[\"fps\"], 0.3048, \"speed\", [\"<meter>\"], [\"<second>\"]],\n\n    /* acceleration */\n    \"<gee>\" : [[\"gee\"], 9.80665, \"acceleration\", [\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<Gal>\" : [[\"Gal\"], 1e-2, \"acceleration\", [\"<meter>\"], [\"<second>\",\"<second>\"]],\n\n    /* temperature_difference */\n    \"<kelvin>\" : [[\"degK\",\"kelvin\"], 1.0, \"temperature\", [\"<kelvin>\"]],\n    \"<celsius>\" : [[\"degC\",\"celsius\",\"celsius\",\"centigrade\"], 1.0, \"temperature\", [\"<kelvin>\"]],\n    \"<fahrenheit>\" : [[\"degF\",\"fahrenheit\"], 5 / 9, \"temperature\", [\"<kelvin>\"]],\n    \"<rankine>\" : [[\"degR\",\"rankine\"], 5 / 9, \"temperature\", [\"<kelvin>\"]],\n    \"<temp-K>\"  : [[\"tempK\",\"temp-K\"], 1.0, \"temperature\", [\"<temp-K>\"]],\n    \"<temp-C>\"  : [[\"tempC\",\"temp-C\"], 1.0, \"temperature\", [\"<temp-K>\"]],\n    \"<temp-F>\"  : [[\"tempF\",\"temp-F\"], 5 / 9, \"temperature\", [\"<temp-K>\"]],\n    \"<temp-R>\"  : [[\"tempR\",\"temp-R\"], 5 / 9, \"temperature\", [\"<temp-K>\"]],\n\n    /* time */\n    \"<second>\":  [[\"s\",\"sec\",\"secs\",\"second\",\"seconds\"], 1.0, \"time\", [\"<second>\"]],\n    \"<minute>\":  [[\"min\",\"mins\",\"minute\",\"minutes\"], 60.0, \"time\", [\"<second>\"]],\n    \"<hour>\":  [[\"h\",\"hr\",\"hrs\",\"hour\",\"hours\"], 3600.0, \"time\", [\"<second>\"]],\n    \"<day>\":  [[\"d\",\"day\",\"days\"], 3600 * 24, \"time\", [\"<second>\"]],\n    \"<week>\":  [[\"wk\",\"week\",\"weeks\"], 7 * 3600 * 24, \"time\", [\"<second>\"]],\n    \"<fortnight>\": [[\"fortnight\",\"fortnights\"], 1209600, \"time\", [\"<second>\"]],\n    \"<year>\":  [[\"y\",\"yr\",\"year\",\"years\",\"annum\"], 31556926, \"time\", [\"<second>\"]],\n    \"<decade>\":[[\"decade\",\"decades\"], 315569260, \"time\", [\"<second>\"]],\n    \"<century>\":[[\"century\",\"centuries\"], 3155692600, \"time\", [\"<second>\"]],\n\n    /* pressure */\n    \"<pascal>\" : [[\"Pa\",\"pascal\",\"Pascal\"], 1.0, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<bar>\" : [[\"bar\",\"bars\"], 100000, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<mmHg>\" : [[\"mmHg\"], 133.322368, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<inHg>\" : [[\"inHg\"], 3386.3881472, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<torr>\" : [[\"torr\"], 133.322368, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<atm>\" : [[\"atm\",\"ATM\",\"atmosphere\",\"atmospheres\"], 101325, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<psi>\" : [[\"psi\"], 6894.76, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<cmh2o>\" : [[\"cmH2O\",\"cmh2o\"], 98.0638, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<inh2o>\" : [[\"inH2O\",\"inh2o\"], 249.082052, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n\n    /* viscosity */\n    \"<poise>\"  : [[\"P\",\"poise\"], 0.1, \"viscosity\", [\"<kilogram>\"],[\"<meter>\",\"<second>\"] ],\n    \"<stokes>\" : [[\"St\",\"stokes\"], 1e-4, \"viscosity\", [\"<meter>\",\"<meter>\"], [\"<second>\"]],\n\n    /* substance */\n    \"<mole>\"  :  [[\"mol\",\"mole\"], 1.0, \"substance\", [\"<mole>\"]],\n\n    /* molar_concentration */\n    \"<molar>\" : [[\"M\",\"molar\"], 1000, \"molar_concentration\", [\"<mole>\"], [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<wtpercent>\"  : [[\"wt%\",\"wtpercent\"], 10, \"molar_concentration\", [\"<kilogram>\"], [\"<meter>\",\"<meter>\",\"<meter>\"]],\n\n    /* activity */\n    \"<katal>\" :  [[\"kat\",\"katal\",\"Katal\"], 1.0, \"activity\", [\"<mole>\"], [\"<second>\"]],\n    \"<unit>\"  :  [[\"U\",\"enzUnit\",\"unit\"], 16.667e-16, \"activity\", [\"<mole>\"], [\"<second>\"]],\n\n    /* capacitance */\n    \"<farad>\" :  [[\"F\",\"farad\",\"Farad\"], 1.0, \"capacitance\", [\"<second>\",\"<second>\",\"<second>\",\"<second>\",\"<ampere>\",\"<ampere>\"], [\"<meter>\", \"<meter>\", \"<kilogram>\"]],\n\n    /* charge */\n    \"<coulomb>\" :  [[\"C\",\"coulomb\",\"Coulomb\"], 1.0, \"charge\", [\"<ampere>\",\"<second>\"]],\n    \"<Ah>\" :  [[\"Ah\"], 3600, \"charge\", [\"<ampere>\",\"<second>\"]],\n\n    /* current */\n    \"<ampere>\"  :  [[\"A\",\"Ampere\",\"ampere\",\"amp\",\"amps\"], 1.0, \"current\", [\"<ampere>\"]],\n\n    /* conductance */\n    \"<siemens>\" : [[\"S\",\"Siemens\",\"siemens\"], 1.0, \"conductance\", [\"<second>\",\"<second>\",\"<second>\",\"<ampere>\",\"<ampere>\"], [\"<kilogram>\",\"<meter>\",\"<meter>\"]],\n\n    /* inductance */\n    \"<henry>\" :  [[\"H\",\"Henry\",\"henry\"], 1.0, \"inductance\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\",\"<ampere>\"]],\n\n    /* potential */\n    \"<volt>\"  :  [[\"V\",\"Volt\",\"volt\",\"volts\"], 1.0, \"potential\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\",\"<second>\",\"<ampere>\"]],\n\n    /* resistance */\n    \"<ohm>\" :  [\n      [\"Ohm\",\"ohm\",\"\\u03A9\"/*Ω as greek letter*/,\"\\u2126\"/*Ω as ohm sign*/],\n      1.0,\n      \"resistance\",\n      [\"<meter>\",\"<meter>\",\"<kilogram>\"],[\"<second>\",\"<second>\",\"<second>\",\"<ampere>\",\"<ampere>\"]\n    ],\n    /* magnetism */\n    \"<weber>\" : [[\"Wb\",\"weber\",\"webers\"], 1.0, \"magnetism\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\"]],\n    \"<tesla>\"  : [[\"T\",\"tesla\",\"teslas\"], 1.0, \"magnetism\", [\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\"]],\n    \"<gauss>\" : [[\"G\",\"gauss\"], 1e-4, \"magnetism\",  [\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\"]],\n    \"<maxwell>\" : [[\"Mx\",\"maxwell\",\"maxwells\"], 1e-8, \"magnetism\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\"]],\n    \"<oersted>\"  : [[\"Oe\",\"oersted\",\"oersteds\"], 250.0 / Math.PI, \"magnetism\", [\"<ampere>\"], [\"<meter>\"]],\n\n    /* energy */\n    \"<joule>\" :  [[\"J\",\"joule\",\"Joule\",\"joules\",\"Joules\"], 1.0, \"energy\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<erg>\"   :  [[\"erg\",\"ergs\"], 1e-7, \"energy\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<btu>\"   :  [[\"BTU\",\"btu\",\"BTUs\"], 1055.056, \"energy\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<calorie>\" :  [[\"cal\",\"calorie\",\"calories\"], 4.18400, \"energy\",[\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<Calorie>\" :  [[\"Cal\",\"Calorie\",\"Calories\"], 4184.00, \"energy\",[\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<therm-US>\" : [[\"th\",\"therm\",\"therms\",\"Therm\",\"therm-US\"], 105480400, \"energy\",[\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<Wh>\" : [[\"Wh\"], 3600, \"energy\",[\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<electronvolt>\" : [[\"eV\", \"electronvolt\", \"electronvolts\"], 1.602176634E-19, \"energy\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n\n    /* force */\n    \"<newton>\"  : [[\"N\",\"Newton\",\"newton\"], 1.0, \"force\", [\"<kilogram>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<dyne>\"  : [[\"dyn\",\"dyne\"], 1e-5, \"force\", [\"<kilogram>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<pound-force>\"  : [[\"lbf\",\"pound-force\"], 4.448222, \"force\", [\"<kilogram>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n\n    /* frequency */\n    \"<hertz>\" : [[\"Hz\",\"hertz\",\"Hertz\"], 1.0, \"frequency\", [\"<1>\"], [\"<second>\"]],\n\n    /* angle */\n    \"<radian>\" :[[\"rad\",\"radian\",\"radians\"], 1.0, \"angle\", [\"<radian>\"]],\n    \"<degree>\" :[[\"deg\",\"degree\",\"degrees\"], Math.PI / 180.0, \"angle\", [\"<radian>\"]],\n    \"<arcminute>\" :[[\"arcmin\",\"arcminute\",\"arcminutes\"], Math.PI / 10800.0, \"angle\", [\"<radian>\"]],\n    \"<arcsecond>\" :[[\"arcsec\",\"arcsecond\",\"arcseconds\"], Math.PI / 648000.0, \"angle\", [\"<radian>\"]],\n    \"<gradian>\"   :[[\"gon\",\"grad\",\"gradian\",\"grads\"], Math.PI / 200.0, \"angle\", [\"<radian>\"]],\n    \"<steradian>\"  : [[\"sr\",\"steradian\",\"steradians\"], 1.0, \"solid_angle\", [\"<steradian>\"]],\n\n    /* rotation */\n    \"<rotation>\" : [[\"rotation\"], 2.0 * Math.PI, \"angle\", [\"<radian>\"]],\n    \"<rpm>\"   :[[\"rpm\"], 2.0 * Math.PI / 60.0, \"angular_velocity\", [\"<radian>\"], [\"<second>\"]],\n\n    /* information */\n    \"<byte>\"  :[[\"B\",\"byte\",\"bytes\"], 1.0, \"information\", [\"<byte>\"]],\n    \"<bit>\"  :[[\"b\",\"bit\",\"bits\"], 0.125, \"information\", [\"<byte>\"]],\n\n    /* information rate */\n    \"<Bps>\" : [[\"Bps\"], 1.0, \"information_rate\", [\"<byte>\"], [\"<second>\"]],\n    \"<bps>\" : [[\"bps\"], 0.125, \"information_rate\", [\"<byte>\"], [\"<second>\"]],\n\n    /* currency */\n    \"<dollar>\":[[\"USD\",\"dollar\"], 1.0, \"currency\", [\"<dollar>\"]],\n    \"<cents>\" :[[\"cents\"], 0.01, \"currency\", [\"<dollar>\"]],\n\n    /* luminosity */\n    \"<candela>\" : [[\"cd\",\"candela\"], 1.0, \"luminosity\", [\"<candela>\"]],\n    \"<lumen>\" : [[\"lm\",\"lumen\"], 1.0, \"luminous_power\", [\"<candela>\",\"<steradian>\"]],\n    \"<lux>\" :[[\"lux\"], 1.0, \"illuminance\", [\"<candela>\",\"<steradian>\"], [\"<meter>\",\"<meter>\"]],\n\n    /* power */\n    \"<watt>\"  : [[\"W\",\"watt\",\"watts\"], 1.0, \"power\", [\"<kilogram>\",\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\",\"<second>\"]],\n    \"<volt-ampere>\"  : [[\"VA\",\"volt-ampere\"], 1.0, \"power\", [\"<kilogram>\",\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\",\"<second>\"]],\n    \"<volt-ampere-reactive>\"  : [[\"var\",\"Var\",\"VAr\",\"VAR\",\"volt-ampere-reactive\"], 1.0, \"power\", [\"<kilogram>\",\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\",\"<second>\"]],\n    \"<horsepower>\"  :  [[\"hp\",\"horsepower\"], 745.699872, \"power\", [\"<kilogram>\",\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\",\"<second>\"]],\n\n    /* radiation */\n    \"<gray>\" : [[\"Gy\",\"gray\",\"grays\"], 1.0, \"radiation\", [\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<roentgen>\" : [[\"R\",\"roentgen\"], 0.009330, \"radiation\", [\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<sievert>\" : [[\"Sv\",\"sievert\",\"sieverts\"], 1.0, \"radiation\", [\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<becquerel>\" : [[\"Bq\",\"becquerel\",\"becquerels\"], 1.0, \"radiation\", [\"<1>\"],[\"<second>\"]],\n    \"<curie>\" : [[\"Ci\",\"curie\",\"curies\"], 3.7e10, \"radiation\", [\"<1>\"],[\"<second>\"]],\n\n    /* rate */\n    \"<cpm>\" : [[\"cpm\"], 1.0 / 60.0, \"rate\", [\"<count>\"],[\"<second>\"]],\n    \"<dpm>\" : [[\"dpm\"], 1.0 / 60.0, \"rate\", [\"<count>\"],[\"<second>\"]],\n    \"<bpm>\" : [[\"bpm\"], 1.0 / 60.0, \"rate\", [\"<count>\"],[\"<second>\"]],\n\n    /* resolution / typography */\n    \"<dot>\" : [[\"dot\",\"dots\"], 1, \"resolution\", [\"<each>\"]],\n    \"<pixel>\" : [[\"pixel\",\"px\"], 1, \"resolution\", [\"<each>\"]],\n    \"<ppi>\" : [[\"ppi\"], 1, \"resolution\", [\"<pixel>\"], [\"<inch>\"]],\n    \"<dpi>\" : [[\"dpi\"], 1, \"typography\", [\"<dot>\"], [\"<inch>\"]],\n\n    /* other */\n    \"<cell>\" : [[\"cells\",\"cell\"], 1, \"counting\", [\"<each>\"]],\n    \"<each>\" : [[\"each\"], 1.0, \"counting\", [\"<each>\"]],\n    \"<count>\" : [[\"count\"], 1.0, \"counting\", [\"<each>\"]],\n    \"<base-pair>\"  : [[\"bp\",\"base-pair\"], 1.0, \"counting\", [\"<each>\"]],\n    \"<nucleotide>\" : [[\"nt\",\"nucleotide\"], 1.0, \"counting\", [\"<each>\"]],\n    \"<molecule>\" : [[\"molecule\",\"molecules\"], 1.0, \"counting\", [\"<1>\"]],\n    \"<dozen>\" :  [[\"doz\",\"dz\",\"dozen\"],12.0,\"prefix_only\", [\"<each>\"]],\n    \"<percent>\": [[\"%\",\"percent\"], 0.01, \"prefix_only\", [\"<1>\"]],\n    \"<ppm>\" :  [[\"ppm\"],1e-6, \"prefix_only\", [\"<1>\"]],\n    \"<ppb>\" :  [[\"ppb\"],1e-9, \"prefix_only\", [\"<1>\"]],\n    \"<ppt>\" :  [[\"ppt\"],1e-12, \"prefix_only\", [\"<1>\"]],\n    \"<ppq>\" :  [[\"ppq\"],1e-15, \"prefix_only\", [\"<1>\"]],\n    \"<gross>\" :  [[\"gr\",\"gross\"],144.0, \"prefix_only\", [\"<dozen>\",\"<dozen>\"]],\n    \"<decibel>\"  : [[\"dB\",\"decibel\",\"decibels\"], 1.0, \"logarithmic\", [\"<decibel>\"]]\n  };\n\n  var BASE_UNITS = [\"<meter>\",\"<kilogram>\",\"<second>\",\"<mole>\", \"<ampere>\",\"<radian>\",\"<kelvin>\",\"<temp-K>\",\"<byte>\",\"<dollar>\",\"<candela>\",\"<each>\",\"<steradian>\",\"<decibel>\"];\n\n  var UNITY = \"<1>\";\n  var UNITY_ARRAY = [UNITY];\n\n  // Setup\n\n  /**\n   * Asserts unit definition is valid\n   *\n   * @param {string} unitDef - Name of unit to test\n   * @param {Object} definition - Definition of unit to test\n   *\n   * @returns {void}\n   * @throws {QtyError} if unit definition is not valid\n   */\n  function validateUnitDefinition(unitDef, definition) {\n    var scalar = definition[1];\n    var numerator = definition[3] || [];\n    var denominator = definition[4] || [];\n    if (!isNumber(scalar)) {\n      throw new QtyError(unitDef + \": Invalid unit definition. \" +\n                         \"'scalar' must be a number\");\n    }\n\n    numerator.forEach(function(unit) {\n      if (UNITS[unit] === undefined) {\n        throw new QtyError(unitDef + \": Invalid unit definition. \" +\n                           \"Unit \" + unit + \" in 'numerator' is not recognized\");\n      }\n    });\n\n    denominator.forEach(function(unit) {\n      if (UNITS[unit] === undefined) {\n        throw new QtyError(unitDef + \": Invalid unit definition. \" +\n                           \"Unit \" + unit + \" in 'denominator' is not recognized\");\n      }\n    });\n  }\n\n  var PREFIX_VALUES = {};\n  var PREFIX_MAP = {};\n  var UNIT_VALUES = {};\n  var UNIT_MAP = {};\n  var OUTPUT_MAP = {};\n  for (var unitDef in UNITS) {\n    if (UNITS.hasOwnProperty(unitDef)) {\n      var definition = UNITS[unitDef];\n      if (definition[2] === \"prefix\") {\n        PREFIX_VALUES[unitDef] = definition[1];\n        for (var i = 0; i < definition[0].length; i++) {\n          PREFIX_MAP[definition[0][i]] = unitDef;\n        }\n      }\n      else {\n        validateUnitDefinition(unitDef, definition);\n        UNIT_VALUES[unitDef] = {\n          scalar: definition[1],\n          numerator: definition[3],\n          denominator: definition[4]\n        };\n        for (var j = 0; j < definition[0].length; j++) {\n          UNIT_MAP[definition[0][j]] = unitDef;\n        }\n      }\n      OUTPUT_MAP[unitDef] = definition[0][0];\n    }\n  }\n\n  /**\n   * Returns a list of available units of kind\n   *\n   * @param {string} [kind] - kind of units\n   * @returns {array} names of units\n   * @throws {QtyError} if kind is unknown\n   */\n  function getUnits(kind) {\n    var i;\n    var units = [];\n    var unitKeys = Object.keys(UNITS);\n    if (typeof kind === \"undefined\") {\n      for (i = 0; i < unitKeys.length; i++) {\n        if ([\"\", \"prefix\"].indexOf(UNITS[unitKeys[i]][2]) === -1) {\n          units.push(unitKeys[i].substr(1, unitKeys[i].length - 2));\n        }\n      }\n    }\n    else if (this.getKinds().indexOf(kind) === -1) {\n      throw new QtyError(\"Kind not recognized\");\n    }\n    else {\n      for (i = 0; i < unitKeys.length; i++) {\n        if (UNITS[unitKeys[i]][2] === kind) {\n          units.push(unitKeys[i].substr(1, unitKeys[i].length - 2));\n        }\n      }\n    }\n\n    return units.sort(function(a, b) {\n      if (a.toLowerCase() < b.toLowerCase()) {\n        return -1;\n      }\n      if (a.toLowerCase() > b.toLowerCase()) {\n        return 1;\n      }\n      return 0;\n    });\n  }\n\n  /**\n   * Returns a list of alternative names for a unit\n   *\n   * @param {string} unitName - name of unit\n   * @returns {string[]} aliases for unit\n   * @throws {QtyError} if unit is unknown\n   */\n  function getAliases(unitName) {\n    if (!UNIT_MAP[unitName]) {\n      throw new QtyError(\"Unit not recognized\");\n    }\n    return UNITS[UNIT_MAP[unitName]][0];\n  }\n\n  var SIGNATURE_VECTOR = [\"length\", \"time\", \"temperature\", \"mass\", \"current\", \"substance\", \"luminosity\", \"currency\", \"information\", \"angle\"];\n\n  /*\n  calculates the unit signature id for use in comparing compatible units and simplification\n  the signature is based on a simple classification of units and is based on the following publication\n\n  Novak, G.S., Jr. \"Conversion of units of measurement\", IEEE Transactions on Software Engineering,\n  21(8), Aug 1995, pp.651-661\n  doi://10.1109/32.403789\n  http://ieeexplore.ieee.org/Xplore/login.jsp?url=/iel1/32/9079/00403789.pdf?isnumber=9079&prod=JNL&arnumber=403789&arSt=651&ared=661&arAuthor=Novak%2C+G.S.%2C+Jr.\n  */\n  function unitSignature() {\n    if (this.signature) {\n      return this.signature;\n    }\n    var vector = unitSignatureVector.call(this);\n    for (var i = 0; i < vector.length; i++) {\n      vector[i] *= Math.pow(20, i);\n    }\n\n    return vector.reduce(\n      function(previous, current) {\n        return previous + current;\n      },\n      0\n    );\n  }\n\n  // calculates the unit signature vector used by unit_signature\n  function unitSignatureVector() {\n    if (!this.isBase()) {\n      return unitSignatureVector.call(this.toBase());\n    }\n\n    var vector = new Array(SIGNATURE_VECTOR.length);\n    for (var i = 0; i < vector.length; i++) {\n      vector[i] = 0;\n    }\n    var r, n;\n    for (var j = 0; j < this.numerator.length; j++) {\n      if ((r = UNITS[this.numerator[j]])) {\n        n = SIGNATURE_VECTOR.indexOf(r[2]);\n        if (n >= 0) {\n          vector[n] = vector[n] + 1;\n        }\n      }\n    }\n\n    for (var k = 0; k < this.denominator.length; k++) {\n      if ((r = UNITS[this.denominator[k]])) {\n        n = SIGNATURE_VECTOR.indexOf(r[2]);\n        if (n >= 0) {\n          vector[n] = vector[n] - 1;\n        }\n      }\n    }\n    return vector;\n  }\n\n  var SIGN = \"[+-]\";\n  var INTEGER = \"\\\\d+\";\n  var SIGNED_INTEGER = SIGN + \"?\" + INTEGER;\n  var FRACTION = \"\\\\.\" + INTEGER;\n  var FLOAT = \"(?:\" + INTEGER + \"(?:\" + FRACTION + \")?\" + \")\" +\n              \"|\" +\n              \"(?:\" + FRACTION + \")\";\n  var EXPONENT = \"[Ee]\" + SIGNED_INTEGER;\n  var SCI_NUMBER = \"(?:\" + FLOAT + \")(?:\" + EXPONENT + \")?\";\n  var SIGNED_NUMBER = SIGN + \"?\\\\s*\" + SCI_NUMBER;\n  var QTY_STRING = \"(\" + SIGNED_NUMBER + \")?\" + \"\\\\s*([^/]*)(?:\\/(.+))?\";\n  var QTY_STRING_REGEX = new RegExp(\"^\" + QTY_STRING + \"$\");\n\n  var POWER_OP = \"\\\\^|\\\\*{2}\";\n  // Allow unit powers representing scalar, length, area, volume; 4 is for some\n  // special case representations in SI base units.\n  var SAFE_POWER = \"[01234]\";\n  var TOP_REGEX = new RegExp (\"([^ \\\\*\\\\d]+?)(?:\" + POWER_OP + \")?(-?\" + SAFE_POWER + \"(?![a-zA-Z]))\");\n  var BOTTOM_REGEX = new RegExp(\"([^ \\\\*\\\\d]+?)(?:\" + POWER_OP + \")?(\" + SAFE_POWER + \"(?![a-zA-Z]))\");\n\n  /* parse a string into a unit object.\n   * Typical formats like :\n   * \"5.6 kg*m/s^2\"\n   * \"5.6 kg*m*s^-2\"\n   * \"5.6 kilogram*meter*second^-2\"\n   * \"2.2 kPa\"\n   * \"37 degC\"\n   * \"1\"  -- creates a unitless constant with value 1\n   * \"GPa\"  -- creates a unit with scalar 1 with units 'GPa'\n   * 6'4\"  -- recognized as 6 feet + 4 inches\n   * 8 lbs 8 oz -- recognized as 8 lbs + 8 ounces\n   */\n  function parse(val) {\n    if (!isString(val)) {\n      val = val.toString();\n    }\n    val = val.trim();\n\n    var result = QTY_STRING_REGEX.exec(val);\n    if (!result) {\n      throw new QtyError(val + \": Quantity not recognized\");\n    }\n\n    var scalarMatch = result[1];\n    if (scalarMatch) {\n      // Allow whitespaces between sign and scalar for loose parsing\n      scalarMatch = scalarMatch.replace(/\\s/g, \"\");\n      this.scalar = parseFloat(scalarMatch);\n    }\n    else {\n      this.scalar = 1;\n    }\n    var top = result[2];\n    var bottom = result[3];\n\n    var n, x, nx;\n    // TODO DRY me\n    while ((result = TOP_REGEX.exec(top))) {\n      n = parseFloat(result[2]);\n      if (isNaN(n)) {\n        // Prevents infinite loops\n        throw new QtyError(\"Unit exponent is not a number\");\n      }\n      // Disallow unrecognized unit even if exponent is 0\n      if (n === 0 && !UNIT_TEST_REGEX.test(result[1])) {\n        throw new QtyError(\"Unit not recognized\");\n      }\n      x = result[1] + \" \";\n      nx = \"\";\n      for (var i = 0; i < Math.abs(n) ; i++) {\n        nx += x;\n      }\n      if (n >= 0) {\n        top = top.replace(result[0], nx);\n      }\n      else {\n        bottom = bottom ? bottom + nx : nx;\n        top = top.replace(result[0], \"\");\n      }\n    }\n\n    while ((result = BOTTOM_REGEX.exec(bottom))) {\n      n = parseFloat(result[2]);\n      if (isNaN(n)) {\n        // Prevents infinite loops\n        throw new QtyError(\"Unit exponent is not a number\");\n      }\n      // Disallow unrecognized unit even if exponent is 0\n      if (n === 0 && !UNIT_TEST_REGEX.test(result[1])) {\n        throw new QtyError(\"Unit not recognized\");\n      }\n      x = result[1] + \" \";\n      nx = \"\";\n      for (var j = 0; j < n ; j++) {\n        nx += x;\n      }\n\n      bottom = bottom.replace(result[0], nx);\n    }\n\n    if (top) {\n      this.numerator = parseUnits(top.trim());\n    }\n    if (bottom) {\n      this.denominator = parseUnits(bottom.trim());\n    }\n  }\n\n  var PREFIX_REGEX = Object.keys(PREFIX_MAP).sort(function(a, b) {\n    return b.length - a.length;\n  }).join(\"|\");\n  var UNIT_REGEX = Object.keys(UNIT_MAP).sort(function(a, b) {\n    return b.length - a.length;\n  }).join(\"|\");\n  /*\n   * Minimal boundary regex to support units with Unicode characters\n   * \\b only works for ASCII\n   */\n  var BOUNDARY_REGEX = \"\\\\b|$\";\n  var UNIT_MATCH = \"(\" + PREFIX_REGEX + \")??(\" +\n                   UNIT_REGEX +\n                   \")(?:\" + BOUNDARY_REGEX + \")\";\n  var UNIT_TEST_REGEX = new RegExp(\"^\\\\s*(\" + UNIT_MATCH + \"[\\\\s\\\\*]*)+$\");\n  var UNIT_MATCH_REGEX = new RegExp(UNIT_MATCH, \"g\"); // g flag for multiple occurences\n  var parsedUnitsCache = {};\n  /**\n   * Parses and converts units string to normalized unit array.\n   * Result is cached to speed up next calls.\n   *\n   * @param {string} units Units string\n   * @returns {string[]} Array of normalized units\n   *\n   * @example\n   * // Returns [\"<second>\", \"<meter>\", \"<second>\"]\n   * parseUnits(\"s m s\");\n   *\n   */\n  function parseUnits(units) {\n    var cached = parsedUnitsCache[units];\n    if (cached) {\n      return cached;\n    }\n\n    var unitMatch, normalizedUnits = [];\n\n    // Scan\n    if (!UNIT_TEST_REGEX.test(units)) {\n      throw new QtyError(\"Unit not recognized\");\n    }\n\n    while ((unitMatch = UNIT_MATCH_REGEX.exec(units))) {\n      normalizedUnits.push(unitMatch.slice(1));\n    }\n\n    normalizedUnits = normalizedUnits.map(function(item) {\n      return PREFIX_MAP[item[0]] ? [PREFIX_MAP[item[0]], UNIT_MAP[item[1]]] : [UNIT_MAP[item[1]]];\n    });\n\n    // Flatten and remove null elements\n    normalizedUnits = normalizedUnits.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n    normalizedUnits = normalizedUnits.filter(function(item) {\n      return item;\n    });\n\n    parsedUnitsCache[units] = normalizedUnits;\n\n    return normalizedUnits;\n  }\n\n  /**\n   * Parses a string as a quantity\n   * @param {string} value - quantity as text\n   * @throws if value is not a string\n   * @returns {Qty|null} Parsed quantity or null if unrecognized\n   */\n  function globalParse(value) {\n    if (!isString(value)) {\n      throw new QtyError(\"Argument should be a string\");\n    }\n\n    try {\n      return this(value);\n    }\n    catch (e) {\n      return null;\n    }\n  }\n\n  /**\n   * Tests if a value is a Qty instance\n   *\n   * @param {*} value - Value to test\n   *\n   * @returns {boolean} true if value is a Qty instance, false otherwise\n   */\n  function isQty(value) {\n    return value instanceof Qty;\n  }\n\n  function Qty(initValue, initUnits) {\n    assertValidConstructorArgs.apply(null, arguments);\n\n    if (!(isQty(this))) {\n      return new Qty(initValue, initUnits);\n    }\n\n    this.scalar = null;\n    this.baseScalar = null;\n    this.signature = null;\n    this._conversionCache = {};\n    this.numerator = UNITY_ARRAY;\n    this.denominator = UNITY_ARRAY;\n\n    if (isDefinitionObject(initValue)) {\n      this.scalar = initValue.scalar;\n      this.numerator = (initValue.numerator && initValue.numerator.length !== 0) ? initValue.numerator : UNITY_ARRAY;\n      this.denominator = (initValue.denominator && initValue.denominator.length !== 0) ? initValue.denominator : UNITY_ARRAY;\n    }\n    else if (initUnits) {\n      parse.call(this, initUnits);\n      this.scalar = initValue;\n    }\n    else {\n      parse.call(this, initValue);\n    }\n\n    // math with temperatures is very limited\n    if (this.denominator.join(\"*\").indexOf(\"temp\") >= 0) {\n      throw new QtyError(\"Cannot divide with temperatures\");\n    }\n    if (this.numerator.join(\"*\").indexOf(\"temp\") >= 0) {\n      if (this.numerator.length > 1) {\n        throw new QtyError(\"Cannot multiply by temperatures\");\n      }\n      if (!compareArray(this.denominator, UNITY_ARRAY)) {\n        throw new QtyError(\"Cannot divide with temperatures\");\n      }\n    }\n\n    this.initValue = initValue;\n    updateBaseScalar.call(this);\n\n    if (this.isTemperature() && this.baseScalar < 0) {\n      throw new QtyError(\"Temperatures must not be less than absolute zero\");\n    }\n  }\n\n  Qty.prototype = {\n    // Properly set up constructor\n    constructor: Qty,\n  };\n\n  /**\n   * Asserts constructor arguments are valid\n   *\n   * @param {*} value - Value to test\n   * @param {string} [units] - Optional units when value is passed as a number\n   *\n   * @returns {void}\n   * @throws {QtyError} if constructor arguments are invalid\n   */\n  function assertValidConstructorArgs(value, units) {\n    if (units) {\n      if (!(isNumber(value) && isString(units))) {\n        throw new QtyError(\"Only number accepted as initialization value \" +\n                           \"when units are explicitly provided\");\n      }\n    }\n    else {\n      if (!(isString(value) ||\n            isNumber(value) ||\n            isQty(value)    ||\n            isDefinitionObject(value))) {\n        throw new QtyError(\"Only string, number or quantity accepted as \" +\n                           \"single initialization value\");\n      }\n    }\n  }\n\n  /**\n   * Tests if a value is a Qty definition object\n   *\n   * @param {*} value - Value to test\n   *\n   * @returns {boolean} true if value is a definition object, false otherwise\n   */\n  function isDefinitionObject(value) {\n    return value && typeof value === \"object\" && value.hasOwnProperty(\"scalar\");\n  }\n\n  function updateBaseScalar() {\n    if (this.baseScalar) {\n      return this.baseScalar;\n    }\n    if (this.isBase()) {\n      this.baseScalar = this.scalar;\n      this.signature = unitSignature.call(this);\n    }\n    else {\n      var base = this.toBase();\n      this.baseScalar = base.scalar;\n      this.signature = base.signature;\n    }\n  }\n\n  var KINDS = {\n    \"-312078\": \"elastance\",\n    \"-312058\": \"resistance\",\n    \"-312038\": \"inductance\",\n    \"-152058\": \"potential\",\n    \"-152040\": \"magnetism\",\n    \"-152038\": \"magnetism\",\n    \"-7997\": \"specific_volume\",\n    \"-79\": \"snap\",\n    \"-59\": \"jolt\",\n    \"-39\": \"acceleration\",\n    \"-38\": \"radiation\",\n    \"-20\": \"frequency\",\n    \"-19\": \"speed\",\n    \"-18\": \"viscosity\",\n    \"-17\": \"volumetric_flow\",\n    \"-1\": \"wavenumber\",\n    \"0\": \"unitless\",\n    \"1\": \"length\",\n    \"2\": \"area\",\n    \"3\": \"volume\",\n    \"20\": \"time\",\n    \"400\": \"temperature\",\n    \"7941\": \"yank\",\n    \"7942\": \"power\",\n    \"7959\": \"pressure\",\n    \"7961\": \"force\",\n    \"7962\": \"energy\",\n    \"7979\": \"viscosity\",\n    \"7981\": \"momentum\",\n    \"7982\": \"angular_momentum\",\n    \"7997\": \"density\",\n    \"7998\": \"area_density\",\n    \"8000\": \"mass\",\n    \"152020\": \"radiation_exposure\",\n    \"159999\": \"magnetism\",\n    \"160000\": \"current\",\n    \"160020\": \"charge\",\n    \"312058\": \"conductance\",\n    \"312078\": \"capacitance\",\n    \"3199980\": \"activity\",\n    \"3199997\": \"molar_concentration\",\n    \"3200000\": \"substance\",\n    \"63999998\": \"illuminance\",\n    \"64000000\": \"luminous_power\",\n    \"1280000000\": \"currency\",\n    \"25599999980\": \"information_rate\",\n    \"25600000000\": \"information\",\n    \"511999999980\": \"angular_velocity\",\n    \"512000000000\": \"angle\"\n  };\n\n  /**\n   * Returns the list of available well-known kinds of units, e.g.\n   * \"radiation\" or \"length\".\n   *\n   * @returns {string[]} names of kinds of units\n   */\n  function getKinds() {\n    return uniq(Object.keys(KINDS).map(function(knownSignature) {\n      return KINDS[knownSignature];\n    }));\n  }\n\n  Qty.prototype.kind = function() {\n    return KINDS[this.signature.toString()];\n  };\n\n  assign(Qty.prototype, {\n    isDegrees: function() {\n      // signature may not have been calculated yet\n      return (this.signature === null || this.signature === 400) &&\n        this.numerator.length === 1 &&\n        compareArray(this.denominator, UNITY_ARRAY) &&\n        (this.numerator[0].match(/<temp-[CFRK]>/) || this.numerator[0].match(/<(kelvin|celsius|rankine|fahrenheit)>/));\n    },\n\n    isTemperature: function() {\n      return this.isDegrees() && this.numerator[0].match(/<temp-[CFRK]>/);\n    }\n  });\n\n  function subtractTemperatures(lhs,rhs) {\n    var lhsUnits = lhs.units();\n    var rhsConverted = rhs.to(lhsUnits);\n    var dstDegrees = Qty(getDegreeUnits(lhsUnits));\n    return Qty({\"scalar\": lhs.scalar - rhsConverted.scalar, \"numerator\": dstDegrees.numerator, \"denominator\": dstDegrees.denominator});\n  }\n\n  function subtractTempDegrees(temp,deg) {\n    var tempDegrees = deg.to(getDegreeUnits(temp.units()));\n    return Qty({\"scalar\": temp.scalar - tempDegrees.scalar, \"numerator\": temp.numerator, \"denominator\": temp.denominator});\n  }\n\n  function addTempDegrees(temp,deg) {\n    var tempDegrees = deg.to(getDegreeUnits(temp.units()));\n    return Qty({\"scalar\": temp.scalar + tempDegrees.scalar, \"numerator\": temp.numerator, \"denominator\": temp.denominator});\n  }\n\n  function getDegreeUnits(units) {\n    if (units === \"tempK\") {\n      return \"degK\";\n    }\n    else if (units === \"tempC\") {\n      return \"degC\";\n    }\n    else if (units === \"tempF\") {\n      return \"degF\";\n    }\n    else if (units === \"tempR\") {\n      return \"degR\";\n    }\n    else {\n      throw new QtyError(\"Unknown type for temp conversion from: \" + units);\n    }\n  }\n\n  function toDegrees(src,dst) {\n    var srcDegK = toDegK(src);\n    var dstUnits = dst.units();\n    var dstScalar;\n\n    if (dstUnits === \"degK\") {\n      dstScalar = srcDegK.scalar;\n    }\n    else if (dstUnits === \"degC\") {\n      dstScalar = srcDegK.scalar ;\n    }\n    else if (dstUnits === \"degF\") {\n      dstScalar = srcDegK.scalar * 9 / 5;\n    }\n    else if (dstUnits === \"degR\") {\n      dstScalar = srcDegK.scalar * 9 / 5;\n    }\n    else {\n      throw new QtyError(\"Unknown type for degree conversion to: \" + dstUnits);\n    }\n\n    return Qty({\"scalar\": dstScalar, \"numerator\": dst.numerator, \"denominator\": dst.denominator});\n  }\n\n  function toDegK(qty) {\n    var units = qty.units();\n    var q;\n    if (units.match(/(deg)[CFRK]/)) {\n      q = qty.baseScalar;\n    }\n    else if (units === \"tempK\") {\n      q = qty.scalar;\n    }\n    else if (units === \"tempC\") {\n      q = qty.scalar;\n    }\n    else if (units === \"tempF\") {\n      q = qty.scalar * 5 / 9;\n    }\n    else if (units === \"tempR\") {\n      q = qty.scalar * 5 / 9;\n    }\n    else {\n      throw new QtyError(\"Unknown type for temp conversion from: \" + units);\n    }\n\n    return Qty({\"scalar\": q, \"numerator\": [\"<kelvin>\"], \"denominator\": UNITY_ARRAY});\n  }\n\n  function toTemp(src,dst) {\n    var dstUnits = dst.units();\n    var dstScalar;\n\n    if (dstUnits === \"tempK\") {\n      dstScalar = src.baseScalar;\n    }\n    else if (dstUnits === \"tempC\") {\n      dstScalar = src.baseScalar - 273.15;\n    }\n    else if (dstUnits === \"tempF\") {\n      dstScalar = (src.baseScalar * 9 / 5) - 459.67;\n    }\n    else if (dstUnits === \"tempR\") {\n      dstScalar = src.baseScalar * 9 / 5;\n    }\n    else {\n      throw new QtyError(\"Unknown type for temp conversion to: \" + dstUnits);\n    }\n\n    return Qty({\"scalar\": dstScalar, \"numerator\": dst.numerator, \"denominator\": dst.denominator});\n  }\n\n  function toTempK(qty) {\n    var units = qty.units();\n    var q;\n    if (units.match(/(deg)[CFRK]/)) {\n      q = qty.baseScalar;\n    }\n    else if (units === \"tempK\") {\n      q = qty.scalar;\n    }\n    else if (units === \"tempC\") {\n      q = qty.scalar + 273.15;\n    }\n    else if (units === \"tempF\") {\n      q = (qty.scalar + 459.67) * 5 / 9;\n    }\n    else if (units === \"tempR\") {\n      q = qty.scalar * 5 / 9;\n    }\n    else {\n      throw new QtyError(\"Unknown type for temp conversion from: \" + units);\n    }\n\n    return Qty({\"scalar\": q, \"numerator\": [\"<temp-K>\"], \"denominator\": UNITY_ARRAY});\n  }\n\n  assign(Qty.prototype, {\n    /**\n     * Converts to other compatible units.\n     * Instance's converted quantities are cached for faster subsequent calls.\n     *\n     * @param {(string|Qty)} other - Target units as string or retrieved from\n     *                               other Qty instance (scalar is ignored)\n     *\n     * @returns {Qty} New converted Qty instance with target units\n     *\n     * @throws {QtyError} if target units are incompatible\n     *\n     * @example\n     * var weight = Qty(\"25 kg\");\n     * weight.to(\"lb\"); // => Qty(\"55.11556554621939 lbs\");\n     * weight.to(Qty(\"3 g\")); // => Qty(\"25000 g\"); // scalar of passed Qty is ignored\n     */\n    to: function(other) {\n      var cached, target;\n\n      if (other === undefined || other === null) {\n        return this;\n      }\n\n      if (!isString(other)) {\n        return this.to(other.units());\n      }\n\n      cached = this._conversionCache[other];\n      if (cached) {\n        return cached;\n      }\n\n      // Instantiating target to normalize units\n      target = Qty(other);\n      if (target.units() === this.units()) {\n        return this;\n      }\n\n      if (!this.isCompatible(target)) {\n        if (this.isInverse(target)) {\n          target = this.inverse().to(other);\n        }\n        else {\n          throwIncompatibleUnits(this.units(), target.units());\n        }\n      }\n      else {\n        if (target.isTemperature()) {\n          target = toTemp(this,target);\n        }\n        else if (target.isDegrees()) {\n          target = toDegrees(this,target);\n        }\n        else {\n          var q = divSafe(this.baseScalar, target.baseScalar);\n          target = Qty({\"scalar\": q, \"numerator\": target.numerator, \"denominator\": target.denominator});\n        }\n      }\n\n      this._conversionCache[other] = target;\n      return target;\n    },\n\n    // convert to base SI units\n    // results of the conversion are cached so subsequent calls to this will be fast\n    toBase: function() {\n      if (this.isBase()) {\n        return this;\n      }\n\n      if (this.isTemperature()) {\n        return toTempK(this);\n      }\n\n      var cached = baseUnitCache[this.units()];\n      if (!cached) {\n        cached = toBaseUnits(this.numerator,this.denominator);\n        baseUnitCache[this.units()] = cached;\n      }\n      return cached.mul(this.scalar);\n    },\n\n    // Converts the unit back to a float if it is unitless.  Otherwise raises an exception\n    toFloat: function() {\n      if (this.isUnitless()) {\n        return this.scalar;\n      }\n      throw new QtyError(\"Can't convert to Float unless unitless.  Use Unit#scalar\");\n    },\n\n    /**\n     * Returns the nearest multiple of quantity passed as\n     * precision\n     *\n     * @param {(Qty|string|number)} precQuantity - Quantity, string formated\n     *   quantity or number as expected precision\n     *\n     * @returns {Qty} Nearest multiple of precQuantity\n     *\n     * @example\n     * Qty('5.5 ft').toPrec('2 ft'); // returns 6 ft\n     * Qty('0.8 cu').toPrec('0.25 cu'); // returns 0.75 cu\n     * Qty('6.3782 m').toPrec('cm'); // returns 6.38 m\n     * Qty('1.146 MPa').toPrec('0.1 bar'); // returns 1.15 MPa\n     *\n     */\n    toPrec: function(precQuantity) {\n      if (isString(precQuantity)) {\n        precQuantity = Qty(precQuantity);\n      }\n      if (isNumber(precQuantity)) {\n        precQuantity = Qty(precQuantity + \" \" + this.units());\n      }\n\n      if (!this.isUnitless()) {\n        precQuantity = precQuantity.to(this.units());\n      }\n      else if (!precQuantity.isUnitless()) {\n        throwIncompatibleUnits(this.units(), precQuantity.units());\n      }\n\n      if (precQuantity.scalar === 0) {\n        throw new QtyError(\"Divide by zero\");\n      }\n\n      var precRoundedResult = mulSafe(\n        Math.round(this.scalar / precQuantity.scalar),\n        precQuantity.scalar\n      );\n\n      return Qty(precRoundedResult + this.units());\n    }\n  });\n\n  /**\n   * Configures and returns a fast function to convert\n   * Number values from units to others.\n   * Useful to efficiently convert large array of values\n   * with same units into others with iterative methods.\n   * Does not take care of rounding issues.\n   *\n   * @param {string} srcUnits Units of values to convert\n   * @param {string} dstUnits Units to convert to\n   *\n   * @returns {Function} Converting function accepting Number value\n   *   and returning converted value\n   *\n   * @throws \"Incompatible units\" if units are incompatible\n   *\n   * @example\n   * // Converting large array of numbers with the same units\n   * // into other units\n   * var converter = Qty.swiftConverter(\"m/h\", \"ft/s\");\n   * var convertedSerie = largeSerie.map(converter);\n   *\n   */\n  function swiftConverter(srcUnits, dstUnits) {\n    var srcQty = Qty(srcUnits);\n    var dstQty = Qty(dstUnits);\n\n    if (srcQty.eq(dstQty)) {\n      return identity;\n    }\n\n    var convert;\n    if (!srcQty.isTemperature()) {\n      convert = function(value) {\n        return value * srcQty.baseScalar / dstQty.baseScalar;\n      };\n    }\n    else {\n      convert = function(value) {\n        // TODO Not optimized\n        return srcQty.mul(value).to(dstQty).scalar;\n      };\n    }\n\n    return function converter(value) {\n      var i, length, result;\n      if (!Array.isArray(value)) {\n        return convert(value);\n      }\n      else {\n        length = value.length;\n        result = [];\n        for (i = 0; i < length; i++) {\n          result.push(convert(value[i]));\n        }\n        return result;\n      }\n    };\n  }\n\n  var baseUnitCache = {};\n\n  function toBaseUnits(numerator,denominator) {\n    var num = [];\n    var den = [];\n    var q = 1;\n    var unit;\n    for (var i = 0; i < numerator.length; i++) {\n      unit = numerator[i];\n      if (PREFIX_VALUES[unit]) {\n        // workaround to fix\n        // 0.1 * 0.1 => 0.010000000000000002\n        q = mulSafe(q, PREFIX_VALUES[unit]);\n      }\n      else {\n        if (UNIT_VALUES[unit]) {\n          q *= UNIT_VALUES[unit].scalar;\n\n          if (UNIT_VALUES[unit].numerator) {\n            num.push(UNIT_VALUES[unit].numerator);\n          }\n          if (UNIT_VALUES[unit].denominator) {\n            den.push(UNIT_VALUES[unit].denominator);\n          }\n        }\n      }\n    }\n    for (var j = 0; j < denominator.length; j++) {\n      unit = denominator[j];\n      if (PREFIX_VALUES[unit]) {\n        q /= PREFIX_VALUES[unit];\n      }\n      else {\n        if (UNIT_VALUES[unit]) {\n          q /= UNIT_VALUES[unit].scalar;\n\n          if (UNIT_VALUES[unit].numerator) {\n            den.push(UNIT_VALUES[unit].numerator);\n          }\n          if (UNIT_VALUES[unit].denominator) {\n            num.push(UNIT_VALUES[unit].denominator);\n          }\n        }\n      }\n    }\n\n    // Flatten\n    num = num.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n    den = den.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n\n    return Qty({\"scalar\": q, \"numerator\": num, \"denominator\": den});\n  }\n\n  Qty.parse = globalParse;\n\n  Qty.getUnits = getUnits;\n  Qty.getAliases = getAliases;\n\n  Qty.mulSafe = mulSafe;\n  Qty.divSafe = divSafe;\n\n  Qty.getKinds = getKinds;\n\n  Qty.swiftConverter = swiftConverter;\n\n  Qty.Error = QtyError;\n\n  assign(Qty.prototype, {\n    // Returns new instance with units of this\n    add: function(other) {\n      if (isString(other)) {\n        other = Qty(other);\n      }\n\n      if (!this.isCompatible(other)) {\n        throwIncompatibleUnits(this.units(), other.units());\n      }\n\n      if (this.isTemperature() && other.isTemperature()) {\n        throw new QtyError(\"Cannot add two temperatures\");\n      }\n      else if (this.isTemperature()) {\n        return addTempDegrees(this, other);\n      }\n      else if (other.isTemperature()) {\n        return addTempDegrees(other, this);\n      }\n\n      return Qty({\"scalar\": this.scalar + other.to(this).scalar, \"numerator\": this.numerator, \"denominator\": this.denominator});\n    },\n\n    sub: function(other) {\n      if (isString(other)) {\n        other = Qty(other);\n      }\n\n      if (!this.isCompatible(other)) {\n        throwIncompatibleUnits(this.units(), other.units());\n      }\n\n      if (this.isTemperature() && other.isTemperature()) {\n        return subtractTemperatures(this,other);\n      }\n      else if (this.isTemperature()) {\n        return subtractTempDegrees(this,other);\n      }\n      else if (other.isTemperature()) {\n        throw new QtyError(\"Cannot subtract a temperature from a differential degree unit\");\n      }\n\n      return Qty({\"scalar\": this.scalar - other.to(this).scalar, \"numerator\": this.numerator, \"denominator\": this.denominator});\n    },\n\n    mul: function(other) {\n      if (isNumber(other)) {\n        return Qty({\"scalar\": mulSafe(this.scalar, other), \"numerator\": this.numerator, \"denominator\": this.denominator});\n      }\n      else if (isString(other)) {\n        other = Qty(other);\n      }\n\n      if ((this.isTemperature() || other.isTemperature()) && !(this.isUnitless() || other.isUnitless())) {\n        throw new QtyError(\"Cannot multiply by temperatures\");\n      }\n\n      // Quantities should be multiplied with same units if compatible, with base units else\n      var op1 = this;\n      var op2 = other;\n\n      // so as not to confuse results, multiplication and division between temperature degrees will maintain original unit info in num/den\n      // multiplication and division between deg[CFRK] can never factor each other out, only themselves: \"degK*degC/degC^2\" == \"degK/degC\"\n      if (op1.isCompatible(op2) && op1.signature !== 400) {\n        op2 = op2.to(op1);\n      }\n      var numdenscale = cleanTerms(op1.numerator, op1.denominator, op2.numerator, op2.denominator);\n\n      return Qty({\"scalar\": mulSafe(op1.scalar, op2.scalar, numdenscale[2]), \"numerator\": numdenscale[0], \"denominator\": numdenscale[1]});\n    },\n\n    div: function(other) {\n      if (isNumber(other)) {\n        if (other === 0) {\n          throw new QtyError(\"Divide by zero\");\n        }\n        return Qty({\"scalar\": this.scalar / other, \"numerator\": this.numerator, \"denominator\": this.denominator});\n      }\n      else if (isString(other)) {\n        other = Qty(other);\n      }\n\n      if (other.scalar === 0) {\n        throw new QtyError(\"Divide by zero\");\n      }\n\n      if (other.isTemperature()) {\n        throw new QtyError(\"Cannot divide with temperatures\");\n      }\n      else if (this.isTemperature() && !other.isUnitless()) {\n        throw new QtyError(\"Cannot divide with temperatures\");\n      }\n\n      // Quantities should be multiplied with same units if compatible, with base units else\n      var op1 = this;\n      var op2 = other;\n\n      // so as not to confuse results, multiplication and division between temperature degrees will maintain original unit info in num/den\n      // multiplication and division between deg[CFRK] can never factor each other out, only themselves: \"degK*degC/degC^2\" == \"degK/degC\"\n      if (op1.isCompatible(op2) && op1.signature !== 400) {\n        op2 = op2.to(op1);\n      }\n      var numdenscale = cleanTerms(op1.numerator, op1.denominator, op2.denominator, op2.numerator);\n\n      return Qty({\"scalar\": mulSafe(op1.scalar, numdenscale[2]) / op2.scalar, \"numerator\": numdenscale[0], \"denominator\": numdenscale[1]});\n    },\n\n    // Returns a Qty that is the inverse of this Qty,\n    inverse: function() {\n      if (this.isTemperature()) {\n        throw new QtyError(\"Cannot divide with temperatures\");\n      }\n      if (this.scalar === 0) {\n        throw new QtyError(\"Divide by zero\");\n      }\n      return Qty({\"scalar\": 1 / this.scalar, \"numerator\": this.denominator, \"denominator\": this.numerator});\n    }\n  });\n\n  function cleanTerms(num1, den1, num2, den2) {\n    function notUnity(val) {\n      return val !== UNITY;\n    }\n\n    num1 = num1.filter(notUnity);\n    num2 = num2.filter(notUnity);\n    den1 = den1.filter(notUnity);\n    den2 = den2.filter(notUnity);\n\n    var combined = {};\n\n    function combineTerms(terms, direction) {\n      var k;\n      var prefix;\n      var prefixValue;\n      for (var i = 0; i < terms.length; i++) {\n        if (PREFIX_VALUES[terms[i]]) {\n          k = terms[i + 1];\n          prefix = terms[i];\n          prefixValue = PREFIX_VALUES[prefix];\n          i++;\n        }\n        else {\n          k = terms[i];\n          prefix = null;\n          prefixValue = 1;\n        }\n        if (k && k !== UNITY) {\n          if (combined[k]) {\n            combined[k][0] += direction;\n            var combinedPrefixValue = combined[k][2] ? PREFIX_VALUES[combined[k][2]] : 1;\n            combined[k][direction === 1 ? 3 : 4] *= divSafe(prefixValue, combinedPrefixValue);\n          }\n          else {\n            combined[k] = [direction, k, prefix, 1, 1];\n          }\n        }\n      }\n    }\n\n    combineTerms(num1, 1);\n    combineTerms(den1, -1);\n    combineTerms(num2, 1);\n    combineTerms(den2, -1);\n\n    var num = [];\n    var den = [];\n    var scale = 1;\n\n    for (var prop in combined) {\n      if (combined.hasOwnProperty(prop)) {\n        var item = combined[prop];\n        var n;\n        if (item[0] > 0) {\n          for (n = 0; n < item[0]; n++) {\n            num.push(item[2] === null ? item[1] : [item[2], item[1]]);\n          }\n        }\n        else if (item[0] < 0) {\n          for (n = 0; n < -item[0]; n++) {\n            den.push(item[2] === null ? item[1] : [item[2], item[1]]);\n          }\n        }\n        scale *= divSafe(item[3], item[4]);\n      }\n    }\n\n    if (num.length === 0) {\n      num = UNITY_ARRAY;\n    }\n    if (den.length === 0) {\n      den = UNITY_ARRAY;\n    }\n\n    // Flatten\n    num = num.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n    den = den.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n\n    return [num, den, scale];\n  }\n\n  assign(Qty.prototype, {\n    eq: function(other) {\n      return this.compareTo(other) === 0;\n    },\n\n    lt: function(other) {\n      return this.compareTo(other) === -1;\n    },\n\n    lte: function(other) {\n      return this.eq(other) || this.lt(other);\n    },\n\n    gt: function(other) {\n      return this.compareTo(other) === 1;\n    },\n\n    gte: function(other) {\n      return this.eq(other) || this.gt(other);\n    },\n\n    // Compare two Qty objects. Throws an exception if they are not of compatible types.\n    // Comparisons are done based on the value of the quantity in base SI units.\n    //\n    // NOTE: We cannot compare inverses as that breaks the general compareTo contract:\n    //   if a.compareTo(b) < 0 then b.compareTo(a) > 0\n    //   if a.compareTo(b) == 0 then b.compareTo(a) == 0\n    //\n    //   Since \"10S\" == \".1ohm\" (10 > .1) and \"10ohm\" == \".1S\" (10 > .1)\n    //     Qty(\"10S\").inverse().compareTo(\"10ohm\") == -1\n    //     Qty(\"10ohm\").inverse().compareTo(\"10S\") == -1\n    //\n    //   If including inverses in the sort is needed, I suggest writing: Qty.sort(qtyArray,units)\n    compareTo: function(other) {\n      if (isString(other)) {\n        return this.compareTo(Qty(other));\n      }\n      if (!this.isCompatible(other)) {\n        throwIncompatibleUnits(this.units(), other.units());\n      }\n      if (this.baseScalar < other.baseScalar) {\n        return -1;\n      }\n      else if (this.baseScalar === other.baseScalar) {\n        return 0;\n      }\n      else if (this.baseScalar > other.baseScalar) {\n        return 1;\n      }\n    },\n\n    // Return true if quantities and units match\n    // Unit(\"100 cm\").same(Unit(\"100 cm\"))  # => true\n    // Unit(\"100 cm\").same(Unit(\"1 m\"))     # => false\n    same: function(other) {\n      return (this.scalar === other.scalar) && (this.units() === other.units());\n    }\n  });\n\n  assign(Qty.prototype, {\n    // returns true if no associated units\n    // false, even if the units are \"unitless\" like 'radians, each, etc'\n    isUnitless: function() {\n      return [this.numerator, this.denominator].every(function(item) {\n        return compareArray(item, UNITY_ARRAY);\n      });\n    },\n\n    /*\n    check to see if units are compatible, but not the scalar part\n    this check is done by comparing signatures for performance reasons\n    if passed a string, it will create a unit object with the string and then do the comparison\n    this permits a syntax like:\n    unit =~ \"mm\"\n    if you want to do a regexp on the unit string do this ...\n    unit.units =~ /regexp/\n    */\n    isCompatible: function(other) {\n      if (isString(other)) {\n        return this.isCompatible(Qty(other));\n      }\n\n      if (!(isQty(other))) {\n        return false;\n      }\n\n      if (other.signature !== undefined) {\n        return this.signature === other.signature;\n      }\n      else {\n        return false;\n      }\n    },\n\n    /*\n    check to see if units are inverse of each other, but not the scalar part\n    this check is done by comparing signatures for performance reasons\n    if passed a string, it will create a unit object with the string and then do the comparison\n    this permits a syntax like:\n    unit =~ \"mm\"\n    if you want to do a regexp on the unit string do this ...\n    unit.units =~ /regexp/\n    */\n    isInverse: function(other) {\n      return this.inverse().isCompatible(other);\n    },\n\n    // Returns 'true' if the Unit is represented in base units\n    isBase: function() {\n      if (this._isBase !== undefined) {\n        return this._isBase;\n      }\n      if (this.isDegrees() && this.numerator[0].match(/<(kelvin|temp-K)>/)) {\n        this._isBase = true;\n        return this._isBase;\n      }\n\n      this.numerator.concat(this.denominator).forEach(function(item) {\n        if (item !== UNITY && BASE_UNITS.indexOf(item) === -1 ) {\n          this._isBase = false;\n        }\n      }, this);\n      if (this._isBase === false) {\n        return this._isBase;\n      }\n      this._isBase = true;\n      return this._isBase;\n    }\n  });\n\n  function NestedMap() {}\n\n  NestedMap.prototype.get = function(keys) {\n\n    // Allows to pass key1, key2, ... instead of [key1, key2, ...]\n    if (arguments.length > 1) {\n      // Slower with Firefox but faster with Chrome than\n      // Array.prototype.slice.call(arguments)\n      // See http://jsperf.com/array-apply-versus-array-prototype-slice-call\n      keys = Array.apply(null, arguments);\n    }\n\n    return keys.reduce(function(map, key, index) {\n      if (map) {\n\n        var childMap = map[key];\n\n        if (index === keys.length - 1) {\n          return childMap ? childMap.data : undefined;\n        }\n        else {\n          return childMap;\n        }\n      }\n    },\n    this);\n  };\n\n  NestedMap.prototype.set = function(keys, value) {\n\n    if (arguments.length > 2) {\n      keys = Array.prototype.slice.call(arguments, 0, -1);\n      value = arguments[arguments.length - 1];\n    }\n\n    return keys.reduce(function(map, key, index) {\n\n      var childMap = map[key];\n      if (childMap === undefined) {\n        childMap = map[key] = {};\n      }\n\n      if (index === keys.length - 1) {\n        childMap.data = value;\n        return value;\n      }\n      else {\n        return childMap;\n      }\n    }, this);\n  };\n\n  /**\n   * Default formatter\n   *\n   * @param {number} scalar - scalar value\n   * @param {string} units - units as string\n   *\n   * @returns {string} formatted result\n   */\n  function defaultFormatter(scalar, units) {\n    return (scalar + \" \" + units).trim();\n  }\n\n  /**\n   *\n   * Configurable Qty default formatter\n   *\n   * @type {function}\n   *\n   * @param {number} scalar\n   * @param {string} units\n   *\n   * @returns {string} formatted result\n   */\n  Qty.formatter = defaultFormatter;\n\n  assign(Qty.prototype, {\n\n    // returns the 'unit' part of the Unit object without the scalar\n    units: function() {\n      if (this._units !== undefined) {\n        return this._units;\n      }\n\n      var numIsUnity = compareArray(this.numerator, UNITY_ARRAY);\n      var denIsUnity = compareArray(this.denominator, UNITY_ARRAY);\n      if (numIsUnity && denIsUnity) {\n        this._units = \"\";\n        return this._units;\n      }\n\n      var numUnits = stringifyUnits(this.numerator);\n      var denUnits = stringifyUnits(this.denominator);\n      this._units = numUnits + (denIsUnity ? \"\" : (\"/\" + denUnits));\n      return this._units;\n    },\n\n    /**\n     * Stringifies the quantity\n     * Deprecation notice: only units parameter is supported.\n     *\n     * @param {(number|string|Qty)} targetUnitsOrMaxDecimalsOrPrec -\n     *                              target units if string,\n     *                              max number of decimals if number,\n     *                              passed to #toPrec before converting if Qty\n     *\n     * @param {number=} maxDecimals - Maximum number of decimals of\n     *                                formatted output\n     *\n     * @returns {string} reparseable quantity as string\n     */\n    toString: function(targetUnitsOrMaxDecimalsOrPrec, maxDecimals) {\n      var targetUnits;\n      if (isNumber(targetUnitsOrMaxDecimalsOrPrec)) {\n        targetUnits = this.units();\n        maxDecimals = targetUnitsOrMaxDecimalsOrPrec;\n      }\n      else if (isString(targetUnitsOrMaxDecimalsOrPrec)) {\n        targetUnits = targetUnitsOrMaxDecimalsOrPrec;\n      }\n      else if (isQty(targetUnitsOrMaxDecimalsOrPrec)) {\n        return this.toPrec(targetUnitsOrMaxDecimalsOrPrec).toString(maxDecimals);\n      }\n\n      var out = this.to(targetUnits);\n\n      var outScalar = maxDecimals !== undefined ? round(out.scalar, maxDecimals) : out.scalar;\n      out = (outScalar + \" \" + out.units()).trim();\n      return out;\n    },\n\n    /**\n     * Format the quantity according to optional passed target units\n     * and formatter\n     *\n     * @param {string} [targetUnits=current units] -\n     *                 optional units to convert to before formatting\n     *\n     * @param {function} [formatter=Qty.formatter] -\n     *                   delegates formatting to formatter callback.\n     *                   formatter is called back with two parameters (scalar, units)\n     *                   and should return formatted result.\n     *                   If unspecified, formatting is delegated to default formatter\n     *                   set to Qty.formatter\n     *\n     * @example\n     * var roundingAndLocalizingFormatter = function(scalar, units) {\n     *   // localize or limit scalar to n max decimals for instance\n     *   // return formatted result\n     * };\n     * var qty = Qty('1.1234 m');\n     * qty.format(); // same units, default formatter => \"1.234 m\"\n     * qty.format(\"cm\"); // converted to \"cm\", default formatter => \"123.45 cm\"\n     * qty.format(roundingAndLocalizingFormatter); // same units, custom formatter => \"1,2 m\"\n     * qty.format(\"cm\", roundingAndLocalizingFormatter); // convert to \"cm\", custom formatter => \"123,4 cm\"\n     *\n     * @returns {string} quantity as string\n     */\n    format: function(targetUnits, formatter) {\n      if (arguments.length === 1) {\n        if (typeof targetUnits === \"function\") {\n          formatter = targetUnits;\n          targetUnits = undefined;\n        }\n      }\n\n      formatter = formatter || Qty.formatter;\n      var targetQty = this.to(targetUnits);\n      return formatter.call(this, targetQty.scalar, targetQty.units());\n    }\n  });\n\n  var stringifiedUnitsCache = new NestedMap();\n  /**\n   * Returns a string representing a normalized unit array\n   *\n   * @param {string[]} units Normalized unit array\n   * @returns {string} String representing passed normalized unit array and\n   *   suitable for output\n   *\n   */\n  function stringifyUnits(units) {\n\n    var stringified = stringifiedUnitsCache.get(units);\n    if (stringified) {\n      return stringified;\n    }\n\n    var isUnity = compareArray(units, UNITY_ARRAY);\n    if (isUnity) {\n      stringified = \"1\";\n    }\n    else {\n      stringified = simplify(getOutputNames(units)).join(\"*\");\n    }\n\n    // Cache result\n    stringifiedUnitsCache.set(units, stringified);\n\n    return stringified;\n  }\n\n  function getOutputNames(units) {\n    var unitNames = [], token, tokenNext;\n    for (var i = 0; i < units.length; i++) {\n      token = units[i];\n      tokenNext = units[i + 1];\n      if (PREFIX_VALUES[token]) {\n        unitNames.push(OUTPUT_MAP[token] + OUTPUT_MAP[tokenNext]);\n        i++;\n      }\n      else {\n        unitNames.push(OUTPUT_MAP[token]);\n      }\n    }\n    return unitNames;\n  }\n\n  function simplify(units) {\n    // this turns ['s','m','s'] into ['s2','m']\n\n    var unitCounts = units.reduce(function(acc, unit) {\n      var unitCounter = acc[unit];\n      if (!unitCounter) {\n        acc.push(unitCounter = acc[unit] = [unit, 0]);\n      }\n\n      unitCounter[1]++;\n\n      return acc;\n    }, []);\n\n    return unitCounts.map(function(unitCount) {\n      return unitCount[0] + (unitCount[1] > 1 ? unitCount[1] : \"\");\n    });\n  }\n\n  Qty.version = \"1.8.0\";\n\n  return Qty;\n\n}));\n","import Qty from 'js-quantities';\nexport function convertUnit(array, fromUnit, toUnit) {\n    fromUnit = normalize(fromUnit);\n    toUnit = normalize(toUnit);\n    if (fromUnit === toUnit)\n        return array;\n    const convert = Qty.swiftConverter(fromUnit, toUnit); // Configures converter\n    //@ts-expect-error convert does not allowed typed array but it works\n    return convert(array);\n}\nfunction normalize(unit) {\n    unit = unit.replaceAll('°C', 'tempC');\n    unit = unit.replaceAll('°F', 'tempF');\n    unit = unit.replaceAll(/(^|\\W)K(\\W|$)/g, '$1tempK$2');\n    return unit;\n}\n//# sourceMappingURL=convertUnit.js.map","const testRegExp = /^\\/((?:\\\\\\/|[^/])+)\\/([gimuy]{0,5})?$/;\nexport function ensureRegexp(string) {\n    if (typeof string !== 'string')\n        return string;\n    const parts = testRegExp.exec(string);\n    if (parts) {\n        try {\n            return new RegExp(parts[1], parts[2]);\n        }\n        catch {\n            return stringToRegexp(string);\n        }\n    }\n    else {\n        return stringToRegexp(string);\n    }\n}\nfunction stringToRegexp(string, flags = 'i') {\n    return new RegExp(string.replaceAll(/[$()*+.?[\\\\\\]^{|}]/g, (match) => `\\\\${match}`), flags);\n}\n//# sourceMappingURL=ensureRegexp.js.map","import { xIsMonotonic, xMaxValue, xMinValue } from 'ml-spectra-processing';\nimport { convertUnit } from './convertUnit.js';\nexport function getConvertedVariable(variable, newUnits) {\n    const data = variable.units !== undefined && variable.units !== newUnits // would be nice if convertUnit would allow typedArray\n        ? convertUnit(Array.from(variable.data), variable.units, newUnits)\n        : variable.data;\n    return {\n        units: newUnits,\n        label: variable.label.replace(`[${variable.units || ''}]`, `[${newUnits}]`),\n        data: data || [],\n        min: data ? xMinValue(data) : undefined,\n        max: data ? xMaxValue(data) : undefined,\n        isMonotonic: xIsMonotonic(data),\n    };\n}\n//# sourceMappingURL=getConvertedVariable.js.map","/* eslint-disable @typescript-eslint/no-dynamic-delete */\nimport { convertUnit } from './convertUnit.js';\nimport { ensureRegexp } from './ensureRegexp.js';\nimport { getConvertedVariable } from './getConvertedVariable.js';\n/**\n * Retrieve the spectrum with only X/Y data that match all the selectors\n * If more than one variable match the selector the 'x' or 'y' variable will be\n * taken\n * @param spectra\n * @param selector\n */\nexport function getXYSpectra(spectra = [], selector = {}) {\n    const selectedSpectra = [];\n    if (spectra.length === 0)\n        return selectedSpectra;\n    const { variables, units, labels, meta, index } = selector;\n    let { dataType, title, xUnits, yUnits, xVariable = 'x', yVariable = 'y', xLabel, yLabel, } = selector;\n    if (index !== undefined) {\n        return [spectra[index]];\n    }\n    if (dataType) {\n        dataType = ensureRegexp(dataType);\n    }\n    if (title) {\n        title = ensureRegexp(title);\n    }\n    if (units && !xUnits && !yUnits)\n        [yUnits, xUnits] = units.split(/\\s*vs\\s*/);\n    if (labels && !xLabel && !yLabel) {\n        [yLabel, xLabel] = labels.split(/\\s*vs\\s*/);\n    }\n    if (variables) {\n        const parts = variables.split(/\\s*vs\\s*/);\n        if (parts.length === 2) {\n            xVariable = parts[1];\n            yVariable = parts[0];\n        }\n    }\n    if (xLabel)\n        xLabel = ensureRegexp(xLabel);\n    if (yLabel)\n        yLabel = ensureRegexp(yLabel);\n    for (const spectrum of spectra) {\n        const variableNames = Object.keys(spectrum.variables);\n        if (!(variableNames.length > 1))\n            continue;\n        // we filter on general spectrum information\n        if (dataType &&\n            (!spectrum.dataType || !dataType.exec(spectrum.dataType))) {\n            continue;\n        }\n        if (title && (!spectrum.title || !title.exec(spectrum.title))) {\n            continue;\n        }\n        if (meta && typeof meta === 'object') {\n            if (!spectrum.meta)\n                continue;\n            for (const key in spectrum.meta) {\n                if (!spectrum.meta[key])\n                    continue;\n                const value = ensureRegexp(spectrum.meta[key]);\n                if (!value.exec(spectrum.meta[key]))\n                    continue;\n            }\n        }\n        const x = getPossibleVariable(spectrum.variables, {\n            units: xUnits,\n            label: xLabel,\n            variableName: xVariable,\n        });\n        const y = getPossibleVariable(spectrum.variables, {\n            units: yUnits,\n            label: yLabel,\n            variableName: yVariable,\n        });\n        if (x && y) {\n            // should we reverse the x axis?\n            if (x.data[0] > x.data.at(-1)) {\n                x.data = x.data.slice().reverse();\n                y.data = y.data.slice().reverse();\n            }\n            selectedSpectra.push({\n                title: spectrum.title,\n                dataType: spectrum.dataType,\n                meta: spectrum.meta,\n                variables: { x, y },\n                id: spectrum.id,\n            });\n        }\n    }\n    return selectedSpectra;\n}\nfunction getPossibleVariable(variables, selector = {}) {\n    const { units, label, variableName } = selector;\n    const possible = { ...variables };\n    let key;\n    if (units !== undefined) {\n        for (key in possible) {\n            const variable = variables[key];\n            let convertibleUnits = true;\n            try {\n                convertUnit(1, variable?.units || '', units);\n            }\n            catch {\n                convertibleUnits = false;\n            }\n            if (convertibleUnits && variable) {\n                possible[key] = getConvertedVariable(variable, units);\n            }\n            else {\n                delete possible[key];\n            }\n        }\n    }\n    if (label !== undefined) {\n        const regexpLabel = ensureRegexp(label);\n        for (key in possible) {\n            if (!regexpLabel.exec(variables[key]?.label ?? '')) {\n                delete possible[key];\n            }\n        }\n    }\n    if (variableName !== undefined) {\n        if (possible[variableName])\n            return possible[variableName];\n        const upper = variableName.toUpperCase();\n        if (Object.hasOwn(possible, upper)) {\n            return possible[upper];\n        }\n        const lower = variableName.toLowerCase();\n        if (Object.hasOwn(possible, lower)) {\n            return possible[lower];\n        }\n    }\n    const possibleFiltered = Object.values(possible).filter((val) => val !== undefined);\n    if (possibleFiltered.length > 0) {\n        return possibleFiltered[0];\n    }\n}\n//# sourceMappingURL=getXYSpectra.js.map","import { isAnyArray } from 'is-any-array';\nimport { stringify, xIsMonotonic, xMaxValue, xMinValue, } from 'ml-spectra-processing';\nimport { getNormalizedSpectrum } from './util/getNormalizedSpectrum.js';\nimport { getXYSpectra } from './util/getXYSpectra.js';\nimport { getXYSpectrum } from './util/getXYSpectrum.js';\n/**\n * Class allowing to store and manipulate an analysis.\n * An analysis may contain one or more spectra that can be selected\n * based on their units\n */\nexport class Analysis {\n    id;\n    label;\n    spectrumCallback;\n    spectra;\n    cache;\n    constructor(options = {}) {\n        this.id = options.id || Math.random().toString(36).slice(2, 10);\n        this.label = options.label || this.id;\n        this.spectrumCallback = options.spectrumCallback;\n        this.spectra = [];\n        this.cache = { spectrum: {}, spectra: {} };\n    }\n    clone({ filter = {} }) {\n        const { ids } = filter;\n        const analysis = new Analysis();\n        analysis.id = this.id;\n        analysis.label = this.label;\n        analysis.spectrumCallback = this.spectrumCallback;\n        analysis.spectra = this.spectra.filter((spectrum) => {\n            //@ts-expect-error spectrum.id is not expected to be undefined at this level\n            return !ids || ids.includes(spectrum.id);\n        });\n        return analysis;\n    }\n    toJSON() {\n        // TODO this is likely not the most optimized way to remove typedArray\n        // if data are small seems still reasonable\n        return {\n            id: this.id,\n            label: this.label,\n            spectra: JSON.parse(stringify(this.spectra)),\n        };\n    }\n    static fromJSON(json) {\n        const analysis = new Analysis();\n        analysis.id = json.id;\n        analysis.label = json.label;\n        analysis.spectra = json.spectra;\n        return analysis;\n    }\n    /**\n     * Add a spectrum in the internal spectra variable\n     * @param variables\n     * @param options\n     */\n    pushSpectrum(variables, options = {}) {\n        this.spectra.push(standardizeData(variables, options, {\n            spectrumCallback: this.spectrumCallback,\n        }));\n        this.cache = { spectrum: {}, spectra: {} };\n    }\n    /**\n     * Retrieve a MeasurementXY based on x/y units\n     * @param selector\n     */\n    getXYSpectrum(selector = {}) {\n        const id = JSON.stringify(selector);\n        if (!this.cache.spectrum[id]) {\n            this.cache.spectrum[id] = getXYSpectrum(this.spectra, selector);\n        }\n        return this.cache.spectrum[id];\n    }\n    /**\n     * Retrieve spectra matching selector\n     * @param selector\n     */\n    getXYSpectra(selector = {}) {\n        const id = JSON.stringify(selector);\n        if (!this.cache.spectra[id]) {\n            this.cache.spectra[id] = getXYSpectra(this.spectra, selector);\n        }\n        return this.cache.spectra[id];\n    }\n    /**\n     * Retrieve a xy object\n     * @param selector.units - Units separated by vs like for example \"g vs °C\"\n     * @param selector.xUnits - if undefined takes the first variable\n     * @param selector.yUnits - if undefined takes the second variable\n     * @param selector\n     */\n    getXY(selector = {}) {\n        const spectrum = this.getXYSpectrum(selector);\n        if (!spectrum)\n            return undefined;\n        return {\n            x: spectrum.variables.x.data,\n            y: spectrum.variables.y.data,\n        };\n    }\n    /**\n     * Return the data object for specific x/y units with possibly some\n     * normalization options\n     * @param options.selector.xUnits - // if undefined takes the first variable\n     * @param options.selector.yUnits - // if undefined takes the second variable\n     * @param options\n     */\n    getNormalizedSpectrum(options = {}) {\n        const { normalization, selector } = options;\n        const spectrum = this.getXYSpectrum(selector);\n        if (!spectrum)\n            return undefined;\n        return getNormalizedSpectrum(spectrum, normalization);\n    }\n    /**\n     * @param options\n     */\n    getNormalizedSpectra(options = {}) {\n        const { normalization, selector } = options;\n        const spectra = this.getXYSpectra(selector);\n        if (spectra.length === 0)\n            return [];\n        const normalizedSpectra = [];\n        for (const spectrum of spectra) {\n            normalizedSpectra.push(getNormalizedSpectrum(spectrum, normalization));\n        }\n        return normalizedSpectra;\n    }\n    /**\n     * Returns the first spectrum. This method could be improved in the future\n     * @returns\n     */\n    getSpectrum() {\n        return this.spectra[0];\n    }\n    /**\n     * Returns the xLabel\n     * @param selector.xUnits - // if undefined takes the first variable\n     * @param selector.yUnits - // if undefined takes the second variable\n     * @param selector\n     */\n    getXLabel(selector) {\n        return this.getXYSpectrum(selector)?.variables.x.label;\n    }\n    /**\n     * Returns the yLabel\n     * @param selector.xUnits - // if undefined takes the first variable\n     * @param selector.yUnits - // if undefined takes the second variable\n     * @param selector\n     */\n    getYLabel(selector) {\n        return this.getXYSpectrum(selector)?.variables.y.label;\n    }\n}\n/**\n * Internal function that ensure the order of x / y array\n * @param variables\n * @param options\n * @param analysisOptions\n */\nfunction standardizeData(variables, options, analysisOptions) {\n    const { meta = {}, dataType = '', title = '', id = Math.random().toString(36).replace('0.', ''), } = options;\n    const { spectrumCallback } = analysisOptions;\n    if (spectrumCallback) {\n        spectrumCallback(variables);\n    }\n    const xVariable = variables.x;\n    const yVariable = variables.y;\n    if (!xVariable || !yVariable) {\n        throw new Error('A spectrum must contain at least x and y variables');\n    }\n    if (!isAnyArray(xVariable.data) || !isAnyArray(yVariable.data)) {\n        throw new Error('x and y variables must contain an array data');\n    }\n    const x = xVariable.data;\n    const reverse = x && x.length > 1 && x[0] > x.at(-1);\n    for (const [key, variable] of Object.entries(variables)) {\n        if (reverse)\n            variable.data = variable.data.slice().reverse();\n        variable.label = variable.label || key;\n        if (variable.label.match(/^.*[([](?<units>.*)[)\\]].*$/)) {\n            const units = variable.label.replace(/^.*[([](?<units>.*)[)\\]].*$/, '$<units>');\n            if (!variable.units || variable.units === units) {\n                variable.units = units;\n                variable.label = variable.label.replace(/[([].*[)\\]]/, '').trim();\n            }\n        }\n        variable.min = xMinValue(variable.data);\n        variable.max = xMaxValue(variable.data);\n        variable.isMonotonic = xIsMonotonic(variable.data);\n    }\n    return {\n        variables,\n        title,\n        dataType,\n        meta,\n        id,\n    };\n}\n//# sourceMappingURL=Analysis.js.map","import { getXYSpectra } from './getXYSpectra.js';\n/**\n * Retrieve the spectrum with only X/Y data that match all the selectors\n * If more than one variable match the selector the 'x' or 'y' variable will be\n * taken\n * @param spectra\n * @param selector\n */\nexport function getXYSpectrum(spectra = [], selector = {}) {\n    const selectedSpectra = getXYSpectra(spectra, selector);\n    if (selectedSpectra.length === 0)\n        return undefined;\n    return selectedSpectra[0];\n}\n//# sourceMappingURL=getXYSpectrum.js.map","export function appendDistinctParameter(values, key, value) {\n    if (!values[key]) {\n        values[key] = {\n            key,\n            values: [],\n            count: 0,\n        };\n    }\n    if (!values[key].values.includes(value)) {\n        values[key].values.push(value);\n    }\n    values[key].count++;\n}\n//# sourceMappingURL=appendDistinctParameter.js.map","export function appendDistinctValue(values, key) {\n    if (!values[key]) {\n        values[key] = {\n            key,\n            count: 0,\n        };\n    }\n    values[key].count++;\n}\n//# sourceMappingURL=appendDistinctValue.js.map","import { Analysis } from './Analysis.js';\nimport { appendDistinctParameter } from './util/appendDistinctParameter.js';\nimport { appendDistinctValue } from './util/appendDistinctValue.js';\nexport class AnalysesManager {\n    analyses;\n    constructor() {\n        this.analyses = [];\n    }\n    static fromJSON(json) {\n        const analysesManager = new AnalysesManager();\n        for (const analysis of json.analyses) {\n            analysesManager.analyses.push(Analysis.fromJSON(analysis));\n        }\n        return analysesManager;\n    }\n    addAnalysis(analysis) {\n        const index = this.getAnalysisIndex(analysis.id);\n        if (index === undefined) {\n            this.analyses.push(analysis);\n        }\n        else {\n            this.analyses[index] = analysis;\n        }\n    }\n    /**\n     *\n     * @param options\n     * @returns\n     */\n    getAnalyses(options = {}) {\n        const { ids } = options;\n        const analyses = [];\n        const processedAnalysisIds = new Set();\n        for (const analysis of this.analyses) {\n            if (!ids || ids.includes(analysis.id)) {\n                analyses.push(analysis);\n                processedAnalysisIds.add(analysis.id);\n                continue;\n            }\n            for (const spectrum of analysis.spectra) {\n                if (spectrum.id &&\n                    ids.includes(spectrum.id) &&\n                    !processedAnalysisIds.has(analysis.id)) {\n                    analyses.push(analysis.clone({ filter: { ids } }));\n                    processedAnalysisIds.add(analysis.id);\n                }\n            }\n        }\n        return analyses;\n    }\n    getSpectra() {\n        const spectra = [];\n        for (const analysis of this.analyses) {\n            spectra.push(...analysis.spectra);\n        }\n        return spectra;\n    }\n    getAnalysisBySpectrumId(id) {\n        for (const analysis of this.analyses) {\n            for (const spectrum of analysis.spectra) {\n                if (spectrum.id === id)\n                    return analysis;\n            }\n        }\n        return undefined;\n    }\n    getSpectrumById(id) {\n        for (const analysis of this.analyses) {\n            for (const spectrum of analysis.spectra) {\n                if (spectrum.id === id)\n                    return spectrum;\n            }\n        }\n        return undefined;\n    }\n    /**\n     * Get an array of objects (key + count) of all the titles\n     */\n    getDistinctTitles() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.title) {\n                appendDistinctValue(values, spectrum.title);\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + count) of all the units\n     */\n    getDistinctUnits() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.variables) {\n                for (const [, variable] of Object.entries(spectrum.variables)) {\n                    if (variable.units) {\n                        appendDistinctValue(values, variable.units);\n                    }\n                }\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + unit + label + count) of all the units\n     */\n    getDistinctLabelUnits() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.variables) {\n                for (const [, variable] of Object.entries(spectrum.variables)) {\n                    const { label, units } = normalizeLabelUnits(variable.label, variable.units);\n                    const key = label + (units ? ` (${units})` : '');\n                    if (key) {\n                        if (!values[key]) {\n                            values[key] = { key, units, label, count: 0 };\n                        }\n                        values[key].count++;\n                    }\n                }\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + count) of all the labels\n     */\n    getDistinctLabels() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.variables) {\n                for (const [, variable] of Object.entries(spectrum.variables)) {\n                    appendDistinctValue(values, variable.label.replace(/\\s+[([].*$/, ''));\n                }\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + count) of all the dataTypes\n     */\n    getDistinctDataTypes() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.dataType) {\n                appendDistinctValue(values, spectrum.dataType);\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + count) of all the meta\n     */\n    getDistinctMeta() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.meta) {\n                for (const key in spectrum.meta) {\n                    appendDistinctParameter(values, key, spectrum.meta[key]);\n                }\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    removeAllAnalyses() {\n        this.analyses.splice(0);\n    }\n    /**\n     * Remove the analysis from the AnalysesManager for the specified id\n     * @param id\n     */\n    removeAnalysis(id) {\n        const index = this.getAnalysisIndex(id);\n        if (index === undefined)\n            return undefined;\n        return this.analyses.splice(index, 1);\n    }\n    /**\n     * Returns the index of the analysis in the analyses array\n     * @param id\n     */\n    getAnalysisIndex(id) {\n        if (!id)\n            return undefined;\n        for (let i = 0; i < this.analyses.length; i++) {\n            const analysis = this.analyses[i];\n            if (analysis.id === id)\n                return i;\n        }\n        return undefined;\n    }\n    /**\n     * Checks if the ID of an analysis exists in the AnalysesManager\n     * @param id\n     */\n    includes(id) {\n        const index = this.getAnalysisIndex(id);\n        return index === undefined ? false : !Number.isNaN(index);\n    }\n}\nfunction normalizeLabelUnits(originalLabel, originalUnits) {\n    if (!originalLabel) {\n        return { units: '', label: '' };\n    }\n    if (originalLabel.search(/[([]]/) >= 0) {\n        const [units, label] = originalLabel.split(/\\s*[([]/);\n        return { units: originalUnits || units, label };\n    }\n    return { label: originalLabel, units: originalUnits };\n}\n//# sourceMappingURL=AnalysesManager.js.map","import isutf8 from 'isutf8';\n/**\n * Ensure that the data is string. If it is an ArrayBuffer it will be converted to string using TextDecoder.\n * @param blob\n * @param options\n * @returns\n */\nexport function ensureString(blob, options = {}) {\n    if (typeof blob === 'string') {\n        return blob;\n    }\n    if (ArrayBuffer.isView(blob) || blob instanceof ArrayBuffer) {\n        const { encoding = guessEncoding(blob) } = options;\n        const decoder = new TextDecoder(encoding);\n        return decoder.decode(blob);\n    }\n    throw new TypeError(`blob must be a string, ArrayBuffer or ArrayBufferView`);\n}\nfunction guessEncoding(blob) {\n    const uint8 = ArrayBuffer.isView(blob)\n        ? new Uint8Array(blob.buffer, blob.byteOffset, blob.byteLength)\n        : new Uint8Array(blob);\n    if (uint8.length >= 2) {\n        if (uint8[0] === 0xfe && uint8[1] === 0xff) {\n            return 'utf-16be';\n        }\n        if (uint8[0] === 0xff && uint8[1] === 0xfe) {\n            return 'utf-16le';\n        }\n    }\n    //@ts-expect-error an ArrayBuffer is also ok\n    if (!isutf8(blob))\n        return 'latin1';\n    return 'utf-8';\n}\n//# sourceMappingURL=index.js.map","/*\n    https://tools.ietf.org/html/rfc3629\n\n    UTF8-char = UTF8-1 / UTF8-2 / UTF8-3 / UTF8-4\n\n    UTF8-1    = %x00-7F\n\n    UTF8-2    = %xC2-DF UTF8-tail\n\n    UTF8-3    = %xE0 %xA0-BF UTF8-tail\n                %xE1-EC 2( UTF8-tail )\n                %xED %x80-9F UTF8-tail\n                %xEE-EF 2( UTF8-tail )\n\n    UTF8-4    = %xF0 %x90-BF 2( UTF8-tail )\n                %xF1-F3 3( UTF8-tail )\n                %xF4 %x80-8F 2( UTF8-tail )\n\n    UTF8-tail = %x80-BF\n*/\n/**\n * Check if a Node.js Buffer or Uint8Array is UTF-8.\n */\nfunction isUtf8(buf) {\n    if (!buf) {\n        return false;\n    }\n    var i = 0;\n    var len = buf.length;\n    while (i < len) {\n        // UTF8-1 = %x00-7F\n        if (buf[i] <= 0x7F) {\n            i++;\n            continue;\n        }\n        // UTF8-2 = %xC2-DF UTF8-tail\n        if (buf[i] >= 0xC2 && buf[i] <= 0xDF) {\n            // if(buf[i + 1] >= 0x80 && buf[i + 1] <= 0xBF) {\n            if (buf[i + 1] >> 6 === 2) {\n                i += 2;\n                continue;\n            }\n            else {\n                return false;\n            }\n        }\n        // UTF8-3 = %xE0 %xA0-BF UTF8-tail\n        // UTF8-3 = %xED %x80-9F UTF8-tail\n        if (((buf[i] === 0xE0 && buf[i + 1] >= 0xA0 && buf[i + 1] <= 0xBF) ||\n            (buf[i] === 0xED && buf[i + 1] >= 0x80 && buf[i + 1] <= 0x9F)) && buf[i + 2] >> 6 === 2) {\n            i += 3;\n            continue;\n        }\n        // UTF8-3 = %xE1-EC 2( UTF8-tail )\n        // UTF8-3 = %xEE-EF 2( UTF8-tail )\n        if (((buf[i] >= 0xE1 && buf[i] <= 0xEC) ||\n            (buf[i] >= 0xEE && buf[i] <= 0xEF)) &&\n            buf[i + 1] >> 6 === 2 &&\n            buf[i + 2] >> 6 === 2) {\n            i += 3;\n            continue;\n        }\n        // UTF8-4 = %xF0 %x90-BF 2( UTF8-tail )\n        //          %xF1-F3 3( UTF8-tail )\n        //          %xF4 %x80-8F 2( UTF8-tail )\n        if (((buf[i] === 0xF0 && buf[i + 1] >= 0x90 && buf[i + 1] <= 0xBF) ||\n            (buf[i] >= 0xF1 && buf[i] <= 0xF3 && buf[i + 1] >> 6 === 2) ||\n            (buf[i] === 0xF4 && buf[i + 1] >= 0x80 && buf[i + 1] <= 0x8F)) &&\n            buf[i + 2] >> 6 === 2 &&\n            buf[i + 3] >> 6 === 2) {\n            i += 4;\n            continue;\n        }\n        return false;\n    }\n    return true;\n}\n\nexport { isUtf8 as default };\n","export function parseString(value) {\n    if (value.length === 4 || value.length === 5) {\n        const lowercase = value.toLowerCase();\n        if (lowercase === 'true')\n            return true;\n        if (lowercase === 'false')\n            return false;\n    }\n    const number = Number(value);\n    if (number === 0 && !value.includes('0')) {\n        return value;\n    }\n    if (!Number.isNaN(number))\n        return number;\n    return value;\n}\n//# sourceMappingURL=parseString.js.map","import { getGyromagneticNucleus, gyromagneticRatio } from '.';\n/**\n * Returns the gyromagnetic ratio for a given nucleus string.\n * @param nucleus - The name or symbol of the nucleus (e.g., '1H', 'proton').\n * @returns The gyromagnetic ratio for the nucleus, or null if not found.\n */\nexport function getGyromagneticRatio(nucleus) {\n    const realNucleus = getGyromagneticNucleus(nucleus);\n    if (realNucleus) {\n        return gyromagneticRatio[realNucleus];\n    }\n    return null;\n}\n//# sourceMappingURL=getGyromagneticRatio.js.map","import { gyromagneticRatio } from '.';\n/**\n * Attempts to resolve a nucleus string to a canonical gyromagnetic nucleus symbol.\n * @param nucleus - The name or symbol of the nucleus (e.g., '1H', 'proton').\n * @returns The canonical nucleus symbol if found, otherwise null.\n */\nexport function getGyromagneticNucleus(nucleus) {\n    nucleus = nucleus.toLowerCase();\n    if (nucleus === 'proton')\n        return '1H';\n    for (const key in gyromagneticRatio) {\n        if (key.toLowerCase() === nucleus)\n            return key;\n    }\n    if (nucleus in gyromagneticRatio) {\n        return nucleus;\n    }\n    // we try to use only the numbers\n    const nucleusNumber = nucleus.replaceAll(/[^0-9]/g, '');\n    if (!nucleusNumber)\n        return null;\n    const filteredNuclei = [];\n    for (const key in gyromagneticRatio) {\n        if (key.replaceAll(/[^0-9]/g, '') === nucleusNumber) {\n            filteredNuclei.push(key);\n        }\n    }\n    if (filteredNuclei.length === 1) {\n        return filteredNuclei[0];\n    }\n    return null;\n}\n//# sourceMappingURL=getGyromagneticNucleus.js.map","import { gyromagneticRatioMHzT } from './gyromagneticRatioMHzT';\nexport const gyromagneticRatio = Object.fromEntries(Object.entries(gyromagneticRatioMHzT).map(([key, value]) => [\n    key,\n    value * 2 * Math.PI * 1e6,\n]));\nexport * from './gyromagneticRatioMHzT';\nexport * from './getGyromagneticNucleus';\nexport * from './getGyromagneticRatio';\n//# sourceMappingURL=index.js.map","export const gyromagneticRatioMHzT = {\n    '1H': 42.577478615342585,\n    '2H': 6.5359028540009305,\n    '3H': 45.41483815473964,\n    '3He': -32.43604456417949,\n    '6Li': 6.266099405837534,\n    '7Li': 16.548177299618295,\n    '9Be': -5.983379963834242,\n    '10B': 4.57473388220653,\n    '11B': 13.66160796005943,\n    '13C': 10.707746367473973,\n    '14N': 3.076272817251739,\n    '15N': -4.3152552187859134,\n    '17O': -5.7734832203316975,\n    '19F': 40.06924371705693,\n    '21Ne': -3.362579959801532,\n    '22Na': 4.436349259342206,\n    '23Na': 11.268733657034753,\n    '25Mg': -2.607933066661972,\n    '26Al': 4.273225764239245,\n    '27Al': 11.100630067688776,\n    '29Si': -8.461871234008282,\n    '31P': 17.241162495263175,\n    '33S': 3.2688220630834754,\n    '35Cl': 4.175656570906633,\n    '36Cl': 4.897135020041924,\n    '37Cl': 3.4759025124743057,\n    '39Ar': -3.462835209795831,\n    '39K': 1.9893443809332112,\n    '40K': -2.4734743333970806,\n    '41K': 1.091921234883595,\n    '41Ca': -3.4724832349401047,\n    '43Ca': -2.8689916395725414,\n    '45Sc': 10.353659488911559,\n    '47Hi': -2.403068251036403,\n    '49Hi': -2.403730327705445,\n    '50V': 4.248579379465121,\n    '51V': 11.208261084083814,\n    '53Cr': -2.4103147963328766,\n    '53Mn': 10.961289063460638,\n    '55Mn': 10.570707386401027,\n    '57Fe': 1.3818237005731187,\n    '59Co': 10.050933643526891,\n    '60Co': 5.7916463354780205,\n    '61Ni': -3.809518009468367,\n    '63Ni': 7.561612483277437,\n    '63Cu': 11.311420179117773,\n    '65Cu': 12.116874196993763,\n    '67Zn': 2.6674502745948656,\n    '69Ga': 10.23978520568125,\n    '71Ga': 13.010902748192017,\n    '73Ge': -1.4876591727852992,\n    '75As': 7.3090505609529135,\n    '77Se': 8.134221686648205,\n    '79Se': -2.21708568778123,\n    '79Br': 10.695006473323717,\n    '81Br': 11.528409999706447,\n    '81Kr': -1.9753405882294455,\n    '83Kr': -1.6443288722876133,\n    '85Kr': -1.703226109304539,\n    '85Rb': 4.125530397832004,\n    '87Rb': 13.981309683545954,\n    '87Sr': -1.851714225407608,\n    '89Y': -2.0931336103407774,\n    '91Zr': -3.970456361178983,\n    '91Nb': 11.032433266932335,\n    '92Nb': 5.58627189504799,\n    '93Nb': 10.439564904668199,\n    '95Mo': -2.784380854729418,\n    '97Mo': -2.842922370728985,\n    '97Hc': 9.858553909649345,\n    '99Hc': 9.618018745530753,\n    '99Ru': -1.9544329039438861,\n    '101Ru': -2.1892087754004836,\n    '103Rh': -1.3459975123963002,\n    '105Pd': -1.9574819412355304,\n    '107Ag': -1.730633566737207,\n    '109Ag': 1.9896492846623755,\n    '111Cd': -9.05564075618306,\n    '113Cd': -9.471834346492482,\n    '113In': 9.351736155393834,\n    '115In': 9.371724288750167,\n    '115Sn': -13.985934056771613,\n    '117Sn': -15.237563864991529,\n    '119Sn': -15.944940516652968,\n    '121Sn': 3.541456814244654,\n    '121Sb': 10.238667225340981,\n    '123Sb': 5.544238738098897,\n    '125Sb': 5.727834340731468,\n    '123He': -11.217408195958745,\n    '125He': -13.522480388441707,\n    '127I': 8.563831041040862,\n    '129I': 5.6984329097048985,\n    '129Xe': -11.860160502223787,\n    '131Xe': 3.5157686750625525,\n    '133Cs': 5.614148807428737,\n    '134Cs': 5.69655448494487,\n    '135Cs': 5.941920316280481,\n    '137Cs': 6.179527436650749,\n    '133Ba': 11.767759427100511,\n    '135Ba': 4.258996923544905,\n    '137Ba': 4.7641207681939495,\n    '137La': 5.871574670194692,\n    '138La': 5.653524946166542,\n    '139La': 6.052556812291568,\n    '141Pr': 13.00719308615385,\n    '143Nd': -2.319446225429283,\n    '145Nd': -1.4286917595132482,\n    '145Pm': 11.586341708247685,\n    '147Pm': 5.618940151744178,\n    '147Sm': -1.7619079778143567,\n    '149Sm': -1.454172999736274,\n    '151Sm': -1.099177943637708,\n    '150Eu': 4.119249381011216,\n    '151Eu': 10.560340659609437,\n    '152Eu': -4.917588978540037,\n    '153Eu': 4.66319763384053,\n    '154Eu': -5.081728819406879,\n    '155Eu': 4.622340534132499,\n    '155Gd': -1.3166759371083225,\n    '157Gd': -1.7267714528344573,\n    '157Hb': 10.315909503395963,\n    '158Hb': 4.4541353102101295,\n    '159Hb': 10.209193198188421,\n    '161Hy': -1.4604888626975372,\n    '163Hy': 2.04590402269321,\n    '163Ho': 9.190669550527298,\n    '165Ho': 9.059996523742551,\n    '166Ho': 3.941969641339908,\n    '167Er': -1.2246240493510665,\n    '169Hm': -3.5216380718489675,\n    '171Hm': -3.506392885390747,\n    '171Yb': 7.505205293382021,\n    '173Yb': -2.067247283734719,\n    '173Lu': 4.950329831362216,\n    '174Lu': 15.107979780096652,\n    '175Lu': 4.847315928580239,\n    '176Lu': 3.4410563719983727,\n    '177Hf': 1.7227060697789323,\n    '179Hf': -1.0822388475730185,\n    '179Ha': 4.978642320498912,\n    '180Ha': 4.077240422770786,\n    '181Ha': 5.15069513909883,\n    '183W': 1.7896324383305209,\n    '185Re': 9.683742438261751,\n    '187Re': 9.784360668886006,\n    '187Os': 0.9820949116385737,\n    '189Os': 3.3417448716419638,\n    '191Ir': 0.7632756686749131,\n    '193Ir': 0.8283217975633214,\n    '193Pt': 9.162357061390605,\n    '195Pt': 9.258401736077394,\n    '197Au': 0.7378670245778789,\n    '199Hg': 7.68204945629738,\n    '201Hg': -2.8356046812290385,\n    '203Hl': 24.63622131648455,\n    '204Hl': 0.3430166953099643,\n    '205Hl': 24.88014429981608,\n    '205Pb': 2.162987054692344,\n    '207Pb': 9.00380712222511,\n    '207Bi': 6.899124436187426,\n    '208Bi': 6.970099248698476,\n    '209Bi': 6.931478109670983,\n    '209Po': 10.366726791590036,\n    '227Ac': 6.1997091596763925,\n    '229Hh': 1.402557154156299,\n    '231Pa': 10.11264035061969,\n    '233U': -1.7989320020700355,\n    '235U': -0.827595836303406,\n    '237Np': 9.634957841595446,\n    '239Pu': 3.079527664560569,\n    '241Pu': -2.067247283734719,\n    '241Am': 4.878459666630606,\n    '243Am': 4.634536683299075,\n    '243Cm': 1.2196149166576515,\n    '245Cm': 1.0889418898729026,\n    '247Cm': 0.6098074583288254,\n};\n//# sourceMappingURL=gyromagneticRatioMHzT.js.map","(function(){function a(d){for(var e=0,f=d.length-1,g=void 0,h=void 0,i=void 0,j=c(e,f);!0;){if(f<=e)return d[j];if(f==e+1)return d[e]>d[f]&&b(d,e,f),d[j];for(g=c(e,f),d[g]>d[f]&&b(d,g,f),d[e]>d[f]&&b(d,e,f),d[g]>d[e]&&b(d,g,e),b(d,g,e+1),h=e+1,i=f;!0;){do h++;while(d[e]>d[h]);do i--;while(d[i]>d[e]);if(i<h)break;b(d,h,i)}b(d,e,i),i<=j&&(e=h),i>=j&&(f=i-1)}}var b=function b(d,e,f){var _ref;return _ref=[d[f],d[e]],d[e]=_ref[0],d[f]=_ref[1],_ref},c=function c(d,e){return~~((d+e)/2)};'undefined'!=typeof module&&module.exports?module.exports=a:window.median=a})();\n","import { isAnyArray } from 'is-any-array';\nimport quickSelectMedian from 'median-quickselect';\n\nfunction median(input) {\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  return quickSelectMedian(input.slice());\n}\n\nexport { median as default };\n","import{ensureString as fe}from\"ensure-string\";var $=/\\s*\\$\\$.*/;function M(e){return e.replace($,\"\")}function Te(e,m={}){e=fe(e);let{flatten:n=!1}=m,s=e.split(/\\r?\\n/),f=[],i=[],t=[],l={title:\"\",jcamp:\"\",children:[]},r=0,p=e.includes(\"## \");for(let c=0;c<s.length;c++){let b=s[c],h=p?b.replaceAll(\" \",\"\"):b;if(h.startsWith(\"##NTUPLES\")&&r++,h.startsWith(\"##TITLE\")){let o=[h.slice(8).trim()];for(let a=c+1;a<s.length&&!s[a].startsWith(\"##\");a++)o.push(s[a].trim());i.push({title:o.join(`\n`),jcamp:`${b}\n`,children:[]}),l=i.at(-1),f.push(l)}else if(h.startsWith(\"##END\")&&r===0&&l){l.jcamp+=`${b}\n`;let o=i.pop();if(!o)throw new Error(\"Not finished\");i.length>0?(l=i.at(-1),l.children?.push(o)):(l=void 0,t.push(o))}else if(l?.jcamp){l.jcamp+=`${b}\n`;let o=h.match(/^##(.*?)=(.+)/);if(o){let a=o[1].replaceAll(/[ _-]/g,\"\").toUpperCase();a===\"DATATYPE\"?l.dataType=o[2].trim():a===\"DATACLASS\"?l.dataClass=o[2].trim():a===\"JCAMPDX\"?l.jcampDX=M(o[2].trim()):a===\"JCAMPCS\"&&(l.jcampCS=M(o[2].trim()))}}h.startsWith(\"##END\")&&r>0&&r--}if(n){for(let c of f)c.children=void 0;return f}else return t}import{parseString as de}from\"dynamic-typing\";import{ensureString as be}from\"ensure-string\";var ee=[\"TIC\",\".RIC\",\"SCANNUMBER\"];function te(e){let m=e.spectra,n=m.length,s={times:new Array(n),series:{ms:{dimension:2,data:new Array(n)}}},f=[];for(let i of ee){let t=U(i);m[0][t]&&(f.push(t),s.series[t]={dimension:1,data:new Array(n)})}for(let i=0;i<n;i++){let t=m[i];s.times[i]=t.pageValue;for(let l of f)s.series[l].data[i]=Number(t[l]);t.data&&(s.series.ms.data[i]=[t.data.x,t.data.y])}e.chromatogram=s}function ne(e){return ee.includes(e)}function U(e){return e.toLowerCase().replaceAll(/[^a-z0-9]/g,\"\")}function E(e){return e.map(Number)}function k(e,m,n){let{logger:s}=n;s&&(e.xFactor||s.info(\"The xFactor is not defined, it will be set to 1\"),e.yFactor||s.info(\"The yFactor is not defined, it will be set to 1\"));let f=e.yFactor??1,i=e.xFactor??1,t=e.deltaX??1,l=Math.abs(t*.1),r=.01;e.isXYdata=!0;let p={x:[],y:[]};e.data=p;let c=e.firstX||0,b=e.firstY||0,h=!1,o,a=0;for(;a<m.length;a++)if(o=m.codePointAt(a),o===13||o===10)h=!0;else if(h)break;let u=0,d=!0,C=!1,x=!1,j=0,N=!1,S=!1,g=0,X=0,O=!1,A=!1,Y=!1,R=0;for(;a<=m.length;a++)if(a===m.length?o=13:o=m.codePointAt(a),S)(o===13||o===10)&&(d=!0,S=!1,u++);else if(o<=57&&o>=48)A=!0,R>0?g+=(o-48)/10**R++:(g*=10,g+=o-48);else if(o===44||o===46)A=!0,R++;else{if(A){if(O&&(g=g*-1,O=!1),d)g*=i,s&&(x?Math.abs(c-t-g)>l&&(Math.abs(c-g)<l?s.trace(`Data line ${u}: After a DIFFERENCE the next line should repeat the last value and this does not seem to be the case: Current value: ${g} - Expected: ${c}.`):Math.abs(c-t-g)>10*l?s.trace(`Data line ${u}: The difference between the first value ${g} and the expected first x value ${c} based on increment after a DIFFERENCE is too high`):s.trace(`Data line ${u}: The difference between the first value ${g} and the expected first x value ${c} based on increment after a DIFFERENCE is too high`)):Math.abs(c-g)>l&&s.trace(`Data line ${u}: The difference between the first value ${g} and the first x value ${c} is too high`)),d=!1,x&&(Y=!0);else if(Y)Y=!1,s&&Math.abs(b-g)>r&&s.trace(`Data line ${u}: After a duplicate the next line should repeat the same value ${g} !== ${b}`),b=g;else{C?(j=O?0-g:g,x=!0,C=!1):N||(X=O?0-g:g);let y=N?g-1:1;for(let F=0;F<y;F++)x?b+=j:b=X,p.x.push(c),p.y.push(b*f),c+=t}O=!1,g=0,R=0,A=!1,N=!1}if(o<74&&o>63)A=!0,x=!1,g=o-64;else if(o>96&&o<106)A=!0,x=!1,g=o-96,O=!0;else if(o===115)A=!0,N=!0,g=9;else if(o>82&&o<91)A=!0,N=!0,g=o-82;else if(o>73&&o<83)A=!0,C=!0,g=o-73;else if(o>105&&o<115)A=!0,C=!0,g=o-105,O=!0;else if(o===36&&m.codePointAt(a+1)===36)A=!0,S=!0;else if(o===37)A=!0,C=!0,g=0,O=!1;else if(o===45){let y=m.codePointAt(a+1);(y!==void 0&&y>=48&&y<=57||y===44||y===46)&&(A=!0,d||(x=!1),O=!0)}else(o===13||o===10)&&(d=!0,S=!1,u++)}s&&x&&s.warn(\"The last value is a difference, it should be repeated on the next line\")}var re=/[,\\t ]+/;function P(e,m,n){if(e.isPeaktable=!0,!e.variables||Object.keys(e.variables).length===2?me(e,m,n):ce(e,m,n),e.variables)for(let s in e.variables)e.variables[s].data=e.data?.[s]}function me(e,m,n){let{logger:s}=n,f={x:[],y:[]};e.data=f;let i=m.split(/,? *,?[;\\r\\n]+ */);for(let t=1;t<i.length;t++){let l=i[t].trim().replace($,\"\").split(re);if(l.length%2===0)for(let r=0;r<l.length;r=r+2)e.xFactor!==void 0&&e.yFactor!==void 0&&(f.x.push(Number(l[r])*e.xFactor),f.y.push(Number(l[r+1])*e.yFactor));else s?.warn(`Format error: ${l.toString()}`)}}function ce(e,m,n){let{logger:s}=n,f={},i=Object.keys(e.variables),t=i.length;for(let r of i)f[r]=[];e.data=f;let l=m.split(/,? *,?[;\\r\\n]+ */);for(let r=1;r<l.length;r++){let p=l[r].trim().replace($,\"\").split(re);if(p.length%t===0)for(let c=0;c<p.length;c++)f[i[c%t]].push(Number(p[c]));else s?.warn(`Wrong number of columns: ${p.toString()}`)}}function V(e,m){e.isXYAdata=!0;let n={};e.data=n;let s=m.split(/\\r?\\n/),f=s[0].replace(/^.*?([A-Z]+).*$/,\"$1\").split(\"\").map(i=>i.toLowerCase());for(let i=1;i<s.length;i++){let t=s[i].replace(/^\\((.*)\\)$/,\"$1\").split(/ *, */);for(let l=0;l<f.length;l++){let r=t[l];switch(f[l]){case\"x\":case\"y\":case\"w\":r=Number.parseFloat(r);break;case\"a\":r=r.replace(/^<(.*)>$/,\"$1\");break;case\"m\":break;default:continue}n[f[l]]||(n[f[l]]=[]),n[f[l]].push(r)}}}import{parseString as ae}from\"dynamic-typing\";import{getGyromagneticRatio as se}from\"gyromagnetic-ratio\";import ie from\"ml-array-median\";function oe(e){return Array.isArray(e)?e[0]:e}function B(e){let{spectra:m}=e,n=m[0].data.y[0],s=n,f=m.length,i=m[0].data.x.length||0,t=new Array(f);for(let o=0;o<f;o++){t[o]=m[o].data.y;for(let a=0;a<i;a++){let u=t[o][a];u<n&&(n=u),u>s&&(s=u)}}let l=m[0].data.x[0],r=m[0].data.x.at(-1),{firstY:p,lastY:c}=ue(e);if(l>r)for(let o of t)o.reverse();p>c&&t.reverse();let b=[];for(let o of t){let a=Float64Array.from(o);for(let u=0;u<a.length;u++)a[u]<0&&(a[u]=-a[u]);b.push(ie(a))}let h=ie(b);return{z:t,minX:Math.min(l,r),maxX:Math.max(l,r),minY:Math.min(p,c),maxY:Math.max(p,c),minZ:n,maxZ:s,noise:h}}function ue(e){let{spectra:m,ntuples:n,info:s}=e;if(n)for(let f of n){let{symbol:i,nucleus:t,units:l}=f;if(i.match(/[F|T]1/)&&l?.toUpperCase().match(\"HZ\")){let r=oe(s[\".OBSERVEFREQUENCY\"]),{nucleus:p}=n.find(u=>u.symbol.match(/[F|T]2/));if([r,p,t].some(u=>!u))break;let c=se(p),b=se(t),{first:h,last:o}=f,a=b!==null&&c!==null?r*b/c:r;return{firstY:h/a,lastY:o/a}}}return{firstY:m[0].pageValue,lastY:m.at(-1).pageValue}}function Z(e,m){let n=e.noise,s=e.z,f,i,t,l,r,p,c,b,h=s.length,o=s[0].length,a,u,d,C,x=e.minX,N=(e.maxX-x)/(o-1),S=e.minY,X=(e.maxY-S)/(h-1),O=e.minZ,A=e.maxZ,Y=m.nbContourLevels*2,R=new Array(Y),y;for(let F=0;F<Y;F++){let I={};R[F]=I;let le=F%2,K=(A-m.noiseMultiplier*n)*Math.exp((F>>1)-m.nbContourLevels);le===0?y=K+m.noiseMultiplier*n:y=0-K-m.noiseMultiplier*n;let D=[];if(I.zValue=y,I.lines=D,!(y<=O||y>=A))for(let T=0;T<h-1;T++){let Q=s[T],_=s[T+1];for(let v=0;v<o-1;v++)f=Q[v],i=Q[v+1],t=_[v],l=_[v+1],r=f>y,p=i>y,c=t>y,b=l>y,r!==p&&r!==c&&(a=v+(y-f)/(i-f),u=T,d=v,C=T+(y-f)/(t-f),D.push(a*N+x,u*X+S,d*N+x,C*X+S)),b!==p&&b!==c&&(a=v+1,u=T+1-(y-l)/(i-l),d=v+1-(y-l)/(t-l),C=T+1,D.push(a*N+x,u*X+S,d*N+x,C*X+S)),p!==c&&(a=(v+1-(y-i)/(t-i))*N+x,u=(T+(y-i)/(t-i))*X+S,p!==r&&(d=v+1-(y-i)/(f-i),C=T,D.push(a,u,d*N+x,C*X+S)),c!==r&&(d=v,C=T+1-(y-t)/(f-t),D.push(a,u,d*N+x,C*X+S)),p!==b&&(d=v+1,C=T+(y-i)/(l-i),D.push(a,u,d*N+x,C*X+S)),c!==b&&(d=v+(y-t)/(l-t),C=T+1,D.push(a,u,d*N+x,C*X+S)))}}return{minX:e.minX,maxX:e.maxX,minY:e.minY,maxY:e.maxY,segments:R}}function G(e,m){let n=B(e);m.noContour||(e.contourLines=Z(n,m),delete n.z),e.minMax=n}import{getGyromagneticRatio as W}from\"gyromagnetic-ratio\";function H(e,m){for(let n of e){let s=0,f=0;for(let i of n.spectra){if(n.ntuples?.symbol?(!s&&i.observeFrequency&&(s=i.observeFrequency),!f&&i.shiftOffsetVal&&(f=i.shiftOffsetVal)):(s=i.observeFrequency,f=i.shiftOffsetVal),s&&i.xUnits?.toUpperCase().includes(\"HZ\")&&(i.xUnits=\"PPM\",i.xFactor=i.xFactor!==void 0?i.xFactor/s:void 0,i.firstX=i.firstX!==void 0?i.firstX/s:void 0,i.lastX=i.lastX!==void 0?i.lastX/s:void 0,i.deltaX=i.deltaX!==void 0?i.deltaX/s:void 0,i.data))for(let t=0;t<i.data.x.length;t++)i.data.x[t]/=s;if(f&&i.xUnits.toLowerCase().includes(\"ppm\")&&i.firstX!==void 0&&i.lastX!==void 0){let t=i.firstX-f;if(i.firstX=i.firstX-t,i.lastX=i.lastX-t,i.data)for(let l=0;l<i.data.x.length;l++)i.data.x[l]-=t}if(n.ntuples?.nucleus&&n.ntuples.symbol)for(let t=0;t<n.ntuples.nucleus.length;t++){let l=n.ntuples.symbol[t],r=n.ntuples.nucleus[t];if(l.match(/^[F|T]/)&&!r){if(l.match(/[F|T]1/))if(n.tmp.$NUC2&&typeof n.tmp.$NUC2==\"string\")n.ntuples.nucleus[t]=n.tmp.$NUC2;else{let p=n.ntuples.symbol.indexOf(l.replace(/^([F|T]).*/,\"$12\"));p&&n.ntuples.nucleus[p]&&(n.ntuples.nucleus[t]=n.ntuples.nucleus[p])}l.match(/[F|T]2/)&&typeof n.tmp.$NUC1==\"string\"&&(n.ntuples.nucleus[t]=n.tmp.$NUC1)}l.match(/[F|T]2/)&&(n.yType=n.ntuples.nucleus[0],n.xType&&!W(n.xType)&&(n.xType=n.ntuples.nucleus[1]))}if(s&&n.ntuples?.symbol&&n.ntuples.nucleus){let t=\"\",l=n.ntuples.symbol.indexOf(i.pageSymbol);n.ntuples.units?.[l]&&(t=n.ntuples.units[l]);let{nucleus:r}=n.ntuples;if(!t.toLowerCase().match(/(ppm|seconds)/)&&r.length>1){if(l!==0){let h=\"Not sure about this ntuples format\";if(m){m.warn(h);continue}else throw new Error(h)}let{nucleus:p}=n.ntuples,c=W(p[0]),b=W(p[1]);if(!c||!b){let h=`Problem with determination of gyromagnetic ratio for ${p.join(\"-\")}`;if(m)m.error(h);else throw new Error(h)}else{let h=c/b*s;i.pageValue/=h}}}}}}function J(e){let m=e.spectra[0].data;e.chromatogram={times:m.x.slice(),series:{intensity:{dimension:1,data:m.y.slice()}}}}function q(e,m,n){H(e,n.logger),pe(e,n);for(let s of e){if(Object.keys(s.ntuples).length>0){let f=[],i=Object.keys(s.ntuples);for(let t of i){let l=s.ntuples[t];if(l)for(let r=0;r<l.length;r++)f[r]||(f[r]={}),f[r][t]=l[r]}s.ntuples=f}s.twoD&&n.wantXY&&(G(s,n),n.logger?.trace({profiling:!0},\"Finished countour plot calculation\"),n.keepSpectra||delete s.spectra),n.chromatogram&&(s.spectra.length>1?te(s):J(s),n.logger?.trace({profiling:!0},\"Finished chromatogram calculation\")),delete s.tmp}}function pe(e,m){for(let n of e)for(let s in n.meta){let f=n.meta[s];if(typeof f==\"string\"){if(f.startsWith(\"{\")){if(!f.includes(\":\")&&f.endsWith(\"}\")){let i=f.slice(1,-1).split(/[,; ]+/).filter(Boolean);for(let t=0;t<i.length;t++)n.meta[s+String(t)]=m.dynamicTyping?ae(i[t]):i[t]}}else if(f.startsWith(\"(\")){let i=f.split(/\\r?\\n/),t=/^\\((?<from>\\d+)\\.\\.(?<to>\\d+)\\).*$/;if(t.test(i[0])){let[l,r]=i[0].match(t)?.slice(1).map(Number)??[],p=i.slice(1).join(\" \").split(/[,; ]+/).filter(Boolean);for(let c=l;c<=r;c++)m.dynamicTyping&&typeof p[c-l]==\"string\"?n.meta[s+String(c)]=ae(p[c-l]):n.meta[s+String(c)]=p[c-l]}}}}}function z(e,m,n){let s=-1,f=-1,i=\"\",t=\"\";if(n.indexOf(\"++\")>0)i=n.replace(/.*\\(([a-zA-Z0-9]+)\\+\\+.*/,\"$1\"),t=n.replace(/.*\\.\\.([a-zA-Z0-9]+).*/,\"$1\");else{n=n.replaceAll(/[^a-zA-Z%]/g,\"\"),i=n.charAt(0),t=n.charAt(1),m.variables={};for(let l of n){let r=l.toLowerCase(),p=e.ntuples.symbol?.indexOf(l)||0;if(p===-1)throw new Error(`Symbol undefined: ${l}`);m.variables[r]={};for(let c in e.ntuples)e.ntuples[c]?.[p]&&(m.variables[r][c.replace(/^var/,\"\")]=e.ntuples[c]?.[p])}}s=e.ntuples.symbol?.indexOf(i)??-1,f=e.ntuples.symbol?.indexOf(t)??-1,s===-1&&(s=0),f===-1&&(f=0),e.ntuples.first&&(e.ntuples.first.length>s&&(m.firstX=e.ntuples.first[s]),e.ntuples.first.length>f&&(m.firstY=e.ntuples.first[f])),e.ntuples.last&&(e.ntuples.last.length>s&&(m.lastX=e.ntuples.last[s]),e.ntuples.last.length>f&&(m.lastY=e.ntuples.last[f])),e.ntuples.vardim&&e.ntuples.vardim.length>s&&(m.nbPoints=e.ntuples.vardim[s]),e.ntuples.factor&&(e.ntuples.factor.length>s&&(m.xFactor=e.ntuples.factor[s]),e.ntuples.factor.length>f&&(m.yFactor=e.ntuples.factor[f])),e.ntuples.units&&(e.ntuples.units.length>s&&(e.ntuples.varname?.[s]?m.xUnits=`${e.ntuples.varname[s]} [${e.ntuples.units[s]}]`:m.xUnits=e.ntuples.units[s]),e.ntuples.units.length>f&&(e.ntuples.varname?.[f]?m.yUnits=`${e.ntuples.varname[f]} [${e.ntuples.units[f]}]`:m.yUnits=e.ntuples.units[f]))}function w(e){e.xFactor||(e.xFactor=1),e.yFactor||(e.yFactor=1)}var L=/[ \\t]*,[ \\t]*/,ge={removeComments:!1,keepRecordsRegExp:/^$/,canonicDataLabels:!0,canonicMetadataLabels:!1,dynamicTyping:!0,withoutXY:!1,noTrimRegExp:/^$/,chromatogram:!1,keepSpectra:!1,noContour:!1,nbContourLevels:7,noiseMultiplier:5};function mt(e,m={}){e=be(e);let n={...ge,...m};n.logger?.debug(\"Starting jcamp conversion\"),n.wantXY=!n.withoutXY,n.start=Date.now();let s=[],f={entries:[],flatten:[]},i={children:[],spectra:[],ntuples:{},info:{},meta:{},tmp:{}},t=i,l=[],r={data:{}};n.logger?.trace({profiling:!0},\"Before split to LDRS\");let p=e.replaceAll(/[\\r\\n]+##/g,`\n##`).split(`\n##`);n.logger?.trace({profiling:!0},\"Split to LDRS\"),p[0]&&(p[0]=p[0].replace(/^[\\r\\n ]*##/,\"\"));for(let c of p){let b=c.indexOf(\"=\"),h=b>0?c.slice(0,Math.max(0,b)):c,o=b>0?h.match(n.noTrimRegExp)?c.slice(Math.max(0,b+1)):c.slice(Math.max(0,b+1)).trim():\"\",a=h.replaceAll(/[_ -]/g,\"\").toUpperCase();if(a===\"DATATABLE\"){let u=o.indexOf(`\n`);if(u===-1&&(u=o.indexOf(\"\\r\")),u>0){let d=o.slice(0,Math.max(0,u)).split(/[ ,;\\t]+/);z(t,r,d[0]),r.datatable=d[0],d[1]?.includes(\"PEAKS\")?a=\"PEAKTABLE\":d[1]&&(d[1].indexOf(\"XYDATA\")||d[0].indexOf(\"++\")>0)&&(a=\"XYDATA\",r.nbPoints&&r.lastX!==void 0&&r.firstX!==void 0&&(r.deltaX=(r.lastX-r.firstX)/(r.nbPoints-1)))}}if(a===\"XYDATA\"){n.wantXY&&(w(r),o.match(/.*\\+\\+.*/)?(r.nbPoints&&r.lastX!==void 0&&r.firstX!==void 0&&(r.deltaX=(r.lastX-r.firstX)/(r.nbPoints-1)),k(r,o,n)):P(r,o,n),t?.spectra.push(r),r={data:{}});continue}else if(a===\"PEAKTABLE\"){n.wantXY&&(w(r),P(r,o,n),t?.spectra.push(r),r={data:{}});continue}if(a===\"PEAKASSIGNMENTS\"){n.wantXY&&(o.match(/.*[^A-Z]*.*/)&&V(r,o),t?.spectra.push(r),r={data:{}});continue}if(n.removeComments&&(o=o.split(/\\r?\\n/).map(u=>u.replace(/ *\\$\\$.*$/,\"\")).join(`\n`)),a===\"TITLE\"){let u=t;u.children||(u.children=[]),t={spectra:[],ntuples:{},info:{},meta:{},tmp:{}},u.children.push(t),l.push(u),s.push(t),t.title=o}else a===\"DATATYPE\"?(t.dataType=o,o.match(/^nd|\\snd\\s/i)&&(t.twoD=!0)):a===\"NTUPLES\"?o.match(/^nd|\\snd\\s/i)&&(t.twoD=!0):a===\"DATACLASS\"?t.dataClass=o:a===\"JCAMPDX\"?t.jcampDX=M(o):a===\"JCAMPCS\"?t.jcampCS=M(o):a===\"XUNITS\"?r.xUnits=o:a===\"YUNITS\"?r.yUnits=o:a===\"FIRSTX\"?r.firstX=Number(o):a===\"LASTX\"?r.lastX=Number(o):a===\"FIRSTY\"?r.firstY=Number(o):a===\"LASTY\"?r.lastY=Number(o):a===\"NPOINTS\"?r.nbPoints=Number(o):a===\"XFACTOR\"?r.xFactor=Number(o):a===\"YFACTOR\"?r.yFactor=Number(o):a===\"MAXX\"?r.maxX=Number(o):a===\"MINX\"?r.minX=Number(o):a===\"MAXY\"?r.maxY=Number(o):a===\"MINY\"?r.minY=Number(o):a===\"DELTAX\"?r.deltaX=Number(o):a===\".OBSERVEFREQUENCY\"||a===\"$SFO1\"?r.observeFrequency||(r.observeFrequency=Number(o)):a===\".OBSERVENUCLEUS\"?r.xType||(t.xType=o.replaceAll(/[^a-zA-Z0-9]/g,\"\")):a===\"$OFFSET\"?(t.shiftOffsetNum=0,r.shiftOffsetVal||(r.shiftOffsetVal=Number(o))):a===\"$REFERENCEPOINT\"||(a===\"VARNAME\"?t.ntuples.varname=o.split(L):a===\"SYMBOL\"?t.ntuples.symbol=o.split(L):a===\"VARTYPE\"?t.ntuples.vartype=o.split(L):a===\"VARFORM\"?t.ntuples.varform=o.split(L):a===\"VARDIM\"?t.ntuples.vardim=E(o.split(L)):a===\"UNITS\"?t.ntuples.units=o.split(L):a===\"FACTOR\"?t.ntuples.factor=E(o.split(L)):a===\"FIRST\"?t.ntuples.first=E(o.split(L)):a===\"LAST\"?t.ntuples.last=E(o.split(L)):a===\"MIN\"?t.ntuples.min=E(o.split(L)):a===\"MAX\"?t.ntuples.max=E(o.split(L)):a===\".NUCLEUS\"?t.ntuples&&(t.ntuples.nucleus=o.split(L).map(u=>u.replaceAll(/[^a-zA-Z0-9]/g,\"\"))):a===\"PAGE\"?(r.page=o.trim(),r.pageValue=Number(o.replace(/^.*=/,\"\")),r.pageSymbol=r.page.replace(/[=].*/,\"\")):a===\"RETENTIONTIME\"?r.pageValue=Number(o):ne(a)?r[U(a)]=o:a===\"SAMPLEDESCRIPTION\"?r.sampleDescription=o:a.startsWith(\"$NUC\")?!t.tmp[a]&&!o.includes(\"off\")&&(t.tmp[a]=o.replaceAll(/[<>]/g,\"\")):a===\"END\"&&(t=l.pop()));if(t?.info&&t.meta&&a.match(n.keepRecordsRegExp)){let u,d;h.startsWith(\"$\")?(d=n.canonicMetadataLabels?a.slice(1):h.slice(1),u=t.meta):(d=n.canonicDataLabels?a:h,u=t.info),n.dynamicTyping&&(o=de(o)),u[d]?(Array.isArray(u[d])||(u[d]=[u[d]]),u[d].push(o)):u[d]=o}}if(n.logger?.trace({profiling:!0},\"Finished parsing\"),q(s,f,n),n.logger?.trace({profiling:!0},\"Total time\"),f.entries=i.children||[],f.flatten=s,n.logger){n.logger.debug(\"Finished jcamp conversion\");for(let c of f.flatten)n.logger.debug(`${c.dataType} - ${c.title}`)}return f}function pt(e,m){let{logger:n,OCL:s}=m;if(!e.info.ATOMLIST||!e.info.BONDLIST){n?.warn(\"No ATOMLIST or BONDLIST in the JCAMP-CS entry\");return}Ae(e,n);let f=ye(e.info.ATOMLIST),i=xe(e.info.BONDLIST),t=Ce(e.info.CHARGE,n),l=he(s,f,i,t,n);return{molecule:l,molfile:l.toMolfile()}}function he(e,m,n,s,f){let i={S:e.Molecule.cBondTypeSingle,D:e.Molecule.cBondTypeDouble,T:e.Molecule.cBondTypeTriple,Q:e.Molecule.cBondTypeQuadruple},t={},l=new e.Molecule(m.length,n.length);for(let r of m){let p=e.Molecule.getAtomicNoFromLabel(r.element);p||(f?.error(`Atomic number of ${r.element} could not be determined`),p=e.Molecule.getAtomicNoFromLabel(\"X\")),t[r.atomNumber]=l.addAtom(p),l.setAtomMapNo(t[r.atomNumber],r.atomNumber,!1)}for(let r of n){if(t[r.atomNumber1]===void 0){f?.error(`A bond goes to atomNumber ${r.atomNumber1} that does not exists`);continue}if(t[r.atomNumber2]===void 0){f?.error(`A bond goes to atomNumber ${r.atomNumber2} that does not exists`);continue}let p=l.addBond(t[r.atomNumber1],t[r.atomNumber2]);l.setBondType(p,i[r.bondType])}for(let r of s){if(t[r.atomNumber]===void 0){f?.error(`A charge goes to atomNumber ${r.atomNumber} that does not exists`);continue}l.setAtomCharge(t[r.atomNumber],r.value)}return l}function ye(e){let m=e.split(/\\r?\\n/).map(s=>M(s)).filter(Boolean),n=[];for(let s of m){let[f,i,t]=s.trim().split(/\\s+/);n.push({atomNumber:Number(f),element:i,nbImplicitHydrogens:t?.length>0?Number(t):void 0})}return n}function xe(e){let m=e.split(/\\r?\\n/).map(s=>M(s)).filter(Boolean),n=[];for(let s of m){let[f,i,t]=s.trim().split(/\\s+/);n.push({atomNumber1:Number(f),atomNumber2:Number(i),bondType:t})}return n}function Ce(e,m){if(!e)return[];let n=e.split(/\\r?\\n/).map(f=>M(f)).filter(Boolean),s=[];for(let f of n){let[i,t,l]=f.trim().split(/\\s+/);l!==void 0&&m?.warn(\"Charge on multiple atom is not supported\"),s.push({atomNumber:Number(t),value:Number(i)})}return s}function Ae(e,m){let n=[\"STEREOPAIR\",\"STEREOCENTER\",\"RADICAL\",\"STEREOMOLECULE\"];for(let s of n)e.info[s]&&m?.warn(`JCAMP-CS parser do not support: ${s}`)}export{mt as convert,Te as createTree,pt as parseJcampCS};\n","import { convert } from 'jcampconverter';\nimport { Analysis } from '../Analysis.js';\n/**\n * Creates a new Analysis from a JCAMP string\n * @param jcamp - String containing the JCAMP data\n * @param [options={}]\n * @param [options.id=Math.random()]\n * @param [options.label=options.id] - human redeable label\n * @param [options.spectrumCallback] - a callback to apply on variables when creating spectrum\n * @returns - New class element with the given data\n */\nexport function fromJcamp(jcamp, options = {}) {\n    const analysis = new Analysis(options);\n    addJcamp(analysis, jcamp);\n    return analysis;\n}\nfunction addJcamp(analysis, jcamp) {\n    const converted = convert(jcamp, {\n        keepRecordsRegExp: /.*/,\n    });\n    for (const entry of converted.flatten) {\n        if (!entry.spectra?.[0])\n            continue;\n        const currentSpectrum = entry.spectra[0];\n        // we ensure variables\n        if (!currentSpectrum.variables) {\n            const variables = {};\n            currentSpectrum.variables = variables;\n            variables.x = {\n                label: currentSpectrum.xUnits,\n                symbol: 'X',\n                data: currentSpectrum.data.x || currentSpectrum.data.X,\n            };\n            variables.y = {\n                label: currentSpectrum.yUnits,\n                symbol: 'Y',\n                data: currentSpectrum.data.y || currentSpectrum.data.Y,\n            };\n        }\n        else {\n            for (const key in currentSpectrum.variables) {\n                const variable = currentSpectrum.variables[key];\n                if (variable.label)\n                    continue;\n                variable.label = variable.name || variable.symbol || key;\n                if (variable.units && !variable.label.includes(variable.units)) {\n                    // eslint-disable-next-line @typescript-eslint/restrict-plus-operands\n                    variable.label += ` [${variable.units}]`;\n                }\n            }\n        }\n        analysis.pushSpectrum(currentSpectrum.variables, {\n            dataType: entry.dataType,\n            title: entry.title,\n            meta: entry.meta,\n        });\n    }\n}\n//# sourceMappingURL=fromJcamp.js.map","import { ensureString } from 'ensure-string';\nimport { xyUniqueX, xMaxValue, xIsMonotonic } from 'ml-spectra-processing';\n/**\n * General internal parsing function\n * @param text - Csv or tsv strings.\n * @param options - Parsing options\n * @returns parsed text file with column information\n */\nexport function parse(text, options = {}) {\n    const { rescale = false, uniqueX = false, bestGuess = false, \n    //@ts-expect-error old library used this property and we want to throw an error so that people are forced to migrate\n    keepInfo, } = options;\n    let { xColumn = 0, yColumn = 1, numberColumns = Number.MAX_SAFE_INTEGER, maxNumberColumns = Number.MAX_SAFE_INTEGER, minNumberColumns = 2, } = options;\n    if (keepInfo !== undefined) {\n        throw new Error('keepInfo has been deprecated, pelase use the new method parseXYAndKeepInfo');\n    }\n    text = ensureString(text);\n    maxNumberColumns = Math.max(maxNumberColumns, xColumn + 1, yColumn + 1);\n    minNumberColumns = Math.max(xColumn + 1, yColumn + 1, minNumberColumns);\n    const lines = text.split(/[\\r\\n]+/);\n    let matrix = [];\n    const info = [];\n    let position = 0;\n    lines.forEach((line) => {\n        line = line.trim();\n        // we will consider only lines that contains only numbers\n        if (/[0-9]+/.test(line) && /^[0-9eE,;. \\t+-]+$/.test(line)) {\n            let fields = line.split(/,[; \\t]+|[; \\t]+/);\n            if (fields.length === 1) {\n                fields = line.split(/[,; \\t]+/);\n            }\n            if (fields &&\n                fields.length >= minNumberColumns && // we filter lines that have not enough or too many columns\n                fields.length <= maxNumberColumns) {\n                matrix.push(fields.map((value) => parseFloat(value.replace(',', '.'))));\n                position++;\n            }\n        }\n        else if (line) {\n            info.push({ position, value: line });\n        }\n    });\n    if (bestGuess) {\n        if (matrix[0] &&\n            matrix[0].length === 3 &&\n            options.xColumn === undefined &&\n            options.yColumn === undefined) {\n            // is the first column a seuqnetial number ?\n            let skipFirstColumn = true;\n            for (let i = 0; i < matrix.length - 1; i++) {\n                if (Math.abs(matrix[i][0] - matrix[i + 1][0]) !== 1) {\n                    skipFirstColumn = false;\n                }\n            }\n            if (skipFirstColumn) {\n                xColumn = 1;\n                yColumn = 2;\n            }\n        }\n        if (matrix[0] && matrix[0].length > 3) {\n            const xs = [];\n            for (const row of matrix) {\n                for (let i = xColumn; i < row.length; i += 2) {\n                    xs.push(row[i]);\n                }\n            }\n            if (xIsMonotonic(xs)) {\n                numberColumns = 2;\n            }\n        }\n    }\n    if (numberColumns) {\n        const newMatrix = [];\n        for (const row of matrix) {\n            for (let i = 0; i < row.length; i += numberColumns) {\n                newMatrix.push(row.slice(i, i + numberColumns));\n            }\n        }\n        matrix = newMatrix;\n    }\n    let result = {\n        x: matrix.map((row) => row[xColumn]),\n        y: matrix.map((row) => row[yColumn]),\n    };\n    if (uniqueX) {\n        result = xyUniqueX(result, { algorithm: 'sum' });\n    }\n    if (rescale) {\n        const maxY = xMaxValue(result.y);\n        for (let i = 0; i < result.y.length; i++) {\n            result.y[i] /= maxY;\n        }\n    }\n    return {\n        info,\n        data: result,\n    };\n}\n//# sourceMappingURL=parse.js.map","import { parse } from './parse';\nexport * from './ParseXYOptions';\n/**\n * Parse a text-file and convert it to an object {x:[], y:[]}\n * @param text - Csv or tsv strings.\n * @param options - Parsing options\n * @returns - The parsed data\n */\nexport function parseXY(text, options = {}) {\n    return parse(text, options).data;\n}\n/**\n * Parse a text-file and returns the parsed data and information about the columns\n * @param text - Csv or tsv strings.\n * @param options - Parsing options\n * @returns - The parsed data with information about the columns\n */\nexport function parseXYAndKeepInfo(text, options = {}) {\n    return parse(text, options);\n}\n//# sourceMappingURL=index.js.map","export const addInfoData = (data, options = {}) => {\n    const { keys = Object.keys(data), prefix = '##$' } = options;\n    let header = '';\n    for (const key of keys) {\n        header +=\n            typeof data[key] === 'object'\n                ? `${prefix}${key}=${JSON.stringify(data[key])}\\n`\n                : `${prefix}${key}=${data[key]}\\n`;\n    }\n    return header;\n};\n//# sourceMappingURL=addInfoData.js.map","import { isAnyArray } from 'is-any-array';\nexport function checkNumberOrArray(data) {\n    if (!isAnyArray(data) || isAnyArray(data[0])) {\n        throw new Error(`x and y data should be an array of numbers`);\n    }\n}\n//# sourceMappingURL=checkNumberOrArray.js.map","import { isAnyArray } from 'is-any-array';\nimport { matrixMinMaxZ, xMinMaxValues, } from 'ml-spectra-processing';\nimport { checkMatrix } from './checkMatrix';\nimport { checkNumberOrArray } from './checkNumberOrArray';\nexport function getExtremeValues(data) {\n    if (isAnyArray(data[0])) {\n        checkMatrix(data);\n        const firstRow = data[0];\n        return {\n            firstLast: {\n                first: firstRow[0],\n                last: data[data.length - 1][data[0].length - 1],\n            },\n            minMax: matrixMinMaxZ(data),\n        };\n    }\n    checkNumberOrArray(data);\n    return {\n        firstLast: {\n            first: data[0],\n            last: data[data.length - 1],\n        },\n        minMax: xMinMaxValues(data),\n    };\n}\n//# sourceMappingURL=getExtremeValues.js.map","import { isAnyArray } from 'is-any-array';\nexport function checkMatrix(data) {\n    if (!isAnyArray(data) || !isAnyArray(data[0])) {\n        throw new Error(`2D data should be a matrix`);\n    }\n}\n//# sourceMappingURL=checkMatrix.js.map","import { xMinMaxValues } from 'ml-spectra-processing';\nimport { getFactorNumber } from './getFactorNumber';\nexport function getBestFactor(array, options = {}) {\n    const { maxValue, factor, minMax } = options;\n    if (factor !== undefined) {\n        return factor;\n    }\n    // is there non integer number ?\n    let onlyInteger = true;\n    for (const y of array) {\n        if (Math.round(y) !== y) {\n            onlyInteger = false;\n            break;\n        }\n    }\n    if (onlyInteger) {\n        return 1;\n    }\n    // we need to rescale the values\n    // need to find the max and min values\n    const extremeValues = minMax || xMinMaxValues(array);\n    return getFactorNumber(extremeValues, maxValue);\n}\n//# sourceMappingURL=getBestFactor.js.map","export function getFactorNumber(minMax, maxValue = 2 ** 31 - 1) {\n    let factor;\n    if (minMax.min < 0) {\n        if (minMax.max > 0) {\n            factor = Math.max(-minMax.min, minMax.max) / maxValue;\n        }\n        else {\n            factor = -minMax.min / maxValue;\n        }\n    }\n    else {\n        factor = minMax.max / maxValue;\n    }\n    return factor;\n}\n//# sourceMappingURL=getFactorNumber.js.map","/**\n * Reconvert number to original value\n * @param number Number used for computation\n * @param factor Multiplying factor\n * @returns Original value\n */\nexport function getNumber(number, factor) {\n    if (factor !== 1)\n        number /= factor;\n    const rounded = Math.round(number);\n    if (rounded !== number && Math.abs(rounded - number) <= Number.EPSILON) {\n        return rounded;\n    }\n    return number;\n}\n//# sourceMappingURL=getNumber.js.map","/**\n * class encodes a integer vector as a String in order to store it in a text file.\n * The algorithms used to encode the data are describe in:\n *            http://www.iupac.org/publications/pac/pdf/2001/pdf/7311x1765.pdf\n */\nconst newLine = '\\n';\nconst pseudoDigits = [\n    ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9'],\n    ['@', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I'],\n    ['@', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i'],\n    ['%', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R'],\n    ['%', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r'],\n    [' ', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 's'],\n];\nconst SQZ_P = 1;\nconst SQZ_N = 2;\nconst DIF_P = 3;\nconst DIF_N = 4;\nconst DUP = 5;\nconst maxLinelength = 100;\n/**\n * This function encodes the given vector. The xyEncoding format is specified by the\n * xyEncoding option\n * @param xyEncoding: ('FIX','SQZ','DIF','DIFDUP','CVS','PAC') Default 'DIFDUP'\n * @return {string}\n */\nexport function vectorEncoder(data, firstX, intervalX, xyEncoding) {\n    switch (xyEncoding) {\n        case 'FIX':\n            return fixEncoding(data, firstX, intervalX);\n        case 'SQZ':\n            return squeezedEncoding(data, firstX, intervalX);\n        case 'DIF':\n            return differenceEncoding(data, firstX, intervalX);\n        case 'DIFDUP':\n            return differenceDuplicateEncoding(data, firstX, intervalX);\n        case 'CSV':\n            return commaSeparatedValuesEncoding(data, firstX, intervalX);\n        case 'PAC':\n            return packedEncoding(data, firstX, intervalX);\n        default:\n            return differenceEncoding(data, firstX, intervalX);\n    }\n}\n/**\n * @private\n * No data compression used. The data is separated by a comma(',').\n */\nexport function commaSeparatedValuesEncoding(data, firstX, intervalX) {\n    return fixEncoding(data, firstX, intervalX, ',');\n}\n/**\n * @private\n * No data compression used. The data is separated by the specified separator.\n */\nexport function fixEncoding(data, firstX, intervalX, separator = ' ') {\n    let outputData = '';\n    let j = 0;\n    const dataLength = data.length;\n    while (j < dataLength - 7) {\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = 0; i < 8; i++) {\n            outputData += `${separator}${data[j++]}`;\n        }\n        outputData += newLine;\n    }\n    if (j < dataLength) {\n        // We add last numbers\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = j; i < dataLength; i++) {\n            outputData += `${separator}${data[i]}`;\n        }\n    }\n    return outputData;\n}\n/**\n * @private\n * No data compression used. The data is separated by the sign of the number.\n */\nexport function packedEncoding(data, firstX, intervalX) {\n    let outputData = '';\n    let j = 0;\n    const dataLength = data.length;\n    while (j < dataLength - 7) {\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = 0; i < 8; i++) {\n            outputData += data[j] < 0 ? String(data[j++]) : `+${data[j++]}`;\n        }\n        outputData += newLine;\n    }\n    if (j < dataLength) {\n        // We add last numbers\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = j; i < dataLength; i++) {\n            outputData += data[i] < 0 ? String(data[i]) : `+${data[i]}`;\n        }\n    }\n    return outputData;\n}\n/**\n * @private\n * Data compression is possible using the squeezed form (SQZ) in which the delimiter, the leading digit,\n * and sign are replaced by a pseudo-digit from Table 1. For example, the Y-values 30, 32 would be\n * represented as C0C2.\n */\nexport function squeezedEncoding(data, firstX, intervalX) {\n    let outputData = '';\n    // String outputData = new String();\n    let j = 0;\n    const dataLength = data.length;\n    while (j < dataLength - 10) {\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = 0; i < 10; i++) {\n            outputData += squeezedDigit(data[j++].toString());\n        }\n        outputData += newLine;\n    }\n    if (j < dataLength) {\n        // We add last numbers\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = j; i < dataLength; i++) {\n            outputData += squeezedDigit(data[i].toString());\n        }\n    }\n    return outputData;\n}\n/**\n * @private\n * Duplicate suppression xyEncoding\n */\nexport function differenceDuplicateEncoding(data, firstX, intervalX) {\n    let mult = 0;\n    let index = 0;\n    let charCount = 0;\n    // We built a string where we store the encoded data.\n    let encodedData = '';\n    let encodedNumber = '';\n    let temp = '';\n    // We calculate the differences vector\n    const diffData = new Array(data.length - 1);\n    for (let i = 0; i < diffData.length; i++) {\n        diffData[i] = data[i + 1] - data[i];\n    }\n    // We simulate a line carry\n    const numDiff = diffData.length;\n    while (index < numDiff) {\n        if (charCount === 0) {\n            // Start line\n            encodedNumber = `${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}${differenceDigit(diffData[index].toString())}`;\n            encodedData += encodedNumber;\n            charCount += encodedNumber.length;\n        }\n        else if (diffData[index - 1] === diffData[index]) {\n            // Try to insert next difference\n            mult++;\n        }\n        else if (mult > 0) {\n            // Now we know that it can be in line\n            mult++;\n            encodedNumber = duplicateDigit(mult.toString());\n            encodedData += encodedNumber;\n            charCount += encodedNumber.length;\n            mult = 0;\n            index--;\n        }\n        else {\n            // Check if it fits, otherwise start a new line\n            encodedNumber = differenceDigit(diffData[index].toString());\n            if (encodedNumber.length + charCount < maxLinelength) {\n                encodedData += encodedNumber;\n                charCount += encodedNumber.length;\n            }\n            else {\n                // start a new line\n                encodedData += newLine;\n                temp = `${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}${encodedNumber}`;\n                encodedData += temp; // Each line start with first index number.\n                charCount = temp.length;\n            }\n        }\n        index++;\n    }\n    if (mult > 0) {\n        encodedData += duplicateDigit((mult + 1).toString());\n    }\n    // We insert the last data from fid. It is done to control of data\n    // The last line start with the number of datas in the fid.\n    encodedData += `${newLine}${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}`;\n    return encodedData;\n}\n/**\n * @private\n * Differential xyEncoding\n */\nexport function differenceEncoding(data, firstX, intervalX) {\n    let index = 0;\n    let charCount = 0;\n    let i;\n    let encodedData = '';\n    let encodedNumber = '';\n    let temp = '';\n    // We calculate the differences vector\n    const diffData = new Array(data.length - 1);\n    for (i = 0; i < diffData.length; i++) {\n        diffData[i] = data[i + 1] - data[i];\n    }\n    const numDiff = diffData.length;\n    while (index < numDiff) {\n        if (charCount === 0) {\n            // We convert the first number.\n            encodedNumber = `${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}${differenceDigit(diffData[index].toString())}`;\n            encodedData += encodedNumber;\n            charCount += encodedNumber.length;\n        }\n        else {\n            encodedNumber = differenceDigit(diffData[index].toString());\n            if (encodedNumber.length + charCount < maxLinelength) {\n                encodedData += encodedNumber;\n                charCount += encodedNumber.length;\n            }\n            else {\n                encodedData += newLine;\n                temp = `${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}${encodedNumber}`;\n                encodedData += temp; // Each line start with first index number.\n                charCount = temp.length;\n            }\n        }\n        index++;\n    }\n    // We insert the last number from data. It is done to control of data\n    encodedData += `${newLine}${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}`;\n    return encodedData;\n}\n/**\n * @private\n * Convert number to the ZQZ format, using pseudo digits.\n */\nfunction squeezedDigit(num) {\n    let sqzDigits = '';\n    if (num.startsWith('-')) {\n        sqzDigits += pseudoDigits[SQZ_N][num.charCodeAt(1) - 48];\n        if (num.length > 2) {\n            sqzDigits += num.substring(2);\n        }\n    }\n    else {\n        sqzDigits += pseudoDigits[SQZ_P][num.charCodeAt(0) - 48];\n        if (num.length > 1) {\n            sqzDigits += num.substring(1);\n        }\n    }\n    return sqzDigits;\n}\n/**\n * Convert number to the DIF format, using pseudo digits.\n */\nfunction differenceDigit(num) {\n    let diffDigits = '';\n    if (num.startsWith('-')) {\n        diffDigits += pseudoDigits[DIF_N][num.charCodeAt(1) - 48];\n        if (num.length > 2) {\n            diffDigits += num.substring(2);\n        }\n    }\n    else {\n        diffDigits += pseudoDigits[DIF_P][num.charCodeAt(0) - 48];\n        if (num.length > 1) {\n            diffDigits += num.substring(1);\n        }\n    }\n    return diffDigits;\n}\n/**\n * Convert number to the DUP format, using pseudo digits.\n */\nfunction duplicateDigit(num) {\n    let dupDigits = '';\n    dupDigits += pseudoDigits[DUP][num.charCodeAt(0) - 48];\n    if (num.length > 1) {\n        dupDigits += num.substring(1);\n    }\n    return dupDigits;\n}\n//# sourceMappingURL=vectorEncoder.js.map","import { rescaleAndEnsureInteger } from './rescaleAndEnsureInteger';\nimport { vectorEncoder } from './vectorEncoder';\nexport function xyDataCreator(data, options = {}) {\n    const { xyEncoding = 'DIF' } = options;\n    const { xFactor = 1, yFactor = 1 } = options.info || {};\n    const firstX = data.x[0];\n    const lastX = data.x[data.x.length - 1];\n    const firstY = data.y[0];\n    const lastY = data.y[data.y.length - 1];\n    const nbPoints = data.x.length;\n    const deltaX = (lastX - firstX) / (nbPoints - 1);\n    const lines = [];\n    lines.push(`##FIRSTX=${firstX}`);\n    lines.push(`##LASTX=${lastX}`);\n    lines.push(`##FIRSTY=${firstY}`);\n    lines.push(`##LASTY=${lastY}`);\n    lines.push(`##DELTAX=${deltaX}`);\n    lines.push(`##XFACTOR=${xFactor}`);\n    lines.push(`##YFACTOR=${yFactor}`);\n    lines.push('##XYDATA=(X++(Y..Y))');\n    const line = vectorEncoder(rescaleAndEnsureInteger(data.y, yFactor), firstX / xFactor, deltaX / xFactor, xyEncoding);\n    if (line)\n        lines.push(line);\n    return lines;\n}\n//# sourceMappingURL=xyDataCreator.js.map","import { xDivide } from 'ml-spectra-processing';\nexport function rescaleAndEnsureInteger(data, factor = 1) {\n    if (factor === 1)\n        return data.map((value) => Math.round(value));\n    return xDivide(data, factor).map((value) => Math.round(value));\n}\n//# sourceMappingURL=rescaleAndEnsureInteger.js.map","import { addInfoData } from './utils/addInfoData';\nimport { getBestFactor } from './utils/getBestFactor';\nimport { peakTableCreator } from './utils/peakTableCreator';\nimport { xyDataCreator } from './utils/xyDataCreator';\n/**\n * Create a jcamp\n * @param data object of array\n * @param [options={meta:{},info:{}} - metadata object\n * @returns JCAMP of the input\n */\nexport function fromJSON(data, options = {}) {\n    const { meta = {}, info = {}, xyEncoding } = options;\n    const { title = '', owner = '', origin = '', dataType = '', xUnits = '', yUnits = '', ...resInfo } = info;\n    let { xFactor, yFactor } = info;\n    data = { x: data.x, y: data.y };\n    let header = `##TITLE=${title}\n##JCAMP-DX=4.24\n##DATA TYPE=${dataType}\n##ORIGIN=${origin}\n##OWNER=${owner}\n##XUNITS=${xUnits}\n##YUNITS=${yUnits}\\n`;\n    header += addInfoData(resInfo, { prefix: '##' });\n    header += addInfoData(meta);\n    // we leave the header and utf8 fonts ${header.replace(/[^\\t\\n\\x20-\\x7F]/g, '')\n    if (xyEncoding) {\n        xFactor = getBestFactor(data.x, { factor: xFactor });\n        yFactor = getBestFactor(data.y, { factor: yFactor });\n        return `${header}##NPOINTS=${data.x.length}\n${xyDataCreator(data, { info: { xFactor, yFactor }, xyEncoding }).join('\\n')}\n##END=`;\n    }\n    else {\n        if (xFactor === undefined)\n            xFactor = 1;\n        if (yFactor === undefined)\n            yFactor = 1;\n        if (xFactor !== 1) {\n            //@ts-expect-error xFactor is always defined\n            data.x = data.x.map((value) => value / xFactor);\n        }\n        if (yFactor !== 1) {\n            //@ts-expect-error yFactor is always defined\n            data.y = data.y.map((value) => value / yFactor);\n        }\n        return `${header}##NPOINTS=${data.x.length}\n${peakTableCreator(data, { info: { xFactor, yFactor } }).join('\\n')}\n##END=`;\n    }\n}\n//# sourceMappingURL=fromJSON.js.map","import { getNumber } from './getNumber';\nexport function peakTableCreator(data, options = {}) {\n    const { xFactor = 1, yFactor = 1 } = options.info || {};\n    let firstX = Number.POSITIVE_INFINITY;\n    let lastX = Number.NEGATIVE_INFINITY;\n    let firstY = Number.POSITIVE_INFINITY;\n    let lastY = Number.NEGATIVE_INFINITY;\n    const lines = [];\n    for (let i = 0; i < data.x.length; i++) {\n        const x = data.x[i];\n        const y = data.y[i];\n        if (firstX > x) {\n            firstX = x;\n        }\n        if (lastX < x) {\n            lastX = x;\n        }\n        if (firstY > y) {\n            firstY = y;\n        }\n        if (lastY < y) {\n            lastY = y;\n        }\n    }\n    lines.push(`##FIRSTX=${firstX}`);\n    lines.push(`##LASTX=${lastX}`);\n    lines.push(`##FIRSTY=${firstY}`);\n    lines.push(`##LASTY=${lastY}`);\n    lines.push(`##XFACTOR=${xFactor}`);\n    lines.push(`##YFACTOR=${yFactor}`);\n    lines.push('##PEAK TABLE=(XY..XY)');\n    for (let i = 0; i < data.x.length; i++) {\n        lines.push(`${getNumber(data.x[i], xFactor)} ${getNumber(data.y[i], yFactor)}`);\n    }\n    return lines;\n}\n//# sourceMappingURL=peakTableCreator.js.map","import creatorNtuples from './creatorNtuples';\nimport { fromJSON } from './fromJSON';\nimport { checkNumberOrArray } from './utils/checkNumberOrArray';\n/**\n * Create a jcamp from variables\n */\nexport function fromVariables(\n/** object of variables */\nvariables, options = {}) {\n    const { info = {}, meta = {}, forceNtuples = false } = options;\n    const jcampOptions = {\n        info,\n        meta,\n    };\n    const keys = Object.keys(variables).map((key) => key.toLowerCase());\n    if (!forceNtuples && keys.length === 2) {\n        const x = variables.x;\n        const xLabel = x.label || 'x';\n        if (variables.x.units) {\n            if (xLabel.includes(variables.x.units)) {\n                jcampOptions.info.xUnits = xLabel;\n            }\n            else {\n                jcampOptions.info.xUnits = `${xLabel} (${variables.x.units})`;\n            }\n        }\n        else {\n            jcampOptions.info.xUnits = xLabel;\n        }\n        const y = variables.y;\n        const yLabel = y.label || 'y';\n        if (variables.y.units) {\n            if (yLabel.includes(variables.y.units)) {\n                jcampOptions.info.xUnits = yLabel;\n            }\n            else {\n                jcampOptions.info.yUnits = `${yLabel} (${variables.y.units})`;\n            }\n        }\n        else {\n            jcampOptions.info.yUnits = yLabel;\n        }\n        const xData = variables.x.data;\n        const yData = variables.y.data;\n        checkNumberOrArray(xData);\n        checkNumberOrArray(yData);\n        return fromJSON({ x: xData, y: yData }, jcampOptions);\n    }\n    else {\n        return creatorNtuples(variables, options);\n    }\n}\n//# sourceMappingURL=fromVariables.js.map","import { addInfoData } from './utils/addInfoData';\nimport { getExtremeValues } from './utils/getExtremeValues';\n/**\n * Parse from a xyxy data array\n * @param variables - Variables to convert to jcamp\n * @param [options={}] - options that allows to add meta data in the jcamp\n * @return JCAMP-DX text file corresponding to the variables\n */\nexport default function creatorNtuples(variables, options) {\n    const { meta = {}, info = {} } = options;\n    const { title = '', owner = '', origin = '', dataType = '', ...resInfo } = info;\n    const symbol = [];\n    const varName = [];\n    const varType = [];\n    const varDim = [];\n    const units = [];\n    const first = [];\n    const last = [];\n    const min = [];\n    const max = [];\n    const keys = Object.keys(variables);\n    for (let i = 0; i < keys.length; i++) {\n        const key = keys[i];\n        const variable = variables[key];\n        if (!variable)\n            continue;\n        const name = variable?.label.replace(/ *\\[.*/, '');\n        const unit = variable?.label.replace(/.*\\[(?<units>.*)\\].*/, '$<units>');\n        const { firstLast, minMax } = getExtremeValues(variable.data);\n        symbol.push(variable.symbol || key);\n        varName.push(name || key);\n        varDim.push(variable.data.length);\n        first.push(firstLast.first);\n        last.push(firstLast.last);\n        max.push(minMax.max);\n        min.push(minMax.min);\n        if (variable.isDependent !== undefined) {\n            varType.push(variable.isDependent ? 'DEPENDENT' : 'INDEPENDENT');\n        }\n        else {\n            varType.push(variable.isDependent !== undefined\n                ? !variable.isDependent\n                : i === 0\n                    ? 'INDEPENDENT'\n                    : 'DEPENDENT');\n        }\n        units.push(variable.units || unit || '');\n    }\n    let header = `##TITLE=${title}\n##JCAMP-DX=6.00\n##DATA TYPE=${dataType}\n##DATA CLASS= NTUPLES\n##ORIGIN=${origin}\n##OWNER=${owner}\\n`;\n    header += addInfoData(resInfo, { prefix: '##' });\n    header += addInfoData(meta);\n    header += `##NTUPLES= ${dataType}\n##VAR_NAME=  ${varName.join()}\n##SYMBOL=    ${symbol.join()}\n##VAR_TYPE=  ${varType.join()}\n##VAR_DIM=   ${varDim.join()}\n##UNITS=     ${units.join()}\n##FIRST=     ${first.join()}\n##LAST=      ${last.join()}\n##MIN=       ${min.join()}\n##MAX=       ${max.join()}\n##PAGE= N=1\\n`;\n    header += `##DATA TABLE= (${symbol.join('')}..${symbol.join('')}), PEAKS\\n`;\n    for (let i = 0; i < variables.x.data.length; i++) {\n        const point = [];\n        for (const key of keys) {\n            const variable = variables[key];\n            if (!variable)\n                continue;\n            point.push(variable.data[i]);\n        }\n        header += `${point.join('\\t')}\\n`;\n    }\n    header += `##END NTUPLES= ${dataType}\\n`;\n    header += '##END=\\n##END=';\n    return header;\n}\n//# sourceMappingURL=creatorNtuples.js.map","import { fromVariables } from 'convert-to-jcamp';\nexport function toJcamps(analysis, options = {}) {\n    const jcamps = [];\n    for (const spectrum of analysis.spectra) {\n        jcamps.push(getJcamp(spectrum, options));\n    }\n    return jcamps;\n}\nfunction getJcamp(spectrum, options) {\n    const { info = {}, meta = {} } = options;\n    const jcampOptions = {\n        options: {},\n        info: {\n            title: spectrum.title,\n            dataType: spectrum.dataType,\n            ...info,\n        },\n        meta: { ...spectrum.meta, ...meta },\n    };\n    return fromVariables(spectrum.variables, jcampOptions);\n}\n//# sourceMappingURL=toJcamps.js.map","import { getJSGraph } from './jsgraph/getJSGraph.js';\nimport { getNormalizationAnnotations } from './jsgraph/getNormalizationAnnotations.js';\nexport * from './AnalysesManager.js';\nexport * from './Analysis.js';\nexport * from './from/fromJcamp.js';\nexport * from './from/fromText.js';\nexport * from './to/toJcamp.js';\nexport * from './to/toJcamps.js';\nexport * from './to/toText.js';\nexport * from './to/toMatrix.js';\nexport * from './util/getNormalizedSpectrum.js';\nexport * from './util/peakPicking.js';\nexport * from './util/autoPeakPicking.js';\nexport * from './types/types.js';\nexport * from './types/AutoPeakPickingOptions.js';\nexport * from './types/PeakPickingOptions.js';\nexport * from './types/NormalizedSpectrumOptions.js';\nexport * from './types/PlotObject.js';\nexport * from './types/SpectrumSelector.js';\nexport { getReactPlotJSON } from './reactPlot/getReactPlotJSON.js';\nexport const JSGraph = {\n    getJSGraph,\n    getNormalizationAnnotations,\n};\n//# sourceMappingURL=index.js.map","import { xyFilterXPositive } from 'ml-spectra-processing';\nimport { addStyle } from './addStyle.js';\nimport { COLORS } from './colors.js';\n/**\n * Generate a jsgraph chart format from an array of Analysis\n * @param analyses\n * @param options\n */\nexport function getJSGraph(analyses, options = {}) {\n    const { colors = COLORS, opacities = [1], linesWidth = [1], selector = {}, normalization, xAxis = {}, yAxis = {}, } = options;\n    const series = [];\n    let xLabel = xAxis.label;\n    let yLabel = yAxis.label;\n    let xUnits = xAxis.units;\n    let yUnits = yAxis.units;\n    for (let i = 0; i < analyses.length; i++) {\n        const analysis = analyses[i];\n        const spectra = analysis.getNormalizedSpectra({\n            selector,\n            normalization,\n        });\n        if (spectra.length === 0)\n            continue;\n        const firstSpectrum = spectra[0];\n        // todo: if many spectra are available and not xUnits / yUnits are specified we should ensure that all the spectra are compatible\n        if (!xLabel)\n            xLabel = firstSpectrum.variables.x.label;\n        if (!yLabel)\n            yLabel = firstSpectrum.variables.y.label;\n        if (!xUnits)\n            xUnits = firstSpectrum.variables.x.units;\n        if (!yUnits)\n            yUnits = firstSpectrum.variables.y.units;\n        for (const spectrum of spectra) {\n            const serie = {};\n            addStyle(serie, analysis, {\n                color: colors[i % colors.length],\n                opacity: opacities[i % opacities.length],\n                lineWidth: linesWidth[i % linesWidth.length],\n            });\n            serie.data = {\n                x: spectrum.variables.x.data,\n                y: spectrum.variables.y.data,\n            };\n            serie.id = spectrum.id;\n            if (xAxis.logScale) {\n                serie.data = xyFilterXPositive(serie.data);\n            }\n            series.push(serie);\n        }\n    }\n    return {\n        axes: {\n            x: {\n                label: xLabel,\n                unit: xUnits,\n                unitWrapperBefore: '(',\n                unitWrapperAfter: ')',\n                flipped: false,\n                display: true,\n                ...xAxis,\n            },\n            y: {\n                label: yLabel,\n                unit: yUnits,\n                unitWrapperBefore: '(',\n                unitWrapperAfter: ')',\n                flipped: false,\n                display: true,\n                ...yAxis,\n            },\n        },\n        series,\n    };\n}\n//# sourceMappingURL=getJSGraph.js.map","export function getNormalizationAnnotations(filter = {}, boundary = { y: { min: '0px', max: '2000px' } }) {\n    let { exclusions = [] } = filter;\n    let annotations = [];\n    exclusions = exclusions.filter((exclusion) => !exclusion.ignore);\n    annotations = exclusions.map((exclusion) => {\n        const annotation = {\n            type: 'rect',\n            position: [\n                { x: exclusion.from, y: boundary.y.min },\n                { x: exclusion.to, y: boundary.y.max },\n            ],\n            strokeWidth: 0,\n            fillColor: 'rgba(255,255,224,1)',\n        };\n        return annotation;\n    });\n    if (filter.from !== undefined) {\n        annotations.push({\n            type: 'rect',\n            position: [\n                { x: Number.MIN_SAFE_INTEGER, y: boundary.y.min },\n                { x: filter.from, y: boundary.y.max },\n            ],\n            strokeWidth: 0,\n            fillColor: 'rgba(255,255,224,1)',\n        });\n    }\n    if (filter.to !== undefined) {\n        annotations.push({\n            type: 'rect',\n            position: [\n                { x: filter.to, y: boundary.y.min },\n                { x: Number.MAX_SAFE_INTEGER, y: boundary.y.max },\n            ],\n            strokeWidth: 0,\n            fillColor: 'rgba(255,255,224,1)',\n        });\n    }\n    return annotations;\n}\n//# sourceMappingURL=getNormalizationAnnotations.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getBestPeaks = getBestPeaks;\nconst ml_spectra_processing_1 = require(\"ml-spectra-processing\");\n/**\n * Filter the array by taking the higher peaks and only\n * keep one per slot.\n * There are 2 different slots, the smallest one will have the\n * extra annotation `close` to true\n * @param {array} peaks - array of all the peaks\n * @param {object} [options={}]\n * @param {number} [options.from] - min X value of the window to consider\n * @param {number} [options.to] - max X value of the window to consider\n * @param {number} [options.minValue=Number.NEGATIVE_INFINITY] - min Y value of the window to consider\n * @param {number} [options.maxValue=Number.POSITIVE_INFINITY] - max Y value of the window to consider\n * @param {number} [options.searchMonoisotopicRatio=0] - search previous peaks with at least ratio height\n * @param {number} [options.limit=20] - max number of peaks\n * @param {number} [options.threshold=0.01] - minimal intensity compare to base peak\n * @param {number} [options.numberSlots=10] - define the number of slots and indirectly the slot width\n * @param {number} [options.numberCloseSlots=50]\n * @returns {array} - copy of peaks with 'close' annotation\n */\nfunction getBestPeaks(peaks, options = {}) {\n    const { searchMonoisotopicRatio = 0, from = (0, ml_spectra_processing_1.xyObjectMinXPoint)(peaks).x, to = (0, ml_spectra_processing_1.xyObjectMaxXPoint)(peaks).x, limit = 20, threshold = 0.01, numberCloseSlots = 50, numberSlots = 10, minValue = Number.NEGATIVE_INFINITY, maxValue = Number.POSITIVE_INFINITY, } = options;\n    let slot = (to - from) / numberSlots;\n    let closeSlot = (to - from) / numberCloseSlots;\n    let selected = peaks\n        .filter((peak) => peak.x >= from && peak.x <= to)\n        .filter((peak) => peak.y >= minValue && peak.y <= maxValue)\n        .map((peak) => {\n        return {\n            peak,\n            monoisotopic: false,\n        };\n    });\n    if (searchMonoisotopicRatio) {\n        selected = selected.sort((a, b) => b.peak.x - a.peak.x);\n        for (let i = 0; i < selected.length; i++) {\n            let item = selected[i];\n            for (let j = i + 1; j < selected.length; j++) {\n                let nextItem = selected[j];\n                if (item.peak.x - nextItem.peak.x < 0.09)\n                    continue;\n                if (item.peak.x - nextItem.peak.x > 1.1)\n                    break;\n                if (nextItem.peak.y > item.peak.y * searchMonoisotopicRatio) {\n                    item.monoisotopic = false;\n                    nextItem.monoisotopic = true;\n                    break;\n                }\n            }\n        }\n    }\n    selected = selected.sort((a, b) => {\n        if (a.monoisotopic && !b.monoisotopic)\n            return -1;\n        if (b.monoisotopic && !a.monoisotopic)\n            return 1;\n        return b.peak.y - a.peak.y;\n    });\n    let toReturn = [];\n    if (selected.length === 0)\n        return [];\n    let minY = selected[0].peak.y * threshold;\n    peakLoop: for (let item of selected) {\n        if (item.peak.y < minY) {\n            if (item.monoisotopic) {\n                continue;\n            }\n            else {\n                break;\n            }\n        }\n        let close = false;\n        for (let existing of toReturn) {\n            if (Math.abs(existing.x - item.peak.x) < closeSlot) {\n                continue peakLoop;\n            }\n            if (Math.abs(existing.x - item.peak.x) < slot) {\n                close = true;\n            }\n        }\n        let newPeak = structuredClone(item.peak);\n        newPeak.close = close;\n        toReturn.push(newPeak);\n        if (toReturn.length === limit)\n            break;\n    }\n    return toReturn.sort((a, b) => a.x - b.x);\n}\n//# sourceMappingURL=getBestPeaks.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.atomSorter = atomSorter;\n/**\n * Implementation of the Hill system for sorting atoms\n * https://en.wikipedia.org/wiki/Chemical_formula#Hill_system\n * @param a - first atom to compare\n * @param b - second atom to compare\n * @returns A value suitable for use in Array.prototype.sort.\n */\nfunction atomSorter(a, b) {\n    if (a === b)\n        return 0;\n    if (a === 'C')\n        return -1;\n    if (b === 'C')\n        return 1;\n    if (a === 'H')\n        return -1;\n    if (b === 'H')\n        return 1;\n    if (a < b)\n        return -1;\n    return 1;\n}\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.elementsAndIsotopes = void 0;\nexports.elementsAndIsotopes = [\n    {\n        number: 1,\n        isotopes: [\n            { nominal: 1, mass: 1.00782503223, abundance: 0.999885 },\n            { nominal: 2, mass: 2.01410177812, abundance: 0.000115 },\n            { nominal: 3, mass: 3.0160492779 },\n            { nominal: 4, mass: 4.02643 },\n            { nominal: 5, mass: 5.035311 },\n            { nominal: 6, mass: 6.04496 },\n            { nominal: 7, mass: 7.0527 },\n        ],\n        symbol: 'H',\n        mass: 1.0079407540557772,\n        name: 'Hydrogen',\n        monoisotopicMass: 1.00782503223,\n    },\n    {\n        number: 2,\n        isotopes: [\n            { nominal: 3, mass: 3.0160293201, abundance: 0.00000134 },\n            { nominal: 4, mass: 4.00260325413, abundance: 0.99999866 },\n            { nominal: 5, mass: 5.012057 },\n            { nominal: 6, mass: 6.018885891 },\n            { nominal: 7, mass: 7.0279907 },\n            { nominal: 8, mass: 8.03393439 },\n            { nominal: 9, mass: 9.043946 },\n            { nominal: 10, mass: 10.05279 },\n        ],\n        symbol: 'He',\n        mass: 4.002601932120929,\n        name: 'Helium',\n        monoisotopicMass: 4.00260325413,\n    },\n    {\n        number: 3,\n        isotopes: [\n            { nominal: 3, mass: 3.0308 },\n            { nominal: 4, mass: 4.02719 },\n            { nominal: 5, mass: 5.012538 },\n            { nominal: 6, mass: 6.0151228874, abundance: 0.0759 },\n            { nominal: 7, mass: 7.0160034366, abundance: 0.9241 },\n            { nominal: 8, mass: 8.022486246 },\n            { nominal: 9, mass: 9.02679019 },\n            { nominal: 10, mass: 10.035483 },\n            { nominal: 11, mass: 11.04372358 },\n            { nominal: 12, mass: 12.052517 },\n            { nominal: 13, mass: 13.06263 },\n        ],\n        symbol: 'Li',\n        mass: 6.94003660291572,\n        name: 'Lithium',\n        monoisotopicMass: 7.0160034366,\n    },\n    {\n        number: 4,\n        isotopes: [\n            { nominal: 5, mass: 5.0399 },\n            { nominal: 6, mass: 6.0197264 },\n            { nominal: 7, mass: 7.016928717 },\n            { nominal: 8, mass: 8.005305102 },\n            { nominal: 9, mass: 9.012183065, abundance: 1 },\n            { nominal: 10, mass: 10.013534695 },\n            { nominal: 11, mass: 11.02166108 },\n            { nominal: 12, mass: 12.0269221 },\n            { nominal: 13, mass: 13.036135 },\n            { nominal: 14, mass: 14.04289 },\n            { nominal: 15, mass: 15.05342 },\n            { nominal: 16, mass: 16.06167 },\n        ],\n        symbol: 'Be',\n        mass: 9.012183065,\n        name: 'Beryllium',\n        monoisotopicMass: 9.012183065,\n    },\n    {\n        number: 5,\n        isotopes: [\n            { nominal: 6, mass: 6.0508 },\n            { nominal: 7, mass: 7.029712 },\n            { nominal: 8, mass: 8.0246073 },\n            { nominal: 9, mass: 9.01332965 },\n            { nominal: 10, mass: 10.01293695, abundance: 0.199 },\n            { nominal: 11, mass: 11.00930536, abundance: 0.801 },\n            { nominal: 12, mass: 12.0143527 },\n            { nominal: 13, mass: 13.0177802 },\n            { nominal: 14, mass: 14.025404 },\n            { nominal: 15, mass: 15.031088 },\n            { nominal: 16, mass: 16.039842 },\n            { nominal: 17, mass: 17.04699 },\n            { nominal: 18, mass: 18.05566 },\n            { nominal: 19, mass: 19.0631 },\n            { nominal: 20, mass: 20.07207 },\n            { nominal: 21, mass: 21.08129 },\n        ],\n        symbol: 'B',\n        mass: 10.811028046410001,\n        name: 'Boron',\n        monoisotopicMass: 11.00930536,\n    },\n    {\n        number: 6,\n        isotopes: [\n            { nominal: 8, mass: 8.037643 },\n            { nominal: 9, mass: 9.0310372 },\n            { nominal: 10, mass: 10.01685331 },\n            { nominal: 11, mass: 11.0114336 },\n            { nominal: 12, mass: 12, abundance: 0.9893 },\n            { nominal: 13, mass: 13.00335483507, abundance: 0.0107 },\n            { nominal: 14, mass: 14.0032419884 },\n            { nominal: 15, mass: 15.01059926 },\n            { nominal: 16, mass: 16.0147013 },\n            { nominal: 17, mass: 17.022577 },\n            { nominal: 18, mass: 18.026751 },\n            { nominal: 19, mass: 19.0348 },\n            { nominal: 20, mass: 20.04032 },\n            { nominal: 21, mass: 21.049 },\n            { nominal: 22, mass: 22.05753 },\n            { nominal: 23, mass: 23.0689 },\n        ],\n        symbol: 'C',\n        mass: 12.010735896735248,\n        name: 'Carbon',\n        monoisotopicMass: 12,\n    },\n    {\n        number: 7,\n        isotopes: [\n            { nominal: 10, mass: 10.04165 },\n            { nominal: 11, mass: 11.026091 },\n            { nominal: 12, mass: 12.0186132 },\n            { nominal: 13, mass: 13.00573861 },\n            { nominal: 14, mass: 14.00307400443, abundance: 0.99636 },\n            { nominal: 15, mass: 15.00010889888, abundance: 0.00364 },\n            { nominal: 16, mass: 16.0061019 },\n            { nominal: 17, mass: 17.008449 },\n            { nominal: 18, mass: 18.014078 },\n            { nominal: 19, mass: 19.017022 },\n            { nominal: 20, mass: 20.023366 },\n            { nominal: 21, mass: 21.02711 },\n            { nominal: 22, mass: 22.03439 },\n            { nominal: 23, mass: 23.04114 },\n            { nominal: 24, mass: 24.05039 },\n            { nominal: 25, mass: 25.0601 },\n        ],\n        symbol: 'N',\n        mass: 14.006703211445798,\n        name: 'Nitrogen',\n        monoisotopicMass: 14.00307400443,\n    },\n    {\n        number: 8,\n        isotopes: [\n            { nominal: 12, mass: 12.034262 },\n            { nominal: 13, mass: 13.024815 },\n            { nominal: 14, mass: 14.00859636 },\n            { nominal: 15, mass: 15.00306562 },\n            { nominal: 16, mass: 15.99491461957, abundance: 0.99757 },\n            { nominal: 17, mass: 16.9991317565, abundance: 0.00038 },\n            { nominal: 18, mass: 17.99915961286, abundance: 0.00205 },\n            { nominal: 19, mass: 19.003578 },\n            { nominal: 20, mass: 20.00407535 },\n            { nominal: 21, mass: 21.008655 },\n            { nominal: 22, mass: 22.009966 },\n            { nominal: 23, mass: 23.015696 },\n            { nominal: 24, mass: 24.01986 },\n            { nominal: 25, mass: 25.02936 },\n            { nominal: 26, mass: 26.03729 },\n            { nominal: 27, mass: 27.04772 },\n            { nominal: 28, mass: 28.05591 },\n        ],\n        symbol: 'O',\n        mass: 15.999404924318277,\n        name: 'Oxygen',\n        monoisotopicMass: 15.99491461957,\n    },\n    {\n        number: 9,\n        isotopes: [\n            { nominal: 14, mass: 14.034315 },\n            { nominal: 15, mass: 15.018043 },\n            { nominal: 16, mass: 16.0114657 },\n            { nominal: 17, mass: 17.00209524 },\n            { nominal: 18, mass: 18.00093733 },\n            { nominal: 19, mass: 18.99840316273, abundance: 1 },\n            { nominal: 20, mass: 19.999981252 },\n            { nominal: 21, mass: 20.9999489 },\n            { nominal: 22, mass: 22.002999 },\n            { nominal: 23, mass: 23.003557 },\n            { nominal: 24, mass: 24.008115 },\n            { nominal: 25, mass: 25.012199 },\n            { nominal: 26, mass: 26.020038 },\n            { nominal: 27, mass: 27.02644 },\n            { nominal: 28, mass: 28.03534 },\n            { nominal: 29, mass: 29.04254 },\n            { nominal: 30, mass: 30.05165 },\n            { nominal: 31, mass: 31.05971 },\n        ],\n        symbol: 'F',\n        mass: 18.99840316273,\n        name: 'Fluorine',\n        monoisotopicMass: 18.99840316273,\n    },\n    {\n        number: 10,\n        isotopes: [\n            { nominal: 16, mass: 16.02575 },\n            { nominal: 17, mass: 17.01771396 },\n            { nominal: 18, mass: 18.0057087 },\n            { nominal: 19, mass: 19.00188091 },\n            { nominal: 20, mass: 19.9924401762, abundance: 0.9048 },\n            { nominal: 21, mass: 20.993846685, abundance: 0.0027 },\n            { nominal: 22, mass: 21.991385114, abundance: 0.0925 },\n            { nominal: 23, mass: 22.99446691 },\n            { nominal: 24, mass: 23.99361065 },\n            { nominal: 25, mass: 24.997789 },\n            { nominal: 26, mass: 26.000515 },\n            { nominal: 27, mass: 27.007553 },\n            { nominal: 28, mass: 28.01212 },\n            { nominal: 29, mass: 29.01975 },\n            { nominal: 30, mass: 30.02473 },\n            { nominal: 31, mass: 31.0331 },\n            { nominal: 32, mass: 32.03972 },\n            { nominal: 33, mass: 33.04938 },\n            { nominal: 34, mass: 34.05673 },\n        ],\n        symbol: 'Ne',\n        mass: 20.18004638052026,\n        name: 'Neon',\n        monoisotopicMass: 19.9924401762,\n    },\n    {\n        number: 11,\n        isotopes: [\n            { nominal: 18, mass: 18.02688 },\n            { nominal: 19, mass: 19.01388 },\n            { nominal: 20, mass: 20.0073544 },\n            { nominal: 21, mass: 20.99765469 },\n            { nominal: 22, mass: 21.99443741 },\n            { nominal: 23, mass: 22.989769282, abundance: 1 },\n            { nominal: 24, mass: 23.99096295 },\n            { nominal: 25, mass: 24.989954 },\n            { nominal: 26, mass: 25.9926346 },\n            { nominal: 27, mass: 26.9940765 },\n            { nominal: 28, mass: 27.998939 },\n            { nominal: 29, mass: 29.0028771 },\n            { nominal: 30, mass: 30.0090979 },\n            { nominal: 31, mass: 31.013163 },\n            { nominal: 32, mass: 32.02019 },\n            { nominal: 33, mass: 33.02573 },\n            { nominal: 34, mass: 34.03359 },\n            { nominal: 35, mass: 35.04062 },\n            { nominal: 36, mass: 36.04929 },\n            { nominal: 37, mass: 37.05705 },\n        ],\n        symbol: 'Na',\n        mass: 22.989769282,\n        name: 'Sodium',\n        monoisotopicMass: 22.989769282,\n    },\n    {\n        number: 12,\n        isotopes: [\n            { nominal: 19, mass: 19.034169 },\n            { nominal: 20, mass: 20.01885 },\n            { nominal: 21, mass: 21.011716 },\n            { nominal: 22, mass: 21.99957065 },\n            { nominal: 23, mass: 22.99412421 },\n            { nominal: 24, mass: 23.985041697, abundance: 0.7899 },\n            { nominal: 25, mass: 24.985836976, abundance: 0.1 },\n            { nominal: 26, mass: 25.982592968, abundance: 0.1101 },\n            { nominal: 27, mass: 26.984340624 },\n            { nominal: 28, mass: 27.9838767 },\n            { nominal: 29, mass: 28.988617 },\n            { nominal: 30, mass: 29.9904629 },\n            { nominal: 31, mass: 30.996648 },\n            { nominal: 32, mass: 31.9991102 },\n            { nominal: 33, mass: 33.0053271 },\n            { nominal: 34, mass: 34.008935 },\n            { nominal: 35, mass: 35.01679 },\n            { nominal: 36, mass: 36.02188 },\n            { nominal: 37, mass: 37.03037 },\n            { nominal: 38, mass: 38.03658 },\n            { nominal: 39, mass: 39.04538 },\n            { nominal: 40, mass: 40.05218 },\n        ],\n        symbol: 'Mg',\n        mass: 24.3050516198371,\n        name: 'Magnesium',\n        monoisotopicMass: 23.985041697,\n    },\n    {\n        number: 13,\n        isotopes: [\n            { nominal: 21, mass: 21.02897 },\n            { nominal: 22, mass: 22.01954 },\n            { nominal: 23, mass: 23.00724435 },\n            { nominal: 24, mass: 23.9999489 },\n            { nominal: 25, mass: 24.9904281 },\n            { nominal: 26, mass: 25.986891904 },\n            { nominal: 27, mass: 26.98153853, abundance: 1 },\n            { nominal: 28, mass: 27.98191021 },\n            { nominal: 29, mass: 28.9804565 },\n            { nominal: 30, mass: 29.98296 },\n            { nominal: 31, mass: 30.983945 },\n            { nominal: 32, mass: 31.988085 },\n            { nominal: 33, mass: 32.990909 },\n            { nominal: 34, mass: 33.996705 },\n            { nominal: 35, mass: 34.999764 },\n            { nominal: 36, mass: 36.00639 },\n            { nominal: 37, mass: 37.01053 },\n            { nominal: 38, mass: 38.0174 },\n            { nominal: 39, mass: 39.02254 },\n            { nominal: 40, mass: 40.03003 },\n            { nominal: 41, mass: 41.03638 },\n            { nominal: 42, mass: 42.04384 },\n            { nominal: 43, mass: 43.05147 },\n        ],\n        symbol: 'Al',\n        mass: 26.98153853,\n        name: 'Aluminium',\n        monoisotopicMass: 26.98153853,\n    },\n    {\n        number: 14,\n        isotopes: [\n            { nominal: 22, mass: 22.03579 },\n            { nominal: 23, mass: 23.02544 },\n            { nominal: 24, mass: 24.011535 },\n            { nominal: 25, mass: 25.004109 },\n            { nominal: 26, mass: 25.99233384 },\n            { nominal: 27, mass: 26.98670481 },\n            { nominal: 28, mass: 27.97692653465, abundance: 0.92223 },\n            { nominal: 29, mass: 28.9764946649, abundance: 0.04685 },\n            { nominal: 30, mass: 29.973770136, abundance: 0.03092 },\n            { nominal: 31, mass: 30.975363194 },\n            { nominal: 32, mass: 31.97415154 },\n            { nominal: 33, mass: 32.97797696 },\n            { nominal: 34, mass: 33.978576 },\n            { nominal: 35, mass: 34.984583 },\n            { nominal: 36, mass: 35.986695 },\n            { nominal: 37, mass: 36.992921 },\n            { nominal: 38, mass: 37.995523 },\n            { nominal: 39, mass: 39.002491 },\n            { nominal: 40, mass: 40.00583 },\n            { nominal: 41, mass: 41.01301 },\n            { nominal: 42, mass: 42.01778 },\n            { nominal: 43, mass: 43.0248 },\n            { nominal: 44, mass: 44.03061 },\n            { nominal: 45, mass: 45.03995 },\n        ],\n        symbol: 'Si',\n        mass: 28.085498705705955,\n        name: 'Silicon',\n        monoisotopicMass: 27.97692653465,\n    },\n    {\n        number: 15,\n        isotopes: [\n            { nominal: 24, mass: 24.03577 },\n            { nominal: 25, mass: 25.02119 },\n            { nominal: 26, mass: 26.01178 },\n            { nominal: 27, mass: 26.999224 },\n            { nominal: 28, mass: 27.9923266 },\n            { nominal: 29, mass: 28.98180079 },\n            { nominal: 30, mass: 29.97831375 },\n            { nominal: 31, mass: 30.97376199842, abundance: 1 },\n            { nominal: 32, mass: 31.973907643 },\n            { nominal: 33, mass: 32.9717257 },\n            { nominal: 34, mass: 33.97364589 },\n            { nominal: 35, mass: 34.9733141 },\n            { nominal: 36, mass: 35.97826 },\n            { nominal: 37, mass: 36.979607 },\n            { nominal: 38, mass: 37.984252 },\n            { nominal: 39, mass: 38.986227 },\n            { nominal: 40, mass: 39.99133 },\n            { nominal: 41, mass: 40.994654 },\n            { nominal: 42, mass: 42.00108 },\n            { nominal: 43, mass: 43.00502 },\n            { nominal: 44, mass: 44.01121 },\n            { nominal: 45, mass: 45.01645 },\n            { nominal: 46, mass: 46.02446 },\n            { nominal: 47, mass: 47.03139 },\n        ],\n        symbol: 'P',\n        mass: 30.97376199842,\n        name: 'Phosphorus',\n        monoisotopicMass: 30.97376199842,\n    },\n    {\n        number: 16,\n        isotopes: [\n            { nominal: 26, mass: 26.02907 },\n            { nominal: 27, mass: 27.01828 },\n            { nominal: 28, mass: 28.00437 },\n            { nominal: 29, mass: 28.996611 },\n            { nominal: 30, mass: 29.98490703 },\n            { nominal: 31, mass: 30.97955701 },\n            { nominal: 32, mass: 31.9720711744, abundance: 0.9499 },\n            { nominal: 33, mass: 32.9714589098, abundance: 0.0075 },\n            { nominal: 34, mass: 33.967867004, abundance: 0.0425 },\n            { nominal: 35, mass: 34.96903231 },\n            { nominal: 36, mass: 35.96708071, abundance: 0.0001 },\n            { nominal: 37, mass: 36.97112551 },\n            { nominal: 38, mass: 37.9711633 },\n            { nominal: 39, mass: 38.975134 },\n            { nominal: 40, mass: 39.9754826 },\n            { nominal: 41, mass: 40.9795935 },\n            { nominal: 42, mass: 41.9810651 },\n            { nominal: 43, mass: 42.9869076 },\n            { nominal: 44, mass: 43.9901188 },\n            { nominal: 45, mass: 44.99572 },\n            { nominal: 46, mass: 46.00004 },\n            { nominal: 47, mass: 47.00795 },\n            { nominal: 48, mass: 48.0137 },\n            { nominal: 49, mass: 49.02276 },\n        ],\n        symbol: 'S',\n        mass: 32.06478740612706,\n        name: 'Sulfur',\n        monoisotopicMass: 31.9720711744,\n    },\n    {\n        number: 17,\n        isotopes: [\n            { nominal: 28, mass: 28.02954 },\n            { nominal: 29, mass: 29.01478 },\n            { nominal: 30, mass: 30.00477 },\n            { nominal: 31, mass: 30.992414 },\n            { nominal: 32, mass: 31.98568464 },\n            { nominal: 33, mass: 32.97745199 },\n            { nominal: 34, mass: 33.973762485 },\n            { nominal: 35, mass: 34.968852682, abundance: 0.7576 },\n            { nominal: 36, mass: 35.968306809 },\n            { nominal: 37, mass: 36.965902602, abundance: 0.2424 },\n            { nominal: 38, mass: 37.96801044 },\n            { nominal: 39, mass: 38.9680082 },\n            { nominal: 40, mass: 39.970415 },\n            { nominal: 41, mass: 40.970685 },\n            { nominal: 42, mass: 41.97325 },\n            { nominal: 43, mass: 42.97389 },\n            { nominal: 44, mass: 43.97787 },\n            { nominal: 45, mass: 44.98029 },\n            { nominal: 46, mass: 45.98517 },\n            { nominal: 47, mass: 46.98916 },\n            { nominal: 48, mass: 47.99564 },\n            { nominal: 49, mass: 49.00123 },\n            { nominal: 50, mass: 50.00905 },\n            { nominal: 51, mass: 51.01554 },\n        ],\n        symbol: 'Cl',\n        mass: 35.452937582608,\n        name: 'Chlorine',\n        monoisotopicMass: 34.968852682,\n    },\n    {\n        number: 18,\n        isotopes: [\n            { nominal: 30, mass: 30.02307 },\n            { nominal: 31, mass: 31.01212 },\n            { nominal: 32, mass: 31.9976378 },\n            { nominal: 33, mass: 32.98992555 },\n            { nominal: 34, mass: 33.98027009 },\n            { nominal: 35, mass: 34.97525759 },\n            { nominal: 36, mass: 35.967545105, abundance: 0.003336 },\n            { nominal: 37, mass: 36.96677633 },\n            { nominal: 38, mass: 37.96273211, abundance: 0.000629 },\n            { nominal: 39, mass: 38.964313 },\n            { nominal: 40, mass: 39.9623831237, abundance: 0.996035 },\n            { nominal: 41, mass: 40.96450057 },\n            { nominal: 42, mass: 41.9630457 },\n            { nominal: 43, mass: 42.9656361 },\n            { nominal: 44, mass: 43.9649238 },\n            { nominal: 45, mass: 44.96803973 },\n            { nominal: 46, mass: 45.968083 },\n            { nominal: 47, mass: 46.972935 },\n            { nominal: 48, mass: 47.97591 },\n            { nominal: 49, mass: 48.9819 },\n            { nominal: 50, mass: 49.98613 },\n            { nominal: 51, mass: 50.9937 },\n            { nominal: 52, mass: 51.99896 },\n            { nominal: 53, mass: 53.00729 },\n        ],\n        symbol: 'Ar',\n        mass: 39.947798563582005,\n        name: 'Argon',\n        monoisotopicMass: 39.9623831237,\n    },\n    {\n        number: 19,\n        isotopes: [\n            { nominal: 32, mass: 32.02265 },\n            { nominal: 33, mass: 33.00756 },\n            { nominal: 34, mass: 33.99869 },\n            { nominal: 35, mass: 34.98800541 },\n            { nominal: 36, mass: 35.98130201 },\n            { nominal: 37, mass: 36.97337589 },\n            { nominal: 38, mass: 37.96908112 },\n            { nominal: 39, mass: 38.9637064864, abundance: 0.932581 },\n            { nominal: 40, mass: 39.963998166, abundance: 0.000117 },\n            { nominal: 41, mass: 40.9618252579, abundance: 0.067302 },\n            { nominal: 42, mass: 41.96240231 },\n            { nominal: 43, mass: 42.9607347 },\n            { nominal: 44, mass: 43.96158699 },\n            { nominal: 45, mass: 44.96069149 },\n            { nominal: 46, mass: 45.96198159 },\n            { nominal: 47, mass: 46.9616616 },\n            { nominal: 48, mass: 47.96534119 },\n            { nominal: 49, mass: 48.96821075 },\n            { nominal: 50, mass: 49.97238 },\n            { nominal: 51, mass: 50.975828 },\n            { nominal: 52, mass: 51.98224 },\n            { nominal: 53, mass: 52.98746 },\n            { nominal: 54, mass: 53.99463 },\n            { nominal: 55, mass: 55.00076 },\n            { nominal: 56, mass: 56.00851 },\n        ],\n        symbol: 'K',\n        mass: 39.098300910086,\n        name: 'Potassium',\n        monoisotopicMass: 38.9637064864,\n    },\n    {\n        number: 20,\n        isotopes: [\n            { nominal: 34, mass: 34.01487 },\n            { nominal: 35, mass: 35.00514 },\n            { nominal: 36, mass: 35.993074 },\n            { nominal: 37, mass: 36.98589785 },\n            { nominal: 38, mass: 37.97631922 },\n            { nominal: 39, mass: 38.97071081 },\n            { nominal: 40, mass: 39.962590863, abundance: 0.96941 },\n            { nominal: 41, mass: 40.96227792 },\n            { nominal: 42, mass: 41.95861783, abundance: 0.00647 },\n            { nominal: 43, mass: 42.95876644, abundance: 0.00135 },\n            { nominal: 44, mass: 43.95548156, abundance: 0.02086 },\n            { nominal: 45, mass: 44.95618635 },\n            { nominal: 46, mass: 45.953689, abundance: 0.00004 },\n            { nominal: 47, mass: 46.9545424 },\n            { nominal: 48, mass: 47.95252276, abundance: 0.00187 },\n            { nominal: 49, mass: 48.95566274 },\n            { nominal: 50, mass: 49.9574992 },\n            { nominal: 51, mass: 50.960989 },\n            { nominal: 52, mass: 51.963217 },\n            { nominal: 53, mass: 52.96945 },\n            { nominal: 54, mass: 53.9734 },\n            { nominal: 55, mass: 54.9803 },\n            { nominal: 56, mass: 55.98508 },\n            { nominal: 57, mass: 56.99262 },\n            { nominal: 58, mass: 57.99794 },\n        ],\n        symbol: 'Ca',\n        mass: 40.078022511017735,\n        name: 'Calcium',\n        monoisotopicMass: 39.962590863,\n    },\n    {\n        number: 21,\n        isotopes: [\n            { nominal: 36, mass: 36.01648 },\n            { nominal: 37, mass: 37.00374 },\n            { nominal: 38, mass: 37.99512 },\n            { nominal: 39, mass: 38.984785 },\n            { nominal: 40, mass: 39.9779673 },\n            { nominal: 41, mass: 40.969251105 },\n            { nominal: 42, mass: 41.96551653 },\n            { nominal: 43, mass: 42.9611505 },\n            { nominal: 44, mass: 43.9594029 },\n            { nominal: 45, mass: 44.95590828, abundance: 1 },\n            { nominal: 46, mass: 45.95516826 },\n            { nominal: 47, mass: 46.9524037 },\n            { nominal: 48, mass: 47.9522236 },\n            { nominal: 49, mass: 48.9500146 },\n            { nominal: 50, mass: 49.952176 },\n            { nominal: 51, mass: 50.953592 },\n            { nominal: 52, mass: 51.95688 },\n            { nominal: 53, mass: 52.95909 },\n            { nominal: 54, mass: 53.96393 },\n            { nominal: 55, mass: 54.96782 },\n            { nominal: 56, mass: 55.97345 },\n            { nominal: 57, mass: 56.97777 },\n            { nominal: 58, mass: 57.98403 },\n            { nominal: 59, mass: 58.98894 },\n            { nominal: 60, mass: 59.99565 },\n            { nominal: 61, mass: 61.001 },\n        ],\n        symbol: 'Sc',\n        mass: 44.95590828,\n        name: 'Scandium',\n        monoisotopicMass: 44.95590828,\n    },\n    {\n        number: 22,\n        isotopes: [\n            { nominal: 38, mass: 38.01145 },\n            { nominal: 39, mass: 39.00236 },\n            { nominal: 40, mass: 39.9905 },\n            { nominal: 41, mass: 40.983148 },\n            { nominal: 42, mass: 41.97304903 },\n            { nominal: 43, mass: 42.9685225 },\n            { nominal: 44, mass: 43.95968995 },\n            { nominal: 45, mass: 44.95812198 },\n            { nominal: 46, mass: 45.95262772, abundance: 0.0825 },\n            { nominal: 47, mass: 46.95175879, abundance: 0.0744 },\n            { nominal: 48, mass: 47.94794198, abundance: 0.7372 },\n            { nominal: 49, mass: 48.94786568, abundance: 0.0541 },\n            { nominal: 50, mass: 49.94478689, abundance: 0.0518 },\n            { nominal: 51, mass: 50.94661065 },\n            { nominal: 52, mass: 51.946893 },\n            { nominal: 53, mass: 52.94973 },\n            { nominal: 54, mass: 53.95105 },\n            { nominal: 55, mass: 54.95527 },\n            { nominal: 56, mass: 55.95791 },\n            { nominal: 57, mass: 56.96364 },\n            { nominal: 58, mass: 57.9666 },\n            { nominal: 59, mass: 58.97247 },\n            { nominal: 60, mass: 59.97603 },\n            { nominal: 61, mass: 60.98245 },\n            { nominal: 62, mass: 61.98651 },\n            { nominal: 63, mass: 62.99375 },\n        ],\n        symbol: 'Ti',\n        mass: 47.866744962721995,\n        name: 'Titanium',\n        monoisotopicMass: 47.94794198,\n    },\n    {\n        number: 23,\n        isotopes: [\n            { nominal: 40, mass: 40.01276 },\n            { nominal: 41, mass: 41.00021 },\n            { nominal: 42, mass: 41.99182 },\n            { nominal: 43, mass: 42.980766 },\n            { nominal: 44, mass: 43.97411 },\n            { nominal: 45, mass: 44.9657748 },\n            { nominal: 46, mass: 45.96019878 },\n            { nominal: 47, mass: 46.95490491 },\n            { nominal: 48, mass: 47.9522522 },\n            { nominal: 49, mass: 48.9485118 },\n            { nominal: 50, mass: 49.94715601, abundance: 0.0025 },\n            { nominal: 51, mass: 50.94395704, abundance: 0.9975 },\n            { nominal: 52, mass: 51.94477301 },\n            { nominal: 53, mass: 52.9443367 },\n            { nominal: 54, mass: 53.946439 },\n            { nominal: 55, mass: 54.94724 },\n            { nominal: 56, mass: 55.95048 },\n            { nominal: 57, mass: 56.95252 },\n            { nominal: 58, mass: 57.95672 },\n            { nominal: 59, mass: 58.95939 },\n            { nominal: 60, mass: 59.96431 },\n            { nominal: 61, mass: 60.96725 },\n            { nominal: 62, mass: 61.97265 },\n            { nominal: 63, mass: 62.97639 },\n            { nominal: 64, mass: 63.98264 },\n            { nominal: 65, mass: 64.9875 },\n            { nominal: 66, mass: 65.99398 },\n        ],\n        symbol: 'V',\n        mass: 50.941465037425004,\n        name: 'Vanadium',\n        monoisotopicMass: 50.94395704,\n    },\n    {\n        number: 24,\n        isotopes: [\n            { nominal: 42, mass: 42.0067 },\n            { nominal: 43, mass: 42.99753 },\n            { nominal: 44, mass: 43.98536 },\n            { nominal: 45, mass: 44.97905 },\n            { nominal: 46, mass: 45.968359 },\n            { nominal: 47, mass: 46.9628974 },\n            { nominal: 48, mass: 47.9540291 },\n            { nominal: 49, mass: 48.9513333 },\n            { nominal: 50, mass: 49.94604183, abundance: 0.04345 },\n            { nominal: 51, mass: 50.94476502 },\n            { nominal: 52, mass: 51.94050623, abundance: 0.83789 },\n            { nominal: 53, mass: 52.94064815, abundance: 0.09501 },\n            { nominal: 54, mass: 53.93887916, abundance: 0.02365 },\n            { nominal: 55, mass: 54.94083843 },\n            { nominal: 56, mass: 55.9406531 },\n            { nominal: 57, mass: 56.943613 },\n            { nominal: 58, mass: 57.94435 },\n            { nominal: 59, mass: 58.94859 },\n            { nominal: 60, mass: 59.95008 },\n            { nominal: 61, mass: 60.95442 },\n            { nominal: 62, mass: 61.9561 },\n            { nominal: 63, mass: 62.96165 },\n            { nominal: 64, mass: 63.96408 },\n            { nominal: 65, mass: 64.96996 },\n            { nominal: 66, mass: 65.97366 },\n            { nominal: 67, mass: 66.98016 },\n            { nominal: 68, mass: 67.98403 },\n        ],\n        symbol: 'Cr',\n        mass: 51.9961317554337,\n        name: 'Chromium',\n        monoisotopicMass: 51.94050623,\n    },\n    {\n        number: 25,\n        isotopes: [\n            { nominal: 44, mass: 44.00715 },\n            { nominal: 45, mass: 44.99449 },\n            { nominal: 46, mass: 45.98609 },\n            { nominal: 47, mass: 46.975775 },\n            { nominal: 48, mass: 47.96852 },\n            { nominal: 49, mass: 48.959595 },\n            { nominal: 50, mass: 49.95423778 },\n            { nominal: 51, mass: 50.94820847 },\n            { nominal: 52, mass: 51.9455639 },\n            { nominal: 53, mass: 52.94128889 },\n            { nominal: 54, mass: 53.9403576 },\n            { nominal: 55, mass: 54.93804391, abundance: 1 },\n            { nominal: 56, mass: 55.93890369 },\n            { nominal: 57, mass: 56.9382861 },\n            { nominal: 58, mass: 57.9400666 },\n            { nominal: 59, mass: 58.9403911 },\n            { nominal: 60, mass: 59.9431366 },\n            { nominal: 61, mass: 60.9444525 },\n            { nominal: 62, mass: 61.94795 },\n            { nominal: 63, mass: 62.9496647 },\n            { nominal: 64, mass: 63.9538494 },\n            { nominal: 65, mass: 64.9560198 },\n            { nominal: 66, mass: 65.960547 },\n            { nominal: 67, mass: 66.96424 },\n            { nominal: 68, mass: 67.96962 },\n            { nominal: 69, mass: 68.97366 },\n            { nominal: 70, mass: 69.97937 },\n            { nominal: 71, mass: 70.98368 },\n        ],\n        symbol: 'Mn',\n        mass: 54.93804391,\n        name: 'Manganese',\n        monoisotopicMass: 54.93804391,\n    },\n    {\n        number: 26,\n        isotopes: [\n            { nominal: 45, mass: 45.01442 },\n            { nominal: 46, mass: 46.00063 },\n            { nominal: 47, mass: 46.99185 },\n            { nominal: 48, mass: 47.98023 },\n            { nominal: 49, mass: 48.973429 },\n            { nominal: 50, mass: 49.962975 },\n            { nominal: 51, mass: 50.956841 },\n            { nominal: 52, mass: 51.9481131 },\n            { nominal: 53, mass: 52.9453064 },\n            { nominal: 54, mass: 53.93960899, abundance: 0.05845 },\n            { nominal: 55, mass: 54.93829199 },\n            { nominal: 56, mass: 55.93493633, abundance: 0.91754 },\n            { nominal: 57, mass: 56.93539284, abundance: 0.02119 },\n            { nominal: 58, mass: 57.93327443, abundance: 0.00282 },\n            { nominal: 59, mass: 58.93487434 },\n            { nominal: 60, mass: 59.9340711 },\n            { nominal: 61, mass: 60.9367462 },\n            { nominal: 62, mass: 61.9367918 },\n            { nominal: 63, mass: 62.9402727 },\n            { nominal: 64, mass: 63.9409878 },\n            { nominal: 65, mass: 64.9450115 },\n            { nominal: 66, mass: 65.94625 },\n            { nominal: 67, mass: 66.95054 },\n            { nominal: 68, mass: 67.95295 },\n            { nominal: 69, mass: 68.95807 },\n            { nominal: 70, mass: 69.96102 },\n            { nominal: 71, mass: 70.96672 },\n            { nominal: 72, mass: 71.96983 },\n            { nominal: 73, mass: 72.97572 },\n            { nominal: 74, mass: 73.97935 },\n        ],\n        symbol: 'Fe',\n        mass: 55.845144433865904,\n        name: 'Iron',\n        monoisotopicMass: 55.93493633,\n    },\n    {\n        number: 27,\n        isotopes: [\n            { nominal: 47, mass: 47.01057 },\n            { nominal: 48, mass: 48.00093 },\n            { nominal: 49, mass: 48.98891 },\n            { nominal: 50, mass: 49.98091 },\n            { nominal: 51, mass: 50.970647 },\n            { nominal: 52, mass: 51.96351 },\n            { nominal: 53, mass: 52.9542041 },\n            { nominal: 54, mass: 53.94845987 },\n            { nominal: 55, mass: 54.9419972 },\n            { nominal: 56, mass: 55.9398388 },\n            { nominal: 57, mass: 56.93629057 },\n            { nominal: 58, mass: 57.9357521 },\n            { nominal: 59, mass: 58.93319429, abundance: 1 },\n            { nominal: 60, mass: 59.9338163 },\n            { nominal: 61, mass: 60.93247662 },\n            { nominal: 62, mass: 61.934059 },\n            { nominal: 63, mass: 62.9336 },\n            { nominal: 64, mass: 63.935811 },\n            { nominal: 65, mass: 64.9364621 },\n            { nominal: 66, mass: 65.939443 },\n            { nominal: 67, mass: 66.9406096 },\n            { nominal: 68, mass: 67.94426 },\n            { nominal: 69, mass: 68.94614 },\n            { nominal: 70, mass: 69.94963 },\n            { nominal: 71, mass: 70.95237 },\n            { nominal: 72, mass: 71.95729 },\n            { nominal: 73, mass: 72.96039 },\n            { nominal: 74, mass: 73.96515 },\n            { nominal: 75, mass: 74.96876 },\n            { nominal: 76, mass: 75.97413 },\n        ],\n        symbol: 'Co',\n        mass: 58.93319429,\n        name: 'Cobalt',\n        monoisotopicMass: 58.93319429,\n    },\n    {\n        number: 28,\n        isotopes: [\n            { nominal: 48, mass: 48.01769 },\n            { nominal: 49, mass: 49.0077 },\n            { nominal: 50, mass: 49.99474 },\n            { nominal: 51, mass: 50.98611 },\n            { nominal: 52, mass: 51.9748 },\n            { nominal: 53, mass: 52.96819 },\n            { nominal: 54, mass: 53.957892 },\n            { nominal: 55, mass: 54.95133063 },\n            { nominal: 56, mass: 55.94212855 },\n            { nominal: 57, mass: 56.93979218 },\n            { nominal: 58, mass: 57.93534241, abundance: 0.68077 },\n            { nominal: 59, mass: 58.9343462 },\n            { nominal: 60, mass: 59.93078588, abundance: 0.26223 },\n            { nominal: 61, mass: 60.93105557, abundance: 0.011399 },\n            { nominal: 62, mass: 61.92834537, abundance: 0.036346 },\n            { nominal: 63, mass: 62.92966963 },\n            { nominal: 64, mass: 63.92796682, abundance: 0.009255 },\n            { nominal: 65, mass: 64.93008517 },\n            { nominal: 66, mass: 65.9291393 },\n            { nominal: 67, mass: 66.9315694 },\n            { nominal: 68, mass: 67.9318688 },\n            { nominal: 69, mass: 68.9356103 },\n            { nominal: 70, mass: 69.9364313 },\n            { nominal: 71, mass: 70.940519 },\n            { nominal: 72, mass: 71.9417859 },\n            { nominal: 73, mass: 72.9462067 },\n            { nominal: 74, mass: 73.94798 },\n            { nominal: 75, mass: 74.9525 },\n            { nominal: 76, mass: 75.95533 },\n            { nominal: 77, mass: 76.96055 },\n            { nominal: 78, mass: 77.96336 },\n            { nominal: 79, mass: 78.97025 },\n        ],\n        symbol: 'Ni',\n        mass: 58.69334710994765,\n        name: 'Nickel',\n        monoisotopicMass: 57.93534241,\n    },\n    {\n        number: 29,\n        isotopes: [\n            { nominal: 52, mass: 51.99671 },\n            { nominal: 53, mass: 52.98459 },\n            { nominal: 54, mass: 53.97666 },\n            { nominal: 55, mass: 54.96604 },\n            { nominal: 56, mass: 55.95895 },\n            { nominal: 57, mass: 56.9492125 },\n            { nominal: 58, mass: 57.94453305 },\n            { nominal: 59, mass: 58.93949748 },\n            { nominal: 60, mass: 59.9373645 },\n            { nominal: 61, mass: 60.9334576 },\n            { nominal: 62, mass: 61.93259541 },\n            { nominal: 63, mass: 62.92959772, abundance: 0.6915 },\n            { nominal: 64, mass: 63.92976434 },\n            { nominal: 65, mass: 64.9277897, abundance: 0.3085 },\n            { nominal: 66, mass: 65.92886903 },\n            { nominal: 67, mass: 66.9277303 },\n            { nominal: 68, mass: 67.9296109 },\n            { nominal: 69, mass: 68.9294293 },\n            { nominal: 70, mass: 69.9323921 },\n            { nominal: 71, mass: 70.9326768 },\n            { nominal: 72, mass: 71.9358203 },\n            { nominal: 73, mass: 72.9366744 },\n            { nominal: 74, mass: 73.9398749 },\n            { nominal: 75, mass: 74.9415226 },\n            { nominal: 76, mass: 75.945275 },\n            { nominal: 77, mass: 76.94792 },\n            { nominal: 78, mass: 77.95223 },\n            { nominal: 79, mass: 78.95502 },\n            { nominal: 80, mass: 79.96089 },\n            { nominal: 81, mass: 80.96587 },\n            { nominal: 82, mass: 81.97244 },\n        ],\n        symbol: 'Cu',\n        mass: 63.54603994583,\n        name: 'Copper',\n        monoisotopicMass: 62.92959772,\n    },\n    {\n        number: 30,\n        isotopes: [\n            { nominal: 54, mass: 53.99204 },\n            { nominal: 55, mass: 54.98398 },\n            { nominal: 56, mass: 55.97254 },\n            { nominal: 57, mass: 56.96506 },\n            { nominal: 58, mass: 57.954591 },\n            { nominal: 59, mass: 58.94931266 },\n            { nominal: 60, mass: 59.9418421 },\n            { nominal: 61, mass: 60.939507 },\n            { nominal: 62, mass: 61.93433397 },\n            { nominal: 63, mass: 62.9332115 },\n            { nominal: 64, mass: 63.92914201, abundance: 0.4917 },\n            { nominal: 65, mass: 64.92924077 },\n            { nominal: 66, mass: 65.92603381, abundance: 0.2773 },\n            { nominal: 67, mass: 66.92712775, abundance: 0.0404 },\n            { nominal: 68, mass: 67.92484455, abundance: 0.1845 },\n            { nominal: 69, mass: 68.9265507 },\n            { nominal: 70, mass: 69.9253192, abundance: 0.0061 },\n            { nominal: 71, mass: 70.9277196 },\n            { nominal: 72, mass: 71.9268428 },\n            { nominal: 73, mass: 72.9295826 },\n            { nominal: 74, mass: 73.9294073 },\n            { nominal: 75, mass: 74.9328402 },\n            { nominal: 76, mass: 75.933115 },\n            { nominal: 77, mass: 76.9368872 },\n            { nominal: 78, mass: 77.9382892 },\n            { nominal: 79, mass: 78.9426381 },\n            { nominal: 80, mass: 79.9445529 },\n            { nominal: 81, mass: 80.9504026 },\n            { nominal: 82, mass: 81.95426 },\n            { nominal: 83, mass: 82.96056 },\n            { nominal: 84, mass: 83.96521 },\n            { nominal: 85, mass: 84.97226 },\n        ],\n        symbol: 'Zn',\n        mass: 65.37778252952499,\n        name: 'Zinc',\n        monoisotopicMass: 63.92914201,\n    },\n    {\n        number: 31,\n        isotopes: [\n            { nominal: 56, mass: 55.99536 },\n            { nominal: 57, mass: 56.9832 },\n            { nominal: 58, mass: 57.97478 },\n            { nominal: 59, mass: 58.96353 },\n            { nominal: 60, mass: 59.95729 },\n            { nominal: 61, mass: 60.949399 },\n            { nominal: 62, mass: 61.94419025 },\n            { nominal: 63, mass: 62.9392942 },\n            { nominal: 64, mass: 63.9368404 },\n            { nominal: 65, mass: 64.93273459 },\n            { nominal: 66, mass: 65.9315894 },\n            { nominal: 67, mass: 66.9282025 },\n            { nominal: 68, mass: 67.9279805 },\n            { nominal: 69, mass: 68.9255735, abundance: 0.60108 },\n            { nominal: 70, mass: 69.9260219 },\n            { nominal: 71, mass: 70.92470258, abundance: 0.39892 },\n            { nominal: 72, mass: 71.92636747 },\n            { nominal: 73, mass: 72.9251747 },\n            { nominal: 74, mass: 73.9269457 },\n            { nominal: 75, mass: 74.9265002 },\n            { nominal: 76, mass: 75.9288276 },\n            { nominal: 77, mass: 76.9291543 },\n            { nominal: 78, mass: 77.9316088 },\n            { nominal: 79, mass: 78.9328523 },\n            { nominal: 80, mass: 79.9364208 },\n            { nominal: 81, mass: 80.9381338 },\n            { nominal: 82, mass: 81.9431765 },\n            { nominal: 83, mass: 82.9471203 },\n            { nominal: 84, mass: 83.95246 },\n            { nominal: 85, mass: 84.95699 },\n            { nominal: 86, mass: 85.96301 },\n            { nominal: 87, mass: 86.96824 },\n        ],\n        symbol: 'Ga',\n        mass: 69.7230660725936,\n        name: 'Gallium',\n        monoisotopicMass: 68.9255735,\n    },\n    {\n        number: 32,\n        isotopes: [\n            { nominal: 58, mass: 57.99172 },\n            { nominal: 59, mass: 58.98249 },\n            { nominal: 60, mass: 59.97036 },\n            { nominal: 61, mass: 60.96379 },\n            { nominal: 62, mass: 61.95502 },\n            { nominal: 63, mass: 62.949628 },\n            { nominal: 64, mass: 63.9416899 },\n            { nominal: 65, mass: 64.9393681 },\n            { nominal: 66, mass: 65.9338621 },\n            { nominal: 67, mass: 66.9327339 },\n            { nominal: 68, mass: 67.9280953 },\n            { nominal: 69, mass: 68.9279645 },\n            { nominal: 70, mass: 69.92424875, abundance: 0.2057 },\n            { nominal: 71, mass: 70.92495233 },\n            { nominal: 72, mass: 71.922075826, abundance: 0.2745 },\n            { nominal: 73, mass: 72.923458956, abundance: 0.0775 },\n            { nominal: 74, mass: 73.921177761, abundance: 0.365 },\n            { nominal: 75, mass: 74.92285837 },\n            { nominal: 76, mass: 75.921402726, abundance: 0.0773 },\n            { nominal: 77, mass: 76.923549843 },\n            { nominal: 78, mass: 77.9228529 },\n            { nominal: 79, mass: 78.92536 },\n            { nominal: 80, mass: 79.9253508 },\n            { nominal: 81, mass: 80.9288329 },\n            { nominal: 82, mass: 81.929774 },\n            { nominal: 83, mass: 82.9345391 },\n            { nominal: 84, mass: 83.9375751 },\n            { nominal: 85, mass: 84.9429697 },\n            { nominal: 86, mass: 85.94658 },\n            { nominal: 87, mass: 86.95268 },\n            { nominal: 88, mass: 87.95691 },\n            { nominal: 89, mass: 88.96379 },\n            { nominal: 90, mass: 89.96863 },\n        ],\n        symbol: 'Ge',\n        mass: 72.6275501646868,\n        name: 'Germanium',\n        monoisotopicMass: 73.921177761,\n    },\n    {\n        number: 33,\n        isotopes: [\n            { nominal: 60, mass: 59.99388 },\n            { nominal: 61, mass: 60.98112 },\n            { nominal: 62, mass: 61.97361 },\n            { nominal: 63, mass: 62.9639 },\n            { nominal: 64, mass: 63.95743 },\n            { nominal: 65, mass: 64.949611 },\n            { nominal: 66, mass: 65.9441488 },\n            { nominal: 67, mass: 66.93925111 },\n            { nominal: 68, mass: 67.9367741 },\n            { nominal: 69, mass: 68.932246 },\n            { nominal: 70, mass: 69.930926 },\n            { nominal: 71, mass: 70.9271138 },\n            { nominal: 72, mass: 71.9267523 },\n            { nominal: 73, mass: 72.9238291 },\n            { nominal: 74, mass: 73.9239286 },\n            { nominal: 75, mass: 74.92159457, abundance: 1 },\n            { nominal: 76, mass: 75.92239202 },\n            { nominal: 77, mass: 76.9206476 },\n            { nominal: 78, mass: 77.921828 },\n            { nominal: 79, mass: 78.9209484 },\n            { nominal: 80, mass: 79.9224746 },\n            { nominal: 81, mass: 80.9221323 },\n            { nominal: 82, mass: 81.9247412 },\n            { nominal: 83, mass: 82.9252069 },\n            { nominal: 84, mass: 83.9293033 },\n            { nominal: 85, mass: 84.9321637 },\n            { nominal: 86, mass: 85.9367015 },\n            { nominal: 87, mass: 86.9402917 },\n            { nominal: 88, mass: 87.94555 },\n            { nominal: 89, mass: 88.94976 },\n            { nominal: 90, mass: 89.95563 },\n            { nominal: 91, mass: 90.96039 },\n            { nominal: 92, mass: 91.96674 },\n        ],\n        symbol: 'As',\n        mass: 74.92159457,\n        name: 'Arsenic',\n        monoisotopicMass: 74.92159457,\n    },\n    {\n        number: 34,\n        isotopes: [\n            { nominal: 64, mass: 63.97109 },\n            { nominal: 65, mass: 64.9644 },\n            { nominal: 66, mass: 65.95559 },\n            { nominal: 67, mass: 66.949994 },\n            { nominal: 68, mass: 67.94182524 },\n            { nominal: 69, mass: 68.9394148 },\n            { nominal: 70, mass: 69.9335155 },\n            { nominal: 71, mass: 70.9322094 },\n            { nominal: 72, mass: 71.9271405 },\n            { nominal: 73, mass: 72.9267549 },\n            { nominal: 74, mass: 73.922475934, abundance: 0.0089 },\n            { nominal: 75, mass: 74.92252287 },\n            { nominal: 76, mass: 75.919213704, abundance: 0.0937 },\n            { nominal: 77, mass: 76.919914154, abundance: 0.0763 },\n            { nominal: 78, mass: 77.91730928, abundance: 0.2377 },\n            { nominal: 79, mass: 78.91849929 },\n            { nominal: 80, mass: 79.9165218, abundance: 0.4961 },\n            { nominal: 81, mass: 80.917993 },\n            { nominal: 82, mass: 81.9166995, abundance: 0.0873 },\n            { nominal: 83, mass: 82.9191186 },\n            { nominal: 84, mass: 83.9184668 },\n            { nominal: 85, mass: 84.9222608 },\n            { nominal: 86, mass: 85.9243117 },\n            { nominal: 87, mass: 86.9286886 },\n            { nominal: 88, mass: 87.9314175 },\n            { nominal: 89, mass: 88.9366691 },\n            { nominal: 90, mass: 89.9401 },\n            { nominal: 91, mass: 90.94596 },\n            { nominal: 92, mass: 91.94984 },\n            { nominal: 93, mass: 92.95629 },\n            { nominal: 94, mass: 93.96049 },\n            { nominal: 95, mass: 94.9673 },\n        ],\n        symbol: 'Se',\n        mass: 78.95938855701361,\n        name: 'Selenium',\n        monoisotopicMass: 79.9165218,\n    },\n    {\n        number: 35,\n        isotopes: [\n            { nominal: 67, mass: 66.96465 },\n            { nominal: 68, mass: 67.95873 },\n            { nominal: 69, mass: 68.950497 },\n            { nominal: 70, mass: 69.944792 },\n            { nominal: 71, mass: 70.9393422 },\n            { nominal: 72, mass: 71.9365886 },\n            { nominal: 73, mass: 72.9316715 },\n            { nominal: 74, mass: 73.9299102 },\n            { nominal: 75, mass: 74.9258105 },\n            { nominal: 76, mass: 75.924542 },\n            { nominal: 77, mass: 76.9213792 },\n            { nominal: 78, mass: 77.9211459 },\n            { nominal: 79, mass: 78.9183376, abundance: 0.5069 },\n            { nominal: 80, mass: 79.9185298 },\n            { nominal: 81, mass: 80.9162897, abundance: 0.4931 },\n            { nominal: 82, mass: 81.9168032 },\n            { nominal: 83, mass: 82.9151756 },\n            { nominal: 84, mass: 83.916496 },\n            { nominal: 85, mass: 84.9156458 },\n            { nominal: 86, mass: 85.9188054 },\n            { nominal: 87, mass: 86.920674 },\n            { nominal: 88, mass: 87.9240833 },\n            { nominal: 89, mass: 88.9267046 },\n            { nominal: 90, mass: 89.9312928 },\n            { nominal: 91, mass: 90.9343986 },\n            { nominal: 92, mass: 91.9396316 },\n            { nominal: 93, mass: 92.94313 },\n            { nominal: 94, mass: 93.9489 },\n            { nominal: 95, mass: 94.95301 },\n            { nominal: 96, mass: 95.95903 },\n            { nominal: 97, mass: 96.96344 },\n            { nominal: 98, mass: 97.96946 },\n        ],\n        symbol: 'Br',\n        mass: 79.90352778050999,\n        name: 'Bromine',\n        monoisotopicMass: 78.9183376,\n    },\n    {\n        number: 36,\n        isotopes: [\n            { nominal: 69, mass: 68.96518 },\n            { nominal: 70, mass: 69.95604 },\n            { nominal: 71, mass: 70.95027 },\n            { nominal: 72, mass: 71.9420924 },\n            { nominal: 73, mass: 72.9392892 },\n            { nominal: 74, mass: 73.933084 },\n            { nominal: 75, mass: 74.9309457 },\n            { nominal: 76, mass: 75.9259103 },\n            { nominal: 77, mass: 76.92467 },\n            { nominal: 78, mass: 77.92036494, abundance: 0.00355 },\n            { nominal: 79, mass: 78.9200829 },\n            { nominal: 80, mass: 79.91637808, abundance: 0.02286 },\n            { nominal: 81, mass: 80.9165912 },\n            { nominal: 82, mass: 81.91348273, abundance: 0.11593 },\n            { nominal: 83, mass: 82.91412716, abundance: 0.115 },\n            { nominal: 84, mass: 83.9114977282, abundance: 0.56987 },\n            { nominal: 85, mass: 84.9125273 },\n            { nominal: 86, mass: 85.9106106269, abundance: 0.17279 },\n            { nominal: 87, mass: 86.91335476 },\n            { nominal: 88, mass: 87.9144479 },\n            { nominal: 89, mass: 88.9178355 },\n            { nominal: 90, mass: 89.9195279 },\n            { nominal: 91, mass: 90.9238063 },\n            { nominal: 92, mass: 91.9261731 },\n            { nominal: 93, mass: 92.9311472 },\n            { nominal: 94, mass: 93.93414 },\n            { nominal: 95, mass: 94.939711 },\n            { nominal: 96, mass: 95.943017 },\n            { nominal: 97, mass: 96.94909 },\n            { nominal: 98, mass: 97.95243 },\n            { nominal: 99, mass: 98.95839 },\n            { nominal: 100, mass: 99.96237 },\n            { nominal: 101, mass: 100.96873 },\n        ],\n        symbol: 'Kr',\n        mass: 83.7979999953261,\n        name: 'Krypton',\n        monoisotopicMass: 83.9114977282,\n    },\n    {\n        number: 37,\n        isotopes: [\n            { nominal: 71, mass: 70.96532 },\n            { nominal: 72, mass: 71.95908 },\n            { nominal: 73, mass: 72.95053 },\n            { nominal: 74, mass: 73.9442659 },\n            { nominal: 75, mass: 74.9385732 },\n            { nominal: 76, mass: 75.935073 },\n            { nominal: 77, mass: 76.9304016 },\n            { nominal: 78, mass: 77.9281419 },\n            { nominal: 79, mass: 78.9239899 },\n            { nominal: 80, mass: 79.9225164 },\n            { nominal: 81, mass: 80.9189939 },\n            { nominal: 82, mass: 81.918209 },\n            { nominal: 83, mass: 82.9151142 },\n            { nominal: 84, mass: 83.9143752 },\n            { nominal: 85, mass: 84.9117897379, abundance: 0.7217 },\n            { nominal: 86, mass: 85.91116743 },\n            { nominal: 87, mass: 86.909180531, abundance: 0.2783 },\n            { nominal: 88, mass: 87.91131559 },\n            { nominal: 89, mass: 88.9122783 },\n            { nominal: 90, mass: 89.9147985 },\n            { nominal: 91, mass: 90.9165372 },\n            { nominal: 92, mass: 91.9197284 },\n            { nominal: 93, mass: 92.9220393 },\n            { nominal: 94, mass: 93.9263948 },\n            { nominal: 95, mass: 94.92926 },\n            { nominal: 96, mass: 95.9341334 },\n            { nominal: 97, mass: 96.9371771 },\n            { nominal: 98, mass: 97.9416869 },\n            { nominal: 99, mass: 98.94503 },\n            { nominal: 100, mass: 99.95003 },\n            { nominal: 101, mass: 100.95404 },\n            { nominal: 102, mass: 101.95952 },\n            { nominal: 103, mass: 102.96392 },\n        ],\n        symbol: 'Rb',\n        mass: 85.46766359561973,\n        name: 'Rubidium',\n        monoisotopicMass: 84.9117897379,\n    },\n    {\n        number: 38,\n        isotopes: [\n            { nominal: 73, mass: 72.9657 },\n            { nominal: 74, mass: 73.95617 },\n            { nominal: 75, mass: 74.94995 },\n            { nominal: 76, mass: 75.941763 },\n            { nominal: 77, mass: 76.9379455 },\n            { nominal: 78, mass: 77.93218 },\n            { nominal: 79, mass: 78.9297077 },\n            { nominal: 80, mass: 79.9245175 },\n            { nominal: 81, mass: 80.9232114 },\n            { nominal: 82, mass: 81.9183999 },\n            { nominal: 83, mass: 82.9175544 },\n            { nominal: 84, mass: 83.9134191, abundance: 0.0056 },\n            { nominal: 85, mass: 84.912932 },\n            { nominal: 86, mass: 85.9092606, abundance: 0.0986 },\n            { nominal: 87, mass: 86.9088775, abundance: 0.07 },\n            { nominal: 88, mass: 87.9056125, abundance: 0.8258 },\n            { nominal: 89, mass: 88.9074511 },\n            { nominal: 90, mass: 89.90773 },\n            { nominal: 91, mass: 90.9101954 },\n            { nominal: 92, mass: 91.9110382 },\n            { nominal: 93, mass: 92.9140242 },\n            { nominal: 94, mass: 93.9153556 },\n            { nominal: 95, mass: 94.9193529 },\n            { nominal: 96, mass: 95.9217066 },\n            { nominal: 97, mass: 96.926374 },\n            { nominal: 98, mass: 97.9286888 },\n            { nominal: 99, mass: 98.9328907 },\n            { nominal: 100, mass: 99.93577 },\n            { nominal: 101, mass: 100.940352 },\n            { nominal: 102, mass: 101.943791 },\n            { nominal: 103, mass: 102.94909 },\n            { nominal: 104, mass: 103.95265 },\n            { nominal: 105, mass: 104.95855 },\n            { nominal: 106, mass: 105.96265 },\n            { nominal: 107, mass: 106.96897 },\n        ],\n        symbol: 'Sr',\n        mass: 87.61664446962,\n        name: 'Strontium',\n        monoisotopicMass: 87.9056125,\n    },\n    {\n        number: 39,\n        isotopes: [\n            { nominal: 76, mass: 75.95856 },\n            { nominal: 77, mass: 76.949781 },\n            { nominal: 78, mass: 77.94361 },\n            { nominal: 79, mass: 78.93735 },\n            { nominal: 80, mass: 79.9343561 },\n            { nominal: 81, mass: 80.9294556 },\n            { nominal: 82, mass: 81.9269314 },\n            { nominal: 83, mass: 82.922485 },\n            { nominal: 84, mass: 83.9206721 },\n            { nominal: 85, mass: 84.916433 },\n            { nominal: 86, mass: 85.914886 },\n            { nominal: 87, mass: 86.9108761 },\n            { nominal: 88, mass: 87.9095016 },\n            { nominal: 89, mass: 88.9058403, abundance: 1 },\n            { nominal: 90, mass: 89.9071439 },\n            { nominal: 91, mass: 90.9072974 },\n            { nominal: 92, mass: 91.9089451 },\n            { nominal: 93, mass: 92.909578 },\n            { nominal: 94, mass: 93.9115906 },\n            { nominal: 95, mass: 94.9128161 },\n            { nominal: 96, mass: 95.9158968 },\n            { nominal: 97, mass: 96.9182741 },\n            { nominal: 98, mass: 97.9223821 },\n            { nominal: 99, mass: 98.924148 },\n            { nominal: 100, mass: 99.927715 },\n            { nominal: 101, mass: 100.9301477 },\n            { nominal: 102, mass: 101.9343277 },\n            { nominal: 103, mass: 102.937243 },\n            { nominal: 104, mass: 103.94196 },\n            { nominal: 105, mass: 104.94544 },\n            { nominal: 106, mass: 105.95056 },\n            { nominal: 107, mass: 106.95452 },\n            { nominal: 108, mass: 107.95996 },\n            { nominal: 109, mass: 108.96436 },\n        ],\n        symbol: 'Y',\n        mass: 88.9058403,\n        name: 'Yttrium',\n        monoisotopicMass: 88.9058403,\n    },\n    {\n        number: 40,\n        isotopes: [\n            { nominal: 78, mass: 77.95566 },\n            { nominal: 79, mass: 78.94948 },\n            { nominal: 80, mass: 79.9404 },\n            { nominal: 81, mass: 80.93731 },\n            { nominal: 82, mass: 81.93135 },\n            { nominal: 83, mass: 82.9292421 },\n            { nominal: 84, mass: 83.9233269 },\n            { nominal: 85, mass: 84.9214444 },\n            { nominal: 86, mass: 85.9162972 },\n            { nominal: 87, mass: 86.914818 },\n            { nominal: 88, mass: 87.9102213 },\n            { nominal: 89, mass: 88.9088814 },\n            { nominal: 90, mass: 89.9046977, abundance: 0.5145 },\n            { nominal: 91, mass: 90.9056396, abundance: 0.1122 },\n            { nominal: 92, mass: 91.9050347, abundance: 0.1715 },\n            { nominal: 93, mass: 92.9064699 },\n            { nominal: 94, mass: 93.9063108, abundance: 0.1738 },\n            { nominal: 95, mass: 94.9080385 },\n            { nominal: 96, mass: 95.9082714, abundance: 0.028 },\n            { nominal: 97, mass: 96.9109512 },\n            { nominal: 98, mass: 97.9127289 },\n            { nominal: 99, mass: 98.916667 },\n            { nominal: 100, mass: 99.9180006 },\n            { nominal: 101, mass: 100.921448 },\n            { nominal: 102, mass: 101.9231409 },\n            { nominal: 103, mass: 102.927191 },\n            { nominal: 104, mass: 103.929436 },\n            { nominal: 105, mass: 104.934008 },\n            { nominal: 106, mass: 105.93676 },\n            { nominal: 107, mass: 106.94174 },\n            { nominal: 108, mass: 107.94487 },\n            { nominal: 109, mass: 108.95041 },\n            { nominal: 110, mass: 109.95396 },\n            { nominal: 111, mass: 110.95968 },\n            { nominal: 112, mass: 111.9637 },\n        ],\n        symbol: 'Zr',\n        mass: 91.22364159706,\n        name: 'Zirconium',\n        monoisotopicMass: 89.9046977,\n    },\n    {\n        number: 41,\n        isotopes: [\n            { nominal: 81, mass: 80.9496 },\n            { nominal: 82, mass: 81.94396 },\n            { nominal: 83, mass: 82.93729 },\n            { nominal: 84, mass: 83.93449 },\n            { nominal: 85, mass: 84.9288458 },\n            { nominal: 86, mass: 85.9257828 },\n            { nominal: 87, mass: 86.9206937 },\n            { nominal: 88, mass: 87.918222 },\n            { nominal: 89, mass: 88.913445 },\n            { nominal: 90, mass: 89.9112584 },\n            { nominal: 91, mass: 90.9069897 },\n            { nominal: 92, mass: 91.9071881 },\n            { nominal: 93, mass: 92.906373, abundance: 1 },\n            { nominal: 94, mass: 93.9072788 },\n            { nominal: 95, mass: 94.9068324 },\n            { nominal: 96, mass: 95.9080973 },\n            { nominal: 97, mass: 96.9080959 },\n            { nominal: 98, mass: 97.9103265 },\n            { nominal: 99, mass: 98.911613 },\n            { nominal: 100, mass: 99.9143276 },\n            { nominal: 101, mass: 100.9153103 },\n            { nominal: 102, mass: 101.9180772 },\n            { nominal: 103, mass: 102.9194572 },\n            { nominal: 104, mass: 103.9228925 },\n            { nominal: 105, mass: 104.9249465 },\n            { nominal: 106, mass: 105.9289317 },\n            { nominal: 107, mass: 106.9315937 },\n            { nominal: 108, mass: 107.9360748 },\n            { nominal: 109, mass: 108.93922 },\n            { nominal: 110, mass: 109.94403 },\n            { nominal: 111, mass: 110.94753 },\n            { nominal: 112, mass: 111.95247 },\n            { nominal: 113, mass: 112.95651 },\n            { nominal: 114, mass: 113.96201 },\n            { nominal: 115, mass: 114.96634 },\n        ],\n        symbol: 'Nb',\n        mass: 92.906373,\n        name: 'Niobium',\n        monoisotopicMass: 92.906373,\n    },\n    {\n        number: 42,\n        isotopes: [\n            { nominal: 83, mass: 82.94988 },\n            { nominal: 84, mass: 83.94149 },\n            { nominal: 85, mass: 84.938261 },\n            { nominal: 86, mass: 85.9311748 },\n            { nominal: 87, mass: 86.9281962 },\n            { nominal: 88, mass: 87.9219678 },\n            { nominal: 89, mass: 88.9194682 },\n            { nominal: 90, mass: 89.9139309 },\n            { nominal: 91, mass: 90.9117453 },\n            { nominal: 92, mass: 91.90680796, abundance: 0.1453 },\n            { nominal: 93, mass: 92.90680958 },\n            { nominal: 94, mass: 93.9050849, abundance: 0.0915 },\n            { nominal: 95, mass: 94.90583877, abundance: 0.1584 },\n            { nominal: 96, mass: 95.90467612, abundance: 0.1667 },\n            { nominal: 97, mass: 96.90601812, abundance: 0.096 },\n            { nominal: 98, mass: 97.90540482, abundance: 0.2439 },\n            { nominal: 99, mass: 98.90770851 },\n            { nominal: 100, mass: 99.9074718, abundance: 0.0982 },\n            { nominal: 101, mass: 100.9103414 },\n            { nominal: 102, mass: 101.9102834 },\n            { nominal: 103, mass: 102.913079 },\n            { nominal: 104, mass: 103.9137344 },\n            { nominal: 105, mass: 104.916969 },\n            { nominal: 106, mass: 105.918259 },\n            { nominal: 107, mass: 106.922106 },\n            { nominal: 108, mass: 107.924033 },\n            { nominal: 109, mass: 108.928424 },\n            { nominal: 110, mass: 109.930704 },\n            { nominal: 111, mass: 110.935654 },\n            { nominal: 112, mass: 111.93831 },\n            { nominal: 113, mass: 112.94335 },\n            { nominal: 114, mass: 113.94653 },\n            { nominal: 115, mass: 114.95196 },\n            { nominal: 116, mass: 115.95545 },\n            { nominal: 117, mass: 116.96117 },\n        ],\n        symbol: 'Mo',\n        mass: 95.959788541188,\n        name: 'Molybdenum',\n        monoisotopicMass: 97.90540482,\n    },\n    {\n        number: 43,\n        isotopes: [\n            { nominal: 85, mass: 84.95058 },\n            { nominal: 86, mass: 85.94493 },\n            { nominal: 87, mass: 86.9380672 },\n            { nominal: 88, mass: 87.93378 },\n            { nominal: 89, mass: 88.9276487 },\n            { nominal: 90, mass: 89.9240739 },\n            { nominal: 91, mass: 90.9184254 },\n            { nominal: 92, mass: 91.9152698 },\n            { nominal: 93, mass: 92.910246 },\n            { nominal: 94, mass: 93.9096536 },\n            { nominal: 95, mass: 94.9076536 },\n            { nominal: 96, mass: 95.907868 },\n            { nominal: 97, mass: 96.9063667 },\n            { nominal: 98, mass: 97.9072124 },\n            { nominal: 99, mass: 98.9062508 },\n            { nominal: 100, mass: 99.9076539 },\n            { nominal: 101, mass: 100.907309 },\n            { nominal: 102, mass: 101.9092097 },\n            { nominal: 103, mass: 102.909176 },\n            { nominal: 104, mass: 103.911425 },\n            { nominal: 105, mass: 104.911655 },\n            { nominal: 106, mass: 105.914358 },\n            { nominal: 107, mass: 106.9154606 },\n            { nominal: 108, mass: 107.9184957 },\n            { nominal: 109, mass: 108.920256 },\n            { nominal: 110, mass: 109.923744 },\n            { nominal: 111, mass: 110.925901 },\n            { nominal: 112, mass: 111.9299458 },\n            { nominal: 113, mass: 112.932569 },\n            { nominal: 114, mass: 113.93691 },\n            { nominal: 115, mass: 114.93998 },\n            { nominal: 116, mass: 115.94476 },\n            { nominal: 117, mass: 116.94806 },\n            { nominal: 118, mass: 117.95299 },\n            { nominal: 119, mass: 118.95666 },\n            { nominal: 120, mass: 119.96187 },\n        ],\n        symbol: 'Tc',\n        mass: null,\n        name: 'Technetium',\n    },\n    {\n        number: 44,\n        isotopes: [\n            { nominal: 87, mass: 86.95069 },\n            { nominal: 88, mass: 87.9416 },\n            { nominal: 89, mass: 88.93762 },\n            { nominal: 90, mass: 89.9303444 },\n            { nominal: 91, mass: 90.9267419 },\n            { nominal: 92, mass: 91.9202344 },\n            { nominal: 93, mass: 92.9171044 },\n            { nominal: 94, mass: 93.9113429 },\n            { nominal: 95, mass: 94.910406 },\n            { nominal: 96, mass: 95.90759025, abundance: 0.0554 },\n            { nominal: 97, mass: 96.9075471 },\n            { nominal: 98, mass: 97.9052868, abundance: 0.0187 },\n            { nominal: 99, mass: 98.9059341, abundance: 0.1276 },\n            { nominal: 100, mass: 99.9042143, abundance: 0.126 },\n            { nominal: 101, mass: 100.9055769, abundance: 0.1706 },\n            { nominal: 102, mass: 101.9043441, abundance: 0.3155 },\n            { nominal: 103, mass: 102.9063186 },\n            { nominal: 104, mass: 103.9054275, abundance: 0.1862 },\n            { nominal: 105, mass: 104.9077476 },\n            { nominal: 106, mass: 105.9073291 },\n            { nominal: 107, mass: 106.909972 },\n            { nominal: 108, mass: 107.910188 },\n            { nominal: 109, mass: 108.913326 },\n            { nominal: 110, mass: 109.9140407 },\n            { nominal: 111, mass: 110.91757 },\n            { nominal: 112, mass: 111.918809 },\n            { nominal: 113, mass: 112.922844 },\n            { nominal: 114, mass: 113.9246136 },\n            { nominal: 115, mass: 114.92882 },\n            { nominal: 116, mass: 115.9312192 },\n            { nominal: 117, mass: 116.9361 },\n            { nominal: 118, mass: 117.93853 },\n            { nominal: 119, mass: 118.94357 },\n            { nominal: 120, mass: 119.94631 },\n            { nominal: 121, mass: 120.95164 },\n            { nominal: 122, mass: 121.95447 },\n            { nominal: 123, mass: 122.95989 },\n            { nominal: 124, mass: 123.96305 },\n        ],\n        symbol: 'Ru',\n        mass: 101.06494013916,\n        name: 'Ruthenium',\n        monoisotopicMass: 101.9043441,\n    },\n    {\n        number: 45,\n        isotopes: [\n            { nominal: 89, mass: 88.95058 },\n            { nominal: 90, mass: 89.94422 },\n            { nominal: 91, mass: 90.93688 },\n            { nominal: 92, mass: 91.9323677 },\n            { nominal: 93, mass: 92.9259128 },\n            { nominal: 94, mass: 93.9217305 },\n            { nominal: 95, mass: 94.9158979 },\n            { nominal: 96, mass: 95.914453 },\n            { nominal: 97, mass: 96.911329 },\n            { nominal: 98, mass: 97.910708 },\n            { nominal: 99, mass: 98.9081282 },\n            { nominal: 100, mass: 99.908117 },\n            { nominal: 101, mass: 100.9061606 },\n            { nominal: 102, mass: 101.9068374 },\n            { nominal: 103, mass: 102.905498, abundance: 1 },\n            { nominal: 104, mass: 103.9066492 },\n            { nominal: 105, mass: 104.9056885 },\n            { nominal: 106, mass: 105.9072868 },\n            { nominal: 107, mass: 106.906748 },\n            { nominal: 108, mass: 107.908714 },\n            { nominal: 109, mass: 108.9087488 },\n            { nominal: 110, mass: 109.911079 },\n            { nominal: 111, mass: 110.9116423 },\n            { nominal: 112, mass: 111.914403 },\n            { nominal: 113, mass: 112.9154393 },\n            { nominal: 114, mass: 113.918718 },\n            { nominal: 115, mass: 114.9203116 },\n            { nominal: 116, mass: 115.924059 },\n            { nominal: 117, mass: 116.9260354 },\n            { nominal: 118, mass: 117.93034 },\n            { nominal: 119, mass: 118.932557 },\n            { nominal: 120, mass: 119.93686 },\n            { nominal: 121, mass: 120.93942 },\n            { nominal: 122, mass: 121.94399 },\n            { nominal: 123, mass: 122.94685 },\n            { nominal: 124, mass: 123.95151 },\n            { nominal: 125, mass: 124.95469 },\n            { nominal: 126, mass: 125.95946 },\n        ],\n        symbol: 'Rh',\n        mass: 102.905498,\n        name: 'Rhodium',\n        monoisotopicMass: 102.905498,\n    },\n    {\n        number: 46,\n        isotopes: [\n            { nominal: 91, mass: 90.95032 },\n            { nominal: 92, mass: 91.94088 },\n            { nominal: 93, mass: 92.93651 },\n            { nominal: 94, mass: 93.9290376 },\n            { nominal: 95, mass: 94.9248898 },\n            { nominal: 96, mass: 95.9182151 },\n            { nominal: 97, mass: 96.916472 },\n            { nominal: 98, mass: 97.9126983 },\n            { nominal: 99, mass: 98.9117748 },\n            { nominal: 100, mass: 99.908505 },\n            { nominal: 101, mass: 100.9082864 },\n            { nominal: 102, mass: 101.9056022, abundance: 0.0102 },\n            { nominal: 103, mass: 102.9060809 },\n            { nominal: 104, mass: 103.9040305, abundance: 0.1114 },\n            { nominal: 105, mass: 104.9050796, abundance: 0.2233 },\n            { nominal: 106, mass: 105.9034804, abundance: 0.2733 },\n            { nominal: 107, mass: 106.9051282 },\n            { nominal: 108, mass: 107.9038916, abundance: 0.2646 },\n            { nominal: 109, mass: 108.9059504 },\n            { nominal: 110, mass: 109.9051722, abundance: 0.1172 },\n            { nominal: 111, mass: 110.90768968 },\n            { nominal: 112, mass: 111.9073297 },\n            { nominal: 113, mass: 112.910261 },\n            { nominal: 114, mass: 113.9103686 },\n            { nominal: 115, mass: 114.913659 },\n            { nominal: 116, mass: 115.914297 },\n            { nominal: 117, mass: 116.9179547 },\n            { nominal: 118, mass: 117.9190667 },\n            { nominal: 119, mass: 118.9233402 },\n            { nominal: 120, mass: 119.9245511 },\n            { nominal: 121, mass: 120.9289503 },\n            { nominal: 122, mass: 121.930632 },\n            { nominal: 123, mass: 122.93514 },\n            { nominal: 124, mass: 123.93714 },\n            { nominal: 125, mass: 124.94179 },\n            { nominal: 126, mass: 125.94416 },\n            { nominal: 127, mass: 126.94907 },\n            { nominal: 128, mass: 127.95183 },\n        ],\n        symbol: 'Pd',\n        mass: 106.41532750734,\n        name: 'Palladium',\n        monoisotopicMass: 105.9034804,\n    },\n    {\n        number: 47,\n        isotopes: [\n            { nominal: 93, mass: 92.95033 },\n            { nominal: 94, mass: 93.94373 },\n            { nominal: 95, mass: 94.93602 },\n            { nominal: 96, mass: 95.930744 },\n            { nominal: 97, mass: 96.92397 },\n            { nominal: 98, mass: 97.92156 },\n            { nominal: 99, mass: 98.9176458 },\n            { nominal: 100, mass: 99.9161154 },\n            { nominal: 101, mass: 100.912684 },\n            { nominal: 102, mass: 101.9117047 },\n            { nominal: 103, mass: 102.9089631 },\n            { nominal: 104, mass: 103.9086239 },\n            { nominal: 105, mass: 104.9065256 },\n            { nominal: 106, mass: 105.9066636 },\n            { nominal: 107, mass: 106.9050916, abundance: 0.51839 },\n            { nominal: 108, mass: 107.9059503 },\n            { nominal: 109, mass: 108.9047553, abundance: 0.48161 },\n            { nominal: 110, mass: 109.9061102 },\n            { nominal: 111, mass: 110.9052959 },\n            { nominal: 112, mass: 111.9070486 },\n            { nominal: 113, mass: 112.906573 },\n            { nominal: 114, mass: 113.908823 },\n            { nominal: 115, mass: 114.908767 },\n            { nominal: 116, mass: 115.9113868 },\n            { nominal: 117, mass: 116.911774 },\n            { nominal: 118, mass: 117.9145955 },\n            { nominal: 119, mass: 118.91557 },\n            { nominal: 120, mass: 119.9187848 },\n            { nominal: 121, mass: 120.920125 },\n            { nominal: 122, mass: 121.923664 },\n            { nominal: 123, mass: 122.925337 },\n            { nominal: 124, mass: 123.92893 },\n            { nominal: 125, mass: 124.93105 },\n            { nominal: 126, mass: 125.93475 },\n            { nominal: 127, mass: 126.93711 },\n            { nominal: 128, mass: 127.94106 },\n            { nominal: 129, mass: 128.94395 },\n            { nominal: 130, mass: 129.9507 },\n        ],\n        symbol: 'Ag',\n        mass: 107.868149634557,\n        name: 'Silver',\n        monoisotopicMass: 106.9050916,\n    },\n    {\n        number: 48,\n        isotopes: [\n            { nominal: 95, mass: 94.94994 },\n            { nominal: 96, mass: 95.94034 },\n            { nominal: 97, mass: 96.9351 },\n            { nominal: 98, mass: 97.927389 },\n            { nominal: 99, mass: 98.9249258 },\n            { nominal: 100, mass: 99.9203488 },\n            { nominal: 101, mass: 100.9185862 },\n            { nominal: 102, mass: 101.914482 },\n            { nominal: 103, mass: 102.9134165 },\n            { nominal: 104, mass: 103.9098564 },\n            { nominal: 105, mass: 104.9094639 },\n            { nominal: 106, mass: 105.9064599, abundance: 0.0125 },\n            { nominal: 107, mass: 106.9066121 },\n            { nominal: 108, mass: 107.9041834, abundance: 0.0089 },\n            { nominal: 109, mass: 108.9049867 },\n            { nominal: 110, mass: 109.90300661, abundance: 0.1249 },\n            { nominal: 111, mass: 110.90418287, abundance: 0.128 },\n            { nominal: 112, mass: 111.90276287, abundance: 0.2413 },\n            { nominal: 113, mass: 112.90440813, abundance: 0.1222 },\n            { nominal: 114, mass: 113.90336509, abundance: 0.2873 },\n            { nominal: 115, mass: 114.90543751 },\n            { nominal: 116, mass: 115.90476315, abundance: 0.0749 },\n            { nominal: 117, mass: 116.907226 },\n            { nominal: 118, mass: 117.906922 },\n            { nominal: 119, mass: 118.909847 },\n            { nominal: 120, mass: 119.9098681 },\n            { nominal: 121, mass: 120.9129637 },\n            { nominal: 122, mass: 121.9134591 },\n            { nominal: 123, mass: 122.9168925 },\n            { nominal: 124, mass: 123.9176574 },\n            { nominal: 125, mass: 124.9212576 },\n            { nominal: 126, mass: 125.9224291 },\n            { nominal: 127, mass: 126.926472 },\n            { nominal: 128, mass: 127.9278129 },\n            { nominal: 129, mass: 128.93182 },\n            { nominal: 130, mass: 129.93394 },\n            { nominal: 131, mass: 130.9406 },\n            { nominal: 132, mass: 131.94604 },\n            { nominal: 133, mass: 132.95285 },\n        ],\n        symbol: 'Cd',\n        mass: 112.411557818268,\n        name: 'Cadmium',\n        monoisotopicMass: 113.90336509,\n    },\n    {\n        number: 49,\n        isotopes: [\n            { nominal: 97, mass: 96.94934 },\n            { nominal: 98, mass: 97.94214 },\n            { nominal: 99, mass: 98.93411 },\n            { nominal: 100, mass: 99.93096 },\n            { nominal: 101, mass: 100.92634 },\n            { nominal: 102, mass: 101.9241071 },\n            { nominal: 103, mass: 102.9198819 },\n            { nominal: 104, mass: 103.9182145 },\n            { nominal: 105, mass: 104.914502 },\n            { nominal: 106, mass: 105.913464 },\n            { nominal: 107, mass: 106.91029 },\n            { nominal: 108, mass: 107.9096935 },\n            { nominal: 109, mass: 108.9071514 },\n            { nominal: 110, mass: 109.90717 },\n            { nominal: 111, mass: 110.9051085 },\n            { nominal: 112, mass: 111.9055377 },\n            { nominal: 113, mass: 112.90406184, abundance: 0.0429 },\n            { nominal: 114, mass: 113.90491791 },\n            { nominal: 115, mass: 114.903878776, abundance: 0.9571 },\n            { nominal: 116, mass: 115.90525999 },\n            { nominal: 117, mass: 116.9045157 },\n            { nominal: 118, mass: 117.9063566 },\n            { nominal: 119, mass: 118.9058507 },\n            { nominal: 120, mass: 119.907967 },\n            { nominal: 121, mass: 120.907851 },\n            { nominal: 122, mass: 121.910281 },\n            { nominal: 123, mass: 122.910434 },\n            { nominal: 124, mass: 123.913182 },\n            { nominal: 125, mass: 124.913605 },\n            { nominal: 126, mass: 125.916507 },\n            { nominal: 127, mass: 126.917446 },\n            { nominal: 128, mass: 127.9204 },\n            { nominal: 129, mass: 128.9218053 },\n            { nominal: 130, mass: 129.924977 },\n            { nominal: 131, mass: 130.9269715 },\n            { nominal: 132, mass: 131.933001 },\n            { nominal: 133, mass: 132.93831 },\n            { nominal: 134, mass: 133.94454 },\n            { nominal: 135, mass: 134.95005 },\n        ],\n        symbol: 'In',\n        mass: 114.81808662944559,\n        name: 'Indium',\n        monoisotopicMass: 114.903878776,\n    },\n    {\n        number: 50,\n        isotopes: [\n            { nominal: 99, mass: 98.94853 },\n            { nominal: 100, mass: 99.9385 },\n            { nominal: 101, mass: 100.93526 },\n            { nominal: 102, mass: 101.93029 },\n            { nominal: 103, mass: 102.928105 },\n            { nominal: 104, mass: 103.9231052 },\n            { nominal: 105, mass: 104.9212684 },\n            { nominal: 106, mass: 105.9169574 },\n            { nominal: 107, mass: 106.9157137 },\n            { nominal: 108, mass: 107.9118943 },\n            { nominal: 109, mass: 108.9112921 },\n            { nominal: 110, mass: 109.907845 },\n            { nominal: 111, mass: 110.9077401 },\n            { nominal: 112, mass: 111.90482387, abundance: 0.0097 },\n            { nominal: 113, mass: 112.9051757 },\n            { nominal: 114, mass: 113.9027827, abundance: 0.0066 },\n            { nominal: 115, mass: 114.903344699, abundance: 0.0034 },\n            { nominal: 116, mass: 115.9017428, abundance: 0.1454 },\n            { nominal: 117, mass: 116.90295398, abundance: 0.0768 },\n            { nominal: 118, mass: 117.90160657, abundance: 0.2422 },\n            { nominal: 119, mass: 118.90331117, abundance: 0.0859 },\n            { nominal: 120, mass: 119.90220163, abundance: 0.3258 },\n            { nominal: 121, mass: 120.9042426 },\n            { nominal: 122, mass: 121.9034438, abundance: 0.0463 },\n            { nominal: 123, mass: 122.9057252 },\n            { nominal: 124, mass: 123.9052766, abundance: 0.0579 },\n            { nominal: 125, mass: 124.9077864 },\n            { nominal: 126, mass: 125.907659 },\n            { nominal: 127, mass: 126.91039 },\n            { nominal: 128, mass: 127.910507 },\n            { nominal: 129, mass: 128.913465 },\n            { nominal: 130, mass: 129.9139738 },\n            { nominal: 131, mass: 130.917045 },\n            { nominal: 132, mass: 131.9178267 },\n            { nominal: 133, mass: 132.9239134 },\n            { nominal: 134, mass: 133.9286821 },\n            { nominal: 135, mass: 134.9349086 },\n            { nominal: 136, mass: 135.93999 },\n            { nominal: 137, mass: 136.94655 },\n            { nominal: 138, mass: 137.95184 },\n        ],\n        symbol: 'Sn',\n        mass: 118.71011259301059,\n        name: 'Tin',\n        monoisotopicMass: 119.90220163,\n    },\n    {\n        number: 51,\n        isotopes: [\n            { nominal: 103, mass: 102.93969 },\n            { nominal: 104, mass: 103.93648 },\n            { nominal: 105, mass: 104.931276 },\n            { nominal: 106, mass: 105.928638 },\n            { nominal: 107, mass: 106.9241506 },\n            { nominal: 108, mass: 107.9222267 },\n            { nominal: 109, mass: 108.9181411 },\n            { nominal: 110, mass: 109.9168543 },\n            { nominal: 111, mass: 110.9132182 },\n            { nominal: 112, mass: 111.9124 },\n            { nominal: 113, mass: 112.909375 },\n            { nominal: 114, mass: 113.90929 },\n            { nominal: 115, mass: 114.906598 },\n            { nominal: 116, mass: 115.9067931 },\n            { nominal: 117, mass: 116.9048415 },\n            { nominal: 118, mass: 117.9055321 },\n            { nominal: 119, mass: 118.9039455 },\n            { nominal: 120, mass: 119.9050794 },\n            { nominal: 121, mass: 120.903812, abundance: 0.5721 },\n            { nominal: 122, mass: 121.9051699 },\n            { nominal: 123, mass: 122.9042132, abundance: 0.4279 },\n            { nominal: 124, mass: 123.905935 },\n            { nominal: 125, mass: 124.905253 },\n            { nominal: 126, mass: 125.907253 },\n            { nominal: 127, mass: 126.9069243 },\n            { nominal: 128, mass: 127.909146 },\n            { nominal: 129, mass: 128.909147 },\n            { nominal: 130, mass: 129.911662 },\n            { nominal: 131, mass: 130.9119888 },\n            { nominal: 132, mass: 131.9145077 },\n            { nominal: 133, mass: 132.9152732 },\n            { nominal: 134, mass: 133.9205357 },\n            { nominal: 135, mass: 134.9251851 },\n            { nominal: 136, mass: 135.9307459 },\n            { nominal: 137, mass: 136.93555 },\n            { nominal: 138, mass: 137.94145 },\n            { nominal: 139, mass: 138.94655 },\n            { nominal: 140, mass: 139.95283 },\n        ],\n        symbol: 'Sb',\n        mass: 121.75978367348,\n        name: 'Antimony',\n        monoisotopicMass: 120.903812,\n    },\n    {\n        number: 52,\n        isotopes: [\n            { nominal: 105, mass: 104.9433 },\n            { nominal: 106, mass: 105.9375 },\n            { nominal: 107, mass: 106.935012 },\n            { nominal: 108, mass: 107.9293805 },\n            { nominal: 109, mass: 108.9273045 },\n            { nominal: 110, mass: 109.9224581 },\n            { nominal: 111, mass: 110.9210006 },\n            { nominal: 112, mass: 111.9167279 },\n            { nominal: 113, mass: 112.915891 },\n            { nominal: 114, mass: 113.912089 },\n            { nominal: 115, mass: 114.911902 },\n            { nominal: 116, mass: 115.90846 },\n            { nominal: 117, mass: 116.908646 },\n            { nominal: 118, mass: 117.905854 },\n            { nominal: 119, mass: 118.9064071 },\n            { nominal: 120, mass: 119.9040593, abundance: 0.0009 },\n            { nominal: 121, mass: 120.904944 },\n            { nominal: 122, mass: 121.9030435, abundance: 0.0255 },\n            { nominal: 123, mass: 122.9042698, abundance: 0.0089 },\n            { nominal: 124, mass: 123.9028171, abundance: 0.0474 },\n            { nominal: 125, mass: 124.9044299, abundance: 0.0707 },\n            { nominal: 126, mass: 125.9033109, abundance: 0.1884 },\n            { nominal: 127, mass: 126.9052257 },\n            { nominal: 128, mass: 127.90446128, abundance: 0.3174 },\n            { nominal: 129, mass: 128.90659646 },\n            { nominal: 130, mass: 129.906222748, abundance: 0.3408 },\n            { nominal: 131, mass: 130.908522213 },\n            { nominal: 132, mass: 131.9085467 },\n            { nominal: 133, mass: 132.9109688 },\n            { nominal: 134, mass: 133.911394 },\n            { nominal: 135, mass: 134.9165557 },\n            { nominal: 136, mass: 135.9201006 },\n            { nominal: 137, mass: 136.9255989 },\n            { nominal: 138, mass: 137.9294722 },\n            { nominal: 139, mass: 138.9353672 },\n            { nominal: 140, mass: 139.939499 },\n            { nominal: 141, mass: 140.9458 },\n            { nominal: 142, mass: 141.95022 },\n            { nominal: 143, mass: 142.95676 },\n        ],\n        symbol: 'Te',\n        mass: 127.6031264846604,\n        name: 'Tellurium',\n        monoisotopicMass: 129.906222748,\n    },\n    {\n        number: 53,\n        isotopes: [\n            { nominal: 107, mass: 106.94678 },\n            { nominal: 108, mass: 107.94348 },\n            { nominal: 109, mass: 108.9380853 },\n            { nominal: 110, mass: 109.935089 },\n            { nominal: 111, mass: 110.9302692 },\n            { nominal: 112, mass: 111.928005 },\n            { nominal: 113, mass: 112.9236501 },\n            { nominal: 114, mass: 113.92185 },\n            { nominal: 115, mass: 114.918048 },\n            { nominal: 116, mass: 115.91681 },\n            { nominal: 117, mass: 116.913648 },\n            { nominal: 118, mass: 117.913074 },\n            { nominal: 119, mass: 118.910074 },\n            { nominal: 120, mass: 119.910087 },\n            { nominal: 121, mass: 120.9074051 },\n            { nominal: 122, mass: 121.9075888 },\n            { nominal: 123, mass: 122.9055885 },\n            { nominal: 124, mass: 123.906209 },\n            { nominal: 125, mass: 124.9046294 },\n            { nominal: 126, mass: 125.9056233 },\n            { nominal: 127, mass: 126.9044719, abundance: 1 },\n            { nominal: 128, mass: 127.9058086 },\n            { nominal: 129, mass: 128.9049837 },\n            { nominal: 130, mass: 129.9066702 },\n            { nominal: 131, mass: 130.9061263 },\n            { nominal: 132, mass: 131.9079935 },\n            { nominal: 133, mass: 132.907797 },\n            { nominal: 134, mass: 133.9097588 },\n            { nominal: 135, mass: 134.9100488 },\n            { nominal: 136, mass: 135.914604 },\n            { nominal: 137, mass: 136.9180282 },\n            { nominal: 138, mass: 137.9227264 },\n            { nominal: 139, mass: 138.926506 },\n            { nominal: 140, mass: 139.93173 },\n            { nominal: 141, mass: 140.93569 },\n            { nominal: 142, mass: 141.9412 },\n            { nominal: 143, mass: 142.94565 },\n            { nominal: 144, mass: 143.95139 },\n            { nominal: 145, mass: 144.95605 },\n        ],\n        symbol: 'I',\n        mass: 126.9044719,\n        name: 'Iodine',\n        monoisotopicMass: 126.9044719,\n    },\n    {\n        number: 54,\n        isotopes: [\n            { nominal: 109, mass: 108.95043 },\n            { nominal: 110, mass: 109.94426 },\n            { nominal: 111, mass: 110.941607 },\n            { nominal: 112, mass: 111.935559 },\n            { nominal: 113, mass: 112.9332217 },\n            { nominal: 114, mass: 113.92798 },\n            { nominal: 115, mass: 114.926294 },\n            { nominal: 116, mass: 115.921581 },\n            { nominal: 117, mass: 116.920359 },\n            { nominal: 118, mass: 117.916179 },\n            { nominal: 119, mass: 118.915411 },\n            { nominal: 120, mass: 119.911784 },\n            { nominal: 121, mass: 120.911453 },\n            { nominal: 122, mass: 121.908368 },\n            { nominal: 123, mass: 122.908482 },\n            { nominal: 124, mass: 123.905892, abundance: 0.000952 },\n            { nominal: 125, mass: 124.9063944 },\n            { nominal: 126, mass: 125.9042983, abundance: 0.00089 },\n            { nominal: 127, mass: 126.9051829 },\n            { nominal: 128, mass: 127.903531, abundance: 0.019102 },\n            { nominal: 129, mass: 128.9047808611, abundance: 0.264006 },\n            { nominal: 130, mass: 129.903509349, abundance: 0.04071 },\n            { nominal: 131, mass: 130.90508406, abundance: 0.212324 },\n            { nominal: 132, mass: 131.9041550856, abundance: 0.269086 },\n            { nominal: 133, mass: 132.9059108 },\n            { nominal: 134, mass: 133.90539466, abundance: 0.104357 },\n            { nominal: 135, mass: 134.9072278 },\n            { nominal: 136, mass: 135.907214484, abundance: 0.088573 },\n            { nominal: 137, mass: 136.91155778 },\n            { nominal: 138, mass: 137.9141463 },\n            { nominal: 139, mass: 138.9187922 },\n            { nominal: 140, mass: 139.9216458 },\n            { nominal: 141, mass: 140.9267872 },\n            { nominal: 142, mass: 141.9299731 },\n            { nominal: 143, mass: 142.9353696 },\n            { nominal: 144, mass: 143.9389451 },\n            { nominal: 145, mass: 144.94472 },\n            { nominal: 146, mass: 145.948518 },\n            { nominal: 147, mass: 146.95426 },\n            { nominal: 148, mass: 147.95813 },\n        ],\n        symbol: 'Xe',\n        mass: 131.29276144779053,\n        name: 'Xenon',\n        monoisotopicMass: 131.9041550856,\n    },\n    {\n        number: 55,\n        isotopes: [\n            { nominal: 112, mass: 111.950309 },\n            { nominal: 113, mass: 112.9444291 },\n            { nominal: 114, mass: 113.941296 },\n            { nominal: 115, mass: 114.93591 },\n            { nominal: 116, mass: 115.93337 },\n            { nominal: 117, mass: 116.928617 },\n            { nominal: 118, mass: 117.92656 },\n            { nominal: 119, mass: 118.922377 },\n            { nominal: 120, mass: 119.920677 },\n            { nominal: 121, mass: 120.917227 },\n            { nominal: 122, mass: 121.916108 },\n            { nominal: 123, mass: 122.912996 },\n            { nominal: 124, mass: 123.9122578 },\n            { nominal: 125, mass: 124.909728 },\n            { nominal: 126, mass: 125.909446 },\n            { nominal: 127, mass: 126.9074174 },\n            { nominal: 128, mass: 127.9077487 },\n            { nominal: 129, mass: 128.9060657 },\n            { nominal: 130, mass: 129.9067093 },\n            { nominal: 131, mass: 130.9054649 },\n            { nominal: 132, mass: 131.9064339 },\n            { nominal: 133, mass: 132.905451961, abundance: 1 },\n            { nominal: 134, mass: 133.906718503 },\n            { nominal: 135, mass: 134.905977 },\n            { nominal: 136, mass: 135.9073114 },\n            { nominal: 137, mass: 136.90708923 },\n            { nominal: 138, mass: 137.9110171 },\n            { nominal: 139, mass: 138.9133638 },\n            { nominal: 140, mass: 139.9172831 },\n            { nominal: 141, mass: 140.9200455 },\n            { nominal: 142, mass: 141.924296 },\n            { nominal: 143, mass: 142.927349 },\n            { nominal: 144, mass: 143.932076 },\n            { nominal: 145, mass: 144.935527 },\n            { nominal: 146, mass: 145.940344 },\n            { nominal: 147, mass: 146.944156 },\n            { nominal: 148, mass: 147.94923 },\n            { nominal: 149, mass: 148.95302 },\n            { nominal: 150, mass: 149.95833 },\n            { nominal: 151, mass: 150.96258 },\n        ],\n        symbol: 'Cs',\n        mass: 132.905451961,\n        name: 'Caesium',\n        monoisotopicMass: 132.905451961,\n    },\n    {\n        number: 56,\n        isotopes: [\n            { nominal: 114, mass: 113.95066 },\n            { nominal: 115, mass: 114.94737 },\n            { nominal: 116, mass: 115.94128 },\n            { nominal: 117, mass: 116.93814 },\n            { nominal: 118, mass: 117.93306 },\n            { nominal: 119, mass: 118.93066 },\n            { nominal: 120, mass: 119.92605 },\n            { nominal: 121, mass: 120.92405 },\n            { nominal: 122, mass: 121.919904 },\n            { nominal: 123, mass: 122.918781 },\n            { nominal: 124, mass: 123.915094 },\n            { nominal: 125, mass: 124.914472 },\n            { nominal: 126, mass: 125.91125 },\n            { nominal: 127, mass: 126.911091 },\n            { nominal: 128, mass: 127.908342 },\n            { nominal: 129, mass: 128.908681 },\n            { nominal: 130, mass: 129.9063207, abundance: 0.00106 },\n            { nominal: 131, mass: 130.906941 },\n            { nominal: 132, mass: 131.9050611, abundance: 0.00101 },\n            { nominal: 133, mass: 132.9060074 },\n            { nominal: 134, mass: 133.90450818, abundance: 0.02417 },\n            { nominal: 135, mass: 134.90568838, abundance: 0.06592 },\n            { nominal: 136, mass: 135.90457573, abundance: 0.07854 },\n            { nominal: 137, mass: 136.90582714, abundance: 0.11232 },\n            { nominal: 138, mass: 137.905247, abundance: 0.71698 },\n            { nominal: 139, mass: 138.9088411 },\n            { nominal: 140, mass: 139.9106057 },\n            { nominal: 141, mass: 140.9144033 },\n            { nominal: 142, mass: 141.9164324 },\n            { nominal: 143, mass: 142.9206253 },\n            { nominal: 144, mass: 143.9229549 },\n            { nominal: 145, mass: 144.9275184 },\n            { nominal: 146, mass: 145.930284 },\n            { nominal: 147, mass: 146.935304 },\n            { nominal: 148, mass: 147.938171 },\n            { nominal: 149, mass: 148.94308 },\n            { nominal: 150, mass: 149.94605 },\n            { nominal: 151, mass: 150.95127 },\n            { nominal: 152, mass: 151.95481 },\n            { nominal: 153, mass: 152.96036 },\n        ],\n        symbol: 'Ba',\n        mass: 137.3268916286322,\n        name: 'Barium',\n        monoisotopicMass: 137.905247,\n    },\n    {\n        number: 57,\n        isotopes: [\n            { nominal: 116, mass: 115.9563 },\n            { nominal: 117, mass: 116.94999 },\n            { nominal: 118, mass: 117.94673 },\n            { nominal: 119, mass: 118.94099 },\n            { nominal: 120, mass: 119.93807 },\n            { nominal: 121, mass: 120.93315 },\n            { nominal: 122, mass: 121.93071 },\n            { nominal: 123, mass: 122.9263 },\n            { nominal: 124, mass: 123.924574 },\n            { nominal: 125, mass: 124.920816 },\n            { nominal: 126, mass: 125.919513 },\n            { nominal: 127, mass: 126.916375 },\n            { nominal: 128, mass: 127.915592 },\n            { nominal: 129, mass: 128.912694 },\n            { nominal: 130, mass: 129.912369 },\n            { nominal: 131, mass: 130.91007 },\n            { nominal: 132, mass: 131.910119 },\n            { nominal: 133, mass: 132.908218 },\n            { nominal: 134, mass: 133.908514 },\n            { nominal: 135, mass: 134.906984 },\n            { nominal: 136, mass: 135.907635 },\n            { nominal: 137, mass: 136.9064504 },\n            { nominal: 138, mass: 137.9071149, abundance: 0.0008881 },\n            { nominal: 139, mass: 138.9063563, abundance: 0.9991119 },\n            { nominal: 140, mass: 139.9094806 },\n            { nominal: 141, mass: 140.910966 },\n            { nominal: 142, mass: 141.9140909 },\n            { nominal: 143, mass: 142.9160795 },\n            { nominal: 144, mass: 143.919646 },\n            { nominal: 145, mass: 144.921808 },\n            { nominal: 146, mass: 145.925875 },\n            { nominal: 147, mass: 146.928418 },\n            { nominal: 148, mass: 147.932679 },\n            { nominal: 149, mass: 148.93535 },\n            { nominal: 150, mass: 149.93947 },\n            { nominal: 151, mass: 150.94232 },\n            { nominal: 152, mass: 151.94682 },\n            { nominal: 153, mass: 152.95036 },\n            { nominal: 154, mass: 153.95517 },\n            { nominal: 155, mass: 154.95901 },\n        ],\n        symbol: 'La',\n        mass: 138.90546887371266,\n        name: 'Lanthanum',\n        monoisotopicMass: 138.9063563,\n    },\n    {\n        number: 58,\n        isotopes: [\n            { nominal: 119, mass: 118.95271 },\n            { nominal: 120, mass: 119.94654 },\n            { nominal: 121, mass: 120.94335 },\n            { nominal: 122, mass: 121.93787 },\n            { nominal: 123, mass: 122.93528 },\n            { nominal: 124, mass: 123.93031 },\n            { nominal: 125, mass: 124.92844 },\n            { nominal: 126, mass: 125.923971 },\n            { nominal: 127, mass: 126.922727 },\n            { nominal: 128, mass: 127.918911 },\n            { nominal: 129, mass: 128.918102 },\n            { nominal: 130, mass: 129.914736 },\n            { nominal: 131, mass: 130.914429 },\n            { nominal: 132, mass: 131.911464 },\n            { nominal: 133, mass: 132.91152 },\n            { nominal: 134, mass: 133.908928 },\n            { nominal: 135, mass: 134.909161 },\n            { nominal: 136, mass: 135.90712921, abundance: 0.00185 },\n            { nominal: 137, mass: 136.90776236 },\n            { nominal: 138, mass: 137.905991, abundance: 0.00251 },\n            { nominal: 139, mass: 138.9066551 },\n            { nominal: 140, mass: 139.9054431, abundance: 0.8845 },\n            { nominal: 141, mass: 140.9082807 },\n            { nominal: 142, mass: 141.9092504, abundance: 0.11114 },\n            { nominal: 143, mass: 142.9123921 },\n            { nominal: 144, mass: 143.9136529 },\n            { nominal: 145, mass: 144.917265 },\n            { nominal: 146, mass: 145.918802 },\n            { nominal: 147, mass: 146.9226899 },\n            { nominal: 148, mass: 147.924424 },\n            { nominal: 149, mass: 148.928427 },\n            { nominal: 150, mass: 149.930384 },\n            { nominal: 151, mass: 150.934272 },\n            { nominal: 152, mass: 151.9366 },\n            { nominal: 153, mass: 152.94093 },\n            { nominal: 154, mass: 153.9438 },\n            { nominal: 155, mass: 154.94855 },\n            { nominal: 156, mass: 155.95183 },\n            { nominal: 157, mass: 156.95705 },\n        ],\n        symbol: 'Ce',\n        mass: 140.1157307378545,\n        name: 'Cerium',\n        monoisotopicMass: 139.9054431,\n    },\n    {\n        number: 59,\n        isotopes: [\n            { nominal: 121, mass: 120.95532 },\n            { nominal: 122, mass: 121.95175 },\n            { nominal: 123, mass: 122.94596 },\n            { nominal: 124, mass: 123.94294 },\n            { nominal: 125, mass: 124.9377 },\n            { nominal: 126, mass: 125.93524 },\n            { nominal: 127, mass: 126.93071 },\n            { nominal: 128, mass: 127.928791 },\n            { nominal: 129, mass: 128.925095 },\n            { nominal: 130, mass: 129.92359 },\n            { nominal: 131, mass: 130.920235 },\n            { nominal: 132, mass: 131.919255 },\n            { nominal: 133, mass: 132.916331 },\n            { nominal: 134, mass: 133.915697 },\n            { nominal: 135, mass: 134.913112 },\n            { nominal: 136, mass: 135.912677 },\n            { nominal: 137, mass: 136.9106792 },\n            { nominal: 138, mass: 137.910754 },\n            { nominal: 139, mass: 138.9089408 },\n            { nominal: 140, mass: 139.9090803 },\n            { nominal: 141, mass: 140.9076576, abundance: 1 },\n            { nominal: 142, mass: 141.9100496 },\n            { nominal: 143, mass: 142.9108228 },\n            { nominal: 144, mass: 143.9133109 },\n            { nominal: 145, mass: 144.9145182 },\n            { nominal: 146, mass: 145.91768 },\n            { nominal: 147, mass: 146.919008 },\n            { nominal: 148, mass: 147.92213 },\n            { nominal: 149, mass: 148.923736 },\n            { nominal: 150, mass: 149.9266765 },\n            { nominal: 151, mass: 150.928309 },\n            { nominal: 152, mass: 151.931553 },\n            { nominal: 153, mass: 152.933904 },\n            { nominal: 154, mass: 153.93753 },\n            { nominal: 155, mass: 154.940509 },\n            { nominal: 156, mass: 155.94464 },\n            { nominal: 157, mass: 156.94789 },\n            { nominal: 158, mass: 157.95241 },\n            { nominal: 159, mass: 158.95589 },\n        ],\n        symbol: 'Pr',\n        mass: 140.9076576,\n        name: 'Praseodymium',\n        monoisotopicMass: 140.9076576,\n    },\n    {\n        number: 60,\n        isotopes: [\n            { nominal: 124, mass: 123.9522 },\n            { nominal: 125, mass: 124.9489 },\n            { nominal: 126, mass: 125.94311 },\n            { nominal: 127, mass: 126.94038 },\n            { nominal: 128, mass: 127.93525 },\n            { nominal: 129, mass: 128.9331 },\n            { nominal: 130, mass: 129.928506 },\n            { nominal: 131, mass: 130.927248 },\n            { nominal: 132, mass: 131.923321 },\n            { nominal: 133, mass: 132.922348 },\n            { nominal: 134, mass: 133.91879 },\n            { nominal: 135, mass: 134.918181 },\n            { nominal: 136, mass: 135.914976 },\n            { nominal: 137, mass: 136.914562 },\n            { nominal: 138, mass: 137.91195 },\n            { nominal: 139, mass: 138.911954 },\n            { nominal: 140, mass: 139.90955 },\n            { nominal: 141, mass: 140.9096147 },\n            { nominal: 142, mass: 141.907729, abundance: 0.27152 },\n            { nominal: 143, mass: 142.90982, abundance: 0.12174 },\n            { nominal: 144, mass: 143.910093, abundance: 0.23798 },\n            { nominal: 145, mass: 144.9125793, abundance: 0.08293 },\n            { nominal: 146, mass: 145.9131226, abundance: 0.17189 },\n            { nominal: 147, mass: 146.9161061 },\n            { nominal: 148, mass: 147.9168993, abundance: 0.05756 },\n            { nominal: 149, mass: 148.9201548 },\n            { nominal: 150, mass: 149.9209022, abundance: 0.05638 },\n            { nominal: 151, mass: 150.9238403 },\n            { nominal: 152, mass: 151.924692 },\n            { nominal: 153, mass: 152.927718 },\n            { nominal: 154, mass: 153.92948 },\n            { nominal: 155, mass: 154.9331357 },\n            { nominal: 156, mass: 155.93508 },\n            { nominal: 157, mass: 156.939386 },\n            { nominal: 158, mass: 157.94197 },\n            { nominal: 159, mass: 158.94653 },\n            { nominal: 160, mass: 159.9494 },\n            { nominal: 161, mass: 160.95428 },\n        ],\n        symbol: 'Nd',\n        mass: 144.241596031827,\n        name: 'Neodymium',\n        monoisotopicMass: 141.907729,\n    },\n    {\n        number: 61,\n        isotopes: [\n            { nominal: 126, mass: 125.95792 },\n            { nominal: 127, mass: 126.95192 },\n            { nominal: 128, mass: 127.9487 },\n            { nominal: 129, mass: 128.94323 },\n            { nominal: 130, mass: 129.94053 },\n            { nominal: 131, mass: 130.93567 },\n            { nominal: 132, mass: 131.93384 },\n            { nominal: 133, mass: 132.929782 },\n            { nominal: 134, mass: 133.928353 },\n            { nominal: 135, mass: 134.924823 },\n            { nominal: 136, mass: 135.923585 },\n            { nominal: 137, mass: 136.92048 },\n            { nominal: 138, mass: 137.919548 },\n            { nominal: 139, mass: 138.9168 },\n            { nominal: 140, mass: 139.91604 },\n            { nominal: 141, mass: 140.913555 },\n            { nominal: 142, mass: 141.91289 },\n            { nominal: 143, mass: 142.9109383 },\n            { nominal: 144, mass: 143.9125964 },\n            { nominal: 145, mass: 144.9127559 },\n            { nominal: 146, mass: 145.9147024 },\n            { nominal: 147, mass: 146.915145 },\n            { nominal: 148, mass: 147.9174819 },\n            { nominal: 149, mass: 148.9183423 },\n            { nominal: 150, mass: 149.920991 },\n            { nominal: 151, mass: 150.9212175 },\n            { nominal: 152, mass: 151.923506 },\n            { nominal: 153, mass: 152.9241567 },\n            { nominal: 154, mass: 153.926472 },\n            { nominal: 155, mass: 154.928137 },\n            { nominal: 156, mass: 155.9311175 },\n            { nominal: 157, mass: 156.9331214 },\n            { nominal: 158, mass: 157.936565 },\n            { nominal: 159, mass: 158.939287 },\n            { nominal: 160, mass: 159.9431 },\n            { nominal: 161, mass: 160.94607 },\n            { nominal: 162, mass: 161.95022 },\n            { nominal: 163, mass: 162.95357 },\n        ],\n        symbol: 'Pm',\n        mass: null,\n        name: 'Promethium',\n    },\n    {\n        number: 62,\n        isotopes: [\n            { nominal: 128, mass: 127.95842 },\n            { nominal: 129, mass: 128.95476 },\n            { nominal: 130, mass: 129.949 },\n            { nominal: 131, mass: 130.94618 },\n            { nominal: 132, mass: 131.94087 },\n            { nominal: 133, mass: 132.93856 },\n            { nominal: 134, mass: 133.93411 },\n            { nominal: 135, mass: 134.93252 },\n            { nominal: 136, mass: 135.928276 },\n            { nominal: 137, mass: 136.926971 },\n            { nominal: 138, mass: 137.923244 },\n            { nominal: 139, mass: 138.922297 },\n            { nominal: 140, mass: 139.918995 },\n            { nominal: 141, mass: 140.9184816 },\n            { nominal: 142, mass: 141.9152044 },\n            { nominal: 143, mass: 142.9146353 },\n            { nominal: 144, mass: 143.9120065, abundance: 0.0307 },\n            { nominal: 145, mass: 144.9134173 },\n            { nominal: 146, mass: 145.913047 },\n            { nominal: 147, mass: 146.9149044, abundance: 0.1499 },\n            { nominal: 148, mass: 147.9148292, abundance: 0.1124 },\n            { nominal: 149, mass: 148.9171921, abundance: 0.1382 },\n            { nominal: 150, mass: 149.9172829, abundance: 0.0738 },\n            { nominal: 151, mass: 150.9199398 },\n            { nominal: 152, mass: 151.9197397, abundance: 0.2675 },\n            { nominal: 153, mass: 152.9221047 },\n            { nominal: 154, mass: 153.9222169, abundance: 0.2275 },\n            { nominal: 155, mass: 154.9246477 },\n            { nominal: 156, mass: 155.925536 },\n            { nominal: 157, mass: 156.9284187 },\n            { nominal: 158, mass: 157.929951 },\n            { nominal: 159, mass: 158.9332172 },\n            { nominal: 160, mass: 159.9353353 },\n            { nominal: 161, mass: 160.9391602 },\n            { nominal: 162, mass: 161.94146 },\n            { nominal: 163, mass: 162.94555 },\n            { nominal: 164, mass: 163.94836 },\n            { nominal: 165, mass: 164.95297 },\n        ],\n        symbol: 'Sm',\n        mass: 150.36635571193,\n        name: 'Samarium',\n        monoisotopicMass: 151.9197397,\n    },\n    {\n        number: 63,\n        isotopes: [\n            { nominal: 130, mass: 129.96369 },\n            { nominal: 131, mass: 130.95784 },\n            { nominal: 132, mass: 131.95467 },\n            { nominal: 133, mass: 132.94929 },\n            { nominal: 134, mass: 133.9464 },\n            { nominal: 135, mass: 134.94187 },\n            { nominal: 136, mass: 135.93962 },\n            { nominal: 137, mass: 136.93546 },\n            { nominal: 138, mass: 137.933709 },\n            { nominal: 139, mass: 138.929792 },\n            { nominal: 140, mass: 139.928088 },\n            { nominal: 141, mass: 140.924932 },\n            { nominal: 142, mass: 141.923442 },\n            { nominal: 143, mass: 142.920299 },\n            { nominal: 144, mass: 143.91882 },\n            { nominal: 145, mass: 144.9162726 },\n            { nominal: 146, mass: 145.917211 },\n            { nominal: 147, mass: 146.9167527 },\n            { nominal: 148, mass: 147.918089 },\n            { nominal: 149, mass: 148.9179378 },\n            { nominal: 150, mass: 149.9197077 },\n            { nominal: 151, mass: 150.9198578, abundance: 0.4781 },\n            { nominal: 152, mass: 151.9217522 },\n            { nominal: 153, mass: 152.921238, abundance: 0.5219 },\n            { nominal: 154, mass: 153.922987 },\n            { nominal: 155, mass: 154.9229011 },\n            { nominal: 156, mass: 155.9247605 },\n            { nominal: 157, mass: 156.9254334 },\n            { nominal: 158, mass: 157.927799 },\n            { nominal: 159, mass: 158.9291001 },\n            { nominal: 160, mass: 159.931851 },\n            { nominal: 161, mass: 160.933664 },\n            { nominal: 162, mass: 161.936989 },\n            { nominal: 163, mass: 162.939196 },\n            { nominal: 164, mass: 163.94274 },\n            { nominal: 165, mass: 164.94559 },\n            { nominal: 166, mass: 165.94962 },\n            { nominal: 167, mass: 166.95289 },\n        ],\n        symbol: 'Eu',\n        mass: 151.96437812637998,\n        name: 'Europium',\n        monoisotopicMass: 152.921238,\n    },\n    {\n        number: 64,\n        isotopes: [\n            { nominal: 133, mass: 132.96133 },\n            { nominal: 134, mass: 133.95566 },\n            { nominal: 135, mass: 134.95245 },\n            { nominal: 136, mass: 135.9473 },\n            { nominal: 137, mass: 136.94502 },\n            { nominal: 138, mass: 137.94025 },\n            { nominal: 139, mass: 138.93813 },\n            { nominal: 140, mass: 139.933674 },\n            { nominal: 141, mass: 140.932126 },\n            { nominal: 142, mass: 141.928116 },\n            { nominal: 143, mass: 142.92675 },\n            { nominal: 144, mass: 143.922963 },\n            { nominal: 145, mass: 144.921713 },\n            { nominal: 146, mass: 145.9183188 },\n            { nominal: 147, mass: 146.9191014 },\n            { nominal: 148, mass: 147.9181215 },\n            { nominal: 149, mass: 148.9193481 },\n            { nominal: 150, mass: 149.9186644 },\n            { nominal: 151, mass: 150.920356 },\n            { nominal: 152, mass: 151.9197995, abundance: 0.002 },\n            { nominal: 153, mass: 152.921758 },\n            { nominal: 154, mass: 153.9208741, abundance: 0.0218 },\n            { nominal: 155, mass: 154.9226305, abundance: 0.148 },\n            { nominal: 156, mass: 155.9221312, abundance: 0.2047 },\n            { nominal: 157, mass: 156.9239686, abundance: 0.1565 },\n            { nominal: 158, mass: 157.9241123, abundance: 0.2484 },\n            { nominal: 159, mass: 158.926397 },\n            { nominal: 160, mass: 159.9270624, abundance: 0.2186 },\n            { nominal: 161, mass: 160.9296775 },\n            { nominal: 162, mass: 161.930993 },\n            { nominal: 163, mass: 162.9341769 },\n            { nominal: 164, mass: 163.93583 },\n            { nominal: 165, mass: 164.93936 },\n            { nominal: 166, mass: 165.94146 },\n            { nominal: 167, mass: 166.94545 },\n            { nominal: 168, mass: 167.94808 },\n            { nominal: 169, mass: 168.9526 },\n        ],\n        symbol: 'Gd',\n        mass: 157.25213064687998,\n        name: 'Gadolinium',\n        monoisotopicMass: 157.9241123,\n    },\n    {\n        number: 65,\n        isotopes: [\n            { nominal: 135, mass: 134.96476 },\n            { nominal: 136, mass: 135.96129 },\n            { nominal: 137, mass: 136.95602 },\n            { nominal: 138, mass: 137.95312 },\n            { nominal: 139, mass: 138.94833 },\n            { nominal: 140, mass: 139.94581 },\n            { nominal: 141, mass: 140.94145 },\n            { nominal: 142, mass: 141.93928 },\n            { nominal: 143, mass: 142.935137 },\n            { nominal: 144, mass: 143.933045 },\n            { nominal: 145, mass: 144.92882 },\n            { nominal: 146, mass: 145.927253 },\n            { nominal: 147, mass: 146.9240548 },\n            { nominal: 148, mass: 147.924282 },\n            { nominal: 149, mass: 148.9232535 },\n            { nominal: 150, mass: 149.9236649 },\n            { nominal: 151, mass: 150.9231096 },\n            { nominal: 152, mass: 151.924083 },\n            { nominal: 153, mass: 152.9234424 },\n            { nominal: 154, mass: 153.924685 },\n            { nominal: 155, mass: 154.923511 },\n            { nominal: 156, mass: 155.9247552 },\n            { nominal: 157, mass: 156.924033 },\n            { nominal: 158, mass: 157.9254209 },\n            { nominal: 159, mass: 158.9253547, abundance: 1 },\n            { nominal: 160, mass: 159.9271756 },\n            { nominal: 161, mass: 160.9275778 },\n            { nominal: 162, mass: 161.929495 },\n            { nominal: 163, mass: 162.9306547 },\n            { nominal: 164, mass: 163.93336 },\n            { nominal: 165, mass: 164.93498 },\n            { nominal: 166, mass: 165.93786 },\n            { nominal: 167, mass: 166.93996 },\n            { nominal: 168, mass: 167.9434 },\n            { nominal: 169, mass: 168.94597 },\n            { nominal: 170, mass: 169.94984 },\n            { nominal: 171, mass: 170.95273 },\n        ],\n        symbol: 'Tb',\n        mass: 158.9253547,\n        name: 'Terbium',\n        monoisotopicMass: 158.9253547,\n    },\n    {\n        number: 66,\n        isotopes: [\n            { nominal: 138, mass: 137.9625 },\n            { nominal: 139, mass: 138.95959 },\n            { nominal: 140, mass: 139.95402 },\n            { nominal: 141, mass: 140.95128 },\n            { nominal: 142, mass: 141.94619 },\n            { nominal: 143, mass: 142.943994 },\n            { nominal: 144, mass: 143.9392695 },\n            { nominal: 145, mass: 144.937474 },\n            { nominal: 146, mass: 145.9328445 },\n            { nominal: 147, mass: 146.9310827 },\n            { nominal: 148, mass: 147.927157 },\n            { nominal: 149, mass: 148.927322 },\n            { nominal: 150, mass: 149.9255933 },\n            { nominal: 151, mass: 150.9261916 },\n            { nominal: 152, mass: 151.9247253 },\n            { nominal: 153, mass: 152.9257724 },\n            { nominal: 154, mass: 153.9244293 },\n            { nominal: 155, mass: 154.925759 },\n            { nominal: 156, mass: 155.9242847, abundance: 0.00056 },\n            { nominal: 157, mass: 156.9254707 },\n            { nominal: 158, mass: 157.9244159, abundance: 0.00095 },\n            { nominal: 159, mass: 158.925747 },\n            { nominal: 160, mass: 159.9252046, abundance: 0.02329 },\n            { nominal: 161, mass: 160.9269405, abundance: 0.18889 },\n            { nominal: 162, mass: 161.9268056, abundance: 0.25475 },\n            { nominal: 163, mass: 162.9287383, abundance: 0.24896 },\n            { nominal: 164, mass: 163.9291819, abundance: 0.2826 },\n            { nominal: 165, mass: 164.9317105 },\n            { nominal: 166, mass: 165.9328139 },\n            { nominal: 167, mass: 166.935661 },\n            { nominal: 168, mass: 167.93713 },\n            { nominal: 169, mass: 168.94031 },\n            { nominal: 170, mass: 169.94239 },\n            { nominal: 171, mass: 170.94612 },\n            { nominal: 172, mass: 171.94846 },\n            { nominal: 173, mass: 172.95283 },\n        ],\n        symbol: 'Dy',\n        mass: 162.499472819424,\n        name: 'Dysprosium',\n        monoisotopicMass: 163.9291819,\n    },\n    {\n        number: 67,\n        isotopes: [\n            { nominal: 140, mass: 139.96859 },\n            { nominal: 141, mass: 140.96311 },\n            { nominal: 142, mass: 141.96001 },\n            { nominal: 143, mass: 142.95486 },\n            { nominal: 144, mass: 143.9521097 },\n            { nominal: 145, mass: 144.9472674 },\n            { nominal: 146, mass: 145.9449935 },\n            { nominal: 147, mass: 146.9401423 },\n            { nominal: 148, mass: 147.937744 },\n            { nominal: 149, mass: 148.933803 },\n            { nominal: 150, mass: 149.933498 },\n            { nominal: 151, mass: 150.9316983 },\n            { nominal: 152, mass: 151.931724 },\n            { nominal: 153, mass: 152.9302064 },\n            { nominal: 154, mass: 153.9306068 },\n            { nominal: 155, mass: 154.929104 },\n            { nominal: 156, mass: 155.929706 },\n            { nominal: 157, mass: 156.928254 },\n            { nominal: 158, mass: 157.928946 },\n            { nominal: 159, mass: 158.9277197 },\n            { nominal: 160, mass: 159.928737 },\n            { nominal: 161, mass: 160.9278615 },\n            { nominal: 162, mass: 161.9291023 },\n            { nominal: 163, mass: 162.928741 },\n            { nominal: 164, mass: 163.9302403 },\n            { nominal: 165, mass: 164.9303288, abundance: 1 },\n            { nominal: 166, mass: 165.9322909 },\n            { nominal: 167, mass: 166.9331385 },\n            { nominal: 168, mass: 167.935522 },\n            { nominal: 169, mass: 168.936878 },\n            { nominal: 170, mass: 169.939625 },\n            { nominal: 171, mass: 170.94147 },\n            { nominal: 172, mass: 171.94473 },\n            { nominal: 173, mass: 172.94702 },\n            { nominal: 174, mass: 173.95095 },\n            { nominal: 175, mass: 174.95362 },\n        ],\n        symbol: 'Ho',\n        mass: 164.9303288,\n        name: 'Holmium',\n        monoisotopicMass: 164.9303288,\n    },\n    {\n        number: 68,\n        isotopes: [\n            { nominal: 142, mass: 141.9701 },\n            { nominal: 143, mass: 142.96662 },\n            { nominal: 144, mass: 143.9607 },\n            { nominal: 145, mass: 144.95805 },\n            { nominal: 146, mass: 145.9524184 },\n            { nominal: 147, mass: 146.949964 },\n            { nominal: 148, mass: 147.944735 },\n            { nominal: 149, mass: 148.942306 },\n            { nominal: 150, mass: 149.937916 },\n            { nominal: 151, mass: 150.937449 },\n            { nominal: 152, mass: 151.935057 },\n            { nominal: 153, mass: 152.93508 },\n            { nominal: 154, mass: 153.9327908 },\n            { nominal: 155, mass: 154.9332159 },\n            { nominal: 156, mass: 155.931067 },\n            { nominal: 157, mass: 156.931949 },\n            { nominal: 158, mass: 157.929893 },\n            { nominal: 159, mass: 158.9306918 },\n            { nominal: 160, mass: 159.929077 },\n            { nominal: 161, mass: 160.9300046 },\n            { nominal: 162, mass: 161.9287884, abundance: 0.00139 },\n            { nominal: 163, mass: 162.9300408 },\n            { nominal: 164, mass: 163.9292088, abundance: 0.01601 },\n            { nominal: 165, mass: 164.9307345 },\n            { nominal: 166, mass: 165.9302995, abundance: 0.33503 },\n            { nominal: 167, mass: 166.9320546, abundance: 0.22869 },\n            { nominal: 168, mass: 167.9323767, abundance: 0.26978 },\n            { nominal: 169, mass: 168.9345968 },\n            { nominal: 170, mass: 169.9354702, abundance: 0.1491 },\n            { nominal: 171, mass: 170.9380357 },\n            { nominal: 172, mass: 171.9393619 },\n            { nominal: 173, mass: 172.9424 },\n            { nominal: 174, mass: 173.94423 },\n            { nominal: 175, mass: 174.94777 },\n            { nominal: 176, mass: 175.94994 },\n            { nominal: 177, mass: 176.95399 },\n        ],\n        symbol: 'Er',\n        mass: 167.259082649669,\n        name: 'Erbium',\n        monoisotopicMass: 165.9302995,\n    },\n    {\n        number: 69,\n        isotopes: [\n            { nominal: 144, mass: 143.97628 },\n            { nominal: 145, mass: 144.97039 },\n            { nominal: 146, mass: 145.96684 },\n            { nominal: 147, mass: 146.9613799 },\n            { nominal: 148, mass: 147.958384 },\n            { nominal: 149, mass: 148.95289 },\n            { nominal: 150, mass: 149.95009 },\n            { nominal: 151, mass: 150.945488 },\n            { nominal: 152, mass: 151.944422 },\n            { nominal: 153, mass: 152.94204 },\n            { nominal: 154, mass: 153.94157 },\n            { nominal: 155, mass: 154.93921 },\n            { nominal: 156, mass: 155.938992 },\n            { nominal: 157, mass: 156.936944 },\n            { nominal: 158, mass: 157.93698 },\n            { nominal: 159, mass: 158.934975 },\n            { nominal: 160, mass: 159.935263 },\n            { nominal: 161, mass: 160.933549 },\n            { nominal: 162, mass: 161.934002 },\n            { nominal: 163, mass: 162.9326592 },\n            { nominal: 164, mass: 163.933544 },\n            { nominal: 165, mass: 164.9324431 },\n            { nominal: 166, mass: 165.933561 },\n            { nominal: 167, mass: 166.9328562 },\n            { nominal: 168, mass: 167.9341774 },\n            { nominal: 169, mass: 168.9342179, abundance: 1 },\n            { nominal: 170, mass: 169.935806 },\n            { nominal: 171, mass: 170.9364339 },\n            { nominal: 172, mass: 171.9384055 },\n            { nominal: 173, mass: 172.9396084 },\n            { nominal: 174, mass: 173.942173 },\n            { nominal: 175, mass: 174.943841 },\n            { nominal: 176, mass: 175.947 },\n            { nominal: 177, mass: 176.94904 },\n            { nominal: 178, mass: 177.95264 },\n            { nominal: 179, mass: 178.95534 },\n        ],\n        symbol: 'Tm',\n        mass: 168.9342179,\n        name: 'Thulium',\n        monoisotopicMass: 168.9342179,\n    },\n    {\n        number: 70,\n        isotopes: [\n            { nominal: 148, mass: 147.96758 },\n            { nominal: 149, mass: 148.96436 },\n            { nominal: 150, mass: 149.95852 },\n            { nominal: 151, mass: 150.9554 },\n            { nominal: 152, mass: 151.95027 },\n            { nominal: 153, mass: 152.94932 },\n            { nominal: 154, mass: 153.946396 },\n            { nominal: 155, mass: 154.945783 },\n            { nominal: 156, mass: 155.942825 },\n            { nominal: 157, mass: 156.942645 },\n            { nominal: 158, mass: 157.9398705 },\n            { nominal: 159, mass: 158.940055 },\n            { nominal: 160, mass: 159.937557 },\n            { nominal: 161, mass: 160.937907 },\n            { nominal: 162, mass: 161.935774 },\n            { nominal: 163, mass: 162.93634 },\n            { nominal: 164, mass: 163.934495 },\n            { nominal: 165, mass: 164.93527 },\n            { nominal: 166, mass: 165.9338747 },\n            { nominal: 167, mass: 166.934953 },\n            { nominal: 168, mass: 167.9338896, abundance: 0.00123 },\n            { nominal: 169, mass: 168.9351825 },\n            { nominal: 170, mass: 169.9347664, abundance: 0.02982 },\n            { nominal: 171, mass: 170.9363302, abundance: 0.1409 },\n            { nominal: 172, mass: 171.9363859, abundance: 0.2168 },\n            { nominal: 173, mass: 172.9382151, abundance: 0.16103 },\n            { nominal: 174, mass: 173.9388664, abundance: 0.32026 },\n            { nominal: 175, mass: 174.9412808 },\n            { nominal: 176, mass: 175.9425764, abundance: 0.12996 },\n            { nominal: 177, mass: 176.9452656 },\n            { nominal: 178, mass: 177.946651 },\n            { nominal: 179, mass: 178.95004 },\n            { nominal: 180, mass: 179.95212 },\n            { nominal: 181, mass: 180.95589 },\n        ],\n        symbol: 'Yb',\n        mass: 173.05415016631702,\n        name: 'Ytterbium',\n        monoisotopicMass: 173.9388664,\n    },\n    {\n        number: 71,\n        isotopes: [\n            { nominal: 150, mass: 149.97355 },\n            { nominal: 151, mass: 150.96768 },\n            { nominal: 152, mass: 151.96412 },\n            { nominal: 153, mass: 152.95875 },\n            { nominal: 154, mass: 153.95736 },\n            { nominal: 155, mass: 154.954321 },\n            { nominal: 156, mass: 155.953033 },\n            { nominal: 157, mass: 156.950127 },\n            { nominal: 158, mass: 157.949316 },\n            { nominal: 159, mass: 158.946636 },\n            { nominal: 160, mass: 159.946033 },\n            { nominal: 161, mass: 160.943572 },\n            { nominal: 162, mass: 161.943283 },\n            { nominal: 163, mass: 162.941179 },\n            { nominal: 164, mass: 163.941339 },\n            { nominal: 165, mass: 164.939407 },\n            { nominal: 166, mass: 165.939859 },\n            { nominal: 167, mass: 166.93827 },\n            { nominal: 168, mass: 167.938736 },\n            { nominal: 169, mass: 168.9376441 },\n            { nominal: 170, mass: 169.938478 },\n            { nominal: 171, mass: 170.937917 },\n            { nominal: 172, mass: 171.9390891 },\n            { nominal: 173, mass: 172.938934 },\n            { nominal: 174, mass: 173.9403409 },\n            { nominal: 175, mass: 174.9407752, abundance: 0.97401 },\n            { nominal: 176, mass: 175.9426897, abundance: 0.02599 },\n            { nominal: 177, mass: 176.9437615 },\n            { nominal: 178, mass: 177.945958 },\n            { nominal: 179, mass: 178.9473309 },\n            { nominal: 180, mass: 179.949888 },\n            { nominal: 181, mass: 180.95191 },\n            { nominal: 182, mass: 181.95504 },\n            { nominal: 183, mass: 182.957363 },\n            { nominal: 184, mass: 183.96091 },\n            { nominal: 185, mass: 184.96362 },\n        ],\n        symbol: 'Lu',\n        mass: 174.96681495785498,\n        name: 'Lutetium',\n        monoisotopicMass: 174.9407752,\n    },\n    {\n        number: 72,\n        isotopes: [\n            { nominal: 153, mass: 152.97069 },\n            { nominal: 154, mass: 153.96486 },\n            { nominal: 155, mass: 154.96311 },\n            { nominal: 156, mass: 155.95935 },\n            { nominal: 157, mass: 156.95824 },\n            { nominal: 158, mass: 157.954801 },\n            { nominal: 159, mass: 158.953996 },\n            { nominal: 160, mass: 159.950691 },\n            { nominal: 161, mass: 160.950278 },\n            { nominal: 162, mass: 161.9472148 },\n            { nominal: 163, mass: 162.947113 },\n            { nominal: 164, mass: 163.944371 },\n            { nominal: 165, mass: 164.944567 },\n            { nominal: 166, mass: 165.94218 },\n            { nominal: 167, mass: 166.9426 },\n            { nominal: 168, mass: 167.940568 },\n            { nominal: 169, mass: 168.941259 },\n            { nominal: 170, mass: 169.939609 },\n            { nominal: 171, mass: 170.940492 },\n            { nominal: 172, mass: 171.93945 },\n            { nominal: 173, mass: 172.940513 },\n            { nominal: 174, mass: 173.9400461, abundance: 0.0016 },\n            { nominal: 175, mass: 174.9415092 },\n            { nominal: 176, mass: 175.9414076, abundance: 0.0526 },\n            { nominal: 177, mass: 176.9432277, abundance: 0.186 },\n            { nominal: 178, mass: 177.9437058, abundance: 0.2728 },\n            { nominal: 179, mass: 178.9458232, abundance: 0.1362 },\n            { nominal: 180, mass: 179.946557, abundance: 0.3508 },\n            { nominal: 181, mass: 180.9491083 },\n            { nominal: 182, mass: 181.9505612 },\n            { nominal: 183, mass: 182.95353 },\n            { nominal: 184, mass: 183.955446 },\n            { nominal: 185, mass: 184.958862 },\n            { nominal: 186, mass: 185.960897 },\n            { nominal: 187, mass: 186.96477 },\n            { nominal: 188, mass: 187.96685 },\n            { nominal: 189, mass: 188.97084 },\n        ],\n        symbol: 'Hf',\n        mass: 178.4849787234,\n        name: 'Hafnium',\n        monoisotopicMass: 179.946557,\n    },\n    {\n        number: 73,\n        isotopes: [\n            { nominal: 155, mass: 154.97424 },\n            { nominal: 156, mass: 155.97203 },\n            { nominal: 157, mass: 156.96818 },\n            { nominal: 158, mass: 157.96654 },\n            { nominal: 159, mass: 158.963023 },\n            { nominal: 160, mass: 159.961488 },\n            { nominal: 161, mass: 160.958452 },\n            { nominal: 162, mass: 161.957294 },\n            { nominal: 163, mass: 162.954337 },\n            { nominal: 164, mass: 163.953534 },\n            { nominal: 165, mass: 164.950781 },\n            { nominal: 166, mass: 165.950512 },\n            { nominal: 167, mass: 166.948093 },\n            { nominal: 168, mass: 167.948047 },\n            { nominal: 169, mass: 168.946011 },\n            { nominal: 170, mass: 169.946175 },\n            { nominal: 171, mass: 170.944476 },\n            { nominal: 172, mass: 171.944895 },\n            { nominal: 173, mass: 172.94375 },\n            { nominal: 174, mass: 173.944454 },\n            { nominal: 175, mass: 174.943737 },\n            { nominal: 176, mass: 175.944857 },\n            { nominal: 177, mass: 176.9444795 },\n            { nominal: 178, mass: 177.945678 },\n            { nominal: 179, mass: 178.9459366 },\n            { nominal: 180, mass: 179.9474648, abundance: 0.0001201 },\n            { nominal: 181, mass: 180.9479958, abundance: 0.9998799 },\n            { nominal: 182, mass: 181.9501519 },\n            { nominal: 183, mass: 182.9513726 },\n            { nominal: 184, mass: 183.954008 },\n            { nominal: 185, mass: 184.955559 },\n            { nominal: 186, mass: 185.958551 },\n            { nominal: 187, mass: 186.960386 },\n            { nominal: 188, mass: 187.963916 },\n            { nominal: 189, mass: 188.96583 },\n            { nominal: 190, mass: 189.96939 },\n            { nominal: 191, mass: 190.97156 },\n            { nominal: 192, mass: 191.97514 },\n        ],\n        symbol: 'Ta',\n        mass: 180.9478756362269,\n        name: 'Tantalum',\n        monoisotopicMass: 180.9479958,\n    },\n    {\n        number: 74,\n        isotopes: [\n            { nominal: 157, mass: 156.97884 },\n            { nominal: 158, mass: 157.97456 },\n            { nominal: 159, mass: 158.97264 },\n            { nominal: 160, mass: 159.96846 },\n            { nominal: 161, mass: 160.9672 },\n            { nominal: 162, mass: 161.963499 },\n            { nominal: 163, mass: 162.962524 },\n            { nominal: 164, mass: 163.958961 },\n            { nominal: 165, mass: 164.958281 },\n            { nominal: 166, mass: 165.955031 },\n            { nominal: 167, mass: 166.954805 },\n            { nominal: 168, mass: 167.951806 },\n            { nominal: 169, mass: 168.951779 },\n            { nominal: 170, mass: 169.949232 },\n            { nominal: 171, mass: 170.949451 },\n            { nominal: 172, mass: 171.947292 },\n            { nominal: 173, mass: 172.947689 },\n            { nominal: 174, mass: 173.946079 },\n            { nominal: 175, mass: 174.946717 },\n            { nominal: 176, mass: 175.945634 },\n            { nominal: 177, mass: 176.946643 },\n            { nominal: 178, mass: 177.945883 },\n            { nominal: 179, mass: 178.947077 },\n            { nominal: 180, mass: 179.9467108, abundance: 0.0012 },\n            { nominal: 181, mass: 180.9481978 },\n            { nominal: 182, mass: 181.94820394, abundance: 0.265 },\n            { nominal: 183, mass: 182.95022275, abundance: 0.1431 },\n            { nominal: 184, mass: 183.95093092, abundance: 0.3064 },\n            { nominal: 185, mass: 184.95341897 },\n            { nominal: 186, mass: 185.9543628, abundance: 0.2843 },\n            { nominal: 187, mass: 186.9571588 },\n            { nominal: 188, mass: 187.9584862 },\n            { nominal: 189, mass: 188.961763 },\n            { nominal: 190, mass: 189.963091 },\n            { nominal: 191, mass: 190.966531 },\n            { nominal: 192, mass: 191.96817 },\n            { nominal: 193, mass: 192.97178 },\n            { nominal: 194, mass: 193.97367 },\n        ],\n        symbol: 'W',\n        mass: 183.841777550513,\n        name: 'Tungsten',\n        monoisotopicMass: 183.95093092,\n    },\n    {\n        number: 75,\n        isotopes: [\n            { nominal: 159, mass: 158.98418 },\n            { nominal: 160, mass: 159.98182 },\n            { nominal: 161, mass: 160.97757 },\n            { nominal: 162, mass: 161.97584 },\n            { nominal: 163, mass: 162.97208 },\n            { nominal: 164, mass: 163.970453 },\n            { nominal: 165, mass: 164.967103 },\n            { nominal: 166, mass: 165.965761 },\n            { nominal: 167, mass: 166.962595 },\n            { nominal: 168, mass: 167.961573 },\n            { nominal: 169, mass: 168.958766 },\n            { nominal: 170, mass: 169.95822 },\n            { nominal: 171, mass: 170.955716 },\n            { nominal: 172, mass: 171.95542 },\n            { nominal: 173, mass: 172.953243 },\n            { nominal: 174, mass: 173.953115 },\n            { nominal: 175, mass: 174.951381 },\n            { nominal: 176, mass: 175.951623 },\n            { nominal: 177, mass: 176.950328 },\n            { nominal: 178, mass: 177.950989 },\n            { nominal: 179, mass: 178.949989 },\n            { nominal: 180, mass: 179.950792 },\n            { nominal: 181, mass: 180.950058 },\n            { nominal: 182, mass: 181.95121 },\n            { nominal: 183, mass: 182.9508196 },\n            { nominal: 184, mass: 183.9525228 },\n            { nominal: 185, mass: 184.9529545, abundance: 0.374 },\n            { nominal: 186, mass: 185.9549856 },\n            { nominal: 187, mass: 186.9557501, abundance: 0.626 },\n            { nominal: 188, mass: 187.9581115 },\n            { nominal: 189, mass: 188.959226 },\n            { nominal: 190, mass: 189.961744 },\n            { nominal: 191, mass: 190.963122 },\n            { nominal: 192, mass: 191.966088 },\n            { nominal: 193, mass: 192.967541 },\n            { nominal: 194, mass: 193.97076 },\n            { nominal: 195, mass: 194.97254 },\n            { nominal: 196, mass: 195.9758 },\n            { nominal: 197, mass: 196.97799 },\n            { nominal: 198, mass: 197.9816 },\n        ],\n        symbol: 'Re',\n        mass: 186.20670454560002,\n        name: 'Rhenium',\n        monoisotopicMass: 186.9557501,\n    },\n    {\n        number: 76,\n        isotopes: [\n            { nominal: 161, mass: 160.98903 },\n            { nominal: 162, mass: 161.98443 },\n            { nominal: 163, mass: 162.98241 },\n            { nominal: 164, mass: 163.97802 },\n            { nominal: 165, mass: 164.9766 },\n            { nominal: 166, mass: 165.972692 },\n            { nominal: 167, mass: 166.971549 },\n            { nominal: 168, mass: 167.967808 },\n            { nominal: 169, mass: 168.967018 },\n            { nominal: 170, mass: 169.963578 },\n            { nominal: 171, mass: 170.963174 },\n            { nominal: 172, mass: 171.960017 },\n            { nominal: 173, mass: 172.959808 },\n            { nominal: 174, mass: 173.957064 },\n            { nominal: 175, mass: 174.956945 },\n            { nominal: 176, mass: 175.954806 },\n            { nominal: 177, mass: 176.954966 },\n            { nominal: 178, mass: 177.953254 },\n            { nominal: 179, mass: 178.953817 },\n            { nominal: 180, mass: 179.952375 },\n            { nominal: 181, mass: 180.953247 },\n            { nominal: 182, mass: 181.95211 },\n            { nominal: 183, mass: 182.953125 },\n            { nominal: 184, mass: 183.9524885, abundance: 0.0002 },\n            { nominal: 185, mass: 184.9540417 },\n            { nominal: 186, mass: 185.953835, abundance: 0.0159 },\n            { nominal: 187, mass: 186.9557474, abundance: 0.0196 },\n            { nominal: 188, mass: 187.9558352, abundance: 0.1324 },\n            { nominal: 189, mass: 188.9581442, abundance: 0.1615 },\n            { nominal: 190, mass: 189.9584437, abundance: 0.2626 },\n            { nominal: 191, mass: 190.9609264 },\n            { nominal: 192, mass: 191.961477, abundance: 0.4078 },\n            { nominal: 193, mass: 192.9641479 },\n            { nominal: 194, mass: 193.9651772 },\n            { nominal: 195, mass: 194.968318 },\n            { nominal: 196, mass: 195.969641 },\n            { nominal: 197, mass: 196.97283 },\n            { nominal: 198, mass: 197.97441 },\n            { nominal: 199, mass: 198.97801 },\n            { nominal: 200, mass: 199.97984 },\n            { nominal: 201, mass: 200.98364 },\n            { nominal: 202, mass: 201.98595 },\n        ],\n        symbol: 'Os',\n        mass: 190.22485962823998,\n        name: 'Osmium',\n        monoisotopicMass: 191.961477,\n    },\n    {\n        number: 77,\n        isotopes: [\n            { nominal: 164, mass: 163.99191 },\n            { nominal: 165, mass: 164.9875 },\n            { nominal: 166, mass: 165.98566 },\n            { nominal: 167, mass: 166.981666 },\n            { nominal: 168, mass: 167.979907 },\n            { nominal: 169, mass: 168.976298 },\n            { nominal: 170, mass: 169.974922 },\n            { nominal: 171, mass: 170.97164 },\n            { nominal: 172, mass: 171.970607 },\n            { nominal: 173, mass: 172.967506 },\n            { nominal: 174, mass: 173.966861 },\n            { nominal: 175, mass: 174.96415 },\n            { nominal: 176, mass: 175.96365 },\n            { nominal: 177, mass: 176.961301 },\n            { nominal: 178, mass: 177.961082 },\n            { nominal: 179, mass: 178.95912 },\n            { nominal: 180, mass: 179.959229 },\n            { nominal: 181, mass: 180.957625 },\n            { nominal: 182, mass: 181.958076 },\n            { nominal: 183, mass: 182.95684 },\n            { nominal: 184, mass: 183.957476 },\n            { nominal: 185, mass: 184.956698 },\n            { nominal: 186, mass: 185.957944 },\n            { nominal: 187, mass: 186.957542 },\n            { nominal: 188, mass: 187.958828 },\n            { nominal: 189, mass: 188.958715 },\n            { nominal: 190, mass: 189.9605412 },\n            { nominal: 191, mass: 190.9605893, abundance: 0.373 },\n            { nominal: 192, mass: 191.9626002 },\n            { nominal: 193, mass: 192.9629216, abundance: 0.627 },\n            { nominal: 194, mass: 193.9650735 },\n            { nominal: 195, mass: 194.9659747 },\n            { nominal: 196, mass: 195.968397 },\n            { nominal: 197, mass: 196.969655 },\n            { nominal: 198, mass: 197.97228 },\n            { nominal: 199, mass: 198.973805 },\n            { nominal: 200, mass: 199.9768 },\n            { nominal: 201, mass: 200.97864 },\n            { nominal: 202, mass: 201.98199 },\n            { nominal: 203, mass: 202.98423 },\n            { nominal: 204, mass: 203.9896 },\n        ],\n        symbol: 'Ir',\n        mass: 192.2160516521,\n        name: 'Iridium',\n        monoisotopicMass: 192.9629216,\n    },\n    {\n        number: 78,\n        isotopes: [\n            { nominal: 166, mass: 165.99486 },\n            { nominal: 167, mass: 166.99269 },\n            { nominal: 168, mass: 167.98813 },\n            { nominal: 169, mass: 168.98657 },\n            { nominal: 170, mass: 169.982496 },\n            { nominal: 171, mass: 170.981245 },\n            { nominal: 172, mass: 171.977351 },\n            { nominal: 173, mass: 172.976443 },\n            { nominal: 174, mass: 173.97282 },\n            { nominal: 175, mass: 174.97241 },\n            { nominal: 176, mass: 175.968938 },\n            { nominal: 177, mass: 176.96847 },\n            { nominal: 178, mass: 177.96565 },\n            { nominal: 179, mass: 178.965359 },\n            { nominal: 180, mass: 179.963032 },\n            { nominal: 181, mass: 180.963098 },\n            { nominal: 182, mass: 181.961172 },\n            { nominal: 183, mass: 182.961597 },\n            { nominal: 184, mass: 183.959915 },\n            { nominal: 185, mass: 184.960614 },\n            { nominal: 186, mass: 185.959351 },\n            { nominal: 187, mass: 186.960617 },\n            { nominal: 188, mass: 187.9593889 },\n            { nominal: 189, mass: 188.960831 },\n            { nominal: 190, mass: 189.9599297, abundance: 0.00012 },\n            { nominal: 191, mass: 190.9616729 },\n            { nominal: 192, mass: 191.9610387, abundance: 0.00782 },\n            { nominal: 193, mass: 192.9629824 },\n            { nominal: 194, mass: 193.9626809, abundance: 0.3286 },\n            { nominal: 195, mass: 194.9647917, abundance: 0.3378 },\n            { nominal: 196, mass: 195.96495209, abundance: 0.2521 },\n            { nominal: 197, mass: 196.96734069 },\n            { nominal: 198, mass: 197.9678949, abundance: 0.07356 },\n            { nominal: 199, mass: 198.9705952 },\n            { nominal: 200, mass: 199.971443 },\n            { nominal: 201, mass: 200.974513 },\n            { nominal: 202, mass: 201.975639 },\n            { nominal: 203, mass: 202.97893 },\n            { nominal: 204, mass: 203.98076 },\n            { nominal: 205, mass: 204.98608 },\n            { nominal: 206, mass: 205.98966 },\n        ],\n        symbol: 'Pt',\n        mass: 195.084456864931,\n        name: 'Platinum',\n        monoisotopicMass: 194.9647917,\n    },\n    {\n        number: 79,\n        isotopes: [\n            { nominal: 169, mass: 168.99808 },\n            { nominal: 170, mass: 169.99597 },\n            { nominal: 171, mass: 170.991876 },\n            { nominal: 172, mass: 171.989942 },\n            { nominal: 173, mass: 172.986241 },\n            { nominal: 174, mass: 173.984717 },\n            { nominal: 175, mass: 174.981304 },\n            { nominal: 176, mass: 175.98025 },\n            { nominal: 177, mass: 176.97687 },\n            { nominal: 178, mass: 177.976032 },\n            { nominal: 179, mass: 178.973174 },\n            { nominal: 180, mass: 179.972523 },\n            { nominal: 181, mass: 180.970079 },\n            { nominal: 182, mass: 181.969618 },\n            { nominal: 183, mass: 182.967591 },\n            { nominal: 184, mass: 183.967452 },\n            { nominal: 185, mass: 184.96579 },\n            { nominal: 186, mass: 185.965953 },\n            { nominal: 187, mass: 186.964543 },\n            { nominal: 188, mass: 187.965349 },\n            { nominal: 189, mass: 188.963948 },\n            { nominal: 190, mass: 189.964698 },\n            { nominal: 191, mass: 190.963702 },\n            { nominal: 192, mass: 191.964814 },\n            { nominal: 193, mass: 192.9641373 },\n            { nominal: 194, mass: 193.9654178 },\n            { nominal: 195, mass: 194.9650352 },\n            { nominal: 196, mass: 195.9665699 },\n            { nominal: 197, mass: 196.96656879, abundance: 1 },\n            { nominal: 198, mass: 197.96824242 },\n            { nominal: 199, mass: 198.96876528 },\n            { nominal: 200, mass: 199.970756 },\n            { nominal: 201, mass: 200.9716575 },\n            { nominal: 202, mass: 201.973856 },\n            { nominal: 203, mass: 202.9751544 },\n            { nominal: 204, mass: 203.97783 },\n            { nominal: 205, mass: 204.97985 },\n            { nominal: 206, mass: 205.98474 },\n            { nominal: 207, mass: 206.9884 },\n            { nominal: 208, mass: 207.99345 },\n            { nominal: 209, mass: 208.99735 },\n            { nominal: 210, mass: 210.0025 },\n        ],\n        symbol: 'Au',\n        mass: 196.96656879,\n        name: 'Gold',\n        monoisotopicMass: 196.96656879,\n    },\n    {\n        number: 80,\n        isotopes: [\n            { nominal: 171, mass: 171.00353 },\n            { nominal: 172, mass: 171.99881 },\n            { nominal: 173, mass: 172.99709 },\n            { nominal: 174, mass: 173.992865 },\n            { nominal: 175, mass: 174.991441 },\n            { nominal: 176, mass: 175.987361 },\n            { nominal: 177, mass: 176.986277 },\n            { nominal: 178, mass: 177.982484 },\n            { nominal: 179, mass: 178.981831 },\n            { nominal: 180, mass: 179.97826 },\n            { nominal: 181, mass: 180.977819 },\n            { nominal: 182, mass: 181.974689 },\n            { nominal: 183, mass: 182.9744448 },\n            { nominal: 184, mass: 183.971714 },\n            { nominal: 185, mass: 184.971899 },\n            { nominal: 186, mass: 185.969362 },\n            { nominal: 187, mass: 186.969814 },\n            { nominal: 188, mass: 187.967567 },\n            { nominal: 189, mass: 188.968195 },\n            { nominal: 190, mass: 189.966323 },\n            { nominal: 191, mass: 190.967157 },\n            { nominal: 192, mass: 191.965635 },\n            { nominal: 193, mass: 192.966653 },\n            { nominal: 194, mass: 193.9654491 },\n            { nominal: 195, mass: 194.966721 },\n            { nominal: 196, mass: 195.9658326, abundance: 0.0015 },\n            { nominal: 197, mass: 196.9672128 },\n            { nominal: 198, mass: 197.9667686, abundance: 0.0997 },\n            { nominal: 199, mass: 198.96828064, abundance: 0.1687 },\n            { nominal: 200, mass: 199.96832659, abundance: 0.231 },\n            { nominal: 201, mass: 200.97030284, abundance: 0.1318 },\n            { nominal: 202, mass: 201.9706434, abundance: 0.2986 },\n            { nominal: 203, mass: 202.9728728 },\n            { nominal: 204, mass: 203.97349398, abundance: 0.0687 },\n            { nominal: 205, mass: 204.9760734 },\n            { nominal: 206, mass: 205.977514 },\n            { nominal: 207, mass: 206.9823 },\n            { nominal: 208, mass: 207.985759 },\n            { nominal: 209, mass: 208.99072 },\n            { nominal: 210, mass: 209.99424 },\n            { nominal: 211, mass: 210.99933 },\n            { nominal: 212, mass: 212.00296 },\n            { nominal: 213, mass: 213.00823 },\n            { nominal: 214, mass: 214.012 },\n            { nominal: 215, mass: 215.0174 },\n            { nominal: 216, mass: 216.02132 },\n        ],\n        symbol: 'Hg',\n        mass: 200.59916703455602,\n        name: 'Mercury',\n        monoisotopicMass: 201.9706434,\n    },\n    {\n        number: 81,\n        isotopes: [\n            { nominal: 176, mass: 176.000624 },\n            { nominal: 177, mass: 176.996431 },\n            { nominal: 178, mass: 177.99485 },\n            { nominal: 179, mass: 178.991111 },\n            { nominal: 180, mass: 179.990057 },\n            { nominal: 181, mass: 180.98626 },\n            { nominal: 182, mass: 181.985713 },\n            { nominal: 183, mass: 182.982193 },\n            { nominal: 184, mass: 183.981886 },\n            { nominal: 185, mass: 184.978789 },\n            { nominal: 186, mass: 185.978651 },\n            { nominal: 187, mass: 186.9759063 },\n            { nominal: 188, mass: 187.976021 },\n            { nominal: 189, mass: 188.973588 },\n            { nominal: 190, mass: 189.973828 },\n            { nominal: 191, mass: 190.9717842 },\n            { nominal: 192, mass: 191.972225 },\n            { nominal: 193, mass: 192.970502 },\n            { nominal: 194, mass: 193.971081 },\n            { nominal: 195, mass: 194.969774 },\n            { nominal: 196, mass: 195.970481 },\n            { nominal: 197, mass: 196.969576 },\n            { nominal: 198, mass: 197.970483 },\n            { nominal: 199, mass: 198.969877 },\n            { nominal: 200, mass: 199.9709633 },\n            { nominal: 201, mass: 200.970822 },\n            { nominal: 202, mass: 201.972102 },\n            { nominal: 203, mass: 202.9723446, abundance: 0.2952 },\n            { nominal: 204, mass: 203.9738639 },\n            { nominal: 205, mass: 204.9744278, abundance: 0.7048 },\n            { nominal: 206, mass: 205.9761106 },\n            { nominal: 207, mass: 206.9774197 },\n            { nominal: 208, mass: 207.982019 },\n            { nominal: 209, mass: 208.9853594 },\n            { nominal: 210, mass: 209.990074 },\n            { nominal: 211, mass: 210.993475 },\n            { nominal: 212, mass: 211.99834 },\n            { nominal: 213, mass: 213.001915 },\n            { nominal: 214, mass: 214.00694 },\n            { nominal: 215, mass: 215.01064 },\n            { nominal: 216, mass: 216.0158 },\n            { nominal: 217, mass: 217.01966 },\n            { nominal: 218, mass: 218.02479 },\n        ],\n        symbol: 'Tl',\n        mass: 204.38341283936,\n        name: 'Thallium',\n        monoisotopicMass: 204.9744278,\n    },\n    {\n        number: 82,\n        isotopes: [\n            { nominal: 178, mass: 178.003831 },\n            { nominal: 179, mass: 179.002201 },\n            { nominal: 180, mass: 179.997928 },\n            { nominal: 181, mass: 180.996653 },\n            { nominal: 182, mass: 181.992672 },\n            { nominal: 183, mass: 182.991872 },\n            { nominal: 184, mass: 183.988136 },\n            { nominal: 185, mass: 184.98761 },\n            { nominal: 186, mass: 185.984238 },\n            { nominal: 187, mass: 186.9839109 },\n            { nominal: 188, mass: 187.980875 },\n            { nominal: 189, mass: 188.980807 },\n            { nominal: 190, mass: 189.978082 },\n            { nominal: 191, mass: 190.978276 },\n            { nominal: 192, mass: 191.975775 },\n            { nominal: 193, mass: 192.976173 },\n            { nominal: 194, mass: 193.974012 },\n            { nominal: 195, mass: 194.974543 },\n            { nominal: 196, mass: 195.972774 },\n            { nominal: 197, mass: 196.9734312 },\n            { nominal: 198, mass: 197.972034 },\n            { nominal: 199, mass: 198.972913 },\n            { nominal: 200, mass: 199.971819 },\n            { nominal: 201, mass: 200.972883 },\n            { nominal: 202, mass: 201.972152 },\n            { nominal: 203, mass: 202.9733911 },\n            { nominal: 204, mass: 203.973044, abundance: 0.014 },\n            { nominal: 205, mass: 204.9744822 },\n            { nominal: 206, mass: 205.9744657, abundance: 0.241 },\n            { nominal: 207, mass: 206.9758973, abundance: 0.221 },\n            { nominal: 208, mass: 207.9766525, abundance: 0.524 },\n            { nominal: 209, mass: 208.9810905 },\n            { nominal: 210, mass: 209.9841889 },\n            { nominal: 211, mass: 210.9887371 },\n            { nominal: 212, mass: 211.9918977 },\n            { nominal: 213, mass: 212.9965629 },\n            { nominal: 214, mass: 213.9998059 },\n            { nominal: 215, mass: 215.00474 },\n            { nominal: 216, mass: 216.00803 },\n            { nominal: 217, mass: 217.01314 },\n            { nominal: 218, mass: 218.01659 },\n            { nominal: 219, mass: 219.02177 },\n            { nominal: 220, mass: 220.02541 },\n        ],\n        symbol: 'Pb',\n        mass: 207.216908063,\n        name: 'Lead',\n        monoisotopicMass: 207.9766525,\n    },\n    {\n        number: 83,\n        isotopes: [\n            { nominal: 184, mass: 184.001275 },\n            { nominal: 185, mass: 184.9976 },\n            { nominal: 186, mass: 185.996644 },\n            { nominal: 187, mass: 186.993147 },\n            { nominal: 188, mass: 187.992287 },\n            { nominal: 189, mass: 188.989195 },\n            { nominal: 190, mass: 189.988622 },\n            { nominal: 191, mass: 190.9857866 },\n            { nominal: 192, mass: 191.985469 },\n            { nominal: 193, mass: 192.98296 },\n            { nominal: 194, mass: 193.982785 },\n            { nominal: 195, mass: 194.9806488 },\n            { nominal: 196, mass: 195.980667 },\n            { nominal: 197, mass: 196.9788651 },\n            { nominal: 198, mass: 197.979206 },\n            { nominal: 199, mass: 198.977673 },\n            { nominal: 200, mass: 199.978131 },\n            { nominal: 201, mass: 200.97701 },\n            { nominal: 202, mass: 201.977734 },\n            { nominal: 203, mass: 202.976893 },\n            { nominal: 204, mass: 203.9778361 },\n            { nominal: 205, mass: 204.9773867 },\n            { nominal: 206, mass: 205.9784993 },\n            { nominal: 207, mass: 206.978471 },\n            { nominal: 208, mass: 207.9797425 },\n            { nominal: 209, mass: 208.9803991, abundance: 1 },\n            { nominal: 210, mass: 209.9841207 },\n            { nominal: 211, mass: 210.9872697 },\n            { nominal: 212, mass: 211.991286 },\n            { nominal: 213, mass: 212.9943851 },\n            { nominal: 214, mass: 213.998712 },\n            { nominal: 215, mass: 215.00177 },\n            { nominal: 216, mass: 216.006306 },\n            { nominal: 217, mass: 217.009372 },\n            { nominal: 218, mass: 218.014188 },\n            { nominal: 219, mass: 219.01748 },\n            { nominal: 220, mass: 220.02235 },\n            { nominal: 221, mass: 221.02587 },\n            { nominal: 222, mass: 222.03078 },\n            { nominal: 223, mass: 223.0345 },\n            { nominal: 224, mass: 224.03947 },\n        ],\n        symbol: 'Bi',\n        mass: 208.9803991,\n        name: 'Bismuth',\n        monoisotopicMass: 208.9803991,\n    },\n    {\n        number: 84,\n        isotopes: [\n            { nominal: 186, mass: 186.004393 },\n            { nominal: 187, mass: 187.003041 },\n            { nominal: 188, mass: 187.999416 },\n            { nominal: 189, mass: 188.998473 },\n            { nominal: 190, mass: 189.995101 },\n            { nominal: 191, mass: 190.9945585 },\n            { nominal: 192, mass: 191.991336 },\n            { nominal: 193, mass: 192.991026 },\n            { nominal: 194, mass: 193.988186 },\n            { nominal: 195, mass: 194.988126 },\n            { nominal: 196, mass: 195.985526 },\n            { nominal: 197, mass: 196.98566 },\n            { nominal: 198, mass: 197.983389 },\n            { nominal: 199, mass: 198.983667 },\n            { nominal: 200, mass: 199.981799 },\n            { nominal: 201, mass: 200.9822598 },\n            { nominal: 202, mass: 201.980758 },\n            { nominal: 203, mass: 202.9814161 },\n            { nominal: 204, mass: 203.98031 },\n            { nominal: 205, mass: 204.981203 },\n            { nominal: 206, mass: 205.980474 },\n            { nominal: 207, mass: 206.9815938 },\n            { nominal: 208, mass: 207.9812461 },\n            { nominal: 209, mass: 208.9824308 },\n            { nominal: 210, mass: 209.9828741 },\n            { nominal: 211, mass: 210.9866536 },\n            { nominal: 212, mass: 211.9888684 },\n            { nominal: 213, mass: 212.9928576 },\n            { nominal: 214, mass: 213.9952017 },\n            { nominal: 215, mass: 214.9994201 },\n            { nominal: 216, mass: 216.0019152 },\n            { nominal: 217, mass: 217.0063182 },\n            { nominal: 218, mass: 218.0089735 },\n            { nominal: 219, mass: 219.013614 },\n            { nominal: 220, mass: 220.016386 },\n            { nominal: 221, mass: 221.021228 },\n            { nominal: 222, mass: 222.02414 },\n            { nominal: 223, mass: 223.02907 },\n            { nominal: 224, mass: 224.03211 },\n            { nominal: 225, mass: 225.03707 },\n            { nominal: 226, mass: 226.04031 },\n            { nominal: 227, mass: 227.04539 },\n        ],\n        symbol: 'Po',\n        mass: null,\n        name: 'Polonium',\n    },\n    {\n        number: 85,\n        isotopes: [\n            { nominal: 191, mass: 191.004148 },\n            { nominal: 192, mass: 192.003152 },\n            { nominal: 193, mass: 192.999927 },\n            { nominal: 194, mass: 193.999236 },\n            { nominal: 195, mass: 194.9962685 },\n            { nominal: 196, mass: 195.9958 },\n            { nominal: 197, mass: 196.993189 },\n            { nominal: 198, mass: 197.992784 },\n            { nominal: 199, mass: 198.9905277 },\n            { nominal: 200, mass: 199.990351 },\n            { nominal: 201, mass: 200.9884171 },\n            { nominal: 202, mass: 201.98863 },\n            { nominal: 203, mass: 202.986943 },\n            { nominal: 204, mass: 203.987251 },\n            { nominal: 205, mass: 204.986076 },\n            { nominal: 206, mass: 205.986657 },\n            { nominal: 207, mass: 206.9858 },\n            { nominal: 208, mass: 207.9866133 },\n            { nominal: 209, mass: 208.9861702 },\n            { nominal: 210, mass: 209.9871479 },\n            { nominal: 211, mass: 210.9874966 },\n            { nominal: 212, mass: 211.9907377 },\n            { nominal: 213, mass: 212.992937 },\n            { nominal: 214, mass: 213.9963721 },\n            { nominal: 215, mass: 214.9986528 },\n            { nominal: 216, mass: 216.0024236 },\n            { nominal: 217, mass: 217.0047192 },\n            { nominal: 218, mass: 218.008695 },\n            { nominal: 219, mass: 219.0111618 },\n            { nominal: 220, mass: 220.015433 },\n            { nominal: 221, mass: 221.018017 },\n            { nominal: 222, mass: 222.022494 },\n            { nominal: 223, mass: 223.025151 },\n            { nominal: 224, mass: 224.029749 },\n            { nominal: 225, mass: 225.03263 },\n            { nominal: 226, mass: 226.03716 },\n            { nominal: 227, mass: 227.04024 },\n            { nominal: 228, mass: 228.04475 },\n            { nominal: 229, mass: 229.04812 },\n        ],\n        symbol: 'At',\n        mass: null,\n        name: 'Astatine',\n    },\n    {\n        number: 86,\n        isotopes: [\n            { nominal: 193, mass: 193.009708 },\n            { nominal: 194, mass: 194.006144 },\n            { nominal: 195, mass: 195.005422 },\n            { nominal: 196, mass: 196.002116 },\n            { nominal: 197, mass: 197.001585 },\n            { nominal: 198, mass: 197.998679 },\n            { nominal: 199, mass: 198.99839 },\n            { nominal: 200, mass: 199.99569 },\n            { nominal: 201, mass: 200.995628 },\n            { nominal: 202, mass: 201.993264 },\n            { nominal: 203, mass: 202.993388 },\n            { nominal: 204, mass: 203.99143 },\n            { nominal: 205, mass: 204.991719 },\n            { nominal: 206, mass: 205.990214 },\n            { nominal: 207, mass: 206.9907303 },\n            { nominal: 208, mass: 207.989635 },\n            { nominal: 209, mass: 208.990415 },\n            { nominal: 210, mass: 209.9896891 },\n            { nominal: 211, mass: 210.9906011 },\n            { nominal: 212, mass: 211.9907039 },\n            { nominal: 213, mass: 212.9938831 },\n            { nominal: 214, mass: 213.995363 },\n            { nominal: 215, mass: 214.9987459 },\n            { nominal: 216, mass: 216.0002719 },\n            { nominal: 217, mass: 217.003928 },\n            { nominal: 218, mass: 218.0056016 },\n            { nominal: 219, mass: 219.0094804 },\n            { nominal: 220, mass: 220.0113941 },\n            { nominal: 221, mass: 221.0155371 },\n            { nominal: 222, mass: 222.0175782 },\n            { nominal: 223, mass: 223.0218893 },\n            { nominal: 224, mass: 224.024096 },\n            { nominal: 225, mass: 225.028486 },\n            { nominal: 226, mass: 226.030861 },\n            { nominal: 227, mass: 227.035304 },\n            { nominal: 228, mass: 228.037835 },\n            { nominal: 229, mass: 229.042257 },\n            { nominal: 230, mass: 230.04514 },\n            { nominal: 231, mass: 231.04987 },\n        ],\n        symbol: 'Rn',\n        mass: null,\n        name: 'Radon',\n    },\n    {\n        number: 87,\n        isotopes: [\n            { nominal: 199, mass: 199.007259 },\n            { nominal: 200, mass: 200.006586 },\n            { nominal: 201, mass: 201.003867 },\n            { nominal: 202, mass: 202.00332 },\n            { nominal: 203, mass: 203.0009407 },\n            { nominal: 204, mass: 204.000652 },\n            { nominal: 205, mass: 204.9985939 },\n            { nominal: 206, mass: 205.998666 },\n            { nominal: 207, mass: 206.996946 },\n            { nominal: 208, mass: 207.997138 },\n            { nominal: 209, mass: 208.995955 },\n            { nominal: 210, mass: 209.996422 },\n            { nominal: 211, mass: 210.995556 },\n            { nominal: 212, mass: 211.9962257 },\n            { nominal: 213, mass: 212.996186 },\n            { nominal: 214, mass: 213.9989713 },\n            { nominal: 215, mass: 215.0003418 },\n            { nominal: 216, mass: 216.0031899 },\n            { nominal: 217, mass: 217.0046323 },\n            { nominal: 218, mass: 218.0075787 },\n            { nominal: 219, mass: 219.0092524 },\n            { nominal: 220, mass: 220.0123277 },\n            { nominal: 221, mass: 221.0142552 },\n            { nominal: 222, mass: 222.017552 },\n            { nominal: 223, mass: 223.019736 },\n            { nominal: 224, mass: 224.023398 },\n            { nominal: 225, mass: 225.025573 },\n            { nominal: 226, mass: 226.029566 },\n            { nominal: 227, mass: 227.031869 },\n            { nominal: 228, mass: 228.035823 },\n            { nominal: 229, mass: 229.038298 },\n            { nominal: 230, mass: 230.042416 },\n            { nominal: 231, mass: 231.045158 },\n            { nominal: 232, mass: 232.04937 },\n            { nominal: 233, mass: 233.05264 },\n        ],\n        symbol: 'Fr',\n        mass: null,\n        name: 'Francium',\n    },\n    {\n        number: 88,\n        isotopes: [\n            { nominal: 201, mass: 201.01271 },\n            { nominal: 202, mass: 202.00976 },\n            { nominal: 203, mass: 203.009304 },\n            { nominal: 204, mass: 204.006492 },\n            { nominal: 205, mass: 205.006268 },\n            { nominal: 206, mass: 206.003828 },\n            { nominal: 207, mass: 207.003799 },\n            { nominal: 208, mass: 208.001841 },\n            { nominal: 209, mass: 209.00199 },\n            { nominal: 210, mass: 210.000494 },\n            { nominal: 211, mass: 211.0008932 },\n            { nominal: 212, mass: 211.999787 },\n            { nominal: 213, mass: 213.000384 },\n            { nominal: 214, mass: 214.0000997 },\n            { nominal: 215, mass: 215.0027204 },\n            { nominal: 216, mass: 216.0035334 },\n            { nominal: 217, mass: 217.0063207 },\n            { nominal: 218, mass: 218.007141 },\n            { nominal: 219, mass: 219.0100855 },\n            { nominal: 220, mass: 220.0110259 },\n            { nominal: 221, mass: 221.0139177 },\n            { nominal: 222, mass: 222.0153748 },\n            { nominal: 223, mass: 223.0185023 },\n            { nominal: 224, mass: 224.020212 },\n            { nominal: 225, mass: 225.0236119 },\n            { nominal: 226, mass: 226.0254103 },\n            { nominal: 227, mass: 227.0291783 },\n            { nominal: 228, mass: 228.0310707 },\n            { nominal: 229, mass: 229.034942 },\n            { nominal: 230, mass: 230.037055 },\n            { nominal: 231, mass: 231.041027 },\n            { nominal: 232, mass: 232.0434753 },\n            { nominal: 233, mass: 233.047582 },\n            { nominal: 234, mass: 234.050342 },\n            { nominal: 235, mass: 235.05497 },\n        ],\n        symbol: 'Ra',\n        mass: null,\n        name: 'Radium',\n    },\n    {\n        number: 89,\n        isotopes: [\n            { nominal: 206, mass: 206.014452 },\n            { nominal: 207, mass: 207.011966 },\n            { nominal: 208, mass: 208.01155 },\n            { nominal: 209, mass: 209.009495 },\n            { nominal: 210, mass: 210.009436 },\n            { nominal: 211, mass: 211.007732 },\n            { nominal: 212, mass: 212.007813 },\n            { nominal: 213, mass: 213.006609 },\n            { nominal: 214, mass: 214.006918 },\n            { nominal: 215, mass: 215.006475 },\n            { nominal: 216, mass: 216.008743 },\n            { nominal: 217, mass: 217.009344 },\n            { nominal: 218, mass: 218.011642 },\n            { nominal: 219, mass: 219.012421 },\n            { nominal: 220, mass: 220.0147549 },\n            { nominal: 221, mass: 221.015592 },\n            { nominal: 222, mass: 222.0178442 },\n            { nominal: 223, mass: 223.0191377 },\n            { nominal: 224, mass: 224.0217232 },\n            { nominal: 225, mass: 225.02323 },\n            { nominal: 226, mass: 226.0260984 },\n            { nominal: 227, mass: 227.0277523 },\n            { nominal: 228, mass: 228.0310215 },\n            { nominal: 229, mass: 229.032956 },\n            { nominal: 230, mass: 230.036327 },\n            { nominal: 231, mass: 231.038393 },\n            { nominal: 232, mass: 232.042034 },\n            { nominal: 233, mass: 233.044346 },\n            { nominal: 234, mass: 234.048139 },\n            { nominal: 235, mass: 235.05084 },\n            { nominal: 236, mass: 236.054988 },\n            { nominal: 237, mass: 237.05827 },\n        ],\n        symbol: 'Ac',\n        mass: null,\n        name: 'Actinium',\n    },\n    {\n        number: 90,\n        isotopes: [\n            { nominal: 208, mass: 208.0179 },\n            { nominal: 209, mass: 209.017753 },\n            { nominal: 210, mass: 210.015094 },\n            { nominal: 211, mass: 211.014929 },\n            { nominal: 212, mass: 212.012988 },\n            { nominal: 213, mass: 213.013009 },\n            { nominal: 214, mass: 214.0115 },\n            { nominal: 215, mass: 215.0117248 },\n            { nominal: 216, mass: 216.011056 },\n            { nominal: 217, mass: 217.013117 },\n            { nominal: 218, mass: 218.013276 },\n            { nominal: 219, mass: 219.015537 },\n            { nominal: 220, mass: 220.015748 },\n            { nominal: 221, mass: 221.018184 },\n            { nominal: 222, mass: 222.018469 },\n            { nominal: 223, mass: 223.0208119 },\n            { nominal: 224, mass: 224.021464 },\n            { nominal: 225, mass: 225.0239514 },\n            { nominal: 226, mass: 226.0249034 },\n            { nominal: 227, mass: 227.0277042 },\n            { nominal: 228, mass: 228.0287413 },\n            { nominal: 229, mass: 229.0317627 },\n            { nominal: 230, mass: 230.0331341 },\n            { nominal: 231, mass: 231.0363046 },\n            { nominal: 232, mass: 232.0380558, abundance: 1 },\n            { nominal: 233, mass: 233.0415823 },\n            { nominal: 234, mass: 234.0436014 },\n            { nominal: 235, mass: 235.047255 },\n            { nominal: 236, mass: 236.049657 },\n            { nominal: 237, mass: 237.053629 },\n            { nominal: 238, mass: 238.0565 },\n            { nominal: 239, mass: 239.06077 },\n        ],\n        symbol: 'Th',\n        mass: 232.0380558,\n        name: 'Thorium',\n        monoisotopicMass: 232.0380558,\n    },\n    {\n        number: 91,\n        isotopes: [\n            { nominal: 212, mass: 212.023203 },\n            { nominal: 213, mass: 213.021109 },\n            { nominal: 214, mass: 214.020918 },\n            { nominal: 215, mass: 215.019183 },\n            { nominal: 216, mass: 216.019109 },\n            { nominal: 217, mass: 217.018325 },\n            { nominal: 218, mass: 218.020059 },\n            { nominal: 219, mass: 219.019904 },\n            { nominal: 220, mass: 220.021705 },\n            { nominal: 221, mass: 221.021875 },\n            { nominal: 222, mass: 222.023784 },\n            { nominal: 223, mass: 223.023963 },\n            { nominal: 224, mass: 224.0256176 },\n            { nominal: 225, mass: 225.026131 },\n            { nominal: 226, mass: 226.027948 },\n            { nominal: 227, mass: 227.0288054 },\n            { nominal: 228, mass: 228.0310517 },\n            { nominal: 229, mass: 229.0320972 },\n            { nominal: 230, mass: 230.034541 },\n            { nominal: 231, mass: 231.0358842, abundance: 1 },\n            { nominal: 232, mass: 232.0385917 },\n            { nominal: 233, mass: 233.0402472 },\n            { nominal: 234, mass: 234.0433072 },\n            { nominal: 235, mass: 235.045399 },\n            { nominal: 236, mass: 236.048668 },\n            { nominal: 237, mass: 237.051023 },\n            { nominal: 238, mass: 238.054637 },\n            { nominal: 239, mass: 239.05726 },\n            { nominal: 240, mass: 240.06098 },\n            { nominal: 241, mass: 241.06408 },\n        ],\n        symbol: 'Pa',\n        mass: 231.0358842,\n        name: 'Protactinium',\n        monoisotopicMass: 231.0358842,\n    },\n    {\n        number: 92,\n        isotopes: [\n            { nominal: 217, mass: 217.02466 },\n            { nominal: 218, mass: 218.023523 },\n            { nominal: 219, mass: 219.024999 },\n            { nominal: 220, mass: 220.02462 },\n            { nominal: 221, mass: 221.02628 },\n            { nominal: 222, mass: 222.026 },\n            { nominal: 223, mass: 223.027739 },\n            { nominal: 224, mass: 224.027605 },\n            { nominal: 225, mass: 225.029391 },\n            { nominal: 226, mass: 226.029339 },\n            { nominal: 227, mass: 227.031157 },\n            { nominal: 228, mass: 228.031371 },\n            { nominal: 229, mass: 229.0335063 },\n            { nominal: 230, mass: 230.0339401 },\n            { nominal: 231, mass: 231.0362939 },\n            { nominal: 232, mass: 232.0371563 },\n            { nominal: 233, mass: 233.0396355 },\n            { nominal: 234, mass: 234.0409523, abundance: 0.000054 },\n            { nominal: 235, mass: 235.0439301, abundance: 0.007204 },\n            { nominal: 236, mass: 236.0455682 },\n            { nominal: 237, mass: 237.0487304 },\n            { nominal: 238, mass: 238.0507884, abundance: 0.992742 },\n            { nominal: 239, mass: 239.0542935 },\n            { nominal: 240, mass: 240.0565934 },\n            { nominal: 241, mass: 241.06033 },\n            { nominal: 242, mass: 242.06293 },\n            { nominal: 243, mass: 243.06699 },\n        ],\n        symbol: 'U',\n        mass: 238.0289104616574,\n        name: 'Uranium',\n        monoisotopicMass: 238.0507884,\n    },\n    {\n        number: 93,\n        isotopes: [\n            { nominal: 219, mass: 219.03143 },\n            { nominal: 220, mass: 220.03254 },\n            { nominal: 221, mass: 221.03204 },\n            { nominal: 222, mass: 222.0333 },\n            { nominal: 223, mass: 223.03285 },\n            { nominal: 224, mass: 224.03422 },\n            { nominal: 225, mass: 225.033911 },\n            { nominal: 226, mass: 226.035188 },\n            { nominal: 227, mass: 227.034957 },\n            { nominal: 228, mass: 228.036067 },\n            { nominal: 229, mass: 229.036264 },\n            { nominal: 230, mass: 230.037828 },\n            { nominal: 231, mass: 231.038245 },\n            { nominal: 232, mass: 232.04011 },\n            { nominal: 233, mass: 233.040741 },\n            { nominal: 234, mass: 234.0428953 },\n            { nominal: 235, mass: 235.0440635 },\n            { nominal: 236, mass: 236.04657 },\n            { nominal: 237, mass: 237.0481736 },\n            { nominal: 238, mass: 238.0509466 },\n            { nominal: 239, mass: 239.0529392 },\n            { nominal: 240, mass: 240.056165 },\n            { nominal: 241, mass: 241.058253 },\n            { nominal: 242, mass: 242.06164 },\n            { nominal: 243, mass: 243.06428 },\n            { nominal: 244, mass: 244.06785 },\n            { nominal: 245, mass: 245.0708 },\n        ],\n        symbol: 'Np',\n        mass: null,\n        name: 'Neptunium',\n    },\n    {\n        number: 94,\n        isotopes: [\n            { nominal: 228, mass: 228.038732 },\n            { nominal: 229, mass: 229.040144 },\n            { nominal: 230, mass: 230.03965 },\n            { nominal: 231, mass: 231.041102 },\n            { nominal: 232, mass: 232.041185 },\n            { nominal: 233, mass: 233.042998 },\n            { nominal: 234, mass: 234.0433174 },\n            { nominal: 235, mass: 235.045286 },\n            { nominal: 236, mass: 236.0460581 },\n            { nominal: 237, mass: 237.0484098 },\n            { nominal: 238, mass: 238.0495601 },\n            { nominal: 239, mass: 239.0521636 },\n            { nominal: 240, mass: 240.0538138 },\n            { nominal: 241, mass: 241.0568517 },\n            { nominal: 242, mass: 242.0587428 },\n            { nominal: 243, mass: 243.0620036 },\n            { nominal: 244, mass: 244.0642053 },\n            { nominal: 245, mass: 245.067826 },\n            { nominal: 246, mass: 246.070205 },\n            { nominal: 247, mass: 247.07419 },\n        ],\n        symbol: 'Pu',\n        mass: null,\n        name: 'Plutonium',\n    },\n    {\n        number: 95,\n        isotopes: [\n            { nominal: 230, mass: 230.04609 },\n            { nominal: 231, mass: 231.04556 },\n            { nominal: 232, mass: 232.04645 },\n            { nominal: 233, mass: 233.04644 },\n            { nominal: 234, mass: 234.04773 },\n            { nominal: 235, mass: 235.047908 },\n            { nominal: 236, mass: 236.04943 },\n            { nominal: 237, mass: 237.049996 },\n            { nominal: 238, mass: 238.051985 },\n            { nominal: 239, mass: 239.0530247 },\n            { nominal: 240, mass: 240.0553 },\n            { nominal: 241, mass: 241.0568293 },\n            { nominal: 242, mass: 242.0595494 },\n            { nominal: 243, mass: 243.0613813 },\n            { nominal: 244, mass: 244.0642851 },\n            { nominal: 245, mass: 245.0664548 },\n            { nominal: 246, mass: 246.069775 },\n            { nominal: 247, mass: 247.07209 },\n            { nominal: 248, mass: 248.07575 },\n            { nominal: 249, mass: 249.07848 },\n        ],\n        symbol: 'Am',\n        name: 'Americium',\n        mass: null,\n    },\n    {\n        number: 96,\n        isotopes: [\n            { nominal: 232, mass: 232.04982 },\n            { nominal: 233, mass: 233.05077 },\n            { nominal: 234, mass: 234.05016 },\n            { nominal: 235, mass: 235.05154 },\n            { nominal: 236, mass: 236.051374 },\n            { nominal: 237, mass: 237.052869 },\n            { nominal: 238, mass: 238.053081 },\n            { nominal: 239, mass: 239.05491 },\n            { nominal: 240, mass: 240.0555297 },\n            { nominal: 241, mass: 241.0576532 },\n            { nominal: 242, mass: 242.058836 },\n            { nominal: 243, mass: 243.0613893 },\n            { nominal: 244, mass: 244.0627528 },\n            { nominal: 245, mass: 245.0654915 },\n            { nominal: 246, mass: 246.0672238 },\n            { nominal: 247, mass: 247.0703541 },\n            { nominal: 248, mass: 248.0723499 },\n            { nominal: 249, mass: 249.0759548 },\n            { nominal: 250, mass: 250.078358 },\n            { nominal: 251, mass: 251.082286 },\n            { nominal: 252, mass: 252.08487 },\n        ],\n        symbol: 'Cm',\n        name: 'Curium',\n        mass: null,\n    },\n    {\n        number: 97,\n        isotopes: [\n            { nominal: 234, mass: 234.05727 },\n            { nominal: 235, mass: 235.05658 },\n            { nominal: 236, mass: 236.05748 },\n            { nominal: 237, mass: 237.0571 },\n            { nominal: 238, mass: 238.0582 },\n            { nominal: 239, mass: 239.05824 },\n            { nominal: 240, mass: 240.05976 },\n            { nominal: 241, mass: 241.06016 },\n            { nominal: 242, mass: 242.06198 },\n            { nominal: 243, mass: 243.0630078 },\n            { nominal: 244, mass: 244.065181 },\n            { nominal: 245, mass: 245.0663618 },\n            { nominal: 246, mass: 246.068673 },\n            { nominal: 247, mass: 247.0703073 },\n            { nominal: 248, mass: 248.073088 },\n            { nominal: 249, mass: 249.0749877 },\n            { nominal: 250, mass: 250.0783167 },\n            { nominal: 251, mass: 251.080762 },\n            { nominal: 252, mass: 252.08431 },\n            { nominal: 253, mass: 253.08688 },\n            { nominal: 254, mass: 254.0906 },\n        ],\n        symbol: 'Bk',\n        name: 'Berkelium',\n        mass: null,\n    },\n    {\n        number: 98,\n        isotopes: [\n            { nominal: 237, mass: 237.062198 },\n            { nominal: 238, mass: 238.06149 },\n            { nominal: 239, mass: 239.06253 },\n            { nominal: 240, mass: 240.062256 },\n            { nominal: 241, mass: 241.06369 },\n            { nominal: 242, mass: 242.063754 },\n            { nominal: 243, mass: 243.06548 },\n            { nominal: 244, mass: 244.0660008 },\n            { nominal: 245, mass: 245.0680487 },\n            { nominal: 246, mass: 246.0688055 },\n            { nominal: 247, mass: 247.070965 },\n            { nominal: 248, mass: 248.0721851 },\n            { nominal: 249, mass: 249.0748539 },\n            { nominal: 250, mass: 250.0764062 },\n            { nominal: 251, mass: 251.0795886 },\n            { nominal: 252, mass: 252.0816272 },\n            { nominal: 253, mass: 253.0851345 },\n            { nominal: 254, mass: 254.087324 },\n            { nominal: 255, mass: 255.09105 },\n            { nominal: 256, mass: 256.09344 },\n        ],\n        symbol: 'Cf',\n        name: 'Californium',\n        mass: null,\n    },\n    {\n        number: 99,\n        isotopes: [\n            { nominal: 239, mass: 239.06823 },\n            { nominal: 240, mass: 240.06892 },\n            { nominal: 241, mass: 241.06856 },\n            { nominal: 242, mass: 242.06957 },\n            { nominal: 243, mass: 243.06951 },\n            { nominal: 244, mass: 244.07088 },\n            { nominal: 245, mass: 245.07125 },\n            { nominal: 246, mass: 246.0729 },\n            { nominal: 247, mass: 247.073622 },\n            { nominal: 248, mass: 248.075471 },\n            { nominal: 249, mass: 249.076411 },\n            { nominal: 250, mass: 250.07861 },\n            { nominal: 251, mass: 251.0799936 },\n            { nominal: 252, mass: 252.08298 },\n            { nominal: 253, mass: 253.0848257 },\n            { nominal: 254, mass: 254.0880222 },\n            { nominal: 255, mass: 255.090275 },\n            { nominal: 256, mass: 256.0936 },\n            { nominal: 257, mass: 257.09598 },\n            { nominal: 258, mass: 258.09952 },\n        ],\n        symbol: 'Es',\n        name: 'Einsteinium',\n        mass: null,\n    },\n    {\n        number: 100,\n        isotopes: [\n            { nominal: 241, mass: 241.07421 },\n            { nominal: 242, mass: 242.07343 },\n            { nominal: 243, mass: 243.07446 },\n            { nominal: 244, mass: 244.07404 },\n            { nominal: 245, mass: 245.07535 },\n            { nominal: 246, mass: 246.07535 },\n            { nominal: 247, mass: 247.07694 },\n            { nominal: 248, mass: 248.0771865 },\n            { nominal: 249, mass: 249.0789275 },\n            { nominal: 250, mass: 250.079521 },\n            { nominal: 251, mass: 251.08154 },\n            { nominal: 252, mass: 252.0824671 },\n            { nominal: 253, mass: 253.0851846 },\n            { nominal: 254, mass: 254.0868544 },\n            { nominal: 255, mass: 255.089964 },\n            { nominal: 256, mass: 256.0917745 },\n            { nominal: 257, mass: 257.0951061 },\n            { nominal: 258, mass: 258.09708 },\n            { nominal: 259, mass: 259.1006 },\n            { nominal: 260, mass: 260.10281 },\n        ],\n        symbol: 'Fm',\n        name: 'Fermium',\n        mass: null,\n    },\n    {\n        number: 101,\n        isotopes: [\n            { nominal: 245, mass: 245.08081 },\n            { nominal: 246, mass: 246.08171 },\n            { nominal: 247, mass: 247.08152 },\n            { nominal: 248, mass: 248.08282 },\n            { nominal: 249, mass: 249.08291 },\n            { nominal: 250, mass: 250.08441 },\n            { nominal: 251, mass: 251.084774 },\n            { nominal: 252, mass: 252.08643 },\n            { nominal: 253, mass: 253.087144 },\n            { nominal: 254, mass: 254.08959 },\n            { nominal: 255, mass: 255.0910841 },\n            { nominal: 256, mass: 256.09389 },\n            { nominal: 257, mass: 257.0955424 },\n            { nominal: 258, mass: 258.0984315 },\n            { nominal: 259, mass: 259.10051 },\n            { nominal: 260, mass: 260.10365 },\n            { nominal: 261, mass: 261.10583 },\n            { nominal: 262, mass: 262.1091 },\n        ],\n        symbol: 'Md',\n        name: 'Mendelevium',\n        mass: null,\n    },\n    {\n        number: 102,\n        isotopes: [\n            { nominal: 248, mass: 248.08655 },\n            { nominal: 249, mass: 249.0878 },\n            { nominal: 250, mass: 250.08756 },\n            { nominal: 251, mass: 251.08894 },\n            { nominal: 252, mass: 252.088967 },\n            { nominal: 253, mass: 253.0905641 },\n            { nominal: 254, mass: 254.090956 },\n            { nominal: 255, mass: 255.093191 },\n            { nominal: 256, mass: 256.0942829 },\n            { nominal: 257, mass: 257.0968878 },\n            { nominal: 258, mass: 258.09821 },\n            { nominal: 259, mass: 259.10103 },\n            { nominal: 260, mass: 260.10264 },\n            { nominal: 261, mass: 261.1057 },\n            { nominal: 262, mass: 262.10746 },\n            { nominal: 263, mass: 263.11071 },\n            { nominal: 264, mass: 264.11273 },\n        ],\n        symbol: 'No',\n        name: 'Nobelium',\n        mass: null,\n    },\n    {\n        number: 103,\n        isotopes: [\n            { nominal: 251, mass: 251.09418 },\n            { nominal: 252, mass: 252.09526 },\n            { nominal: 253, mass: 253.09509 },\n            { nominal: 254, mass: 254.09648 },\n            { nominal: 255, mass: 255.096562 },\n            { nominal: 256, mass: 256.098494 },\n            { nominal: 257, mass: 257.099418 },\n            { nominal: 258, mass: 258.10176 },\n            { nominal: 259, mass: 259.102902 },\n            { nominal: 260, mass: 260.1055 },\n            { nominal: 261, mass: 261.10688 },\n            { nominal: 262, mass: 262.10961 },\n            { nominal: 263, mass: 263.11136 },\n            { nominal: 264, mass: 264.1142 },\n            { nominal: 265, mass: 265.11619 },\n            { nominal: 266, mass: 266.11983 },\n        ],\n        symbol: 'Lr',\n        name: 'Lawrencium',\n        mass: null,\n    },\n    {\n        number: 104,\n        isotopes: [\n            { nominal: 253, mass: 253.10044 },\n            { nominal: 254, mass: 254.10005 },\n            { nominal: 255, mass: 255.10127 },\n            { nominal: 256, mass: 256.101152 },\n            { nominal: 257, mass: 257.102918 },\n            { nominal: 258, mass: 258.103428 },\n            { nominal: 259, mass: 259.105596 },\n            { nominal: 260, mass: 260.10644 },\n            { nominal: 261, mass: 261.108773 },\n            { nominal: 262, mass: 262.10992 },\n            { nominal: 263, mass: 263.11249 },\n            { nominal: 264, mass: 264.11388 },\n            { nominal: 265, mass: 265.11668 },\n            { nominal: 266, mass: 266.11817 },\n            { nominal: 267, mass: 267.12179 },\n            { nominal: 268, mass: 268.12397 },\n        ],\n        symbol: 'Rf',\n        name: 'Rutherfordium',\n        mass: null,\n    },\n    {\n        number: 105,\n        isotopes: [\n            { nominal: 255, mass: 255.10707 },\n            { nominal: 256, mass: 256.10789 },\n            { nominal: 257, mass: 257.10758 },\n            { nominal: 258, mass: 258.10928 },\n            { nominal: 259, mass: 259.109492 },\n            { nominal: 260, mass: 260.1113 },\n            { nominal: 261, mass: 261.11192 },\n            { nominal: 262, mass: 262.11407 },\n            { nominal: 263, mass: 263.11499 },\n            { nominal: 264, mass: 264.11741 },\n            { nominal: 265, mass: 265.11861 },\n            { nominal: 266, mass: 266.12103 },\n            { nominal: 267, mass: 267.12247 },\n            { nominal: 268, mass: 268.12567 },\n            { nominal: 269, mass: 269.12791 },\n            { nominal: 270, mass: 270.13136 },\n        ],\n        symbol: 'Db',\n        name: 'Dubnium',\n        mass: null,\n    },\n    {\n        number: 106,\n        isotopes: [\n            { nominal: 258, mass: 258.11298 },\n            { nominal: 259, mass: 259.1144 },\n            { nominal: 260, mass: 260.114384 },\n            { nominal: 261, mass: 261.115949 },\n            { nominal: 262, mass: 262.116337 },\n            { nominal: 263, mass: 263.11829 },\n            { nominal: 264, mass: 264.11893 },\n            { nominal: 265, mass: 265.12109 },\n            { nominal: 266, mass: 266.12198 },\n            { nominal: 267, mass: 267.12436 },\n            { nominal: 268, mass: 268.12539 },\n            { nominal: 269, mass: 269.12863 },\n            { nominal: 270, mass: 270.13043 },\n            { nominal: 271, mass: 271.13393 },\n            { nominal: 272, mass: 272.13589 },\n            { nominal: 273, mass: 273.13958 },\n        ],\n        symbol: 'Sg',\n        name: 'Seaborgium',\n        mass: null,\n    },\n    {\n        number: 107,\n        isotopes: [\n            { nominal: 260, mass: 260.12166 },\n            { nominal: 261, mass: 261.12145 },\n            { nominal: 262, mass: 262.12297 },\n            { nominal: 263, mass: 263.12292 },\n            { nominal: 264, mass: 264.12459 },\n            { nominal: 265, mass: 265.12491 },\n            { nominal: 266, mass: 266.12679 },\n            { nominal: 267, mass: 267.1275 },\n            { nominal: 268, mass: 268.12969 },\n            { nominal: 269, mass: 269.13042 },\n            { nominal: 270, mass: 270.13336 },\n            { nominal: 271, mass: 271.13526 },\n            { nominal: 272, mass: 272.13826 },\n            { nominal: 273, mass: 273.14024 },\n            { nominal: 274, mass: 274.14355 },\n            { nominal: 275, mass: 275.14567 },\n        ],\n        symbol: 'Bh',\n        name: 'Bohrium',\n        mass: null,\n    },\n    {\n        number: 108,\n        isotopes: [\n            { nominal: 263, mass: 263.12852 },\n            { nominal: 264, mass: 264.128357 },\n            { nominal: 265, mass: 265.129793 },\n            { nominal: 266, mass: 266.130046 },\n            { nominal: 267, mass: 267.13167 },\n            { nominal: 268, mass: 268.13186 },\n            { nominal: 269, mass: 269.13375 },\n            { nominal: 270, mass: 270.13429 },\n            { nominal: 271, mass: 271.13717 },\n            { nominal: 272, mass: 272.1385 },\n            { nominal: 273, mass: 273.14168 },\n            { nominal: 274, mass: 274.1433 },\n            { nominal: 275, mass: 275.14667 },\n            { nominal: 276, mass: 276.14846 },\n            { nominal: 277, mass: 277.1519 },\n        ],\n        symbol: 'Hs',\n        name: 'Hassium',\n        mass: null,\n    },\n    {\n        number: 109,\n        isotopes: [\n            { nominal: 265, mass: 265.136 },\n            { nominal: 266, mass: 266.13737 },\n            { nominal: 267, mass: 267.13719 },\n            { nominal: 268, mass: 268.13865 },\n            { nominal: 269, mass: 269.13882 },\n            { nominal: 270, mass: 270.14033 },\n            { nominal: 271, mass: 271.14074 },\n            { nominal: 272, mass: 272.14341 },\n            { nominal: 273, mass: 273.1444 },\n            { nominal: 274, mass: 274.14724 },\n            { nominal: 275, mass: 275.14882 },\n            { nominal: 276, mass: 276.15159 },\n            { nominal: 277, mass: 277.15327 },\n            { nominal: 278, mass: 278.15631 },\n            { nominal: 279, mass: 279.15808 },\n        ],\n        symbol: 'Mt',\n        name: 'Meitnerium',\n        mass: null,\n    },\n    {\n        number: 110,\n        isotopes: [\n            { nominal: 267, mass: 267.14377 },\n            { nominal: 268, mass: 268.14348 },\n            { nominal: 269, mass: 269.144752 },\n            { nominal: 270, mass: 270.144584 },\n            { nominal: 271, mass: 271.14595 },\n            { nominal: 272, mass: 272.14602 },\n            { nominal: 273, mass: 273.14856 },\n            { nominal: 274, mass: 274.14941 },\n            { nominal: 275, mass: 275.15203 },\n            { nominal: 276, mass: 276.15303 },\n            { nominal: 277, mass: 277.15591 },\n            { nominal: 278, mass: 278.15704 },\n            { nominal: 279, mass: 279.1601 },\n            { nominal: 280, mass: 280.16131 },\n            { nominal: 281, mass: 281.16451 },\n        ],\n        symbol: 'Ds',\n        name: 'Darmstadtium',\n        mass: null,\n    },\n    {\n        number: 111,\n        isotopes: [\n            { nominal: 272, mass: 272.15327 },\n            { nominal: 273, mass: 273.15313 },\n            { nominal: 274, mass: 274.15525 },\n            { nominal: 275, mass: 275.15594 },\n            { nominal: 276, mass: 276.15833 },\n            { nominal: 277, mass: 277.15907 },\n            { nominal: 278, mass: 278.16149 },\n            { nominal: 279, mass: 279.16272 },\n            { nominal: 280, mass: 280.16514 },\n            { nominal: 281, mass: 281.16636 },\n            { nominal: 282, mass: 282.16912 },\n            { nominal: 283, mass: 283.17054 },\n        ],\n        symbol: 'Rg',\n        name: 'Roentgenium',\n        mass: null,\n    },\n    {\n        number: 112,\n        isotopes: [\n            { nominal: 276, mass: 276.16141 },\n            { nominal: 277, mass: 277.16364 },\n            { nominal: 278, mass: 278.16416 },\n            { nominal: 279, mass: 279.16654 },\n            { nominal: 280, mass: 280.16715 },\n            { nominal: 281, mass: 281.16975 },\n            { nominal: 282, mass: 282.1705 },\n            { nominal: 283, mass: 283.17327 },\n            { nominal: 284, mass: 284.17416 },\n            { nominal: 285, mass: 285.17712 },\n        ],\n        symbol: 'Cn',\n        name: 'Copernicium',\n        mass: null,\n    },\n    {\n        number: 113,\n        isotopes: [\n            { nominal: 278, mass: 278.17058 },\n            { nominal: 279, mass: 279.17095 },\n            { nominal: 280, mass: 280.17293 },\n            { nominal: 281, mass: 281.17348 },\n            { nominal: 282, mass: 282.17567 },\n            { nominal: 283, mass: 283.17657 },\n            { nominal: 284, mass: 284.17873 },\n            { nominal: 285, mass: 285.17973 },\n            { nominal: 286, mass: 286.18221 },\n            { nominal: 287, mass: 287.18339 },\n        ],\n        symbol: 'Nh',\n        name: 'Nihonium',\n        mass: null,\n    },\n    {\n        number: 114,\n        isotopes: [\n            { nominal: 285, mass: 285.18364 },\n            { nominal: 286, mass: 286.18423 },\n            { nominal: 287, mass: 287.18678 },\n            { nominal: 288, mass: 288.18757 },\n            { nominal: 289, mass: 289.19042 },\n        ],\n        symbol: 'Fl',\n        name: 'Flerovium',\n        mass: null,\n    },\n    {\n        number: 115,\n        isotopes: [\n            { nominal: 287, mass: 287.1907 },\n            { nominal: 288, mass: 288.19274 },\n            { nominal: 289, mass: 289.19363 },\n            { nominal: 290, mass: 290.19598 },\n            { nominal: 291, mass: 291.19707 },\n        ],\n        symbol: 'Mc',\n        name: 'Moscovium',\n        mass: null,\n    },\n    {\n        number: 116,\n        isotopes: [\n            { nominal: 289, mass: 289.19816 },\n            { nominal: 290, mass: 290.19864 },\n            { nominal: 291, mass: 291.20108 },\n            { nominal: 292, mass: 292.20174 },\n            { nominal: 293, mass: 293.20449 },\n        ],\n        symbol: 'Lv',\n        name: 'Livermorium',\n        mass: null,\n    },\n    {\n        number: 117,\n        isotopes: [\n            { nominal: 291, mass: 291.20553 },\n            { nominal: 292, mass: 292.20746 },\n            { nominal: 293, mass: 293.20824 },\n            { nominal: 294, mass: 294.21046 },\n        ],\n        symbol: 'Ts',\n        name: 'Teennessine',\n        mass: null,\n    },\n    {\n        number: 118,\n        isotopes: [\n            { nominal: 293, mass: 293.21356 },\n            { nominal: 294, mass: 294.21392 },\n            { nominal: 295, mass: 295.21624 },\n        ],\n        symbol: 'Og',\n        name: 'Oganesson',\n        mass: null,\n    },\n];\n//# sourceMappingURL=elementsAndIsotopes.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.elements = void 0;\nconst elementsAndIsotopes_js_1 = require(\"./elementsAndIsotopes.js\");\nexports.elements = elementsAndIsotopes_js_1.elementsAndIsotopes.map((element) => ({\n    number: element.number,\n    symbol: element.symbol,\n    mass: element.mass,\n    name: element.name,\n    monoisotopicMass: element.monoisotopicMass,\n}));\n//# sourceMappingURL=elements.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.elementsAndIsotopesObject = void 0;\nconst elementsAndIsotopes_js_1 = require(\"./elementsAndIsotopes.js\");\nexports.elementsAndIsotopesObject = {};\nfor (const element of elementsAndIsotopes_js_1.elementsAndIsotopes) {\n    exports.elementsAndIsotopesObject[element.symbol] = element;\n}\n//# sourceMappingURL=elementsAndIsotopesObject.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.elementsAndStableIsotopes = void 0;\nconst elementsAndIsotopes_js_1 = require(\"./elementsAndIsotopes.js\");\nexports.elementsAndStableIsotopes = structuredClone(elementsAndIsotopes_js_1.elementsAndIsotopes);\nfor (const element of exports.elementsAndStableIsotopes) {\n    element.isotopes = element.isotopes.filter((i) => {\n        return typeof i.abundance === 'number' && i.abundance > 0;\n    });\n}\n//# sourceMappingURL=elementsAndStableIsotopes.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.elementsAndStableIsotopesObject = void 0;\nconst elementsAndStableIsotopes_js_1 = require(\"./elementsAndStableIsotopes.js\");\nexports.elementsAndStableIsotopesObject = {};\nfor (const element of elementsAndStableIsotopes_js_1.elementsAndStableIsotopes) {\n    exports.elementsAndStableIsotopesObject[element.symbol] = element;\n}\n//# sourceMappingURL=elementsAndStableIsotopesObject.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.elementsObject = void 0;\nconst elements_js_1 = require(\"./elements.js\");\nexports.elementsObject = {};\nfor (const element of elements_js_1.elements) {\n    exports.elementsObject[element.symbol] = element;\n}\n//# sourceMappingURL=elementsObject.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isotopesObject = void 0;\nconst elementsAndIsotopesObject_js_1 = require(\"./elementsAndIsotopesObject.js\");\nexports.isotopesObject = {};\nfor (const [symbol, element] of Object.entries(elementsAndIsotopesObject_js_1.elementsAndIsotopesObject)) {\n    if (!element)\n        continue;\n    for (const isotope of element.isotopes) {\n        exports.isotopesObject[`${isotope.nominal}${symbol}`] = {\n            abundance: isotope.abundance,\n            mass: isotope.mass,\n        };\n    }\n}\n//# sourceMappingURL=isotopesObject.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.stableIsotopesObject = void 0;\nconst elementsAndIsotopes_js_1 = require(\"./elementsAndIsotopes.js\");\nexports.stableIsotopesObject = {};\nfor (const element of elementsAndIsotopes_js_1.elementsAndIsotopes) {\n    let abundance = 0;\n    let mostAbundant = 0;\n    for (const isotope of element.isotopes) {\n        if (typeof isotope.abundance === 'number' &&\n            isotope.abundance > abundance) {\n            abundance = isotope.abundance;\n            mostAbundant = isotope.nominal;\n        }\n    }\n    for (const isotope of element.isotopes) {\n        if (isotope.abundance === 0)\n            continue;\n        const entry = {\n            name: element.name,\n            mass: isotope.mass,\n            symbol: element.symbol,\n            mostAbundant: false,\n        };\n        if (isotope.nominal === mostAbundant) {\n            entry.mostAbundant = true;\n        }\n        exports.stableIsotopesObject[`${isotope.nominal}${element.symbol}`] = entry;\n    }\n}\n//# sourceMappingURL=stableIsotopesObject.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.unsaturationsObject = void 0;\nexports.unsaturationsObject = {\n    O: 0,\n    N: 1,\n    H: -1,\n    Na: -1,\n    K: -1,\n    Li: -1,\n    Ca: -2,\n    C: 2,\n    F: -1,\n    Si: 2,\n    Cl: -1,\n    Br: -1,\n    I: -1,\n    S: 0,\n    P: 1,\n};\n//# sourceMappingURL=unsaturationsObject.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.groupsObject = void 0;\nconst groups_1 = require(\"./groups\");\nexports.groupsObject = {};\ngroups_1.groups.forEach((e) => {\n    if (exports.groupsObject[e.symbol]) {\n        // eslint-disable-next-line no-console\n        console.log(`The symbol ${e.symbol} is used more than once`);\n    }\n    exports.groupsObject[e.symbol] = e;\n});\n//# sourceMappingURL=groupsObject.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.groupsToSequence = groupsToSequence;\nconst groupsObject_js_1 = require(\"./groupsObject.js\");\n/**\n * Recreate a one letter sequence\n * @param {object} mf\n */\nfunction groupsToSequence(mf) {\n    mf = mf.replaceAll(/\\([^(]*\\)/g, '');\n    let parts = mf.split(/(?=[ A-Z])/);\n    let usefulParts = [];\n    for (let part of parts) {\n        if (part === ' ') {\n            usefulParts.push(' ');\n            continue;\n        }\n        if (!part.match(/^[A-Z][a-z]{2,6}/))\n            continue;\n        if (groupsObject_js_1.groupsObject[part] && groupsObject_js_1.groupsObject[part].oneLetter) {\n            usefulParts.push(groupsObject_js_1.groupsObject[part].oneLetter);\n        }\n        else {\n            usefulParts.push('?');\n        }\n    }\n    return usefulParts.join('').replaceAll(/ +/g, ' ').trim();\n}\n//# sourceMappingURL=groupsToSequence.js.map","\"use strict\";\n/**\n * Define static variable corresponding to the various Kinds of a molecular formula part.\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Kind = void 0;\nexports.Kind = {\n    BEGIN: 'begin',\n    ATOM: 'atom',\n    MULTIPLIER_RANGE: 'multiplierRange',\n    ISOTOPE: 'isotope',\n    ISOTOPE_RATIO: 'isotopeRatio',\n    CHARGE: 'charge',\n    SALT: 'salt',\n    OPENING_PARENTHESIS: 'openingParenthesis',\n    CLOSING_PARENTHESIS: 'closingParenthesis',\n    PRE_MULTIPLIER: 'preMultiplier',\n    MULTIPLIER: 'multiplier',\n    TEXT: 'text',\n    ANCHOR: 'anchor',\n    COMMENT: 'comment',\n};\n//# sourceMappingURL=Kind.js.map","\"use strict\";\n/**\n * Parse a string to extract the charge.\n * The charge may be in the form --, +++, +3, -2, 4+, 2-\n * @param {*} charge\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.parseCharge = parseCharge;\nfunction parseCharge(charge) {\n    charge = charge.replaceAll(/[()]/g, '');\n    let chargeNumber = 0;\n    if (charge.match(/^[+-]+$/)) {\n        for (let i = 0; i < charge.length; i++) {\n            if (charge.charAt(i) === '+')\n                chargeNumber++;\n            else\n                chargeNumber--;\n        }\n    }\n    else if (charge.match(/^\\d+[+-]$/)) {\n        chargeNumber = Number(\n        // eslint-disable-next-line unicorn/prefer-at\n        charge.charAt(charge.length - 1) + charge.slice(0, -1));\n    }\n    else {\n        chargeNumber = Number(charge);\n    }\n    return chargeNumber;\n}\n//# sourceMappingURL=parseCharge.js.map","\"use strict\";\n/* eslint-disable unicorn/prefer-code-point */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.parse = parse;\nconst atom_sorter_1 = require(\"atom-sorter\");\nconst chemical_elements_1 = require(\"chemical-elements\");\nconst chemical_groups_1 = require(\"chemical-groups\");\nconst Kind_1 = require(\"./Kind\");\nconst parseCharge_1 = require(\"./util/parseCharge\");\n/**\n * Parse a mf to an array of kind / value\n * @param {String} mf\n * @param {Object} [options={}]\n * @param {Boolean} [options.expandGroups=false] - if true, expand groups\n * @param {Boolean} [options.simplify=false] - if true, remove all the parenthesis and join identical atoms / groups\n */\nfunction parse(mf, options = {}) {\n    return new MFParser().parse(mf, options);\n}\nclass MFParser {\n    parse(mf = '', options = {}) {\n        this.expandGroups = options?.expandGroups ?? false;\n        this.simplify = options?.simplify ?? false;\n        this.mf = mf;\n        this.i = 0;\n        this.result = [];\n        let lastKind = Kind_1.Kind.BEGIN;\n        while (this.i < mf.length) {\n            if (this.result.length > 0 && this.result.at(-1).kind !== Kind_1.Kind.TEXT) {\n                lastKind = this.result.at(-1).kind;\n            }\n            let char = mf.charAt(this.i);\n            let ascii = mf.charCodeAt(this.i);\n            let nextAscii = 0;\n            if (this.i + 1 < mf.length)\n                nextAscii = mf.charCodeAt(this.i + 1);\n            if ((ascii > 47 && ascii < 58) ||\n                (char === '-' && nextAscii > 47 && nextAscii < 58)) {\n                // a number\n                let value = this.getNumber(ascii);\n                if (lastKind === Kind_1.Kind.SALT ||\n                    lastKind === Kind_1.Kind.BEGIN ||\n                    lastKind === Kind_1.Kind.OPENING_PARENTHESIS) {\n                    if (value.to) {\n                        throw new MFError(this.mf, this.i, 'Premultiplier may not contain a -');\n                    }\n                    this.result.push({ kind: Kind_1.Kind.PRE_MULTIPLIER, value: value.from });\n                }\n                else if (lastKind === Kind_1.Kind.ANCHOR) {\n                    if (value.to) {\n                        throw new MFError(this.mf, this.i, 'Anchor ID may not contain -');\n                    }\n                    this.result.at(-1).value = value.from;\n                }\n                else if (value.to) {\n                    this.result.push({\n                        kind: Kind_1.Kind.MULTIPLIER_RANGE,\n                        value: {\n                            from: Math.min(value.from, value.to),\n                            to: Math.max(value.from, value.to),\n                        },\n                    });\n                }\n                else {\n                    this.result.push({ kind: Kind_1.Kind.MULTIPLIER, value: value.from });\n                }\n                continue;\n            }\n            else if (char === '.') {\n                // a point\n                this.result.push({ kind: Kind_1.Kind.SALT, value: char });\n                // it is not in a number otherwise it would have been taken before\n                // it must be in a salt\n            }\n            else if (char === '#') {\n                // an anchor\n                this.result.push({ kind: Kind_1.Kind.ANCHOR, value: 0 });\n                // it is not in a number otherwise it would have been taken before\n                // it must be in a salt\n            }\n            else if (ascii > 64 && ascii < 91) {\n                // an uppercase = new atom\n                this.result.push(...this.getAtom(ascii));\n                continue;\n            }\n            else if (ascii > 96 && ascii < 123) {\n                // a lowercase\n                throw new MFError(this.mf, this.i, 'found a lowercase not following an uppercase');\n            }\n            else if (char === '(') {\n                let charge = this.getParenthesisCharge(ascii);\n                if (charge) {\n                    this.result.push({ kind: Kind_1.Kind.CHARGE, value: charge });\n                }\n                else {\n                    this.result.push({ kind: Kind_1.Kind.OPENING_PARENTHESIS, value: '(' });\n                }\n            }\n            else if (char === ')') {\n                this.result.push({ kind: Kind_1.Kind.CLOSING_PARENTHESIS, value: ')' });\n            }\n            else if (char === '[') {\n                // defines an isotope\n                let isotope = this.getIsotope(ascii);\n                this.result.push({ kind: Kind_1.Kind.ISOTOPE, value: isotope });\n            }\n            else if (char === ']') {\n                throw new MFError(this.mf, this.i, 'should never meet an closing bracket not in isotopes');\n            }\n            else if (char === '{') {\n                // can define an exotic isotopic ratio or mixtures of groups\n                let isotopeRatio = this.getCurlyBracketIsotopeRatio(ascii);\n                if (lastKind === Kind_1.Kind.ATOM) {\n                    let lastResult = this.result.at(-1);\n                    lastResult.kind = Kind_1.Kind.ISOTOPE_RATIO;\n                    lastResult.value = {\n                        atom: lastResult.value,\n                        ratio: isotopeRatio,\n                    };\n                }\n                else {\n                    throw new MFError(this.mf, this.i, 'isotopic composition has to follow an atom');\n                }\n            }\n            else if (char === '}') {\n                throw new MFError(this.mf, this.i, 'found a unexpected closing curly bracket');\n            }\n            else if (char === '+') {\n                // charge not in parenthesis\n                let charge = this.getNonParenthesisCharge(ascii);\n                this.result.push({ kind: Kind_1.Kind.CHARGE, value: charge });\n            }\n            else if (char === '-') {\n                // charge not in parenthesis\n                let charge = this.getNonParenthesisCharge(ascii);\n                this.result.push({ kind: Kind_1.Kind.CHARGE, value: charge });\n            }\n            else if (char === '$') {\n                // it is a comment after\n                this.result.push({\n                    kind: Kind_1.Kind.COMMENT,\n                    value: this.mf.slice(this.i + 1),\n                });\n                break;\n            }\n            else {\n                this.result.push({ kind: Kind_1.Kind.TEXT, value: char });\n            }\n            this.i++;\n        }\n        this.checkParenthesis();\n        if (this.simplify) {\n            this.result = simplify(this.result);\n        }\n        return this.result;\n    }\n    checkParenthesis() {\n        let counter = 0;\n        for (let line of this.result) {\n            if (line.kind === Kind_1.Kind.OPENING_PARENTHESIS)\n                counter++;\n            if (line.kind === Kind_1.Kind.CLOSING_PARENTHESIS)\n                counter--;\n        }\n        if (counter !== 0) {\n            throw new MFError(this.mf, this.i, 'number of opening and closing parenthesis not equal');\n        }\n    }\n    getNumber(ascii) {\n        let number = '';\n        let previous;\n        do {\n            previous = ascii;\n            number += String.fromCharCode(ascii);\n            this.i++;\n            ascii = this.mf.charCodeAt(this.i);\n        } while ((ascii > 47 && ascii < 58) ||\n            ascii === 46 ||\n            ascii === 45 ||\n            ascii === 47); // number . - /\n        // we need to deal with the case there is a from / to\n        if (previous === 46)\n            this.i--;\n        let indexOfDash = number.indexOf('-', 1);\n        if (indexOfDash > -1) {\n            return {\n                from: parseNumberWithDivision(number.slice(0, indexOfDash)),\n                to: parseNumberWithDivision(number.slice(indexOfDash + 1)),\n            };\n        }\n        return { from: parseNumberWithDivision(number) };\n    }\n    getAtom(ascii) {\n        let atom = '';\n        do {\n            atom += String.fromCharCode(ascii);\n            this.i++;\n            ascii = this.mf.charCodeAt(this.i);\n        } while (ascii > 96 && ascii < 123);\n        if (chemical_elements_1.elementsObject[atom] || !this.expandGroups) {\n            return [\n                {\n                    kind: Kind_1.Kind.ATOM,\n                    value: atom,\n                },\n            ];\n        }\n        if (chemical_groups_1.groupsObject[atom]) {\n            const group = chemical_groups_1.groupsObject[atom].mf;\n            const expandedGroups = parse(group, {\n                expandGroups: this.expandGroups,\n            });\n            // need to surround with parenthesis\n            return [\n                { kind: Kind_1.Kind.OPENING_PARENTHESIS, value: '(' },\n                ...expandedGroups,\n                { kind: Kind_1.Kind.CLOSING_PARENTHESIS, value: ')' },\n            ];\n        }\n        throw new MFError(`Not able to expand group: ${this.mf}`);\n    }\n    getIsotope(ascii) {\n        // [13C]\n        let substring = '';\n        do {\n            substring += String.fromCharCode(ascii);\n            this.i++;\n            ascii = this.mf.charCodeAt(this.i);\n        } while (ascii !== 93 && this.i <= this.mf.length);\n        let atom = substring.replaceAll(/[^A-Za-z]/g, '');\n        let isotope = Number(substring.replaceAll(/\\D/g, ''));\n        return { atom, isotope };\n    }\n    getCurlyBracketIsotopeRatio(ascii) {\n        let substring = '';\n        let first = true;\n        do {\n            if (!first) {\n                substring += String.fromCharCode(ascii);\n            }\n            else {\n                first = false;\n            }\n            this.i++;\n            ascii = this.mf.charCodeAt(this.i);\n        } while (ascii !== 125 && this.i <= this.mf.length); // closing curly bracket\n        if (substring.match(/^[0-9.,]+$/)) {\n            return substring.split(',').map(Number);\n        }\n        throw new MFError(this.mf, this.i, 'Curly brackets should contain only number, dot and comma');\n    }\n    getParenthesisCharge(ascii) {\n        let substring = '';\n        let begin = this.i;\n        do {\n            substring += String.fromCharCode(ascii);\n            this.i++;\n            ascii = this.mf.charCodeAt(this.i);\n        } while (ascii !== 41 && this.i <= this.mf.length); // closing parenthesis\n        if (substring.match(/^\\([\\d+-]+$/)) {\n            return (0, parseCharge_1.parseCharge)(substring.slice(1));\n        }\n        else {\n            this.i = begin;\n            return undefined;\n        }\n    }\n    getNonParenthesisCharge(ascii) {\n        let substring = '';\n        do {\n            substring += String.fromCharCode(ascii);\n            this.i++;\n            ascii = this.mf.charCodeAt(this.i);\n        } while (ascii === 43 || ascii === 45 || (ascii > 47 && ascii < 58));\n        this.i--;\n        return (0, parseCharge_1.parseCharge)(substring);\n    }\n}\nclass MFError extends SyntaxError {\n    constructor(mf, i, message) {\n        let text = `${message}\\n\\n${mf}\\n${' '.repeat(i)}^`;\n        super(text);\n    }\n}\nfunction parseNumberWithDivision(string) {\n    if (string.includes('/')) {\n        let parts = string.split('/');\n        if (parts.length !== 2) {\n            throw new TypeError('Can not parse MF with number like: ', string);\n        }\n        return Number(parts[0]) / Number(parts[1]);\n    }\n    else {\n        return Number(string);\n    }\n}\n/**\n * Remove all the parenthesis and multipliers\n * Merge atoms and groups if present many times\n * We will also sort the atoms and groups\n * @param {*} parsed\n * @returns\n */\nfunction simplify(parsed) {\n    if (!parsed || parsed.length === 0)\n        return [];\n    const multipliers = [];\n    let currentMultiplier = { from: 1, to: 1 };\n    let newParsed = [];\n    for (let i = parsed.length - 1; i >= 0; i--) {\n        const item = parsed[i];\n        switch (item.kind) {\n            case 'atom':\n            case 'isotope':\n                {\n                    let realMultiplier = currentMultiplier;\n                    for (const multiplier of multipliers) {\n                        realMultiplier = {\n                            from: multiplier.from * realMultiplier.from,\n                            to: multiplier.to * realMultiplier.to,\n                        };\n                    }\n                    newParsed.push({\n                        kind: item.kind,\n                        value: item.value,\n                    }, {\n                        kind: 'multiplierRange',\n                        value: realMultiplier,\n                    });\n                    currentMultiplier = { from: 1, to: 1 };\n                }\n                break;\n            case 'multiplier':\n                currentMultiplier = { from: item.value, to: item.value };\n                break;\n            case 'multiplierRange':\n                currentMultiplier = item.value;\n                break;\n            case 'openingParenthesis':\n                multipliers.pop();\n                break;\n            case 'closingParenthesis':\n                multipliers.push(currentMultiplier);\n                currentMultiplier = { from: 1, to: 1 };\n                break;\n            case 'text':\n                break;\n            default:\n                throw new Error(`Unexpected kind --${item.kind}-- in removeParenthesis`);\n        }\n    }\n    // if we have many times the same atom / group, we can merge them\n    const distinctParsedObject = {};\n    for (let i = 0; i < newParsed.length; i = i + 2) {\n        const item = newParsed[i];\n        const multiplier = newParsed[i + 1];\n        const key = JSON.stringify(item.value);\n        if (!distinctParsedObject[key]) {\n            distinctParsedObject[key] = {\n                ...item,\n                multiplier: multiplier.value,\n            };\n        }\n        else {\n            distinctParsedObject[key].multiplier.from += multiplier.value.from;\n            distinctParsedObject[key].multiplier.to += multiplier.value.to;\n        }\n    }\n    const sorted = Object.values(distinctParsedObject).sort((a, b) => {\n        const atomA = a.kind === 'atom' ? a.value : a.value.atom;\n        const atomB = b.kind === 'atom' ? b.value : b.value.atom;\n        if (atomA === atomB) {\n            if (a.kind === 'isotope' && b.kind === 'isotope') {\n                return a.value.isotope - b.value.isotope;\n            }\n            if (a.kind === 'isotope' && b.kind !== 'isotope') {\n                return -1; // isotope comes before non-isotope\n            }\n            if (a.kind !== 'isotope' && b.kind === 'isotope') {\n                return 1; // non-isotope comes after isotope\n            }\n            return 0;\n        }\n        return (0, atom_sorter_1.atomSorter)(atomA, atomB);\n    });\n    const distinctParsed = [];\n    for (const item of sorted) {\n        if (item.multiplier.from === 0 && item.multiplier.to === 0) {\n            continue;\n        }\n        distinctParsed.push({\n            kind: item.kind,\n            value: item.value,\n        });\n        if (item.multiplier.from === 1 && item.multiplier.to === 1) {\n            continue; // no need to add a multiplier\n        }\n        if (item.multiplier.from === item.multiplier.to) {\n            distinctParsed.push({\n                kind: 'multiplier',\n                value: item.multiplier.from,\n            });\n        }\n        else {\n            distinctParsed.push({\n                kind: 'multiplierRange',\n                value: {\n                    from: item.multiplier.from,\n                    to: item.multiplier.to,\n                },\n            });\n        }\n    }\n    return distinctParsed;\n}\n//# sourceMappingURL=parse.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.subscript = exports.superscript = void 0;\nexports.superscript = {\n    0: '⁰',\n    1: '¹',\n    2: '²',\n    3: '³',\n    4: '⁴',\n    5: '⁵',\n    6: '⁶',\n    7: '⁷',\n    8: '⁸',\n    9: '⁹',\n    '+': '⁺',\n    '-': '⁻',\n    '(': '⁽',\n    ')': '⁾',\n    '{': '⁽',\n    '}': '⁾',\n    '.': '˙',\n    ',': '˒',\n};\nexports.subscript = {\n    0: '₀',\n    1: '₁',\n    2: '₂',\n    3: '₃',\n    4: '₄',\n    5: '₅',\n    6: '₆',\n    7: '₇',\n    8: '₈',\n    9: '₉',\n    '(': '₍',\n    ')': '₎',\n    '{': '₍',\n    '}': '₎',\n    '.': ' ',\n    ',': ' ',\n};\n//# sourceMappingURL=subSuperscript.js.map","\"use strict\";\n/**\n * Defines static variables corresponding to the various formatting possibilities\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Format = void 0;\nexports.Format = {\n    SUBSCRIPT: 'subscript',\n    SUPERSCRIPT: 'superscript',\n    SUPERIMPOSE: 'superimpose',\n    TEXT: 'text',\n};\n//# sourceMappingURL=Format.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.formatCharge = formatCharge;\nfunction formatCharge(charge) {\n    if (charge === 1)\n        return '+';\n    if (charge > 1)\n        return `+${charge}`;\n    if (charge < 0)\n        return String(charge);\n    return '';\n}\n//# sourceMappingURL=formatCharge.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.improveLinesForDisplay = improveLinesForDisplay;\nconst Kind_js_1 = require(\"../Kind.js\");\n/**\n * We try to remove useless lines that are not needed for the display and could be confusing\n * for the user\n * @param {object[]} lines\n */\nfunction improveLinesForDisplay(lines) {\n    lines = lines.slice(0);\n    // multipliers by one seems completely useless\n    lines = lines.filter((line) => !(line.kind === Kind_js_1.Kind.MULTIPLIER && line.value === 1));\n    // global surrouding useless parenthesis\n    // (C) -> C, (CH2) -> CH2, ((CH2)) -> CH2, ((CH2)2) -> (CH2)2, (C(CH2)2) -> C(CH2)2\n    // need to count the number of opening parenthesis\n    // and check the minimum number of parenthesis we find\n    let beginCounter = 0;\n    let endCounter = 0;\n    let minCounter = Number.MAX_SAFE_INTEGER;\n    let counter = 0;\n    let begin = true;\n    for (let line of lines) {\n        switch (line.kind) {\n            case Kind_js_1.Kind.OPENING_PARENTHESIS:\n                if (begin) {\n                    beginCounter++;\n                }\n                counter++;\n                break;\n            case Kind_js_1.Kind.CLOSING_PARENTHESIS:\n                endCounter++;\n                counter--;\n                break;\n            case Kind_js_1.Kind.CHARGE: // seems to me we can still remove parenthesis even if we have some charges\n                break;\n            default:\n                if (counter < minCounter)\n                    minCounter = counter;\n                endCounter = 0;\n                begin = false;\n        }\n    }\n    let nbParenthesisToSuppress = Math.min(minCounter, beginCounter, endCounter);\n    if (nbParenthesisToSuppress > 0) {\n        // need to remove from the beginning and from the end the number of parenthesis\n        // knowing some of the lines could be charges\n        let toSuppress = nbParenthesisToSuppress;\n        let i = 0;\n        while (toSuppress > 0) {\n            if (lines[0].kind === Kind_js_1.Kind.OPENING_PARENTHESIS) {\n                lines.splice(i, 1);\n                toSuppress--;\n            }\n            else {\n                i++;\n            }\n        }\n        toSuppress = nbParenthesisToSuppress;\n        i = lines.length - 1;\n        while (toSuppress > 0) {\n            if (lines[i].kind === Kind_js_1.Kind.CLOSING_PARENTHESIS) {\n                toSuppress--;\n                lines.splice(i, 1);\n            }\n            i--;\n        }\n    }\n    return lines;\n}\n//# sourceMappingURL=improveLinesForDisplay.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.toDisplay = toDisplay;\nconst Format_1 = require(\"../Format\");\nconst Kind_1 = require(\"../Kind\");\nconst formatCharge_js_1 = require(\"./formatCharge.js\");\nconst improveLinesForDisplay_js_1 = require(\"./improveLinesForDisplay.js\");\n/**\n * Converts an array of mf elements to an array of formatting information\n * @param {object[]} lines of the parse method\n * @returns {{kind: string, value: string}[]}\n */\nfunction toDisplay(lines) {\n    lines = (0, improveLinesForDisplay_js_1.improveLinesForDisplay)(lines);\n    const special = specialCases(lines);\n    if (special)\n        return special;\n    let results = [];\n    let result = {};\n    for (let line of lines) {\n        switch (line.kind) {\n            case Kind_1.Kind.MULTIPLIER:\n                if (line.value !== 1) {\n                    result = {\n                        kind: Format_1.Format.SUBSCRIPT,\n                        value: String(line.value),\n                    };\n                    results.push(result);\n                }\n                break;\n            case Kind_1.Kind.MULTIPLIER_RANGE:\n                result = {\n                    kind: Format_1.Format.SUBSCRIPT,\n                    value: `${String(line.value.from)}-${line.value.to}`,\n                };\n                results.push(result);\n                break;\n            case Kind_1.Kind.CHARGE:\n                if (result.kind === Format_1.Format.SUBSCRIPT) {\n                    result.kind = Format_1.Format.SUPERIMPOSE;\n                    result.over = (0, formatCharge_js_1.formatCharge)(line.value);\n                    result.under = result.value;\n                    result.value = undefined;\n                }\n                else {\n                    result = {\n                        kind: Format_1.Format.SUPERSCRIPT,\n                        value: (0, formatCharge_js_1.formatCharge)(line.value),\n                    };\n                    results.push(result);\n                }\n                break;\n            case Kind_1.Kind.ISOTOPE:\n                result = {\n                    kind: Format_1.Format.SUPERSCRIPT,\n                    value: line.value.isotope,\n                };\n                results.push(result);\n                result = {\n                    kind: Format_1.Format.TEXT,\n                    value: line.value.atom,\n                };\n                results.push(result);\n                break;\n            case Kind_1.Kind.ISOTOPE_RATIO:\n                if (result.kind === Format_1.Format.TEXT) {\n                    result.value += line.value.atom;\n                }\n                else {\n                    result = {\n                        kind: Format_1.Format.TEXT,\n                        value: line.value.atom,\n                    };\n                    results.push(result);\n                }\n                result = {\n                    kind: Format_1.Format.SUPERSCRIPT,\n                    value: `{${line.value.ratio.join(',')}}`,\n                };\n                results.push(result);\n                break;\n            case Kind_1.Kind.SALT:\n                if (result.kind === Format_1.Format.TEXT) {\n                    result.value += ' • ';\n                }\n                else {\n                    result = {\n                        kind: Format_1.Format.TEXT,\n                        value: ' • ',\n                    };\n                    results.push(result);\n                }\n                break;\n            default:\n                if (result.kind === Format_1.Format.TEXT) {\n                    result.value += line.value;\n                }\n                else {\n                    result = {\n                        kind: Format_1.Format.TEXT,\n                        value: line.value,\n                    };\n                    results.push(result);\n                }\n        }\n    }\n    return results;\n}\n/**\n * Some special changes for specific cases\n * @param {} lines\n */\nfunction specialCases(lines) {\n    // (-)\n    if (lines.length === 1 && lines[0].kind === Kind_1.Kind.CHARGE) {\n        const charge = lines[0].value;\n        if (charge === 0)\n            return [];\n        if (charge === 1) {\n            return [\n                { kind: Format_1.Format.TEXT, value: '-e' },\n                { kind: Format_1.Format.SUPERSCRIPT, value: '-' },\n            ];\n        }\n        if (charge === -1) {\n            return [\n                { kind: Format_1.Format.TEXT, value: '+e' },\n                { kind: Format_1.Format.SUPERSCRIPT, value: '-' },\n            ];\n        }\n        if (charge > 1) {\n            return [\n                { kind: Format_1.Format.TEXT, value: `-${charge}e` },\n                { kind: Format_1.Format.SUPERSCRIPT, value: '-' },\n            ];\n        }\n        if (charge < -1) {\n            return [\n                { kind: Format_1.Format.TEXT, value: `+${-charge}e` },\n                { kind: Format_1.Format.SUPERSCRIPT, value: '-' },\n            ];\n        }\n    }\n    // (-)2, (-)-1, (+)2, (+)-1, (2+)2, (2+)-1, (2-)+1, (2-)-1\n    if (lines.length === 2 &&\n        lines[0].kind === Kind_1.Kind.CHARGE &&\n        lines[1].kind === Kind_1.Kind.MULTIPLIER) {\n        const charge = lines[0].value;\n        const nbElectrons = -lines[1].value * charge;\n        const results = [];\n        if (nbElectrons === 0)\n            return [];\n        if (nbElectrons === 1) {\n            results.push({ kind: Format_1.Format.TEXT, value: '+e' });\n        }\n        if (nbElectrons === -1) {\n            results.push({ kind: Format_1.Format.TEXT, value: '-e' });\n        }\n        if (nbElectrons > 1) {\n            results.push({ kind: Format_1.Format.TEXT, value: `+${nbElectrons}e` });\n        }\n        if (nbElectrons < -1) {\n            results.push({ kind: Format_1.Format.TEXT, value: `${nbElectrons}e` });\n        }\n        results.push({ kind: Format_1.Format.SUPERSCRIPT, value: '-' });\n        return results;\n    }\n    return undefined;\n}\n//# sourceMappingURL=toDisplay.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isMF = isMF;\nconst chemical_elements_1 = require(\"chemical-elements\");\nconst chemical_groups_1 = require(\"chemical-groups\");\nfunction isMF(mf) {\n    let tmpMF = mf.replaceAll(/[^A-Za-z]/g, '');\n    let parts = tmpMF.replaceAll(/([A-Za-z])(?=[A-Z])/g, '$1 ').split(' ');\n    for (let i = 0; i < parts.length; i++) {\n        if (!chemical_elements_1.elementsObject[parts[i]] && !chemical_groups_1.groupsObject[parts[i]]) {\n            return false;\n        }\n    }\n    return true;\n}\n//# sourceMappingURL=isMF.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Style = void 0;\nexports.Style = {\n    SUPERIMPOSE: 'flex-direction: column;display: inline-flex;justify-content: center;text-align: left;vertical-align: middle;',\n    SUPERIMPOSE_SUP_SUB: 'line-height: 1; font-size: 70%',\n};\n//# sourceMappingURL=Style.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.toHtml = toHtml;\nconst Format_1 = require(\"../Format\");\nconst Style_1 = require(\"../Style\");\nfunction toHtml(lines) {\n    let html = [];\n    for (let line of lines) {\n        switch (line.kind) {\n            case Format_1.Format.SUBSCRIPT:\n                html.push(`<sub>${line.value}</sub>`);\n                break;\n            case Format_1.Format.SUPERSCRIPT:\n                html.push(`<sup>${line.value}</sup>`);\n                break;\n            case Format_1.Format.SUPERIMPOSE:\n                html.push(`<span style=\"${Style_1.Style.SUPERIMPOSE}\">`, `<sup style=\"${Style_1.Style.SUPERIMPOSE_SUP_SUB}\">${line.over}</sup>`, `<sub style=\"${Style_1.Style.SUPERIMPOSE_SUP_SUB}\">${line.under}</sub>`, '</span>');\n                break;\n            default:\n                html.push(line.value);\n        }\n    }\n    return html.join('');\n}\n//# sourceMappingURL=toHtml.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ensureCase = ensureCase;\nconst chemical_elements_1 = require(\"chemical-elements\");\nconst elements = new Set(Object.keys(chemical_elements_1.elementsObject).sort((a, b) => b.length - a.length));\n/**\n * Ensure that the mf has been entered with capital letters and not only lowercase\n * If there is only lowercase we try to capitalize the mf\n * @param {string} mf\n */\nfunction ensureCase(mf) {\n    for (let i = 0; i < mf.length; i++) {\n        // eslint-disable-next-line unicorn/prefer-code-point\n        if (mf.charCodeAt(i) > 64 && mf.charCodeAt(i) < 91) {\n            return mf;\n        }\n    }\n    let parts = mf.replaceAll(/([a-z]*)([^a-z]*)/g, '$1 $2 ').split(/ +/);\n    for (let i = 0; i < parts.length; i++) {\n        if (parts[i].match(/^[a-z]$/)) {\n            parts[i] = parts[i].toUpperCase();\n        }\n        else if (parts[i].match(/^[a-z]+$/)) {\n            let newPart = '';\n            for (let j = 0; j < parts[i].length; j++) {\n                let two = parts[i].slice(j, j + 2);\n                let one = parts[i].charAt(j).toUpperCase();\n                if (['c', 'h', 'o', 'n'].includes(two.charAt(0)) &&\n                    ['h', 'o', 'n'].includes(two.charAt(1))) {\n                    newPart += two.toUpperCase();\n                    j++;\n                }\n                else {\n                    two = two.charAt(0).toUpperCase() + two.charAt(1);\n                    if (elements.has(two)) {\n                        newPart += two;\n                        j++;\n                    }\n                    else if (elements.has(one)) {\n                        newPart += one;\n                    }\n                    else {\n                        return mf;\n                    }\n                }\n            }\n            parts[i] = newPart;\n        }\n    }\n    return parts.join('');\n}\n//# sourceMappingURL=ensureCase.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.flatten = flatten;\n/**\n * This method will generate all possible molecular formulas\n * from ranges.\n * It should rather be called expand because it expands all the ranges\n * @param parsed\n * @param options\n * @return {string[]}\n */\nfunction flatten(parsed, options = {}) {\n    const { groupIdentical = false, limit = 100000 } = options;\n    if (parsed.length === 0)\n        return [''];\n    let parts = [];\n    let parenthesisLevel = 0;\n    let currentPart;\n    let comments = [];\n    for (const entry of parsed) {\n        if ((entry.kind === 'atom' ||\n            entry.kind === 'charge' ||\n            entry.kind === 'isotope' ||\n            entry.kind === 'openingParenthesis' ||\n            !currentPart) &&\n            parenthesisLevel === 0) {\n            currentPart = {\n                mf: '',\n                min: 1,\n                max: 1,\n            };\n            parts.push(currentPart);\n        }\n        switch (entry.kind) {\n            case 'atom':\n                currentPart.mf += entry.value;\n                break;\n            case 'isotope':\n                currentPart.mf += `[${entry.value.isotope}${entry.value.atom}]`;\n                break;\n            case 'multiplier':\n                currentPart.mf += entry.value;\n                break;\n            case 'multiplierRange':\n                if (parenthesisLevel !== 0) {\n                    throw new Error('Range definition inside parenthesis is not allowed.');\n                }\n                currentPart.min = entry.value.from;\n                currentPart.max = entry.value.to;\n                break;\n            case 'openingParenthesis':\n                parenthesisLevel++;\n                currentPart.mf += entry.value;\n                break;\n            case 'charge':\n                if (entry.value === 1) {\n                    currentPart.mf += '+';\n                }\n                else if (entry.value > 1) {\n                    currentPart.mf += `(+${entry.value})`;\n                }\n                else if (entry.value < 0) {\n                    currentPart.mf += `(${entry.value})`;\n                }\n                break;\n            case 'closingParenthesis':\n                parenthesisLevel--;\n                currentPart.mf += entry.value;\n                break;\n            case 'comment':\n                comments.push(entry.value);\n                break;\n            case 'text':\n                break;\n            default:\n                throw new Error(`Could not flatten the parsed MF. Unknown kind: ${entry.kind}`);\n        }\n    }\n    if (groupIdentical) {\n        parts = optimizeRanges(parts);\n    }\n    const mfs = createMFs(parts, comments.join(' '), limit);\n    return mfs;\n}\n/**\n * If we have many times the same mf we can combine them\n * This should only be applied if there are acutaly some ranges\n */\nfunction optimizeRanges(parts) {\n    let newParts = [];\n    let mfsObject = {};\n    let hasRange = false;\n    for (const mf of parts) {\n        if (mf.min !== mf.max) {\n            hasRange = true;\n            break;\n        }\n    }\n    if (!hasRange)\n        return parts;\n    for (const mf of parts) {\n        if (!mfsObject[mf.mf]) {\n            mfsObject[mf.mf] = {\n                mf: mf.mf,\n                min: mf.min,\n                max: mf.max,\n            };\n            newParts.push(mfsObject[mf.mf]);\n        }\n        else {\n            mfsObject[mf.mf].min = mfsObject[mf.mf].min + mf.min;\n            mfsObject[mf.mf].max = mfsObject[mf.mf].max + mf.max;\n        }\n    }\n    return newParts;\n}\nfunction createMFs(parts, comment, limit) {\n    const currents = new Array(parts.length);\n    for (let i = 0; i < currents.length; i++) {\n        currents[i] = parts[i].min;\n    }\n    /** @type {string[]} */\n    const mfs = [];\n    let position = 0;\n    while (position < currents.length) {\n        if (currents[position] < parts[position].max) {\n            mfs.push(getMF(parts, currents, comment));\n            currents[position]++;\n            for (let i = 0; i < position; i++) {\n                currents[i] = parts[i].min;\n            }\n            position = 0;\n        }\n        else {\n            position++;\n        }\n        if (mfs.length > limit) {\n            throw new Error(`MF.flatten generates too many fragments (over ${limit})`);\n        }\n    }\n    mfs.push(getMF(parts, currents, comment));\n    return mfs;\n}\nfunction getMF(parts, currents, comment) {\n    let mf = '';\n    for (let i = 0; i < parts.length; i++) {\n        if (currents[i] === 0) {\n            continue;\n        }\n        mf += parts[i].mf;\n        if (currents[i] !== 1) {\n            mf += currents[i];\n        }\n    }\n    if (comment)\n        mf += `$${comment}`;\n    return mf;\n}\n//# sourceMappingURL=flatten.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getIsotopeRatioInfo = getIsotopeRatioInfo;\nconst chemical_elements_1 = require(\"chemical-elements\");\nfunction getIsotopeRatioInfo(value) {\n    let result = { mass: 0, monoisotopicMass: 0 };\n    let element = chemical_elements_1.elementsAndStableIsotopesObject[value.atom];\n    if (!element)\n        throw new Error(`Element not found: ${value.atom}`);\n    let isotopesArray = element.isotopes;\n    let ratios = normalize(value.ratio);\n    let max = Math.max(...ratios);\n    if (ratios.length > isotopesArray.length) {\n        throw new Error(`the number of specified ratios is bigger that the number of stable isotopes: ${value.atom}`);\n    }\n    for (let i = 0; i < ratios.length; i++) {\n        result.mass += ratios[i] * isotopesArray[i].mass;\n        if (max === ratios[i] && result.monoisotopicMass === 0) {\n            result.monoisotopicMass = isotopesArray[i].mass;\n        }\n    }\n    return result;\n}\nfunction normalize(array) {\n    let sum = array.reduce((prev, current) => prev + current, 0);\n    return array.map((a) => a / sum);\n}\n//# sourceMappingURL=getIsotopeRatioInfo.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getEA = getEA;\nconst chemical_elements_1 = require(\"chemical-elements\");\nconst chemical_groups_1 = require(\"chemical-groups\");\nconst Kind_1 = require(\"../Kind\");\nconst getIsotopeRatioInfo_1 = require(\"./getIsotopeRatioInfo\");\n/**\n * @param {*} parts\n */\nfunction getEA(parts) {\n    let results = {};\n    for (let part of parts) {\n        for (let line of part) {\n            switch (line.kind) {\n                case Kind_1.Kind.ISOTOPE: {\n                    let isotope = chemical_elements_1.isotopesObject[line.value.isotope + line.value.atom];\n                    if (!isotope) {\n                        throw new Error(`Unknown isotope: ${line.value.isotope}${line.value.atom}`);\n                    }\n                    addMass(results, line.value.atom, isotope.mass * line.multiplier);\n                    break;\n                }\n                case Kind_1.Kind.ISOTOPE_RATIO: {\n                    let isotopeRatioInfo = (0, getIsotopeRatioInfo_1.getIsotopeRatioInfo)(line.value);\n                    addMass(results, line.value.atom, isotopeRatioInfo.mass * line.multiplier);\n                    break;\n                }\n                case Kind_1.Kind.ATOM: {\n                    let element = chemical_elements_1.elementsObject[line.value];\n                    if (!element) {\n                        element = chemical_groups_1.groupsObject[line.value];\n                        if (!element)\n                            throw new Error(`Unknown element: ${line.value}`);\n                        // need to explode group ????\n                    }\n                    addMass(results, line.value, element.mass * line.multiplier);\n                    break;\n                }\n                case Kind_1.Kind.CHARGE:\n                    break;\n                default:\n                    throw new Error('partToMF unhandled Kind: ', line.kind);\n            }\n        }\n    }\n    let eas = [];\n    let sum = 0;\n    for (let key in results) {\n        sum += results[key];\n        eas.push({\n            element: key,\n            mass: results[key],\n        });\n    }\n    for (const ea of eas) {\n        ea.ratio = ea.mass / sum;\n    }\n    return eas;\n}\nfunction addMass(results, atom, mass) {\n    if (!results[atom])\n        results[atom] = 0;\n    results[atom] += mass;\n}\n//# sourceMappingURL=getEA.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getElements = getElements;\nconst chemical_elements_1 = require(\"chemical-elements\");\nconst Kind_1 = require(\"../Kind\");\n/**\n * @param {*} parts\n */\nfunction getElements(parts) {\n    const elements = [];\n    for (const part of parts) {\n        for (const line of part) {\n            let number = line.multiplier;\n            switch (line.kind) {\n                case Kind_1.Kind.ATOM: {\n                    let symbol = line.value;\n                    let element = chemical_elements_1.elementsObject[symbol];\n                    if (!element) {\n                        throw new Error(`element unknown: ${symbol} - ${line}`);\n                    }\n                    addElement(elements, { symbol, number });\n                    break;\n                }\n                case Kind_1.Kind.ISOTOPE: {\n                    let element = chemical_elements_1.elementsAndIsotopesObject[line.value.atom];\n                    if (!element) {\n                        throw new Error(`element unknown: ${part.value.atom} - ${line}`);\n                    }\n                    let isotope = element.isotopes.find((a) => a.nominal === line.value.isotope);\n                    if (!isotope) {\n                        throw new Error(`isotope unknown: ${line.value.isotope} - ${line}`);\n                    }\n                    addElement(elements, {\n                        symbol: line.value.atom,\n                        number,\n                        isotope: line.value.isotope,\n                    });\n                    break;\n                }\n                default:\n                    throw new Error(`unknown type: ${line.kind}`);\n            }\n        }\n    }\n    return elements;\n}\nfunction addElement(elements, newElement) {\n    for (let element of elements) {\n        if (element.symbol === newElement.symbol &&\n            element.isotope === newElement.isotope) {\n            element.number += newElement.number;\n            return;\n        }\n    }\n    elements.push(newElement);\n}\n//# sourceMappingURL=getElements.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getNumberOfIsotopologues = getNumberOfIsotopologues;\nconst chemical_elements_1 = require(\"chemical-elements\");\n/**\n * Returns the theoretical number of isotopologues for a given MF based on stable isotopes for each element.\n * This method will not take into account possible non natural isotopic composition (e.g. 13C enrichment)\n * If one element does not have any stable isotope, the result will be 0.\n * @param atoms\n * @returns\n */\nfunction getNumberOfIsotopologues(atoms) {\n    if (Object.keys(atoms).length === 0) {\n        return 0;\n    }\n    let result = 1;\n    for (const atom in atoms) {\n        const nbIsotopes = chemical_elements_1.elementsAndStableIsotopesObject[atom]?.isotopes.length;\n        if (!nbIsotopes) {\n            return 0;\n        }\n        const nbAtoms = atoms[atom];\n        result *= getNbCombinationsPerAtom(nbAtoms, nbIsotopes);\n    }\n    return result;\n}\n/**\n * Returns the number of isotopologues for one specific atom\n *\n * @param nbAtoms\n * @param nbIsotopes\n * @returns\n */\nfunction getNbCombinationsPerAtom(nbAtoms, nbIsotopes) {\n    let result = 1;\n    for (let i = nbAtoms + 1; i < nbAtoms + nbIsotopes; i++) {\n        result *= i;\n    }\n    for (let i = 2; i < nbIsotopes; i++) {\n        result /= i;\n    }\n    return result;\n}\n//# sourceMappingURL=getNumberOfIsotopologues.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.partToAtoms = partToAtoms;\nconst Kind_js_1 = require(\"../Kind.js\");\n/** @typedef {import('./partToAtoms.types').AtomsMap} AtomsMap */\n/**\n * Convert a MF part to a map of atoms\n * This procedure will suppress the isotopes !\n * This is mainly used to make queries\n * @returns {AtomsMap}\n */\nfunction partToAtoms(part) {\n    /** @type {AtomsMap} */\n    const atoms = {};\n    for (let line of part) {\n        switch (line.kind) {\n            case Kind_js_1.Kind.ISOTOPE:\n                if (!atoms[line.value.atom])\n                    atoms[line.value.atom] = 0;\n                atoms[line.value.atom] += line.multiplier;\n                break;\n            case Kind_js_1.Kind.ISOTOPE_RATIO:\n                if (!atoms[line.value.atom])\n                    atoms[line.value.atom] = 0;\n                atoms[line.value.atom] += line.multiplier;\n                break;\n            case Kind_js_1.Kind.ATOM:\n                if (!atoms[line.value])\n                    atoms[line.value] = 0;\n                atoms[line.value] += line.multiplier;\n                break;\n            case Kind_js_1.Kind.CHARGE:\n                break;\n            case Kind_js_1.Kind.ANCHOR:\n                break;\n            default:\n                throw new Error('partToMF unhandled Kind: ', line.kind);\n        }\n    }\n    return atoms;\n}\n//# sourceMappingURL=partToAtoms.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.partToMF = partToMF;\nconst Kind_1 = require(\"../Kind\");\nfunction partToMF(part, options = {}) {\n    let mf = [];\n    for (let line of part) {\n        switch (line.kind) {\n            case Kind_1.Kind.ISOTOPE:\n                if (line.multiplier !== 0) {\n                    mf.push(`[${line.value.isotope}${line.value.atom}]${line.multiplier !== 1 ? line.multiplier : ''}`);\n                }\n                break;\n            case Kind_1.Kind.ISOTOPE_RATIO:\n                if (line.multiplier !== 0) {\n                    mf.push(`${line.value.atom}{${line.value.ratio.join(',')}}${line.multiplier !== 1 ? line.multiplier : ''}`);\n                }\n                break;\n            case Kind_1.Kind.ATOM:\n                if (line.multiplier !== 0) {\n                    mf.push(line.value + (line.multiplier !== 1 ? line.multiplier : ''));\n                }\n                break;\n            case Kind_1.Kind.CHARGE:\n                if (line.value === 0 || options.neutral)\n                    break;\n                mf.push(`(${line.value > 0 ? `+${line.value}` : line.value})`);\n                break;\n            default:\n        }\n    }\n    return mf.join('');\n}\n//# sourceMappingURL=partToMF.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getInfoInternal = getInfoInternal;\nconst chemical_elements_1 = require(\"chemical-elements\");\nconst chemical_groups_1 = require(\"chemical-groups\");\nconst Kind_1 = require(\"../Kind\");\nconst getIsotopeRatioInfo_1 = require(\"./getIsotopeRatioInfo\");\nconst getNumberOfIsotopologues_1 = require(\"./getNumberOfIsotopologues\");\nconst partToAtoms_1 = require(\"./partToAtoms\");\nconst partToMF_1 = require(\"./partToMF\");\n/** @typedef {import('./getInfo.types').MFInfo} MFInfo */\n/** @typedef {import('./getInfo.types').MFInfoWithParts} MFInfoWithParts */\n/**\n *\n * @param {*} parts\n * @param {*} [options={}]\n * @returns {object|MFInfo|MFInfoWithParts}\n */\nfunction getInfoInternal(parts, options = {}) {\n    let { customUnsaturations = {}, emFieldName = 'monoisotopicMass', msemFieldName = 'observedMonoisotopicMass', } = options;\n    if (parts.length === 0)\n        return {};\n    if (parts.length === 1) {\n        let oneResult = getProcessedPart(parts[0], {\n            customUnsaturations,\n            emFieldName,\n            msemFieldName,\n        });\n        oneResult.nbIsotopologues = (0, getNumberOfIsotopologues_1.getNumberOfIsotopologues)(oneResult.atoms);\n        return oneResult;\n    }\n    let result = { parts: [] };\n    for (let part of parts) {\n        result.parts.push(getProcessedPart(part, {\n            customUnsaturations,\n            emFieldName,\n            msemFieldName,\n        }));\n    }\n    result[emFieldName] = 0;\n    result.mass = 0;\n    result.charge = 0;\n    result.unsaturation = 0;\n    result.atoms = {};\n    result.mf = result.parts.map((a) => a.mf).join('.');\n    for (const part of result.parts) {\n        result.mass += part.mass;\n        result[emFieldName] += part[emFieldName];\n        result.charge += part.charge;\n        result.unsaturation += part.unsaturation;\n        for (const atom in part.atoms) {\n            if (!result.atoms[atom]) {\n                result.atoms[atom] = 0;\n            }\n            result.atoms[atom] += part.atoms[atom];\n        }\n    }\n    result.nbIsotopologues = (0, getNumberOfIsotopologues_1.getNumberOfIsotopologues)(result.atoms);\n    return result;\n}\nfunction getProcessedPart(part, options) {\n    let { customUnsaturations, emFieldName, msemFieldName } = options;\n    /** @type {MFInfo} */\n    let currentPart = {\n        mass: 0,\n        charge: 0,\n        mf: '',\n        atoms: (0, partToAtoms_1.partToAtoms)(part),\n    };\n    currentPart[emFieldName] = 0;\n    let unsaturation = 0;\n    let validUnsaturation = true;\n    currentPart.mf = (0, partToMF_1.partToMF)(part);\n    for (let line of part) {\n        let currentElement = '';\n        switch (line.kind) {\n            case Kind_1.Kind.ATOM: {\n                currentElement = line.value;\n                let element = chemical_elements_1.elementsAndIsotopesObject[line.value];\n                // todo should we have a kind GROUP ?\n                if (!element) {\n                    element = chemical_groups_1.groupsObject[line.value];\n                    if (!element)\n                        throw new Error(`Unknown element: ${line.value}`);\n                    if (!customUnsaturations[line.value]) {\n                        customUnsaturations[line.value] = element.unsaturation;\n                    }\n                }\n                if (!element)\n                    throw new Error(`Unknown element: ${line.value}`);\n                currentPart[emFieldName] += element.monoisotopicMass * line.multiplier;\n                currentPart.mass += element.mass * line.multiplier;\n                break;\n            }\n            case Kind_1.Kind.ISOTOPE: {\n                currentElement = line.value.atom;\n                let isotope = chemical_elements_1.isotopesObject[line.value.isotope + line.value.atom];\n                if (!isotope) {\n                    throw new Error(`Unknown isotope: ${line.value.isotope}${line.value.atom}`);\n                }\n                currentPart[emFieldName] += isotope.mass * line.multiplier;\n                currentPart.mass += isotope.mass * line.multiplier;\n                break;\n            }\n            case Kind_1.Kind.ISOTOPE_RATIO: {\n                currentElement = line.value.atom;\n                let isotopeRatioInfo = (0, getIsotopeRatioInfo_1.getIsotopeRatioInfo)(line.value);\n                currentPart[emFieldName] +=\n                    isotopeRatioInfo[emFieldName] * line.multiplier;\n                currentPart.mass += isotopeRatioInfo.mass * line.multiplier;\n                break;\n            }\n            case Kind_1.Kind.CHARGE:\n                currentPart.charge = line.value;\n                if (validUnsaturation) {\n                    unsaturation -= line.value;\n                }\n                break;\n            default:\n                throw new Error('Unimplemented Kind in getInfo', line.kind);\n        }\n        if (currentElement) {\n            if (customUnsaturations[currentElement] !== undefined) {\n                unsaturation += customUnsaturations[currentElement] * line.multiplier;\n            }\n            else if (chemical_elements_1.unsaturationsObject[currentElement] !== undefined) {\n                unsaturation += chemical_elements_1.unsaturationsObject[currentElement] * line.multiplier;\n            }\n            else {\n                validUnsaturation = false;\n            }\n        }\n    }\n    // need to calculate the observedMonoisotopicMass\n    if (currentPart.charge) {\n        currentPart[msemFieldName] =\n            (currentPart[emFieldName] - currentPart.charge * chemical_elements_1.ELECTRON_MASS) /\n                Math.abs(currentPart.charge);\n    }\n    if (validUnsaturation) {\n        currentPart.unsaturation = unsaturation / 2 + 1;\n    }\n    return currentPart;\n}\n//# sourceMappingURL=getInfoInternal.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getIsotopesInfo = getIsotopesInfo;\nconst chemical_elements_1 = require(\"chemical-elements\");\nconst Kind_1 = require(\"../Kind\");\n/** @typedef {import('./getIsotopesInfo.types').IsotopesInfo} IsotopesInfo\n\n/**\n *\n * @param {*} parts\n * @returns {[]|IsotopesInfo}\n */\nfunction getIsotopesInfo(parts) {\n    if (parts.length === 0)\n        return [];\n    if (parts.length > 1) {\n        throw new Error('getIsotopesInfo can not be applied on multipart MF');\n    }\n    return getProcessedPart(parts[0]);\n}\n/**\n * @returns {IsotopesInfo}\n */\nfunction getProcessedPart(part) {\n    /** @type {IsotopesInfo} */\n    let result = {\n        charge: 0,\n        isotopes: [],\n    };\n    for (let line of part) {\n        switch (line.kind) {\n            case Kind_1.Kind.ISOTOPE: {\n                let isotope = chemical_elements_1.isotopesObject[line.value.isotope + line.value.atom];\n                if (!isotope) {\n                    throw new Error('unknown isotope:', line.value.atom, line.value.isotope);\n                }\n                result.isotopes.push({\n                    atom: line.value.atom,\n                    number: line.multiplier,\n                    distribution: [{ x: isotope.mass, y: 1 }],\n                });\n                break;\n            }\n            case Kind_1.Kind.ISOTOPE_RATIO:\n                {\n                    let element = chemical_elements_1.elementsAndStableIsotopesObject[line.value.atom];\n                    if (!element)\n                        throw new Error('unknown element:', line.value);\n                    let distribution = getDistribution(element.isotopes, line.value.ratio);\n                    result.isotopes.push({\n                        atom: line.value.atom,\n                        number: line.multiplier,\n                        distribution,\n                    });\n                }\n                break;\n            case Kind_1.Kind.ATOM: {\n                let element = chemical_elements_1.elementsAndStableIsotopesObject[line.value];\n                if (!element)\n                    throw new Error('unknown element:', line.value);\n                result.isotopes.push({\n                    atom: line.value,\n                    number: line.multiplier,\n                    distribution: element.isotopes.map((e) => ({\n                        x: e.mass,\n                        y: e.abundance,\n                    })),\n                });\n                break;\n            }\n            case Kind_1.Kind.CHARGE:\n                result.charge += line.value;\n                break;\n            default:\n                throw new Error('partToMF unhandled Kind: ', line.kind);\n        }\n    }\n    return result;\n}\nfunction getDistribution(isotopesArray, ratio) {\n    let ratios = normalize(ratio);\n    let result = [];\n    if (ratios.length > isotopesArray.length) {\n        throw new Error(`the number of specified ratios is bigger that the number of stable isotopes: ${chemical_elements_1.isotopesObject}`);\n    }\n    for (let i = 0; i < ratios.length; i++) {\n        result.push({\n            x: isotopesArray[i].mass,\n            y: ratios[i],\n        });\n    }\n    return result;\n}\nfunction normalize(array) {\n    let sum = array.reduce((prev, current) => prev + current, 0);\n    return array.map((a) => a / sum);\n}\n//# sourceMappingURL=getIsotopesInfo.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.partsToDisplay = partsToDisplay;\nconst Kind_1 = require(\"../Kind\");\nconst toDisplay_js_1 = require(\"./toDisplay.js\");\n/**\n * Converts an array of mf elements to an array of formatting information\n * @param {Array<Object>} result of the parse method\n */\nfunction partsToDisplay(parts) {\n    let lines = [];\n    for (let part of parts) {\n        if (lines.length > 0)\n            lines.push({ kind: Kind_1.Kind.SALT, value: '•' });\n        for (let partLine of part) {\n            lines.push(partLine);\n            if (partLine.multiplier) {\n                lines.push({\n                    kind: Kind_1.Kind.MULTIPLIER,\n                    value: partLine.multiplier,\n                });\n            }\n        }\n    }\n    return (0, toDisplay_js_1.toDisplay)(lines);\n}\n//# sourceMappingURL=partsToDisplay.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.partsToMF = partsToMF;\nconst partToMF_1 = require(\"./partToMF\");\nfunction partsToMF(parts, options) {\n    let mf = [];\n    for (let part of parts) {\n        mf.push((0, partToMF_1.partToMF)(part, options));\n    }\n    return mf.join(' . ');\n}\n//# sourceMappingURL=partsToMF.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.toParts = toParts;\nconst atom_sorter_1 = require(\"atom-sorter\");\nconst chemical_groups_1 = require(\"chemical-groups\");\nconst Kind_1 = require(\"../Kind\");\n/**\n *\n * @param {*} lines\n * @param {object} [options={}]\n * @param {boolean} [options.expand=true] - Should we expand the groupsObject\n */\nfunction toParts(lines, options = {}) {\n    const { expand: shouldExpandgroupsObject = true } = options;\n    let parts = [];\n    let currentPart = createNewPart();\n    let previousKind = Kind_1.Kind.BEGIN;\n    parts.push(currentPart);\n    for (let line of lines) {\n        switch (line.kind) {\n            case Kind_1.Kind.ATOM:\n            case Kind_1.Kind.ISOTOPE_RATIO:\n            case Kind_1.Kind.ISOTOPE:\n            case Kind_1.Kind.CHARGE:\n                currentPart.lines.push({ ...line, multiplier: 1 });\n                break;\n            case Kind_1.Kind.OPENING_PARENTHESIS:\n                openingParenthesis(currentPart);\n                break;\n            case Kind_1.Kind.CLOSING_PARENTHESIS:\n                closingParenthesis(currentPart);\n                break;\n            case Kind_1.Kind.PRE_MULTIPLIER:\n                preMultiplier(currentPart, line);\n                break;\n            case Kind_1.Kind.MULTIPLIER:\n                postMultiplier(currentPart, line.value, previousKind);\n                break;\n            case Kind_1.Kind.SALT:\n                globalPartMultiplier(currentPart);\n                currentPart = createNewPart();\n                parts.push(currentPart);\n                break;\n            case Kind_1.Kind.ANCHOR: // we ignore anchors to create the parts and canonized MF\n                break;\n            case Kind_1.Kind.COMMENT: // we ignore comments to create the parts and canonized MF\n                break;\n            case Kind_1.Kind.TEXT:\n                break;\n            default:\n                throw new Error(`Can not process mf having: ${line.kind}`);\n        }\n        previousKind = line.kind;\n    }\n    globalPartMultiplier(currentPart);\n    if (shouldExpandgroupsObject)\n        expandgroupsObject(parts);\n    return combineAtomsIsotopesCharges(parts);\n}\nfunction createNewPart() {\n    let currentMultiplier = { value: 1, fromIndex: 0 };\n    return { lines: [], multipliers: [currentMultiplier], currentMultiplier };\n}\nfunction openingParenthesis(currentPart) {\n    currentPart.currentMultiplier = {\n        value: 1,\n        fromIndex: currentPart.lines.length,\n    };\n    currentPart.multipliers.push(currentPart.currentMultiplier);\n}\nfunction closingParenthesis(currentPart) {\n    currentPart.currentMultiplier = currentPart.multipliers.pop();\n    if (currentPart.currentMultiplier !== 1) {\n        for (let i = currentPart.currentMultiplier.fromIndex; i < currentPart.lines.length; i++) {\n            currentPart.lines[i].multiplier *= currentPart.currentMultiplier.value;\n        }\n    }\n}\nfunction preMultiplier(currentPart, line) {\n    currentPart.currentMultiplier.value *= line.value;\n}\nfunction globalPartMultiplier(currentPart) {\n    for (let i = currentPart.multipliers[0].fromIndex; i < currentPart.lines.length; i++) {\n        currentPart.lines[i].multiplier *= currentPart.multipliers[0].value;\n    }\n}\nfunction postMultiplier(currentPart, value, previousKind) {\n    if (previousKind === Kind_1.Kind.CLOSING_PARENTHESIS) {\n        // need to apply to everything till the previous parenthesis\n        for (let i = currentPart.currentMultiplier.fromIndex; i < currentPart.lines.length; i++) {\n            currentPart.lines[i].multiplier *= value;\n        }\n    }\n    else {\n        // just applies to the previous element\n        currentPart.lines.at(-1).multiplier *= value;\n    }\n}\nfunction expandgroupsObject(parts) {\n    for (let part of parts) {\n        let expanded = false;\n        for (let i = 0; i < part.lines.length; i++) {\n            let line = part.lines[i];\n            if (line.kind === Kind_1.Kind.ATOM) {\n                let group = chemical_groups_1.groupsObject[line.value];\n                if (group) {\n                    expanded = true;\n                    for (let element of group.elements) {\n                        if (element.isotope) {\n                            part.lines.push({\n                                kind: 'isotope',\n                                value: { atom: element.symbol, isotope: element.isotope },\n                                multiplier: line.multiplier * element.number,\n                            });\n                        }\n                        else {\n                            part.lines.push({\n                                kind: 'atom',\n                                value: element.symbol,\n                                multiplier: line.multiplier * element.number,\n                            });\n                        }\n                    }\n                    part.lines[i] = undefined;\n                }\n            }\n        }\n        if (expanded)\n            part.lines = part.lines.filter(Boolean);\n    }\n}\nfunction combineAtomsIsotopesCharges(parts) {\n    let results = [];\n    for (let part of parts) {\n        let result = [];\n        results.push(result);\n        calculateAndSortKeys(part);\n        let currentKey = '';\n        for (let key of part.keys) {\n            if (key.key === Kind_1.Kind.CHARGE) {\n                if (currentKey !== key.key) {\n                    result.push({\n                        kind: Kind_1.Kind.CHARGE,\n                        value: key.value.value * key.value.multiplier,\n                    });\n                }\n                else {\n                    result.at(-1).value += key.value.value * key.value.multiplier;\n                }\n            }\n            else if (currentKey !== key.key) {\n                result.push(key.value);\n            }\n            else {\n                result.at(-1).multiplier += key.value.multiplier;\n            }\n            currentKey = key.key;\n        }\n        result.sort((a, b) => {\n            if (a.kind === Kind_1.Kind.CHARGE)\n                return 1;\n            if (b.kind === Kind_1.Kind.CHARGE)\n                return -1;\n            let atomA = a.kind === Kind_1.Kind.ATOM ? a.value : a.value.atom;\n            let atomB = b.kind === Kind_1.Kind.ATOM ? b.value : b.value.atom;\n            if (atomA !== atomB)\n                return (0, atom_sorter_1.atomSorter)(atomA, atomB);\n            // same atome but some isotopes ...\n            if (a.kind === Kind_1.Kind.ATOM)\n                return -1;\n            if (b.kind === Kind_1.Kind.ATOM)\n                return 1;\n            if (a.kind === Kind_1.Kind.ISOTOPE)\n                return -1;\n            if (b.kind === Kind_1.Kind.ISOTOPE)\n                return 1;\n            if (a.kind === Kind_1.Kind.ISOTOPE_RATIO)\n                return -1;\n            if (b.kind === Kind_1.Kind.ISOTOPE_RATIO)\n                return 1;\n            return 0;\n        });\n    }\n    return results;\n}\nfunction calculateAndSortKeys(part) {\n    part.keys = [];\n    for (let line of part.lines) {\n        part.keys.push({ key: getKey(line), value: line });\n    }\n    part.keys.sort((a, b) => stringComparator(a.key, b.key));\n}\nfunction getKey(line) {\n    let key = [line.kind];\n    switch (line.kind) {\n        case Kind_1.Kind.CHARGE:\n            break;\n        default:\n            if (typeof line.value === 'string') {\n                key.push(line.value);\n            }\n            else {\n                for (let prop of Object.keys(line.value).sort()) {\n                    key.push(line.value[prop]);\n                }\n            }\n    }\n    return key.join('-');\n}\nfunction stringComparator(a, b) {\n    if (a < b)\n        return -1;\n    if (a > b)\n        return 1;\n    return 0;\n}\n//# sourceMappingURL=toParts.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.toText = toText;\nconst Format_1 = require(\"../Format\");\nconst subSuperscript_1 = require(\"./subSuperscript\");\nfunction toText(lines) {\n    let text = [];\n    for (let line of lines) {\n        switch (line.kind) {\n            case Format_1.Format.SUBSCRIPT:\n                {\n                    const value = String(line.value);\n                    for (let i = 0; i < value.length; i++) {\n                        const char = value[i];\n                        if (subSuperscript_1.subscript[char]) {\n                            text.push(subSuperscript_1.subscript[char]);\n                        }\n                        else {\n                            throw new Error(`Subscript problem with: ${char}`);\n                        }\n                    }\n                }\n                break;\n            case Format_1.Format.SUPERSCRIPT: {\n                const value = String(line.value);\n                for (let i = 0; i < value.length; i++) {\n                    const char = value[i];\n                    if (subSuperscript_1.superscript[char]) {\n                        text.push(subSuperscript_1.superscript[char]);\n                    }\n                    else {\n                        throw new Error(`Superscript problem with: ${char}`);\n                    }\n                }\n                break;\n            }\n            case Format_1.Format.SUPERIMPOSE: {\n                const under = String(line.under);\n                for (let i = 0; i < under.length; i++) {\n                    const char = under[i];\n                    if (subSuperscript_1.subscript[char]) {\n                        text.push(subSuperscript_1.subscript[char]);\n                    }\n                    else {\n                        throw new Error(`Subscript problem with: ${char}`);\n                    }\n                }\n                const over = String(line.over);\n                for (let i = 0; i < over.length; i++) {\n                    const char = over[i];\n                    if (subSuperscript_1.superscript[char]) {\n                        text.push(subSuperscript_1.superscript[char]);\n                    }\n                    else {\n                        throw new Error(`Superscript problem with: ${char}`);\n                    }\n                }\n                break;\n            }\n            default:\n                text.push(line.value);\n        }\n    }\n    return text.join('');\n}\n//# sourceMappingURL=toText.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MFInternal = void 0;\nconst ensureCase_1 = require(\"./ensureCase\");\nconst parse_1 = require(\"./parse\");\nconst flatten_1 = require(\"./util/flatten\");\nconst getEA_1 = require(\"./util/getEA\");\nconst getElements_1 = require(\"./util/getElements\");\nconst getInfo_1 = require(\"./util/getInfo\");\nconst getIsotopesInfo_1 = require(\"./util/getIsotopesInfo\");\nconst partsToDisplay_1 = require(\"./util/partsToDisplay\");\nconst partsToMF_1 = require(\"./util/partsToMF\");\nconst toDisplay_1 = require(\"./util/toDisplay\");\nconst toHtml_1 = require(\"./util/toHtml\");\nconst toParts_1 = require(\"./util/toParts\");\nconst toText_1 = require(\"./util/toText\");\n/** @typedef {import('./util/getIsotopesInfo.types').IsotopesInfo} IsotopesInfo */\n/** @typedef {import('./util/getInfo.types').MFInfo} MFInfo */\n/** @typedef {import('./util/getInfo.types').MFInfoWithParts} MFInfoWithParts */\n/**\n * Class allowing to deal with molecular formula and derived information\n */\nclass MFInternal {\n    constructor(mf, options = {}) {\n        if (options.ensureCase) {\n            mf = (0, ensureCase_1.ensureCase)(mf);\n        }\n        this.parsed = (0, parse_1.parse)(mf);\n        this.cache = {};\n    }\n    /**\n     * Returns an array of objects with kind and value that can be used to easily\n     * display the molecular formula.\n     * @returns {{kind: string, value: string}[]}\n     */\n    toDisplay() {\n        if (!this.cache.displayed)\n            this.cache.displayed = (0, toDisplay_1.toDisplay)(this.parsed);\n        return this.cache.displayed;\n    }\n    /**\n     * Returns a string that represents the molecular formula adding subscript and superscript in HTML.\n     * @returns {string}\n     */\n    toHtml() {\n        if (!this.cache.html) {\n            this.toDisplay();\n            this.cache.html = (0, toHtml_1.toHtml)(this.cache.displayed);\n        }\n        return this.cache.html;\n    }\n    /**\n     * Returns a string that represents the molecular formula adding subscript and superscript\n     * using Unicode characters. This can not be parsed anymore so kind of dead end ...\n     * @returns {string}\n     */\n    toText() {\n        if (!this.cache.text) {\n            this.toDisplay();\n            this.cache.text = (0, toText_1.toText)(this.cache.displayed);\n        }\n        return this.cache.text;\n    }\n    /**\n     * Similar to toText but returns a canonic string in which the atoms are sorted using the Hill system\n     * @returns {string}\n     */\n    toCanonicText() {\n        if (!this.cache.canonicText) {\n            this.cache.canonicText = new MFInternal(this.toMF()).toText();\n        }\n        return this.cache.canonicText;\n    }\n    toParts(options) {\n        if (options) {\n            return (0, toParts_1.toParts)(this.parsed, options);\n        }\n        // we don't want to cache the parts if we are using options\n        if (!this.cache.parts) {\n            this.cache.parts = (0, toParts_1.toParts)(this.parsed, options);\n        }\n        return this.cache.parts;\n    }\n    /**\n     * Returns an object with the global MF, global charge, monoisotopic mass and mass\n     * as well as the same information for all the parts\n     * @param {object} [options={}] options\n     * @param {object} [options.customUnsaturations={}] custom unsaturations\n     * @param {string} [options.emFieldName='monoisotopicMass'] name of the monoisotopic mass field\n     * @param {string} [options.msemFieldName='observedMonoisotopicMass'] name of the observed monoisotopic mass field\n     * @returns {MFInfo|MFInfoWithParts}\n     */\n    getInfo(options = {}) {\n        if (!this.cache.info) {\n            this.toParts();\n            this.cache.info = (0, getInfo_1.getInfo)(this.cache.parts, options);\n        }\n        return this.cache.info;\n    }\n    /**\n     * Returns an object with the elemental analysis\n     * @returns {*[]}\n     */\n    getEA() {\n        if (!this.cache.ea) {\n            this.toParts();\n            this.cache.ea = (0, getEA_1.getEA)(this.cache.parts);\n        }\n        return this.cache.ea;\n    }\n    /**\n     * Get the different elements for each part\n     * @returns {*[]}\n     */\n    getElements() {\n        if (!this.cache.elements) {\n            this.toParts();\n            this.cache.elements = (0, getElements_1.getElements)(this.cache.parts);\n        }\n        return this.cache.elements;\n    }\n    /**\n     * Returns an array with each atom and isotopic composition\n     * @returns {IsotopesInfo}\n     */\n    getIsotopesInfo(options = {}) {\n        if (!this.cache.isotopesInfo) {\n            this.toParts();\n            this.cache.isotopesInfo = (0, getIsotopesInfo_1.getIsotopesInfo)(this.cache.parts, options);\n        }\n        return this.cache.isotopesInfo;\n    }\n    /**\n     * Get a canonized MF\n     * @returns {string}\n     */\n    toMF() {\n        if (!this.cache.mf) {\n            this.toParts();\n            this.cache.mf = (0, partsToMF_1.partsToMF)(this.cache.parts);\n        }\n        return this.cache.mf;\n    }\n    /**\n     * Get a canonized MF\n     * @returns {string}\n     */\n    toNeutralMF() {\n        if (!this.cache.neutralMF) {\n            this.toParts();\n            this.cache.neutralMF = (0, partsToMF_1.partsToMF)(this.cache.parts, { neutral: true });\n        }\n        return this.cache.neutralMF;\n    }\n    canonize() {\n        this.toParts();\n        this.cache.displayed = (0, partsToDisplay_1.partsToDisplay)(this.cache.parts);\n        this.cache.html = undefined;\n    }\n    flatten(options) {\n        return (0, flatten_1.flatten)(this.parsed, options);\n    }\n}\nexports.MFInternal = MFInternal;\n//# sourceMappingURL=MFInternal.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MF = void 0;\nconst MFInternal_1 = require(\"./MFInternal\");\nclass MF {\n    internal;\n    constructor(mf, options = {}) {\n        this.internal = new MFInternal_1.MFInternal(mf, options);\n    }\n    /**\n     * Returns an array of objects with kind and value that can be used to easily\n     * display the molecular formula.\n     */\n    toDisplay() {\n        return this.internal.toDisplay();\n    }\n    /**\n     * Returns a string that represents the molecular formula adding subscript and superscript in HTML.\n     */\n    toHtml() {\n        return this.internal.toHtml();\n    }\n    /**\n     * Returns a string that represents the molecular formula adding subscript and superscript\n     * using Unicode characters. This can not be parsed anymore so kind of dead end ...\n     */\n    toText() {\n        return this.internal.toText();\n    }\n    /**\n     * Similar to toText but returns a canonic string in which the atoms are sorted using the Hill system\n     */\n    toCanonicText() {\n        return this.internal.toCanonicText();\n    }\n    toParts(options) {\n        return this.internal.toParts(options);\n    }\n    /**\n     * Returns an object with the global MF, global charge, monoisotopic mass and mass\n     * as well as the same information for all the parts\n     */\n    getInfo(options) {\n        return this.internal.getInfo(options);\n    }\n    /**\n     * Returns an object with the elemental analysis\n     */\n    getEA() {\n        return this.internal.getEA();\n    }\n    /**\n     * Get the different elements for each part\n     */\n    getElements() {\n        return this.internal.getElements();\n    }\n    /**\n     * Returns an array with each atom and isotopic composition\n     */\n    getIsotopesInfo(options = {}) {\n        return this.internal.getIsotopesInfo(options);\n    }\n    /**\n     * Get a canonized parsable Molecule Formula\n     */\n    toMF() {\n        return this.internal.toMF();\n    }\n    /**\n     * Get a canonized MF\n     */\n    toNeutralMF() {\n        return this.internal.toNeutralMF();\n    }\n    canonize() {\n        return this.internal.canonize();\n    }\n    flatten(options) {\n        return this.internal.flatten(options);\n    }\n}\nexports.MF = MF;\n//# sourceMappingURL=MF.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.parseToHtml = parseToHtml;\nconst parse_js_1 = require(\"./parse.js\");\nconst toDisplay_js_1 = require(\"./util/toDisplay.js\");\nconst toHtml_js_1 = require(\"./util/toHtml.js\");\n/**\n * Parse a molecular formula and converts it to an HTML code\n * @param {String} mf String containing the molecular formula\n */\nfunction parseToHtml(mf) {\n    let parsed = (0, parse_js_1.parse)(mf);\n    let display = (0, toDisplay_js_1.toDisplay)(parsed);\n    return (0, toHtml_js_1.toHtml)(display);\n}\n//# sourceMappingURL=parseToHtml.js.map","\"use strict\";\n/**\n * @param {object}   [entry={}]\n * @param {object}   [options={}]\n * @param {number}   [options.min=-Infinity] - Minimal unsaturation\n * @param {number}   [options.max=+Infinity] - Maximal unsaturation\n * @param {boolean}   [options.onlyInteger=false] - Integer unsaturation\n * @param {boolean}   [options.onlyNonInteger=false] - Non integer unsaturation\n * @return {boolean}\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.unsaturationMatcher = unsaturationMatcher;\nfunction unsaturationMatcher(entry, options = {}) {\n    const { min = Number.MIN_SAFE_INTEGER, max = Number.MAX_SAFE_INTEGER, onlyInteger, onlyNonInteger, } = options;\n    if (entry.unsaturation !== undefined) {\n        if (entry.unsaturation < min || entry.unsaturation > max)\n            return false;\n        if (onlyInteger && !Number.isInteger(entry.unsaturation))\n            return false;\n        if (onlyNonInteger && Number.isInteger(entry.unsaturation))\n            return false;\n    }\n    return true;\n}\n//# sourceMappingURL=unsaturationMatcher.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.generalMatcher = generalMatcher;\nconst unsaturationMatcher_js_1 = require(\"./unsaturationMatcher.js\");\n/**\n * Returns true if the entry containing MF information match\n * @param {object}   [entry={}] - object containing mw, ...\n * @param {object}   [options={}]\n * @param {number}   [options.minMW=0] - Minimal molecular weight\n * @param {number}   [options.maxMW=+Infinity] - Maximal molecular weight\n * @param {number}   [options.minEM=0] - Minimal monoisotopic mass\n * @param {number}   [options.maxEM=+Infinity] - Maximal monoisotopic mass\n * @param {number}   [options.minCharge=-Infinity] - Minimal charge\n * @param {number}   [options.maxCharge=+Infinity] - Maximal charge\n * @param {boolean}  [options.absoluteCharge=false] - If true, the charge is absolute (so between 0 and +Infinity by default)\n * @param {object}   [options.unsaturation={}]\n * @param {number}   [options.unsaturation.min=-Infinity] - Minimal unsaturation\n * @param {number}   [options.unsaturation.max=+Infinity] - Maximal unsaturation\n * @param {boolean}   [options.unsaturation.onlyInteger=false] - Integer unsaturation\n * @param {boolean}   [options.unsaturation.onlyNonInteger=false] - Non integer unsaturation\n * @param {object}   [options.atoms] - object of atom:{min, max}\n * @return {boolean}\n */\nfunction generalMatcher(entry, options = {}) {\n    const { minMW = 0, maxMW = +Infinity, minEM = 0, maxEM = +Infinity, minCharge = Number.MIN_SAFE_INTEGER, maxCharge = Number.MAX_SAFE_INTEGER, absoluteCharge = false, unsaturation = {}, atoms, } = options;\n    if (entry.mw !== undefined && (entry.mw < minMW || entry.mw > maxMW)) {\n        return false;\n    }\n    if (entry.em !== undefined && (entry.em < minEM || entry.em > maxEM)) {\n        return false;\n    }\n    if (entry.charge !== undefined) {\n        let charge = absoluteCharge ? Math.abs(entry.charge) : entry.charge;\n        if (charge < minCharge || charge > maxCharge)\n            return false;\n    }\n    if (unsaturation !== undefined &&\n        entry.unsaturation !== undefined &&\n        !(0, unsaturationMatcher_js_1.unsaturationMatcher)(entry, unsaturation)) {\n        return false;\n    }\n    if (entry.atoms !== undefined && atoms) {\n        // all the atoms of the entry must fit in the range\n        for (let atom in entry.atoms) {\n            if (!atoms[atom])\n                return false;\n            if (entry.atoms[atom] < atoms[atom].min)\n                return false;\n            if (entry.atoms[atom] > atoms[atom].max)\n                return false;\n        }\n    }\n    return true;\n}\n//# sourceMappingURL=generalMatcher.js.map","\"use strict\";\n/**\n * Ensure that the sequence is in uppercase taking into account possible modifications\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ensureUppercaseSequence = ensureUppercaseSequence;\nfunction ensureUppercaseSequence(sequence) {\n    let parenthesisCounter = 0;\n    let parts = [];\n    let part = '';\n    for (let i = 0; i < sequence.length; i++) {\n        let currentSymbol = sequence[i];\n        if (currentSymbol === '(' && parenthesisCounter === 0 && part) {\n            parts.push(part);\n            part = currentSymbol;\n        }\n        else if (currentSymbol === ')' && parenthesisCounter === 0) {\n            part += currentSymbol;\n            parts.push(part);\n            part = '';\n        }\n        else {\n            part += currentSymbol;\n        }\n    }\n    if (part)\n        parts.push(part);\n    for (let i = 0; i < parts.length; i++) {\n        if (!parts[i].startsWith('(') && parts[i].match(/^[a-z]+$/)) {\n            parts[i] = parts[i].toUpperCase();\n        }\n    }\n    return parts.join('');\n}\n//# sourceMappingURL=ensureUppercaseSequence.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getEutrophicationPotential = getEutrophicationPotential;\nconst mf_parser_1 = require(\"mf-parser\");\nfunction getEutrophicationPotential(mfString) {\n    let parsed = new mf_parser_1.MF(mfString);\n    let info = parsed.getInfo();\n    let mf = info.mf;\n    let mw = info.mass;\n    let nC = info.atoms.C || 0;\n    let nO = info.atoms.O || 0;\n    let nN = info.atoms.N || 0;\n    let nP = info.atoms.P || 0;\n    let nH = info.atoms.H || 0;\n    let atoms = Object.keys(info.atoms);\n    for (let atom of atoms) {\n        if (!['C', 'H', 'N', 'O', 'P'].includes(atom)) {\n            return {\n                log: `EP can not be calculated because the MF contains the element: ${atom}`,\n            };\n        }\n    }\n    let vRef = 1;\n    let mwRef = 94.97;\n    let thOD = nC + (nH - 3 * nN) / 4 - nO / 2;\n    let v = nP + nN / 16 + thOD / 138;\n    let ep = v / mw / (vRef / mwRef);\n    return {\n        v,\n        thOD,\n        ep,\n        mf,\n        mw,\n        log: 'Successful calculation',\n    };\n}\n//# sourceMappingURL=getEutrophicationPotential.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getMsem = getMsem;\nconst chemical_elements_1 = require(\"chemical-elements\");\nfunction getMsem(em, charge) {\n    if (charge > 0) {\n        return em / charge - chemical_elements_1.ELECTRON_MASS;\n    }\n    else if (charge < 0) {\n        return em / (charge * -1) + chemical_elements_1.ELECTRON_MASS;\n    }\n    else {\n        return 0;\n    }\n}\n//# sourceMappingURL=getMsem.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getMsInfo = getMsInfo;\nconst getMsem_1 = require(\"./getMsem\");\n/**\n * Returns an object containing:\n * {ms: {em, charge, ionization}, ionization: {}}\n * We return the ionization in order to know which one has been selected\n */\nfunction getMsInfo(entry, options = {}) {\n    const { allowNeutralMolecules, ionization = { mf: '', em: 0, charge: 0 }, forceIonization = false, targetMass, } = options;\n    let realIonization = ionization;\n    if (!forceIonization && entry.ionization && entry.ionization.mf !== '') {\n        realIonization = entry.ionization;\n    }\n    let ms = {\n        ionization: realIonization.mf,\n        em: 0,\n        charge: entry.charge + realIonization.charge,\n    };\n    if (ms.charge !== 0) {\n        ms.em = (0, getMsem_1.getMsem)(entry.em + realIonization.em, ms.charge);\n    }\n    else if (allowNeutralMolecules) {\n        ms.em = entry.em + realIonization.em;\n    }\n    if (targetMass) {\n        ms.delta = targetMass - ms.em;\n        ms.ppm = ((targetMass - ms.em) / ms.em) * 1e6;\n    }\n    return {\n        ms,\n        ionization: realIonization,\n    };\n}\n//# sourceMappingURL=getMsInfo.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getRangesForFragment = getRangesForFragment;\nconst mf_parser_1 = require(\"mf-parser\");\nfunction getRangesForFragment(ranges) {\n    ranges = structuredClone(ranges);\n    if (typeof ranges === 'string') {\n        // need to convert to ranges\n        let parsed = (0, mf_parser_1.parse)(ranges.replaceAll(/[\\t\\n\\r ]/g, ''));\n        let newRanges = [];\n        // example ClBr2(CH2)0-2NO\n        // the idea is that as long as we don't have a range we don't really care\n        // there is a limitation is that the range has to be first level of parenthesis\n        let parenthesisLevel = 0;\n        let currentMF = ''; // start at an atom first level or a parenthesis\n        for (let item of parsed) {\n            switch (item.kind) {\n                case mf_parser_1.Kind.ATOM:\n                    if (parenthesisLevel === 0 && currentMF) {\n                        newRanges.push({\n                            mf: currentMF,\n                        });\n                        currentMF = '';\n                    }\n                    currentMF += item.value;\n                    break;\n                case mf_parser_1.Kind.ISOTOPE:\n                    if (parenthesisLevel === 0 && currentMF) {\n                        newRanges.push({\n                            mf: currentMF,\n                        });\n                        currentMF = '';\n                    }\n                    currentMF += `[${item.value.isotope}${item.value.atom}]`;\n                    break;\n                case mf_parser_1.Kind.MULTIPLIER:\n                    if (parenthesisLevel === 0 && currentMF) {\n                        newRanges.push({\n                            mf: currentMF,\n                            max: item.value,\n                        });\n                        currentMF = '';\n                    }\n                    else {\n                        currentMF += item.value;\n                    }\n                    break;\n                case mf_parser_1.Kind.MULTIPLIER_RANGE:\n                    if (parenthesisLevel !== 0) {\n                        throw new Error('Range multiplier can only be at the first level');\n                    }\n                    newRanges.push({\n                        mf: currentMF,\n                        min: item.value.from,\n                        max: item.value.to,\n                    });\n                    currentMF = '';\n                    break;\n                case mf_parser_1.Kind.OPENING_PARENTHESIS:\n                    if (parenthesisLevel === 0 && currentMF) {\n                        newRanges.push({\n                            mf: currentMF,\n                        });\n                        currentMF = '';\n                    }\n                    parenthesisLevel++;\n                    currentMF += '(';\n                    break;\n                case mf_parser_1.Kind.CLOSING_PARENTHESIS:\n                    parenthesisLevel--;\n                    currentMF += ')';\n                    break;\n                default:\n                    throw new Error(`can not preprocess ${ranges}`);\n            }\n        }\n        if (currentMF) {\n            newRanges.push({ mf: currentMF });\n        }\n        ranges = newRanges;\n    }\n    let possibilities = [];\n    for (const range of ranges) {\n        if (range.max === 0)\n            continue;\n        let max = range.max === undefined ? 1 : range.max;\n        possibilities.push(`${range.mf}0-${max}`);\n    }\n    return possibilities.join(' ');\n}\n//# sourceMappingURL=getRangesForFragment.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MFRange = void 0;\nconst mf_parser_1 = require(\"mf-parser\");\nclass MFRange {\n    constructor(mf) {\n        this.range = getRange(mf);\n    }\n    isInRange(mf) {\n        const target = getRange(mf);\n        let rangeIndex = 0;\n        let targetIndex = 0;\n        while (rangeIndex < this.range.length && targetIndex < target.length) {\n            const rangeElement = this.range[rangeIndex];\n            const targetElement = target[targetIndex];\n            if (rangeElement.element === targetElement.element) {\n                // Check if the target's range is within the range's range\n                if (targetElement.range.from >= rangeElement.range.from &&\n                    targetElement.range.to <= rangeElement.range.to) {\n                    targetIndex++;\n                    rangeIndex++;\n                }\n                else {\n                    return false; // Target element is out of range\n                }\n            }\n            else if (rangeElement.element < targetElement.element) {\n                if (rangeElement.range.from > 0) {\n                    return false; // Remaining range elements must have a minimum of 1\n                }\n                rangeIndex++;\n            }\n            else {\n                return false; // Target element is not in the range\n            }\n        }\n        if (rangeIndex < this.range.length) {\n            if (this.range[rangeIndex].range.from > 0) {\n                return false; // Remaining range elements must have a minimum of 1\n            }\n            rangeIndex++;\n        }\n        if (targetIndex < target.length) {\n            return false; // Not all target elements were matched\n        }\n        return true; // All target elements are within the range\n    }\n}\nexports.MFRange = MFRange;\nfunction getRange(mf) {\n    const parsed = (0, mf_parser_1.parse)(mf, { expandGroups: true, simplify: true });\n    const ranges = [];\n    let currentRange;\n    for (const item of parsed) {\n        switch (item.kind) {\n            case 'atom':\n                currentRange = { element: item.value, range: { from: 1, to: 1 } };\n                ranges.push(currentRange);\n                break;\n            case 'isotope':\n                currentRange = {\n                    element: item.value.isotope + item.value.atom,\n                    range: { from: 1, to: 1 },\n                };\n                break;\n            case 'multiplier':\n                if (currentRange) {\n                    currentRange.range.from = item.value;\n                    currentRange.range.to = item.value;\n                }\n                else {\n                    throw new Error(`MFRange: Multiplier without preceding element in MF: ${mf}`);\n                }\n                break;\n            case 'multiplierRange':\n                if (currentRange) {\n                    currentRange.range.from = item.value.from;\n                    currentRange.range.to = item.value.to;\n                }\n                else {\n                    throw new Error(`MFRange: Multiplier range without preceding element in MF: ${mf}`);\n                }\n                break;\n            default:\n                throw new Error(`MFRange: Unknown kind: ${item.kind} in MF: ${mf}`);\n        }\n    }\n    return ranges.sort((a, b) => {\n        if (a.element < b.element)\n            return -1;\n        if (a.element > b.element)\n            return 1;\n        return 0;\n    });\n}\n//# sourceMappingURL=MFRange.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.mfDiff = mfDiff;\nconst mf_parser_1 = require(\"mf-parser\");\nfunction mfDiff(mfString1, mfString2) {\n    let mf1 = new mf_parser_1.MF(mfString1).getInfo().atoms;\n    let mf2 = new mf_parser_1.MF(mfString2).getInfo().atoms;\n    let atoms = Object.keys(mf1);\n    for (const atom of Object.keys(mf2)) {\n        if (!atoms.includes(atom))\n            atoms.push(atom);\n    }\n    let mf = '';\n    for (let atom of atoms) {\n        let diff = (mf1[atom] || 0) - (mf2[atom] || 0);\n        if (diff)\n            mf += atom + diff;\n    }\n    return new mf_parser_1.MF(mf).toMF();\n}\n//# sourceMappingURL=mfDiff.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.preprocessIonizations = preprocessIonizations;\nconst mf_parser_1 = require(\"mf-parser\");\nfunction preprocessIonizations(ionizationsString = '') {\n    if (Array.isArray(ionizationsString))\n        return ionizationsString;\n    const ionizations = ionizationsString.split(/ *[\\t\\n\\r,.;]+ */);\n    // it is allowed to have ranges in Ionizations. We need to explode them.\n    const results = [];\n    for (const ionization of ionizations) {\n        const parts = new mf_parser_1.MF(ionization).flatten();\n        for (const part of parts) {\n            const info = new mf_parser_1.MF(part).getInfo();\n            results.push({\n                mf: part,\n                em: info.monoisotopicMass,\n                charge: info.charge,\n                atoms: info.atoms,\n            });\n        }\n    }\n    return results;\n}\n//# sourceMappingURL=preprocessIonizations.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.preprocessRanges = preprocessRanges;\nconst mf_parser_1 = require(\"mf-parser\");\nfunction preprocessRanges(ranges) {\n    ranges = structuredClone(ranges);\n    if (typeof ranges === 'string') {\n        // need to convert to ranges\n        let parsed = (0, mf_parser_1.parse)(ranges.replaceAll(/[\\t\\n\\r ]/g, ''));\n        let newRanges = [];\n        let current = {\n            mf: '',\n            min: 1,\n            max: 1,\n        };\n        // example ClBr2(CH2)0-2NO\n        // the idea is that has long as we don't have a range we don't really care\n        // but the range should only applied on the previous atom, group or parenthesis\n        // there is a limitation is that the range has to be first level of parenthesis\n        let parenthesisLevel = 0;\n        let currentMF = ''; // start at an atom first level or a parenthesis\n        for (let item of parsed) {\n            switch (item.kind) {\n                case mf_parser_1.Kind.ATOM:\n                    if (parenthesisLevel === 0 && currentMF) {\n                        current.mf += currentMF;\n                        currentMF = '';\n                    }\n                    currentMF += item.value;\n                    break;\n                case mf_parser_1.Kind.ISOTOPE:\n                    if (parenthesisLevel === 0 && currentMF) {\n                        current.mf += currentMF;\n                        currentMF = '';\n                    }\n                    currentMF += `[${item.value.isotope}${item.value.atom}]`;\n                    break;\n                case mf_parser_1.Kind.MULTIPLIER:\n                    if (parenthesisLevel === 0 && currentMF) {\n                        current.mf += currentMF + item.value;\n                        currentMF = '';\n                    }\n                    else {\n                        currentMF += item.value;\n                    }\n                    break;\n                case mf_parser_1.Kind.MULTIPLIER_RANGE:\n                    if (parenthesisLevel !== 0) {\n                        throw new Error('Range multiplier can only be at the first level');\n                    }\n                    newRanges.push({\n                        mf: currentMF,\n                        min: item.value.from,\n                        max: item.value.to,\n                    });\n                    currentMF = '';\n                    break;\n                case mf_parser_1.Kind.OPENING_PARENTHESIS:\n                    if (parenthesisLevel === 0 && currentMF) {\n                        current.mf += currentMF;\n                        currentMF = '';\n                    }\n                    parenthesisLevel++;\n                    currentMF += '(';\n                    break;\n                case mf_parser_1.Kind.CLOSING_PARENTHESIS:\n                    parenthesisLevel--;\n                    currentMF += ')';\n                    break;\n                default:\n                    throw new Error(`can not preprocess ${ranges}`);\n            }\n        }\n        if (currentMF) {\n            current.mf += currentMF;\n        }\n        if (current.mf) {\n            newRanges.push(current);\n        }\n        ranges = newRanges;\n    }\n    let possibilities = [];\n    for (let i = 0; i < ranges.length; i++) {\n        let range = ranges[i];\n        let min = range.min === undefined ? 0 : range.min;\n        let max = range.max === undefined ? 1 : range.max;\n        let possibility = {\n            mf: range.mf,\n            originalMinCount: min, // value defined by the user\n            originalMaxCount: max, // value defined by the user\n            currentMinCount: min,\n            currentMaxCount: max,\n            currentCount: min,\n            currentMonoisotopicMass: 0,\n            currentCharge: 0,\n            currentUnsaturation: 0,\n            initialOrder: i,\n            minInnerMass: 0,\n            maxInnerMass: 0,\n            minInnerCharge: 0,\n            maxInnerCharge: 0,\n            minCharge: 0,\n            maxCharge: 0,\n            minMass: 0,\n            maxMass: 0,\n            innerCharge: false,\n        };\n        possibilities.push(possibility);\n        let info = new mf_parser_1.MF(range.mf).getInfo();\n        possibility.em = range.em || info.monoisotopicMass;\n        possibility.charge = range.charge || info.charge;\n        possibility.unsaturation =\n            range.unsaturation === undefined\n                ? (info.unsaturation - 1) * 2\n                : range.unsaturation;\n        possibility.atoms = info.atoms;\n        if (possibility.mf !== info.mf) {\n            possibility.isGroup = true;\n        }\n    }\n    possibilities = possibilities.filter((r) => r.originalMinCount !== 0 || r.originalMaxCount !== 0);\n    // we will sort the way we analyse the data\n    // 1. The one possibility parameter\n    // 2. The charged part\n    // 3. Decreasing em\n    possibilities.sort((a, b) => {\n        if (a.originalMinCount === a.originalMaxCount)\n            return -1; // should be in front, they are 'static'\n        if (b.originalMinCount === b.originalMaxCount)\n            return 1;\n        if (a.charge && b.charge) {\n            if (Math.abs(a.charge) > Math.abs(b.charge))\n                return -1;\n            if (Math.abs(a.charge) < Math.abs(b.charge))\n                return 1;\n            return b.em - a.em;\n        }\n        if (a.charge)\n            return -1;\n        if (b.charge)\n            return 1;\n        return b.em - a.em;\n    });\n    // we calculate couple of fixed values\n    for (let i = 0; i < possibilities.length; i++) {\n        for (let j = i; j < possibilities.length; j++) {\n            let possibility = possibilities[j];\n            if (possibility.em > 0) {\n                possibilities[i].minMass +=\n                    possibility.em * possibility.originalMinCount;\n                possibilities[i].maxMass +=\n                    possibility.em * possibility.originalMaxCount;\n            }\n            else {\n                possibilities[i].minMass +=\n                    possibility.em * possibility.originalMaxCount;\n                possibilities[i].maxMass +=\n                    possibility.em * possibility.originalMinCount;\n            }\n            if (possibility.charge > 0) {\n                possibilities[i].minCharge +=\n                    possibility.charge * possibility.originalMinCount;\n                possibilities[i].maxCharge +=\n                    possibility.charge * possibility.originalMaxCount;\n            }\n            else {\n                possibilities[i].minCharge +=\n                    possibility.charge * possibility.originalMaxCount;\n                possibilities[i].maxCharge +=\n                    possibility.charge * possibility.originalMinCount;\n            }\n        }\n    }\n    for (let i = 0; i < possibilities.length; i++) {\n        if (i < possibilities.length - 1) {\n            let possibility = possibilities[i];\n            let innerPossibility = possibilities[i + 1];\n            possibility.minInnerMass = innerPossibility.minMass;\n            possibility.maxInnerMass = innerPossibility.maxMass;\n            possibility.minInnerCharge = innerPossibility.minCharge;\n            possibility.maxInnerCharge = innerPossibility.maxCharge;\n            if (possibility.minInnerCharge || possibility.maxInnerCharge) {\n                possibility.innerCharge = true;\n            }\n        }\n    }\n    return possibilities;\n}\n//# sourceMappingURL=preprocessRanges.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.msemMatcher = msemMatcher;\nconst mf_utilities_1 = require(\"mf-utilities\");\nconst ml_spectra_processing_1 = require(\"ml-spectra-processing\");\nconst unsaturationMatcher_js_1 = require(\"./unsaturationMatcher.js\");\n/**\n * @typedef {object} MSEMFilterOptions\n * @property {object}         [ionization={ mf: '', em: 0, charge: 0 }] - ionization method\n * @property {boolean}        [forceIonization=false] - If true ignore existing ionizations\n * @property {number}         [precision=1000] - The precision on the experimental mass\n * @property {number}         [targetMass] - Target mass, allows to calculate error and filter results\n * @property {number[]}       [targetMasses] - Target masses: SORTED array of numbers\n * @property {number[]}       [targetIntensities] - Target intensities: SORTED array of numbers\n * @property {number}         [minMW=-Infinity] - Minimal monoisotopic mass\n * @property {number}         [maxMW=+Infinity] - Maximal monoisotopic mass\n * @property {number}         [minEM=-Infinity] - Minimal monoisotopic mass\n * @property {number}         [maxEM=+Infinity] - Maximal monoisotopic mass\n * @property {number}         [minMSEM=-Infinity] - Minimal monoisotopic mass observed by mass\n * @property {number}         [maxMSEM=+Infinity] - Maximal monoisotopic mass observed by mass\n * @property {number}         [minCharge=-Infinity] - Minimal charge\n * @property {number}         [maxCharge=+Infinity] - Maximal charge\n * @property {boolean}        [absoluteCharge=false] - If true, the charge is absolute (so between 0 and +Infinity by default)\n * @property {boolean}        [allowNegativeAtoms=false] - Allow to have negative number of atoms\n * @property {object}         [unsaturation={}]\n * @property {number}         [unsaturation.min=-Infinity] - Minimal unsaturation\n * @property {number}         [unsaturation.max=+Infinity] - Maximal unsaturation\n * @property {boolean}        [unsaturation.onlyInteger=false] - Integer unsaturation\n * @property {boolean}        [unsaturation.onlyNonInteger=false] - Non integer unsaturation\n * @property {boolean}        [atoms] - object of atom:{min, max}\n * @property {Function}       [callback] - a function that contains information about the current MF\n */\n/**\n * @param {object}             [entry={}]\n * @param {MSEMFilterOptions}  [options={}]\n * @return {boolean}\n */\n/**\n * We always recalculate msem\n */\nfunction msemMatcher(entry, options = {}) {\n    const { ionization = { mf: '', em: 0, charge: 0, atoms: {} }, forceIonization = false, precision = 1000, minCharge = Number.MIN_SAFE_INTEGER, maxCharge = Number.MAX_SAFE_INTEGER, absoluteCharge = false, unsaturation = {}, targetMass, // if present we will calculate the errors\n    targetMasses, // if present we will calculate the smallest error\n    targetIntensities, // if present it will be added in the report\n    minEM = -Infinity, maxEM = +Infinity, minMSEM = -Infinity, maxMSEM = +Infinity, minMW = -Infinity, maxMW = +Infinity, allowNegativeAtoms = false, atoms, callback, } = options;\n    if (entry.mw !== undefined && (entry.mw < minMW || entry.mw > maxMW)) {\n        return false;\n    }\n    let msInfo = (0, mf_utilities_1.getMsInfo)(entry, {\n        ionization,\n        forceIonization,\n        targetMass,\n    });\n    let ms = msInfo.ms;\n    if (entry.em !== undefined && (entry.em < minEM || entry.em > maxEM)) {\n        return false;\n    }\n    if (ms.em !== undefined && (ms.em < minMSEM || ms.em > maxMSEM)) {\n        return false;\n    }\n    if (targetMass && Math.abs(ms.ppm) > precision) {\n        return false;\n    }\n    if (ms.charge !== undefined) {\n        let charge = absoluteCharge ? Math.abs(ms.charge) : ms.charge;\n        if (charge < minCharge || charge > maxCharge)\n            return false;\n    }\n    if (unsaturation !== undefined &&\n        entry.unsaturation !== undefined &&\n        !(0, unsaturationMatcher_js_1.unsaturationMatcher)(entry, unsaturation)) {\n        return false;\n    }\n    if (entry.atoms !== undefined && atoms) {\n        // all the atoms of the entry must fit in the range\n        for (let atom in entry.atoms) {\n            if (!atoms[atom])\n                return false;\n            if (entry.atoms[atom] < atoms[atom].min)\n                return false;\n            if (entry.atoms[atom] > atoms[atom].max)\n                return false;\n        }\n    }\n    if (entry.atoms !== undefined && !allowNegativeAtoms) {\n        const ionizationAtoms = (msInfo.ionization && msInfo.ionization.atoms) || {};\n        const atomKeys = new Set(Object.keys(ionizationAtoms).concat(Object.keys(entry.atoms)));\n        for (let atom of atomKeys) {\n            if ((entry.atoms[atom] || 0) + (ionizationAtoms[atom] || 0) < 0) {\n                return false;\n            }\n        }\n    }\n    if (targetMasses && targetMasses.length > 0) {\n        let index = (0, ml_spectra_processing_1.xFindClosestIndex)(targetMasses, ms.em);\n        let closestMass = targetMasses[index];\n        msInfo = (0, mf_utilities_1.getMsInfo)(entry, {\n            ionization,\n            forceIonization,\n            targetMass: closestMass,\n        });\n        msInfo.ms.target = { mass: closestMass };\n        if (targetIntensities) {\n            msInfo.ms.target.intensity = targetIntensities[index];\n        }\n        // need to find the closest targetMasses\n        if (Math.abs(msInfo.ms.ppm) > precision)\n            return false;\n    }\n    if (callback && !callback(entry))\n        return false;\n    return msInfo;\n}\n//# sourceMappingURL=msemMatcher.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.TargetMassCache = void 0;\nconst chemical_elements_1 = require(\"chemical-elements\");\n/**\n * returns all the possible neutral mass for a defined experimental (targetMass) mass\n */\nclass TargetMassCache {\n    /**\n     * @param {number} targetMass\n     * @param {Array} possibilities\n     * @param {object} [options={}]\n     * @param {boolean} [options.allowNeutral=false]\n     * @param {number} [options.charge=0]\n     * @param {number} [options.precision=100]\n     * @param {object} [options.filter={}]\n     * @param {number} [options.filter.minCharge=Number.MIN_SAFE_INTEGER]\n     * @param {number} [options.filter.maxCharge=Number.MAX_SAFE_INTEGER]\n     * @returns\n     */\n    constructor(targetMass, possibilities, options = {}) {\n        const { allowNeutral = false, // msem because em in this case !\n        filter = {}, charge = 0, precision = 100, } = options;\n        const { minCharge = Number.MIN_SAFE_INTEGER, maxCharge = Number.MAX_SAFE_INTEGER, } = filter;\n        if (!possibilities || possibilities.length === 0)\n            return;\n        let firstPossibility = possibilities[0];\n        let currentMinCharge = Math.max(minCharge, firstPossibility.minCharge + charge);\n        let currentMaxCharge = Math.min(maxCharge, firstPossibility.maxCharge + charge);\n        this.minCharge = currentMinCharge;\n        this.maxCharge = currentMaxCharge;\n        let size = this.maxCharge - this.minCharge + 1;\n        this.data = [];\n        let minMass = 0;\n        let maxMass = 0;\n        let range = (targetMass * precision) / 1e6;\n        for (let i = 0; i < size; i++) {\n            let currentCharge = i + this.minCharge;\n            if (currentCharge === 0) {\n                if (allowNeutral) {\n                    minMass = targetMass - range;\n                    maxMass = targetMass + range;\n                }\n                else {\n                    minMass = Number.MAX_SAFE_INTEGER;\n                    maxMass = Number.MIN_SAFE_INTEGER;\n                }\n            }\n            else {\n                minMass =\n                    (targetMass - range) * Math.abs(currentCharge) +\n                        chemical_elements_1.ELECTRON_MASS * currentCharge;\n                maxMass =\n                    (targetMass + range) * Math.abs(currentCharge) +\n                        chemical_elements_1.ELECTRON_MASS * currentCharge;\n            }\n            this.data.push({\n                charge: currentCharge,\n                minMass,\n                maxMass,\n            });\n        }\n    }\n    getMinMass(charge) {\n        return this.data[charge - this.minCharge]\n            ? this.data[charge - this.minCharge].minMass\n            : Number.MAX_SAFE_INTEGER;\n    }\n    getMaxMass(charge) {\n        return this.data[charge - this.minCharge]\n            ? this.data[charge - this.minCharge].maxMass\n            : Number.MIN_SAFE_INTEGER;\n    }\n}\nexports.TargetMassCache = TargetMassCache;\n//# sourceMappingURL=TargetMassCache.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.findMFsSync = findMFsSync;\nconst atom_sorter_1 = require(\"atom-sorter\");\nconst mf_matcher_1 = require(\"mf-matcher\");\nconst mf_utilities_1 = require(\"mf-utilities\");\nconst TargetMassCache_1 = require(\"./TargetMassCache\");\n/**\n * @param {number}        targetMass - Monoisotopic mass\n * @param {object}        [options={}]\n * @param {number}        [options.maxIterations=10000000] - Maximum number of iterations\n * @param {boolean}       [options.allowNeutral=true]\n * @param {boolean}       [options.uniqueMFs=true]\n * @param {number}        [options.limit=1000] - Maximum number of results\n * @param {string}        [options.ionizations=''] - string containing a comma separated list of modifications\n * @param {string|{mf:string,min:number,max:number}[]}        [options.ranges='C0-100 H0-100 O0-100 N0-100'] - range of mfs to search\n * @param {number}        [options.precision=100] - Allowed mass range based on precision\n * @param {import('mf-matcher').MSEMFilterOptions}        [options.filter={}]\n * @returns {object}\n */\nfunction findMFsSync(targetMass, options = {}) {\n    const { filter = {}, maxIterations = 1e8, limit = 1000, allowNeutral = true, // if there is no msem we use em !\n    uniqueMFs = false, // if there is no msem we use em !\n    ranges = [\n        { mf: 'C', min: 0, max: 100 },\n        { mf: 'H', min: 0, max: 100 },\n        { mf: 'O', min: 0, max: 100 },\n        { mf: 'N', min: 0, max: 100 },\n    ], } = options;\n    let targetMassCache;\n    const { minCharge = Number.MIN_SAFE_INTEGER, maxCharge = Number.MAX_SAFE_INTEGER, unsaturation = {}, } = filter;\n    let filterUnsaturation = !!unsaturation;\n    // we calculate not the real unsaturation but the one before dividing by 2 + 1\n    let fakeMinUnsaturation = unsaturation.min === undefined\n        ? Number.MIN_SAFE_INTEGER\n        : (unsaturation.min - 1) * 2;\n    let fakeMaxUnsaturation = unsaturation.max === undefined\n        ? Number.MAX_SAFE_INTEGER\n        : (unsaturation.max - 1) * 2;\n    let filterCharge = minCharge !== Number.MIN_SAFE_INTEGER ||\n        maxCharge !== Number.MAX_SAFE_INTEGER;\n    let advancedFilter;\n    if (filter.atoms || filter.callback) {\n        advancedFilter = {\n            atoms: filter.atoms,\n            callback: filter.callback,\n        };\n    }\n    let result = {\n        mfs: [],\n        info: {\n            numberMFEvaluated: 0,\n            numberResults: 0,\n        },\n    };\n    let orderMapping = []; // used to sort the atoms\n    // we need to make the processing for all the ionizations\n    let ionizations = (0, mf_utilities_1.preprocessIonizations)(options.ionizations);\n    for (let ionization of ionizations) {\n        let currentIonization = {\n            currentMonoisotopicMass: ionization.em || 0,\n            currentCharge: ionization.charge,\n            currentUnsaturation: 0, // we don't take into account the unsaturation of the ionization agent\n        };\n        // if (DEBUG) console.log('new ionization', ionization.mf, ionization.em, ionization.charge);\n        // ionization em and charge will be used to set the first atom value\n        let possibilities = (0, mf_utilities_1.preprocessRanges)(ranges);\n        orderMapping = getOrderMapping(possibilities);\n        if (possibilities.length === 0)\n            return { mfs: [] };\n        targetMassCache = new TargetMassCache_1.TargetMassCache(targetMass, possibilities, {\n            ...options,\n            charge: ionization.charge,\n        });\n        let theEnd = false;\n        let maxPosition = possibilities.length;\n        let lastPosition = possibilities.length - 1;\n        let currentPosition = 0;\n        let currentAtom;\n        let previousAtom;\n        let lastPossibility = possibilities[lastPosition];\n        initializePossibilities(possibilities, currentIonization, targetMassCache);\n        //  if (DEBUG) console.log('possibilities', possibilities.map((a) => `${a.mf + a.originalMinCount}-${a.originalMaxCount}`));\n        let isValid = false; // designed so that the first time it is not a valid solution\n        while (!theEnd) {\n            if (result.info.numberMFEvaluated++ > maxIterations) {\n                throw new Error(`Iteration number is over the current maximum of: ${maxIterations}`);\n            }\n            if (filterUnsaturation) {\n                let unsaturationValue = lastPossibility.currentUnsaturation;\n                let isOdd = Math.abs(unsaturationValue % 2);\n                if ((unsaturation.onlyInteger && isOdd === 1) ||\n                    (unsaturation.onlyNonInteger && isOdd === 0) ||\n                    fakeMinUnsaturation > unsaturationValue ||\n                    fakeMaxUnsaturation < unsaturationValue) {\n                    isValid = false;\n                }\n            }\n            if (filterCharge &&\n                (lastPossibility.currentCharge < minCharge ||\n                    lastPossibility.currentCharge > maxCharge)) {\n                isValid = false;\n            }\n            if (isValid) {\n                let minMass = targetMassCache.getMinMass(lastPossibility.currentCharge);\n                let maxMass = targetMassCache.getMaxMass(lastPossibility.currentCharge);\n                if (lastPossibility.currentMonoisotopicMass < minMass ||\n                    lastPossibility.currentMonoisotopicMass > maxMass) {\n                    isValid = false;\n                }\n            }\n            if (isValid) {\n                result.info.numberResults++;\n                let newResult = getResult(possibilities, targetMass, allowNeutral, ionization, orderMapping);\n                if (advancedFilter) {\n                    isValid = (0, mf_matcher_1.msemMatcher)(newResult, advancedFilter) !== false;\n                }\n                if (isValid) {\n                    result.mfs.push(newResult);\n                    if (result.mfs.length > 2 * limit) {\n                        if (uniqueMFs)\n                            ensureUniqueMF(result);\n                        result.mfs.sort((a, b) => Math.abs(a.ms.ppm) - Math.abs(b.ms.ppm));\n                        result.mfs.length = limit;\n                    }\n                }\n            }\n            isValid = true;\n            // we need to set up all the arrays if possible\n            while (currentPosition < maxPosition && currentPosition >= 0) {\n                currentAtom = possibilities[currentPosition];\n                previousAtom =\n                    currentPosition === 0\n                        ? currentIonization\n                        : possibilities[currentPosition - 1];\n                if (currentAtom.currentCount < currentAtom.currentMaxCount) {\n                    currentAtom.currentCount++;\n                    updateCurrentAtom(currentAtom, previousAtom);\n                    if (currentPosition < lastPosition) {\n                        currentPosition++;\n                        setCurrentMinMax(possibilities[currentPosition], possibilities[currentPosition - 1], targetMassCache);\n                    }\n                    else {\n                        break;\n                    }\n                }\n                else {\n                    currentPosition--;\n                }\n            }\n            if (currentPosition < 0) {\n                theEnd = true;\n            }\n        }\n    }\n    if (uniqueMFs)\n        ensureUniqueMF(result);\n    result.mfs.sort((a, b) => Math.abs(a.ms.ppm) - Math.abs(b.ms.ppm));\n    if (result.mfs.length > limit) {\n        result.mfs.length = limit;\n    }\n    for (const mf of result.mfs) {\n        delete mf.currentCounts;\n    }\n    return result;\n}\n/**\n * Ensure that we have only once the same MF\n * In order to improve the speed we just consider the em\n * @param {object} result\n */\nfunction ensureUniqueMF(result) {\n    result.mfs.sort((a, b) => a.em - b.em);\n    let previousEM = 0;\n    let bestCounts = [];\n    const mfs = [];\n    next: for (let current of result.mfs) {\n        if (current.em - previousEM > 1e-8) {\n            previousEM = current.em;\n            bestCounts = current.currentCounts;\n            mfs.push(current);\n        }\n        else {\n            for (let i = 0; i < current.currentCounts.length; i++) {\n                // better priority ???\n                if (current.currentCounts[i] > bestCounts[i]) {\n                    mfs.pop();\n                    mfs.push(current);\n                    bestCounts = current.currentCounts;\n                }\n                else if (current.currentCounts[i] < bestCounts[i]) {\n                    continue next;\n                }\n            }\n        }\n    }\n    result.mfs = mfs;\n}\nfunction updateCurrentAtom(currentAtom, previousAtom) {\n    currentAtom.currentMonoisotopicMass =\n        previousAtom.currentMonoisotopicMass +\n            currentAtom.em * currentAtom.currentCount;\n    currentAtom.currentCharge =\n        previousAtom.currentCharge + currentAtom.charge * currentAtom.currentCount;\n    currentAtom.currentUnsaturation =\n        previousAtom.currentUnsaturation +\n            currentAtom.unsaturation * currentAtom.currentCount;\n}\nfunction getResult(possibilities, targetMass, allowNeutralMolecules, ionization, orderMapping) {\n    let lastPossibility = possibilities.at(-1);\n    let result = {\n        em: lastPossibility.currentMonoisotopicMass - ionization.em,\n        unsaturation: lastPossibility.currentUnsaturation,\n        mf: '',\n        charge: lastPossibility.currentCharge - ionization.charge,\n        ionization,\n        atoms: {},\n        groups: {},\n        currentCounts: possibilities.map((possibility) => possibility.currentCount),\n    };\n    // we check that the first time we meet the ionization group it does not end\n    // in the final result\n    for (let i = 0; i < possibilities.length; i++) {\n        let possibility = possibilities[orderMapping[i]];\n        if (possibility.currentCount !== 0) {\n            if (possibility.isGroup) {\n                if (possibility.currentCount === 1) {\n                    result.mf += `${possibility.mf}`;\n                }\n                else if (possibility.mf.match(/^\\([^()]*\\)$/)) {\n                    result.mf += `${possibility.mf}${possibility.currentCount}`;\n                }\n                else {\n                    result.mf += `(${possibility.mf})${possibility.currentCount}`;\n                }\n                if (result.groups[possibility.mf]) {\n                    result.groups[possibility.mf] += possibility.currentCount;\n                }\n                else {\n                    result.groups[possibility.mf] = possibility.currentCount;\n                }\n            }\n            else {\n                result.mf += possibility.mf;\n                if (possibility.currentCount !== 1) {\n                    result.mf += possibility.currentCount;\n                }\n            }\n            for (let atom in possibility.atoms) {\n                if (result.atoms[atom]) {\n                    result.atoms[atom] +=\n                        possibility.atoms[atom] * possibility.currentCount;\n                }\n                else {\n                    result.atoms[atom] =\n                        possibility.atoms[atom] * possibility.currentCount;\n                }\n            }\n        }\n    }\n    result.unsaturation = (result.unsaturation + Math.abs(result.charge)) / 2 + 1;\n    result.ms = (0, mf_utilities_1.getMsInfo)(result, { targetMass, allowNeutralMolecules }).ms;\n    return result;\n}\nfunction setCurrentMinMax(currentAtom, previousAtom, targetMassCache) {\n    // the current min max can only be optimize if the charge will not change anymore\n    // and the currentAtom.em >= 0\n    if (currentAtom.innerCharge === true ||\n        currentAtom.charge !== 0 ||\n        currentAtom.em < 0) {\n        currentAtom.currentMinCount = currentAtom.originalMinCount;\n        currentAtom.currentMaxCount = currentAtom.originalMaxCount;\n        currentAtom.currentCount = currentAtom.currentMinCount - 1;\n    }\n    else {\n        // no more change of charge, we can optimize\n        let currentMass = previousAtom !== undefined ? previousAtom.currentMonoisotopicMass : 0;\n        let currentCharge = previousAtom !== undefined ? previousAtom.currentCharge : 0;\n        currentAtom.currentMinCount = Math.max(Math.floor((targetMassCache.getMinMass(currentCharge) -\n            currentMass -\n            currentAtom.maxInnerMass) /\n            currentAtom.em), currentAtom.originalMinCount);\n        currentAtom.currentMaxCount = Math.min(Math.floor((targetMassCache.getMaxMass(currentCharge) -\n            currentMass -\n            currentAtom.minInnerMass) /\n            currentAtom.em), currentAtom.originalMaxCount);\n        currentAtom.currentCount = currentAtom.currentMinCount - 1;\n    }\n}\nfunction initializePossibilities(possibilities, currentIonization, targetMassCache) {\n    for (let i = 0; i < possibilities.length; i++) {\n        if (i === 0) {\n            updateCurrentAtom(possibilities[i], currentIonization);\n            setCurrentMinMax(possibilities[i], currentIonization, targetMassCache);\n        }\n        else {\n            updateCurrentAtom(possibilities[i], possibilities[i - 1]);\n        }\n    }\n}\n// eslint-disable-next-line no-unused-vars\nfunction possibilitiesToString(possibilities) {\n    return possibilities.map((a) => [\n        `mf:${a.mf}`,\n        `current:${a.currentCount}`,\n        `min:${a.currentMinCount}`,\n        `max:${a.currentMaxCount}`,\n        `charge:${a.currentCharge}`,\n    ]);\n}\nfunction getOrderMapping(possibilities) {\n    let mapping = possibilities.map((p, i) => ({ atom: p.mf, index: i }));\n    mapping.sort((a, b) => {\n        return (0, atom_sorter_1.atomSorter)(a.atom, b.atom);\n    });\n    return mapping.map((a) => a.index);\n}\n//# sourceMappingURL=findMFsSync.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.findMFs = findMFs;\nconst findMFsSync_1 = require(\"./findMFsSync\");\n/** @typedef {import('./types').MFResult} MFResult */\n/** @typedef {import('./types').MFFinderOptions} MFFinderOptions */\n/**\n * @param {number} targetMass - Monoisotopic mass\n * @param {MFFinderOptions} [options={}]\n * @returns {Promise<MFResult[]>}\n */\nasync function findMFs(targetMass, options = {}) {\n    return (0, findMFsSync_1.findMFsSync)(targetMass, options);\n}\n//# sourceMappingURL=findMFs.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.mfIncluded = mfIncluded;\nconst mf_parser_1 = require(\"mf-parser\");\nconst findMFsSync_js_1 = require(\"./findMFsSync.js\");\n/**\n * @param {string}        mf - the molecular formula to check\n * @param {string}        range - the range of MF to explore\n * @param {object}        [options={}]\n * @param {number}        [options.maxIterations=10000000] - Maximum number of iterations\n * @param {boolean}       [options.allowNeutral=true]\n * @param {string}        [options.ionizations=''] - string containing a comma separated list of modifications\n * @param {object}        [options.filter={}]\n * @param {number}        [options.filter.minCharge=-Infinity] - Minimal charge\n * @param {number}        [options.filter.maxCharge=+Infinity] - Maximal charge\n * @param {boolean}       [options.filter.absoluteCharge=false] - If true, the charge is absolute (so between 0 and +Infinity by default)\n * @param {object}        [options.filter.unsaturation={}]\n * @param {number}        [options.filter.unsaturation.min=-Infinity] - Minimal unsaturation\n * @param {number}        [options.filter.unsaturation.max=+Infinity] - Maximal unsaturation\n * @param {boolean}       [options.filter.unsaturation.onlyInteger=false] - Integer unsaturation\n * @param {boolean}       [options.filter.unsaturation.onlyNonInteger=false] - Non integer unsaturation\n * @param {object}        [options.filter.atoms] - object of atom:{min, max}\n * @param {function}      [options.filter.callback] - a function to filter the MF\n * @returns {boolean}\n */\nfunction mfIncluded(mf, range, options = {}) {\n    let targetEM = new mf_parser_1.MF(mf).getInfo().monoisotopicMass;\n    let results = (0, findMFsSync_js_1.findMFsSync)(targetEM, {\n        allowNeutral: true,\n        ...options,\n        ranges: range,\n        precision: 0.0000001,\n        limit: 1,\n    });\n    return results.mfs.length > 0;\n}\n//# sourceMappingURL=mfIncluded.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.fromMonoisotopicMass = fromMonoisotopicMass;\nconst mf_finder_1 = require(\"mf-finder\");\n/**\n * Generates a database 'monoisotopic' from a monoisotopic mass and various options\n * @param {number|string|array}    masses - Monoisotopic mass\n * @param {object}    [options={}]\n * @param {number}    [options.maxIterations=10000000] - Maximum number of iterations\n * @param {function}  [options.onStep] - Callback to do after each step\n * @param {boolean}   [options.allowNeutral=true]\n * @param {boolean}   [options.uniqueMFs=true]\n * @param {number}    [options.limit=1000] - Maximum number of results\n * @param {string}    [options.ionizations=''] - string containing a comma separated list of modifications\n * @param {string}    [options.ranges='C0-100 H0-100 O0-100 N0-100'] - range of mfs to search\n * @param {number}    [options.precision=100] - Allowed mass range based on precision\n * @param {object}    [options.filter={}]\n * @param {number}    [options.filter.minCharge=-Infinity] - Minimal charge\n * @param {number}    [options.filter.maxCharge=+Infinity] - Maximal charge\n * @param {boolean}   [options.filter.absoluteCharge=false] - If true, the charge is absolute (so between 0 and +Infinity by default)\n * @param {object}    [options.filter.unsaturation={}]\n * @param {number}    [options.filter.unsaturation.min=-Infinity] - Minimal unsaturation\n * @param {number}    [options.filter.unsaturation.max=+Infinity] - Maximal unsaturation\n * @param {boolean}    [options.filter.unsaturation.onlyInteger=false] - Integer unsaturation\n * @param {boolean}    [options.filter.unsaturation.onlyNonInteger=false] - Non integer unsaturation\n * @param {object}    [options.filter.atoms] - object of atom:{min, max}\n * @param {function}  [options.filter.callback] - a function to filter the MF\n * @returns {Promise}\n */\nasync function fromMonoisotopicMass(masses, options = {}) {\n    if (typeof masses === 'string') {\n        masses = masses.split(/[\\t\\n\\r ,;]/).map(Number);\n    }\n    if (typeof masses === 'number') {\n        masses = [masses];\n    }\n    let results = [];\n    for (let mass of masses) {\n        results.push(await (0, mf_finder_1.findMFs)(mass, options));\n    }\n    return {\n        mfs: results.flatMap((entry) => entry.mfs),\n        info: {\n            numberMFEvaluated: results.reduce((sum, current) => sum + current.info.numberMFEvaluated, 0),\n            numberResults: results.reduce((sum, current) => sum + current.info.numberResults, 0),\n        },\n    };\n}\n//# sourceMappingURL=fromMonoisotopicMass.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getPeaks = getPeaks;\nconst ml_spectra_processing_1 = require(\"ml-spectra-processing\");\n/**\n * Filter the array of peaks\n * @param {array} peaks - array of all the peaks\n * @param {object} [options={}]\n * @param {number} [options.from] - min X value of the window to consider\n * @param {number} [options.to] - max X value of the window to consider\n * @param {number} [options.threshold=0.01] - minimal intensity compare to base peak\n * @param {number} [options.limit=undefined] - maximal number of peaks (based on intensity)\n * @param {number} [options.sumValue] // if sumValue is defined, maxValue is ignored\n * @returns {array} - copy of peaks with 'close' annotation\n */\nfunction getPeaks(peaks, options = {}) {\n    const { from = (0, ml_spectra_processing_1.xyObjectMinXPoint)(peaks).x, to = (0, ml_spectra_processing_1.xyObjectMaxXPoint)(peaks).x, threshold = 0.01, limit, sumValue, } = options;\n    let maxY = Number.MIN_SAFE_INTEGER;\n    for (let peak of peaks) {\n        if (peak.y > maxY)\n            maxY = peak.y;\n    }\n    let minY = maxY * threshold;\n    peaks = peaks.filter((peak) => peak.x >= from && peak.x <= to && peak.y >= minY);\n    if (limit && peaks.length > limit) {\n        peaks.sort((a, b) => b.y - a.y);\n        peaks = peaks.slice(0, limit);\n    }\n    if (sumValue) {\n        peaks = structuredClone(peaks);\n        const currentSum = (0, ml_spectra_processing_1.xyObjectSumY)(peaks);\n        const ratio = sumValue / currentSum;\n        for (const peak of peaks) {\n            peak.y *= ratio;\n        }\n    }\n    return peaks.sort((a, b) => a.x - b.x);\n}\n//# sourceMappingURL=getPeaks.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getFragmentPeaks = getFragmentPeaks;\nconst mf_parser_1 = require(\"mf-parser\");\nconst fromMonoisotopicMass_1 = require(\"./from/fromMonoisotopicMass\");\nconst getPeaks_js_1 = require(\"./getPeaks.js\");\n/**\n * Filter the array of peaks\n * @param {array} peaks - array of all the peaks\n * @param {string} mf - Molecular formula of the parent molecule\n * @param {object} [options={}]\n * @param {number} [options.from] - min X value of the window to consider\n * @param {number} [options.to] - max X value of the window to consider\n * @param {number} [options.threshold=0.01] - minimal intensity compare to base peak\n * @param {number} [options.limit=undefined] - maximal number of peaks (based on intensity)\n * @param {string} [options.ionizations]\n * @param {number} [options.precision]\n * @returns {array} - copy of peaks with 'close' annotation\n */\nasync function getFragmentPeaks(peaks, mf, options = {}) {\n    const { ionizations = '', precision } = options;\n    const mfInfo = new mf_parser_1.MF(mf).getInfo();\n    const ranges = Object.keys(mfInfo.atoms)\n        .map((key) => `${key}0-${mfInfo.atoms[key]}`)\n        .join(' ');\n    peaks = (0, getPeaks_js_1.getPeaks)(peaks, options);\n    for (let peak of peaks) {\n        const { mfs } = await (0, fromMonoisotopicMass_1.fromMonoisotopicMass)(peak.x, {\n            precision,\n            ranges,\n            ionizations,\n        });\n        peak.mfs = mfs;\n    }\n    peaks = peaks.filter((peak) => peak.mfs.length > 0);\n    return peaks;\n}\n//# sourceMappingURL=getFragmentPeaks.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getMassRemainder = getMassRemainder;\nconst ml_spectra_processing_1 = require(\"ml-spectra-processing\");\n/**\n * Remove an integer number of time the specifiedd monoisotopic mass.\n * Mass remainder analysis (MARA): https://doi.org/10.1021/acs.analchem.7b04730\n * @param {object} spectrum\n * @param {number} mass\n * @param {object} [options={}]\n * @param {number} [options.delta=0.001]\n */\nfunction getMassRemainder(spectrum, mass, options = {}) {\n    const { delta = 0.001 } = options;\n    const x = spectrum.x.slice();\n    const y = spectrum.y;\n    for (let i = 0; i < x.length; i++) {\n        const factor = Math.floor(x[i] / mass);\n        x[i] = x[i] - factor * mass;\n    }\n    // we sort and join\n    return (0, ml_spectra_processing_1.xyJoinX)((0, ml_spectra_processing_1.xySortX)({ x, y }), { delta });\n}\n//# sourceMappingURL=getMassRemainder.js.map","export function calculateOverlapFromDiff(diffs) {\n    if (diffs[1].length === 0)\n        return 0;\n    let sumPos = 0;\n    for (let i = 0; i < diffs[1].length; i++) {\n        sumPos += Math.abs(diffs[1][i]);\n    }\n    return 1 - sumPos;\n}\n//# sourceMappingURL=calculateOverlapFromDiff.js.map","/**\n * This code requires the use of an array like  [[x1,y1],[x2,y2], ...]\n * If it is not the right format, we will just convert it\n * Otherwise we return the correct format\n * @param {Peaks} peaks\n * @returns [number[], number[]]\n */\nexport function checkPeaks(peaks) {\n    // if it is already a 2D array of points, we just return them\n    if (Array.isArray(peaks) && Array.isArray(peaks[0]) && peaks.length === 2) {\n        return peaks;\n    }\n    if (Array.isArray(peaks.x) && Array.isArray(peaks.y)) {\n        return [peaks.x, peaks.y];\n    }\n    const x = new Array(peaks.length);\n    const y = new Array(peaks.length);\n    for (let i = 0; i < peaks.length; i++) {\n        x[i] = peaks[i][0];\n        y[i] = peaks[i][1];\n    }\n    return [x, y];\n}\n//# sourceMappingURL=checkPeaks.js.map","export function extract(array, from, to) {\n    const newArray = [[], []];\n    let j = 0;\n    const length = array[0] ? array[0].length : 0;\n    for (let i = 0; i < length; i++) {\n        if ((!from || array[0][i] >= from) && (!to || array[0][i] <= to)) {\n            newArray[0][j] = array[0][i];\n            newArray[1][j] = array[1][i];\n            j++;\n        }\n    }\n    return newArray;\n}\n//# sourceMappingURL=extract.js.map","// returns an new array based on array1 where there is a peak of array2 at a distance under width/2\nexport function getCommonArray(array1, array2, width) {\n    const newArray = [[], []];\n    let pos2 = 0;\n    width /= 2;\n    let j = 0;\n    const array1Length = array1[0] ? array1[0].length : 0;\n    const array2Length = array2[0] ? array2[0].length : 0;\n    for (let i = 0; i < array1Length; i++) {\n        while (pos2 < array2Length && array1[0][i] > array2[0][pos2] + width) {\n            pos2++;\n        }\n        if (pos2 < array2Length && array1[0][i] > array2[0][pos2] - width) {\n            newArray[0][j] = array1[0][i];\n            newArray[1][j] = array1[1][i];\n            j++;\n        }\n    }\n    return newArray;\n}\n//# sourceMappingURL=getCommonArray.js.map","'use strict';\n\nfunction compareNumbers(a, b) {\n    return a - b;\n}\n\n/**\n * Computes the sum of the given values\n * @param {Array} values\n * @returns {number}\n */\nexports.sum = function sum(values) {\n    var sum = 0;\n    for (var i = 0; i < values.length; i++) {\n        sum += values[i];\n    }\n    return sum;\n};\n\n/**\n * Computes the maximum of the given values\n * @param {Array} values\n * @returns {number}\n */\nexports.max = function max(values) {\n    var max = values[0];\n    var l = values.length;\n    for (var i = 1; i < l; i++) {\n        if (values[i] > max) max = values[i];\n    }\n    return max;\n};\n\n/**\n * Computes the minimum of the given values\n * @param {Array} values\n * @returns {number}\n */\nexports.min = function min(values) {\n    var min = values[0];\n    var l = values.length;\n    for (var i = 1; i < l; i++) {\n        if (values[i] < min) min = values[i];\n    }\n    return min;\n};\n\n/**\n * Computes the min and max of the given values\n * @param {Array} values\n * @returns {{min: number, max: number}}\n */\nexports.minMax = function minMax(values) {\n    var min = values[0];\n    var max = values[0];\n    var l = values.length;\n    for (var i = 1; i < l; i++) {\n        if (values[i] < min) min = values[i];\n        if (values[i] > max) max = values[i];\n    }\n    return {\n        min: min,\n        max: max\n    };\n};\n\n/**\n * Computes the arithmetic mean of the given values\n * @param {Array} values\n * @returns {number}\n */\nexports.arithmeticMean = function arithmeticMean(values) {\n    var sum = 0;\n    var l = values.length;\n    for (var i = 0; i < l; i++) {\n        sum += values[i];\n    }\n    return sum / l;\n};\n\n/**\n * {@link arithmeticMean}\n */\nexports.mean = exports.arithmeticMean;\n\n/**\n * Computes the geometric mean of the given values\n * @param {Array} values\n * @returns {number}\n */\nexports.geometricMean = function geometricMean(values) {\n    var mul = 1;\n    var l = values.length;\n    for (var i = 0; i < l; i++) {\n        mul *= values[i];\n    }\n    return Math.pow(mul, 1 / l);\n};\n\n/**\n * Computes the mean of the log of the given values\n * If the return value is exponentiated, it gives the same result as the\n * geometric mean.\n * @param {Array} values\n * @returns {number}\n */\nexports.logMean = function logMean(values) {\n    var lnsum = 0;\n    var l = values.length;\n    for (var i = 0; i < l; i++) {\n        lnsum += Math.log(values[i]);\n    }\n    return lnsum / l;\n};\n\n/**\n * Computes the weighted grand mean for a list of means and sample sizes\n * @param {Array} means - Mean values for each set of samples\n * @param {Array} samples - Number of original values for each set of samples\n * @returns {number}\n */\nexports.grandMean = function grandMean(means, samples) {\n    var sum = 0;\n    var n = 0;\n    var l = means.length;\n    for (var i = 0; i < l; i++) {\n        sum += samples[i] * means[i];\n        n += samples[i];\n    }\n    return sum / n;\n};\n\n/**\n * Computes the truncated mean of the given values using a given percentage\n * @param {Array} values\n * @param {number} percent - The percentage of values to keep (range: [0,1])\n * @param {boolean} [alreadySorted=false]\n * @returns {number}\n */\nexports.truncatedMean = function truncatedMean(values, percent, alreadySorted) {\n    if (alreadySorted === undefined) alreadySorted = false;\n    if (!alreadySorted) {\n        values = [].concat(values).sort(compareNumbers);\n    }\n    var l = values.length;\n    var k = Math.floor(l * percent);\n    var sum = 0;\n    for (var i = k; i < (l - k); i++) {\n        sum += values[i];\n    }\n    return sum / (l - 2 * k);\n};\n\n/**\n * Computes the harmonic mean of the given values\n * @param {Array} values\n * @returns {number}\n */\nexports.harmonicMean = function harmonicMean(values) {\n    var sum = 0;\n    var l = values.length;\n    for (var i = 0; i < l; i++) {\n        if (values[i] === 0) {\n            throw new RangeError('value at index ' + i + 'is zero');\n        }\n        sum += 1 / values[i];\n    }\n    return l / sum;\n};\n\n/**\n * Computes the contraharmonic mean of the given values\n * @param {Array} values\n * @returns {number}\n */\nexports.contraHarmonicMean = function contraHarmonicMean(values) {\n    var r1 = 0;\n    var r2 = 0;\n    var l = values.length;\n    for (var i = 0; i < l; i++) {\n        r1 += values[i] * values[i];\n        r2 += values[i];\n    }\n    if (r2 < 0) {\n        throw new RangeError('sum of values is negative');\n    }\n    return r1 / r2;\n};\n\n/**\n * Computes the median of the given values\n * @param {Array} values\n * @param {boolean} [alreadySorted=false]\n * @returns {number}\n */\nexports.median = function median(values, alreadySorted) {\n    if (alreadySorted === undefined) alreadySorted = false;\n    if (!alreadySorted) {\n        values = [].concat(values).sort(compareNumbers);\n    }\n    var l = values.length;\n    var half = Math.floor(l / 2);\n    if (l % 2 === 0) {\n        return (values[half - 1] + values[half]) * 0.5;\n    } else {\n        return values[half];\n    }\n};\n\n/**\n * Computes the variance of the given values\n * @param {Array} values\n * @param {boolean} [unbiased=true] - if true, divide by (n-1); if false, divide by n.\n * @returns {number}\n */\nexports.variance = function variance(values, unbiased) {\n    if (unbiased === undefined) unbiased = true;\n    var theMean = exports.mean(values);\n    var theVariance = 0;\n    var l = values.length;\n\n    for (var i = 0; i < l; i++) {\n        var x = values[i] - theMean;\n        theVariance += x * x;\n    }\n\n    if (unbiased) {\n        return theVariance / (l - 1);\n    } else {\n        return theVariance / l;\n    }\n};\n\n/**\n * Computes the standard deviation of the given values\n * @param {Array} values\n * @param {boolean} [unbiased=true] - if true, divide by (n-1); if false, divide by n.\n * @returns {number}\n */\nexports.standardDeviation = function standardDeviation(values, unbiased) {\n    return Math.sqrt(exports.variance(values, unbiased));\n};\n\nexports.standardError = function standardError(values) {\n    return exports.standardDeviation(values) / Math.sqrt(values.length);\n};\n\n/**\n * IEEE Transactions on biomedical engineering, vol. 52, no. 1, january 2005, p. 76-\n * Calculate the standard deviation via the Median of the absolute deviation\n *  The formula for the standard deviation only holds for Gaussian random variables.\n * @returns {{mean: number, stdev: number}}\n */\nexports.robustMeanAndStdev = function robustMeanAndStdev(y) {\n    var mean = 0, stdev = 0;\n    var length = y.length, i = 0;\n    for (i = 0; i < length; i++) {\n        mean += y[i];\n    }\n    mean /= length;\n    var averageDeviations = new Array(length);\n    for (i = 0; i < length; i++)\n        averageDeviations[i] = Math.abs(y[i] - mean);\n    averageDeviations.sort(compareNumbers);\n    if (length % 2 === 1) {\n        stdev = averageDeviations[(length - 1) / 2] / 0.6745;\n    } else {\n        stdev = 0.5 * (averageDeviations[length / 2] + averageDeviations[length / 2 - 1]) / 0.6745;\n    }\n\n    return {\n        mean: mean,\n        stdev: stdev\n    };\n};\n\nexports.quartiles = function quartiles(values, alreadySorted) {\n    if (typeof (alreadySorted) === 'undefined') alreadySorted = false;\n    if (!alreadySorted) {\n        values = [].concat(values).sort(compareNumbers);\n    }\n\n    var quart = values.length / 4;\n    var q1 = values[Math.ceil(quart) - 1];\n    var q2 = exports.median(values, true);\n    var q3 = values[Math.ceil(quart * 3) - 1];\n\n    return {q1: q1, q2: q2, q3: q3};\n};\n\nexports.pooledStandardDeviation = function pooledStandardDeviation(samples, unbiased) {\n    return Math.sqrt(exports.pooledVariance(samples, unbiased));\n};\n\nexports.pooledVariance = function pooledVariance(samples, unbiased) {\n    if (typeof (unbiased) === 'undefined') unbiased = true;\n    var sum = 0;\n    var length = 0, l = samples.length;\n    for (var i = 0; i < l; i++) {\n        var values = samples[i];\n        var vari = exports.variance(values);\n\n        sum += (values.length - 1) * vari;\n\n        if (unbiased)\n            length += values.length - 1;\n        else\n            length += values.length;\n    }\n    return sum / length;\n};\n\nexports.mode = function mode(values) {\n    var l = values.length,\n        itemCount = new Array(l),\n        i;\n    for (i = 0; i < l; i++) {\n        itemCount[i] = 0;\n    }\n    var itemArray = new Array(l);\n    var count = 0;\n\n    for (i = 0; i < l; i++) {\n        var index = itemArray.indexOf(values[i]);\n        if (index >= 0)\n            itemCount[index]++;\n        else {\n            itemArray[count] = values[i];\n            itemCount[count] = 1;\n            count++;\n        }\n    }\n\n    var maxValue = 0, maxIndex = 0;\n    for (i = 0; i < count; i++) {\n        if (itemCount[i] > maxValue) {\n            maxValue = itemCount[i];\n            maxIndex = i;\n        }\n    }\n\n    return itemArray[maxIndex];\n};\n\nexports.covariance = function covariance(vector1, vector2, unbiased) {\n    if (typeof (unbiased) === 'undefined') unbiased = true;\n    var mean1 = exports.mean(vector1);\n    var mean2 = exports.mean(vector2);\n\n    if (vector1.length !== vector2.length)\n        throw 'Vectors do not have the same dimensions';\n\n    var cov = 0, l = vector1.length;\n    for (var i = 0; i < l; i++) {\n        var x = vector1[i] - mean1;\n        var y = vector2[i] - mean2;\n        cov += x * y;\n    }\n\n    if (unbiased)\n        return cov / (l - 1);\n    else\n        return cov / l;\n};\n\nexports.skewness = function skewness(values, unbiased) {\n    if (typeof (unbiased) === 'undefined') unbiased = true;\n    var theMean = exports.mean(values);\n\n    var s2 = 0, s3 = 0, l = values.length;\n    for (var i = 0; i < l; i++) {\n        var dev = values[i] - theMean;\n        s2 += dev * dev;\n        s3 += dev * dev * dev;\n    }\n    var m2 = s2 / l;\n    var m3 = s3 / l;\n\n    var g = m3 / (Math.pow(m2, 3 / 2.0));\n    if (unbiased) {\n        var a = Math.sqrt(l * (l - 1));\n        var b = l - 2;\n        return (a / b) * g;\n    } else {\n        return g;\n    }\n};\n\nexports.kurtosis = function kurtosis(values, unbiased) {\n    if (typeof (unbiased) === 'undefined') unbiased = true;\n    var theMean = exports.mean(values);\n    var n = values.length, s2 = 0, s4 = 0;\n\n    for (var i = 0; i < n; i++) {\n        var dev = values[i] - theMean;\n        s2 += dev * dev;\n        s4 += dev * dev * dev * dev;\n    }\n    var m2 = s2 / n;\n    var m4 = s4 / n;\n\n    if (unbiased) {\n        var v = s2 / (n - 1);\n        var a = (n * (n + 1)) / ((n - 1) * (n - 2) * (n - 3));\n        var b = s4 / (v * v);\n        var c = ((n - 1) * (n - 1)) / ((n - 2) * (n - 3));\n\n        return a * b - 3 * c;\n    } else {\n        return m4 / (m2 * m2) - 3;\n    }\n};\n\nexports.entropy = function entropy(values, eps) {\n    if (typeof (eps) === 'undefined') eps = 0;\n    var sum = 0, l = values.length;\n    for (var i = 0; i < l; i++)\n        sum += values[i] * Math.log(values[i] + eps);\n    return -sum;\n};\n\nexports.weightedMean = function weightedMean(values, weights) {\n    var sum = 0, l = values.length;\n    for (var i = 0; i < l; i++)\n        sum += values[i] * weights[i];\n    return sum;\n};\n\nexports.weightedStandardDeviation = function weightedStandardDeviation(values, weights) {\n    return Math.sqrt(exports.weightedVariance(values, weights));\n};\n\nexports.weightedVariance = function weightedVariance(values, weights) {\n    var theMean = exports.weightedMean(values, weights);\n    var vari = 0, l = values.length;\n    var a = 0, b = 0;\n\n    for (var i = 0; i < l; i++) {\n        var z = values[i] - theMean;\n        var w = weights[i];\n\n        vari += w * (z * z);\n        b += w;\n        a += w * w;\n    }\n\n    return vari * (b / (b * b - a));\n};\n\nexports.center = function center(values, inPlace) {\n    if (typeof (inPlace) === 'undefined') inPlace = false;\n\n    var result = values;\n    if (!inPlace)\n        result = [].concat(values);\n\n    var theMean = exports.mean(result), l = result.length;\n    for (var i = 0; i < l; i++)\n        result[i] -= theMean;\n};\n\nexports.standardize = function standardize(values, standardDev, inPlace) {\n    if (typeof (standardDev) === 'undefined') standardDev = exports.standardDeviation(values);\n    if (typeof (inPlace) === 'undefined') inPlace = false;\n    var l = values.length;\n    var result = inPlace ? values : new Array(l);\n    for (var i = 0; i < l; i++)\n        result[i] = values[i] / standardDev;\n    return result;\n};\n\nexports.cumulativeSum = function cumulativeSum(array) {\n    var l = array.length;\n    var result = new Array(l);\n    result[0] = array[0];\n    for (var i = 1; i < l; i++)\n        result[i] = result[i - 1] + array[i];\n    return result;\n};\n","'use strict';\n\nexports.array = require('./array');\nexports.matrix = require('./matrix');\n","import { array as StatArray } from 'ml-stat';\nexport function normalize(array) {\n    const min = StatArray.min(array[1]);\n    const max = StatArray.max(array[1]);\n    const sum = StatArray.sum(array[1]);\n    const length = array[1] ? array[1].length : 0;\n    if (sum !== 0) {\n        for (let i = 0; i < length; i++) {\n            array[1][i] /= sum;\n        }\n    }\n    return {\n        sum,\n        min,\n        max,\n    };\n}\n//# sourceMappingURL=normalize.js.map","import { extract } from './extract';\nimport { getCommonArray } from './getCommonArray';\nimport { normalize } from './normalize';\nimport { COMMON_SECOND, COMMON_FIRST } from './index';\n// this method will systematically take care of both array\nexport function commonExtractAndNormalize(array1, array2, width, from, to, common) {\n    if (!Array.isArray(array1) || !Array.isArray(array2)) {\n        return {\n            info: undefined,\n            data: undefined,\n        };\n    }\n    const extract1 = extract(array1, from, to);\n    const extract2 = extract(array2, from, to);\n    let common1, common2, info1, info2;\n    if (common & COMMON_SECOND) {\n        common1 = getCommonArray(extract1, extract2, width);\n        info1 = normalize(common1);\n    }\n    else {\n        common1 = extract1;\n        info1 = normalize(common1);\n    }\n    if (common & COMMON_FIRST) {\n        common2 = getCommonArray(extract2, extract1, width);\n        info2 = normalize(common2);\n    }\n    else {\n        common2 = extract2;\n        info2 = normalize(common2);\n    }\n    return {\n        info1,\n        info2,\n        data1: common1,\n        data2: common2,\n    };\n}\n//# sourceMappingURL=commonExtractAndNormalize.js.map","import { extract } from './extract';\nimport { normalize } from './normalize';\nexport function extractAndNormalize(array, from, to) {\n    if (!Array.isArray(array)) {\n        return {\n            info: undefined,\n            data: undefined,\n        };\n    }\n    const newArray = extract(array, from, to);\n    const info = normalize(newArray);\n    return {\n        info,\n        data: newArray,\n    };\n}\n//# sourceMappingURL=extractAndNormalize.js.map","// Adapted from: http://stackoverflow.com/questions/563198/how-do-you-detect-where-two-line-segments-intersect/1968345#1968345\nexport function getIntersection(segment1, segment2) {\n    const p0X = segment1[0][0];\n    const p0Y = segment1[0][1];\n    const p1X = segment1[1][0];\n    const p1Y = segment1[1][1];\n    const p2X = segment2[0][0];\n    const p2Y = segment2[0][1];\n    const p3X = segment2[1][0];\n    const p3Y = segment2[1][1];\n    const s1X = p1X - p0X;\n    const s1Y = p1Y - p0Y;\n    const s2X = p3X - p2X;\n    const s2Y = p3Y - p2Y;\n    const s = (-s1Y * (p0X - p2X) + s1X * (p0Y - p2Y)) / (-s2X * s1Y + s1X * s2Y);\n    const t = (s2X * (p0Y - p2Y) - s2Y * (p0X - p2X)) / (-s2X * s1Y + s1X * s2Y);\n    if (s >= 0 && s <= 1 && t >= 0 && t <= 1) {\n        return {\n            x: p0X + t * s1X,\n            y: p0Y + t * s1Y,\n        };\n    }\n    return null; // No collision\n}\n//# sourceMappingURL=getIntersection.js.map","import { calculateOverlapFromDiff } from './calculateOverlapFromDiff';\nimport { checkPeaks } from './checkPeaks';\nimport { commonExtractAndNormalize } from './commonExtractAndNormalize';\nimport { extract } from './extract';\nimport { extractAndNormalize } from './extractAndNormalize';\nimport { getCommonArray } from './getCommonArray.js';\nimport { getIntersection } from './getIntersection';\nimport { normalize } from './normalize';\nexport const COMMON_NO = 0;\nexport const COMMON_FIRST = 1;\nexport const COMMON_SECOND = 2;\nexport const COMMON_BOTH = 3;\n/**\n * A number, or a string containing a number.\n * @typedef {([number[],number[]]|[number,number][]|{x:number[],y:number[]})} Peaks\n */\n/**\n * Create a comparator class\n * {object} [options={}]\n * {string} [options.common=''] should we take only common peaks 'first', 'second', 'both', ''\n * {number} [options.widthBottom=2] bottom trapezoid width for similarity evaluation\n * {number} [options.widthTop=1] top trapezoid width for similarity evaluation\n * {number} [options.from] from region used for similarity calculation\n * {number} [options.to] to region used for similarity calculation\n */\nexport class Comparator {\n    constructor(options = {}) {\n        this.array1 = [];\n        this.array2 = [];\n        this.setOptions(options);\n    }\n    /*\n       2 formats are allowed:\n       [[x1,x2,...],[y1,y2,...]] or [[x1,y1],[x2,y2], ...]\n      */\n    setOptions(options = {}) {\n        if (typeof options.common === 'string') {\n            if (options.common.toLowerCase() === 'first') {\n                this.common = COMMON_FIRST;\n            }\n            else if (options.common.toLowerCase() === 'second') {\n                this.common = COMMON_SECOND;\n            }\n            else if (options.common.toLowerCase() === 'both') {\n                this.common = COMMON_BOTH;\n            }\n            else {\n                this.common = COMMON_NO;\n            }\n        }\n        else if (options.common === true) {\n            this.common = COMMON_BOTH;\n        }\n        else {\n            this.common = COMMON_NO;\n        }\n        this.trapezoid = options.trapezoid;\n        this.commonFactor = options.commonFactor || this.commonFactor || 4;\n        const { widthBottom = this.widthBottom || 2, widthTop = this.widthTop || 1, from = this.from, to = this.to, } = options;\n        this.setTrapezoid(widthBottom, widthTop);\n        this.setFromTo(from, to);\n    }\n    /**\n     *\n     * @param {Peaks} peaks\n     */\n    setPeaks1(peaks) {\n        this.array1 = checkPeaks(peaks);\n        if (this.common) {\n            const extracts = commonExtractAndNormalize(this.array1, this.array2, this.widthBottom, this.from, this.to, this.common);\n            this.array1Extract = extracts.data1;\n            this.array1ExtractInfo = extracts.info1;\n            this.array2Extract = extracts.data2;\n            this.array2ExtractInfo = extracts.info2;\n        }\n        else {\n            const extract = extractAndNormalize(this.array1, this.from, this.to);\n            this.array1Extract = extract.data;\n            this.array1ExtractInfo = extract.info;\n        }\n    }\n    /**\n     *\n     * @param {Peaks} peaks\n     */\n    setPeaks2(peaks) {\n        this.array2 = checkPeaks(peaks);\n        if (this.common) {\n            const extracts = commonExtractAndNormalize(this.array1, this.array2, this.widthBottom, this.from, this.to, this.common);\n            this.array1Extract = extracts.data1;\n            this.array1ExtractInfo = extracts.info1;\n            this.array2Extract = extracts.data2;\n            this.array2ExtractInfo = extracts.info2;\n        }\n        else {\n            const extract = extractAndNormalize(this.array2, this.from, this.to);\n            this.array2Extract = extract.data;\n            this.array2ExtractInfo = extract.info;\n        }\n    }\n    getExtract1() {\n        return this.array1Extract;\n    }\n    getExtract2() {\n        return this.array2Extract;\n    }\n    getExtractInfo1() {\n        return this.array1ExtractInfo;\n    }\n    getExtractInfo2() {\n        return this.array2ExtractInfo;\n    }\n    /**\n     * Set the new bottom and top width of the trapezoid\n     * @param {number} newWidthBottom\n     * @param {number} newWidthTop\n     */\n    setTrapezoid(newWidthBottom, newWidthTop) {\n        this.widthTop = newWidthTop;\n        this.widthBottom = newWidthBottom;\n        this.widthSlope = (this.widthBottom - this.widthTop) / 2;\n        if (this.widthBottom < this.widthTop) {\n            throw new Error('widthBottom has to be larger than widthTop');\n        }\n    }\n    /**\n     * Set the from / to for comparison\n     * @param {number} newFrom - set the new from value\n     * @param {number} newTo - set the new to value\n     * @returns\n     */\n    setFromTo(newFrom, newTo) {\n        if (newFrom === this.from && newTo === this.to)\n            return;\n        this.from = newFrom;\n        this.to = newTo;\n        if (this.common) {\n            const extracts = commonExtractAndNormalize(this.array1, this.array2, this.widthBottom, this.from, this.to, this.common, this.commonFactor);\n            this.array1Extract = extracts.data1;\n            this.array1ExtractInfo = extracts.info1;\n            this.array2Extract = extracts.data2;\n            this.array2ExtractInfo = extracts.info2;\n        }\n        else {\n            let extract1 = extractAndNormalize(this.array1, this.from, this.to);\n            this.array1Extract = extract1.data;\n            this.array1ExtractInfo = extract1.info;\n            let extract2 = extractAndNormalize(this.array2, this.from, this.to);\n            this.array2Extract = extract2.data;\n            this.array2ExtractInfo = extract2.info;\n        }\n    }\n    /**\n     *\n     * @param {number} x1\n     * @param {number} y1\n     * @param {number} x2\n     * @param {number} y2\n     * @returns\n     */\n    getOverlap(x1, y1, x2, y2) {\n        if (y1 === 0 || y2 === 0)\n            return 0;\n        // TAKE CARE !!! We multiply the diff by 2 !!!\n        const diff = Math.abs(x1 - x2) * 2;\n        if (diff > this.widthBottom)\n            return 0;\n        if (diff <= this.widthTop) {\n            return Math.min(y1, y2);\n        }\n        const maxValue = (Math.max(y1, y2) * (this.widthBottom - diff)) /\n            (this.widthBottom - this.widthTop);\n        return Math.min(y1, y2, maxValue);\n    }\n    /**\n     * This is the old trapezoid similarity\n     * @param {number} x1\n     * @param {number} y1\n     * @param {number} x2\n     * @param {number} y2\n     * @param {number} widthTop\n     * @param {number} widthBottom\n     * @returns\n     */\n    getOverlapTrapezoid(x1, y1, x2, y2, widthTop, widthBottom) {\n        // eslint-disable-next-line no-console\n        console.error('getOverlapTrapezoid should not be used anymore');\n        const factor = 2 / (widthTop + widthBottom); // correction for surface=1\n        if (y1 === 0 || y2 === 0)\n            return 0;\n        if (x1 === x2) {\n            // they have the same position\n            return Math.min(y1, y2);\n        }\n        const diff = Math.abs(x1 - x2);\n        if (diff >= widthBottom)\n            return 0;\n        if (y1 === y2) {\n            // do they have the same height ???\n            // we need to find the common length\n            if (diff <= widthTop) {\n                return ((widthTop + widthBottom) / 2 - diff) * y1 * factor;\n            }\n            else if (diff <= widthBottom) {\n                return ((((((widthBottom - diff) * y1) / 2) * (diff - widthTop)) /\n                    (widthBottom - widthTop)) *\n                    factor);\n            }\n            return 0;\n        }\n        else {\n            // the height are different and not the same position ...\n            // we need to consider only one segment to find its intersection\n            const small = Math.min(y1, y2);\n            const big = Math.max(y1, y2);\n            const targets = [\n                [\n                    [0, 0],\n                    [this.widthSlope, small],\n                ],\n                [\n                    [this.widthSlope, small],\n                    [this.widthSlope + widthTop, small],\n                ],\n                [\n                    [widthTop + this.widthSlope, small],\n                    [widthBottom, 0],\n                ],\n            ];\n            let segment;\n            if ((x1 > x2 && y1 > y2) || (x1 < x2 && y1 < y2)) {\n                segment = [\n                    [diff, 0],\n                    [diff + this.widthSlope, big],\n                ];\n            }\n            else {\n                segment = [\n                    [diff + this.widthSlope, big],\n                    [diff, 0],\n                ];\n            }\n            for (let i = 0; i < 3; i++) {\n                const intersection = getIntersection(targets[i], segment);\n                if (intersection) {\n                    switch (i) {\n                        case 0:\n                            return small - ((diff * intersection.y) / 2) * factor;\n                        case 1: // to simplify ...\n                            //     console.log(\"           \",widthSlope,small,big,intersection.x)\n                            return ((((this.widthSlope * small) / (2 * big)) * small +\n                                (widthTop + this.widthSlope - intersection.x) * small +\n                                (this.widthSlope * small) / 2) *\n                                factor);\n                        case 2:\n                            return (((widthBottom - diff) * intersection.y) / 2) * factor;\n                        default:\n                            throw new Error(`unexpected intersection value: ${i}`);\n                    }\n                }\n            }\n        }\n        return NaN;\n    }\n    /**\n     * This method calculates the total diff. The sum of positive value will yield to overlap\n     * @returns\n     */\n    calculateDiff() {\n        // we need to take 2 pointers\n        // and travel progressively between them ...\n        const newFirst = [\n            this.array1Extract[0].slice(),\n            this.array1Extract[1].slice(),\n        ];\n        const newSecond = [\n            this.array2Extract[0].slice(),\n            this.array2Extract[1].slice(),\n        ];\n        const array1Length = this.array1Extract[0]\n            ? this.array1Extract[0].length\n            : 0;\n        const array2Length = this.array2Extract[0]\n            ? this.array2Extract[0].length\n            : 0;\n        let pos1 = 0;\n        let pos2 = 0;\n        let previous2 = 0;\n        while (pos1 < array1Length) {\n            const diff = newFirst[0][pos1] - this.array2Extract[0][pos2];\n            if (Math.abs(diff) < this.widthBottom) {\n                // there is some overlap\n                let overlap;\n                if (this.trapezoid) {\n                    // old trapezoid overlap similarity\n                    overlap = this.getOverlapTrapezoid(newFirst[0][pos1], newFirst[1][pos1], newSecond[0][pos2], newSecond[1][pos2], this.widthTop, this.widthBottom);\n                }\n                else {\n                    overlap = this.getOverlap(newFirst[0][pos1], newFirst[1][pos1], newSecond[0][pos2], newSecond[1][pos2], this.widthTop, this.widthBottom);\n                }\n                newFirst[1][pos1] -= overlap;\n                newSecond[1][pos2] -= overlap;\n                if (pos2 < array2Length - 1) {\n                    pos2++;\n                }\n                else {\n                    pos1++;\n                    pos2 = previous2;\n                }\n            }\n            else if (diff > 0 && pos2 < array2Length - 1) {\n                pos2++;\n                previous2 = pos2;\n            }\n            else {\n                pos1++;\n                pos2 = previous2;\n            }\n        }\n        return newSecond;\n    }\n    /**\n     * Set the new peaks and return info\n     * @param {Peaks} newPeaks1\n     * @param {Peaks} newPeaks2\n     * @returns\n     */\n    getSimilarity(newPeaks1, newPeaks2) {\n        if (newPeaks1)\n            this.setPeaks1(newPeaks1);\n        if (newPeaks2)\n            this.setPeaks2(newPeaks2);\n        const diff = this.calculateDiff();\n        return {\n            diff,\n            extract1: this.getExtract1(),\n            extract2: this.getExtract2(),\n            extractInfo1: this.getExtractInfo1(),\n            extractInfo2: this.getExtractInfo2(),\n            similarity: calculateOverlapFromDiff(diff),\n            widthBottom: this.widthBottom,\n            widthTop: this.widthTop,\n        };\n    }\n    /**\n     * This works mainly when you have a array1 that is fixed\n     * newPeaks2 have to be normalized ! (sum to 1)\n     * @param {Peaks} newPeaks2\n     * @param {number} from\n     * @param {number} to\n     * @returns\n     */\n    fastSimilarity(newPeaks2, from, to) {\n        this.array1Extract = extract(this.array1, from, to);\n        this.array2Extract = newPeaks2;\n        if (this.common & COMMON_SECOND) {\n            this.array1Extract = getCommonArray(this.array1Extract, this.array2Extract, this.widthBottom);\n        }\n        normalize(this.array1Extract);\n        const diff = this.calculateDiff();\n        return calculateOverlapFromDiff(diff);\n    }\n}\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getPeakChargeBySimilarity = getPeakChargeBySimilarity;\nconst peaks_similarity_1 = require(\"peaks-similarity\");\n/**\n * @param {object}   [options={}]\n * @param {number}   [options.minCharge=1]\n * @param {number}   [options.maxCharge=10]\n * @param {object}   [options.similarity={}]\n * @param {number}   [options.similarity.widthBottom]\n * @param {number}   [options.similarity.widthTop]\n * @param {object}   [options.similarity.widthFunction] - function called with mass that should return an object width containing top and bottom\n * @param {object}   [options.similarity.zone={}]\n * @param {number}   [options.similarity.zone.low=-0.5] - window shift based on observed monoisotopic mass\n * @param {number}   [options.similarity.zone.high=2.5] - to value for the comparison window\n * @param {string}   [options.similarity.common]\n */\nconst NEUTRON_MASS = 1;\nfunction getPeakChargeBySimilarity(spectrum, targetMass, options = {}) {\n    let { similarity = {}, minCharge = 1, maxCharge = 10 } = options;\n    let { zone = {}, widthFunction } = similarity;\n    let { low = -0.5, high = 2.5 } = zone;\n    if (!spectrum || spectrum.data.x.length === 0) {\n        throw new Error('You need to add an experimental spectrum first using setMassSpectrum');\n    }\n    let width = {\n        bottom: similarity.widthBottom,\n        top: similarity.widthTop,\n    };\n    similarity = structuredClone(similarity);\n    similarity.common = 'second';\n    let experimentalData = spectrum.data;\n    let similarityProcessor = new peaks_similarity_1.Comparator(similarity);\n    similarityProcessor.setPeaks1([experimentalData.x, experimentalData.y]);\n    if (widthFunction && typeof widthFunction === 'string') {\n        // eslint-disable-next-line no-new-func\n        widthFunction = new Function('mass', widthFunction);\n        let checkTopBottom = widthFunction(123);\n        if (!checkTopBottom.bottom || !checkTopBottom.top) {\n            throw new Error('widthFunction should return an object with bottom and top properties');\n        }\n    }\n    let fromCharge = minCharge * maxCharge > 0\n        ? Math.round(Math.min(Math.abs(minCharge), Math.abs(maxCharge)))\n        : 1;\n    let toCharge = Math.round(Math.max(Math.abs(minCharge), Math.abs(maxCharge)));\n    let fromIsotope = Math.ceil(low);\n    let toIsotope = Math.floor(high);\n    let isotopeHeight = 1 / (toIsotope - fromIsotope + 1);\n    let results = [];\n    for (let charge = fromCharge; charge < toCharge + 1; charge++) {\n        let isotopePositions = { x: [], y: [] };\n        for (let isotopePosition = fromIsotope; isotopePosition < toIsotope + 1; isotopePosition++) {\n            isotopePositions.x.push(targetMass + (isotopePosition * NEUTRON_MASS) / charge);\n            isotopePositions.y.push(isotopeHeight);\n        }\n        let from = targetMass + low / Math.abs(charge);\n        let to = targetMass + high / Math.abs(charge);\n        similarityProcessor.setFromTo(from, to);\n        if (widthFunction) {\n            width = widthFunction(targetMass);\n            similarityProcessor.setTrapezoid(width.bottom, width.top);\n        }\n        similarityProcessor.setPeaks2([isotopePositions.x, isotopePositions.y]);\n        let result = similarityProcessor.getSimilarity();\n        results.push({ charge, similarity: result.similarity });\n    }\n    return results.sort((a, b) => b.similarity - a.similarity)[0].charge;\n}\n//# sourceMappingURL=getPeakChargeBySimilarity.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getPeaksWithCharge = getPeaksWithCharge;\n// We can not really take the real value of the neutron because it varies from one element to another.\nconst NEUTRON_MASS = 1;\n/**\n *\n * @param {Array} selectedPeaks\n * @param {Array} allPeaks\n * @param {object} [options={}]\n * @param {number} [options.min=1]\n * @param {number} [options.max=10]\n * @param {number} [options.low=-1]\n * @param {number} [options.high=1]\n * @param {number} [options.precision=30]\n * @returns\n */\nfunction getPeaksWithCharge(selectedPeaks, allPeaks, options = {}) {\n    let { precision = 100, low = -1, high = 1, min: minCharge = 1, max: maxCharge = 10, } = options;\n    let fromCharge = minCharge * maxCharge > 0\n        ? Math.round(Math.min(Math.abs(minCharge), Math.abs(maxCharge)))\n        : 1;\n    let toCharge = Math.round(Math.max(Math.abs(minCharge), Math.abs(maxCharge)));\n    let fromIsotope = Math.ceil(low);\n    let toIsotope = Math.floor(high);\n    let numberIsotopes = toIsotope - fromIsotope + 1;\n    let isotopeIntensity = 1 / numberIsotopes;\n    let fromIndex = 0;\n    let localFromIndex = 0;\n    let localToIndex = 0;\n    const peaksWithCharge = [];\n    for (const peak of selectedPeaks) {\n        let targetMass = peak.x;\n        localFromIndex = fromIndex;\n        let bestCharge = fromCharge;\n        let bestChargeMatch = 0;\n        for (let charge = fromCharge; charge < toCharge + 1; charge++) {\n            let theoreticalPositions = {\n                x: [],\n                y: new Array(numberIsotopes).fill(isotopeIntensity),\n            };\n            let massRange = precision * 1e-6 * targetMass;\n            for (let isotopePosition = fromIsotope; isotopePosition < toIsotope + 1; isotopePosition++) {\n                theoreticalPositions.x.push(targetMass + (isotopePosition * NEUTRON_MASS) / charge);\n            }\n            let fromMass = targetMass + low / Math.abs(charge) - massRange;\n            let toMass = targetMass + high / Math.abs(charge) + massRange;\n            if (charge === 1) {\n                // we may move the fromIndex\n                while (allPeaks[fromIndex].x < fromMass) {\n                    fromIndex++;\n                }\n            }\n            /*\n             * Find the from / to index for the specific peak and specific charge\n             */\n            while (allPeaks[localFromIndex].x < fromMass) {\n                localFromIndex++;\n            }\n            localToIndex = localFromIndex;\n            let localHeightSum = 0;\n            while (localToIndex < allPeaks.length &&\n                allPeaks[localToIndex].x < toMass) {\n                localHeightSum += allPeaks[localToIndex].y;\n                localToIndex++;\n            }\n            localToIndex--;\n            //  console.log({ localFromIndex, localToIndex });\n            /*\n              Calculate the overlap for a specific peak and specific charge\n            */\n            let currentTheoreticalPosition = 0;\n            let theoreticalMaxValue = 1 / numberIsotopes;\n            let totalMatch = 0;\n            for (let index = localFromIndex; index <= localToIndex; index++) {\n                let minMass = theoreticalPositions.x[currentTheoreticalPosition] -\n                    massRange / charge;\n                let maxMass = theoreticalPositions.x[currentTheoreticalPosition] +\n                    massRange / charge;\n                while (maxMass < allPeaks[index].x) {\n                    currentTheoreticalPosition++;\n                    theoreticalMaxValue = 1 / numberIsotopes;\n                    minMass =\n                        theoreticalPositions.x[currentTheoreticalPosition] -\n                            massRange / charge;\n                    maxMass =\n                        theoreticalPositions.x[currentTheoreticalPosition] +\n                            massRange / charge;\n                }\n                while (index < allPeaks.length && allPeaks[index].x < minMass) {\n                    index++;\n                }\n                //    console.log({ index, minMass, maxMass, massRange, localHeightSum });\n                if (index < allPeaks.length && allPeaks[index].x <= maxMass) {\n                    while (index < allPeaks.length && allPeaks[index].x <= maxMass) {\n                        if (allPeaks[index].x >= minMass && allPeaks[index].x <= maxMass) {\n                            let value = allPeaks[index].y / localHeightSum;\n                            //      console.log({ theoreticalMaxValue, value });\n                            value = Math.min(theoreticalMaxValue, value);\n                            theoreticalMaxValue -= value;\n                            totalMatch += value;\n                        }\n                        index++;\n                    }\n                    index--;\n                }\n                if (totalMatch > bestChargeMatch) {\n                    bestCharge = charge;\n                    bestChargeMatch = totalMatch;\n                }\n            }\n        }\n        peaksWithCharge.push({ ...peak, charge: bestCharge });\n    }\n    return peaksWithCharge;\n}\n//# sourceMappingURL=getPeaksWithCharge.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.isContinuous = isContinuous;\nconst ml_spectra_processing_1 = require(\"ml-spectra-processing\");\n/**\n * When a spectrum is continous ?\n * - has more than 100 points\n * - deltaX change can not be more than a factor 2\n * - deltaX may not be larger than 0.1\n * - if y is zero it does not count\n * @param {object} spectrum\n * @param {object} [options={}]\n * @param {number} [options.minLength=100]\n * @param {number} [options.relativeHeightThreshold=0.001] // Under this value the\n * @param {number} [options.maxDeltaRatio=3]\n */\nfunction isContinuous(spectrum, options = {}) {\n    const { minLength = 100, maxDeltaRatio = 3, relativeHeightThreshold = 0.001, } = options;\n    const minHeight = (0, ml_spectra_processing_1.xMaxValue)(spectrum.data.y) * relativeHeightThreshold;\n    const minRadio = 1 / maxDeltaRatio;\n    const maxRatio = 1 * maxDeltaRatio;\n    if (spectrum.continuous === undefined) {\n        let xs = spectrum.data.x;\n        let ys = spectrum.data.y;\n        if (xs.length < minLength) {\n            spectrum.continuous = false;\n        }\n        else {\n            let previousDelta = xs[1] - xs[0];\n            spectrum.continuous = true;\n            let success = 0;\n            let failed = 0;\n            for (let i = 0; i < xs.length - 1; i++) {\n                if (ys[i] < minHeight || ys[i + 1] < minHeight) {\n                    previousDelta = 0;\n                    continue;\n                }\n                let delta = xs[i + 1] - xs[i];\n                if (previousDelta) {\n                    let ratio = delta / previousDelta;\n                    if ((Math.abs(delta) > 0.1 || ratio < minRadio || ratio > maxRatio) &&\n                        ys[i] !== 0 &&\n                        ys[i + 1] !== 0) {\n                        failed++;\n                    }\n                    else {\n                        success++;\n                    }\n                }\n                previousDelta = delta;\n            }\n            if (success / failed < 10) {\n                spectrum.continuous = false;\n            }\n        }\n    }\n    return spectrum.continuous;\n}\n//# sourceMappingURL=isContinuous.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.peakPicking = peakPicking;\nconst ml_gsd_1 = require(\"ml-gsd\");\nconst ml_spectra_processing_1 = require(\"ml-spectra-processing\");\n/**\n * Filter the array of peaks\n * @param {import('./Spectrum')} spectrum - array of all the peaks\n * @returns {array}\n */\nfunction peakPicking(spectrum) {\n    if (!spectrum.peaks || spectrum.peaks.length === 0) {\n        spectrum.peaks = [];\n        const keys = Object.keys(spectrum.data).filter((key) => key !== 'x' && key !== 'y');\n        if (spectrum.isContinuous()) {\n            // some experimental data are really problematic and we need to add this line\n            const data = (0, ml_spectra_processing_1.xyEnsureGrowingX)(spectrum.data);\n            const gsdPeaks = (0, ml_gsd_1.gsd)(data, {\n                minMaxRatio: spectrum.options.threshold || 0.00025, // Threshold to determine if a given peak should be considered as a noise\n                realTopDetection: true,\n                smoothY: false,\n                sgOptions: { windowSize: 7, polynomial: 3 },\n            });\n            for (let gsdPeak of gsdPeaks) {\n                const peak = { x: gsdPeak.x, y: gsdPeak.y, width: gsdPeak.width };\n                for (let key of keys) {\n                    peak[key] = spectrum.data[key][gsdPeak.index];\n                }\n                spectrum.peaks.push(peak);\n            }\n        }\n        else {\n            spectrum.peaks = [];\n            let data = spectrum.data;\n            for (let i = 0; i < data.x.length; i++) {\n                const peak = {\n                    x: data.x[i],\n                    y: data.y[i],\n                    width: 0,\n                };\n                for (let key of keys) {\n                    peak[key] = spectrum.data[key][i];\n                }\n                spectrum.peaks.push(peak);\n            }\n        }\n    }\n    return spectrum.peaks;\n}\n//# sourceMappingURL=peakPicking.js.map","import { BaseRegression, checkArrayLength, maybeToPrecision, } from 'ml-regression-base';\n/**\n * Class representing simple linear regression.\n * The regression uses OLS to calculate intercept and slope.\n */\nexport class SimpleLinearRegression extends BaseRegression {\n    /**\n     * @param x - explanatory variable\n     * @param y - response variable\n     */\n    constructor(x, y) {\n        super();\n        // @ts-expect-error internal use of the constructor, from `this.load`\n        if (x === true) {\n            // @ts-expect-error internal use of the constructor, from `this.load`\n            const yObj = y;\n            this.slope = yObj.slope;\n            this.intercept = yObj.intercept;\n            this.coefficients = [yObj.intercept, yObj.slope];\n        }\n        else {\n            checkArrayLength(x, y);\n            const result = regress(x, y);\n            this.slope = result.slope;\n            this.intercept = result.intercept;\n            this.coefficients = [result.intercept, result.slope];\n        }\n    }\n    /**\n     * Get the parameters and model name in JSON format\n     * @returns\n     */\n    toJSON() {\n        return {\n            name: 'simpleLinearRegression',\n            slope: this.slope,\n            intercept: this.intercept,\n        };\n    }\n    _predict(x) {\n        return this.slope * x + this.intercept;\n    }\n    /**\n     * Finds x for the given y value.\n     * @param y - response variable value\n     * @returns - x value\n     */\n    computeX(y) {\n        return (y - this.intercept) / this.slope;\n    }\n    /**\n     * Strings the linear function in the form 'f(x) = ax + b'\n     * @param precision - number of significant figures.\n     * @returns\n     */\n    toString(precision) {\n        let result = 'f(x) = ';\n        if (this.slope !== 0) {\n            const xFactor = maybeToPrecision(this.slope, precision);\n            result += `${xFactor === '1' ? '' : `${xFactor} * `}x`;\n            if (this.intercept !== 0) {\n                const absIntercept = Math.abs(this.intercept);\n                const operator = absIntercept === this.intercept ? '+' : '-';\n                result += ` ${operator} ${maybeToPrecision(absIntercept, precision)}`;\n            }\n        }\n        else {\n            result += maybeToPrecision(this.intercept, precision);\n        }\n        return result;\n    }\n    /**\n     * Strings the linear function in the form 'f(x) = ax + b'\n     * @param precision - number of significant figures.\n     * @returns\n     */\n    toLaTeX(precision) {\n        return this.toString(precision);\n    }\n    /**\n     * Class instance from a JSON Object.\n     * @param json\n     * @returns\n     */\n    static load(json) {\n        if (json.name !== 'simpleLinearRegression') {\n            throw new TypeError('not a SLR model');\n        }\n        // @ts-expect-error internal use of the constructor\n        return new SimpleLinearRegression(true, json);\n    }\n}\n/**\n * Internal  function.\n * It determines the parameters (slope, intercept) of the line that best fit the `x,y` vector-data (simple linear regression).\n * @param x - explanatory variable\n * @param y - response variable\n * @returns - slope and intercept of the best fit line\n */\nfunction regress(x, y) {\n    const n = x.length;\n    let xSum = 0;\n    let ySum = 0;\n    let xSquared = 0;\n    let xY = 0;\n    for (let i = 0; i < n; i++) {\n        xSum += x[i];\n        ySum += y[i];\n        xSquared += x[i] * x[i];\n        xY += x[i] * y[i];\n    }\n    const numerator = n * xY - xSum * ySum;\n    const slope = numerator / (n * xSquared - xSum * xSum);\n    return {\n        slope,\n        intercept: (1 / n) * ySum - slope * (1 / n) * xSum,\n    };\n}\n//# sourceMappingURL=index.js.map","import {\n  BaseRegression,\n  checkArrayLength,\n  maybeToPrecision,\n} from 'ml-regression-base';\nimport { SimpleLinearRegression } from 'ml-regression-simple-linear';\n\nexport class PowerRegression extends BaseRegression {\n  constructor(x, y) {\n    super();\n    if (x === true) {\n      // reloading model\n      this.A = y.A;\n      this.B = y.B;\n    } else {\n      checkArrayLength(x, y);\n      regress(this, x, y);\n    }\n  }\n\n  _predict(newInputs) {\n    return this.A * newInputs ** this.B;\n  }\n\n  toJSON() {\n    return {\n      name: 'powerRegression',\n      A: this.A,\n      B: this.B,\n    };\n  }\n\n  toString(precision) {\n    return `f(x) = ${maybeToPrecision(\n      this.A,\n      precision,\n    )} * x^${maybeToPrecision(this.B, precision)}`;\n  }\n\n  toLaTeX(precision) {\n    let latex = '';\n    if (this.B >= 0) {\n      latex = `f(x) = ${maybeToPrecision(\n        this.A,\n        precision,\n      )}x^{${maybeToPrecision(this.B, precision)}}`;\n    } else {\n      latex = `f(x) = \\\\frac{${maybeToPrecision(\n        this.A,\n        precision,\n      )}}{x^{${maybeToPrecision(-this.B, precision)}}}`;\n    }\n    latex = latex.replace(/e([+-]?[0-9]+)/g, 'e^{$1}');\n    return latex;\n  }\n\n  static load(json) {\n    if (json.name !== 'powerRegression') {\n      throw new TypeError('not a power regression model');\n    }\n    return new PowerRegression(true, json);\n  }\n}\n\nfunction regress(pr, x, y) {\n  const n = x.length;\n  const xl = new Array(n);\n  const yl = new Array(n);\n  for (let i = 0; i < n; i++) {\n    xl[i] = Math.log(x[i]);\n    yl[i] = Math.log(y[i]);\n  }\n\n  const linear = new SimpleLinearRegression(xl, yl);\n  pr.A = Math.exp(linear.intercept);\n  pr.B = linear.slope;\n}\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.peaksWidth = peaksWidth;\nconst ml_regression_power_1 = require(\"ml-regression-power\");\nconst ml_spectra_processing_1 = require(\"ml-spectra-processing\");\nfunction peaksWidth(peaks) {\n    let xs = peaks.map((peak) => peak.x);\n    let widths = peaks.map((peak) => peak.width);\n    if (xs.length < 2) {\n        throw new Error(`peaksWidth: not enough peaks (less than 2) for automatic width calculation: ${xs.length}`);\n    }\n    let regression = new ml_regression_power_1.PowerRegression(xs, widths);\n    if (Number.isNaN(regression.A) || Number.isNaN(regression.B)) {\n        throw new Error('peaksWidth: can not calculate regression');\n    }\n    let from = (0, ml_spectra_processing_1.xMinValue)(xs);\n    let to = (0, ml_spectra_processing_1.xMaxValue)(xs);\n    let regressionChart = { x: [], y: [] };\n    for (let x = from; x <= to; x += (to - from) / 1000) {\n        regressionChart.x.push(x);\n        regressionChart.y.push(regression.predict(x));\n    }\n    return {\n        widths: {\n            x: xs,\n            y: widths,\n        },\n        fit: regressionChart,\n        score: regression.score(xs, widths),\n        predictFct: regression.predict.bind(regression),\n        tex: regression.toLaTeX(3),\n        A: regression.A,\n        B: regression.B,\n        predictFctString: `${regression.A} * mass ** ${regression.B}`,\n    };\n}\n//# sourceMappingURL=peaksWidth.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Spectrum = void 0;\nexports.fromPeaks = fromPeaks;\nexports.fromText = fromText;\nconst is_any_array_1 = require(\"is-any-array\");\nconst ml_spectra_processing_1 = require(\"ml-spectra-processing\");\nconst xy_parser_1 = require(\"xy-parser\");\nconst getBestPeaks_js_1 = require(\"./getBestPeaks.js\");\nconst getFragmentPeaks_js_1 = require(\"./getFragmentPeaks.js\");\nconst getMassRemainder_js_1 = require(\"./getMassRemainder.js\");\nconst getPeakChargeBySimilarity_js_1 = require(\"./getPeakChargeBySimilarity.js\");\nconst getPeaks_js_1 = require(\"./getPeaks.js\");\nconst getPeaksWithCharge_js_1 = require(\"./getPeaksWithCharge.js\");\nconst isContinuous_js_1 = require(\"./isContinuous.js\");\nconst peakPicking_js_1 = require(\"./peakPicking.js\");\nconst peaksWidth_js_1 = require(\"./peaksWidth.js\");\nconst defaultData = { x: [], y: [] };\n/**\n * Class dealing with mass spectra and peak picking\n */\nclass Spectrum {\n    /**\n     *\n     * @param {import('cheminfo-types').DataXY} data\n     * @param {object} [options={}]\n     * @param {number} [options.threshold=0.00025]\n     */\n    constructor(data = defaultData, options = {}) {\n        if (typeof data !== 'object' ||\n            !(0, is_any_array_1.isAnyArray)(data.x) ||\n            !(0, is_any_array_1.isAnyArray)(data.y)) {\n            throw new TypeError('Spectrum data must be an object with x:[], y:[]');\n        }\n        this.data = { ...data };\n        this.options = { threshold: 0.00025, ...options };\n        Object.defineProperty(this.data, 'xOriginal', {\n            enumerable: false,\n            writable: true,\n        });\n        if (this.data && this.data.x.length > 0) {\n            this.info = {\n                minX: (0, ml_spectra_processing_1.xMinValue)(this.data.x),\n                maxX: (0, ml_spectra_processing_1.xMaxValue)(this.data.x),\n                minY: (0, ml_spectra_processing_1.xMinValue)(this.data.y),\n                maxY: (0, ml_spectra_processing_1.xMaxValue)(this.data.y),\n            };\n        }\n        else {\n            this.info = {\n                minX: Number.NaN,\n                maxX: Number.NaN,\n                minY: Number.NaN,\n                maxY: Number.NaN,\n            };\n        }\n        this.cache = {};\n        /**\n         * someProperty is an example property that is set to `true`\n         * @type {array}\n         * @public\n         */\n        this.peaks = [];\n    }\n    minMaxX() {\n        return (0, ml_spectra_processing_1.xMinMaxValues)(this.data.x);\n    }\n    /**\n     *\n     * @param {import('ml-spectra-processing').XYMaxYOptions} options\n     * @returns\n     */\n    maxY(options) {\n        return (0, ml_spectra_processing_1.xyMaxY)(this.data, options);\n    }\n    sumY() {\n        if (!this.cache.sumY) {\n            this.cache.sumY = (0, ml_spectra_processing_1.xSum)(this.data.y);\n        }\n        return this.cache.sumY;\n    }\n    scaleY(intensity = 1) {\n        this.data.y = Array.from((0, ml_spectra_processing_1.xNormed)(this.data.y, { value: intensity, algorithm: 'max' }));\n        return this;\n    }\n    rescaleX(callback) {\n        this.ensureOriginalX();\n        for (let i = 0; i < this.data.x.length; i++) {\n            this.data.x[i] = callback(this.data.xOriginal[i]);\n        }\n        return this;\n    }\n    ensureOriginalX() {\n        if (!this.data.xOriginal) {\n            this.data.xOriginal = this.data.x.slice(0);\n        }\n    }\n    normedY(total = 1) {\n        this.data.y = (0, ml_spectra_processing_1.xNormed)(this.data.y, { value: total });\n        return this;\n    }\n    peakPicking() {\n        (0, peakPicking_js_1.peakPicking)(this);\n        return this.peaks;\n    }\n    peaksWidth() {\n        (0, peakPicking_js_1.peakPicking)(this);\n        return (0, peaksWidth_js_1.peaksWidth)(this.peaks);\n    }\n    getBestPeaks(options) {\n        (0, peakPicking_js_1.peakPicking)(this);\n        return (0, getBestPeaks_js_1.getBestPeaks)(this.peaks, options);\n    }\n    /**\n     * This is a very intensive function so better to calculate it on a selection of peaks\n     * @param {Array} selectedPeaks\n     * @param {object} [options={}]\n     * @param {number} [options.min=1]\n     * @param {number} [options.max=10]\n     * @param {number} [options.low=-1]\n     * @param {number} [options.high=1]\n     * @param {number} [options.precision=30]\n     * @returns\n     */\n    getSelectedPeaksWithCharge(selectedPeaks, options) {\n        return (0, getPeaksWithCharge_js_1.getPeaksWithCharge)(selectedPeaks, this.peaks, options);\n    }\n    getPeakChargeBySimilarity(targetMass, options) {\n        return (0, getPeakChargeBySimilarity_js_1.getPeakChargeBySimilarity)(this, targetMass, options);\n    }\n    getPeaks(options) {\n        (0, peakPicking_js_1.peakPicking)(this);\n        return (0, getPeaks_js_1.getPeaks)(this.peaks, options);\n    }\n    getPeaksAsDataXY(options) {\n        (0, peakPicking_js_1.peakPicking)(this);\n        const peaks = (0, getPeaks_js_1.getPeaks)(this.peaks, options);\n        return {\n            x: peaks.map((peak) => peak.x),\n            y: peaks.map((peak) => peak.y),\n        };\n    }\n    /**\n     * Returns also peaks possible for a specific molecular formula\n     * @example\n     *  const spectrum = new Spectrum({x:[], y:[]})\n     *  await spectrum.getFragmentPeaks();\n     * @param {string} mf\n     * @param {object} options\n     * @returns\n     */\n    getFragmentPeaksFct(mf, options) {\n        (0, peakPicking_js_1.peakPicking)(this);\n        return (0, getFragmentPeaks_js_1.getFragmentPeaks)(this.peaks, mf, options);\n    }\n    isContinuous() {\n        return (0, isContinuous_js_1.isContinuous)(this);\n    }\n    /**\n     * Remove an integer number of time the specifiedd monoisotopic mass\n     * Mass remainder analysis (MARA): https://doi.org/10.1021/acs.analchem.7b04730\n     */\n    getMassRemainderFct(mass, options = {}) {\n        return (0, getMassRemainder_js_1.getMassRemainder)(this.data, mass, options);\n    }\n}\nexports.Spectrum = Spectrum;\nfunction fromPeaks(peaks) {\n    if (peaks.length === 0)\n        return new Spectrum();\n    const data = {};\n    for (let key of Object.keys(peaks[0])) {\n        data[key] = peaks.map((peak) => peak[key]);\n    }\n    return new Spectrum(data);\n}\nfunction fromText(text, options) {\n    const data = (0, xy_parser_1.parseXY)(text);\n    return new Spectrum(data, options);\n}\n//# sourceMappingURL=Spectrum.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.MSComparator = void 0;\nconst ml_spectra_processing_1 = require(\"ml-spectra-processing\");\nclass MSComparator {\n    /**\n     * Create a class that will be able to get the similarity between 2 spectra\n     * The similarity is based on 'cosine' similarity. The goal is 2 prepare 2 vectors\n     * on which the similarity is calculated.\n     * The vectors are created by taking the mass and the intensity of the peaks.\n     * @param {object} [options={}]\n     * @param {number} [options.nbPeaks] - Before comparing spectra how many peaks should be kept\n     * @param {number} [options.minNbCommonPeaks] - Minimum number of peaks in common to consider any similarity\n     * @param {number} [options.minIntensity] - What is the minimal relative intensity to keep a peak\n     * @param {number} [options.massPower=3] - High power will give more weight to the mass. If you would prefer to observe fragments you should use a number less than 1\n     * @param {number} [options.intensityPower=0.6] - How important is the intensity. By default we don't give to much importance to it\n     * @param {number[]} [options.selectedMasses] - List of allowed masses.\n     * @param {number|Function} [options.delta=0.1] - Tolerance in Da (u) to consider 2 peaks as aligned. If a function is provided it will be called with the mass of the peak\n     */\n    constructor(options = {}) {\n        this.options = {\n            massPower: 3,\n            intensityPower: 0.6,\n            delta: 0.1,\n            ...options,\n        };\n        this.cache = new WeakMap();\n    }\n    /**\n     * Get the similarity between a spectrum and a list of masses.\n     * The main issue is that we don't have the intensity of the peaks.\n     * So we will use the intensity of the closest peak.\n     * @param {import('cheminfo-types').DataXY} dataXY\n     * @param {number[]} masses\n     */\n    getSimilarityToMasses(dataXY, masses) {\n        const data1 = normalizeAndCacheData(this.cache, dataXY, this.options);\n        const data2 = {\n            x: Float64Array.from(masses),\n            y: new Float64Array(masses.length).fill(1),\n        };\n        let aligned;\n        if (this.options.selectedMasses?.length > 0) {\n            aligned = (0, ml_spectra_processing_1.xyArrayAlign)([\n                data1,\n                data2,\n                {\n                    // this allows to force the selection of some specific masses\n                    x: Float64Array.from(this.options.selectedMasses),\n                    y: new Float64Array(this.options.selectedMasses.length).fill(1),\n                },\n            ], {\n                delta: this.options.delta,\n                requiredY: true,\n            });\n        }\n        else {\n            aligned = (0, ml_spectra_processing_1.xyArrayAlign)([data1, data2], {\n                delta: this.options.delta,\n            });\n        }\n        // because we don't have any idea of the intensity we will use the intensity of the experimental peak\n        // and otherwise we ignore the theoretical peak\n        for (let i = 0; i < aligned.ys[0].length; i++) {\n            if (aligned.ys[0][i] === 0) {\n                aligned.ys[1][i] = 0;\n            }\n            if (aligned.ys[0][i] > 0 && aligned.ys[1][i] !== 0) {\n                aligned.ys[1][i] = aligned.ys[0][i];\n            }\n        }\n        return returnSimilarity(aligned, this.options);\n    }\n    /**\n     *\n     * @param {import('cheminfo-types').DataXY} dataXY1\n     * @param {import('cheminfo-types').DataXY} dataXY2\n     */\n    getSimilarity(dataXY1, dataXY2) {\n        const data1 = normalizeAndCacheData(this.cache, dataXY1, this.options);\n        const data2 = normalizeAndCacheData(this.cache, dataXY2, this.options);\n        let aligned;\n        if (this.options.selectedMasses?.length > 0) {\n            aligned = (0, ml_spectra_processing_1.xyArrayAlign)([\n                data1,\n                data2,\n                {\n                    // this allows to force the selection of some specific masses\n                    x: Float64Array.from(this.options.selectedMasses),\n                    y: new Float64Array(this.options.selectedMasses.length).fill(1),\n                },\n            ], {\n                delta: this.options.delta,\n                requiredY: true,\n            });\n        }\n        else {\n            aligned = (0, ml_spectra_processing_1.xyArrayAlign)([data1, data2], {\n                delta: this.options.delta,\n            });\n        }\n        return returnSimilarity(aligned, this.options);\n    }\n}\nexports.MSComparator = MSComparator;\n/**\n *\n * @param {WeakMap} cache\n * @param {import('cheminfo-types').DataXY} dataXY\n * @param {object} [options={}]\n * @param {number} [options.nbPeaks]\n * @param {number} [options.minIntensity]\n */\nfunction normalizeAndCacheData(cache, dataXY, options = {}) {\n    const { nbPeaks, minIntensity } = options;\n    if (cache.has(dataXY))\n        return cache.get(dataXY);\n    let data = { ...dataXY };\n    if ((0, ml_spectra_processing_1.xIsMonotonic)(data.x) !== 1) {\n        data = (0, ml_spectra_processing_1.xySortX)(data);\n    }\n    if (minIntensity !== undefined) {\n        data = (0, ml_spectra_processing_1.xyFilterMinYValue)(data, minIntensity);\n    }\n    if (nbPeaks !== undefined) {\n        data = (0, ml_spectra_processing_1.xyFilterTopYValues)(data, nbPeaks);\n    }\n    cache.set(dataXY, data);\n    return data;\n}\n/**\n *\n * @param {*} aligned\n * @param {object} [options={}]\n * @param {number} [options.massPower]\n * @param {number} [options.intensityPower]\n * @param {number} [options.minNbCommonPeaks]\n\n * @returns\n */\nfunction returnSimilarity(aligned, options = {}) {\n    const { massPower, intensityPower, minNbCommonPeaks } = options;\n    let nbCommonPeaks = 0;\n    let nbPeaks1 = 0;\n    let nbPeaks2 = 0;\n    for (let i = 0; i < aligned.ys[0].length; i++) {\n        if (aligned.ys[0][i] !== 0) {\n            nbPeaks1++;\n        }\n        if (aligned.ys[1][i] !== 0) {\n            nbPeaks2++;\n        }\n        if (aligned.ys[0][i] !== 0 && aligned.ys[1][i] !== 0) {\n            nbCommonPeaks++;\n        }\n    }\n    if (nbCommonPeaks === 0 ||\n        (minNbCommonPeaks && nbCommonPeaks < minNbCommonPeaks)) {\n        return {\n            nbCommonPeaks,\n            nbPeaks1,\n            nbPeaks2,\n            tanimoto: 0,\n            cosine: 0,\n        };\n    }\n    const vector1 = new Float64Array(aligned.x.length);\n    const vector2 = new Float64Array(aligned.x.length);\n    for (let i = 0; i < aligned.x.length; i++) {\n        vector1[i] = aligned.x[i] ** massPower * aligned.ys[0][i] ** intensityPower;\n        vector2[i] = aligned.x[i] ** massPower * aligned.ys[1][i] ** intensityPower;\n    }\n    return {\n        nbCommonPeaks,\n        nbPeaks1,\n        nbPeaks2,\n        tanimoto: nbCommonPeaks / (nbPeaks1 + nbPeaks2 - nbCommonPeaks),\n        cosine: cosineSimilarity(vector1, vector2),\n    };\n}\n/**\n * Returns the average of cosine distances between vectors a and b\n * Copied from https://github.com/mljs/distance/blob/0b15acd6476413f4111cb4852ca1bec9edaa2805/src/similarities/cosine.ts\n * @param a {import('cheminfo-types').NumberArray} - first vector\n * @param b {import('cheminfo-types').NumberArray} - second vector\n * @returns {number} - cosine similarity\n */\nfunction cosineSimilarity(a, b) {\n    let p = 0;\n    let p2 = 0;\n    let q2 = 0;\n    for (let i = 0; i < a.length; i++) {\n        p += a[i] * b[i];\n        p2 += a[i] * a[i];\n        q2 += b[i] * b[i];\n    }\n    return p / (Math.sqrt(p2) * Math.sqrt(q2));\n}\n//# sourceMappingURL=MSComparator.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.getPeaksAnnotation = getPeaksAnnotation;\nconst fromMonoisotopicMass_1 = require(\"../from/fromMonoisotopicMass\");\n/**\n *\n * @param {array} bestPeaks\n * @param {object} [options={}]\n * @param {number} [options.numberDigits=5]\n * @param {number} [options.numberMFs=0]\n * @param {boolean} [options.showMF=false]\n * @param {array} [options.mfColors={}]\n * @param {number} [options.charge=1]\n * @param {number} [options.shift=0]\n * @param {object} [options.mfPrefs]\n * @param {number} [options.displayCharge=true]\n * @param {number} [options.displayProperties=[]] Array of properties name to display\n * @returns {Promise}\n */\nasync function getPeaksAnnotation(bestPeaks, options = {}) {\n    let { numberDigits = 5, shift = 0, showMF = false, numberMFs = 0, charge = 1, mfPrefs = {}, displayCharge = true, displayProperties = [], mfColors = [\n        { limit: 3, color: 'green' },\n        { limit: 20, color: 'lightgreen' },\n        { limit: 50, color: 'lightorange' },\n    ], } = options;\n    if (showMF && !numberMFs)\n        numberMFs = 1;\n    let annotations = [];\n    bestPeaks.sort((a, b) => (a.close ? -1 : b.close ? 1 : 0));\n    for (let peak of bestPeaks) {\n        let textLine = 0;\n        let annotation;\n        if (peak.close) {\n            annotation = {\n                type: 'line',\n                _highlight: peak._highlight,\n                info: peak,\n                position: [\n                    {\n                        y: peak.y,\n                        dy: '-5px',\n                        x: peak.x,\n                    },\n                    {\n                        y: peak.y,\n                        dy: '-15px',\n                        x: peak.x,\n                    },\n                ],\n            };\n            annotations.push(annotation);\n            annotation = {\n                type: 'ellipse',\n                _highlight: peak._highlight,\n                info: peak,\n                position: [\n                    {\n                        y: peak.y,\n                        dy: '-15px',\n                        x: peak.x,\n                    },\n                ],\n                props: {\n                    rx: '3px',\n                    ry: '3px',\n                    fillOpacity: 0.3,\n                },\n            };\n        }\n        else {\n            annotation = {\n                type: 'line',\n                _highlight: peak._highlight,\n                position: [\n                    {\n                        y: peak.y,\n                        dy: '-5px',\n                        x: peak.x,\n                    },\n                    {\n                        y: peak.y,\n                        dy: '-25px',\n                        x: peak.x,\n                    },\n                ],\n                labels: [\n                    {\n                        text: (peak.x + shift).toFixed(numberDigits),\n                        color: 'red',\n                        position: {\n                            x: peak.x,\n                            y: peak.y,\n                            dy: `${textLine++ * -13 - 17}px`,\n                            dx: '2px',\n                        },\n                    },\n                ],\n            };\n            if (displayCharge && peak.charge !== undefined) {\n                annotation.labels.push({\n                    text: `Z:${peak.charge}`,\n                    color: 'grey',\n                    position: {\n                        x: peak.x,\n                        y: peak.y,\n                        dy: '-4px',\n                        dx: '2px',\n                    },\n                });\n            }\n            let mfs = [];\n            if (numberMFs) {\n                // we have 2 cases. Either there is a shift and we deal with differences\n                // otherwise it is absolute\n                // if there is a shift we consider only a neutral loss and the parameter charge is important\n                // we also check that the selected peak (for relative mass) is not the current peak\n                if (shift && Math.abs(peak.x + shift) > Number.EPSILON) {\n                    // neutral loss\n                    let currentMfPrefs = {\n                        ...mfPrefs,\n                        allowNeutral: true,\n                        ionizations: '',\n                    };\n                    // we need to deal with the precision and increase it\n                    currentMfPrefs.precision =\n                        (currentMfPrefs.precision / Math.max(Math.abs(peak.x + shift), 1)) *\n                            peak.x;\n                    ({ mfs } = await (0, fromMonoisotopicMass_1.fromMonoisotopicMass)(Math.abs((peak.x + shift) * charge), currentMfPrefs));\n                }\n                else {\n                    ({ mfs } = await (0, fromMonoisotopicMass_1.fromMonoisotopicMass)(Math.abs(peak.x * charge), mfPrefs));\n                }\n                let numberOfMFS = Math.min(mfs.length, numberMFs);\n                for (let i = 0; i < numberOfMFS; i++) {\n                    let mf = mfs[i];\n                    let ppm = shift ? (mf.ms.ppm / shift) * mfs[0].ms.em : mf.ms.ppm;\n                    annotation.labels.push({\n                        text: mf.mf,\n                        color: getColor(mfColors, Math.abs(ppm)),\n                        position: {\n                            x: peak.x,\n                            y: peak.y,\n                            dy: `${textLine++ * -13 - 17}px`,\n                            dx: '2px',\n                        },\n                    });\n                }\n            }\n            if (displayProperties.length > 0) {\n                for (let property of displayProperties) {\n                    annotation.labels.push({\n                        text: peak[property],\n                        color: 'red',\n                        position: {\n                            x: peak.x,\n                            y: peak.y,\n                            dy: `${textLine++ * -13 - 17}px`,\n                            dx: '2px',\n                        },\n                    });\n                }\n            }\n        }\n        annotations.push(annotation);\n    }\n    return annotations;\n}\nfunction getColor(colors, value) {\n    for (let color of colors) {\n        if (value < color.limit)\n            return color.color;\n    }\n    return 'lightgrey';\n}\n//# sourceMappingURL=getPeaksAnnotation.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.JsGraph = void 0;\nconst getPeaksAnnotation_js_1 = require(\"./getPeaksAnnotation.js\");\nexports.JsGraph = {\n    getPeaksAnnotation: getPeaksAnnotation_js_1.getPeaksAnnotation,\n};\n//# sourceMappingURL=index.js.map","import { xNormed } from 'ml-spectra-processing';\n/**\n * We will force maxY to 100\n * @param variables - The variables object containing x and y data\n * @returns - The modified variables object with y data normalized\n */\nexport function spectrumCallback(variables) {\n    variables.y.data = xNormed(variables.y.data, {\n        algorithm: 'max',\n        value: 100,\n    });\n    return variables;\n}\n//# sourceMappingURL=spectrumCallback.js.map","import { JSGraph as OriginalJSGraph, peakPicking as originalPeakPicking, } from 'common-spectrum';\nimport { Spectrum } from 'ms-spectrum';\nimport { getAnnotations } from \"./jsgraph/getAnnotations.js\";\nexport { AnalysesManager, Analysis, toJcamp } from 'common-spectrum';\nexport { fromText } from \"./from/fromText.js\";\nexport { fromJcamp } from \"./from/fromJcamp.js\";\nexport function autoPeakPicking(spectrum, options = {}) {\n    options = {\n        threshold: 0.1,\n        numberSlots: 20,\n        numberCloseSlots: 40,\n        ...options,\n    };\n    const data = {\n        x: spectrum.variables.x.data,\n        y: spectrum.variables.y.data,\n    };\n    const msSpectrum = new Spectrum(data);\n    // we need to know the global best peaks to know his intensity and set it to 100\n    const minMaxX = msSpectrum.minMaxX();\n    const maxY = msSpectrum\n        .getBestPeaks({\n        ...options,\n        from: minMaxX.min,\n        to: minMaxX.max,\n    })\n        .sort((a, b) => b.y - a.y)[0]?.y;\n    const maxRatio = maxY ? 100 / maxY : 1;\n    const peaks = msSpectrum.getBestPeaks(options);\n    return peaks.map((peak) => {\n        return {\n            mass: peak.x,\n            intensity: peak.y * maxRatio,\n        };\n    });\n}\nexport function peakPicking(spectrum, target) {\n    const peak = originalPeakPicking(spectrum, target, {\n        xVariable: 'x',\n        yVariable: 'y',\n        optimize: false,\n        // we could optimize the peaks but it depends of the width\n        // and also if it is continuous or not. Not obvious\n        // if we optimize we need to add this parameters for high res spectrum\n        //   shape: { kind: 'gaussian', fwhm: 0.01 },\n        max: true,\n    });\n    if (!peak)\n        return undefined;\n    return {\n        mass: peak.x,\n        intensity: peak.y,\n    };\n}\nexport const JSGraph = { ...OriginalJSGraph, getAnnotations };\n//# sourceMappingURL=index.js.map","/**\n * Creates annotations for jsgraph that allows to display the result of peak picking\n * @param peaks - Array of peaks to create annotations for\n * @param options - Configuration options for the annotations\n * @returns Array of annotations\n */\nexport function getAnnotations(peaks, options = {}) {\n    const { fillColor = 'green', strokeColor = 'red', creationFct } = options;\n    const annotations = peaks.map((peak) => {\n        const annotation = {\n            line: 1,\n            type: 'rect',\n            strokeColor,\n            strokeWidth: 0,\n            fillColor,\n        };\n        if (creationFct) {\n            creationFct(annotation, peak);\n        }\n        annotationPeak(annotation, peak, options);\n        return annotation;\n    });\n    return annotations;\n}\nfunction annotationPeak(annotation, peak, options = {}) {\n    const { showAssignment = true, showIntensity = true, showMass = true, } = options;\n    const labels = [];\n    let line = 0;\n    const shiftY = -3;\n    if (showMass) {\n        labels.push({\n            text: `m/z: ${peak.mass?.toFixed(0)}`,\n            size: '18px',\n            anchor: 'left',\n            color: 'green',\n            position: {\n                x: peak.mass,\n                y: peak.intensity,\n                dy: `${shiftY - line * 14}px`,\n                dx: '3px',\n            },\n        });\n        line++;\n    }\n    if (showIntensity) {\n        labels.push({\n            text: `${peak.intensity?.toFixed(0)}%`,\n            size: '18px',\n            anchor: 'left',\n            color: 'green',\n            position: {\n                x: peak.mass,\n                y: peak.intensity,\n                dy: `${shiftY - line * 14}px`,\n                dx: '3px',\n            },\n        });\n        line++;\n    }\n    if (showAssignment && peak.assignment) {\n        labels.push({\n            text: peak.assignment,\n            size: '18px',\n            anchor: 'middle',\n            color: 'red',\n            position: {\n                x: peak.mass,\n                y: peak.intensity,\n                dy: `${shiftY - 3 - line * 14}px`,\n            },\n        });\n        // line++; // it it the last one we do not increase the line number\n    }\n    annotation.labels = labels;\n    annotation.position = [\n        {\n            x: peak.mass,\n            y: peak.intensity,\n            dy: '-1px',\n            dx: '-1px',\n        },\n        {\n            x: peak.mass,\n            y: peak.intensity,\n            dy: `-${3 + line * 14}px`,\n            dx: '1px',\n        },\n    ];\n}\n//# sourceMappingURL=getAnnotations.js.map","import { fromJcamp as commonFromJcamp } from 'common-spectrum';\nimport { spectrumCallback } from \"./utils/spectrumCallback.js\";\n/**\n * Creates a new Analysis from a SPC buffer\n * @param jcamp\n * @param [options={}]\n * @param [options.id=Math.random()]\n * @param [options.label=options.id] - human redeable label\n * @param [options.spectrumCallback] - a callback to apply on variables when creating spectrum. Default will add a and t\n * @returns - New class element with the given data\n */\nexport function fromJcamp(jcamp, options = {}) {\n    return commonFromJcamp(jcamp, { ...options, spectrumCallback });\n}\n//# sourceMappingURL=fromJcamp.js.map","import { Analysis } from 'common-spectrum';\nimport { ensureString } from 'ensure-string';\nimport { parseXYAndKeepInfo } from 'xy-parser';\nimport { spectrumCallback } from \"./utils/spectrumCallback.js\";\nexport function fromText(blob, options = {}) {\n    const text = ensureString(blob);\n    const { title } = options;\n    const { data, info } = parseXYAndKeepInfo(text, {\n        bestGuess: true,\n        ...options,\n    });\n    const spectrum = {\n        x: {\n            data: data.x,\n            units: 'm/z',\n            label: 'm/z',\n        },\n        y: {\n            data: data.y,\n            units: '',\n            label: 'Relative intensity',\n        },\n    };\n    const meta = {};\n    let index = 1;\n    for (const item of info) {\n        meta[`Info ${index++}`] = item.value;\n    }\n    const analysis = new Analysis({\n        spectrumCallback,\n    });\n    analysis.pushSpectrum(spectrum, {\n        dataType: 'MASS SPECTRUM',\n        title,\n        meta,\n    });\n    return analysis;\n}\n//# sourceMappingURL=fromText.js.map","import { optimize as optimizePeak } from 'ml-spectra-fitting';\nimport { xFindClosestIndex, xMaxValue } from 'ml-spectra-processing';\n/**\n * Based on a x value we will return a peak\n * if you set optimize=True the returned positions will be\n * the closest actual datapoints to the fitted peak location.\n * the x/y of the fitted peak will be in xOptimized and yOptimized\n * @param spectrum\n * @param target\n * @param options\n */\nexport function peakPicking(spectrum, \n/** value to search (on x axis) */\ntarget, options = {}) {\n    const { xVariable = 'x', yVariable = 'y', optimize = false, max: isMax = true, shape = { kind: 'gaussian', fwhm: 1 }, } = options;\n    const x = spectrum.variables[xVariable]?.data;\n    let y;\n    if (!isMax) {\n        y = spectrum.variables[yVariable]?.data.slice(); // do deep copy as we maybe need to flip sign\n    }\n    else {\n        y = spectrum.variables[yVariable]?.data;\n    }\n    if (!x || !y)\n        return;\n    const targetIndex = xFindClosestIndex(x, target);\n    let optimizedPeak;\n    let optimizedIndex;\n    const result = {};\n    if (optimize) {\n        if (!isMax) {\n            const maximumY = xMaxValue(y);\n            for (let i = 0; i < y.length; i++) {\n                y[i] *= -1;\n                y[i] += maximumY; // This makes it somewhat more robust\n            }\n        }\n        optimizedPeak = optimizePeak({ x, y }, [{ x: x[targetIndex], y: y[targetIndex] }], { shape });\n        optimizedIndex = xFindClosestIndex(x, optimizedPeak.peaks[0].x);\n        for (const [key, variable] of Object.entries(spectrum.variables)) {\n            result[key] = variable.data[optimizedIndex];\n        }\n        result.optimized = optimizedPeak.peaks[0];\n    }\n    else {\n        for (const [key, variable] of Object.entries(spectrum.variables)) {\n            result[key] = variable.data[targetIndex];\n        }\n    }\n    return result;\n}\n//# sourceMappingURL=peakPicking.js.map","import { toJcamps } from './toJcamps.js';\nexport function toJcamp(analysis, options = {}) {\n    return toJcamps(analysis, options).join('\\n');\n}\n//# sourceMappingURL=toJcamp.js.map"],"names":["reimAbsolute","data","length","re","im","newArray","Float64Array","i","Math","hypot","toString","Object","prototype","isAnyArray","value","tag","call","endsWith","includes","getOutputArray","output","undefined","TypeError","xAbsolute","array","tmpArray","slice","xMedian","input","options","exact","middleIndex","calcMiddle","median","quickSelect","low","high","middle","currentLow","currentHigh","swap","j","temp","floor","xCheck","minLength","Error","xFindClosestIndex","target","sorted","abs","index","diff","Number","POSITIVE_INFINITY","currentDiff","xGetFromToIndex","x","fromIndex","toIndex","from","to","xAbsoluteSum","sum","xAdd","array1","array2","isConstant","constant","array3","xApplyFunctionStr","variableLabel","fctString","fct","Function","replaceAll","toReturn","isNaN","xMultiply","xDotProduct","A","B","g","result","xCrossCorrelation","tau","lag","n","q","k","w","l","xBoxPlot","posQ1","sort","posQ3","medianPos","q1MinProportion","q3MinProportion","medianMinProportion","min","q1","q3","max","at","xBoxPlotWithOutliers","boxPlot","iqr","lowerWhisker","upperWhisker","outliers","minWhisker","maxWhisker","push","xCheckLengths","xCorrelation","sumA","sumA2","sumB","sumB2","sumAB","a","b","sqrt","arguments","Array","currentMin","_options$fromIndex","_options$toIndex","isInteger","minValue","currentMax","maxValue","RangeError","_options$min","autoMinMax","_options$max","factor","defineProperty","matrix","require$$0","rescale","require$$1","indent","repeat","indentData","inspectMatrixWithOptions","maxRows","maxColumns","maxNumSize","padMinus","constructor","name","rows","columns","maxI","maxJ","loop","get","line","formatNumber","join","inspectData","num","formatNumber2","padEnd","len","str","fix","toFixed","startsWith","exp","toExponential","checkRowIndex","outer","checkColumnIndex","checkRowVector","vector","to1DArray","checkColumnVector","checkRowIndices","rowIndices","checkColumnIndices","columnIndices","checkRange","startRow","endRow","startColumn","endColumn","checkNumber","checkNonEmpty","isEmpty","AbstractMatrix","from1DArray","newRows","newColumns","newData","newMatrix","Matrix","row","column","set","rowVector","columnVector","zeros","ones","fill","rand","random","randInt","interval","round","eye","this","diag","matrix1","matrix2","checkMatrix","isMatrix","klass","size","apply","callback","to2DArray","copy","toJSON","isRowVector","isColumnVector","isVector","isSquare","isSymmetric","isDistance","isEchelonForm","previousColumn","checked","isReducedEchelonForm","echelonForm","clone","h","iMax","swapRows","tmp","reducedEchelonForm","m","maxRow","p","pivot","setSubMatrix","neg","mulS","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","v","idx","minIndex","maxRowIndex","minRow","minRowIndex","maxColumn","maxColumnIndex","minColumn","minColumnIndex","norm","type","dot","cumulativeSum","vector2","vector1","mmul","other","Bcolj","s","mpow","scalar","bb","e","strassen2x2","a11","b11","a12","b12","a21","b21","a22","b22","m1","m2","m3","m4","m5","c00","c01","c10","c11","strassen3x3","a00","a01","a02","a10","a20","b00","b01","b02","b10","b20","m6","m7","m8","m9","m12","m13","m14","m15","m16","m17","m18","c02","c12","c20","c21","c22","mmulStrassen","y","r1","c1","r2","c2","embed","mat","cols","r","c","resultat","console","warn","blockMult","halfRows","parseInt","halfCols","subMatrix","add","sub","scaleRows","isFinite","scaleColumns","flipRows","ceil","first","last","flipColumns","kroneckerProduct","kroneckerSum","AxI","IxB","transpose","sortRows","compareFunction","compareNumbers","sortColumns","subMatrixRow","indices","subMatrixColumn","selection","rowIndex","columnIndex","trace","entries","sumByRow","sumByColumn","sumAll","product","productByRow","productByColumn","productAll","mean","variance","unbiased","sum1","sum2","varianceByRow","varianceByColumn","varianceAll","standardDeviation","center","centerByRow","centerByColumn","centerAll","scale","getScaleByRow","scaleByRow","getScaleByColumn","scaleByColumn","divider","getScaleAll","scaleAll","Symbol","iterator","col","values","isArrayOfNumbers","every","element","for","randomInt","diagonal","identity","negate","tensorProduct","initData","nRows","nColumns","super","arrayData","removeRow","splice","addRow","removeColumn","newRow","addColumn","addS","addM","subS","subM","subtract","subtractS","subtractM","mul","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","clz32","cos","cosh","expm1","fround","log","log1p","log10","log2","sign","sin","sinh","tan","tanh","trunc","pow","arg0","powS","powM","installMathOperations","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","BaseView","MatrixSelectionView","WrapperMatrix1D","_calculateIndex","WrapperMatrix2D","LuDecomposition","t","LUcolj","kmax","lu","pivotVector","pivotSign","LU","isSingular","solve","count","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","ks","f","cs","sn","sp","spm1","epm1","sk","ek","shift","Y","threshold","scols","Ls","rightSingularVectors","VL","vrows","urows","VLU","solveForDiagonal","inverse","vcols","ucols","condition","norm2","rank","tol","ii","leftSingularVectors","diagonalMatrix","leftHandSide","rightHandSide","useSVD","xrange","exception","range","dependenciesOneRow","error","thresholdValue","thresholdError","returnArray","EigenvalueDecomposition","assumeSymmetric","d","hh","tred2","dl1","c3","el1","s2","tst1","tql2","H","ort","orthes","nn","ra","sa","vr","vi","notlast","cdivres","exshift","z","iter","cdiv","hqr2","realEigenvalues","imaginaryEigenvalues","eigenvectorMatrix","xr","xi","yr","yi","CholeskyDecomposition","dimension","positiveDefinite","L","isPositiveDefinite","nipals","scaleScores","maxIterations","terminationCriteria","u","tOld","counter","xResidual","residual","yResidual","betas","CHO","EVD","Matrix_1","MatrixColumnSelectionView","MatrixColumnView","MatrixFlipColumnView","MatrixFlipRowView","MatrixRowSelectionView","MatrixRowView","MatrixSubView","MatrixTransposeView_1","MatrixTransposeView","NIPALS","Nipals","SVD","correlation","xMatrix","yMatrix","yIsSame","sdx","sdy","corr","covariance","cov","_default","default","subMatrix0","subMatrix1","subMatrix2","inverse_1","linearDependencies","results","Abis","pseudoInverse","svdSolution","solve_1","wrap","absDiff","xCumulative","xMean","sumValue","xVariance","sqrError","xStandardDeviation","xDivide","xEnsureFloat64","xGetTargetIndex","targetIndex","FFT","_csize","table","angle","PI","power","_width","_bitrev","revShift","_out","_data","_inv","fft","fromComplexArray","complex","storage","res","createComplexArray","toComplexArray","completeSpectrum","spectrum","half","transform","out","_transform4","realTransform","_realTransform4","inverseTransform","outOff","step","bitrev","off","_singleTransform2","_singleTransform4","inv","quarterLen","limit","C","D","Ar","Ai","Br","Bi","Cr","Ci","Dr","Di","MAr","MAi","tableBr","tableBi","MBr","MBi","tableCr","tableCi","MCr","MCi","tableDr","tableDi","MDr","MDi","T0r","T0i","T1r","T1i","T2r","T2i","T3r","T3i","FAr","FAi","FCr","FCi","FBr","FBi","FDr","FDi","evenR","evenI","oddR","oddI","leftR","leftI","rightR","rightI","step2","step3","_singleRealTransform2","_singleRealTransform4","halfLen","hquarterLen","SFAr","SFAi","SFBr","SFBi","SA","SB","createNumberArray","ArrayConstructor","createFromToArray","includeFrom","includeTo","distribution","delta","base","firstExponent","FLOAT_MUL","multiplyUint32","nlo","XSadd","state","seed","Date","now","Uint32Array","init","getFloat","bind","getUint32","nextState","periodCertification","GaussianGenerator","spare","hasSpare","generator","generateGaussian","val","isPowerOfTwo","nextPowerOfTwo","appendPromises","object","promises","key","then","modifier","ArrayBuffer","isView","replacer","space","internalReplacer","xSubtract","calculateAdaptiveWeights","yData","baseline","weights","controlPoints","factorStd","learningRate","minWeight","absResiduals","rawWeights","maxWeight","MIN_SAFE_INTEGER","newWeights","oneMinusLearningRate","weight","hilbertTransformWithFFT","fftResult","multiplier","hilbertSignal","resampling","oldLength","ratio","currentIndex","xMaxValue","xMinValue","xHistogram","histogram","centerX","nbSlots","logBaseX","logBaseY","absolute","logOfBase","slotSize","xIsEquallySpaced","tolerance","maxDx","minDx","MAX_SAFE_INTEGER","absoluteDifference","xIsMonotonic","shiftSubTree","depth","level","slot","currentLevel","levelSlotShift","levelShift","levelSlotSize","slotIndex","getDepth","xMedianAbsoluteDeviation","averageDeviations","mad","xMinMaxValues","P1","Q1","P2","Q2","P3","Q3","P4","Q4","P5","Q5","polyval","coef","calc","P","Q","erfcinv","simpleNormInvNumber","magnitudeMode","SQRT2","simpleNormInv","xNoiseSanPlot","cutOff","refine","scaleFactor","fixOffset","filter","_e","prepareData","medianIndex","firstNegativeValueIndex","findIndex","lastPositiveValueIndex","signPositive","signNegative","cutOffDist","considerList","indexMax","minKi","whereToCutStat","top","elementsOfCutOff","averageValue","kiSqrt","determineCutOff","initialNoiseLevelPositive","skyPoint","initialNoiseLevelNegative","noiseLevelPositive","noiseLevelNegative","cloneSignPositive","cloneSignNegative","cutOffSignalsIndexPlus","cutOffSignalsIndexNeg","cutOffSignals","correctionFactor","effectiveCutOffDist","refinedCorrectionFactor","positive","negative","snr","sanplot","generateSanPlot","fromTo","xNoiseStandardDeviation","sd","xNorm","xSum","xNormed","algorithm","absoluteSumValue","absoluteSum","currentMaxValue","sumFactor","String","xPadding","fromEnd","toEnd","xParetoNormalization","sqrtSD","xRescale","xRolling","window","padding","padded","subarray","xRollingAverage","xRollingMedian","xRotate","xSequentialFillFromStep","parameters","xSortDescending","isArray","matrixCholeskySolver","nonZerosArray","permutationEncoded","pinv","mt","ar","ac","ap","ai","ax","lnz","colOffset","adr","lp","parent","lnzArray","flag","pattern","bp1","kk","p2","ldlSymbolic","lx","li","lKi","ldlNumeric","ldlPerm","ldlLsolve","ldlDsolve","ldlLTsolve","ldlPermt","addWeights","nbPoints","newLeftHandSide","newRightHandSide","next","xWhittakerSmoother","lambda","getWeightsAndControlPoints","prevBaseline","iteration","Infinity","upperTriangularNonZeros","createSystemMatrix","cho","newBaseline","calculateDelta","xWhitakerSmoother","reimPhaseCorrection","phi0","phi1","firstAngle","beta","cosTheta","sinTheta","newRe","newIm","newSinTheta","determiningGlobalValues","ph0Values","ph0","ph1","sxtw","swx","sw","sxtwy","swy","detMx","inMx","weightedLinearRegression","maxDiff","predictedPh0","autoPhaseRegion","x0","start","stop","maxSteps","bestAng","minArea","dAng","negArea","getNegArea","toRadians","phased","area","sumX","robustBaseLineRegionsDetection","maxDistanceToJoin","factorNoise","Uint8Array","change","prev","degree","zeroShift","reimZeroFilling","totalLength","newRE","newIM","xyCheck","xyMaxYPoint","current","STEPS","xyEnsureGrowingX","prevX","zonesNormalize","zones","exclusions","map","zone","currentZone","beforeExclusionsZones","normalizedExclusions","currentExclusionIndex","zoneIndex","zonesWithPoints","numberOfPoints","normalizedZones","zonesWithNumberOfPoints","unitsPerPoint","reduce","previous","currentTotal","tempZone","tempZoneNumberOfPoints","integral","x1","slope","intercept","getSlope","y0","y1","xyEquallySpaced","xLength","variant","zonesWithPointsRes","xResult","yResult","zoneResult","processZone","concat","halfStep","lastStep","previousX","MAX_VALUE","previousY","nextX","nextY","frontOutsideSpectra","backOutsideSpectra","currentValue","currentPoints","main","equallySpacedSlot","initialOriginalStep","lastOriginalStep","sumAtMin","sumAtMax","equallySpacedSmooth","xyFilterX","currentZoneIndex","newX","newY","position","xyFilterXPositive","xyGrowingX","xyJoinX","deltaIsFunction","notEnoughPoints","internalZones","totalPoints","getInternalZones","xySortX","xyObject","response","xyUniqueX","isSorted","cumulativeY","average","getSlots","possibleXs","flatMap","currentSlot","number","slots","currentDelta","xyArrayWeightedMerge","deltaNumber","positions","point","nextValue","maxX","sumY","sumXY","minX","currentX","xyObjectCheck","points","xyObjectMaxXPoint","xyObjectMinXPoint","matrixCreateEmpty","nbRows","nbColumns","matrixCheck","firstLength","matrixClone","matrixCheckRanges","boundaries","matrixMinMaxAbsoluteZ","matrixMinMaxZ","matrixMaxAbsoluteZ","matrixToArray","flatten","currentRow","gaussianGenerator","targetMin","targetMax","clamp","algorithmOptions","originalMin","originalMax","convert","kind","getDataConverter","originalRange","targetRange","matrixInitial","dictionary","arrayOfValues","targetArray","sourceArray","info","columnArray","q1max","q3min","middleOver","list","adj","visited","toVisit","eol","ptr","nbhd","duplicate","minMax","xHistogramOptions","finalHistogram","invertedDictionary","ret","dictCategoricalToNumerical","matrixB","normalizationFactor","referenceSpectrum","currentVariable","medianOfQuotients","quotients","async","Promise","all","minRegSize","finalPeaks","magnitudeData","peaksDs","dk","holoborodko","peaksSp","detectBaselineRegions","indexMask","reTmp","imTmp","applyZeroShift","csize","complexArray","rowsArray","columnsArray","nb","forceFFT","inClockwise","aSum","cSum","hilbertTransform","recenter","similarityFct","depth1","depth2","similarity","maxSimilarity","value1","value2","sumWeights","minDelta","maxDelta","maxCount","counts","higherWhisker","filteredArray","downSampling","Set","deltaX","xy2","xyValue","data1","data2","common","y2","length1","length2","difference","weightedX","requiredY","ys","newYs","filterRequiredY","firstXs","otherXs","currentPosition","getSlotsToFirst","meanX","meanY","maxY","x25","x50","x75","x100","xMode","currentStep","breakPoint","minRelativeYValue","nbPeaks","descending","nbThreshold","numberMaxPoints","xyIntegration","currentxyIntegral","currentxyIntegration","sumYs","sumProducts","weightedIntegral","firstIntegration","totalIntegration","totalWeightedIntegral","currentIntegration","lastIntegration","getWeightedIntegral","endIndexes","Int32Array","beginIndexes","currentBeginIndex","currentEndIndex","nextIndex","previousIndex","xyMaxY","groupWidth","merged","maxAbscissa","currentxyMaxY","maxima","startEqualIndex","cumSumY","centroids","mergedPoints","originalIndex","mergedIndex","minY","numberCloseSlots","numberSlots","closeSlot","selected","monoisotopic","peakLoop","item","close","existing","newPeak","xError","normalizedYs","structuredClone","slotWidth","halfSlot","entry","newDiff","after","before","inflectionBefore","inflectionAfter","extrema","inflectionMiddle","width","gamma","optimize","appendFromTo","zoneNbPoints","maxApproximateNbPoints","internalZone","maxNbPoints","currentY","lastX","objectArray","weightedAbscissa","addStyle","serie","color","opacity","lineWidth","match","toUpperCase","replace","style","dash","label","id","COLORS","prepare","M","Pinv","Mt","Ap","Ax","LNZ","coloffset","Lp","Parent","Lnz","Flag","Pattern","Lx","Li","compareNum","getCloseIndex","goal","closest","getClosestNumber","curr","indexOf","updateSystem","newVector","airPLS","Int8Array","forEach","indexFrom","indexTo","getControlPoints","sumNegDifferences","corrected","stopCriterion","getStopCriterion","lowerTriangularNonZeros","permutationEncodedArray","getDeltaMatrix","cuthillMckee","prevNegSum","cholesky","applyCorrection","absChange","_typeof","obj","sequentialFill","_options","_options$from","_options$to","_options$size","_i","checkArrayLength","BaseRegression","predict","_predict","xVal","train","precision","toLaTeX","score","ySum","chi2","rmsd","xSquared","ySquared","xY","maybeToPrecision","figures","toPrecision","PolynomialRegression","powers","coefficients","interceptAtZero","nCoefficients","F","FT","regress","_toFormula","isLaTeX","sup","closeSup","times","fn","load","json","iterativePolynomialBaseline","numberPoints","regressionOptions","Regression","regression","fitting","oldFitting","baselineCorrectionRegression","correctedSpectrum","rollingBallBaseline","minima","windowM","windowS","windowLeft","windowRight","rollingBall","sgg","xs","windowSize","derivative","polynomial","np","ans","fullWeights","hs","constantH","wg1","wg2","d1","d2","getHs","wg","gramPoly","Grampoly","genFact","gf","gsd","noiseLevel","sgOptions","smoothY","maxCriteria","minMaxRatio","realTopDetection","equallySpaced","noiseInfo","xValue","dY","ddY","yThreshold","dX","lastMax","lastMin","minddY","intervalL","intervalR","lastK","peaks","minddYIndex","possible","minDistance","currentDistance","crypto","randomUUID","inflectionPoints","peak","xCurrent","xPrevious","optimizeTop","GAUSSIAN_EXP_FACTOR","LN2","ROOT_PI_OVER_LN2","ROOT_THREE","ROOT_2LN2","ROOT_2LN2_MINUS_ONE","Gaussian","fwhm","gaussianWidthToFWHM","fwhmToWidth","gaussianFwhmToWidth","widthToFWHM","gaussianFct","getArea","height","calculateGaussianHeight","getGaussianArea","getFactor","getGaussianFactor","getData","shape","getGaussianData","calculateHeight","getParameters","ln1MinusXSqrd","lnEtcBy2Plus2","firstSqrt","erfinv","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","assert","message","DefaultParameters","peakShape","gradientDifference","properties","getNormalizedValue","parameter","property","minMaxY","checkOptions","timeout","initialValues","damping","dampingStepUp","dampingStepDown","errorTolerance","centralDifference","improvementThreshold","minValues","maxValues","parLen","gradientDifferenceArray","getGradientDifferenceArray","filler","dataLength","getFiller","checkTimeout","endTime","getCheckTimeout","weightSquare","_","errorCalculation","parameterizedFunction","func","params","evaluatedData","gradientFunc","paramFunction","nbParams","param","auxParams","funcParam","funcParam2","gradientFunction","residualError","matrixFunction","inverseMatrix","jacobianWeightResidualError","perturbations","levenbergMarquardt","checkedOptions","optimalError","optimalParameters","converged","previousError","parameterValues","parameterError","iterations","antiLowerConvexHull","currentPoint","moveOn","moveBack","getMinIndex","functionValues","diagonalDistances","choiceLimit","bestCurrentValue","directOptimization","sumOfShapes","epsilon","tolerance2","initialState","objectiveFunction","getObjectiveFunction","lowerBoundaries","upperBoundaries","diffBorders","numberOfRectangles","totalIterations","unitaryCoordinates","middlePoint","fCalls","smallerDistance","edgeSizes","differentDistances","smallerValuesByDistance","originalCoordinates","optimumValuesIndex","S3","S1","a1","b1","a2","S2","xHull","yHull","lowerIndexHull","largerSide","largeSidesIndex","bestFunctionValues","firstMiddleCenter","secondMiddleCenter","firstMiddleValue","secondMiddleValue","firstMinValue","secondMinValue","ix1","ix2","minFunctionValue","pair","finalState","minimizer","optima","direct","internalPeaks","shiftValue","normalizedPeaks","shapeFct","propertiesValues","propertyValue","generalParameterValue","defaultParameterValues","getInternalPeaks","normalizedY","gradientDifferences","optimizationOptions","selectMethod","optimization","totalY","peakX","shapeFctKey","getSumOfShapes","fitted","fittedValues","newPeaks","addMissingShape","shapeInstance","hasShape","optimizePeaksWithLogs","peakList","groupingFactor","factorLimits","groups","parse","previousPeak","currentGroup","groupPeaks","logs","peakGroup","firstPeak","lastPeak","groupSize","time","optimizedPeaks","addMissingIDs","pushBackPeaks","broadLines","indexes","getGSDPeakOptimizedStructure","overlap","xFrom","xTo","mapPeaks","nextPeak","broadWidth","broadRatio","maxDdy","candidates","initialWidth","find","airpls","baselineFct","targetX","gsdOptions","existingMax","existingMin","function","getNormalizedSpectrum","variables","newSpectrum","units","title","dataType","meta","filters","filterFct","Filters","filterXY","isMonotonic","module","exports","isString","isFiniteImpl","isNumber","uniq","strings","seen","hasOwnProperty","compareArray","assign","keys","mulSafe","decimals","arg","getFractional","divSafe","den","QtyError","err","create","stack","throwIncompatibleUnits","left","right","UNITS","BASE_UNITS","UNITY","UNITY_ARRAY","validateUnitDefinition","unitDef","definition","numerator","denominator","unit","PREFIX_VALUES","PREFIX_MAP","UNIT_VALUES","UNIT_MAP","OUTPUT_MAP","getUnits","unitKeys","substr","getKinds","toLowerCase","getAliases","unitName","SIGNATURE_VECTOR","unitSignature","signature","unitSignatureVector","isBase","toBase","SIGN","INTEGER","FRACTION","QTY_STRING_REGEX","RegExp","POWER_OP","SAFE_POWER","TOP_REGEX","BOTTOM_REGEX","trim","exec","scalarMatch","parseFloat","nx","bottom","UNIT_TEST_REGEX","test","parseUnits","PREFIX_REGEX","UNIT_REGEX","UNIT_MATCH","UNIT_MATCH_REGEX","parsedUnitsCache","cached","unitMatch","normalizedUnits","globalParse","isQty","Qty","initValue","initUnits","assertValidConstructorArgs","baseScalar","_conversionCache","isDefinitionObject","updateBaseScalar","isTemperature","KINDS","knownSignature","subtractTemperatures","lhs","rhs","lhsUnits","rhsConverted","dstDegrees","getDegreeUnits","subtractTempDegrees","deg","tempDegrees","addTempDegrees","toDegrees","src","dst","dstScalar","srcDegK","toDegK","dstUnits","qty","toTemp","toTempK","swiftConverter","srcUnits","srcQty","dstQty","eq","isDegrees","isCompatible","isInverse","baseUnitCache","toBaseUnits","toFloat","isUnitless","toPrec","precQuantity","cleanTerms","num1","den1","num2","den2","notUnity","combined","combineTerms","terms","direction","prefix","prefixValue","combinedPrefixValue","prop","NestedMap","defaultFormatter","op1","op2","numdenscale","compareTo","lt","lte","gt","gte","same","_isBase","childMap","formatter","_units","numIsUnity","denIsUnity","numUnits","stringifyUnits","denUnits","targetUnitsOrMaxDecimalsOrPrec","maxDecimals","targetUnits","format","targetQty","stringifiedUnitsCache","stringified","simplify","getOutputNames","token","tokenNext","unitNames","acc","unitCounter","unitCount","version","factory","convertUnit","fromUnit","toUnit","normalize","testRegExp","ensureRegexp","string","parts","stringToRegexp","flags","getConvertedVariable","variable","newUnits","getXYSpectra","spectra","selector","selectedSpectra","labels","xUnits","yUnits","xVariable","yVariable","xLabel","yLabel","split","getPossibleVariable","variableName","convertibleUnits","regexpLabel","upper","hasOwn","lower","possibleFiltered","Analysis","spectrumCallback","cache","ids","analysis","fromJSON","pushSpectrum","analysisOptions","standardizeData","getXYSpectrum","getXY","normalization","getNormalizedSpectra","normalizedSpectra","getSpectrum","getXLabel","getYLabel","appendDistinctParameter","appendDistinctValue","AnalysesManager","analyses","analysesManager","addAnalysis","getAnalysisIndex","getAnalyses","processedAnalysisIds","has","getSpectra","getAnalysisBySpectrumId","getSpectrumById","getDistinctTitles","getDistinctUnits","getDistinctLabelUnits","normalizeLabelUnits","getDistinctLabels","getDistinctDataTypes","getDistinctMeta","removeAllAnalyses","removeAnalysis","originalLabel","originalUnits","search","ensureString","blob","encoding","guessEncoding","TextDecoder","decode","uint8","buffer","byteOffset","byteLength","buf","isutf8","parseString","lowercase","getGyromagneticRatio","nucleus","realNucleus","gyromagneticRatio","nucleusNumber","filteredNuclei","getGyromagneticNucleus","fromEntries","_ref","quickSelectMedian","$","ee","te","series","ms","pageValue","chromatogram","ne","E","logger","xFactor","yFactor","isXYdata","o","firstX","firstY","codePointAt","N","S","O","R","isPeaktable","ce","me","isXYAdata","oe","lastY","ntuples","symbol","some","se","ue","ie","minZ","maxZ","noise","G","noContour","contourLines","nbContourLevels","I","le","K","noiseMultiplier","zValue","lines","T","segments","Z","J","intensity","observeFrequency","shiftOffsetVal","$NUC2","$NUC1","yType","xType","W","pageSymbol","dynamicTyping","ae","pe","twoD","wantXY","profiling","keepSpectra","charAt","vardim","varname","ge","removeComments","keepRecordsRegExp","canonicDataLabels","canonicMetadataLabels","withoutXY","noTrimRegExp","fromJcamp","jcamp","converted","be","debug","children","datatable","dataClass","jcampDX","jcampCS","shiftOffsetNum","vartype","varform","page","sampleDescription","pop","de","currentSpectrum","addJcamp","text","uniqueX","bestGuess","keepInfo","xColumn","yColumn","numberColumns","maxNumberColumns","minNumberColumns","fields","skipFirstColumn","parseXYAndKeepInfo","addInfoData","header","checkNumberOrArray","getExtremeValues","firstLast","getBestFactor","onlyInteger","getFactorNumber","getNumber","rounded","newLine","pseudoDigits","vectorEncoder","intervalX","xyEncoding","fixEncoding","outputData","squeezedDigit","squeezedEncoding","differenceEncoding","mult","charCount","encodedData","encodedNumber","diffData","numDiff","differenceDigit","duplicateDigit","differenceDuplicateEncoding","commaSeparatedValuesEncoding","packedEncoding","separator","sqzDigits","charCodeAt","substring","diffDigits","dupDigits","xyDataCreator","rescaleAndEnsureInteger","owner","origin","resInfo","peakTableCreator","fromVariables","forceNtuples","jcampOptions","varName","varType","varDim","isDependent","creatorNtuples","xData","getJcamp","JSGraph","getJSGraph","colors","opacities","linesWidth","xAxis","yAxis","firstSpectrum","logScale","axes","unitWrapperBefore","unitWrapperAfter","flipped","display","getNormalizationAnnotations","boundary","annotations","exclusion","ignore","strokeWidth","fillColor","searchMonoisotopicRatio","ml_spectra_processing_1","nextItem","elementsAndIsotopes","nominal","mass","abundance","monoisotopicMass","elements","elementsAndIsotopes_js_1","elementsAndIsotopesObject","elementsAndStableIsotopes","elementsAndStableIsotopesObject","elementsObject","isotopesObject","elementsAndIsotopesObject_js_1","isotope","isotopes","stableIsotopesObject","mostAbundant","unsaturationsObject","Na","Ca","Si","Cl","groupsObject","groups_1","mf","part","groupsObject_js_1","oneLetter","usefulParts","Kind","BEGIN","ATOM","MULTIPLIER_RANGE","ISOTOPE","ISOTOPE_RATIO","CHARGE","SALT","OPENING_PARENTHESIS","CLOSING_PARENTHESIS","PRE_MULTIPLIER","MULTIPLIER","TEXT","parseCharge_1","parseCharge","charge","chargeNumber","Kind_1","require$$3","require$$4","expandGroups","lastKind","char","ascii","nextAscii","MFError","ANCHOR","getAtom","getParenthesisCharge","getIsotope","isotopeRatio","getCurlyBracketIsotopeRatio","lastResult","atom","getNonParenthesisCharge","COMMENT","checkParenthesis","parsed","multipliers","currentMultiplier","newParsed","realMultiplier","distinctParsedObject","atomA","atomB","fromCharCode","indexOfDash","parseNumberWithDivision","chemical_elements_1","expandedGroups","chemical_groups_1","begin","SyntaxError","subSuperscript","superscript","Format","SUBSCRIPT","SUPERSCRIPT","improveLinesForDisplay","Kind_js_1","beginCounter","endCounter","minCounter","nbParenthesisToSuppress","toSuppress","specialCases","Format_1","nbElectrons","improveLinesForDisplay_js_1","special","SUPERIMPOSE","over","formatCharge_js_1","formatCharge","under","require$$2","isMF_1","isMF","Style","toHtml_1","toHtml","html","Style_1","SUPERIMPOSE_SUP_SUB","ensureCase_1","ensureCase","newPart","two","one","getMF","currents","comment","groupIdentical","currentPart","parenthesisLevel","comments","optimizeRanges","newParts","mfsObject","hasRange","createMFs","mfs","getIsotopeRatioInfo_1","getIsotopeRatioInfo","isotopesArray","ratios","getEA_1","getEA","addMass","isotopeRatioInfo","eas","getElements_1","getElements","addElement","newElement","getNumberOfIsotopologues","atoms","nbIsotopes","getNbCombinationsPerAtom","nbAtoms","partToAtoms_1","partToMF_1","partToMF","neutral","getInfoInternal_1","getInfoInternal","customUnsaturations","emFieldName","msemFieldName","oneResult","getProcessedPart","nbIsotopologues","getNumberOfIsotopologues_1","unsaturation","require$$5","require$$6","partToAtoms","validUnsaturation","currentElement","getIsotopesInfo","getDistribution","partsToDisplay","partLine","toDisplay_js_1","partsToMF_1","partsToMF","expand","shouldExpandgroupsObject","createNewPart","previousKind","openingParenthesis","closingParenthesis","preMultiplier","postMultiplier","globalPartMultiplier","expandgroupsObject","group","expanded","combineAtomsIsotopesCharges","calculateAndSortKeys","currentKey","atom_sorter_1","getKey","stringComparator","toText_1","toText","subSuperscript_1","subscript","MFInternal_1","MFInternal","flatten_1","getInfo_1","getIsotopesInfo_1","partsToDisplay_1","require$$7","require$$8","toDisplay_1","require$$9","require$$10","toParts_1","require$$11","parse_1","toDisplay","displayed","toCanonicText","toParts","ea","isotopesInfo","toNeutralMF","MF_1","MF","internal","getInfo","parse_js_1","toHtml_js_1","unsaturationMatcher_1","unsaturationMatcher","onlyNonInteger","minMW","maxMW","minEM","maxEM","minCharge","maxCharge","absoluteCharge","mw","em","unsaturationMatcher_js_1","ensureUppercaseSequence_1","ensureUppercaseSequence","sequence","currentSymbol","getEutrophicationPotential_1","getEutrophicationPotential","mfString","mf_parser_1","nC","nO","nN","nP","thOD","nH","ep","getMsem_1","getMsem","ELECTRON_MASS","allowNeutralMolecules","ionization","forceIonization","targetMass","realIonization","ppm","getRangesForFragment_1","getRangesForFragment","ranges","newRanges","currentMF","possibilities","MFRange_1","MFRange","getRange","currentRange","isInRange","rangeIndex","rangeElement","targetElement","mfDiff_1","mfDiff","mfString1","mfString2","mf1","mf2","preprocessIonizations_1","preprocessIonizations","ionizationsString","ionizations","preprocessRanges_1","preprocessRanges","possibility","originalMinCount","originalMaxCount","currentMinCount","currentMaxCount","currentCount","currentMonoisotopicMass","currentCharge","currentUnsaturation","initialOrder","minInnerMass","maxInnerMass","minInnerCharge","maxInnerCharge","minMass","maxMass","innerCharge","isGroup","innerPossibility","targetMasses","targetIntensities","minMSEM","maxMSEM","allowNegativeAtoms","msInfo","mf_utilities_1","getMsInfo","ionizationAtoms","atomKeys","TargetMassCache_1","TargetMassCache","allowNeutral","firstPossibility","currentMinCharge","currentMaxCharge","uniqueMFs","targetMassCache","advancedFilter","filterUnsaturation","fakeMinUnsaturation","fakeMaxUnsaturation","numberMFEvaluated","numberResults","orderMapping","currentIonization","getOrderMapping","currentAtom","previousAtom","theEnd","maxPosition","lastPosition","lastPossibility","initializePossibilities","isValid","unsaturationValue","isOdd","filterCharge","getMinMass","getResult","mf_matcher_1","msemMatcher","newResult","updateCurrentAtom","setCurrentMinMax","ensureUniqueMF","bestCounts","previousEM","currentCounts","findMFs_1","findMFs","mfIncluded","targetEM","findMFsSync_js_1","findMFsSync","masses","mf_finder_1","getFragmentPeaks","mfInfo","getPeaks_js_1","getPeaks","fromMonoisotopicMass_1","fromMonoisotopicMass","getMassRemainder","calculateOverlapFromDiff","diffs","sumPos","checkPeaks","extract","getCommonArray","pos2","array1Length","array2Length","arithmeticMean","geometricMean","logMean","lnsum","grandMean","means","samples","truncatedMean","percent","alreadySorted","harmonicMean","contraHarmonicMean","theMean","theVariance","standardError","robustMeanAndStdev","stdev","quartiles","quart","q2","pooledStandardDeviation","pooledVariance","vari","mode","itemCount","itemArray","mean1","mean2","skewness","s3","dev","kurtosis","s4","entropy","weightedMean","weightedStandardDeviation","weightedVariance","inPlace","standardize","standardDev","StatArray","commonExtractAndNormalize","extract1","extract2","common1","common2","info1","info2","COMMON_SECOND","COMMON_FIRST","extractAndNormalize","getIntersection","segment1","segment2","p0X","p0Y","p1X","p1Y","p2X","p2Y","s1X","s1Y","s2X","s2Y","setOptions","trapezoid","commonFactor","widthBottom","widthTop","setTrapezoid","setFromTo","setPeaks1","extracts","array1Extract","array1ExtractInfo","array2Extract","array2ExtractInfo","setPeaks2","getExtract1","getExtract2","getExtractInfo1","getExtractInfo2","newWidthBottom","newWidthTop","widthSlope","newFrom","newTo","getOverlap","x2","getOverlapTrapezoid","small","big","targets","segment","intersection","calculateDiff","newFirst","newSecond","pos1","previous2","getSimilarity","newPeaks1","newPeaks2","extractInfo1","extractInfo2","fastSimilarity","getPeakChargeBySimilarity","widthFunction","experimentalData","similarityProcessor","peaks_similarity_1","checkTopBottom","fromCharge","toCharge","fromIsotope","toIsotope","isotopeHeight","NEUTRON_MASS","getPeaksWithCharge_1","getPeaksWithCharge","selectedPeaks","allPeaks","numberIsotopes","isotopeIntensity","localFromIndex","localToIndex","peaksWithCharge","bestCharge","theoreticalPositions","massRange","isotopePosition","fromMass","toMass","localHeightSum","currentTheoreticalPosition","theoreticalMaxValue","maxDeltaRatio","relativeHeightThreshold","minHeight","minRadio","maxRatio","continuous","previousDelta","success","failed","peakPicking","isContinuous","gsdPeaks","ml_gsd_1","gsdPeak","SimpleLinearRegression","yObj","computeX","absIntercept","PowerRegression","pr","xl","yl","linear","newInputs","latex","peaksWidth_1","peaksWidth","widths","ml_regression_power_1","regressionChart","fit","predictFct","tex","Spectrum_1","Spectrum","fromPeaks","is_any_array_1","xy_parser_1","getPeaksWithCharge_js_1","isContinuous_js_1","peaksWidth_js_1","defaultData","scaleY","rescaleX","ensureOriginalX","xOriginal","normedY","total","getBestPeaks","peakPicking_js_1","getBestPeaks_js_1","getFragmentPeaksFct","MSComparator_1","normalizeAndCacheData","dataXY","minIntensity","xyFilterMinYValue","xyFilterTopYValues","returnSimilarity","aligned","massPower","intensityPower","minNbCommonPeaks","nbCommonPeaks","nbPeaks2","nbPeaks1","tanimoto","cosine","selectedMasses","xyArrayAlign","dataXY1","dataXY2","bestPeaks","numberDigits","showMF","numberMFs","mfPrefs","displayCharge","displayProperties","mfColors","annotation","_highlight","dy","props","rx","ry","fillOpacity","textLine","dx","currentMfPrefs","numberOfMFS","getColor","jsgraph","JsGraph","OriginalJSGraph","getAnnotations","strokeColor","creationFct","showAssignment","showIntensity","showMass","shiftY","anchor","assignment","annotationPeak","msSpectrum","minMaxX","commonFromJcamp","isMax","optimizedPeak","optimizedIndex","maximumY","optimizePeak","optimized","originalPeakPicking","jcamps","toJcamps"],"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,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,239,240,241,242,243,244,245,246,247,248,249,250,251,252,253,254,255,256,257,258,259,260,261,262,263,264,265,266,267,268,269,270,271,272,273,274,275,276,277,278,279,280,281,282,283,284,285,286,287,288,289,290,291,292,293,294,295,296,297,298,299,300,301,302,303,304,305,306,307,308,309,310,311,312,313,314,315,316,317,318,319,320,321,322,323,324,325,326,327,328,329,330,331,332,333,334,335,336,337,338,339,340,341,342,343,344,345,346,347,348,349,350,351,352,353,354,355,356,357,358,359,360,361,362,363,364,365,366,367,368,369,370,371,372,373,374,375,376,377,378,379,380,381,382,383,384,385,386,387,388,389,390,391,392,393,394,395,396,397,403,404]}