nmr-processing 9.5.0 → 9.5.1-pre.1684857934

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.
Files changed (241) hide show
  1. package/lib/apodization/apodization.d.ts +9 -4
  2. package/lib/apodization/apodization.js +3 -1
  3. package/lib/apodization/apodization.js.map +1 -1
  4. package/lib/apodization/applyWindow.js.map +1 -1
  5. package/lib/apodization/compose.js.map +1 -1
  6. package/lib/apodization/getFunction.js +3 -0
  7. package/lib/apodization/getFunction.js.map +1 -1
  8. package/lib/apodization/shapes/WindowFunctions.d.ts +6 -1
  9. package/lib/apodization/shapes/sineBell.d.ts +27 -0
  10. package/lib/apodization/shapes/sineBell.js +17 -0
  11. package/lib/apodization/shapes/sineBell.js.map +1 -0
  12. package/lib/apodization/utils/getData.js.map +1 -1
  13. package/lib/filters/Data1D.d.ts +6 -0
  14. package/lib/{xyz/Data2D.js → filters/Data1D.js} +1 -1
  15. package/lib/filters/Data1D.js.map +1 -0
  16. package/lib/filters/Entry1D.d.ts +10 -0
  17. package/lib/filters/Entry1D.js +3 -0
  18. package/lib/filters/Entry1D.js.map +1 -0
  19. package/lib/filters/ExclusionZone.d.ts +5 -0
  20. package/lib/filters/ExclusionZone.js +3 -0
  21. package/lib/filters/ExclusionZone.js.map +1 -0
  22. package/lib/filters/Filters.d.ts +7 -0
  23. package/lib/filters/Filters.js +47 -0
  24. package/lib/filters/Filters.js.map +1 -0
  25. package/lib/filters/FiltersManager.d.ts +23 -0
  26. package/lib/filters/FiltersManager.js +130 -0
  27. package/lib/filters/FiltersManager.js.map +1 -0
  28. package/lib/filters/MatrixFilter.d.ts +39 -0
  29. package/lib/filters/MatrixFilter.js +3 -0
  30. package/lib/filters/MatrixFilter.js.map +1 -0
  31. package/lib/filters/MatrixOptions.d.ts +28 -0
  32. package/lib/filters/MatrixOptions.js +3 -0
  33. package/lib/filters/MatrixOptions.js.map +1 -0
  34. package/lib/filters/filter1d/apodization.d.ts +26 -0
  35. package/lib/filters/filter1d/apodization.js +77 -0
  36. package/lib/filters/filter1d/apodization.js.map +1 -0
  37. package/lib/filters/filter1d/baselineCorrection.d.ts +32 -0
  38. package/lib/filters/filter1d/baselineCorrection.js +61 -0
  39. package/lib/filters/filter1d/baselineCorrection.js.map +1 -0
  40. package/lib/filters/filter1d/digitalFilter.d.ts +15 -0
  41. package/lib/filters/filter1d/digitalFilter.js +47 -0
  42. package/lib/filters/filter1d/digitalFilter.js.map +1 -0
  43. package/lib/filters/filter1d/equallySpaced.d.ts +29 -0
  44. package/lib/filters/filter1d/equallySpaced.js +55 -0
  45. package/lib/filters/filter1d/equallySpaced.js.map +1 -0
  46. package/lib/filters/filter1d/exclusionZones.d.ts +11 -0
  47. package/lib/filters/filter1d/exclusionZones.js +35 -0
  48. package/lib/filters/filter1d/exclusionZones.js.map +1 -0
  49. package/lib/filters/filter1d/fft.d.ts +14 -0
  50. package/lib/filters/filter1d/fft.js +94 -0
  51. package/lib/filters/filter1d/fft.js.map +1 -0
  52. package/lib/filters/filter1d/phaseCorrection.d.ts +26 -0
  53. package/lib/filters/filter1d/phaseCorrection.js +81 -0
  54. package/lib/filters/filter1d/phaseCorrection.js.map +1 -0
  55. package/lib/filters/filter1d/shiftX.d.ts +16 -0
  56. package/lib/filters/filter1d/shiftX.js +30 -0
  57. package/lib/filters/filter1d/shiftX.js.map +1 -0
  58. package/lib/filters/filter1d/signalProcessing.d.ts +17 -0
  59. package/lib/filters/filter1d/signalProcessing.js +88 -0
  60. package/lib/filters/filter1d/signalProcessing.js.map +1 -0
  61. package/lib/filters/filter1d/utils/padDataToNextPowerOfTwo.d.ts +2 -0
  62. package/lib/filters/filter1d/utils/padDataToNextPowerOfTwo.js +41 -0
  63. package/lib/filters/filter1d/utils/padDataToNextPowerOfTwo.js.map +1 -0
  64. package/lib/filters/filter1d/zeroFilling.d.ts +18 -0
  65. package/lib/filters/filter1d/zeroFilling.js +68 -0
  66. package/lib/filters/filter1d/zeroFilling.js.map +1 -0
  67. package/lib/filters/filter2d/shiftX.d.ts +14 -0
  68. package/lib/filters/filter2d/shiftX.js +30 -0
  69. package/lib/filters/filter2d/shiftX.js.map +1 -0
  70. package/lib/filters/filter2d/shiftY.d.ts +14 -0
  71. package/lib/filters/filter2d/shiftY.js +30 -0
  72. package/lib/filters/filter2d/shiftY.js.map +1 -0
  73. package/lib/index.d.ts +2 -0
  74. package/lib/index.js +2 -0
  75. package/lib/index.js.map +1 -1
  76. package/lib/signals/signalsToFID.d.ts +3 -0
  77. package/lib/utilities/checkData2DFid.d.ts +3 -0
  78. package/lib/utilities/checkData2DFid.js +10 -0
  79. package/lib/utilities/checkData2DFid.js.map +1 -0
  80. package/lib/utilities/cloneData1D.d.ts +6 -0
  81. package/lib/utilities/cloneData1D.js +9 -0
  82. package/lib/utilities/cloneData1D.js.map +1 -0
  83. package/lib/utilities/cloneData2D.d.ts +2 -0
  84. package/lib/utilities/cloneData2D.js +28 -0
  85. package/lib/utilities/cloneData2D.js.map +1 -0
  86. package/lib/xyz/Entry2D.d.ts +10 -0
  87. package/lib/xyz/Entry2D.js +3 -0
  88. package/lib/xyz/Entry2D.js.map +1 -0
  89. package/lib/xyz/quadrature.d.ts +7 -0
  90. package/lib/xyz/quadrature.js +54 -0
  91. package/lib/xyz/quadrature.js.map +1 -0
  92. package/lib/xyz/util/fft2d/digitalFilter.d.ts +7 -0
  93. package/lib/xyz/util/fft2d/digitalFilter.js +20 -0
  94. package/lib/xyz/util/fft2d/digitalFilter.js.map +1 -0
  95. package/lib/xyz/util/fft2d/fftDirectDimension.d.ts +24 -0
  96. package/lib/xyz/util/fft2d/fftDirectDimension.js +57 -0
  97. package/lib/xyz/util/fft2d/fftDirectDimension.js.map +1 -0
  98. package/lib/xyz/util/fft2d/fftIndirectDimension.d.ts +23 -0
  99. package/lib/xyz/util/fft2d/fftIndirectDimension.js +72 -0
  100. package/lib/xyz/util/fft2d/fftIndirectDimension.js.map +1 -0
  101. package/lib/xyz/util/fft2d/removeDCOffset.d.ts +5 -0
  102. package/lib/xyz/util/fft2d/removeDCOffset.js +19 -0
  103. package/lib/xyz/util/fft2d/removeDCOffset.js.map +1 -0
  104. package/lib/xyz/util/fft2d/zeroFilling.d.ts +10 -0
  105. package/lib/xyz/util/fft2d/zeroFilling.js +29 -0
  106. package/lib/xyz/util/fft2d/zeroFilling.js.map +1 -0
  107. package/lib/xyz/util/padData.d.ts +5 -3
  108. package/lib/xyz/util/padData.js +7 -7
  109. package/lib/xyz/util/padData.js.map +1 -1
  110. package/lib/xyz/xyzAutoSignalsPicking.d.ts +2 -2
  111. package/lib/xyz/xyzAutoSignalsPicking.js.map +1 -1
  112. package/lib/xyz/xyzAutoZonesPicking.d.ts +2 -8
  113. package/lib/xyz/xyzAutoZonesPicking.js.map +1 -1
  114. package/lib/xyz/xyzBidimensionalFFT.d.ts +40 -0
  115. package/lib/xyz/xyzBidimensionalFFT.js +79 -0
  116. package/lib/xyz/xyzBidimensionalFFT.js.map +1 -0
  117. package/lib-esm/apodization/apodization.js +3 -1
  118. package/lib-esm/apodization/apodization.js.map +1 -1
  119. package/lib-esm/apodization/applyWindow.js.map +1 -1
  120. package/lib-esm/apodization/compose.js.map +1 -1
  121. package/lib-esm/apodization/getFunction.js +3 -0
  122. package/lib-esm/apodization/getFunction.js.map +1 -1
  123. package/lib-esm/apodization/shapes/sineBell.js +13 -0
  124. package/lib-esm/apodization/shapes/sineBell.js.map +1 -0
  125. package/lib-esm/apodization/utils/getData.js.map +1 -1
  126. package/lib-esm/filters/Data1D.js +2 -0
  127. package/lib-esm/filters/Data1D.js.map +1 -0
  128. package/lib-esm/filters/Entry1D.js +2 -0
  129. package/lib-esm/filters/Entry1D.js.map +1 -0
  130. package/lib-esm/filters/ExclusionZone.js +2 -0
  131. package/lib-esm/filters/ExclusionZone.js.map +1 -0
  132. package/lib-esm/filters/Filters.js +21 -0
  133. package/lib-esm/filters/Filters.js.map +1 -0
  134. package/lib-esm/filters/FiltersManager.js +124 -0
  135. package/lib-esm/filters/FiltersManager.js.map +1 -0
  136. package/lib-esm/filters/MatrixFilter.js +2 -0
  137. package/lib-esm/filters/MatrixFilter.js.map +1 -0
  138. package/lib-esm/filters/MatrixOptions.js +2 -0
  139. package/lib-esm/filters/MatrixOptions.js.map +1 -0
  140. package/lib-esm/filters/filter1d/apodization.js +70 -0
  141. package/lib-esm/filters/filter1d/apodization.js.map +1 -0
  142. package/lib-esm/filters/filter1d/baselineCorrection.js +52 -0
  143. package/lib-esm/filters/filter1d/baselineCorrection.js.map +1 -0
  144. package/lib-esm/filters/filter1d/digitalFilter.js +41 -0
  145. package/lib-esm/filters/filter1d/digitalFilter.js.map +1 -0
  146. package/lib-esm/filters/filter1d/equallySpaced.js +49 -0
  147. package/lib-esm/filters/filter1d/equallySpaced.js.map +1 -0
  148. package/lib-esm/filters/filter1d/exclusionZones.js +29 -0
  149. package/lib-esm/filters/filter1d/exclusionZones.js.map +1 -0
  150. package/lib-esm/filters/filter1d/fft.js +88 -0
  151. package/lib-esm/filters/filter1d/fft.js.map +1 -0
  152. package/lib-esm/filters/filter1d/phaseCorrection.js +75 -0
  153. package/lib-esm/filters/filter1d/phaseCorrection.js.map +1 -0
  154. package/lib-esm/filters/filter1d/shiftX.js +24 -0
  155. package/lib-esm/filters/filter1d/shiftX.js.map +1 -0
  156. package/lib-esm/filters/filter1d/signalProcessing.js +58 -0
  157. package/lib-esm/filters/filter1d/signalProcessing.js.map +1 -0
  158. package/lib-esm/filters/filter1d/utils/padDataToNextPowerOfTwo.js +37 -0
  159. package/lib-esm/filters/filter1d/utils/padDataToNextPowerOfTwo.js.map +1 -0
  160. package/lib-esm/filters/filter1d/zeroFilling.js +62 -0
  161. package/lib-esm/filters/filter1d/zeroFilling.js.map +1 -0
  162. package/lib-esm/filters/filter2d/shiftX.js +24 -0
  163. package/lib-esm/filters/filter2d/shiftX.js.map +1 -0
  164. package/lib-esm/filters/filter2d/shiftY.js +24 -0
  165. package/lib-esm/filters/filter2d/shiftY.js.map +1 -0
  166. package/lib-esm/index.js +2 -0
  167. package/lib-esm/index.js.map +1 -1
  168. package/lib-esm/utilities/checkData2DFid.js +6 -0
  169. package/lib-esm/utilities/checkData2DFid.js.map +1 -0
  170. package/lib-esm/utilities/cloneData1D.js +5 -0
  171. package/lib-esm/utilities/cloneData1D.js.map +1 -0
  172. package/lib-esm/utilities/cloneData2D.js +24 -0
  173. package/lib-esm/utilities/cloneData2D.js.map +1 -0
  174. package/lib-esm/xyz/Entry2D.js +2 -0
  175. package/lib-esm/xyz/Entry2D.js.map +1 -0
  176. package/lib-esm/xyz/quadrature.js +50 -0
  177. package/lib-esm/xyz/quadrature.js.map +1 -0
  178. package/lib-esm/xyz/util/fft2d/digitalFilter.js +16 -0
  179. package/lib-esm/xyz/util/fft2d/digitalFilter.js.map +1 -0
  180. package/lib-esm/xyz/util/fft2d/fftDirectDimension.js +50 -0
  181. package/lib-esm/xyz/util/fft2d/fftDirectDimension.js.map +1 -0
  182. package/lib-esm/xyz/util/fft2d/fftIndirectDimension.js +65 -0
  183. package/lib-esm/xyz/util/fft2d/fftIndirectDimension.js.map +1 -0
  184. package/lib-esm/xyz/util/fft2d/removeDCOffset.js +15 -0
  185. package/lib-esm/xyz/util/fft2d/removeDCOffset.js.map +1 -0
  186. package/lib-esm/xyz/util/fft2d/zeroFilling.js +25 -0
  187. package/lib-esm/xyz/util/fft2d/zeroFilling.js.map +1 -0
  188. package/lib-esm/xyz/util/padData.js +7 -4
  189. package/lib-esm/xyz/util/padData.js.map +1 -1
  190. package/lib-esm/xyz/xyzAutoSignalsPicking.js.map +1 -1
  191. package/lib-esm/xyz/xyzAutoZonesPicking.js.map +1 -1
  192. package/lib-esm/xyz/xyzBidimensionalFFT.js +75 -0
  193. package/lib-esm/xyz/xyzBidimensionalFFT.js.map +1 -0
  194. package/package.json +7 -2
  195. package/src/apodization/apodization.ts +6 -4
  196. package/src/apodization/applyWindow.ts +0 -1
  197. package/src/apodization/compose.ts +1 -0
  198. package/src/apodization/getFunction.ts +3 -0
  199. package/src/apodization/shapes/WindowFunctions.ts +7 -1
  200. package/src/apodization/shapes/sineBell.ts +41 -0
  201. package/src/apodization/utils/getData.ts +0 -1
  202. package/src/filters/Data1D.ts +7 -0
  203. package/src/filters/Entry1D.ts +11 -0
  204. package/src/filters/ExclusionZone.ts +5 -0
  205. package/src/filters/Filters.ts +24 -0
  206. package/src/filters/FiltersManager.ts +176 -0
  207. package/src/filters/MatrixFilter.ts +58 -0
  208. package/src/filters/MatrixOptions.ts +26 -0
  209. package/src/filters/filter1d/apodization.ts +90 -0
  210. package/src/filters/filter1d/baselineCorrection.ts +83 -0
  211. package/src/filters/filter1d/digitalFilter.ts +51 -0
  212. package/src/filters/filter1d/equallySpaced.ts +61 -0
  213. package/src/filters/filter1d/exclusionZones.ts +34 -0
  214. package/src/filters/filter1d/fft.ts +135 -0
  215. package/src/filters/filter1d/phaseCorrection.ts +118 -0
  216. package/src/filters/filter1d/shiftX.ts +31 -0
  217. package/src/filters/filter1d/signalProcessing.ts +79 -0
  218. package/src/filters/filter1d/utils/padDataToNextPowerOfTwo.ts +48 -0
  219. package/src/filters/filter1d/zeroFilling.ts +90 -0
  220. package/src/filters/filter2d/shiftX.ts +31 -0
  221. package/src/filters/filter2d/shiftY.ts +29 -0
  222. package/src/index.ts +3 -0
  223. package/src/utilities/checkData2DFid.ts +10 -0
  224. package/src/utilities/cloneData1D.ts +6 -0
  225. package/src/utilities/cloneData2D.ts +27 -0
  226. package/src/xyz/Entry2D.ts +12 -0
  227. package/src/xyz/quadrature.ts +68 -0
  228. package/src/xyz/util/fft2d/digitalFilter.ts +24 -0
  229. package/src/xyz/util/fft2d/fftDirectDimension.ts +111 -0
  230. package/src/xyz/util/fft2d/fftIndirectDimension.ts +123 -0
  231. package/src/xyz/util/fft2d/removeDCOffset.ts +19 -0
  232. package/src/xyz/util/fft2d/zeroFilling.ts +39 -0
  233. package/src/xyz/util/padData.ts +13 -7
  234. package/src/xyz/xyzAutoSignalsPicking.ts +2 -2
  235. package/src/xyz/xyzAutoZonesPicking.ts +3 -9
  236. package/src/xyz/xyzBidimensionalFFT.ts +122 -0
  237. package/lib/xyz/Data2D.d.ts +0 -7
  238. package/lib/xyz/Data2D.js.map +0 -1
  239. package/lib-esm/xyz/Data2D.js +0 -2
  240. package/lib-esm/xyz/Data2D.js.map +0 -1
  241. package/src/xyz/Data2D.ts +0 -7
@@ -1 +1 @@
1
- {"version":3,"file":"xyzAutoSignalsPicking.js","sourceRoot":"","sources":["../../src/xyz/xyzAutoSignalsPicking.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,IAAI,UAAU,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,KAAK,WAAW,MAAM,uBAAuB,CAAC;AACrD,OAAO,KAAK,iBAAiB,MAAM,wBAAwB,CAAC;AAE5D,OAAO,gBAAgB,MAAM,sBAAsB,CAAC;AAEpD,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAEpD,OAAO,KAAK,aAAa,MAAM,6BAA6B,CAAC;AAK7D,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAEzC,MAAM,WAAW,GAAG;IAClB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC3B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC3B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC3B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IACjC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IACjC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IACjC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC3B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC3B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;CAC5B,CAAC;AA+DF,MAAM,UAAU,qBAAqB,CACnC,WAAmB,EACnB,OAAqC;IAErC,IAAI,EACF,SAAS,GAAG,EAAE,EACd,gBAAgB,GAAG,IAAI,EACvB,eAAe,GAAG,GAAG,EACrB,MAAM,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,EACrB,mBAAmB,EACnB,eAAe,GAAG,KAAK,EACvB,KAAK,GAAG,IAAI,EACZ,gBAAgB,GAAG,IAAI,EACvB,UAAU,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,EACrB,gBAAgB,GAAG,IAAI,EACvB,MAAM,EAAE,aAAa,GACtB,GAAG,OAAO,CAAC;IAEZ,IACE,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,CAAC;QACnC,CAAC,WAAW,CAAC,MAAM,CAAC,mBAAmB,CAAC,EACxC;QACA,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;KACrD;IAED,eAAe,GAAG,eAAe,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAExE,IAAI,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IACvC,IAAI,YAAY,GAAG,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC;IAExC,IAAI,YAAY,GAAG,SAAS,EAAE;QAC5B,WAAW,GAAG,OAAO,CAAC,WAAW,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;QACzD,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;QACnC,YAAY,GAAG,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC;KACrC;IAED,IAAI,YAAY,GAAG,IAAI,YAAY,CAAC,QAAQ,GAAG,YAAY,CAAC,CAAC;IAC7D,IAAI,YAAY,GAAG,IAAI,YAAY,CAAC,QAAQ,GAAG,YAAY,CAAC,CAAC;IAE7D,KAAK,IAAI,WAAW,GAAG,CAAC,EAAE,WAAW,GAAG,YAAY,EAAE,WAAW,EAAE,EAAE;QACnE,IAAI,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;QAC1C,KAAK,IAAI,IAAI,GAAG,CAAC,EAAE,IAAI,GAAG,QAAQ,EAAE,IAAI,EAAE,EAAE;YAC1C,IAAI,KAAK,GAAG,WAAW,GAAG,QAAQ,GAAG,IAAI,CAAC;YAC1C,YAAY,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;YAC/C,YAAY,CAAC,KAAK,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,8CAA8C;SACrF;KACF;IAED,MAAM,MAAM,GAAG,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;IAEtE,IAAI,kBAAkB,GAAG,gBAAgB;QACvC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,YAAY,EAAE,MAAM,EAAE;YACpC,IAAI,EAAE,YAAY;YAClB,IAAI,EAAE,QAAQ;SACf,CAAC;QACJ,CAAC,CAAC,WAAW,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,EAAE;YACvC,IAAI,EAAE,YAAY;YAClB,IAAI,EAAE,QAAQ;SACf,CAAC,CAAC;IAEP,IAAI,QAAQ,GAAG,iBAAiB,CAAC,iBAAiB,CAAC,YAAY,EAAE;QAC/D,YAAY;QACZ,YAAY,EAAE,kBAAkB;QAChC,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,eAAe;KACzB,CAAC,CAAC;IAEH,IAAI,KAAK,EAAE;QACT,sEAAsE;QACtE,QAAQ,GAAG,aAAa,CAAC,KAAK,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;KAC5D;IAED,IAAI,OAAO,GAAG,eAAe,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE;QACrD,KAAK,EAAE,YAAY;QACnB,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,YAAY;QACZ,YAAY;QACZ,UAAU;QACV,MAAM;QACN,mBAAmB;QACnB,gBAAgB;KACjB,CAAC,CAAC;IAEH,IAAI,eAAe,EAAE;QACnB,OAAO,GAAG,aAAa,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;KAClD;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAuBD,SAAS,eAAe,CACtB,KAAU,EACV,OAA+B;IAE/B,IAAI,EACF,KAAK,EACL,KAAK,EACL,YAAY,EACZ,YAAY,EACZ,mBAAmB,EACnB,UAAU,EACV,MAAM,EACN,gBAAgB,EAChB,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,GACL,GAAG,OAAO,CAAC;IAEZ,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,GAAG,MAAM,CAAC;IAClC,IAAI,CAAC,UAAU,EAAE,UAAU,CAAC,GAAG,UAAU,CAAC;IAC1C,IAAI,CAAC,iBAAiB,EAAE,iBAAiB,CAAC,GAAG,mBAAmB,CAAC;IAEjE,IAAI,EAAE,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IACrC,IAAI,EAAE,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IAErC,IAAI,gBAAgB,EAAE;QACpB,KAAK,GAAG,gBAAgB,CAAC,KAAK,EAAE;YAC9B,KAAK;YACL,YAAY;YACZ,YAAY;YACZ,IAAI;YACJ,IAAI;YACJ,IAAI;YACJ,IAAI;SACL,CAAC,CAAC;KACJ;IAED,KAAK,IAAI,CAAC,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;QAC1C,IAAI,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QACxB,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,EAAE,GAAG,CAAC,CAAC;QAC3B,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,GAAG,EAAE,GAAG,CAAC,CAAC;QAC3B,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC1C,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC1C,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC1C,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAE1C,oGAAoG;KACrG;IACD,0GAA0G;IAC1G,kBAAkB;IAClB,IAAI,YAAY,GAAG,EAAE,CAAC;IACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QACrC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACrC,IACE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,iBAAiB,GAAG,UAAU;gBAClE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,iBAAiB,GAAG,UAAU,EAClE;gBACA,yEAAyE;gBACzE,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACtB;iBAAM;gBACL,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACtB;SACF;KACF;IACD,IAAI,QAAQ,GAAG,gBAAgB,CAAC,YAAY,CAAC,CAAC;IAE9C,IAAI,OAAO,GAA2B,EAAE,CAAC;IACzC,IAAI,QAAQ,EAAE;QACZ,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE;YAC9B,IAAI,MAAM,GAAQ;gBAChB,EAAE,EAAE,UAAU,EAAE;gBAChB,CAAC,EAAE;oBACD,KAAK,EAAE,CAAC;oBACR,OAAO,EAAE,QAAQ;oBACjB,UAAU,EAAE,EAAE;iBACf;gBACD,CAAC,EAAE;oBACD,KAAK,EAAE,CAAC;oBACR,OAAO,EAAE,QAAQ;oBACjB,UAAU,EAAE,EAAE;iBACf;aACF,CAAC;YACF,IAAI,OAAO,GAAQ,EAAE,CAAC;YACtB,IAAI,IAAI,GAAG,CAAC,CAAC;YAEb,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACnD,IAAI,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;oBACxB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;oBAC3B,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;oBAClD,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;oBAClD,IAAI,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;iBACxB;aACF;YAED,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC;YACvB,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC;YACvB,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC;YACvB,OAAO,CAAC,IAAI,CAAC,MAA8B,CAAC,CAAC;SAC9C;KACF;IACD,OAAO,OAAO,CAAC;AACjB,CAAC"}
1
+ {"version":3,"file":"xyzAutoSignalsPicking.js","sourceRoot":"","sources":["../../src/xyz/xyzAutoSignalsPicking.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"xyzAutoZonesPicking.js","sourceRoot":"","sources":["../../src/xyz/xyzAutoZonesPicking.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,IAAI,CAAC;AAK3C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAmEhD,MAAM,UAAU,mBAAmB,CACjC,WAAmB,EACnB,OAAmC;IAEnC,MAAM,OAAO,GAAG,qBAAqB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;IAC5D,OAAO,WAAW,CAAC,OAAO,CAAC,CAAC;AAC9B,CAAC"}
1
+ {"version":3,"file":"xyzAutoZonesPicking.js","sourceRoot":"","sources":["../../src/xyz/xyzAutoZonesPicking.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAAE,MAAM,IAAI,CAAC;AAK3C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AA2DhD,MAAM,UAAU,mBAAmB,CACjC,WAA0B,EAC1B,OAAmC;IAEnC,MAAM,OAAO,GAAG,qBAAqB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;IAC5D,OAAO,WAAW,CAAC,OAAO,CAAC,CAAC;AAC9B,CAAC"}
@@ -0,0 +1,75 @@
1
+ import { quadrature } from './quadrature';
2
+ import { fftDirectDimension, } from './util/fft2d/fftDirectDimension';
3
+ import { fftIndirectDimension, } from './util/fft2d/fftIndirectDimension';
4
+ export function xyzBidimensionalFFT(data, options) {
5
+ ensureData2DFid(data);
6
+ const { info, fnMode, digitalFilterValue = 0, zeroFilling: zeroFillingGeneral, } = options;
7
+ const orderedData = quadrature(data, { fnMode });
8
+ const { re: reData } = orderedData;
9
+ const nbRows = reData.length;
10
+ const nbColumns = reData[0].length;
11
+ const { direct = {}, indirect = {} } = options;
12
+ const { zeroFilling: zeroFillingF2 = zeroFillingGeneral } = direct;
13
+ const { factor: f2Factor = 2 } = zeroFillingF2 || {};
14
+ const nbPointsF2 = (zeroFillingF2 === null || zeroFillingF2 === void 0 ? void 0 : zeroFillingF2.nbPoints) || 2 ** Math.round(Math.log2(nbColumns * f2Factor));
15
+ const transformed = fftDirectDimension(orderedData, {
16
+ ...direct,
17
+ fnMode,
18
+ digitalFilterValue,
19
+ zeroFilling: { nbPoints: nbPointsF2 },
20
+ });
21
+ const { zeroFilling: zeroFillingF1 } = options;
22
+ const { factor: f1Factor = 2 } = zeroFillingF1 || {};
23
+ const nbPointsF1 = (zeroFillingF1 === null || zeroFillingF1 === void 0 ? void 0 : zeroFillingF1.nbPoints) || 2 ** Math.round(Math.log2(nbRows * f1Factor));
24
+ const { re: reResult, im: imResult } = fftIndirectDimension(transformed, {
25
+ ...indirect,
26
+ fnMode,
27
+ zeroFilling: { nbPoints: nbPointsF1 },
28
+ });
29
+ const minMaxXY = getMinMaxXY(info);
30
+ return {
31
+ re: {
32
+ z: convertToDoubleArray(reResult),
33
+ maxZ: reResult.max(),
34
+ minZ: reResult.min(),
35
+ ...minMaxXY,
36
+ },
37
+ im: {
38
+ z: convertToDoubleArray(imResult),
39
+ maxZ: imResult.max(),
40
+ minZ: imResult.min(),
41
+ ...minMaxXY,
42
+ },
43
+ };
44
+ }
45
+ function ensureData2DFid(data) {
46
+ if (!('re' in data)) {
47
+ throw new Error('bidimensional FFT only can be applied to raw data');
48
+ }
49
+ }
50
+ function convertToDoubleArray(data) {
51
+ const result = new Array(data.rows);
52
+ for (let i = 0; i < data.rows; i++) {
53
+ result[i] = new Float64Array(data.getRow(i));
54
+ }
55
+ return result;
56
+ }
57
+ function getMinMaxXY(info) {
58
+ const min = [];
59
+ const max = [];
60
+ for (let i = 0; i < info.baseFrequency.length; i++) {
61
+ const baseFrequency = Number.parseFloat(info.baseFrequency[i]);
62
+ const frequencyOffset = Number.parseFloat(info.frequencyOffset[i]);
63
+ const spectralWidth = Number.parseFloat(info.spectralWidth[i]);
64
+ const offset = frequencyOffset / baseFrequency;
65
+ min.push(offset - spectralWidth * 0.5);
66
+ max.push(offset + spectralWidth * 0.5);
67
+ }
68
+ return {
69
+ minX: min[0],
70
+ maxX: max[0],
71
+ minY: min[1],
72
+ maxY: max[1],
73
+ };
74
+ }
75
+ //# sourceMappingURL=xyzBidimensionalFFT.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"xyzBidimensionalFFT.js","sourceRoot":"","sources":["../../src/xyz/xyzBidimensionalFFT.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "nmr-processing",
3
- "version": "9.5.0",
3
+ "version": "9.5.1-pre.1684857934",
4
4
  "description": "Pure functions allowing to process NMR spectra.",
5
5
  "main": "./lib/index.js",
6
6
  "module": "./lib-esm/index.js",
@@ -61,20 +61,25 @@
61
61
  "gyromagnetic-ratio": "^1.0.0",
62
62
  "is-any-array": "^2.0.0",
63
63
  "linear-sum-assignment": "^1.0.5",
64
+ "ml-airpls": "^1.0.1",
64
65
  "ml-array-mean": "^1.1.6",
65
66
  "ml-array-rescale": "^1.3.7",
66
67
  "ml-array-sum": "^1.1.6",
68
+ "ml-array-xy-equally-spaced": "^1.2.1",
69
+ "ml-baseline-correction-regression": "^1.0.1",
67
70
  "ml-direct": "^0.1.3",
68
- "ml-gsd": "^12.1.3",
71
+ "ml-gsd": "^12.1.2",
69
72
  "ml-hclust": "^3.1.0",
70
73
  "ml-levenberg-marquardt": "^4.1.0",
71
74
  "ml-matrix": "^6.10.4",
72
75
  "ml-matrix-convolution": "^1.0.0",
73
76
  "ml-matrix-peaks-finder": "^1.0.0",
74
77
  "ml-peak-shape-generator": "^4.1.2",
78
+ "ml-signal-processing": "^1.0.3",
75
79
  "ml-simple-clustering": "^0.1.0",
76
80
  "ml-sparse-matrix": "^2.1.0",
77
81
  "ml-spectra-processing": "^12.4.0",
82
+ "ml-stat": "^1.3.3",
78
83
  "ml-tree-set": "^0.1.1",
79
84
  "nmr-correlation": "^2.3.3",
80
85
  "nmredata": "^0.9.2",
@@ -10,23 +10,25 @@ export interface DataReIm {
10
10
  im: DoubleArray;
11
11
  }
12
12
 
13
- interface ApodizationOptions {
13
+ export interface ApodizationOptions {
14
14
  /**
15
15
  * number of points at the end of the shape to apply the window function inverted
16
16
  * @default 0
17
17
  */
18
18
  pointsToShift?: number;
19
- compose: ShapeOptions;
19
+ compose?: ShapeOptions;
20
20
  }
21
- export function apodization(data: DataReIm, options: ApodizationOptions) {
21
+ export function apodization(data: DataReIm, options: ApodizationOptions = {}) {
22
22
  const { compose: composeOptions, pointsToShift } = options;
23
+
24
+ if (!composeOptions) return { ...data, windowData: [] };
25
+
23
26
  const windowData = compose(composeOptions);
24
27
 
25
28
  const applyWindowOptions = {
26
29
  windowData,
27
30
  pointsToShift,
28
31
  };
29
-
30
32
  const re = applyWindow(data.re, applyWindowOptions);
31
33
  const im = applyWindow(data.im, applyWindowOptions);
32
34
 
@@ -42,7 +42,6 @@ export function applyWindow(data: DoubleArray, options: ApplyWindowOptions) {
42
42
  for (let i = start, j = 0; i < firstEndPoint; i++) {
43
43
  output[i] *= windowData[j++];
44
44
  }
45
-
46
45
  for (let i = dataLength - 1, j = 0; i > dataLength - pointsToShift - 1; i--) {
47
46
  output[i] *= windowData[j++];
48
47
  }
@@ -36,6 +36,7 @@ export function compose(shapeOptions: ShapeOptions) {
36
36
  'length' in shapeOptions ? shapeOptions.length : dataLength - start;
37
37
 
38
38
  const windowData = getData(getFunction(shape), length);
39
+
39
40
  applyWindow(data, {
40
41
  windowData,
41
42
  length,
@@ -1,6 +1,7 @@
1
1
  import type { WindowFunctions } from './shapes/WindowFunctions';
2
2
  import { exponential } from './shapes/exponential';
3
3
  import { lorentzToGauss } from './shapes/lorentzToGauss';
4
+ import { sineBell } from './shapes/sineBell';
4
5
 
5
6
  export function getFunction(shape: WindowFunctions) {
6
7
  const { kind, options } = shape;
@@ -9,6 +10,8 @@ export function getFunction(shape: WindowFunctions) {
9
10
  return exponential(options);
10
11
  case 'lorentzToGauss':
11
12
  return lorentzToGauss(options);
13
+ case 'sineBell':
14
+ return sineBell(options);
12
15
  default:
13
16
  throw Error(`Unknown distribution ${kind as string}`);
14
17
  }
@@ -1,5 +1,6 @@
1
1
  import type { ExponentialOptions } from './exponential';
2
2
  import type { LorentzToGaussOptions } from './lorentzToGauss';
3
+ import { SineBellOptions } from './sineBell';
3
4
 
4
5
  interface Exponential {
5
6
  kind: 'exponential';
@@ -11,4 +12,9 @@ interface LorentToGauss {
11
12
  options: LorentzToGaussOptions;
12
13
  }
13
14
 
14
- export type WindowFunctions = Exponential | LorentToGauss;
15
+ interface SineBell {
16
+ kind: 'sineBell';
17
+ options: SineBellOptions;
18
+ }
19
+
20
+ export type WindowFunctions = Exponential | LorentToGauss | SineBell;
@@ -0,0 +1,41 @@
1
+ export interface SineBellOptions {
2
+ /**
3
+ * Specifies the exponent of the sine-bell; Non-integer values are allowed.
4
+ * Common values are 1.0 (for ordinary sine-bell) and 2.0 (for squared-bell functions).
5
+ * @default 1
6
+ */
7
+ exponent?: number;
8
+ /**
9
+ * Specifies the starting point of the sine-bell in units of pi radians.
10
+ * Common values are 0.0 (for a sine window which starts height at 0.0) and
11
+ * 0.5 (for a cosine window, which starts at height 1.0).
12
+ * @default 0
13
+ */
14
+ offset?: number;
15
+ /**
16
+ * Specifies the ending point of the sine-bell in units of pi radians.
17
+ * Common values are 1.0 (for a window which goes to 0.0 height at the last point) and
18
+ * 0.95 (for a window which doesn't go all the way to 0.0).
19
+ * @default 1
20
+ */
21
+ end?: number;
22
+ /**
23
+ * Specifies the number of points in the window function.
24
+ */
25
+ length: number;
26
+ }
27
+
28
+ export function sineBell(options: SineBellOptions) {
29
+ const { exponent = 1, offset = 0, end = 1, length } = options;
30
+
31
+ if (length === undefined) {
32
+ throw new Error('length options should exists for sineBell shape');
33
+ }
34
+
35
+ if (end < 0 || end > 1) {
36
+ throw new Error(`the end parameter should be [0-1]`);
37
+ }
38
+ const c1 = Math.PI * offset;
39
+ const c2 = (Math.PI * (end - offset)) / (length - 1);
40
+ return (i: number) => Math.pow(Math.sin(c1 + c2 * i), exponent);
41
+ }
@@ -9,7 +9,6 @@ export function getData(func: (i: number) => number, length: number) {
9
9
  data[i] = value;
10
10
  if (value > max) max = value;
11
11
  }
12
-
13
12
  for (let i = 0; i < length; i++) data[i] /= max;
14
13
  return data;
15
14
  }
@@ -0,0 +1,7 @@
1
+ import { DoubleArray } from 'cheminfo-types';
2
+
3
+ export interface Data1D {
4
+ x: DoubleArray;
5
+ re: DoubleArray;
6
+ im: DoubleArray;
7
+ }
@@ -0,0 +1,11 @@
1
+ import { Data1D } from './Data1D';
2
+ import { Filter } from './FiltersManager';
3
+
4
+ export interface Entry1D {
5
+ id?: string;
6
+ info: Record<string, any>;
7
+ originalInfo?: Record<string, any>;
8
+ data: Data1D;
9
+ originalData?: Data1D;
10
+ filters: Array<Filter>;
11
+ }
@@ -0,0 +1,5 @@
1
+ export interface ExclusionZone {
2
+ id: string;
3
+ from: number;
4
+ to: number;
5
+ }
@@ -0,0 +1,24 @@
1
+ import * as apodization from './filter1d/apodization';
2
+ import * as baselineCorrection from './filter1d/baselineCorrection';
3
+ import * as digitalFilter from './filter1d/digitalFilter';
4
+ import * as fft from './filter1d/fft';
5
+ import * as phaseCorrection from './filter1d/phaseCorrection';
6
+ import * as shiftX from './filter1d/shiftX';
7
+ import * as zeroFilling from './filter1d/zeroFilling';
8
+ import * as shift2DX from './filter2d/shiftX';
9
+ import * as shift2DY from './filter2d/shiftY';
10
+
11
+ export const filters: Record<
12
+ string,
13
+ { apply: any; reduce: any; isApplicable: any; name: string; id: string }
14
+ > = {
15
+ apodization,
16
+ baselineCorrection,
17
+ digitalFilter,
18
+ fft,
19
+ phaseCorrection,
20
+ shiftX,
21
+ zeroFilling,
22
+ shift2DX,
23
+ shift2DY,
24
+ };
@@ -0,0 +1,176 @@
1
+ import { v4 } from '@lukeed/uuid';
2
+ import { Data2D } from 'cheminfo-types';
3
+
4
+ import { cloneData1D } from '../utilities/cloneData1D';
5
+ import { cloneData2D } from '../utilities/cloneData2D';
6
+ import { Entry2D } from '../xyz/Entry2D';
7
+
8
+ import { Data1D } from './Data1D';
9
+ import { Entry1D } from './Entry1D';
10
+ import { filters as Filters } from './Filters';
11
+
12
+ export interface Filter {
13
+ id: string;
14
+ name: string;
15
+ label: string;
16
+ isDeleteAllow: boolean;
17
+ flag: boolean | null;
18
+ value: any;
19
+ error?: any;
20
+ }
21
+
22
+ export interface FilterDomainUpdateRules {
23
+ updateYDomain: boolean;
24
+ updateXDomain: boolean;
25
+ }
26
+
27
+ function resetDataToOrigin(datum: Entry1D | Entry2D) {
28
+ datum.data =
29
+ datum.info.dimension === 1
30
+ ? cloneData1D(datum.originalData as Data1D)
31
+ : cloneData2D(datum.originalData as Data2D);
32
+
33
+ datum.info = { ...datum.originalInfo };
34
+ }
35
+
36
+ /***
37
+ * @param {object} Filters [{name:'',options:{}},{...}]
38
+ */
39
+ function applyFilter(
40
+ datum: Entry1D | Entry2D,
41
+ filters: any[] = [],
42
+ forceReapply = false,
43
+ ) {
44
+ let isReduced = false;
45
+ for (let filter of filters) {
46
+ const filterOption = {
47
+ name: filter.name,
48
+ label: Filters[filter.name].name,
49
+ value: filter.options,
50
+ };
51
+ const previousFilter = lookupForFilter(datum, filter.name);
52
+ if (previousFilter) {
53
+ const reduceResult = Filters[filter.name].reduce(
54
+ previousFilter.value,
55
+ filterOption.value,
56
+ );
57
+ if (reduceResult.once) {
58
+ if (!isReduced) {
59
+ isReduced = true;
60
+ }
61
+ if (reduceResult.reduce != null && reduceResult.reduce !== undefined) {
62
+ replaceFilter(datum, previousFilter.id, reduceResult.reduce);
63
+ }
64
+ } else {
65
+ addFilter(
66
+ datum,
67
+ filterOption,
68
+ Object.prototype.hasOwnProperty.call(filter, 'isDeleteAllow')
69
+ ? filter.isDeleteAllow
70
+ : true,
71
+ );
72
+ }
73
+ } else {
74
+ addFilter(
75
+ datum,
76
+ filterOption,
77
+ Object.prototype.hasOwnProperty.call(filter, 'isDeleteAllow')
78
+ ? filter.isDeleteAllow
79
+ : true,
80
+ );
81
+ }
82
+ }
83
+ if (forceReapply) {
84
+ reapplyFilters(datum);
85
+ } else if (isReduced) {
86
+ if (filters.length === 1 && isLastFilter(datum, filters[0].name)) {
87
+ Filters[filters[0].name].apply(datum, filters[0].options);
88
+ } else {
89
+ reapplyFilters(datum);
90
+ }
91
+ } else {
92
+ for (let filter of filters) {
93
+ Filters[filter.name].apply(datum, filter.options);
94
+ }
95
+ }
96
+ }
97
+
98
+ function isLastFilter(datum: Entry1D | Entry2D, id: string) {
99
+ const index = datum.filters.findIndex((f) => f.name === id);
100
+ if (datum.filters.length === index + 1) {
101
+ return true;
102
+ }
103
+ return false;
104
+ }
105
+
106
+ function lookupForFilter(datum: Entry1D | Entry2D, filterName: string) {
107
+ return datum.filters.find((f) => f.name === filterName);
108
+ }
109
+
110
+ function reapplyFilters(datum: Entry1D | Entry2D, filters: any = null) {
111
+ const _filters = filters || datum.filters;
112
+ enableFilter(datum, null, null, _filters);
113
+ }
114
+
115
+ // id filter id
116
+ function enableFilter(
117
+ datum: Entry1D | Entry2D,
118
+ id: string | null,
119
+ checked: boolean | null,
120
+ filters = null,
121
+ ) {
122
+ datum.filters = datum.filters.slice(0);
123
+ if (id) {
124
+ datum.filters = datum.filters.map((filter) => {
125
+ return { ...filter, flag: filter.id === id ? checked : filter.flag };
126
+ });
127
+ }
128
+
129
+ resetDataToOrigin(datum);
130
+
131
+ const _filters = filters || datum.filters;
132
+
133
+ for (let filterIndex = 0; filterIndex < _filters.length; filterIndex++) {
134
+ const filter = datum.filters[filterIndex];
135
+ datum.filters[filterIndex] = {
136
+ ...datum.filters[filterIndex],
137
+ };
138
+
139
+ if (filter.flag) {
140
+ try {
141
+ Filters[filter.name].apply(datum, filter.value);
142
+ } catch (error: any) {
143
+ datum.filters[filterIndex] = {
144
+ ...datum.filters[filterIndex],
145
+ error: error.message,
146
+ };
147
+ }
148
+ }
149
+ }
150
+ }
151
+
152
+ function addFilter(
153
+ datum: Entry1D | Entry2D,
154
+ filter: any,
155
+ isDeleteAllow = true,
156
+ ) {
157
+ const id = v4();
158
+ datum.filters = datum.filters.slice(0);
159
+ datum.filters.push({
160
+ ...filter,
161
+ id,
162
+ flag: true,
163
+ isDeleteAllow,
164
+ });
165
+ }
166
+
167
+ function replaceFilter(datum: Entry1D | Entry2D, filterID: string, value: any) {
168
+ // datum.filters = datum.filters.slice(0);
169
+ const index = datum.filters.findIndex((f) => f.id === filterID);
170
+ datum.filters[index] = {
171
+ ...datum.filters[index],
172
+ value,
173
+ };
174
+ }
175
+
176
+ export { applyFilter, reapplyFilters, enableFilter, addFilter };
@@ -0,0 +1,58 @@
1
+ import type { FilterXYType } from 'ml-signal-processing';
2
+
3
+ interface BaseField {
4
+ key: string;
5
+ level: number;
6
+ name: string;
7
+ description: string;
8
+ }
9
+
10
+ interface Field<T> extends BaseField {
11
+ default: T;
12
+ }
13
+
14
+ interface LabelField extends BaseField {
15
+ type: 'label';
16
+ }
17
+
18
+ interface SelectField extends Field<any> {
19
+ type: 'select';
20
+ choices: any[];
21
+ }
22
+ interface StringField extends Field<string> {
23
+ type: 'string';
24
+ }
25
+ interface NumberField extends Field<number> {
26
+ type: 'number';
27
+ }
28
+ interface BooleanField extends Field<boolean> {
29
+ type: 'boolean';
30
+ }
31
+
32
+ type CommonField =
33
+ | SelectField
34
+ | StringField
35
+ | NumberField
36
+ | BooleanField
37
+ | LabelField;
38
+
39
+ interface ListField extends Field<string[]> {
40
+ type: 'list';
41
+ properties: Record<string, CommonField>;
42
+ }
43
+
44
+ type Properties =
45
+ | ListField
46
+ | SelectField
47
+ | StringField
48
+ | NumberField
49
+ | BooleanField
50
+ | LabelField;
51
+
52
+ export type MatrixProperties = Record<string /*filed name*/, Properties>;
53
+
54
+ export interface MatrixFilter {
55
+ name: FilterXYType['name'] /*filter name*/;
56
+ properties: MatrixProperties;
57
+ options: any;
58
+ }
@@ -0,0 +1,26 @@
1
+ import { MatrixFilter } from './MatrixFilter';
2
+
3
+ import { ExclusionZone } from './ExclusionZone';
4
+
5
+ export interface MatrixOptions {
6
+ /**
7
+ * Matrix generation filters
8
+ * @default []
9
+ *
10
+ */
11
+ filters: (MatrixFilter & { options: object })[];
12
+ /**
13
+ * Exclusion zones
14
+ * @default []
15
+ */
16
+ exclusionsZones: ExclusionZone[];
17
+ /**
18
+ * range
19
+ */
20
+ range: { from: number; to: number };
21
+
22
+ /**
23
+ * number of points
24
+ */
25
+ numberOfPoints: number;
26
+ }