nmr-processing 9.7.8 → 9.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/apodization/compose.js +1 -1
- package/lib/apodization/compose.js.map +1 -1
- package/lib/assignment/get13CAssignments.d.ts +1 -1
- package/lib/assignment/get13CAssignments.js +3 -3
- package/lib/assignment/get13CAssignments.js.map +1 -1
- package/lib/assignment/get1HAssignments.d.ts +2 -4
- package/lib/assignment/get1HAssignments.js +3 -3
- package/lib/assignment/get1HAssignments.js.map +1 -1
- package/lib/assignment/getAssignments.d.ts +3 -5
- package/lib/assignment/getAssignments.js +5 -5
- package/lib/assignment/getAssignments.js.map +1 -1
- package/lib/assignment/nmrAssigment.d.ts +2 -2
- package/lib/assignment/utils/addSolution.d.ts +13 -0
- package/lib/assignment/utils/addSolution.js +29 -0
- package/lib/assignment/utils/addSolution.js.map +1 -0
- package/lib/assignment/utils/{getAssignment → generalAssignment}/buildAssignments.d.ts +13 -27
- package/lib/assignment/utils/{getAssignment → generalAssignment}/buildAssignments.js +15 -15
- package/lib/assignment/utils/generalAssignment/buildAssignments.js.map +1 -0
- package/lib/assignment/utils/{getAssignment → generalAssignment}/checkIDs.js +6 -6
- package/lib/assignment/utils/generalAssignment/checkIDs.js.map +1 -0
- package/lib/assignment/utils/{getAssignment → generalAssignment}/createMapPossibleAssignment.d.ts +3 -7
- package/lib/assignment/utils/{getAssignment → generalAssignment}/createMapPossibleAssignment.js +7 -7
- package/lib/assignment/utils/generalAssignment/createMapPossibleAssignment.js.map +1 -0
- package/lib/assignment/utils/{getAssignment → generalAssignment}/exploreTree.d.ts +1 -1
- package/lib/assignment/utils/{getAssignment → generalAssignment}/exploreTree.js +6 -7
- package/lib/assignment/utils/generalAssignment/exploreTree.js.map +1 -0
- package/lib/assignment/utils/{getAssignment → generalAssignment}/formatData.js +5 -5
- package/lib/assignment/utils/generalAssignment/formatData.js.map +1 -0
- package/lib/assignment/utils/generalAssignment/getIntegrationOfAttachedProtons.js.map +1 -0
- package/lib/assignment/utils/{getAssignment → generalAssignment}/getTargetsAndCorrelations.d.ts +2 -4
- package/lib/assignment/utils/{getAssignment → generalAssignment}/getTargetsAndCorrelations.js +1 -1
- package/lib/assignment/utils/generalAssignment/getTargetsAndCorrelations.js.map +1 -0
- package/lib/assignment/utils/{getAssignment → generalAssignment}/getWorkFlow.d.ts +1 -1
- package/lib/assignment/utils/generalAssignment/getWorkFlow.js.map +1 -0
- package/lib/assignment/utils/{getAssignment → generalAssignment}/groupCarbonTargetByIntegrationZone.js +8 -8
- package/lib/assignment/utils/generalAssignment/groupCarbonTargetByIntegrationZone.js.map +1 -0
- package/lib/assignment/utils/generalAssignment/isSpectraData1D.js.map +1 -0
- package/lib/assignment/utils/{getAssignment → generalAssignment}/partialScore.d.ts +1 -3
- package/lib/assignment/utils/{getAssignment → generalAssignment}/partialScore.js +20 -20
- package/lib/assignment/utils/generalAssignment/partialScore.js.map +1 -0
- package/lib/assignment/utils/generalAssignment/searchIndices.js.map +1 -0
- package/lib/assignment/utils/{buildAssignments.d.ts → oneDimensionalAssignment/buildAssignments.d.ts} +2 -4
- package/lib/assignment/utils/{buildAssignments.js → oneDimensionalAssignment/buildAssignments.js} +4 -4
- package/lib/assignment/utils/oneDimensionalAssignment/buildAssignments.js.map +1 -0
- package/lib/assignment/utils/{createMapPossibleAssignments.d.ts → oneDimensionalAssignment/createMapPossibleAssignments.d.ts} +3 -5
- package/lib/assignment/utils/{createMapPossibleAssignments.js → oneDimensionalAssignment/createMapPossibleAssignments.js} +4 -4
- package/lib/assignment/utils/oneDimensionalAssignment/createMapPossibleAssignments.js.map +1 -0
- package/lib/assignment/utils/{exploreTreeRec.d.ts → oneDimensionalAssignment/exploreTreeRec.d.ts} +1 -1
- package/lib/assignment/utils/{exploreTreeRec.js → oneDimensionalAssignment/exploreTreeRec.js} +7 -8
- package/lib/assignment/utils/oneDimensionalAssignment/exploreTreeRec.js.map +1 -0
- package/lib/assignment/utils/{partialScore.d.ts → oneDimensionalAssignment/partialScore.d.ts} +1 -1
- package/lib/assignment/utils/{partialScore.js → oneDimensionalAssignment/partialScore.js} +9 -9
- package/lib/assignment/utils/oneDimensionalAssignment/partialScore.js.map +1 -0
- package/lib/constants/SignalsKinds.d.ts +2 -2
- package/lib/constants/SignalsKinds.js.map +1 -1
- package/lib/constants/couplingValues.d.ts +1 -3
- package/lib/constants/couplingValues.js.map +1 -1
- package/lib/constants/degreeToRadians.d.ts +1 -0
- package/lib/constants/degreeToRadians.js +5 -0
- package/lib/constants/degreeToRadians.js.map +1 -0
- package/lib/constants/impurities.d.ts +1509 -6
- package/lib/constants/impurities.js +2 -1
- package/lib/constants/impurities.js.map +1 -1
- package/lib/databases/getDatabase.js +1 -1
- package/lib/databases/getDatabase.js.map +1 -1
- package/lib/datum/Filters.js +4 -0
- package/lib/datum/Filters.js.map +1 -1
- package/lib/datum/FiltersManager.d.ts +1 -1
- package/lib/datum/FiltersManager.js +2 -2
- package/lib/datum/FiltersManager.js.map +1 -1
- package/lib/datum/MatrixOptions.d.ts +2 -2
- package/lib/datum/data1d/Entry1D.d.ts +1 -1
- package/lib/datum/data1d/filter1d/baselineCorrection.js +4 -4
- package/lib/datum/data1d/filter1d/baselineCorrection.js.map +1 -1
- package/lib/datum/data1d/filter1d/digitalFilter.js +2 -2
- package/lib/datum/data1d/filter1d/digitalFilter.js.map +1 -1
- package/lib/datum/data1d/filter1d/fft.js +7 -7
- package/lib/datum/data1d/filter1d/fft.js.map +1 -1
- package/lib/datum/data1d/filter1d/phaseCorrection.js +3 -3
- package/lib/datum/data1d/filter1d/phaseCorrection.js.map +1 -1
- package/lib/datum/data1d/filter1d/signalProcessing.js +1 -1
- package/lib/datum/data1d/filter1d/signalProcessing.js.map +1 -1
- package/lib/datum/data1d/filter1d/utils/padDataToNextPowerOfTwo.js +2 -2
- package/lib/datum/data1d/filter1d/utils/padDataToNextPowerOfTwo.js.map +1 -1
- package/lib/datum/data1d/filter1d/zeroFilling.js +8 -8
- package/lib/datum/data1d/filter1d/zeroFilling.js.map +1 -1
- package/lib/datum/data1d/utils/mapPeaks.js +1 -1
- package/lib/datum/data1d/utils/mapPeaks.js.map +1 -1
- package/lib/datum/data2d/Entry2D.d.ts +1 -1
- package/lib/datum/data2d/filter2d/fftDimension1.d.ts +15 -0
- package/lib/datum/data2d/filter2d/fftDimension1.js +69 -0
- package/lib/datum/data2d/filter2d/fftDimension1.js.map +1 -0
- package/lib/datum/data2d/filter2d/fftDimension2.d.ts +15 -0
- package/lib/datum/data2d/filter2d/fftDimension2.js +78 -0
- package/lib/datum/data2d/filter2d/fftDimension2.js.map +1 -0
- package/lib/datum/data2d/utils/getShift.js +1 -1
- package/lib/datum/data2d/utils/getShift.js.map +1 -1
- package/lib/multiplicity/splitPatterns.js +1 -1
- package/lib/multiplicity/splitPatterns.js.map +1 -1
- package/lib/peaks/peaksFilterImpurities.js +7 -6
- package/lib/peaks/peaksFilterImpurities.js.map +1 -1
- package/lib/peaks/peaksToRanges.js +17 -17
- package/lib/peaks/peaksToRanges.js.map +1 -1
- package/lib/peaks/solventSuppression.js +11 -11
- package/lib/peaks/solventSuppression.js.map +1 -1
- package/lib/peaks/util/addMissingIDs.js.map +1 -1
- package/lib/peaks/util/determineRealTop.js +32 -32
- package/lib/peaks/util/determineRealTop.js.map +1 -1
- package/lib/peaks/util/getKernel.js +4 -4
- package/lib/peaks/util/getKernel.js.map +1 -1
- package/lib/peaks/util/peakOptimizer.js +17 -17
- package/lib/peaks/util/peakOptimizer.js.map +1 -1
- package/lib/peaks/util/setIDs.js.map +1 -1
- package/lib/prediction/dataStructure.d.ts +1 -3
- package/lib/prediction/predictAll.js +2 -1
- package/lib/prediction/predictAll.js.map +1 -1
- package/lib/prediction/predictCOSY.js +1 -1
- package/lib/prediction/predictCOSY.js.map +1 -1
- package/lib/prediction/predictCarbon.js +6 -6
- package/lib/prediction/predictCarbon.js.map +1 -1
- package/lib/prediction/predictHMBC.js +1 -1
- package/lib/prediction/predictHMBC.js.map +1 -1
- package/lib/prediction/predictHSQC.js +1 -1
- package/lib/prediction/predictHSQC.js.map +1 -1
- package/lib/prediction/predictProton.js +9 -9
- package/lib/prediction/predictProton.js.map +1 -1
- package/lib/prediction/utils/getFilteredIDiaIDs.js +3 -3
- package/lib/prediction/utils/getFilteredIDiaIDs.js.map +1 -1
- package/lib/prediction/utils/getNuclei.d.ts +1 -3
- package/lib/prediction/utils/getNuclei.js.map +1 -1
- package/lib/prediction/utils/predict2D.d.ts +1 -3
- package/lib/prediction/utils/predict2D.js +17 -17
- package/lib/prediction/utils/predict2D.js.map +1 -1
- package/lib/prediction/utils/queryByHOSE.js +1 -1
- package/lib/prediction/utils/queryByHOSE.js.map +1 -1
- package/lib/ranges/markSolventSignal.js +8 -8
- package/lib/ranges/markSolventSignal.js.map +1 -1
- package/lib/ranges/rangesToACS.js +6 -6
- package/lib/ranges/rangesToACS.js.map +1 -1
- package/lib/ranges/rangesToXY.js +6 -6
- package/lib/ranges/rangesToXY.js.map +1 -1
- package/lib/signal/signalJoinCouplings.js +9 -9
- package/lib/signal/signalJoinCouplings.js.map +1 -1
- package/lib/signal/signalMultiplicityPattern.js +2 -2
- package/lib/signal/signalMultiplicityPattern.js.map +1 -1
- package/lib/signals/addDummySignals.js +4 -4
- package/lib/signals/addDummySignals.js.map +1 -1
- package/lib/signals/hackSignalsToXY.js +1 -1
- package/lib/signals/hackSignalsToXY.js.map +1 -1
- package/lib/signals/optimization/getInternalSignals.js +6 -6
- package/lib/signals/optimization/getInternalSignals.js.map +1 -1
- package/lib/signals/optimization/getSumOfShapes.js +1 -1
- package/lib/signals/optimization/getSumOfShapes.js.map +1 -1
- package/lib/signals/optimizeSignals.js +3 -3
- package/lib/signals/optimizeSignals.js.map +1 -1
- package/lib/signals/signals2DToZ.js +3 -2
- package/lib/signals/signals2DToZ.js.map +1 -1
- package/lib/signals/signalsJoin.js +5 -5
- package/lib/signals/signalsJoin.js.map +1 -1
- package/lib/signals/signalsToFID.js +1 -1
- package/lib/signals/signalsToFID.js.map +1 -1
- package/lib/signals/signalsToRanges.js +3 -3
- package/lib/signals/signalsToRanges.js.map +1 -1
- package/lib/signals/signalsToXY.js +3 -3
- package/lib/signals/signalsToXY.js.map +1 -1
- package/lib/signals/simulation/signalsToSpinSystem.js +2 -2
- package/lib/signals/simulation/signalsToSpinSystem.js.map +1 -1
- package/lib/signals/simulation/simulate1D.js +2 -2
- package/lib/signals/simulation/simulate1D.js.map +1 -1
- package/lib/signals/simulation/simulateXYPeaks.js +15 -17
- package/lib/signals/simulation/simulateXYPeaks.js.map +1 -1
- package/lib/signals/simulation/splitSpinSystem.js +26 -23
- package/lib/signals/simulation/splitSpinSystem.js.map +1 -1
- package/lib/signals/utils/jAnalyzer.js +38 -38
- package/lib/signals/utils/jAnalyzer.js.map +1 -1
- package/lib/types/Integrals.d.ts +1 -1
- package/lib/types/Peaks/Peaks.d.ts +1 -1
- package/lib/types/Ranges/Ranges.d.ts +1 -1
- package/lib/types/Zones/Zone.d.ts +1 -1
- package/lib/types/Zones/Zones.d.ts +1 -1
- package/lib/utilities/getFrequency.js +1 -1
- package/lib/utilities/getFrequency.js.map +1 -1
- package/lib/utilities/resurrectRange.js +1 -1
- package/lib/utilities/resurrectRange.js.map +1 -1
- package/lib/xy/xyAutoPeaksPicking.js +3 -3
- package/lib/xy/xyAutoPeaksPicking.js.map +1 -1
- package/lib/xyz/quadrature.js +1 -19
- package/lib/xyz/quadrature.js.map +1 -1
- package/lib/xyz/util/fft2d/digitalFilter.js +3 -3
- package/lib/xyz/util/fft2d/digitalFilter.js.map +1 -1
- package/lib/xyz/util/fft2d/fftDirectDimension.d.ts +1 -1
- package/lib/xyz/util/fft2d/fftDirectDimension.js +3 -11
- package/lib/xyz/util/fft2d/fftDirectDimension.js.map +1 -1
- package/lib/xyz/util/fft2d/fftIndirectDimension.d.ts +2 -4
- package/lib/xyz/util/fft2d/fftIndirectDimension.js +104 -50
- package/lib/xyz/util/fft2d/fftIndirectDimension.js.map +1 -1
- package/lib/xyz/util/fft2d/removeDCOffset.js +1 -1
- package/lib/xyz/util/fft2d/removeDCOffset.js.map +1 -1
- package/lib/xyz/util/fft2d/zeroFilling.js +4 -6
- package/lib/xyz/util/fft2d/zeroFilling.js.map +1 -1
- package/lib/xyz/util/formatZone.js +3 -3
- package/lib/xyz/util/formatZone.js.map +1 -1
- package/lib/xyz/util/getMinMaxXY.d.ts +6 -0
- package/lib/xyz/util/getMinMaxXY.js +23 -0
- package/lib/xyz/util/getMinMaxXY.js.map +1 -0
- package/lib/xyz/util/padData.js +7 -7
- package/lib/xyz/util/padData.js.map +1 -1
- package/lib/xyz/util/phaseCorrection/applyOverImag.d.ts +24 -0
- package/lib/xyz/util/phaseCorrection/applyOverImag.js +27 -0
- package/lib/xyz/util/phaseCorrection/applyOverImag.js.map +1 -0
- package/lib/xyz/util/phaseCorrection/applyOverReal.d.ts +22 -0
- package/lib/xyz/util/phaseCorrection/applyOverReal.js +27 -0
- package/lib/xyz/util/phaseCorrection/applyOverReal.js.map +1 -0
- package/lib/xyz/util/phaseCorrection/checkNmrData2DFourQuad.d.ts +3 -0
- package/lib/xyz/util/phaseCorrection/checkNmrData2DFourQuad.js +10 -0
- package/lib/xyz/util/phaseCorrection/checkNmrData2DFourQuad.js.map +1 -0
- package/lib/xyz/util/phaseCorrection/checkNmrData2DTwoQuad.d.ts +3 -0
- package/lib/xyz/util/phaseCorrection/checkNmrData2DTwoQuad.js +10 -0
- package/lib/xyz/util/phaseCorrection/checkNmrData2DTwoQuad.js.map +1 -0
- package/lib/xyz/util/phaseCorrection/getZMinMax.d.ts +6 -0
- package/lib/xyz/util/phaseCorrection/getZMinMax.js +13 -0
- package/lib/xyz/util/phaseCorrection/getZMinMax.js.map +1 -0
- package/lib/xyz/xyzAutoSignalsPicking.js +19 -18
- package/lib/xyz/xyzAutoSignalsPicking.js.map +1 -1
- package/lib/xyz/xyzBidimensionalFFT.js +2 -19
- package/lib/xyz/xyzBidimensionalFFT.js.map +1 -1
- package/lib/xyz/xyzJResAnalyzer.js +21 -21
- package/lib/xyz/xyzJResAnalyzer.js.map +1 -1
- package/lib/xyz/xyzPhaseCorrectionDirectDimension.d.ts +16 -0
- package/lib/xyz/xyzPhaseCorrectionDirectDimension.js +30 -0
- package/lib/xyz/xyzPhaseCorrectionDirectDimension.js.map +1 -0
- package/lib/xyz/xyzPhaseCorrectionIndirectDimension.d.ts +25 -0
- package/lib/xyz/xyzPhaseCorrectionIndirectDimension.js +32 -0
- package/lib/xyz/xyzPhaseCorrectionIndirectDimension.js.map +1 -0
- package/lib-esm/apodization/compose.js +1 -1
- package/lib-esm/apodization/compose.js.map +1 -1
- package/lib-esm/assignment/get13CAssignments.js +3 -3
- package/lib-esm/assignment/get13CAssignments.js.map +1 -1
- package/lib-esm/assignment/get1HAssignments.js +3 -3
- package/lib-esm/assignment/get1HAssignments.js.map +1 -1
- package/lib-esm/assignment/getAssignments.js +5 -5
- package/lib-esm/assignment/getAssignments.js.map +1 -1
- package/lib-esm/assignment/utils/addSolution.js +25 -0
- package/lib-esm/assignment/utils/addSolution.js.map +1 -0
- package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/buildAssignments.js +15 -15
- package/lib-esm/assignment/utils/generalAssignment/buildAssignments.js.map +1 -0
- package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/checkIDs.js +6 -6
- package/lib-esm/assignment/utils/generalAssignment/checkIDs.js.map +1 -0
- package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/createMapPossibleAssignment.js +7 -7
- package/lib-esm/assignment/utils/generalAssignment/createMapPossibleAssignment.js.map +1 -0
- package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/exploreTree.js +6 -7
- package/lib-esm/assignment/utils/generalAssignment/exploreTree.js.map +1 -0
- package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/formatData.js +5 -5
- package/lib-esm/assignment/utils/generalAssignment/formatData.js.map +1 -0
- package/lib-esm/assignment/utils/generalAssignment/getIntegrationOfAttachedProtons.js.map +1 -0
- package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/getTargetsAndCorrelations.js +1 -1
- package/lib-esm/assignment/utils/generalAssignment/getTargetsAndCorrelations.js.map +1 -0
- package/lib-esm/assignment/utils/generalAssignment/getWorkFlow.js.map +1 -0
- package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/groupCarbonTargetByIntegrationZone.js +8 -8
- package/lib-esm/assignment/utils/generalAssignment/groupCarbonTargetByIntegrationZone.js.map +1 -0
- package/lib-esm/assignment/utils/generalAssignment/isSpectraData1D.js.map +1 -0
- package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/partialScore.js +20 -20
- package/lib-esm/assignment/utils/generalAssignment/partialScore.js.map +1 -0
- package/lib-esm/assignment/utils/generalAssignment/searchIndices.js.map +1 -0
- package/lib-esm/assignment/utils/{buildAssignments.js → oneDimensionalAssignment/buildAssignments.js} +4 -4
- package/lib-esm/assignment/utils/oneDimensionalAssignment/buildAssignments.js.map +1 -0
- package/lib-esm/assignment/utils/{createMapPossibleAssignments.js → oneDimensionalAssignment/createMapPossibleAssignments.js} +4 -4
- package/lib-esm/assignment/utils/oneDimensionalAssignment/createMapPossibleAssignments.js.map +1 -0
- package/lib-esm/assignment/utils/{exploreTreeRec.js → oneDimensionalAssignment/exploreTreeRec.js} +7 -8
- package/lib-esm/assignment/utils/oneDimensionalAssignment/exploreTreeRec.js.map +1 -0
- package/lib-esm/assignment/utils/{partialScore.js → oneDimensionalAssignment/partialScore.js} +9 -9
- package/lib-esm/assignment/utils/oneDimensionalAssignment/partialScore.js.map +1 -0
- package/lib-esm/constants/SignalsKinds.js.map +1 -1
- package/lib-esm/constants/couplingValues.js.map +1 -1
- package/lib-esm/constants/degreeToRadians.js +2 -0
- package/lib-esm/constants/degreeToRadians.js.map +1 -0
- package/lib-esm/constants/impurities.js +2 -1
- package/lib-esm/constants/impurities.js.map +1 -1
- package/lib-esm/databases/getDatabase.js +1 -1
- package/lib-esm/databases/getDatabase.js.map +1 -1
- package/lib-esm/datum/Filters.js +4 -0
- package/lib-esm/datum/Filters.js.map +1 -1
- package/lib-esm/datum/FiltersManager.js +2 -2
- package/lib-esm/datum/FiltersManager.js.map +1 -1
- package/lib-esm/datum/data1d/filter1d/baselineCorrection.js +4 -4
- package/lib-esm/datum/data1d/filter1d/baselineCorrection.js.map +1 -1
- package/lib-esm/datum/data1d/filter1d/digitalFilter.js +2 -2
- package/lib-esm/datum/data1d/filter1d/digitalFilter.js.map +1 -1
- package/lib-esm/datum/data1d/filter1d/fft.js +7 -7
- package/lib-esm/datum/data1d/filter1d/fft.js.map +1 -1
- package/lib-esm/datum/data1d/filter1d/phaseCorrection.js +3 -3
- package/lib-esm/datum/data1d/filter1d/phaseCorrection.js.map +1 -1
- package/lib-esm/datum/data1d/filter1d/signalProcessing.js +1 -1
- package/lib-esm/datum/data1d/filter1d/signalProcessing.js.map +1 -1
- package/lib-esm/datum/data1d/filter1d/utils/padDataToNextPowerOfTwo.js +2 -2
- package/lib-esm/datum/data1d/filter1d/utils/padDataToNextPowerOfTwo.js.map +1 -1
- package/lib-esm/datum/data1d/filter1d/zeroFilling.js +8 -8
- package/lib-esm/datum/data1d/filter1d/zeroFilling.js.map +1 -1
- package/lib-esm/datum/data1d/utils/mapPeaks.js +1 -1
- package/lib-esm/datum/data1d/utils/mapPeaks.js.map +1 -1
- package/lib-esm/datum/data2d/filter2d/fftDimension1.js +63 -0
- package/lib-esm/datum/data2d/filter2d/fftDimension1.js.map +1 -0
- package/lib-esm/datum/data2d/filter2d/fftDimension2.js +72 -0
- package/lib-esm/datum/data2d/filter2d/fftDimension2.js.map +1 -0
- package/lib-esm/datum/data2d/utils/getShift.js +1 -1
- package/lib-esm/datum/data2d/utils/getShift.js.map +1 -1
- package/lib-esm/multiplicity/splitPatterns.js +1 -1
- package/lib-esm/multiplicity/splitPatterns.js.map +1 -1
- package/lib-esm/peaks/peaksFilterImpurities.js +7 -6
- package/lib-esm/peaks/peaksFilterImpurities.js.map +1 -1
- package/lib-esm/peaks/peaksToRanges.js +17 -17
- package/lib-esm/peaks/peaksToRanges.js.map +1 -1
- package/lib-esm/peaks/solventSuppression.js +11 -11
- package/lib-esm/peaks/solventSuppression.js.map +1 -1
- package/lib-esm/peaks/util/addMissingIDs.js.map +1 -1
- package/lib-esm/peaks/util/determineRealTop.js +32 -32
- package/lib-esm/peaks/util/determineRealTop.js.map +1 -1
- package/lib-esm/peaks/util/getKernel.js +4 -4
- package/lib-esm/peaks/util/getKernel.js.map +1 -1
- package/lib-esm/peaks/util/peakOptimizer.js +17 -17
- package/lib-esm/peaks/util/peakOptimizer.js.map +1 -1
- package/lib-esm/peaks/util/setIDs.js.map +1 -1
- package/lib-esm/prediction/predictAll.js +2 -1
- package/lib-esm/prediction/predictAll.js.map +1 -1
- package/lib-esm/prediction/predictCOSY.js +1 -1
- package/lib-esm/prediction/predictCOSY.js.map +1 -1
- package/lib-esm/prediction/predictCarbon.js +6 -6
- package/lib-esm/prediction/predictCarbon.js.map +1 -1
- package/lib-esm/prediction/predictHMBC.js +1 -1
- package/lib-esm/prediction/predictHMBC.js.map +1 -1
- package/lib-esm/prediction/predictHSQC.js +1 -1
- package/lib-esm/prediction/predictHSQC.js.map +1 -1
- package/lib-esm/prediction/predictProton.js +9 -9
- package/lib-esm/prediction/predictProton.js.map +1 -1
- package/lib-esm/prediction/utils/getFilteredIDiaIDs.js +3 -3
- package/lib-esm/prediction/utils/getFilteredIDiaIDs.js.map +1 -1
- package/lib-esm/prediction/utils/getNuclei.js.map +1 -1
- package/lib-esm/prediction/utils/predict2D.js +17 -17
- package/lib-esm/prediction/utils/predict2D.js.map +1 -1
- package/lib-esm/prediction/utils/queryByHOSE.js +1 -1
- package/lib-esm/prediction/utils/queryByHOSE.js.map +1 -1
- package/lib-esm/ranges/markSolventSignal.js +8 -8
- package/lib-esm/ranges/markSolventSignal.js.map +1 -1
- package/lib-esm/ranges/rangesToACS.js +6 -6
- package/lib-esm/ranges/rangesToACS.js.map +1 -1
- package/lib-esm/ranges/rangesToXY.js +6 -6
- package/lib-esm/ranges/rangesToXY.js.map +1 -1
- package/lib-esm/signal/signalJoinCouplings.js +9 -9
- package/lib-esm/signal/signalJoinCouplings.js.map +1 -1
- package/lib-esm/signal/signalMultiplicityPattern.js +2 -2
- package/lib-esm/signal/signalMultiplicityPattern.js.map +1 -1
- package/lib-esm/signals/addDummySignals.js +4 -4
- package/lib-esm/signals/addDummySignals.js.map +1 -1
- package/lib-esm/signals/hackSignalsToXY.js +1 -1
- package/lib-esm/signals/hackSignalsToXY.js.map +1 -1
- package/lib-esm/signals/optimization/getInternalSignals.js +6 -6
- package/lib-esm/signals/optimization/getInternalSignals.js.map +1 -1
- package/lib-esm/signals/optimization/getSumOfShapes.js +1 -1
- package/lib-esm/signals/optimization/getSumOfShapes.js.map +1 -1
- package/lib-esm/signals/optimizeSignals.js +3 -3
- package/lib-esm/signals/optimizeSignals.js.map +1 -1
- package/lib-esm/signals/signals2DToZ.js +3 -2
- package/lib-esm/signals/signals2DToZ.js.map +1 -1
- package/lib-esm/signals/signalsJoin.js +5 -5
- package/lib-esm/signals/signalsJoin.js.map +1 -1
- package/lib-esm/signals/signalsToFID.js +1 -1
- package/lib-esm/signals/signalsToFID.js.map +1 -1
- package/lib-esm/signals/signalsToRanges.js +3 -3
- package/lib-esm/signals/signalsToRanges.js.map +1 -1
- package/lib-esm/signals/signalsToXY.js +3 -3
- package/lib-esm/signals/signalsToXY.js.map +1 -1
- package/lib-esm/signals/simulation/signalsToSpinSystem.js +2 -2
- package/lib-esm/signals/simulation/signalsToSpinSystem.js.map +1 -1
- package/lib-esm/signals/simulation/simulate1D.js +2 -2
- package/lib-esm/signals/simulation/simulate1D.js.map +1 -1
- package/lib-esm/signals/simulation/simulateXYPeaks.js +15 -17
- package/lib-esm/signals/simulation/simulateXYPeaks.js.map +1 -1
- package/lib-esm/signals/simulation/splitSpinSystem.js +26 -23
- package/lib-esm/signals/simulation/splitSpinSystem.js.map +1 -1
- package/lib-esm/signals/utils/jAnalyzer.js +38 -38
- package/lib-esm/signals/utils/jAnalyzer.js.map +1 -1
- package/lib-esm/utilities/getFrequency.js +1 -1
- package/lib-esm/utilities/getFrequency.js.map +1 -1
- package/lib-esm/utilities/resurrectRange.js +1 -1
- package/lib-esm/utilities/resurrectRange.js.map +1 -1
- package/lib-esm/xy/xyAutoPeaksPicking.js +3 -3
- package/lib-esm/xy/xyAutoPeaksPicking.js.map +1 -1
- package/lib-esm/xyz/quadrature.js +2 -20
- package/lib-esm/xyz/quadrature.js.map +1 -1
- package/lib-esm/xyz/util/fft2d/digitalFilter.js +3 -3
- package/lib-esm/xyz/util/fft2d/digitalFilter.js.map +1 -1
- package/lib-esm/xyz/util/fft2d/fftDirectDimension.js +4 -12
- package/lib-esm/xyz/util/fft2d/fftDirectDimension.js.map +1 -1
- package/lib-esm/xyz/util/fft2d/fftIndirectDimension.js +104 -50
- package/lib-esm/xyz/util/fft2d/fftIndirectDimension.js.map +1 -1
- package/lib-esm/xyz/util/fft2d/removeDCOffset.js +1 -1
- package/lib-esm/xyz/util/fft2d/removeDCOffset.js.map +1 -1
- package/lib-esm/xyz/util/fft2d/zeroFilling.js +4 -6
- package/lib-esm/xyz/util/fft2d/zeroFilling.js.map +1 -1
- package/lib-esm/xyz/util/formatZone.js +3 -3
- package/lib-esm/xyz/util/formatZone.js.map +1 -1
- package/lib-esm/xyz/util/getMinMaxXY.js +19 -0
- package/lib-esm/xyz/util/getMinMaxXY.js.map +1 -0
- package/lib-esm/xyz/util/padData.js +7 -7
- package/lib-esm/xyz/util/padData.js.map +1 -1
- package/lib-esm/xyz/util/phaseCorrection/applyOverImag.js +20 -0
- package/lib-esm/xyz/util/phaseCorrection/applyOverImag.js.map +1 -0
- package/lib-esm/xyz/util/phaseCorrection/applyOverReal.js +20 -0
- package/lib-esm/xyz/util/phaseCorrection/applyOverReal.js.map +1 -0
- package/lib-esm/xyz/util/phaseCorrection/checkNmrData2DFourQuad.js +6 -0
- package/lib-esm/xyz/util/phaseCorrection/checkNmrData2DFourQuad.js.map +1 -0
- package/lib-esm/xyz/util/phaseCorrection/checkNmrData2DTwoQuad.js +6 -0
- package/lib-esm/xyz/util/phaseCorrection/checkNmrData2DTwoQuad.js.map +1 -0
- package/lib-esm/xyz/util/phaseCorrection/getZMinMax.js +9 -0
- package/lib-esm/xyz/util/phaseCorrection/getZMinMax.js.map +1 -0
- package/lib-esm/xyz/xyzAutoSignalsPicking.js +19 -18
- package/lib-esm/xyz/xyzAutoSignalsPicking.js.map +1 -1
- package/lib-esm/xyz/xyzBidimensionalFFT.js +1 -18
- package/lib-esm/xyz/xyzBidimensionalFFT.js.map +1 -1
- package/lib-esm/xyz/xyzJResAnalyzer.js +21 -21
- package/lib-esm/xyz/xyzJResAnalyzer.js.map +1 -1
- package/lib-esm/xyz/xyzPhaseCorrectionDirectDimension.js +26 -0
- package/lib-esm/xyz/xyzPhaseCorrectionDirectDimension.js.map +1 -0
- package/lib-esm/xyz/xyzPhaseCorrectionIndirectDimension.js +28 -0
- package/lib-esm/xyz/xyzPhaseCorrectionIndirectDimension.js.map +1 -0
- package/package.json +4 -4
- package/src/apodization/compose.ts +1 -1
- package/src/assignment/get13CAssignments.ts +6 -3
- package/src/assignment/get1HAssignments.ts +7 -6
- package/src/assignment/getAssignments.ts +7 -7
- package/src/assignment/nmrAssigment.ts +2 -2
- package/src/assignment/utils/addSolution.ts +45 -0
- package/src/assignment/utils/{getAssignment → generalAssignment}/buildAssignments.ts +29 -36
- package/src/assignment/utils/{getAssignment → generalAssignment}/checkIDs.ts +6 -6
- package/src/assignment/utils/{getAssignment → generalAssignment}/createMapPossibleAssignment.ts +10 -14
- package/src/assignment/utils/{getAssignment → generalAssignment}/exploreTree.ts +7 -8
- package/src/assignment/utils/{getAssignment → generalAssignment}/formatData.ts +5 -5
- package/src/assignment/utils/{getAssignment → generalAssignment}/getTargetsAndCorrelations.ts +3 -5
- package/src/assignment/utils/{getAssignment → generalAssignment}/getWorkFlow.ts +2 -5
- package/src/assignment/utils/{getAssignment → generalAssignment}/groupCarbonTargetByIntegrationZone.ts +8 -8
- package/src/assignment/utils/{getAssignment → generalAssignment}/partialScore.ts +25 -29
- package/src/assignment/utils/{buildAssignments.ts → oneDimensionalAssignment/buildAssignments.ts} +6 -8
- package/src/assignment/utils/{createMapPossibleAssignments.ts → oneDimensionalAssignment/createMapPossibleAssignments.ts} +9 -9
- package/src/assignment/utils/{exploreTreeRec.ts → oneDimensionalAssignment/exploreTreeRec.ts} +8 -9
- package/src/assignment/utils/{partialScore.ts → oneDimensionalAssignment/partialScore.ts} +10 -12
- package/src/constants/SignalsKinds.ts +1 -1
- package/src/constants/couplingValues.ts +1 -1
- package/src/constants/degreeToRadians.ts +1 -0
- package/src/constants/impurities.ts +14 -15
- package/src/databases/getDatabase.ts +1 -1
- package/src/datum/Filters.ts +4 -0
- package/src/datum/FiltersManager.ts +3 -3
- package/src/datum/MatrixOptions.ts +1 -1
- package/src/datum/data1d/Entry1D.ts +1 -1
- package/src/datum/data1d/filter1d/baselineCorrection.ts +4 -4
- package/src/datum/data1d/filter1d/digitalFilter.ts +2 -2
- package/src/datum/data1d/filter1d/fft.ts +7 -7
- package/src/datum/data1d/filter1d/phaseCorrection.ts +3 -3
- package/src/datum/data1d/filter1d/signalProcessing.ts +1 -1
- package/src/datum/data1d/filter1d/utils/padDataToNextPowerOfTwo.ts +2 -2
- package/src/datum/data1d/filter1d/zeroFilling.ts +10 -9
- package/src/datum/data1d/utils/mapPeaks.ts +1 -1
- package/src/datum/data2d/Entry2D.ts +1 -1
- package/src/datum/data2d/filter2d/fftDimension1.ts +93 -0
- package/src/datum/data2d/filter2d/fftDimension2.ts +94 -0
- package/src/datum/data2d/utils/getShift.ts +1 -1
- package/src/ml-tree-set.d.ts +1 -1
- package/src/multiplicity/splitPatterns.ts +1 -1
- package/src/peaks/peaksFilterImpurities.ts +7 -6
- package/src/peaks/peaksToRanges.ts +19 -18
- package/src/peaks/solventSuppression.ts +11 -11
- package/src/peaks/util/addMissingIDs.ts +1 -1
- package/src/peaks/util/determineRealTop.ts +32 -32
- package/src/peaks/util/getKernel.ts +4 -4
- package/src/peaks/util/peakOptimizer.ts +17 -17
- package/src/peaks/util/setIDs.ts +6 -4
- package/src/prediction/dataStructure.ts +1 -3
- package/src/prediction/predictAll.ts +3 -2
- package/src/prediction/predictCOSY.ts +1 -1
- package/src/prediction/predictCarbon.ts +6 -6
- package/src/prediction/predictHMBC.ts +1 -1
- package/src/prediction/predictHSQC.ts +1 -1
- package/src/prediction/predictProton.ts +9 -9
- package/src/prediction/utils/getFilteredIDiaIDs.ts +3 -3
- package/src/prediction/utils/getNuclei.ts +2 -2
- package/src/prediction/utils/predict2D.ts +21 -25
- package/src/prediction/utils/queryByHOSE.ts +1 -1
- package/src/ranges/markSolventSignal.ts +8 -8
- package/src/ranges/rangesToACS.ts +6 -6
- package/src/ranges/rangesToXY.ts +6 -6
- package/src/signal/signalJoinCouplings.ts +9 -9
- package/src/signal/signalMultiplicityPattern.ts +2 -2
- package/src/signals/addDummySignals.ts +4 -4
- package/src/signals/hackSignalsToXY.ts +1 -1
- package/src/signals/optimization/getInternalSignals.ts +6 -6
- package/src/signals/optimization/getSumOfShapes.ts +1 -1
- package/src/signals/optimizeSignals.ts +3 -3
- package/src/signals/signals2DToZ.ts +4 -8
- package/src/signals/signalsJoin.ts +5 -5
- package/src/signals/signalsToFID.ts +1 -1
- package/src/signals/signalsToRanges.ts +3 -3
- package/src/signals/signalsToXY.ts +3 -3
- package/src/signals/simulation/signalsToSpinSystem.ts +3 -5
- package/src/signals/simulation/simulate1D.ts +2 -2
- package/src/signals/simulation/simulateXYPeaks.ts +16 -17
- package/src/signals/simulation/splitSpinSystem.ts +28 -25
- package/src/signals/utils/jAnalyzer.ts +38 -38
- package/src/types/Integrals.ts +1 -1
- package/src/types/Peaks/Peaks.ts +1 -1
- package/src/types/Ranges/Ranges.ts +1 -1
- package/src/types/Zones/Zone.ts +1 -1
- package/src/types/Zones/Zones.ts +1 -1
- package/src/utilities/getFrequency.ts +1 -1
- package/src/utilities/resurrectRange.ts +1 -1
- package/src/xy/xyAutoPeaksPicking.ts +3 -3
- package/src/xyz/quadrature.ts +2 -27
- package/src/xyz/util/fft2d/digitalFilter.ts +3 -3
- package/src/xyz/util/fft2d/fftDirectDimension.ts +4 -23
- package/src/xyz/util/fft2d/fftIndirectDimension.ts +123 -73
- package/src/xyz/util/fft2d/removeDCOffset.ts +1 -1
- package/src/xyz/util/fft2d/zeroFilling.ts +5 -6
- package/src/xyz/util/formatZone.ts +3 -3
- package/src/xyz/util/getMinMaxXY.ts +19 -0
- package/src/xyz/util/padData.ts +7 -7
- package/src/xyz/util/phaseCorrection/applyOverImag.ts +29 -0
- package/src/xyz/util/phaseCorrection/applyOverReal.ts +29 -0
- package/src/xyz/util/phaseCorrection/checkNmrData2DFourQuad.ts +12 -0
- package/src/xyz/util/phaseCorrection/checkNmrData2DTwoQuad.ts +11 -0
- package/src/xyz/util/phaseCorrection/getZMinMax.ts +10 -0
- package/src/xyz/xyzAutoSignalsPicking.ts +20 -19
- package/src/xyz/xyzBidimensionalFFT.ts +1 -20
- package/src/xyz/xyzJResAnalyzer.ts +21 -21
- package/src/xyz/xyzPhaseCorrectionDirectDimension.ts +52 -0
- package/src/xyz/xyzPhaseCorrectionIndirectDimension.ts +45 -0
- package/lib/assignment/utils/buildAssignments.js.map +0 -1
- package/lib/assignment/utils/createMapPossibleAssignments.js.map +0 -1
- package/lib/assignment/utils/exploreTreeRec.js.map +0 -1
- package/lib/assignment/utils/getAssignment/buildAssignments.js.map +0 -1
- package/lib/assignment/utils/getAssignment/checkIDs.js.map +0 -1
- package/lib/assignment/utils/getAssignment/createMapPossibleAssignment.js.map +0 -1
- package/lib/assignment/utils/getAssignment/exploreTree.js.map +0 -1
- package/lib/assignment/utils/getAssignment/formatData.js.map +0 -1
- package/lib/assignment/utils/getAssignment/getIntegrationOfAttachedProtons.js.map +0 -1
- package/lib/assignment/utils/getAssignment/getTargetsAndCorrelations.js.map +0 -1
- package/lib/assignment/utils/getAssignment/getWorkFlow.js.map +0 -1
- package/lib/assignment/utils/getAssignment/groupCarbonTargetByIntegrationZone.js.map +0 -1
- package/lib/assignment/utils/getAssignment/isSpectraData1D.js.map +0 -1
- package/lib/assignment/utils/getAssignment/partialScore.js.map +0 -1
- package/lib/assignment/utils/getAssignment/searchIndices.js.map +0 -1
- package/lib/assignment/utils/partialScore.js.map +0 -1
- package/lib-esm/assignment/utils/buildAssignments.js.map +0 -1
- package/lib-esm/assignment/utils/createMapPossibleAssignments.js.map +0 -1
- package/lib-esm/assignment/utils/exploreTreeRec.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/buildAssignments.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/checkIDs.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/createMapPossibleAssignment.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/exploreTree.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/formatData.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/getIntegrationOfAttachedProtons.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/getTargetsAndCorrelations.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/getWorkFlow.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/groupCarbonTargetByIntegrationZone.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/isSpectraData1D.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/partialScore.js.map +0 -1
- package/lib-esm/assignment/utils/getAssignment/searchIndices.js.map +0 -1
- package/lib-esm/assignment/utils/partialScore.js.map +0 -1
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/checkIDs.d.ts +0 -0
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/formatData.d.ts +0 -0
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/getIntegrationOfAttachedProtons.d.ts +0 -0
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/getIntegrationOfAttachedProtons.js +0 -0
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/getWorkFlow.js +0 -0
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/groupCarbonTargetByIntegrationZone.d.ts +0 -0
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/isSpectraData1D.d.ts +0 -0
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/isSpectraData1D.js +0 -0
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/searchIndices.d.ts +0 -0
- /package/lib/assignment/utils/{getAssignment → generalAssignment}/searchIndices.js +0 -0
- /package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/getIntegrationOfAttachedProtons.js +0 -0
- /package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/getWorkFlow.js +0 -0
- /package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/isSpectraData1D.js +0 -0
- /package/lib-esm/assignment/utils/{getAssignment → generalAssignment}/searchIndices.js +0 -0
- /package/src/assignment/utils/{getAssignment → generalAssignment}/getIntegrationOfAttachedProtons.ts +0 -0
- /package/src/assignment/utils/{getAssignment → generalAssignment}/isSpectraData1D.ts +0 -0
- /package/src/assignment/utils/{getAssignment → generalAssignment}/searchIndices.ts +0 -0
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { DoubleArray } from 'cheminfo-types';
|
|
2
2
|
import Matrix from 'ml-matrix';
|
|
3
3
|
import {
|
|
4
|
+
DataReIm,
|
|
4
5
|
reimAbsolute,
|
|
5
|
-
reimAutoPhaseCorrection,
|
|
6
6
|
reimFFT,
|
|
7
7
|
reimPhaseCorrection,
|
|
8
|
+
xMultiply,
|
|
8
9
|
} from 'ml-spectra-processing';
|
|
9
10
|
|
|
10
11
|
import {
|
|
@@ -22,6 +23,7 @@ interface PhaseCorrection {
|
|
|
22
23
|
|
|
23
24
|
export interface IndirectDimensionOptions {
|
|
24
25
|
fnMode?: string;
|
|
26
|
+
reverse?: boolean;
|
|
25
27
|
zeroFilling?: ZeroFillingOptions;
|
|
26
28
|
apodization?: ApodizationFilterOptions;
|
|
27
29
|
phaseCorrection?: PhaseCorrection;
|
|
@@ -31,93 +33,141 @@ export function fftIndirectDimension(
|
|
|
31
33
|
data: { re: DoubleArray[] | Matrix; im: DoubleArray[] | Matrix },
|
|
32
34
|
options: IndirectDimensionOptions,
|
|
33
35
|
) {
|
|
34
|
-
const
|
|
35
|
-
|
|
36
|
+
const newData: Record<string, Matrix> = {
|
|
37
|
+
re: Matrix.checkMatrix(data.re),
|
|
38
|
+
im: Matrix.checkMatrix(data.im),
|
|
39
|
+
};
|
|
36
40
|
|
|
37
|
-
const nbRows =
|
|
38
|
-
const nbColumns =
|
|
41
|
+
const nbRows = newData.re.rows;
|
|
42
|
+
const nbColumns = newData.re.columns;
|
|
39
43
|
|
|
40
|
-
const { zeroFilling: zeroFillingF1 } = options;
|
|
44
|
+
const { zeroFilling: zeroFillingF1, reverse } = options;
|
|
41
45
|
const { factor: f1Factor = 2 } = zeroFillingF1 || {};
|
|
42
|
-
|
|
46
|
+
|
|
47
|
+
const nbPoints =
|
|
43
48
|
zeroFillingF1?.nbPoints || 2 ** Math.round(Math.log2(nbRows * f1Factor));
|
|
44
|
-
const {
|
|
45
|
-
let {
|
|
46
|
-
ph0: ph0F1,
|
|
47
|
-
ph1: ph1F1,
|
|
48
|
-
mode: pcModeF1,
|
|
49
|
-
} = options.phaseCorrection || {};
|
|
50
|
-
|
|
51
|
-
const reResult = new Matrix(nbPointsF1, nbColumns);
|
|
52
|
-
const imResult = new Matrix(nbPointsF1, nbColumns);
|
|
53
|
-
for (let i = 0; i < nbColumns; i++) {
|
|
54
|
-
const { re: aRe, im: aIm } = apodization(
|
|
55
|
-
{
|
|
56
|
-
re: reData.getColumn(i),
|
|
57
|
-
im: imData.getColumn(i),
|
|
58
|
-
},
|
|
59
|
-
apodizationF1,
|
|
60
|
-
);
|
|
49
|
+
const { fnMode } = options;
|
|
61
50
|
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
51
|
+
const newOptions: IndirectDimensionOptions = {
|
|
52
|
+
...options,
|
|
53
|
+
zeroFilling: { ...zeroFillingF1, nbPoints },
|
|
54
|
+
};
|
|
55
|
+
const quadrants: Record<string, Matrix> = {};
|
|
56
|
+
if (fnMode === 'QF') {
|
|
57
|
+
const reResult = new Matrix(nbPoints, nbColumns);
|
|
58
|
+
const imResult = new Matrix(nbPoints, nbColumns);
|
|
59
|
+
for (let i = 0; i < nbColumns; i++) {
|
|
60
|
+
const data = {
|
|
61
|
+
re: newData.re.getColumn(i),
|
|
62
|
+
im: reverse
|
|
63
|
+
? newData.im.getColumn(i)
|
|
64
|
+
: xMultiply(newData.im.getColumn(i), -1),
|
|
65
|
+
};
|
|
66
|
+
const { re, im } = applyFFT(data, newOptions);
|
|
67
|
+
reResult.setColumn(i, re);
|
|
68
|
+
imResult.setColumn(i, im);
|
|
69
|
+
}
|
|
70
|
+
quadrants.rr = reResult;
|
|
71
|
+
quadrants.ir = imResult;
|
|
72
|
+
} else {
|
|
73
|
+
// four quadrant processing
|
|
74
|
+
for (const current in newData) {
|
|
75
|
+
const reResult = new Matrix(nbPoints, nbColumns);
|
|
76
|
+
const imResult = new Matrix(nbPoints, nbColumns);
|
|
77
|
+
for (let i = 0; i < nbColumns; i++) {
|
|
78
|
+
const data = getColumnFrom(newData[current], { fnMode, index: i });
|
|
79
|
+
const { re, im } = applyFFT(data, newOptions);
|
|
80
|
+
reResult.setColumn(i, re);
|
|
81
|
+
imResult.setColumn(i, im);
|
|
68
82
|
}
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
83
|
+
if (current === 're') {
|
|
84
|
+
quadrants.rr = reResult;
|
|
85
|
+
quadrants.ir = imResult;
|
|
86
|
+
} else {
|
|
87
|
+
quadrants.ri = reResult;
|
|
88
|
+
quadrants.ii = imResult;
|
|
73
89
|
}
|
|
74
90
|
}
|
|
91
|
+
}
|
|
92
|
+
return quadrants;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
function applyFFT(data: DataReIm, options: IndirectDimensionOptions) {
|
|
96
|
+
const {
|
|
97
|
+
fnMode,
|
|
98
|
+
apodization: apodizationF1,
|
|
99
|
+
zeroFilling: zeroFillingF1 = {},
|
|
100
|
+
phaseCorrection = {},
|
|
101
|
+
} = options;
|
|
102
|
+
|
|
103
|
+
const { re, im } = apodization(data, apodizationF1);
|
|
75
104
|
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
105
|
+
const { nbPoints = 0 } = zeroFillingF1;
|
|
106
|
+
const transformed = reimFFT(zeroFilling({ re, im }, { nbPoints }), {
|
|
107
|
+
applyZeroShift: !['SEQ', 'TPPI'].some((k) => fnMode === k),
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
if (options.phaseCorrection?.mode === 'mc') {
|
|
111
|
+
Object.assign(transformed, {
|
|
112
|
+
re: reimAbsolute(transformed),
|
|
113
|
+
im: new Float64Array(nbPoints),
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
const { mode: pcModeF1, ph0: ph0F1, ph1: ph1F1 } = phaseCorrection;
|
|
118
|
+
if (pcModeF1 === 'pk' && ph0F1 !== undefined && ph1F1 !== undefined) {
|
|
119
|
+
Object.assign(
|
|
120
|
+
transformed,
|
|
121
|
+
reimPhaseCorrection(
|
|
122
|
+
transformed,
|
|
123
|
+
(ph0F1 * Math.PI) / 180,
|
|
124
|
+
(ph1F1 * Math.PI) / 180,
|
|
83
125
|
),
|
|
84
|
-
{ applyZeroShift: true },
|
|
85
126
|
);
|
|
86
|
-
|
|
127
|
+
}
|
|
128
|
+
return transformed;
|
|
129
|
+
}
|
|
87
130
|
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
131
|
+
function getColumnFrom(
|
|
132
|
+
data: Matrix,
|
|
133
|
+
info: { fnMode?: string; reverse?: boolean; index: number },
|
|
134
|
+
) {
|
|
135
|
+
const { fnMode, index } = info;
|
|
136
|
+
const reverse = info.reverse || fnMode === 'QF';
|
|
137
|
+
const nbPoints = data.rows / 2;
|
|
138
|
+
const re = new Float64Array(nbPoints);
|
|
139
|
+
const im = new Float64Array(nbPoints);
|
|
92
140
|
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
)
|
|
100
|
-
|
|
101
|
-
|
|
141
|
+
switch (fnMode?.toLocaleLowerCase()) {
|
|
142
|
+
// case 'states':
|
|
143
|
+
// case 'echo-antiecho':
|
|
144
|
+
case 'seq':
|
|
145
|
+
case 'tppi':
|
|
146
|
+
return {
|
|
147
|
+
re: data.getColumn(index),
|
|
148
|
+
im: new Float64Array(data.rows),
|
|
149
|
+
};
|
|
150
|
+
default:
|
|
151
|
+
if (reverse) {
|
|
152
|
+
for (let i = 0; i < nbPoints; i++) {
|
|
153
|
+
re[i] = data.get(2 * i, index);
|
|
154
|
+
im[i] = -data.get(2 * i + 1, index);
|
|
155
|
+
}
|
|
156
|
+
} else {
|
|
157
|
+
for (let i = 0; i < nbPoints; i++) {
|
|
158
|
+
re[i] = data.get(2 * i, index);
|
|
159
|
+
im[i] = data.get(2 * i + 1, index);
|
|
160
|
+
}
|
|
102
161
|
}
|
|
103
|
-
|
|
104
|
-
Object.assign(
|
|
105
|
-
transformed,
|
|
106
|
-
reimPhaseCorrection(
|
|
107
|
-
transformed,
|
|
108
|
-
(ph0F1 * Math.PI) / 180,
|
|
109
|
-
(ph1F1 * Math.PI) / 180,
|
|
110
|
-
),
|
|
111
|
-
);
|
|
112
|
-
}
|
|
113
|
-
}
|
|
162
|
+
}
|
|
114
163
|
|
|
115
|
-
|
|
116
|
-
|
|
164
|
+
if (fnMode === 'states-ttpi') {
|
|
165
|
+
//it is to convert to the equivalent of states
|
|
166
|
+
for (let i = 0; i < nbPoints; i += 2) {
|
|
167
|
+
re[i] *= -1;
|
|
168
|
+
im[i] *= -1;
|
|
169
|
+
}
|
|
117
170
|
}
|
|
118
171
|
|
|
119
|
-
return {
|
|
120
|
-
re: reResult,
|
|
121
|
-
im: imResult,
|
|
122
|
-
};
|
|
172
|
+
return { re, im };
|
|
123
173
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { DataReIm, xMean } from 'ml-spectra-processing';
|
|
2
2
|
|
|
3
3
|
export function removeDCOffset(data: DataReIm, options: any) {
|
|
4
|
-
|
|
4
|
+
const { digitalFilterValue = 0 } = options;
|
|
5
5
|
const nbPoints = data.re.length;
|
|
6
6
|
const newRe = new Float64Array(data.re);
|
|
7
7
|
const newIm = new Float64Array(data.im);
|
|
@@ -7,11 +7,10 @@ export interface ZeroFillingOptions {
|
|
|
7
7
|
}
|
|
8
8
|
|
|
9
9
|
export function zeroFilling(data: DataReIm, options: ZeroFillingOptions) {
|
|
10
|
-
|
|
10
|
+
const { factor = 2, digitalFilterValue: grpdly = 0 } = options;
|
|
11
11
|
|
|
12
|
-
|
|
13
|
-
nbPoints
|
|
14
|
-
}
|
|
12
|
+
const nbPoints =
|
|
13
|
+
options.nbPoints || 2 ** Math.round(Math.log2(data.re.length * factor));
|
|
15
14
|
|
|
16
15
|
let pointsToShift;
|
|
17
16
|
if (grpdly > 0) {
|
|
@@ -22,8 +21,8 @@ export function zeroFilling(data: DataReIm, options: ZeroFillingOptions) {
|
|
|
22
21
|
|
|
23
22
|
const { re, im } = data;
|
|
24
23
|
|
|
25
|
-
|
|
26
|
-
|
|
24
|
+
const newRE = new Float64Array(nbPoints);
|
|
25
|
+
const newIM = new Float64Array(nbPoints);
|
|
27
26
|
|
|
28
27
|
const length = Math.min(nbPoints, re.length);
|
|
29
28
|
|
|
@@ -4,10 +4,10 @@ import { NMRSignal2DWithID } from '../xyzAutoSignalsPicking';
|
|
|
4
4
|
import { NMRZoneWithID } from '../xyzAutoZonesPicking';
|
|
5
5
|
|
|
6
6
|
export function formatZones(signals: NMRSignal2DWithID[]) {
|
|
7
|
-
|
|
7
|
+
const zones: NMRZoneWithID[] = [];
|
|
8
8
|
for (const signal of signals) {
|
|
9
|
-
|
|
10
|
-
|
|
9
|
+
const minMax1 = [Number.MAX_VALUE, 0];
|
|
10
|
+
const minMax2 = [Number.MAX_VALUE, 0];
|
|
11
11
|
for (const peak of signal.peaks || []) {
|
|
12
12
|
if (peak.minX < minMax1[0]) {
|
|
13
13
|
minMax1[0] = peak.minX;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
export function getMinMaxXY(info: Record<string, any>) {
|
|
2
|
+
const min: number[] = [];
|
|
3
|
+
const max: number[] = [];
|
|
4
|
+
for (let i = 0; i < info.baseFrequency.length; i++) {
|
|
5
|
+
const baseFrequency = info.baseFrequency[i];
|
|
6
|
+
const frequencyOffset = info.frequencyOffset[i];
|
|
7
|
+
const spectralWidth = info.spectralWidth[i];
|
|
8
|
+
const offset = frequencyOffset / baseFrequency;
|
|
9
|
+
min.push(offset - spectralWidth * 0.5);
|
|
10
|
+
max.push(offset + spectralWidth * 0.5);
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
return {
|
|
14
|
+
minX: min[0],
|
|
15
|
+
maxX: max[0],
|
|
16
|
+
minY: min[1],
|
|
17
|
+
maxY: max[1],
|
|
18
|
+
};
|
|
19
|
+
}
|
package/src/xyz/util/padData.ts
CHANGED
|
@@ -4,23 +4,23 @@ export function padData(
|
|
|
4
4
|
spectraData: NmrData2DContent,
|
|
5
5
|
options: { width: number },
|
|
6
6
|
) {
|
|
7
|
-
|
|
7
|
+
const { minX, maxX, minY, maxY } = spectraData;
|
|
8
8
|
|
|
9
9
|
const width = options.width;
|
|
10
10
|
|
|
11
|
-
|
|
12
|
-
|
|
11
|
+
const nbPoints = spectraData.z[0].length;
|
|
12
|
+
const nbSubSpectra = spectraData.z.length;
|
|
13
13
|
|
|
14
|
-
|
|
15
|
-
|
|
14
|
+
const yInterval = (maxY - minY) / (nbSubSpectra - 1);
|
|
15
|
+
const xInterval = (maxX - minX) / (nbPoints - 1);
|
|
16
16
|
|
|
17
17
|
let yDiff = width - nbSubSpectra;
|
|
18
18
|
let xDiff = Math.max(width - nbPoints, 0);
|
|
19
19
|
if (xDiff % 2) xDiff++;
|
|
20
20
|
if (yDiff % 2) yDiff++;
|
|
21
21
|
|
|
22
|
-
|
|
23
|
-
|
|
22
|
+
const xOffset = xDiff / 2;
|
|
23
|
+
const yOffset = yDiff / 2;
|
|
24
24
|
|
|
25
25
|
const newMatrix: Float64Array[] = [];
|
|
26
26
|
for (let i = 0; i < nbSubSpectra + yDiff; i++) {
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { NmrData2DFt } from 'cheminfo-types';
|
|
2
|
+
import { PhaseCorrectionOptions } from '../../xyzPhaseCorrectionDirectDimension';
|
|
3
|
+
import { getZMinMax } from './getZMinMax';
|
|
4
|
+
import Matrix from 'ml-matrix';
|
|
5
|
+
import { checkNmrData2DFourQuad } from './checkNmrData2DFourQuad';
|
|
6
|
+
|
|
7
|
+
export function applyOverImag<T extends NmrData2DFt>(
|
|
8
|
+
data: T,
|
|
9
|
+
options: PhaseCorrectionOptions,
|
|
10
|
+
) {
|
|
11
|
+
checkNmrData2DFourQuad(data);
|
|
12
|
+
const { applyPhaseCorrection } = options;
|
|
13
|
+
const { re, im } = applyPhaseCorrection(
|
|
14
|
+
{ re: Matrix.checkMatrix(data.ri.z), im: Matrix.checkMatrix(data.ii.z) },
|
|
15
|
+
options,
|
|
16
|
+
);
|
|
17
|
+
|
|
18
|
+
return {
|
|
19
|
+
...data,
|
|
20
|
+
ri: {
|
|
21
|
+
...data.ri,
|
|
22
|
+
...getZMinMax(re),
|
|
23
|
+
},
|
|
24
|
+
ii: {
|
|
25
|
+
...data.ii,
|
|
26
|
+
...getZMinMax(im),
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { NmrData2DFt } from 'cheminfo-types';
|
|
2
|
+
import { checkNmrData2DTwoQuad } from './checkNmrData2DTwoQuad';
|
|
3
|
+
import Matrix from 'ml-matrix';
|
|
4
|
+
import { getZMinMax } from './getZMinMax';
|
|
5
|
+
import { PhaseCorrectionOptions } from '../../xyzPhaseCorrectionDirectDimension';
|
|
6
|
+
|
|
7
|
+
export function applyOverReal<T extends NmrData2DFt>(
|
|
8
|
+
data: T,
|
|
9
|
+
options: PhaseCorrectionOptions,
|
|
10
|
+
) {
|
|
11
|
+
const { applyPhaseCorrection } = options;
|
|
12
|
+
checkNmrData2DTwoQuad(data);
|
|
13
|
+
const { re, im } = applyPhaseCorrection(
|
|
14
|
+
{ re: Matrix.checkMatrix(data.rr.z), im: Matrix.checkMatrix(data.ir.z) },
|
|
15
|
+
options,
|
|
16
|
+
);
|
|
17
|
+
|
|
18
|
+
return {
|
|
19
|
+
...data,
|
|
20
|
+
rr: {
|
|
21
|
+
...data.rr,
|
|
22
|
+
...getZMinMax(re),
|
|
23
|
+
},
|
|
24
|
+
ir: {
|
|
25
|
+
...data.ir,
|
|
26
|
+
...getZMinMax(im),
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { NmrData2DFt } from 'cheminfo-types';
|
|
2
|
+
|
|
3
|
+
export type NmrData2DFourQuadrant = Required<
|
|
4
|
+
Pick<NmrData2DFt, 'rr' | 'ir' | 'ri' | 'ii'>
|
|
5
|
+
>;
|
|
6
|
+
export function checkNmrData2DFourQuad(
|
|
7
|
+
data: NmrData2DFt,
|
|
8
|
+
): asserts data is NmrData2DFourQuadrant {
|
|
9
|
+
if (!('ir' in data)) {
|
|
10
|
+
throw new Error('four quadrants should has ir, ri and ii quadrants');
|
|
11
|
+
}
|
|
12
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { NmrData2DFt } from 'cheminfo-types';
|
|
2
|
+
|
|
3
|
+
export type NmrData2DTwoQuadrant = Required<Pick<NmrData2DFt, 'rr' | 'ir'>>;
|
|
4
|
+
|
|
5
|
+
export function checkNmrData2DTwoQuad(
|
|
6
|
+
data: NmrData2DFt,
|
|
7
|
+
): asserts data is NmrData2DTwoQuadrant {
|
|
8
|
+
if (!('ir' in data)) {
|
|
9
|
+
throw new Error('Two quadrants should has ir quadrant');
|
|
10
|
+
}
|
|
11
|
+
}
|
|
@@ -92,10 +92,9 @@ export function xyzAutoSignalsPicking(
|
|
|
92
92
|
spectraData: NmrData2DContent,
|
|
93
93
|
options: XYZAutoSignalsPickingOptions,
|
|
94
94
|
) {
|
|
95
|
-
|
|
95
|
+
const {
|
|
96
96
|
sizeToPad = 14,
|
|
97
97
|
realTopDetection = true,
|
|
98
|
-
thresholdFactor = 0.5,
|
|
99
98
|
nuclei = ['1H', '1H'],
|
|
100
99
|
observedFrequencies,
|
|
101
100
|
enhanceSymmetry = false,
|
|
@@ -106,6 +105,8 @@ export function xyzAutoSignalsPicking(
|
|
|
106
105
|
kernel: kernelOptions,
|
|
107
106
|
} = options;
|
|
108
107
|
|
|
108
|
+
let { thresholdFactor = 0.5 } = options;
|
|
109
|
+
|
|
109
110
|
if (
|
|
110
111
|
!Array.isArray(observedFrequencies) &&
|
|
111
112
|
!ArrayBuffer.isView(observedFrequencies)
|
|
@@ -124,13 +125,13 @@ export function xyzAutoSignalsPicking(
|
|
|
124
125
|
nbSubSpectra = spectraData.z.length;
|
|
125
126
|
}
|
|
126
127
|
|
|
127
|
-
|
|
128
|
-
|
|
128
|
+
const absoluteData = new Float64Array(nbPoints * nbSubSpectra);
|
|
129
|
+
const originalData = new Float64Array(nbPoints * nbSubSpectra);
|
|
129
130
|
|
|
130
131
|
for (let iSubSpectra = 0; iSubSpectra < nbSubSpectra; iSubSpectra++) {
|
|
131
|
-
|
|
132
|
+
const spectrum = spectraData.z[iSubSpectra];
|
|
132
133
|
for (let iCol = 0; iCol < nbPoints; iCol++) {
|
|
133
|
-
|
|
134
|
+
const index = iSubSpectra * nbPoints + iCol;
|
|
134
135
|
absoluteData[index] = Math.abs(spectrum[iCol]);
|
|
135
136
|
originalData[index] = spectrum[iCol]; //@todo pensar si se puede evitar originalData
|
|
136
137
|
}
|
|
@@ -138,7 +139,7 @@ export function xyzAutoSignalsPicking(
|
|
|
138
139
|
|
|
139
140
|
const kernel = kernelOptions ? getKernel(kernelOptions) : smallFilter;
|
|
140
141
|
|
|
141
|
-
|
|
142
|
+
const convolutedSpectrum = convolutionByFFT
|
|
142
143
|
? convolution.fft(absoluteData, kernel, {
|
|
143
144
|
rows: nbSubSpectra,
|
|
144
145
|
cols: nbPoints,
|
|
@@ -208,7 +209,7 @@ function createSignals2D<T extends Peak2D>(
|
|
|
208
209
|
peaks: T[],
|
|
209
210
|
options: CreateSignals2DOptions,
|
|
210
211
|
) {
|
|
211
|
-
|
|
212
|
+
const {
|
|
212
213
|
nCols,
|
|
213
214
|
nRows,
|
|
214
215
|
absoluteData,
|
|
@@ -223,12 +224,12 @@ function createSignals2D<T extends Peak2D>(
|
|
|
223
224
|
maxX,
|
|
224
225
|
} = options;
|
|
225
226
|
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
227
|
+
const [nucleusX, nucleusY] = nuclei;
|
|
228
|
+
const [toleranceX, toleranceY] = tolerances;
|
|
229
|
+
const [observeFrequencyX, observeFrequencyY] = observedFrequencies;
|
|
229
230
|
|
|
230
|
-
|
|
231
|
-
|
|
231
|
+
const dy = (maxY - minY) / (nRows - 1);
|
|
232
|
+
const dx = (maxX - minX) / (nCols - 1);
|
|
232
233
|
|
|
233
234
|
if (realTopDetection) {
|
|
234
235
|
peaks = determineRealTop(peaks, {
|
|
@@ -243,7 +244,7 @@ function createSignals2D<T extends Peak2D>(
|
|
|
243
244
|
}
|
|
244
245
|
|
|
245
246
|
for (let i = peaks.length - 1; i >= 0; i--) {
|
|
246
|
-
|
|
247
|
+
const { x, y } = peaks[i];
|
|
247
248
|
peaks[i].x = minX + dx * x;
|
|
248
249
|
peaks[i].y = minY + dy * y;
|
|
249
250
|
peaks[i].minX = minX + dx * peaks[i].minX;
|
|
@@ -255,7 +256,7 @@ function createSignals2D<T extends Peak2D>(
|
|
|
255
256
|
}
|
|
256
257
|
// The connectivity matrix is an square and symmetric matrix, so we'll only store the upper diagonal in an
|
|
257
258
|
// array like form
|
|
258
|
-
|
|
259
|
+
const connectivity = [];
|
|
259
260
|
for (let i = 0; i < peaks.length; i++) {
|
|
260
261
|
for (let j = i; j < peaks.length; j++) {
|
|
261
262
|
if (
|
|
@@ -269,12 +270,12 @@ function createSignals2D<T extends Peak2D>(
|
|
|
269
270
|
}
|
|
270
271
|
}
|
|
271
272
|
}
|
|
272
|
-
|
|
273
|
+
const clusters = simpleClustering(connectivity);
|
|
273
274
|
|
|
274
|
-
|
|
275
|
+
const signals: Array<NMRSignal2DWithID<T>> = [];
|
|
275
276
|
if (clusters) {
|
|
276
277
|
for (const cluster of clusters) {
|
|
277
|
-
|
|
278
|
+
const signal: any = {
|
|
278
279
|
id: generateID(),
|
|
279
280
|
x: {
|
|
280
281
|
delta: 0,
|
|
@@ -287,7 +288,7 @@ function createSignals2D<T extends Peak2D>(
|
|
|
287
288
|
resolution: dy,
|
|
288
289
|
},
|
|
289
290
|
};
|
|
290
|
-
|
|
291
|
+
const peaks2D: T[] = [];
|
|
291
292
|
let sumZ = 0;
|
|
292
293
|
|
|
293
294
|
for (let jPeak = 0; jPeak < cluster.length; jPeak++) {
|
|
@@ -13,6 +13,7 @@ import {
|
|
|
13
13
|
IndirectDimensionOptions,
|
|
14
14
|
} from './util/fft2d/fftIndirectDimension';
|
|
15
15
|
import { ZeroFillingOptions } from './util/fft2d/zeroFilling';
|
|
16
|
+
import { getMinMaxXY } from './util/getMinMaxXY';
|
|
16
17
|
|
|
17
18
|
type Info2D = any;
|
|
18
19
|
|
|
@@ -100,23 +101,3 @@ function convertToDoubleArray(data: Matrix) {
|
|
|
100
101
|
}
|
|
101
102
|
return result;
|
|
102
103
|
}
|
|
103
|
-
|
|
104
|
-
function getMinMaxXY(info: Info2D) {
|
|
105
|
-
const min: number[] = [];
|
|
106
|
-
const max: number[] = [];
|
|
107
|
-
for (let i = 0; i < info.baseFrequency.length; i++) {
|
|
108
|
-
const baseFrequency = Number.parseFloat(info.baseFrequency[i]);
|
|
109
|
-
const frequencyOffset = Number.parseFloat(info.frequencyOffset[i]);
|
|
110
|
-
const spectralWidth = Number.parseFloat(info.spectralWidth[i]);
|
|
111
|
-
const offset = frequencyOffset / baseFrequency;
|
|
112
|
-
min.push(offset - spectralWidth * 0.5);
|
|
113
|
-
max.push(offset + spectralWidth * 0.5);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
return {
|
|
117
|
-
minX: min[0],
|
|
118
|
-
maxX: max[0],
|
|
119
|
-
minY: min[1],
|
|
120
|
-
maxY: max[1],
|
|
121
|
-
};
|
|
122
|
-
}
|