nmr-processing 7.4.3 → 8.2.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.
Files changed (114) hide show
  1. package/lib/assignment/getAssignments.js +1 -1
  2. package/lib/assignment/getAssignments.js.map +1 -1
  3. package/lib/assignment/utils/getAssignment/checkIDs.d.ts +1 -1
  4. package/lib/assignment/utils/getAssignment/checkIDs.js.map +1 -1
  5. package/lib/databases/getDatabase.d.ts +6 -1
  6. package/lib/databases/getDatabase.js +13 -3
  7. package/lib/databases/getDatabase.js.map +1 -1
  8. package/lib/index.d.ts +4 -2
  9. package/lib/index.js +3 -1
  10. package/lib/index.js.map +1 -1
  11. package/lib/peaks/NMRPeak1D.d.ts +0 -1
  12. package/lib/peaks/peaksToRanges.d.ts +16 -0
  13. package/lib/peaks/peaksToRanges.js +2 -1
  14. package/lib/peaks/peaksToRanges.js.map +1 -1
  15. package/lib/peaks/solventSuppression.d.ts +3 -0
  16. package/lib/peaks/solventSuppression.js +155 -0
  17. package/lib/peaks/solventSuppression.js.map +1 -0
  18. package/lib/peaks/util/jAnalyzer.d.ts +1 -1
  19. package/lib/peaks/util/jAnalyzer.js +3 -2
  20. package/lib/peaks/util/jAnalyzer.js.map +1 -1
  21. package/lib/prediction/predictAllSpectra.d.ts +22 -4
  22. package/lib/prediction/predictAllSpectra.js +102 -16
  23. package/lib/prediction/predictAllSpectra.js.map +1 -1
  24. package/lib/ranges/markSolventSignal.d.ts +3 -0
  25. package/lib/ranges/markSolventSignal.js +107 -0
  26. package/lib/ranges/markSolventSignal.js.map +1 -0
  27. package/lib/ranges/rangesToXY.js +27 -3
  28. package/lib/ranges/rangesToXY.js.map +1 -1
  29. package/lib/signals/addDummySignals.d.ts +2 -0
  30. package/lib/signals/addDummySignals.js +56 -0
  31. package/lib/signals/addDummySignals.js.map +1 -0
  32. package/lib/signals/hackSignalsToXY.js +2 -48
  33. package/lib/signals/hackSignalsToXY.js.map +1 -1
  34. package/lib/signals/simulation/simulate1D.d.ts +1 -39
  35. package/lib/signals/simulation/simulate1D.js +13 -240
  36. package/lib/signals/simulation/simulate1D.js.map +1 -1
  37. package/lib/signals/simulation/simulateXYPeaks.d.ts +47 -0
  38. package/lib/signals/simulation/simulateXYPeaks.js +246 -0
  39. package/lib/signals/simulation/simulateXYPeaks.js.map +1 -0
  40. package/lib/utilities/getFrequency.d.ts +1 -1
  41. package/lib/utilities/getFrequency.js +4 -4
  42. package/lib/utilities/getFrequency.js.map +1 -1
  43. package/lib/xyz/NMRSignal2D.d.ts +3 -3
  44. package/lib/xyz/util/formatZone.d.ts +3 -0
  45. package/lib/xyz/util/formatZone.js +38 -0
  46. package/lib/xyz/util/formatZone.js.map +1 -0
  47. package/lib/xyz/xyzAutoZonesPicking.d.ts +1 -2
  48. package/lib/xyz/xyzAutoZonesPicking.js +2 -34
  49. package/lib/xyz/xyzAutoZonesPicking.js.map +1 -1
  50. package/lib/xyz/xyzJResAnalyzer.d.ts +6 -1
  51. package/lib/xyz/xyzJResAnalyzer.js +9 -8
  52. package/lib/xyz/xyzJResAnalyzer.js.map +1 -1
  53. package/lib-esm/assignment/getAssignments.js +1 -1
  54. package/lib-esm/assignment/getAssignments.js.map +1 -1
  55. package/lib-esm/assignment/utils/getAssignment/checkIDs.js.map +1 -1
  56. package/lib-esm/databases/getDatabase.js +13 -3
  57. package/lib-esm/databases/getDatabase.js.map +1 -1
  58. package/lib-esm/index.js +3 -1
  59. package/lib-esm/index.js.map +1 -1
  60. package/lib-esm/peaks/peaksToRanges.js +1 -1
  61. package/lib-esm/peaks/peaksToRanges.js.map +1 -1
  62. package/lib-esm/peaks/solventSuppression.js +151 -0
  63. package/lib-esm/peaks/solventSuppression.js.map +1 -0
  64. package/lib-esm/peaks/util/jAnalyzer.js +3 -2
  65. package/lib-esm/peaks/util/jAnalyzer.js.map +1 -1
  66. package/lib-esm/prediction/predictAllSpectra.js +102 -16
  67. package/lib-esm/prediction/predictAllSpectra.js.map +1 -1
  68. package/lib-esm/ranges/markSolventSignal.js +100 -0
  69. package/lib-esm/ranges/markSolventSignal.js.map +1 -0
  70. package/lib-esm/ranges/rangesToXY.js +27 -3
  71. package/lib-esm/ranges/rangesToXY.js.map +1 -1
  72. package/lib-esm/signals/addDummySignals.js +52 -0
  73. package/lib-esm/signals/addDummySignals.js.map +1 -0
  74. package/lib-esm/signals/hackSignalsToXY.js +2 -48
  75. package/lib-esm/signals/hackSignalsToXY.js.map +1 -1
  76. package/lib-esm/signals/simulation/simulate1D.js +14 -238
  77. package/lib-esm/signals/simulation/simulate1D.js.map +1 -1
  78. package/lib-esm/signals/simulation/simulateXYPeaks.js +239 -0
  79. package/lib-esm/signals/simulation/simulateXYPeaks.js.map +1 -0
  80. package/lib-esm/utilities/getFrequency.js +1 -1
  81. package/lib-esm/utilities/getFrequency.js.map +1 -1
  82. package/lib-esm/xyz/util/formatZone.js +34 -0
  83. package/lib-esm/xyz/util/formatZone.js.map +1 -0
  84. package/lib-esm/xyz/xyzAutoZonesPicking.js +1 -33
  85. package/lib-esm/xyz/xyzAutoZonesPicking.js.map +1 -1
  86. package/lib-esm/xyz/xyzJResAnalyzer.js +9 -8
  87. package/lib-esm/xyz/xyzJResAnalyzer.js.map +1 -1
  88. package/package.json +14 -12
  89. package/src/assignment/getAssignments.ts +1 -1
  90. package/src/assignment/utils/getAssignment/checkIDs.ts +1 -1
  91. package/src/databases/getDatabase.ts +19 -2
  92. package/src/index.ts +5 -2
  93. package/src/peaks/NMRPeak1D.ts +0 -1
  94. package/src/peaks/peaksToRanges.ts +1 -1
  95. package/src/peaks/solventSuppression.ts +209 -0
  96. package/src/peaks/util/jAnalyzer.ts +5 -3
  97. package/src/prediction/predictAllSpectra.ts +151 -14
  98. package/src/ranges/markSolventSignal.ts +121 -0
  99. package/src/ranges/rangesToXY.ts +33 -4
  100. package/src/signals/addDummySignals.ts +77 -0
  101. package/src/signals/hackSignalsToXY.ts +2 -72
  102. package/src/signals/simulation/simulate1D.ts +14 -319
  103. package/src/signals/simulation/simulateXYPeaks.ts +332 -0
  104. package/src/utilities/getFrequency.ts +1 -1
  105. package/src/xyz/NMRSignal2D.ts +3 -3
  106. package/src/xyz/util/formatZone.ts +36 -0
  107. package/src/xyz/xyzAutoZonesPicking.ts +1 -35
  108. package/src/xyz/xyzJResAnalyzer.ts +14 -7
  109. package/lib/constants/gyromagneticRatio.d.ts +0 -6
  110. package/lib/constants/gyromagneticRatio.js +0 -26
  111. package/lib/constants/gyromagneticRatio.js.map +0 -1
  112. package/lib-esm/constants/gyromagneticRatio.js +0 -23
  113. package/lib-esm/constants/gyromagneticRatio.js.map +0 -1
  114. package/src/constants/gyromagneticRatio.ts +0 -49
@@ -1,9 +1,5 @@
1
- import binarySearch from 'binary-search';
2
- import { Matrix, EVD } from 'ml-matrix';
3
- import { SparseMatrix } from 'ml-sparse-matrix';
4
- import { SpectrumGenerator } from 'spectrum-generator';
5
- import getPauliMatrix from './getPauliMatrix';
6
- const smallValue = 1e-2;
1
+ import { generateSpectrum } from 'spectrum-generator';
2
+ import { simulateXYPeaks } from './simulateXYPeaks';
7
3
  /**
8
4
  * This function simulates a one dimensional nmr spectrum. This function returns an array containing the relative intensities of the spectrum in the specified simulation window (from-to).
9
5
  */
@@ -12,241 +8,21 @@ export default function simulate1D(
12
8
  * The SpinSystem object to be simulated
13
9
  */
14
10
  spinSystem, options = {}) {
15
- let { lineWidth = 1, maxClusterSize = 8, frequency: frequencyMHz = 400, from = 0, to = 10, nbPoints = 1024, shape = {
11
+ let { lineWidth = 1, frequency: frequencyMHz = 400, from = 0, to = 10, nbPoints = 1024, shape = {
16
12
  kind: 'gaussian',
17
13
  }, } = options;
18
14
  let peakWidth = lineWidth / frequencyMHz;
19
- let spectrumGenerator = new SpectrumGenerator({
20
- from,
21
- to,
22
- nbPoints,
23
- shape,
24
- peakWidthFct: () => peakWidth,
15
+ const xyPeaks = simulateXYPeaks(spinSystem, options);
16
+ return generateSpectrum(xyPeaks, {
17
+ generator: {
18
+ from,
19
+ to,
20
+ nbPoints,
21
+ },
22
+ peakOptions: {
23
+ shape,
24
+ width: peakWidth,
25
+ },
25
26
  });
26
- const chemicalShifts = spinSystem.chemicalShifts.slice();
27
- for (let i = 0; i < chemicalShifts.length; i++) {
28
- chemicalShifts[i] = chemicalShifts[i] * frequencyMHz;
29
- }
30
- const multiplicity = spinSystem.multiplicity;
31
- for (const cluster of spinSystem.clusters) {
32
- let clusterFake = cluster.map((cluster) => cluster < 0 ? -cluster - 1 : cluster);
33
- let weight = 1;
34
- let sumI = 0;
35
- let frequencies = [];
36
- let intensities = [];
37
- if (cluster.length > maxClusterSize) {
38
- // This is a single spin, but the cluster exceeds the maxClusterSize criteria
39
- // we use the simple multiplicity algorithm
40
- // Add the central peak. It will be split with every single J coupling.
41
- let index = 0;
42
- while (cluster[index++] < 0)
43
- ;
44
- index = cluster[index - 1];
45
- frequencies.push(-chemicalShifts[index]);
46
- for (let i = 0; i < cluster.length; i++) {
47
- if (cluster[i] < 0) {
48
- let jc = spinSystem.couplingConstants.get(index, clusterFake[i]) / 2;
49
- let currentSize = frequencies.length;
50
- for (let j = 0; j < currentSize; j++) {
51
- frequencies.push(frequencies[j] + jc);
52
- frequencies[j] -= jc;
53
- }
54
- }
55
- }
56
- frequencies.sort((a, b) => a - b);
57
- sumI = frequencies.length;
58
- weight = 1;
59
- for (let i = 0; i < sumI; i++) {
60
- intensities.push(1);
61
- }
62
- }
63
- else {
64
- const hamiltonian = getHamiltonian(chemicalShifts, spinSystem.couplingConstants, multiplicity, spinSystem.connectivity, clusterFake);
65
- const hamSize = hamiltonian.rows;
66
- // TODO: add support for sparse matrix in matrix types.
67
- // @ts-expect-error sparse matrix not supported
68
- const evd = new EVD(hamiltonian);
69
- const V = evd.eigenvectorMatrix;
70
- const diagB = evd.realEigenvalues;
71
- const assignmentMatrix = new SparseMatrix(hamSize, hamSize);
72
- const multLen = cluster.length;
73
- weight = 0;
74
- for (let n = 0; n < multLen; n++) {
75
- const L = getPauliMatrix(multiplicity[clusterFake[n]]);
76
- let temp = 1;
77
- for (let j = 0; j < n; j++) {
78
- temp *= multiplicity[clusterFake[j]];
79
- }
80
- const A = SparseMatrix.eye(temp);
81
- temp = 1;
82
- for (let j = n + 1; j < multLen; j++) {
83
- temp *= multiplicity[clusterFake[j]];
84
- }
85
- const B = SparseMatrix.eye(temp);
86
- const tempMat = A.kroneckerProduct(L.m).kroneckerProduct(B);
87
- if (cluster[n] >= 0) {
88
- assignmentMatrix.add(tempMat.mul(cluster[n] + 1));
89
- weight++;
90
- }
91
- else {
92
- assignmentMatrix.add(tempMat.mul(cluster[n]));
93
- }
94
- }
95
- let rhoip = Matrix.zeros(hamSize, hamSize);
96
- assignmentMatrix.forEachNonZero((i, j, v) => {
97
- if (v > 0) {
98
- for (let k = 0; k < V.columns; k++) {
99
- let element = V.get(j, k);
100
- if (element !== 0) {
101
- rhoip.set(i, k, rhoip.get(i, k) + element);
102
- }
103
- }
104
- }
105
- return v;
106
- });
107
- let rhoip2 = rhoip.clone();
108
- assignmentMatrix.forEachNonZero((i, j, v) => {
109
- if (v < 0) {
110
- for (let k = 0; k < V.columns; k++) {
111
- let element = V.get(j, k);
112
- if (element !== 0) {
113
- rhoip2.set(i, k, rhoip2.get(i, k) + element);
114
- }
115
- }
116
- }
117
- return v;
118
- });
119
- const tV = V.transpose();
120
- rhoip = tV.mmul(rhoip);
121
- const sparseRhoip = new SparseMatrix(rhoip.to2DArray(), {
122
- threshold: smallValue,
123
- });
124
- triuTimesAbs(sparseRhoip, smallValue);
125
- rhoip2 = tV.mmul(rhoip2);
126
- const sparseRhoip2 = new SparseMatrix(rhoip2.to2DArray(), {
127
- threshold: smallValue,
128
- });
129
- sparseRhoip2.forEachNonZero((i, j, v) => {
130
- return v;
131
- });
132
- triuTimesAbs(sparseRhoip2, smallValue);
133
- sparseRhoip2.forEachNonZero((i, j, v) => {
134
- let val = rhoip.get(i, j);
135
- val = Math.min(Math.abs(val), Math.abs(v));
136
- val *= val;
137
- sumI += val;
138
- let valFreq = diagB[i] - diagB[j];
139
- let insertIn = binarySearch(frequencies, valFreq, (a, b) => a - b);
140
- if (insertIn < 0) {
141
- frequencies.splice(-1 - insertIn, 0, valFreq);
142
- intensities.splice(-1 - insertIn, 0, val);
143
- }
144
- else {
145
- intensities[insertIn] += val;
146
- }
147
- });
148
- }
149
- const numFreq = frequencies.length;
150
- if (numFreq > 0) {
151
- weight /= sumI;
152
- const diff = lineWidth / 64;
153
- let valFreq = frequencies[0];
154
- let inte = intensities[0];
155
- let count = 1;
156
- for (let i = 1; i < numFreq; i++) {
157
- if (Math.abs(frequencies[i] - valFreq / count) < diff) {
158
- inte += intensities[i];
159
- valFreq += frequencies[i];
160
- count++;
161
- }
162
- else {
163
- spectrumGenerator.addPeak({
164
- x: -valFreq / count / frequencyMHz,
165
- y: inte * weight,
166
- });
167
- valFreq = frequencies[i];
168
- inte = intensities[i];
169
- count = 1;
170
- }
171
- }
172
- spectrumGenerator.addPeak({
173
- x: -valFreq / count / frequencyMHz,
174
- y: inte * weight,
175
- });
176
- }
177
- }
178
- return spectrumGenerator.getSpectrum();
179
- }
180
- function triuTimesAbs(A, val) {
181
- A.forEachNonZero((i, j, v) => {
182
- if (i > j)
183
- return 0;
184
- if (Math.abs(v) <= val)
185
- return 0;
186
- return v;
187
- });
188
- }
189
- /**
190
- * Create a hamiltonian matrix for the given spinsystem
191
- * @param {Array} chemicalShifts - An array containing the chemical shift in Hz
192
- * @param {Array} couplingConstants - An array containing the coupling constants in Hz
193
- * @param {Array} multiplicity - An array specifiying the multiplicities of each scalar coupling
194
- * @param {Array} conMatrix - A one step connectivity matrix for the given spin system
195
- * @param {Array} cluster - An binary array specifiying the spins to be considered for this hamiltonial
196
- * @return {object}
197
- */
198
- function getHamiltonian(chemicalShifts, couplingConstants, multiplicity, conMatrix, cluster) {
199
- let hamSize = 1;
200
- for (const element of cluster) {
201
- hamSize *= multiplicity[element];
202
- }
203
- const clusterHam = new SparseMatrix(hamSize, hamSize);
204
- for (let pos = 0; pos < cluster.length; pos++) {
205
- let n = cluster[pos];
206
- const L = getPauliMatrix(multiplicity[n]);
207
- let A1, B1;
208
- let temp = 1;
209
- for (let i = 0; i < pos; i++) {
210
- temp *= multiplicity[cluster[i]];
211
- }
212
- A1 = SparseMatrix.eye(temp);
213
- temp = 1;
214
- for (let i = pos + 1; i < cluster.length; i++) {
215
- temp *= multiplicity[cluster[i]];
216
- }
217
- B1 = SparseMatrix.eye(temp);
218
- const alpha = chemicalShifts[n];
219
- const kronProd = A1.kroneckerProduct(L.z).kroneckerProduct(B1);
220
- clusterHam.add(kronProd.mul(alpha));
221
- for (let pos2 = 0; pos2 < cluster.length; pos2++) {
222
- const k = cluster[pos2];
223
- if (conMatrix.get(n, k) === 1) {
224
- const S = getPauliMatrix(multiplicity[k]);
225
- let A2, B2;
226
- let temp = 1;
227
- for (let i = 0; i < pos2; i++) {
228
- temp *= multiplicity[cluster[i]];
229
- }
230
- A2 = SparseMatrix.eye(temp);
231
- temp = 1;
232
- for (let i = pos2 + 1; i < cluster.length; i++) {
233
- temp *= multiplicity[cluster[i]];
234
- }
235
- B2 = SparseMatrix.eye(temp);
236
- const kron1 = A1.kroneckerProduct(L.x)
237
- .kroneckerProduct(B1)
238
- .mmul(A2.kroneckerProduct(S.x).kroneckerProduct(B2));
239
- kron1.add(A1.kroneckerProduct(L.y)
240
- .kroneckerProduct(B1)
241
- .mul(-1)
242
- .mmul(A2.kroneckerProduct(S.y).kroneckerProduct(B2)));
243
- kron1.add(A1.kroneckerProduct(L.z)
244
- .kroneckerProduct(B1)
245
- .mmul(A2.kroneckerProduct(S.z).kroneckerProduct(B2)));
246
- clusterHam.add(kron1.mul(couplingConstants.get(n, k) / 2));
247
- }
248
- }
249
- }
250
- return clusterHam;
251
27
  }
252
28
  //# sourceMappingURL=simulate1D.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"simulate1D.js","sourceRoot":"","sources":["../../../src/signals/simulation/simulate1D.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"simulate1D.js","sourceRoot":"","sources":["../../../src/signals/simulation/simulate1D.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAKtD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAEpD;;GAEG;AAEH,MAAM,CAAC,OAAO,UAAU,UAAU;AAChC;;GAEG;AACH,UAAsB,EACtB,UAA6B,EAAE;IAE/B,IAAI,EACF,SAAS,GAAG,CAAC,EACb,SAAS,EAAE,YAAY,GAAG,GAAG,EAC7B,IAAI,GAAG,CAAC,EACR,EAAE,GAAG,EAAE,EACP,QAAQ,GAAG,IAAI,EACf,KAAK,GAAG;QACN,IAAI,EAAE,UAAU;KACjB,GACF,GAAG,OAAO,CAAC;IAEZ,IAAI,SAAS,GAAG,SAAS,GAAG,YAAY,CAAC;IAEzC,MAAM,OAAO,GAAG,eAAe,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IAErD,OAAO,gBAAgB,CAAC,OAAO,EAAE;QAC/B,SAAS,EAAE;YACT,IAAI;YACJ,EAAE;YACF,QAAQ;SACT;QACD,WAAW,EAAE;YACX,KAAK;YACL,KAAK,EAAE,SAAS;SACjB;KACF,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,239 @@
1
+ import binarySearch from 'binary-search';
2
+ import { Matrix, EVD } from 'ml-matrix';
3
+ import { SparseMatrix } from 'ml-sparse-matrix';
4
+ import getPauliMatrix from './getPauliMatrix';
5
+ const smallValue = 1e-2;
6
+ export function simulateXYPeaks(
7
+ /**
8
+ * The SpinSystem object to be simulated
9
+ */
10
+ spinSystem, options = {}) {
11
+ let { lineWidth = 1, maxClusterSize = 8, frequency: frequencyMHz = 400, } = options;
12
+ const chemicalShifts = spinSystem.chemicalShifts.slice();
13
+ for (let i = 0; i < chemicalShifts.length; i++) {
14
+ chemicalShifts[i] = chemicalShifts[i] * frequencyMHz;
15
+ }
16
+ const multiplicity = spinSystem.multiplicity;
17
+ const xyPeaks = [];
18
+ for (const cluster of spinSystem.clusters) {
19
+ let clusterFake = cluster.map((cluster) => cluster < 0 ? -cluster - 1 : cluster);
20
+ let weight = 1;
21
+ let sumI = 0;
22
+ let frequencies = [];
23
+ let intensities = [];
24
+ if (cluster.length > maxClusterSize) {
25
+ // This is a single spin, but the cluster exceeds the maxClusterSize criteria
26
+ // we use the simple multiplicity algorithm
27
+ // Add the central peak. It will be split with every single J coupling.
28
+ let index = 0;
29
+ while (cluster[index++] < 0)
30
+ ;
31
+ index = cluster[index - 1];
32
+ frequencies.push(-chemicalShifts[index]);
33
+ for (let i = 0; i < cluster.length; i++) {
34
+ if (cluster[i] < 0) {
35
+ let jc = spinSystem.couplingConstants.get(index, clusterFake[i]) / 2;
36
+ let currentSize = frequencies.length;
37
+ for (let j = 0; j < currentSize; j++) {
38
+ frequencies.push(frequencies[j] + jc);
39
+ frequencies[j] -= jc;
40
+ }
41
+ }
42
+ }
43
+ frequencies.sort((a, b) => a - b);
44
+ sumI = frequencies.length;
45
+ weight = 1;
46
+ for (let i = 0; i < sumI; i++) {
47
+ intensities.push(1);
48
+ }
49
+ }
50
+ else {
51
+ const hamiltonian = getHamiltonian(chemicalShifts, spinSystem.couplingConstants, multiplicity, spinSystem.connectivity, clusterFake);
52
+ const hamSize = hamiltonian.rows;
53
+ // TODO: add support for sparse matrix in matrix types.
54
+ // @ts-expect-error sparse matrix not supported
55
+ const evd = new EVD(hamiltonian);
56
+ const V = evd.eigenvectorMatrix;
57
+ const diagB = evd.realEigenvalues;
58
+ const assignmentMatrix = new SparseMatrix(hamSize, hamSize);
59
+ const multLen = cluster.length;
60
+ weight = 0;
61
+ for (let n = 0; n < multLen; n++) {
62
+ const L = getPauliMatrix(multiplicity[clusterFake[n]]);
63
+ let temp = 1;
64
+ for (let j = 0; j < n; j++) {
65
+ temp *= multiplicity[clusterFake[j]];
66
+ }
67
+ const A = SparseMatrix.eye(temp);
68
+ temp = 1;
69
+ for (let j = n + 1; j < multLen; j++) {
70
+ temp *= multiplicity[clusterFake[j]];
71
+ }
72
+ const B = SparseMatrix.eye(temp);
73
+ const tempMat = A.kroneckerProduct(L.m).kroneckerProduct(B);
74
+ if (cluster[n] >= 0) {
75
+ assignmentMatrix.add(tempMat.mul(cluster[n] + 1));
76
+ weight++;
77
+ }
78
+ else {
79
+ assignmentMatrix.add(tempMat.mul(cluster[n]));
80
+ }
81
+ }
82
+ let rhoip = Matrix.zeros(hamSize, hamSize);
83
+ assignmentMatrix.forEachNonZero((i, j, v) => {
84
+ if (v > 0) {
85
+ for (let k = 0; k < V.columns; k++) {
86
+ let element = V.get(j, k);
87
+ if (element !== 0) {
88
+ rhoip.set(i, k, rhoip.get(i, k) + element);
89
+ }
90
+ }
91
+ }
92
+ return v;
93
+ });
94
+ let rhoip2 = rhoip.clone();
95
+ assignmentMatrix.forEachNonZero((i, j, v) => {
96
+ if (v < 0) {
97
+ for (let k = 0; k < V.columns; k++) {
98
+ let element = V.get(j, k);
99
+ if (element !== 0) {
100
+ rhoip2.set(i, k, rhoip2.get(i, k) + element);
101
+ }
102
+ }
103
+ }
104
+ return v;
105
+ });
106
+ const tV = V.transpose();
107
+ rhoip = tV.mmul(rhoip);
108
+ const sparseRhoip = new SparseMatrix(rhoip.to2DArray(), {
109
+ threshold: smallValue,
110
+ });
111
+ triuTimesAbs(sparseRhoip, smallValue);
112
+ rhoip2 = tV.mmul(rhoip2);
113
+ const sparseRhoip2 = new SparseMatrix(rhoip2.to2DArray(), {
114
+ threshold: smallValue,
115
+ });
116
+ sparseRhoip2.forEachNonZero((i, j, v) => {
117
+ return v;
118
+ });
119
+ triuTimesAbs(sparseRhoip2, smallValue);
120
+ sparseRhoip2.forEachNonZero((i, j, v) => {
121
+ let val = rhoip.get(i, j);
122
+ val = Math.min(Math.abs(val), Math.abs(v));
123
+ val *= val;
124
+ sumI += val;
125
+ let valFreq = diagB[i] - diagB[j];
126
+ let insertIn = binarySearch(frequencies, valFreq, (a, b) => a - b);
127
+ if (insertIn < 0) {
128
+ frequencies.splice(-1 - insertIn, 0, valFreq);
129
+ intensities.splice(-1 - insertIn, 0, val);
130
+ }
131
+ else {
132
+ intensities[insertIn] += val;
133
+ }
134
+ });
135
+ }
136
+ const numFreq = frequencies.length;
137
+ if (numFreq > 0) {
138
+ weight /= sumI;
139
+ const diff = lineWidth / 64;
140
+ let valFreq = frequencies[0];
141
+ let inte = intensities[0];
142
+ let count = 1;
143
+ for (let i = 1; i < numFreq; i++) {
144
+ if (Math.abs(frequencies[i] - valFreq / count) < diff) {
145
+ inte += intensities[i];
146
+ valFreq += frequencies[i];
147
+ count++;
148
+ }
149
+ else {
150
+ xyPeaks.push({
151
+ x: -valFreq / count / frequencyMHz,
152
+ y: inte * weight,
153
+ });
154
+ valFreq = frequencies[i];
155
+ inte = intensities[i];
156
+ count = 1;
157
+ }
158
+ }
159
+ xyPeaks.push({
160
+ x: -valFreq / count / frequencyMHz,
161
+ y: inte * weight,
162
+ });
163
+ }
164
+ }
165
+ return xyPeaks;
166
+ }
167
+ function triuTimesAbs(A, val) {
168
+ A.forEachNonZero((i, j, v) => {
169
+ if (i > j)
170
+ return 0;
171
+ if (Math.abs(v) <= val)
172
+ return 0;
173
+ return v;
174
+ });
175
+ }
176
+ /**
177
+ * Create a hamiltonian matrix for the given spinsystem
178
+ * @param {Array} chemicalShifts - An array containing the chemical shift in Hz
179
+ * @param {Array} couplingConstants - An array containing the coupling constants in Hz
180
+ * @param {Array} multiplicity - An array specifiying the multiplicities of each scalar coupling
181
+ * @param {Array} conMatrix - A one step connectivity matrix for the given spin system
182
+ * @param {Array} cluster - An binary array specifiying the spins to be considered for this hamiltonial
183
+ * @return {object}
184
+ */
185
+ function getHamiltonian(chemicalShifts, couplingConstants, multiplicity, conMatrix, cluster) {
186
+ let hamSize = 1;
187
+ for (const element of cluster) {
188
+ hamSize *= multiplicity[element];
189
+ }
190
+ const clusterHam = new SparseMatrix(hamSize, hamSize);
191
+ for (let pos = 0; pos < cluster.length; pos++) {
192
+ let n = cluster[pos];
193
+ const L = getPauliMatrix(multiplicity[n]);
194
+ let A1, B1;
195
+ let temp = 1;
196
+ for (let i = 0; i < pos; i++) {
197
+ temp *= multiplicity[cluster[i]];
198
+ }
199
+ A1 = SparseMatrix.eye(temp);
200
+ temp = 1;
201
+ for (let i = pos + 1; i < cluster.length; i++) {
202
+ temp *= multiplicity[cluster[i]];
203
+ }
204
+ B1 = SparseMatrix.eye(temp);
205
+ const alpha = chemicalShifts[n];
206
+ const kronProd = A1.kroneckerProduct(L.z).kroneckerProduct(B1);
207
+ clusterHam.add(kronProd.mul(alpha));
208
+ for (let pos2 = 0; pos2 < cluster.length; pos2++) {
209
+ const k = cluster[pos2];
210
+ if (conMatrix.get(n, k) === 1) {
211
+ const S = getPauliMatrix(multiplicity[k]);
212
+ let A2, B2;
213
+ let temp = 1;
214
+ for (let i = 0; i < pos2; i++) {
215
+ temp *= multiplicity[cluster[i]];
216
+ }
217
+ A2 = SparseMatrix.eye(temp);
218
+ temp = 1;
219
+ for (let i = pos2 + 1; i < cluster.length; i++) {
220
+ temp *= multiplicity[cluster[i]];
221
+ }
222
+ B2 = SparseMatrix.eye(temp);
223
+ const kron1 = A1.kroneckerProduct(L.x)
224
+ .kroneckerProduct(B1)
225
+ .mmul(A2.kroneckerProduct(S.x).kroneckerProduct(B2));
226
+ kron1.add(A1.kroneckerProduct(L.y)
227
+ .kroneckerProduct(B1)
228
+ .mul(-1)
229
+ .mmul(A2.kroneckerProduct(S.y).kroneckerProduct(B2)));
230
+ kron1.add(A1.kroneckerProduct(L.z)
231
+ .kroneckerProduct(B1)
232
+ .mmul(A2.kroneckerProduct(S.z).kroneckerProduct(B2)));
233
+ clusterHam.add(kron1.mul(couplingConstants.get(n, k) / 2));
234
+ }
235
+ }
236
+ }
237
+ return clusterHam;
238
+ }
239
+ //# sourceMappingURL=simulateXYPeaks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"simulateXYPeaks.js","sourceRoot":"","sources":["../../../src/signals/simulation/simulateXYPeaks.ts"],"names":[],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { gyromagneticRatio } from '../constants/gyromagneticRatio';
1
+ import { gyromagneticRatio } from 'gyromagnetic-ratio';
2
2
  /**
3
3
  * calculate the frequency of a nucleus with respect to a reference nucleus
4
4
  */
@@ -1 +1 @@
1
- {"version":3,"file":"getFrequency.js","sourceRoot":"","sources":["../../src/utilities/getFrequency.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAU,MAAM,gCAAgC,CAAC;AAgB3E;;GAEG;AACH,MAAM,UAAU,YAAY;AAC1B;;GAEG;AACH,OAAgB,EAChB,mBAAwC;IAExC,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,mBAAmB,CAAC;IAE/D,cAAc,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IAEpC,OAAO,CACL,CAAC,SAAS,GAAG,iBAAiB,CAAC,OAAiB,CAAC,CAAC;QAClD,iBAAiB,CAAC,UAAoB,CAAC,CACxC,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,GAAG,OAAkB;IAC3C,IAAI,MAAM,GAAa,EAAE,CAAC;IAC1B,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE;QACvB,IAAI,CAAC,CAAC,CAAC,IAAI,iBAAiB,CAAC,EAAE;YAC7B,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SAChB;KACF;IACD,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;QACvB,MAAM,IAAI,KAAK,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;KAC3D;AACH,CAAC"}
1
+ {"version":3,"file":"getFrequency.js","sourceRoot":"","sources":["../../src/utilities/getFrequency.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAU,MAAM,oBAAoB,CAAC;AAgB/D;;GAEG;AACH,MAAM,UAAU,YAAY;AAC1B;;GAEG;AACH,OAAgB,EAChB,mBAAwC;IAExC,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,mBAAmB,CAAC;IAE/D,cAAc,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IAEpC,OAAO,CACL,CAAC,SAAS,GAAG,iBAAiB,CAAC,OAAiB,CAAC,CAAC;QAClD,iBAAiB,CAAC,UAAoB,CAAC,CACxC,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,GAAG,OAAkB;IAC3C,IAAI,MAAM,GAAa,EAAE,CAAC;IAC1B,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE;QACvB,IAAI,CAAC,CAAC,CAAC,IAAI,iBAAiB,CAAC,EAAE;YAC7B,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SAChB;KACF;IACD,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;QACvB,MAAM,IAAI,KAAK,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;KAC3D;AACH,CAAC"}
@@ -0,0 +1,34 @@
1
+ export function formatZones(signals) {
2
+ let zones = [];
3
+ for (const signal of signals) {
4
+ let minMax1 = [Number.MAX_VALUE, 0];
5
+ let minMax2 = [Number.MAX_VALUE, 0];
6
+ for (const peak of signal.peaks || []) {
7
+ if (peak.minX < minMax1[0]) {
8
+ minMax1[0] = peak.minX;
9
+ }
10
+ if (peak.maxX > minMax1[1]) {
11
+ minMax1[1] = peak.maxX;
12
+ }
13
+ if (peak.minY < minMax2[0]) {
14
+ minMax2[0] = peak.minY;
15
+ }
16
+ if (peak.maxY > minMax2[1]) {
17
+ minMax2[1] = peak.maxY;
18
+ }
19
+ }
20
+ zones.push({
21
+ x: {
22
+ from: minMax1[0],
23
+ to: minMax1[1],
24
+ },
25
+ y: {
26
+ from: minMax2[0],
27
+ to: minMax2[1],
28
+ },
29
+ signals: [signal],
30
+ });
31
+ }
32
+ return zones;
33
+ }
34
+ //# sourceMappingURL=formatZone.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"formatZone.js","sourceRoot":"","sources":["../../../src/xyz/util/formatZone.ts"],"names":[],"mappings":"AAGA,MAAM,UAAU,WAAW,CAAC,OAAsB;IAChD,IAAI,KAAK,GAAc,EAAE,CAAC;IAC1B,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE;QAC5B,IAAI,OAAO,GAAG,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QACpC,IAAI,OAAO,GAAG,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QACpC,KAAK,MAAM,IAAI,IAAI,MAAM,CAAC,KAAK,IAAI,EAAE,EAAE;YACrC,IAAI,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE;gBAC1B,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;aACxB;YACD,IAAI,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE;gBAC1B,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;aACxB;YACD,IAAI,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE;gBAC1B,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;aACxB;YACD,IAAI,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE;gBAC1B,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC;aACxB;SACF;QACD,KAAK,CAAC,IAAI,CAAC;YACT,CAAC,EAAE;gBACD,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;gBAChB,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC;aACf;YACD,CAAC,EAAE;gBACD,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;gBAChB,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC;aACf;YACD,OAAO,EAAE,CAAC,MAAM,CAAC;SAClB,CAAC,CAAC;KACJ;IACD,OAAO,KAAK,CAAC;AACf,CAAC"}
@@ -5,6 +5,7 @@ import simpleClustering from 'ml-simple-clustering';
5
5
  import { determineRealTop } from '../peaks/util/determineRealTop';
6
6
  import { getKernel } from '../peaks/util/getKernel';
7
7
  import * as PeakOptimizer from '../peaks/util/peakOptimizer';
8
+ import { formatZones } from './util/formatZone';
8
9
  const smallFilter = [
9
10
  [0, 0, 1, 2, 2, 2, 1, 0, 0],
10
11
  [0, 1, 4, 7, 7, 7, 4, 1, 0],
@@ -80,39 +81,6 @@ export function xyzAutoZonesPicking(spectraData, options) {
80
81
  }
81
82
  return formatZones(signals);
82
83
  }
83
- function formatZones(signals) {
84
- let zones = [];
85
- for (const signal of signals) {
86
- let minMax1 = [Number.MAX_VALUE, 0];
87
- let minMax2 = [Number.MAX_VALUE, 0];
88
- for (const peak of signal.peaks || []) {
89
- if (peak.minX < minMax1[0]) {
90
- minMax1[0] = peak.minX;
91
- }
92
- if (peak.maxX > minMax1[1]) {
93
- minMax1[1] = peak.maxX;
94
- }
95
- if (peak.minY < minMax2[0]) {
96
- minMax2[0] = peak.minY;
97
- }
98
- if (peak.maxY > minMax2[1]) {
99
- minMax2[1] = peak.maxY;
100
- }
101
- }
102
- zones.push({
103
- x: {
104
- from: minMax1[0],
105
- to: minMax1[1],
106
- },
107
- y: {
108
- from: minMax2[0],
109
- to: minMax2[1],
110
- },
111
- signals: [signal],
112
- });
113
- }
114
- return zones;
115
- }
116
84
  const createSignals2D = (peaks, options) => {
117
85
  let { nCols, nRows, absoluteData, originalData, observedFrequencies, tolerances, nuclei, realTopDetection, minY, maxY, minX, maxX, } = options;
118
86
  let [nucleusX, nucleusY] = nuclei;