nmr-processing 7.4.1 → 8.0.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 (52) hide show
  1. package/lib/assignment/getAssignments.d.ts +7 -9
  2. package/lib/assignment/getAssignments.js +1 -1
  3. package/lib/assignment/getAssignments.js.map +1 -1
  4. package/lib/assignment/nmrAssigment.d.ts +19 -27
  5. package/lib/assignment/utils/getAssignment/buildAssignments.d.ts +1 -1
  6. package/lib/assignment/utils/getAssignment/buildAssignments.js +5 -0
  7. package/lib/assignment/utils/getAssignment/buildAssignments.js.map +1 -1
  8. package/lib/assignment/utils/getAssignment/checkIDs.d.ts +3 -20
  9. package/lib/assignment/utils/getAssignment/checkIDs.js +5 -9
  10. package/lib/assignment/utils/getAssignment/checkIDs.js.map +1 -1
  11. package/lib/assignment/utils/getAssignment/formatData.d.ts +1 -1
  12. package/lib/assignment/utils/getAssignment/formatData.js +30 -3
  13. package/lib/assignment/utils/getAssignment/formatData.js.map +1 -1
  14. package/lib/assignment/utils/getAssignment/getTargetsAndCorrelations.d.ts +1 -1
  15. package/lib/assignment/utils/getAssignment/getTargetsAndCorrelations.js.map +1 -1
  16. package/lib/assignment/utils/getAssignment/partialScore.js +1 -1
  17. package/lib/assignment/utils/getAssignment/partialScore.js.map +1 -1
  18. package/lib/databases/getDatabase.d.ts +6 -1
  19. package/lib/databases/getDatabase.js +13 -3
  20. package/lib/databases/getDatabase.js.map +1 -1
  21. package/lib/index.d.ts +3 -1
  22. package/lib/prediction/predictAllSpectra.d.ts +22 -4
  23. package/lib/prediction/predictAllSpectra.js +102 -16
  24. package/lib/prediction/predictAllSpectra.js.map +1 -1
  25. package/lib/xyz/NMRSignal2D.d.ts +3 -3
  26. package/lib-esm/assignment/getAssignments.js +1 -1
  27. package/lib-esm/assignment/getAssignments.js.map +1 -1
  28. package/lib-esm/assignment/utils/getAssignment/buildAssignments.js +5 -0
  29. package/lib-esm/assignment/utils/getAssignment/buildAssignments.js.map +1 -1
  30. package/lib-esm/assignment/utils/getAssignment/checkIDs.js +5 -9
  31. package/lib-esm/assignment/utils/getAssignment/checkIDs.js.map +1 -1
  32. package/lib-esm/assignment/utils/getAssignment/formatData.js +30 -3
  33. package/lib-esm/assignment/utils/getAssignment/formatData.js.map +1 -1
  34. package/lib-esm/assignment/utils/getAssignment/getTargetsAndCorrelations.js.map +1 -1
  35. package/lib-esm/assignment/utils/getAssignment/partialScore.js +1 -1
  36. package/lib-esm/assignment/utils/getAssignment/partialScore.js.map +1 -1
  37. package/lib-esm/databases/getDatabase.js +13 -3
  38. package/lib-esm/databases/getDatabase.js.map +1 -1
  39. package/lib-esm/prediction/predictAllSpectra.js +102 -16
  40. package/lib-esm/prediction/predictAllSpectra.js.map +1 -1
  41. package/package.json +12 -12
  42. package/src/assignment/getAssignments.ts +8 -9
  43. package/src/assignment/nmrAssigment.ts +23 -21
  44. package/src/assignment/utils/getAssignment/buildAssignments.ts +7 -1
  45. package/src/assignment/utils/getAssignment/checkIDs.ts +14 -36
  46. package/src/assignment/utils/getAssignment/formatData.ts +41 -4
  47. package/src/assignment/utils/getAssignment/getTargetsAndCorrelations.ts +2 -1
  48. package/src/assignment/utils/getAssignment/partialScore.ts +2 -2
  49. package/src/databases/getDatabase.ts +19 -2
  50. package/src/index.ts +9 -1
  51. package/src/prediction/predictAllSpectra.ts +151 -14
  52. package/src/xyz/NMRSignal2D.ts +3 -3
@@ -8,21 +8,19 @@ import { AtomTypes, RestrictionByCS } from './utils/getAssignment/buildAssignmen
8
8
  export interface SpectraData1D {
9
9
  id?: string;
10
10
  ranges: NMRRange[];
11
- info?: any;
11
+ info: any;
12
12
  }
13
13
  export interface SpectraData2D {
14
14
  id?: string;
15
15
  zones: NMRZone[];
16
- info?: any;
16
+ /**
17
+ * object with information about the spectrum, it is mandatory at the moment
18
+ * to generate correlations.
19
+ */
20
+ info: any;
17
21
  }
18
22
  export declare type SpectraData = SpectraData1D | SpectraData2D;
19
23
  export interface GetAutoAssignmentInput {
20
- /**
21
- * It has the number of each atoms in the chemical structure. e.g. { C: 6, H: 6 }
22
- */
23
- atoms?: {
24
- [key: string]: number;
25
- };
26
24
  spectra: SpectraData[];
27
25
  /**
28
26
  * Instance of Molecule
@@ -77,5 +75,5 @@ export interface GetAssignmentsOptions {
77
75
  }
78
76
  export declare function getAssignments(input: GetAutoAssignmentInput, options?: GetAssignmentsOptions): Promise<{
79
77
  score: w;
80
- assignment: import("./utils/getAssignment/checkIDs").SpectraDataWithIds[];
78
+ assignment: import("./nmrAssigment").SpectraDataWithIds[];
81
79
  }[]>;
@@ -10,7 +10,7 @@ const checkIDs_1 = require("./utils/getAssignment/checkIDs");
10
10
  const getTargetsAndCorrelations_1 = require("./utils/getAssignment/getTargetsAndCorrelations");
11
11
  const getWorkFlow_1 = __importDefault(require("./utils/getAssignment/getWorkFlow"));
12
12
  async function getAssignments(input, options = {}) {
13
- let { restrictionByCS = {}, justAssign, minScore = 1, maxSolutions = 10, nbAllowedUnAssigned, timeout = 6000, predictionOptions = {}, predictions = {}, correlation: correlationOptions = {}, } = options;
13
+ let { restrictionByCS = {}, justAssign, minScore = 0.01, maxSolutions = 10, nbAllowedUnAssigned, timeout = 6000, predictionOptions = {}, predictions = {}, correlation: correlationOptions = {}, } = options;
14
14
  const { tolerance = { H: 0.2, C: 1 }, useChemicalShiftScore = false, chemicalShiftRestriction = true, } = restrictionByCS;
15
15
  const molecule = input.molecule;
16
16
  if (!molecule)
@@ -1 +1 @@
1
- {"version":3,"file":"getAssignments.js","sourceRoot":"","sources":["../../src/assignment/getAssignments.ts"],"names":[],"mappings":";;;;;;AACA,yDAAsE;AAQtE,6EAIgD;AAChD,6DAA0D;AAC1D,+FAA4F;AAC5F,oFAA4D;AA2ErD,KAAK,UAAU,cAAc,CAClC,KAA6B,EAC7B,UAAiC,EAAE;IAEnC,IAAI,EACF,eAAe,GAAG,EAAE,EACpB,UAAU,EACV,QAAQ,GAAG,CAAC,EACZ,YAAY,GAAG,EAAE,EACjB,mBAAmB,EACnB,OAAO,GAAG,IAAI,EACd,iBAAiB,GAAG,EAAE,EACtB,WAAW,GAAG,EAAE,EAChB,WAAW,EAAE,kBAAkB,GAAG,EAAE,GACrC,GAAG,OAAO,CAAC;IAEZ,MAAM,EACJ,SAAS,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAC5B,qBAAqB,GAAG,KAAK,EAC7B,wBAAwB,GAAG,IAAI,GAChC,GAAG,eAAe,CAAC;IAEpB,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;IAEhC,IAAI,CAAC,QAAQ;QAAE,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;IAEpE,QAAQ,CAAC,oBAAoB,EAAE,CAAC;IAChC,IAAA,qDAAiC,EAAC,QAAQ,CAAC,CAAC;IAE5C,MAAM,OAAO,GAAG,IAAA,mBAAQ,EAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IAExC,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,GAAG,IAAA,qDAAyB,EACzD,OAAO,EACP,kBAAkB,CACnB,CAAC;IACF,MAAM,EAAE,eAAe,EAAE,GAAG,IAAA,qBAAW,EAAC,YAAY,EAAE,UAAU,CAAC,CAAC;IAElE,MAAM,SAAS,GAAG,MAAM,IAAA,mCAAgB,EAAC;QACvC,eAAe,EAAE;YACf,SAAS;YACT,qBAAqB;YACrB,wBAAwB;SACzB;QACD,OAAO;QACP,QAAQ;QACR,OAAO;QACP,QAAQ;QACR,YAAY;QACZ,eAAe;QACf,mBAAmB;QACnB,YAAY;QACZ,OAAO;QACP,iBAAiB;QACjB,WAAW;KACZ,CAAC,CAAC;IAEH,OAAO,SAAS,CAAC;AACnB,CAAC;AAzDD,wCAyDC"}
1
+ {"version":3,"file":"getAssignments.js","sourceRoot":"","sources":["../../src/assignment/getAssignments.ts"],"names":[],"mappings":";;;;;;AACA,yDAAsE;AAQtE,6EAIgD;AAChD,6DAA0D;AAC1D,+FAA4F;AAC5F,oFAA4D;AA0ErD,KAAK,UAAU,cAAc,CAClC,KAA6B,EAC7B,UAAiC,EAAE;IAEnC,IAAI,EACF,eAAe,GAAG,EAAE,EACpB,UAAU,EACV,QAAQ,GAAG,IAAI,EACf,YAAY,GAAG,EAAE,EACjB,mBAAmB,EACnB,OAAO,GAAG,IAAI,EACd,iBAAiB,GAAG,EAAE,EACtB,WAAW,GAAG,EAAE,EAChB,WAAW,EAAE,kBAAkB,GAAG,EAAE,GACrC,GAAG,OAAO,CAAC;IAEZ,MAAM,EACJ,SAAS,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAC5B,qBAAqB,GAAG,KAAK,EAC7B,wBAAwB,GAAG,IAAI,GAChC,GAAG,eAAe,CAAC;IAEpB,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;IAEhC,IAAI,CAAC,QAAQ;QAAE,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;IAEpE,QAAQ,CAAC,oBAAoB,EAAE,CAAC;IAChC,IAAA,qDAAiC,EAAC,QAAQ,CAAC,CAAC;IAE5C,MAAM,OAAO,GAAG,IAAA,mBAAQ,EAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IACxC,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,GAAG,IAAA,qDAAyB,EACzD,OAAO,EACP,kBAAkB,CACnB,CAAC;IAEF,MAAM,EAAE,eAAe,EAAE,GAAG,IAAA,qBAAW,EAAC,YAAY,EAAE,UAAU,CAAC,CAAC;IAElE,MAAM,SAAS,GAAG,MAAM,IAAA,mCAAgB,EAAC;QACvC,eAAe,EAAE;YACf,SAAS;YACT,qBAAqB;YACrB,wBAAwB;SACzB;QACD,OAAO;QACP,QAAQ;QACR,OAAO;QACP,QAAQ;QACR,YAAY;QACZ,eAAe;QACf,mBAAmB;QACnB,YAAY;QACZ,OAAO;QACP,iBAAiB;QACjB,WAAW;KACZ,CAAC,CAAC;IAEH,OAAO,SAAS,CAAC;AACnB,CAAC;AAzDD,wCAyDC"}
@@ -1,28 +1,20 @@
1
- import { Molecule } from 'openchemlib';
2
- import type { NMRRange } from '../xy/NMRRange';
3
- import type { NMRZone } from '../xyz/NMRZone';
4
- export interface NMRAssignmentType {
5
- /**
6
- * It has the number of each atoms in the chemical structure. e.g. { C: 6, H: 6 }
7
- */
8
- atoms: {
9
- [key: string]: number;
10
- };
11
- /**
12
- * Contains the ranges for each nucleus or kind of experiment e.g. { H: [], C: [], apt: [], dept135: []}
13
- * the ranges represented with atom label only contain the range from a single pulse experiment or equivalent.
14
- */
15
- ranges: {
16
- [key: string]: NMRRange[];
17
- };
18
- /**
19
- * Contains the zones for each kind of experiment e.g. { H: [], C: [], apt: [], dept135: []};
20
- */
21
- zones: {
22
- [key: string]: NMRZone[];
23
- };
24
- /**
25
- * Instance of Molecule
26
- */
27
- molecule: Molecule;
1
+ import type { NMRRange, NMRSignal1D, NMRSignal2D, NMRZone } from '..';
2
+ import { MakeMandatory } from '../utilities/MakeMandatory';
3
+ import type { SpectraData1D, SpectraData2D } from './getAssignments';
4
+ export declare type NMRSignal1DWithId = MakeMandatory<NMRSignal1D, 'id'>;
5
+ export declare type NMRSignal2DWithId = MakeMandatory<NMRSignal2D, 'id'>;
6
+ export interface NMRZoneWithIds extends Omit<NMRZone, 'signals' | 'id'> {
7
+ id: string;
8
+ signals: Array<NMRSignal2DWithId>;
28
9
  }
10
+ export interface NMRRangeWithIds extends Omit<NMRRange, 'id' | 'signals'> {
11
+ id: string;
12
+ signals: Array<NMRSignal1DWithId>;
13
+ }
14
+ export interface SpectraData1DWithIds extends Omit<SpectraData1D, 'ranges'> {
15
+ ranges: NMRRangeWithIds[];
16
+ }
17
+ export interface SpectraData2DWithIds extends Omit<SpectraData2D, 'zones'> {
18
+ zones: NMRZoneWithIds[];
19
+ }
20
+ export declare type SpectraDataWithIds = SpectraData1DWithIds | SpectraData2DWithIds;
@@ -2,7 +2,7 @@ import { Values } from 'nmr-correlation';
2
2
  import { Molecule } from 'openchemlib';
3
3
  import { NMRSignal1D, PredictCarbonOptions, PredictProtonOptions } from '../../..';
4
4
  import { MakeMandatory } from '../../../utilities/MakeMandatory';
5
- import { SpectraDataWithIds } from './checkIDs';
5
+ import { SpectraDataWithIds } from '../../nmrAssigment';
6
6
  import { TargetsByAtomType } from './getTargetsAndCorrelations';
7
7
  export declare type AtomTypes = 'H' | 'C';
8
8
  export declare type CurrentAtoms = Array<AtomTypes>;
@@ -59,10 +59,12 @@ async function buildAssignments(props) {
59
59
  checkNMRSignal1D(joinedSignals);
60
60
  if (!predictions[atomType])
61
61
  predictions[atomType] = {};
62
+ let totalHydrogens = 0;
62
63
  for (let prediction of joinedSignals) {
63
64
  const diaID = prediction.diaIDs[0];
64
65
  const index = prediction.atoms[0];
65
66
  const allHydrogens = exports.getAllHydrogens[atomType](molecule, index);
67
+ totalHydrogens += prediction.nbAtoms * allHydrogens;
66
68
  predictions[atomType][diaID] = {
67
69
  ...prediction,
68
70
  diaIDIndex: index,
@@ -71,6 +73,9 @@ async function buildAssignments(props) {
71
73
  pathLength: pathLengthMatrix[index],
72
74
  };
73
75
  }
76
+ for (let diaID in predictions[atomType]) {
77
+ predictions[atomType][diaID].allHydrogens *= 100 / totalHydrogens;
78
+ }
74
79
  infoByAtomType[atomType] = {
75
80
  nSources: joinedSignals.length,
76
81
  currentIndex: 0,
@@ -1 +1 @@
1
- {"version":3,"file":"buildAssignments.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/buildAssignments.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"buildAssignments.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/buildAssignments.ts"],"names":[],"mappings":"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"}
@@ -1,23 +1,6 @@
1
- import type { NMRRange, NMRSignal1D, NMRSignal2D, NMRZone } from '../../..';
2
- import { MakeMandatory } from '../../../utilities/MakeMandatory';
3
- import type { SpectraData, SpectraData1D, SpectraData2D } from '../../getAssignments';
4
- export declare type NMRSignal1DWithId = MakeMandatory<NMRSignal1D, 'id'>;
5
- export declare type NMRSignal2DWithId = MakeMandatory<NMRSignal2D, 'id'>;
6
- export interface NMRZoneWithIds extends Omit<NMRZone, 'signals' | 'id'> {
7
- id: string;
8
- signals: Array<NMRSignal2DWithId>;
9
- }
10
- export interface NMRRangeWithIds extends Omit<NMRRange, 'id' | 'signals'> {
11
- id: string;
12
- signals: Array<NMRSignal1DWithId>;
13
- }
14
- export interface SpectraData1DWithIds extends Omit<SpectraData1D, 'ranges'> {
15
- ranges: NMRRangeWithIds[];
16
- }
17
- export interface SpectraData2DWithIds extends Omit<SpectraData2D, 'zones'> {
18
- zones: NMRZoneWithIds[];
19
- }
20
- export declare type SpectraDataWithIds = SpectraData1DWithIds | SpectraData2DWithIds;
1
+ import type { NMRRange, NMRZone } from '../../..';
2
+ import type { SpectraData } from '../../getAssignments';
3
+ import type { SpectraDataWithIds, NMRRangeWithIds, NMRZoneWithIds } from '../../nmrAssigment';
21
4
  export declare function checkIDs(input?: SpectraData[]): SpectraDataWithIds[];
22
5
  export declare function hasIDs(data: NMRRange[] | NMRZone[]): asserts data is NMRRangeWithIds[] | NMRZoneWithIds[];
23
6
  export declare function addIDs(data: NMRRange[] | NMRZone[]): NMRRangeWithIds[] | NMRZoneWithIds[];
@@ -10,17 +10,13 @@ function checkIDs(input = []) {
10
10
  let inputClone = JSON.parse(JSON.stringify(input));
11
11
  let spectra = [];
12
12
  for (const spectraData of inputClone) {
13
+ if (!('info' in spectraData)) {
14
+ throw new Error('each spectrum should contain info properties with nucleus information');
15
+ }
13
16
  const { info, id } = spectraData;
14
17
  if ((0, isSpectraData1D_1.isSpectraData1D)(spectraData)) {
15
- let data = addIDs(spectraData.ranges);
16
- for (const element of data) {
17
- const { integration } = element;
18
- for (let signal of element.signals || []) {
19
- if (!signal.integration)
20
- signal.integration = integration;
21
- }
22
- }
23
- spectra.push({ id, info, ranges: data });
18
+ let ranges = addIDs(spectraData.ranges);
19
+ spectra.push({ id, info, ranges });
24
20
  }
25
21
  else {
26
22
  let data = addIDs(spectraData.zones);
@@ -1 +1 @@
1
- {"version":3,"file":"checkIDs.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/checkIDs.ts"],"names":[],"mappings":";;;;;;AAOA,+DAAuC;AAEvC,uDAAoD;AAwBpD,SAAgB,QAAQ,CAAC,QAAuB,EAAE;IAChD,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAkB,CAAC;IACpE,IAAI,OAAO,GAAyB,EAAE,CAAC;IACvC,KAAK,MAAM,WAAW,IAAI,UAAU,EAAE;QACpC,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,GAAG,WAAW,CAAC;QACjC,IAAI,IAAA,iCAAe,EAAC,WAAW,CAAC,EAAE;YAChC,IAAI,IAAI,GAAG,MAAM,CAAC,WAAW,CAAC,MAAM,CAAsB,CAAC;YAC3D,KAAK,MAAM,OAAO,IAAI,IAAI,EAAE;gBAC1B,MAAM,EAAE,WAAW,EAAE,GAAG,OAAO,CAAC;gBAChC,KAAK,IAAI,MAAM,IAAI,OAAO,CAAC,OAAO,IAAI,EAAE,EAAE;oBACxC,IAAI,CAAC,MAAM,CAAC,WAAW;wBAAE,MAAM,CAAC,WAAW,GAAG,WAAW,CAAC;iBAC3D;aACF;YACD,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;SAC1C;aAAM;YACL,IAAI,IAAI,GAAG,MAAM,CAAC,WAAW,CAAC,KAAK,CAAqB,CAAC;YACzD,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;SACzC;KACF;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AApBD,4BAoBC;AAED,SAAgB,MAAM,CACpB,IAA4B;IAE5B,KAAK,MAAM,OAAO,IAAI,IAAI,EAAE;QAC1B,IAAI,CAAC,OAAO,CAAC,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAC/D,KAAK,IAAI,MAAM,IAAI,OAAO,CAAC,OAAO,IAAI,EAAE,EAAE;YACxC,IAAI,CAAC,MAAM,CAAC,EAAE;gBAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;SAC3D;KACF;AACH,CAAC;AATD,wBASC;AAED,SAAgB,MAAM,CAAC,IAA4B;IACjD,KAAK,MAAM,OAAO,IAAI,IAAI,EAAE;QAC1B,IAAI,CAAC,OAAO,CAAC,EAAE;YAAE,OAAO,CAAC,EAAE,GAAG,IAAA,oBAAU,GAAE,CAAC;QAC3C,KAAK,IAAI,MAAM,IAAI,OAAO,CAAC,OAAO,IAAI,EAAE,EAAE;YACxC,IAAI,CAAC,MAAM,CAAC,EAAE;gBAAE,MAAM,CAAC,EAAE,GAAG,IAAA,oBAAU,GAAE,CAAC;SAC1C;KACF;IACD,MAAM,CAAC,IAAI,CAAC,CAAC;IACb,OAAO,IAAI,CAAC;AACd,CAAC;AATD,wBASC"}
1
+ {"version":3,"file":"checkIDs.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/checkIDs.ts"],"names":[],"mappings":";;;;;;AAOA,+DAAuC;AAEvC,uDAAoD;AAEpD,SAAgB,QAAQ,CAAC,QAAuB,EAAE;IAChD,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAkB,CAAC;IACpE,IAAI,OAAO,GAAyB,EAAE,CAAC;IACvC,KAAK,MAAM,WAAW,IAAI,UAAU,EAAE;QACpC,IAAI,CAAC,CAAC,MAAM,IAAI,WAAW,CAAC,EAAE;YAC5B,MAAM,IAAI,KAAK,CACb,uEAAuE,CACxE,CAAC;SACH;QAED,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,GAAG,WAAW,CAAC;QACjC,IAAI,IAAA,iCAAe,EAAC,WAAW,CAAC,EAAE;YAChC,IAAI,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC,MAAM,CAAsB,CAAC;YAC7D,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC;SACpC;aAAM;YACL,IAAI,IAAI,GAAG,MAAM,CAAC,WAAW,CAAC,KAAK,CAAqB,CAAC;YACzD,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;SACzC;KACF;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AApBD,4BAoBC;AAED,SAAgB,MAAM,CACpB,IAA4B;IAE5B,KAAK,MAAM,OAAO,IAAI,IAAI,EAAE;QAC1B,IAAI,CAAC,OAAO,CAAC,EAAE;YAAE,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAC/D,KAAK,IAAI,MAAM,IAAI,OAAO,CAAC,OAAO,IAAI,EAAE,EAAE;YACxC,IAAI,CAAC,MAAM,CAAC,EAAE;gBAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;SAC3D;KACF;AACH,CAAC;AATD,wBASC;AAED,SAAgB,MAAM,CAAC,IAA4B;IACjD,KAAK,MAAM,OAAO,IAAI,IAAI,EAAE;QAC1B,IAAI,CAAC,OAAO,CAAC,EAAE;YAAE,OAAO,CAAC,EAAE,GAAG,IAAA,oBAAU,GAAE,CAAC;QAC3C,KAAK,IAAI,MAAM,IAAI,OAAO,CAAC,OAAO,IAAI,EAAE,EAAE;YACxC,IAAI,CAAC,MAAM,CAAC,EAAE;gBAAE,MAAM,CAAC,EAAE,GAAG,IAAA,oBAAU,GAAE,CAAC;SAC1C;KACF;IACD,MAAM,CAAC,IAAI,CAAC,CAAC;IACb,OAAO,IAAI,CAAC;AACd,CAAC;AATD,wBASC"}
@@ -1,4 +1,4 @@
1
- import { NMRRangeWithIds, NMRZoneWithIds, SpectraData1DWithIds, SpectraData2DWithIds, SpectraDataWithIds } from './checkIDs';
1
+ import { NMRRangeWithIds, NMRZoneWithIds, SpectraData1DWithIds, SpectraData2DWithIds, SpectraDataWithIds } from '../../nmrAssigment';
2
2
  interface SpectraData1DFormatted extends Omit<SpectraData1DWithIds, 'ranges'> {
3
3
  ranges: {
4
4
  values: NMRRangeWithIds[];
@@ -6,15 +6,42 @@ function formatData(input = []) {
6
6
  let inputClone = JSON.parse(JSON.stringify(input));
7
7
  let spectra = [];
8
8
  for (const spectraData of inputClone) {
9
- const { info } = spectraData;
9
+ const { id, info } = spectraData;
10
10
  if ((0, isSpectraData1D_1.isSpectraData1D)(spectraData)) {
11
- spectra.push({ info, ranges: { values: spectraData.ranges } });
11
+ const ranges = rescaleIntegration({
12
+ id,
13
+ info,
14
+ ranges: spectraData.ranges,
15
+ });
16
+ spectra.push({ id, info, ranges: { values: ranges } });
12
17
  }
13
18
  else {
14
- spectra.push({ info, zones: { values: spectraData.zones } });
19
+ spectra.push({ id, info, zones: { values: spectraData.zones } });
15
20
  }
16
21
  }
17
22
  return spectra;
18
23
  }
19
24
  exports.formatData = formatData;
25
+ function rescaleIntegration(spectrum) {
26
+ if (spectrum.info.nucleus !== '1H')
27
+ return spectrum.ranges;
28
+ let totalIntegration = spectrum.ranges.reduce((total, range) => (range.integration ? total + range.integration : total), 0);
29
+ for (let range of spectrum.ranges) {
30
+ if (range.integration) {
31
+ range.integration *= 100 / totalIntegration;
32
+ if (range.signals) {
33
+ const totalSignalIntegration = range.signals.reduce((total, signal) => signal.integration ? total + signal.integration : total, 0);
34
+ for (let signal of range.signals) {
35
+ if (signal.integration) {
36
+ signal.integration *= range.integration / totalSignalIntegration;
37
+ }
38
+ else {
39
+ signal.integration = range.integration;
40
+ }
41
+ }
42
+ }
43
+ }
44
+ }
45
+ return spectrum.ranges;
46
+ }
20
47
  //# sourceMappingURL=formatData.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"formatData.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/formatData.ts"],"names":[],"mappings":";;;AAOA,uDAAoD;AAapD,SAAgB,UAAU,CACxB,QAA8B,EAAE;IAEhC,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAyB,CAAC;IAC3E,IAAI,OAAO,GAA2B,EAAE,CAAC;IACzC,KAAK,MAAM,WAAW,IAAI,UAAU,EAAE;QACpC,MAAM,EAAE,IAAI,EAAE,GAAG,WAAW,CAAC;QAC7B,IAAI,IAAA,iCAAe,EAAC,WAAW,CAAC,EAAE;YAChC,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,WAAW,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;SAChE;aAAM;YACL,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,WAAW,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;SAC9D;KACF;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAdD,gCAcC"}
1
+ {"version":3,"file":"formatData.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/formatData.ts"],"names":[],"mappings":";;;AAQA,uDAAoD;AAapD,SAAgB,UAAU,CACxB,QAA8B,EAAE;IAEhC,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAyB,CAAC;IAC3E,IAAI,OAAO,GAA2B,EAAE,CAAC;IACzC,KAAK,MAAM,WAAW,IAAI,UAAU,EAAE;QACpC,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,GAAG,WAAW,CAAC;QACjC,IAAI,IAAA,iCAAe,EAAC,WAAW,CAAC,EAAE;YAChC,MAAM,MAAM,GAAG,kBAAkB,CAAC;gBAChC,EAAE;gBACF,IAAI;gBACJ,MAAM,EAAE,WAAW,CAAC,MAAM;aAC3B,CAAC,CAAC;YACH,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;SACxD;aAAM;YACL,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,WAAW,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;SAClE;KACF;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAnBD,gCAmBC;AAED,SAAS,kBAAkB,CAAC,QAA8B;IACxD,IAAI,QAAQ,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI;QAAE,OAAO,QAAQ,CAAC,MAAM,CAAC;IAE3D,IAAI,gBAAgB,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAM,CAC3C,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,GAAG,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,EACzE,CAAC,CACF,CAAC;IAEF,KAAK,IAAI,KAAK,IAAI,QAAQ,CAAC,MAAM,EAAE;QACjC,IAAI,KAAK,CAAC,WAAW,EAAE;YACrB,KAAK,CAAC,WAAW,IAAI,GAAG,GAAG,gBAAgB,CAAC;YAC5C,IAAI,KAAK,CAAC,OAAO,EAAE;gBACjB,MAAM,sBAAsB,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CACjD,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,CAChB,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,EACzD,CAAC,CACF,CAAC;gBACF,KAAK,IAAI,MAAM,IAAI,KAAK,CAAC,OAAO,EAAE;oBAChC,IAAI,MAAM,CAAC,WAAW,EAAE;wBACtB,MAAM,CAAC,WAAW,IAAI,KAAK,CAAC,WAAW,GAAG,sBAAsB,CAAC;qBAClE;yBAAM;wBACL,MAAM,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;qBACxC;iBACF;aACF;SACF;KACF;IAED,OAAO,QAAQ,CAAC,MAAM,CAAC;AACzB,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import type { Correlation, Link } from 'nmr-correlation';
2
- import { SpectraDataWithIds } from './checkIDs';
2
+ import { SpectraDataWithIds } from '../../nmrAssigment';
3
3
  export interface CorrelationWithIntegration extends Pick<Correlation, 'link' | 'atomType' | 'label' | 'attachment' | 'protonsCount'> {
4
4
  integration: number;
5
5
  indirectLinks: Array<Link>;
@@ -1 +1 @@
1
- {"version":3,"file":"getTargetsAndCorrelations.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/getTargetsAndCorrelations.ts"],"names":[],"mappings":";;;AAAA,qDAAuD;AAIvD,6CAA0C;AAC1C,uFAAoF;AAsBpF,SAAgB,yBAAyB,CACvC,OAA6B,EAC7B,UAAe,EAAE;IAEjB,gFAAgF;IAChF,8DAA8D;IAE9D,MAAM,EAAE,SAAS,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,GAAG,OAAO,CAAC;IAErD,MAAM,WAAW,GAAG,IAAA,uBAAU,EAAC,OAAO,CAAC,CAAC;IACxC,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,IAAA,sCAAoB,EAAC,WAAW,EAAE;QACjE,SAAS;KACV,CAAC,CAAC;IAEH,IAAI,OAAO,GAAQ,EAAE,CAAC;IACtB,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE;QACtC,IAAI,WAAW,CAAC,MAAM;YAAE,SAAS;QACjC,MAAM,EAAE,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,WAAW,CAAC;QAC/C,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;YAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QAC/C,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,GAAG,WAAW,CAAC;QAC1C,IAAI,QAAQ,KAAK,GAAG,EAAE;YACpB,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,WAAW;gBACrC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC;SAC1C;aAAM;YACL,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,WAAW,GAAG,IAAA,iEAA+B,EACvE,WAAW,EACX,YAAY,CACb,CAAC;SACH;KACF;IAED,OAAO;QACL,OAAO;QACP,YAAY;KACb,CAAC;AACJ,CAAC;AAnCD,8DAmCC"}
1
+ {"version":3,"file":"getTargetsAndCorrelations.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/getTargetsAndCorrelations.ts"],"names":[],"mappings":";;;AAAA,qDAAuD;AAKvD,6CAA0C;AAC1C,uFAAoF;AAsBpF,SAAgB,yBAAyB,CACvC,OAA6B,EAC7B,UAAe,EAAE;IAEjB,gFAAgF;IAChF,8DAA8D;IAE9D,MAAM,EAAE,SAAS,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,GAAG,OAAO,CAAC;IAErD,MAAM,WAAW,GAAG,IAAA,uBAAU,EAAC,OAAO,CAAC,CAAC;IACxC,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,IAAA,sCAAoB,EAAC,WAAW,EAAE;QACjE,SAAS;KACV,CAAC,CAAC;IAEH,IAAI,OAAO,GAAQ,EAAE,CAAC;IACtB,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE;QACtC,IAAI,WAAW,CAAC,MAAM;YAAE,SAAS;QACjC,MAAM,EAAE,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,WAAW,CAAC;QAC/C,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;YAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QAC/C,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,GAAG,WAAW,CAAC;QAC1C,IAAI,QAAQ,KAAK,GAAG,EAAE;YACpB,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,WAAW;gBACrC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC;SAC1C;aAAM;YACL,OAAO,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,WAAW,GAAG,IAAA,iEAA+B,EACvE,WAAW,EACX,YAAY,CACb,CAAC;SACH;KACF;IAED,OAAO;QACL,OAAO;QACP,YAAY;KACb,CAAC;AACJ,CAAC;AAnCD,8DAmCC"}
@@ -76,7 +76,7 @@ function partialScore(partial, props) {
76
76
  total += prediction.allHydrogens;
77
77
  }
78
78
  }
79
- if (total - integration >= 0.5) {
79
+ if (total - integration >= 5) {
80
80
  return 0;
81
81
  }
82
82
  }
@@ -1 +1 @@
1
- {"version":3,"file":"partialScore.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/partialScore.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"partialScore.js","sourceRoot":"","sources":["../../../../src/assignment/utils/getAssignment/partialScore.ts"],"names":[],"mappings":";;;;;;AAAA,qDAAsD;AAatD,8GAAsF;AAmBtF,SAAgB,YAAY,CAAC,OAAgB,EAAE,KAA0B;IACvE,MAAM,EACJ,2BAA2B,EAC3B,eAAe,EACf,eAAe,EACf,WAAW,EACX,OAAO,EACP,YAAY,GACb,GAAG,KAAK,CAAC;IAEV,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,qBAAqB,EAAE,GAAG,eAAe,CAAC;IAC1E,IAAI,WAAW,GAAG,CAAC,CAAC;IACpB,IAAI,YAAY,GAAG,CAAC,CAAC;IACrB,IAAI,cAAc,GAA4B,EAAE,CAAC;IACjD,IAAI,wBAAwB,GAAgC,EAAE,CAAC;IAC/D,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAgB,CAAC;IACtD,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;QAChC,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,MAAM,EAAE,mBAAmB,EAAE,GAAG,eAAe,CAAC,QAAQ,CAAC,CAAC;QAC1D,MAAM,qBAAqB,GAAsB,EAAE,CAAC;QACpD,MAAM,iBAAiB,GAAG,OAAO,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAClD,cAAc,CAAC,QAAQ,CAAC,GAAG,qBAAqB,CAAC;QACjD,wBAAwB,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QACxC,YAAY,IAAI,iBAAiB,CAAC,MAAM,CAAC;QACzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,iBAAiB,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACjD,MAAM,QAAQ,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAAC;YACtC,IAAI,QAAQ,IAAI,QAAQ,KAAK,GAAG,EAAE;gBAChC,wBAAwB,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC3C,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,EAAE;oBACpC,qBAAqB,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;iBACtC;gBACD,qBAAqB,CAAC,QAAQ,CAAC,CAAC,IAAI,CAClC,2BAA2B,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CACzC,CAAC;aACH;YACD,IAAI,QAAQ,KAAK,GAAG;gBAAE,UAAU,EAAE,CAAC;SACpC;QAED,IAAI,UAAU,GAAG,mBAAmB;YAAE,OAAO,CAAC,CAAC;QAC/C,WAAW,IAAI,UAAU,CAAC;KAC3B;IAED,MAAM,oBAAoB,GAAsB,EAAE,CAAC;IACnD,KAAK,MAAM,QAAQ,IAAI,cAAc,EAAE;QACrC,oBAAoB,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC;KACxE;IAED,MAAM,0BAA0B,GAAG,MAAM,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;IACvE,IACE,0BAA0B,CAAC,MAAM,CAC/B,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAC5C,CAAC,CACF,KAAK,0BAA0B,CAAC,MAAM,EACvC;QACA,OAAO,CAAC,CAAC;KACV;IAED,MAAM,oBAAoB,GAAG,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE,WAAW,CAAC,CAAC;IACjE,wBAAwB;IACxB,MAAM,gBAAgB,GAIhB,EAAE,CAAC;IAET,KAAK,MAAM,QAAQ,IAAI,OAAO,EAAE;QAC9B,IAAI,QAAQ,KAAK,GAAG,IAAI,oBAAoB,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YACjE,gBAAgB,CAAC,IAAI,CACnB,GAAG,IAAA,4CAAkC,EACnC,oBAAoB,CAAC,QAAQ,CAAC,EAC9B,OAAO,CAAC,QAAQ,CAAC,EACjB,YAAY,CACb,CACF,CAAC;SACH;aAAM;YACL,KAAK,IAAI,QAAQ,IAAI,oBAAoB,CAAC,QAAQ,CAAC,EAAE;gBACnD,gBAAgB,CAAC,IAAI,CAAC;oBACpB,QAAQ;oBACR,SAAS,EAAE,CAAC,QAAQ,CAAC;oBACrB,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,WAAW;iBAC7C,CAAC,CAAC;aACJ;SACF;KACF;IAED,KAAK,MAAM,KAAK,IAAI,gBAAgB,EAAE;QACpC,MAAM,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;QACxC,IAAI,WAAW,KAAK,SAAS,IAAI,KAAK,CAAC,WAAW,CAAC;YAAE,SAAS;QAE9D,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,KAAK,IAAI,QAAQ,IAAI,KAAK,CAAC,SAAS,EAAE;YACpC,IAAI,cAAc,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC;YACxD,KAAK,MAAM,KAAK,IAAI,cAAc,EAAE;gBAClC,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,gBAAgB,EAAE,GAC9C,oBAAoB,CAAC,KAAK,CAAC,CAAC;gBAC9B,IAAI,QAAQ,KAAK,gBAAgB;oBAAE,KAAK,IAAI,UAAU,CAAC,YAAY,CAAC;aACrE;SACF;QACD,IAAI,KAAK,GAAG,WAAW,IAAI,CAAC,EAAE;YAC5B,OAAO,CAAC,CAAC;SACV;KACF;IAED,sBAAsB;IACtB,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,IAAI,kBAAkB,GAAG,CAAC,CAAC;IAC3B,IAAI,qBAAqB,EAAE;QACzB,kBAAkB,GAAG,CAAC,CAAC;QACvB,KAAK,GAAG,CAAC,CAAC;QACV,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAgB,EAAE;YAC1D,MAAM,mBAAmB,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;YAC9C,MAAM,mBAAmB,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;YAC9C,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,mBAAmB,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBAC/D,MAAM,QAAQ,GAAG,mBAAmB,CAAC,KAAK,CAAC,CAAC;gBAC5C,IAAI,QAAQ,IAAI,QAAQ,KAAK,GAAG,EAAE;oBAChC,KAAK,EAAE,CAAC;oBACR,IAAI,KAAK,GAAG,2BAA2B,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,CAAC;oBACzD,IAAI,MAAM,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,CAAC;oBAC1C,IAAI,MAAM,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;oBAC3C,IAAI,KAAK,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;oBAClC,sBAAsB;oBACtB,iDAAiD;oBACjD,IAAI;oBACJ,IAAI,OAAO,MAAM,CAAC,KAAK,KAAK,WAAW,EAAE;wBACvC,sCAAsC;wBACtC,kBAAkB,IAAI,CAAC,CAAC;qBACzB;yBAAM;wBACL,MAAM,WAAW,GAAG,IAAA,qCAAmB,EAAC,MAAM,CAAC,CAAC;wBAEhD,IAAI,WAAW,KAAK,SAAS,EAAE;4BAC7B,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAC;yBAC9C;wBAED,IAAI,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,WAAW,CAAC,CAAC;wBAChD,IAAI,IAAI,GAAG,KAAK,EAAE;4BAChB,wCAAwC;4BACxC,kBAAkB,IAAI,CAAC,CAAC;yBACzB;6BAAM;4BACL,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC;4BAC9B,kBAAkB,IAAI,CAAC,CAAC,IAAI,GAAG,KAAK,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC;yBAClD;qBACF;iBACF;aACF;SACF;QACD,IAAI,KAAK,GAAG,CAAC,EAAE;YACb,kBAAkB,IAAI,KAAK,CAAC;SAC7B;KACF;IAED,IAAI,SAAS,GAAG,CAAC,CAAC;IAElB,IAAI,cAAc,CAAC,oBAAoB,CAAC,GAAG,CAAC,EAAE;QAC5C,IAAI,aAAa,GAA8B,EAAE,CAAC;QAClD,IAAI,YAAY,GAAkD,EAAE,CAAC;QAErE,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,IAAI,CAChC,wBAAwB,CACV,EAAE;YAChB,YAAY,GAAG,YAAY,CAAC,MAAM,CAChC,wBAAwB,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,CACxE,CAAC;SACH;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC5C,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;YAC/D,MAAM,WAAW,GACf,WAAW,CAAC,SAAS,CAAC,CAAC,2BAA2B,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;YACzE,KAAK,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAChD,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;gBAC/D,MAAM,WAAW,GACf,WAAW,CAAC,SAAS,CAAC,CACpB,2BAA2B,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAC/C,CAAC;gBACJ,IAAI,UAAU,GAAG,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;gBAChE,IAAI,UAAU,GAAG,UAAU,GAAG,CAAC,CAAC;gBAEhC,IAAI,QAAQ,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC;gBAC1C,IAAI,QAAQ,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC;gBAE1C,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ;oBAAE,SAAS;gBAErC,IAAI,eAAe,GACjB,QAAQ,GAAG,QAAQ;oBACjB,CAAC,CAAC,GAAG,QAAQ,IAAI,QAAQ,EAAE;oBAC3B,CAAC,CAAC,GAAG,QAAQ,IAAI,QAAQ,EAAE,CAAC;gBAEhC,IAAI,SAAS,GAAG,YAAY,CAC1B;oBACE,IAAI,EAAE;wBACJ,QAAQ,EAAE,QAAQ;wBAClB,QAAQ,EAAE,SAAS;qBACpB;oBACD,EAAE,EAAE;wBACF,QAAQ,EAAE,QAAQ;wBAClB,QAAQ,EAAE,SAAS;qBACpB;iBACF,EACD,OAAO,CACR,CAAC;gBAEF,IAAI,cAAc,GAAG,UAAU;oBAC7B,CAAC,CAAC,SAAS;wBACT,CAAC,CAAC,CAAC;wBACH,CAAC,CAAC,CAAC;oBACL,CAAC,CAAC,CAAC,SAAS;wBACZ,CAAC,CAAC,CAAC;wBACH,CAAC,CAAC,CAAC,CAAC;gBAEN,aAAa,CAAC,eAAe,CAAC,GAAG,aAAa,CAAC,eAAe,CAAC;oBAC7D,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,eAAe,CAAC,EAAE,cAAc,CAAC;oBAC1D,CAAC,CAAC,cAAc,CAAC;aACpB;SACF;QAED,IAAI,MAAM,GAAG,CAAC,CAAC;QACf,KAAK,IAAI,GAAG,IAAI,aAAa,EAAE;YAC7B,MAAM,IAAI,aAAa,CAAC,GAAG,CAAC,CAAC;SAC9B;QAED,SAAS;YACP,MAAM,GAAG,CAAC,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;KACpE;IACD,MAAM,eAAe,GAAG,WAAW,GAAG,YAAY,CAAC;IACnD,IAAI,kBAAkB,KAAK,CAAC;QAAE,OAAO,SAAS,GAAG,eAAe,CAAC;IAEjE,IAAI,SAAS,KAAK,CAAC;QAAE,OAAO,kBAAkB,GAAG,eAAe,CAAC;IACjE,OAAO,CAAC,kBAAkB,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,eAAe,CAAC;AAChE,CAAC;AApOD,oCAoOC;AAaD,SAAS,YAAY,CACnB,QAA4B,EAC5B,YAA+B;IAE/B,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,GAAG,QAAQ,CAAC;IAC9B,IAAI,IAAI,CAAC,QAAQ,KAAK,EAAE,CAAC,QAAQ;QAAE,OAAO,IAAI,CAAC;IAC/C,IAAI,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC9D,IAAI,YAAY,GAAG,YAAY,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC;IAC1D,KAAK,MAAM,KAAK,IAAI,YAAY,CAAC,IAAI,EAAE;QACrC,KAAK,MAAM,IAAI,IAAI,YAAY,CAAC,IAAI,EAAE;YACpC,IAAI,IAAI,CAAC,MAAM,CAAC,EAAE,KAAK,KAAK,CAAC,MAAM,CAAC,EAAE;gBAAE,OAAO,IAAI,CAAC;SACrD;KACF;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,aAAa,CAAC,WAAkC,EAAE,KAAa;IACtE,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAgB,CAAC;IAC1D,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;QAChC,MAAM,oBAAoB,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAI,CAAC,oBAAoB;YAAE,MAAM,IAAI,KAAK,CAAC,iBAAiB,QAAQ,EAAE,CAAC,CAAC;QACxE,IAAI,oBAAoB,CAAC,KAAK,CAAC,EAAE;YAC/B,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,oBAAoB,CAAC,KAAK,CAAC,EAAE,CAAC;SAC9D;KACF;IACD,MAAM,IAAI,KAAK,CAAC,+BAA+B,KAAK,EAAE,CAAC,CAAC;AAC1D,CAAC;AAED,SAAS,cAAc,CAAC,OAA0B;IAChD,IAAI,GAAG,GAAG,CAAC,CAAC;IACZ,KAAK,MAAM,IAAI,IAAI,OAAO,EAAE;QAC1B,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC;KAC7B;IACD,OAAO,GAAG,CAAC;AACb,CAAC"}
@@ -1,2 +1,7 @@
1
1
  import { DatabaseNMREntry } from './DatabaseNMREntry';
2
- export declare function getDatabase(url?: string): Promise<DatabaseNMREntry[]>;
2
+ export declare function getDatabase(url?: string, options?: {
3
+ /**
4
+ * @default 'tsv'
5
+ */
6
+ format?: 'tsv' | 'json';
7
+ }): Promise<DatabaseNMREntry[]>;
@@ -3,13 +3,23 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.getDatabase = void 0;
4
4
  const cross_fetch_1 = require("cross-fetch");
5
5
  const resurrectRange_1 = require("../utilities/resurrectRange");
6
- async function getDatabase(url = 'https://docs.google.com/spreadsheets/d/1uwyq_L38PMRWCcT4If_EhPbHKyY3q_2tpjV8vr5_zh0/edit?usp=sharing') {
6
+ async function getDatabase(url = 'https://docs.google.com/spreadsheets/d/1uwyq_L38PMRWCcT4If_EhPbHKyY3q_2tpjV8vr5_zh0/edit?usp=sharing', options = {}) {
7
+ const { format = 'tsv' } = options;
7
8
  if (url.includes('google.com')) {
8
9
  url = `https://googledocs.cheminfo.org/spreadsheets/d/${extractGoogleUUID(url)}/export?format=tsv`;
9
10
  }
11
+ let parsed;
10
12
  const response = await (0, cross_fetch_1.fetch)(url);
11
- const result = await response.text();
12
- const parsed = parseData(result);
13
+ switch (format) {
14
+ case 'tsv':
15
+ parsed = parseData(await response.text());
16
+ break;
17
+ case 'json':
18
+ parsed = await response.json();
19
+ break;
20
+ default:
21
+ throw new Error('unknown database format');
22
+ }
13
23
  const results = [];
14
24
  for (let line of parsed.data) {
15
25
  const result = {
@@ -1 +1 @@
1
- {"version":3,"file":"getDatabase.js","sourceRoot":"","sources":["../../src/databases/getDatabase.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"getDatabase.js","sourceRoot":"","sources":["../../src/databases/getDatabase.ts"],"names":[],"mappings":"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"}
package/lib/index.d.ts CHANGED
@@ -28,10 +28,12 @@ export * from './databases/getDatabase';
28
28
  export * from './databases/carbonImpurities';
29
29
  export * from './databases/protonImpurities';
30
30
  export type { NMRSignal1D } from './signals/NMRSignal1D';
31
- export type { NMRSignal2D } from './xyz/NMRSignal2D';
31
+ export type { NMRSignal2D, Signal2DProjection } from './xyz/NMRSignal2D';
32
32
  export type { NMRRange } from './xy/NMRRange';
33
33
  export type { NMRZone } from './xyz/NMRZone';
34
34
  export type { NMRPeak1D } from './peaks/NMRPeak1D';
35
35
  export type { Prediction1D } from './prediction/prediction1D';
36
36
  export type { Jcoupling } from './signals/jcoupling';
37
+ export type { DatabaseNMREntry } from './databases/DatabaseNMREntry';
37
38
  export type { DataBaseLevelStructure, DataBaseStructure, } from './prediction/dataStructure';
39
+ export type { NMRSignal1DWithId, NMRSignal2DWithId, SpectraData1DWithIds, SpectraData2DWithIds, SpectraDataWithIds, } from './assignment/nmrAssigment';
@@ -1,5 +1,5 @@
1
+ import { FromTo, PointXY } from 'cheminfo-types';
1
2
  import type { Molecule } from 'openchemlib';
2
- import { OptionsSignalsToXY } from '../signals/signalsToXY';
3
3
  import { PredictAllOptions } from './predictAll';
4
4
  /**
5
5
  * This function will generate an object compatible with NMR-ium
@@ -7,12 +7,30 @@ import { PredictAllOptions } from './predictAll';
7
7
  * @param molecule
8
8
  * @param options
9
9
  */
10
- export declare function predictAllSpectra(molecule: Molecule, options?: {
10
+ interface OneDOptions {
11
+ proton: FromTo;
12
+ carbon: FromTo;
13
+ nbPoints: number;
14
+ lineWidth: number;
15
+ }
16
+ interface TwoDOptions {
17
+ from: PointXY;
18
+ to: PointXY;
19
+ nbPoints: PointXY;
20
+ }
21
+ interface SimulationOptions {
22
+ frequency: number;
23
+ oneD?: Partial<OneDOptions>;
24
+ twoD?: Partial<TwoDOptions>;
25
+ }
26
+ interface PredictAllSpectraOptions {
11
27
  prediction?: PredictAllOptions;
12
- simulation?: OptionsSignalsToXY;
13
- }): Promise<{
28
+ simulation?: SimulationOptions;
29
+ }
30
+ export declare function predictAllSpectra(molecule: Molecule, options?: PredictAllSpectraOptions): Promise<{
14
31
  spectra: any[];
15
32
  molecules: {
16
33
  molfile: any;
17
34
  }[];
18
35
  }>;
36
+ export {};
@@ -1,40 +1,126 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.predictAllSpectra = void 0;
4
+ const signals2DToZ_1 = require("../signals/signals2DToZ");
4
5
  const signalsToXY_1 = require("../signals/signalsToXY");
6
+ const getFrequency_1 = require("../utilities/getFrequency");
5
7
  const predictAll_1 = require("./predictAll");
6
- /**
7
- * This function will generate an object compatible with NMR-ium
8
- *
9
- * @param molecule
10
- * @param options
11
- */
12
8
  async function predictAllSpectra(molecule, options = {}) {
13
- const predictions = await (0, predictAll_1.predictAll)(molecule, options.prediction);
9
+ const { simulation: simulationOptions = { oneD: {}, twoD: {} }, prediction: predictionOptions = {}, } = options;
10
+ const predictions = await (0, predictAll_1.predictAll)(molecule, predictionOptions);
14
11
  const spectra = [];
15
12
  const result = { spectra, molecules: [{ molfile: predictions.molfile }] };
16
- spectra.push(getProton(predictions.proton, options.simulation));
13
+ const oneDOptions = {
14
+ ...{
15
+ proton: { from: 0, to: 14 },
16
+ carbon: { from: 0, to: 200 },
17
+ nbPoints: 4098,
18
+ lineWidth: 0.03,
19
+ },
20
+ ...(simulationOptions.oneD || {}),
21
+ };
22
+ const twoDOptions = {
23
+ ...{
24
+ from: { x: oneDOptions.proton.from, y: oneDOptions.carbon.from },
25
+ to: { x: oneDOptions.proton.to, y: oneDOptions.carbon.to },
26
+ nbPoints: { x: 1024, y: 1024 },
27
+ },
28
+ ...(simulationOptions.twoD || {}),
29
+ };
30
+ for (const experiment in predictions) {
31
+ switch (experiment) {
32
+ case 'carbon':
33
+ case 'proton': {
34
+ spectra.push(get1DSpectrum(predictions[experiment], {
35
+ nbPoints: oneDOptions.nbPoints,
36
+ lineWidth: oneDOptions.lineWidth,
37
+ ...oneDOptions[experiment],
38
+ experiment,
39
+ frequency: simulationOptions.frequency,
40
+ }));
41
+ break;
42
+ }
43
+ case 'cosy':
44
+ case 'hsqc':
45
+ case 'hmbc': {
46
+ spectra.push(get2DSpectrum(predictions[experiment], {
47
+ ...twoDOptions,
48
+ experiment,
49
+ frequency: simulationOptions.frequency,
50
+ }));
51
+ break;
52
+ }
53
+ default:
54
+ break;
55
+ }
56
+ }
17
57
  return result;
18
58
  }
19
59
  exports.predictAllSpectra = predictAllSpectra;
20
- function getProton(prediction, options) {
21
- const { x, y } = (0, signalsToXY_1.signalsToXY)(prediction.signals, options);
60
+ function get2DSpectrum(prediction, options) {
61
+ const { signals, zones, nuclei } = prediction;
62
+ const { frequency: baseFrequency, experiment } = options;
63
+ const width = get2DWidth(nuclei);
64
+ const frequency = calculateFrequency(nuclei, baseFrequency);
65
+ const spectrumData = (0, signals2DToZ_1.signals2DToZ)(signals, {
66
+ ...options,
67
+ width,
68
+ factor: 3,
69
+ });
70
+ const spectrum = {
71
+ data: { ...spectrumData, noise: 0.01 },
72
+ info: {
73
+ nucleus: nuclei,
74
+ originFrequency: frequency,
75
+ baseFrequency: frequency,
76
+ pulseSequence: experiment,
77
+ experiment: '2d',
78
+ },
79
+ zones: { values: zones },
80
+ };
81
+ return spectrum;
82
+ }
83
+ function get2DWidth(nucleus) {
84
+ return nucleus[0] === nucleus[1] ? 0.02 : { x: 0.02, y: 0.2133 };
85
+ }
86
+ function get1DSpectrum(prediction, options) {
87
+ const { frequency = 400, experiment } = options;
88
+ const { signals, nucleus } = prediction;
89
+ const realFrequency = calculateFrequency(nucleus, frequency);
90
+ const { x, y } = (0, signalsToXY_1.signalsToXY)(signals, {
91
+ ...options,
92
+ frequency: realFrequency,
93
+ });
22
94
  const spectrum = {
23
- id: '',
24
95
  // todo Array.from is temporary for the developement
25
96
  data: { x: Array.from(x), re: Array.from(y), im: null },
26
97
  info: {
27
98
  nucleus: prediction.nucleus,
28
99
  dimension: 1,
29
- originFrequency: 400,
30
- baseFrequency: 400,
100
+ originFrequency: realFrequency,
101
+ baseFrequency: realFrequency,
31
102
  pulseSequence: 'prediction',
32
- experiment: 'proton',
103
+ experiment,
33
104
  isFt: true,
34
105
  },
35
- // todo: currently we disable the ranges because there is no ID
36
- //ranges: { values: prediction.ranges },
106
+ ranges: { values: prediction.ranges },
37
107
  };
38
108
  return spectrum;
39
109
  }
110
+ function calculateFrequency(nucleus, frequency) {
111
+ if (typeof nucleus === 'string') {
112
+ return (0, getFrequency_1.getFrequency)(nucleus, { nucleus: '1H', frequency });
113
+ }
114
+ else {
115
+ if (nucleus[0] === nucleus[1]) {
116
+ return `${frequency},${frequency}`;
117
+ }
118
+ else {
119
+ return `${frequency},${(0, getFrequency_1.getFrequency)(nucleus[1], {
120
+ nucleus: nucleus[0],
121
+ frequency,
122
+ })}`;
123
+ }
124
+ }
125
+ }
40
126
  //# sourceMappingURL=predictAllSpectra.js.map