nds-mcp 0.1.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 (115) hide show
  1. package/README.md +186 -0
  2. package/bin/nds-mcp.js +33 -0
  3. package/dist/constants.d.ts +14 -0
  4. package/dist/constants.d.ts.map +1 -0
  5. package/dist/constants.js +13 -0
  6. package/dist/constants.js.map +1 -0
  7. package/dist/db/chargeRadii.d.ts +22 -0
  8. package/dist/db/chargeRadii.d.ts.map +1 -0
  9. package/dist/db/chargeRadii.js +75 -0
  10. package/dist/db/chargeRadii.js.map +1 -0
  11. package/dist/db/decayFeedings.d.ts +31 -0
  12. package/dist/db/decayFeedings.d.ts.map +1 -0
  13. package/dist/db/decayFeedings.js +41 -0
  14. package/dist/db/decayFeedings.js.map +1 -0
  15. package/dist/db/ensureDb.d.ts +20 -0
  16. package/dist/db/ensureDb.d.ts.map +1 -0
  17. package/dist/db/ensureDb.js +148 -0
  18. package/dist/db/ensureDb.js.map +1 -0
  19. package/dist/db/gammas.d.ts +39 -0
  20. package/dist/db/gammas.d.ts.map +1 -0
  21. package/dist/db/gammas.js +53 -0
  22. package/dist/db/gammas.js.map +1 -0
  23. package/dist/db/levels.d.ts +68 -0
  24. package/dist/db/levels.d.ts.map +1 -0
  25. package/dist/db/levels.js +121 -0
  26. package/dist/db/levels.js.map +1 -0
  27. package/dist/db/masses.d.ts +16 -0
  28. package/dist/db/masses.d.ts.map +1 -0
  29. package/dist/db/masses.js +22 -0
  30. package/dist/db/masses.js.map +1 -0
  31. package/dist/db/ndsDb.d.ts +10 -0
  32. package/dist/db/ndsDb.d.ts.map +1 -0
  33. package/dist/db/ndsDb.js +61 -0
  34. package/dist/db/ndsDb.js.map +1 -0
  35. package/dist/db/nubase.d.ts +21 -0
  36. package/dist/db/nubase.d.ts.map +1 -0
  37. package/dist/db/nubase.js +61 -0
  38. package/dist/db/nubase.js.map +1 -0
  39. package/dist/db/reactions.d.ts +11 -0
  40. package/dist/db/reactions.d.ts.map +1 -0
  41. package/dist/db/reactions.js +54 -0
  42. package/dist/db/reactions.js.map +1 -0
  43. package/dist/db/references.d.ts +11 -0
  44. package/dist/db/references.d.ts.map +1 -0
  45. package/dist/db/references.js +24 -0
  46. package/dist/db/references.js.map +1 -0
  47. package/dist/index.d.ts +3 -0
  48. package/dist/index.d.ts.map +1 -0
  49. package/dist/index.js +55 -0
  50. package/dist/index.js.map +1 -0
  51. package/dist/ingest/buildDb.d.ts +36 -0
  52. package/dist/ingest/buildDb.d.ts.map +1 -0
  53. package/dist/ingest/buildDb.js +933 -0
  54. package/dist/ingest/buildDb.js.map +1 -0
  55. package/dist/ingest/parseAme.d.ts +79 -0
  56. package/dist/ingest/parseAme.d.ts.map +1 -0
  57. package/dist/ingest/parseAme.js +186 -0
  58. package/dist/ingest/parseAme.js.map +1 -0
  59. package/dist/ingest/parseEnsdf.d.ts +210 -0
  60. package/dist/ingest/parseEnsdf.d.ts.map +1 -0
  61. package/dist/ingest/parseEnsdf.js +469 -0
  62. package/dist/ingest/parseEnsdf.js.map +1 -0
  63. package/dist/ingest/parseLaserRadii.d.ts +33 -0
  64. package/dist/ingest/parseLaserRadii.d.ts.map +1 -0
  65. package/dist/ingest/parseLaserRadii.js +210 -0
  66. package/dist/ingest/parseLaserRadii.js.map +1 -0
  67. package/dist/ingest/parseNubase.d.ts +40 -0
  68. package/dist/ingest/parseNubase.d.ts.map +1 -0
  69. package/dist/ingest/parseNubase.js +146 -0
  70. package/dist/ingest/parseNubase.js.map +1 -0
  71. package/dist/ingest/parseRadii.d.ts +17 -0
  72. package/dist/ingest/parseRadii.d.ts.map +1 -0
  73. package/dist/ingest/parseRadii.js +42 -0
  74. package/dist/ingest/parseRadii.js.map +1 -0
  75. package/dist/ingest/parseTunl.d.ts +48 -0
  76. package/dist/ingest/parseTunl.d.ts.map +1 -0
  77. package/dist/ingest/parseTunl.js +773 -0
  78. package/dist/ingest/parseTunl.js.map +1 -0
  79. package/dist/shared/errors.d.ts +20 -0
  80. package/dist/shared/errors.d.ts.map +1 -0
  81. package/dist/shared/errors.js +45 -0
  82. package/dist/shared/errors.js.map +1 -0
  83. package/dist/shared/index.d.ts +4 -0
  84. package/dist/shared/index.d.ts.map +1 -0
  85. package/dist/shared/index.js +3 -0
  86. package/dist/shared/index.js.map +1 -0
  87. package/dist/shared/sqlite3Cli.d.ts +3 -0
  88. package/dist/shared/sqlite3Cli.d.ts.map +1 -0
  89. package/dist/shared/sqlite3Cli.js +106 -0
  90. package/dist/shared/sqlite3Cli.js.map +1 -0
  91. package/dist/tooling.d.ts +2 -0
  92. package/dist/tooling.d.ts.map +1 -0
  93. package/dist/tooling.js +2 -0
  94. package/dist/tooling.js.map +1 -0
  95. package/dist/tools/dispatcher.d.ts +11 -0
  96. package/dist/tools/dispatcher.d.ts.map +1 -0
  97. package/dist/tools/dispatcher.js +64 -0
  98. package/dist/tools/dispatcher.js.map +1 -0
  99. package/dist/tools/index.d.ts +3 -0
  100. package/dist/tools/index.d.ts.map +1 -0
  101. package/dist/tools/index.js +3 -0
  102. package/dist/tools/index.js.map +1 -0
  103. package/dist/tools/mcpSchema.d.ts +3 -0
  104. package/dist/tools/mcpSchema.d.ts.map +1 -0
  105. package/dist/tools/mcpSchema.js +21 -0
  106. package/dist/tools/mcpSchema.js.map +1 -0
  107. package/dist/tools/registry.d.ts +22 -0
  108. package/dist/tools/registry.d.ts.map +1 -0
  109. package/dist/tools/registry.js +309 -0
  110. package/dist/tools/registry.js.map +1 -0
  111. package/dist/utils/stdioHygiene.d.ts +7 -0
  112. package/dist/utils/stdioHygiene.d.ts.map +1 -0
  113. package/dist/utils/stdioHygiene.js +16 -0
  114. package/dist/utils/stdioHygiene.js.map +1 -0
  115. package/package.json +64 -0
@@ -0,0 +1,39 @@
1
+ export interface EnsdfGammaResult {
2
+ gamma_id: number;
3
+ dataset_id: number;
4
+ level_id: number;
5
+ Z: number;
6
+ A: number;
7
+ element: string;
8
+ level_energy_keV: number;
9
+ gamma_energy_keV: number;
10
+ gamma_energy_raw: string;
11
+ gamma_energy_unc_keV: number | null;
12
+ rel_intensity: number | null;
13
+ rel_intensity_unc: number | null;
14
+ total_intensity: number | null;
15
+ total_intensity_unc: number | null;
16
+ multipolarity: string | null;
17
+ mixing_ratio: number | null;
18
+ mixing_ratio_unc: number | null;
19
+ total_conv_coeff: number | null;
20
+ total_conv_coeff_unc: number | null;
21
+ comment_flag: string | null;
22
+ coin_flag: string | null;
23
+ questionable: boolean;
24
+ be2w: number | null;
25
+ be2w_unc: number | null;
26
+ bm1w: number | null;
27
+ bm1w_unc: number | null;
28
+ dataset_type: string;
29
+ dsid: string;
30
+ }
31
+ export declare function queryGammas(dbPath: string, params: {
32
+ Z: number;
33
+ A: number;
34
+ level_energy?: number;
35
+ gamma_energy_min?: number;
36
+ gamma_energy_max?: number;
37
+ limit?: number;
38
+ }): Promise<EnsdfGammaResult[]>;
39
+ //# sourceMappingURL=gammas.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gammas.d.ts","sourceRoot":"","sources":["../../src/db/gammas.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,OAAO,EAAE,MAAM,CAAC;IAChB,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC;IACzB,gBAAgB,EAAE,MAAM,CAAC;IACzB,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;IACpC,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;IACpC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,YAAY,EAAE,OAAO,CAAC;IACtB,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,YAAY,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC;CACd;AAmCD,wBAAsB,WAAW,CAC/B,MAAM,EAAE,MAAM,EACd,MAAM,EAAE;IACN,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,GACA,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAqB7B"}
@@ -0,0 +1,53 @@
1
+ import { sqlite3JsonQuery } from '../shared/index.js';
2
+ function mapGammaRow(r) {
3
+ return {
4
+ gamma_id: r.gamma_id,
5
+ dataset_id: r.dataset_id,
6
+ level_id: r.level_id,
7
+ Z: r.Z,
8
+ A: r.A,
9
+ element: r.element,
10
+ level_energy_keV: r.level_energy_keV,
11
+ gamma_energy_keV: r.gamma_energy_keV,
12
+ gamma_energy_raw: r.gamma_energy_raw,
13
+ gamma_energy_unc_keV: r.gamma_energy_unc_keV,
14
+ rel_intensity: r.rel_intensity,
15
+ rel_intensity_unc: r.rel_intensity_unc,
16
+ total_intensity: r.total_intensity,
17
+ total_intensity_unc: r.total_intensity_unc,
18
+ multipolarity: r.multipolarity,
19
+ mixing_ratio: r.mixing_ratio,
20
+ mixing_ratio_unc: r.mixing_ratio_unc,
21
+ total_conv_coeff: r.total_conv_coeff,
22
+ total_conv_coeff_unc: r.total_conv_coeff_unc,
23
+ comment_flag: r.comment_flag,
24
+ coin_flag: r.coin_flag,
25
+ questionable: r.questionable === 1,
26
+ be2w: r.be2w,
27
+ be2w_unc: r.be2w_unc,
28
+ bm1w: r.bm1w,
29
+ bm1w_unc: r.bm1w_unc,
30
+ dataset_type: r.dataset_type,
31
+ dsid: r.dsid,
32
+ };
33
+ }
34
+ export async function queryGammas(dbPath, params) {
35
+ const conditions = [
36
+ `g.Z=${params.Z}`,
37
+ `g.A=${params.A}`,
38
+ ];
39
+ if (params.level_energy !== undefined) {
40
+ conditions.push(`ABS(g.level_energy_keV - ${params.level_energy}) < 0.1`);
41
+ }
42
+ if (params.gamma_energy_min !== undefined) {
43
+ conditions.push(`g.gamma_energy_keV >= ${params.gamma_energy_min}`);
44
+ }
45
+ if (params.gamma_energy_max !== undefined) {
46
+ conditions.push(`g.gamma_energy_keV <= ${params.gamma_energy_max}`);
47
+ }
48
+ const limit = params.limit ?? 100;
49
+ const sql = `SELECT g.*, d.dataset_type, d.dsid FROM ensdf_gammas g JOIN ensdf_datasets d ON g.dataset_id = d.dataset_id WHERE ${conditions.join(' AND ')} ORDER BY g.level_energy_keV, g.gamma_energy_keV LIMIT ${limit}`;
50
+ const rows = await sqlite3JsonQuery(dbPath, sql);
51
+ return rows.map(r => mapGammaRow(r));
52
+ }
53
+ //# sourceMappingURL=gammas.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gammas.js","sourceRoot":"","sources":["../../src/db/gammas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAiCtD,SAAS,WAAW,CAAC,CAA0B;IAC7C,OAAO;QACL,QAAQ,EAAE,CAAC,CAAC,QAAkB;QAC9B,UAAU,EAAE,CAAC,CAAC,UAAoB;QAClC,QAAQ,EAAE,CAAC,CAAC,QAAkB;QAC9B,CAAC,EAAE,CAAC,CAAC,CAAW;QAChB,CAAC,EAAE,CAAC,CAAC,CAAW;QAChB,OAAO,EAAE,CAAC,CAAC,OAAiB;QAC5B,gBAAgB,EAAE,CAAC,CAAC,gBAA0B;QAC9C,gBAAgB,EAAE,CAAC,CAAC,gBAA0B;QAC9C,gBAAgB,EAAE,CAAC,CAAC,gBAA0B;QAC9C,oBAAoB,EAAE,CAAC,CAAC,oBAAqC;QAC7D,aAAa,EAAE,CAAC,CAAC,aAA8B;QAC/C,iBAAiB,EAAE,CAAC,CAAC,iBAAkC;QACvD,eAAe,EAAE,CAAC,CAAC,eAAgC;QACnD,mBAAmB,EAAE,CAAC,CAAC,mBAAoC;QAC3D,aAAa,EAAE,CAAC,CAAC,aAA8B;QAC/C,YAAY,EAAE,CAAC,CAAC,YAA6B;QAC7C,gBAAgB,EAAE,CAAC,CAAC,gBAAiC;QACrD,gBAAgB,EAAE,CAAC,CAAC,gBAAiC;QACrD,oBAAoB,EAAE,CAAC,CAAC,oBAAqC;QAC7D,YAAY,EAAE,CAAC,CAAC,YAA6B;QAC7C,SAAS,EAAE,CAAC,CAAC,SAA0B;QACvC,YAAY,EAAG,CAAC,CAAC,YAAuB,KAAK,CAAC;QAC9C,IAAI,EAAE,CAAC,CAAC,IAAqB;QAC7B,QAAQ,EAAE,CAAC,CAAC,QAAyB;QACrC,IAAI,EAAE,CAAC,CAAC,IAAqB;QAC7B,QAAQ,EAAE,CAAC,CAAC,QAAyB;QACrC,YAAY,EAAE,CAAC,CAAC,YAAsB;QACtC,IAAI,EAAE,CAAC,CAAC,IAAc;KACvB,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,MAAc,EACd,MAOC;IAED,MAAM,UAAU,GAAa;QAC3B,OAAO,MAAM,CAAC,CAAC,EAAE;QACjB,OAAO,MAAM,CAAC,CAAC,EAAE;KAClB,CAAC;IAEF,IAAI,MAAM,CAAC,YAAY,KAAK,SAAS,EAAE,CAAC;QACtC,UAAU,CAAC,IAAI,CAAC,4BAA4B,MAAM,CAAC,YAAY,SAAS,CAAC,CAAC;IAC5E,CAAC;IACD,IAAI,MAAM,CAAC,gBAAgB,KAAK,SAAS,EAAE,CAAC;QAC1C,UAAU,CAAC,IAAI,CAAC,yBAAyB,MAAM,CAAC,gBAAgB,EAAE,CAAC,CAAC;IACtE,CAAC;IACD,IAAI,MAAM,CAAC,gBAAgB,KAAK,SAAS,EAAE,CAAC;QAC1C,UAAU,CAAC,IAAI,CAAC,yBAAyB,MAAM,CAAC,gBAAgB,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,IAAI,GAAG,CAAC;IAClC,MAAM,GAAG,GAAG,qHAAqH,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,0DAA0D,KAAK,EAAE,CAAC;IAE3N,MAAM,IAAI,GAAG,MAAM,gBAAgB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACjD,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,CAA4B,CAAC,CAAC,CAAC;AAClE,CAAC"}
@@ -0,0 +1,68 @@
1
+ export interface EnsdfLevelResult {
2
+ level_id: number;
3
+ dataset_id: number;
4
+ Z: number;
5
+ A: number;
6
+ element: string;
7
+ energy_keV: number;
8
+ energy_raw: string;
9
+ energy_unc_keV: number | null;
10
+ spin_parity: string | null;
11
+ half_life: string | null;
12
+ half_life_seconds: number | null;
13
+ half_life_unc_seconds: number | null;
14
+ isomer_flag: string | null;
15
+ questionable: boolean;
16
+ comment_flag: string | null;
17
+ dataset_type: string;
18
+ dsid: string;
19
+ }
20
+ export interface TunlLevelResult {
21
+ tunl_level_id: number;
22
+ Z: number;
23
+ A: number;
24
+ element: string;
25
+ energy_keV: number;
26
+ energy_unc_keV: number | null;
27
+ energy_raw: string | null;
28
+ spin_parity: string | null;
29
+ isospin: string | null;
30
+ width_keV: number | null;
31
+ width_unc_keV: number | null;
32
+ width_raw: string | null;
33
+ width_relation: string | null;
34
+ half_life: string | null;
35
+ decay_modes: string | null;
36
+ evaluation: string;
37
+ table_label: string | null;
38
+ }
39
+ export type UnifiedLevelResult = (EnsdfLevelResult & {
40
+ source: 'ENSDF';
41
+ }) | (TunlLevelResult & {
42
+ source: 'TUNL';
43
+ });
44
+ export declare function queryLevels(dbPath: string, params: {
45
+ Z: number;
46
+ A: number;
47
+ energy_min?: number;
48
+ energy_max?: number;
49
+ include_decay_datasets?: boolean;
50
+ limit?: number;
51
+ }): Promise<EnsdfLevelResult[]>;
52
+ export declare function queryTunlLevels(dbPath: string, params: {
53
+ Z: number;
54
+ A: number;
55
+ energy_min?: number;
56
+ energy_max?: number;
57
+ limit?: number;
58
+ }): Promise<TunlLevelResult[]>;
59
+ export declare function queryAllLevels(dbPath: string, params: {
60
+ Z: number;
61
+ A: number;
62
+ energy_min?: number;
63
+ energy_max?: number;
64
+ include_decay_datasets?: boolean;
65
+ include_tunl?: boolean;
66
+ limit?: number;
67
+ }): Promise<UnifiedLevelResult[]>;
68
+ //# sourceMappingURL=levels.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"levels.d.ts","sourceRoot":"","sources":["../../src/db/levels.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,121 @@
1
+ import { sqlite3JsonQuery } from '../shared/index.js';
2
+ function mapLevelRow(r) {
3
+ return {
4
+ level_id: r.level_id,
5
+ dataset_id: r.dataset_id,
6
+ Z: r.Z,
7
+ A: r.A,
8
+ element: r.element,
9
+ energy_keV: r.energy_keV,
10
+ energy_raw: r.energy_raw,
11
+ energy_unc_keV: r.energy_unc_keV,
12
+ spin_parity: r.spin_parity,
13
+ half_life: r.half_life,
14
+ half_life_seconds: r.half_life_seconds,
15
+ half_life_unc_seconds: r.half_life_unc_seconds,
16
+ isomer_flag: r.isomer_flag,
17
+ questionable: r.questionable === 1,
18
+ comment_flag: r.comment_flag,
19
+ dataset_type: r.dataset_type,
20
+ dsid: r.dsid,
21
+ };
22
+ }
23
+ export async function queryLevels(dbPath, params) {
24
+ const conditions = [
25
+ `l.Z=${params.Z}`,
26
+ `l.A=${params.A}`,
27
+ ];
28
+ if (!params.include_decay_datasets) {
29
+ conditions.push(`d.dataset_type LIKE 'ADOPTED%'`);
30
+ }
31
+ if (params.energy_min !== undefined) {
32
+ conditions.push(`l.energy_keV >= ${params.energy_min}`);
33
+ }
34
+ if (params.energy_max !== undefined) {
35
+ conditions.push(`l.energy_keV <= ${params.energy_max}`);
36
+ }
37
+ const limit = params.limit ?? 100;
38
+ const sql = `SELECT l.*, d.dataset_type, d.dsid FROM ensdf_levels l JOIN ensdf_datasets d ON l.dataset_id = d.dataset_id WHERE ${conditions.join(' AND ')} ORDER BY l.energy_keV, l.level_id LIMIT ${limit}`;
39
+ const rows = await sqlite3JsonQuery(dbPath, sql);
40
+ return rows.map(r => mapLevelRow(r));
41
+ }
42
+ // ── TUNL levels query ──────────────────────────────────────────────────────
43
+ function mapTunlRow(r) {
44
+ return {
45
+ tunl_level_id: r.tunl_level_id,
46
+ Z: r.Z,
47
+ A: r.A,
48
+ element: r.element,
49
+ energy_keV: r.energy_keV,
50
+ energy_unc_keV: r.energy_unc_keV,
51
+ energy_raw: r.energy_raw ?? null,
52
+ spin_parity: r.spin_parity,
53
+ isospin: r.isospin,
54
+ width_keV: r.width_keV,
55
+ width_unc_keV: r.width_unc_keV,
56
+ width_raw: r.width_raw,
57
+ width_relation: r.width_relation,
58
+ half_life: r.half_life,
59
+ decay_modes: r.decay_modes,
60
+ evaluation: r.evaluation,
61
+ table_label: r.table_label ?? null,
62
+ };
63
+ }
64
+ export async function queryTunlLevels(dbPath, params) {
65
+ const conditions = [
66
+ `Z=${params.Z}`,
67
+ `A=${params.A}`,
68
+ ];
69
+ if (params.energy_min !== undefined) {
70
+ conditions.push(`energy_keV >= ${params.energy_min}`);
71
+ }
72
+ if (params.energy_max !== undefined) {
73
+ conditions.push(`energy_keV <= ${params.energy_max}`);
74
+ }
75
+ const limit = params.limit ?? 100;
76
+ const sql = `SELECT * FROM tunl_levels WHERE ${conditions.join(' AND ')} ORDER BY energy_keV, tunl_level_id LIMIT ${limit}`;
77
+ try {
78
+ const rows = await sqlite3JsonQuery(dbPath, sql);
79
+ return rows.map(r => mapTunlRow(r));
80
+ }
81
+ catch (err) {
82
+ // Only swallow "no such table" errors for backward compatibility with older DBs
83
+ const msg = err instanceof Error ? err.message : String(err);
84
+ if (/no such table:\s*tunl_levels/i.test(msg)) {
85
+ return [];
86
+ }
87
+ throw err;
88
+ }
89
+ }
90
+ // ── Unified levels query (ENSDF + TUNL merged) ────────────────────────────
91
+ export async function queryAllLevels(dbPath, params) {
92
+ const results = [];
93
+ // ENSDF levels
94
+ const ensdfRows = await queryLevels(dbPath, params);
95
+ for (const r of ensdfRows) {
96
+ results.push({ ...r, source: 'ENSDF' });
97
+ }
98
+ // TUNL levels (only for A ≤ 20 by default, or when explicitly requested)
99
+ const includeTunl = params.include_tunl ?? (params.A <= 20);
100
+ if (includeTunl) {
101
+ const tunlRows = await queryTunlLevels(dbPath, params);
102
+ for (const r of tunlRows) {
103
+ results.push({ ...r, source: 'TUNL' });
104
+ }
105
+ }
106
+ // Sort by energy, with source as tie-breaker for stable ordering
107
+ // WARNING: This fetch-N-from-each-then-sort-and-slice strategy is correct for
108
+ // limit-only queries but will break if offset/pagination is ever added.
109
+ // Adding pagination requires either SQL UNION ALL or fetching all rows in
110
+ // the energy window before limiting.
111
+ results.sort((a, b) => a.energy_keV - b.energy_keV
112
+ || (a.source < b.source ? -1 : a.source > b.source ? 1 : 0)
113
+ || ('level_id' in a ? a.level_id : 0)
114
+ - ('level_id' in b ? b.level_id : 0)
115
+ || ('tunl_level_id' in a ? a.tunl_level_id : 0)
116
+ - ('tunl_level_id' in b ? b.tunl_level_id : 0));
117
+ // Apply limit
118
+ const limit = params.limit ?? 100;
119
+ return results.slice(0, limit);
120
+ }
121
+ //# sourceMappingURL=levels.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"levels.js","sourceRoot":"","sources":["../../src/db/levels.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,16 @@
1
+ export interface MassResult {
2
+ Z: number;
3
+ A: number;
4
+ element: string;
5
+ mass_excess_keV: number | null;
6
+ mass_excess_unc_keV: number | null;
7
+ binding_energy_per_A_keV: number | null;
8
+ binding_energy_per_A_unc_keV: number | null;
9
+ beta_decay_energy_keV: number | null;
10
+ beta_decay_energy_unc_keV: number | null;
11
+ atomic_mass_micro_u: number | null;
12
+ atomic_mass_unc_micro_u: number | null;
13
+ is_estimated: boolean;
14
+ }
15
+ export declare function getMass(dbPath: string, Z: number, A: number): Promise<MassResult | null>;
16
+ //# sourceMappingURL=masses.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"masses.d.ts","sourceRoot":"","sources":["../../src/db/masses.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,UAAU;IACzB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,OAAO,EAAE,MAAM,CAAC;IAChB,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,wBAAwB,EAAE,MAAM,GAAG,IAAI,CAAC;IACxC,4BAA4B,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5C,qBAAqB,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,yBAAyB,EAAE,MAAM,GAAG,IAAI,CAAC;IACzC,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,uBAAuB,EAAE,MAAM,GAAG,IAAI,CAAC;IACvC,YAAY,EAAE,OAAO,CAAC;CACvB;AAED,wBAAsB,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAkB9F"}
@@ -0,0 +1,22 @@
1
+ import { sqlite3JsonQuery } from '../shared/index.js';
2
+ export async function getMass(dbPath, Z, A) {
3
+ const rows = await sqlite3JsonQuery(dbPath, `SELECT * FROM ame_masses WHERE Z=${Z} AND A=${A}`);
4
+ if (rows.length === 0)
5
+ return null;
6
+ const r = rows[0];
7
+ return {
8
+ Z: r.Z,
9
+ A: r.A,
10
+ element: r.element,
11
+ mass_excess_keV: r.mass_excess_keV,
12
+ mass_excess_unc_keV: r.mass_excess_unc_keV,
13
+ binding_energy_per_A_keV: r.binding_energy_per_A_keV,
14
+ binding_energy_per_A_unc_keV: r.binding_energy_per_A_unc_keV,
15
+ beta_decay_energy_keV: r.beta_decay_energy_keV,
16
+ beta_decay_energy_unc_keV: r.beta_decay_energy_unc_keV,
17
+ atomic_mass_micro_u: r.atomic_mass_micro_u,
18
+ atomic_mass_unc_micro_u: r.atomic_mass_unc_micro_u,
19
+ is_estimated: r.is_estimated === 1,
20
+ };
21
+ }
22
+ //# sourceMappingURL=masses.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"masses.js","sourceRoot":"","sources":["../../src/db/masses.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAiBtD,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,MAAc,EAAE,CAAS,EAAE,CAAS;IAChE,MAAM,IAAI,GAAG,MAAM,gBAAgB,CAAC,MAAM,EAAE,oCAAoC,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;IAChG,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IACnC,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,CAA4B,CAAC;IAC7C,OAAO;QACL,CAAC,EAAE,CAAC,CAAC,CAAW;QAChB,CAAC,EAAE,CAAC,CAAC,CAAW;QAChB,OAAO,EAAE,CAAC,CAAC,OAAiB;QAC5B,eAAe,EAAE,CAAC,CAAC,eAAgC;QACnD,mBAAmB,EAAE,CAAC,CAAC,mBAAoC;QAC3D,wBAAwB,EAAE,CAAC,CAAC,wBAAyC;QACrE,4BAA4B,EAAE,CAAC,CAAC,4BAA6C;QAC7E,qBAAqB,EAAE,CAAC,CAAC,qBAAsC;QAC/D,yBAAyB,EAAE,CAAC,CAAC,yBAA0C;QACvE,mBAAmB,EAAE,CAAC,CAAC,mBAAoC;QAC3D,uBAAuB,EAAE,CAAC,CAAC,uBAAwC;QACnE,YAAY,EAAG,CAAC,CAAC,YAAuB,KAAK,CAAC;KAC/C,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ export declare const NDS_DB_PATH_ENV = "NDS_DB_PATH";
2
+ export declare function getNdsDbPathFromEnv(): string | undefined;
3
+ export declare function requireNdsDbPathFromEnv(): string;
4
+ export declare function sha256File(filePath: string): Promise<string>;
5
+ export declare function getFileMetadata(filePath: string): Promise<{
6
+ size_bytes: number;
7
+ mtime_iso: string;
8
+ sha256: string;
9
+ }>;
10
+ //# sourceMappingURL=ndsDb.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ndsDb.d.ts","sourceRoot":"","sources":["../../src/db/ndsDb.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,eAAe,gBAAgB,CAAC;AAM7C,wBAAgB,mBAAmB,IAAI,MAAM,GAAG,SAAS,CAoBxD;AAED,wBAAgB,uBAAuB,IAAI,MAAM,CAYhD;AAED,wBAAsB,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAoBlE;AAED,wBAAsB,eAAe,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC;IAC/D,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC,CAQD"}
@@ -0,0 +1,61 @@
1
+ import * as crypto from 'crypto';
2
+ import * as fs from 'fs';
3
+ import * as path from 'path';
4
+ import { invalidParams } from '../shared/index.js';
5
+ export const NDS_DB_PATH_ENV = 'NDS_DB_PATH';
6
+ let sha256Cache;
7
+ export function getNdsDbPathFromEnv() {
8
+ const raw = process.env[NDS_DB_PATH_ENV];
9
+ if (!raw || raw.trim().length === 0)
10
+ return undefined;
11
+ const trimmed = raw.trim();
12
+ if (!path.isAbsolute(trimmed)) {
13
+ throw invalidParams(`${NDS_DB_PATH_ENV} must be an absolute path`, { env: NDS_DB_PATH_ENV, value: trimmed });
14
+ }
15
+ const resolved = path.resolve(trimmed);
16
+ if (!fs.existsSync(resolved)) {
17
+ throw invalidParams(`${NDS_DB_PATH_ENV} does not exist`, { env: NDS_DB_PATH_ENV, value: resolved });
18
+ }
19
+ const stat = fs.statSync(resolved);
20
+ if (!stat.isFile()) {
21
+ throw invalidParams(`${NDS_DB_PATH_ENV} must point to a file`, { env: NDS_DB_PATH_ENV, value: resolved });
22
+ }
23
+ return resolved;
24
+ }
25
+ export function requireNdsDbPathFromEnv() {
26
+ const p = getNdsDbPathFromEnv();
27
+ if (!p) {
28
+ throw invalidParams(`${NDS_DB_PATH_ENV} is required. Auto-download may have failed at startup.`, {
29
+ env: NDS_DB_PATH_ENV,
30
+ how_to: 'Set NDS_DB_PATH=/abs/path/to/nds.sqlite or ensure internet access',
31
+ });
32
+ }
33
+ return p;
34
+ }
35
+ export async function sha256File(filePath) {
36
+ const stat = fs.statSync(filePath);
37
+ if (sha256Cache &&
38
+ sha256Cache.filePath === filePath &&
39
+ sha256Cache.sizeBytes === stat.size &&
40
+ sha256Cache.mtimeMs === stat.mtimeMs) {
41
+ return sha256Cache.sha256;
42
+ }
43
+ const hash = crypto.createHash('sha256');
44
+ const stream = fs.createReadStream(filePath);
45
+ for await (const chunk of stream) {
46
+ hash.update(chunk);
47
+ }
48
+ const digest = hash.digest('hex');
49
+ sha256Cache = { filePath, sizeBytes: stat.size, mtimeMs: stat.mtimeMs, sha256: digest };
50
+ return digest;
51
+ }
52
+ export async function getFileMetadata(filePath) {
53
+ const stat = fs.statSync(filePath);
54
+ const digest = await sha256File(filePath);
55
+ return {
56
+ size_bytes: stat.size,
57
+ mtime_iso: stat.mtime.toISOString(),
58
+ sha256: digest,
59
+ };
60
+ }
61
+ //# sourceMappingURL=ndsDb.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ndsDb.js","sourceRoot":"","sources":["../../src/db/ndsDb.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ export interface NubaseResult {
2
+ Z: number;
3
+ A: number;
4
+ element: string;
5
+ isomer_index: number;
6
+ mass_excess_keV: number | null;
7
+ mass_excess_unc_keV: number | null;
8
+ excitation_energy_keV: number | null;
9
+ half_life: string;
10
+ half_life_seconds: number | null;
11
+ half_life_unc_seconds: number | null;
12
+ spin_parity: string;
13
+ decay_modes: string;
14
+ is_estimated: boolean;
15
+ }
16
+ export declare function getDecay(dbPath: string, Z: number, A: number): Promise<NubaseResult[]>;
17
+ export declare function findNuclidesByElement(dbPath: string, element: string): Promise<NubaseResult[]>;
18
+ export declare function findNuclideByZA(dbPath: string, Z: number, A: number): Promise<NubaseResult[]>;
19
+ export declare function findNuclidesByA(dbPath: string, A: number): Promise<NubaseResult[]>;
20
+ export declare function searchNuclides(dbPath: string, property: string, min?: number, max?: number, Z_min?: number, Z_max?: number, limit?: number): Promise<NubaseResult[]>;
21
+ //# sourceMappingURL=nubase.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nubase.d.ts","sourceRoot":"","sources":["../../src/db/nubase.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,YAAY;IAC3B,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,qBAAqB,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,SAAS,EAAE,MAAM,CAAC;IAClB,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,qBAAqB,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,OAAO,CAAC;CACvB;AAoBD,wBAAsB,QAAQ,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,CAM5F;AAED,wBAAsB,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,CAMpG;AAED,wBAAsB,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,CAMnG;AAED,wBAAsB,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,CAMxF;AASD,wBAAsB,cAAc,CAClC,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,GAAG,CAAC,EAAE,MAAM,EACZ,GAAG,CAAC,EAAE,MAAM,EACZ,KAAK,CAAC,EAAE,MAAM,EACd,KAAK,CAAC,EAAE,MAAM,EACd,KAAK,GAAE,MAAW,GACjB,OAAO,CAAC,YAAY,EAAE,CAAC,CAuBzB"}
@@ -0,0 +1,61 @@
1
+ import { sqlite3JsonQuery, sqlStringLiteral, invalidParams } from '../shared/index.js';
2
+ function mapRow(r) {
3
+ return {
4
+ Z: r.Z,
5
+ A: r.A,
6
+ element: r.element,
7
+ isomer_index: r.isomer_index,
8
+ mass_excess_keV: r.mass_excess_keV,
9
+ mass_excess_unc_keV: r.mass_excess_unc_keV,
10
+ excitation_energy_keV: r.excitation_energy_keV,
11
+ half_life: r.half_life,
12
+ half_life_seconds: r.half_life_seconds,
13
+ half_life_unc_seconds: r.half_life_unc_seconds,
14
+ spin_parity: r.spin_parity,
15
+ decay_modes: r.decay_modes,
16
+ is_estimated: r.is_estimated === 1,
17
+ };
18
+ }
19
+ export async function getDecay(dbPath, Z, A) {
20
+ const rows = await sqlite3JsonQuery(dbPath, `SELECT * FROM nubase WHERE Z=${Z} AND A=${A} ORDER BY isomer_index`);
21
+ return rows.map(r => mapRow(r));
22
+ }
23
+ export async function findNuclidesByElement(dbPath, element) {
24
+ const rows = await sqlite3JsonQuery(dbPath, `SELECT * FROM nubase WHERE element=${sqlStringLiteral(element)} ORDER BY A, isomer_index`);
25
+ return rows.map(r => mapRow(r));
26
+ }
27
+ export async function findNuclideByZA(dbPath, Z, A) {
28
+ const rows = await sqlite3JsonQuery(dbPath, `SELECT * FROM nubase WHERE Z=${Z} AND A=${A} ORDER BY isomer_index`);
29
+ return rows.map(r => mapRow(r));
30
+ }
31
+ export async function findNuclidesByA(dbPath, A) {
32
+ const rows = await sqlite3JsonQuery(dbPath, `SELECT * FROM nubase WHERE A=${A} ORDER BY Z, isomer_index`);
33
+ return rows.map(r => mapRow(r));
34
+ }
35
+ const ALLOWED_SEARCH_COLUMNS = {
36
+ half_life: 'half_life_seconds',
37
+ mass_excess: 'mass_excess_keV',
38
+ half_life_seconds: 'half_life_seconds',
39
+ mass_excess_keV: 'mass_excess_keV',
40
+ };
41
+ export async function searchNuclides(dbPath, property, min, max, Z_min, Z_max, limit = 50) {
42
+ const column = ALLOWED_SEARCH_COLUMNS[property];
43
+ if (!column) {
44
+ throw invalidParams(`Unknown search property: ${property}`);
45
+ }
46
+ const conditions = [];
47
+ if (Z_min !== undefined)
48
+ conditions.push(`Z >= ${Z_min}`);
49
+ if (Z_max !== undefined)
50
+ conditions.push(`Z <= ${Z_max}`);
51
+ if (min !== undefined)
52
+ conditions.push(`${column} >= ${min}`);
53
+ if (max !== undefined)
54
+ conditions.push(`${column} <= ${max}`);
55
+ // Only ground states for search
56
+ conditions.push('isomer_index = 0');
57
+ const where = conditions.length > 0 ? `WHERE ${conditions.join(' AND ')}` : '';
58
+ const rows = await sqlite3JsonQuery(dbPath, `SELECT * FROM nubase ${where} ORDER BY Z, A LIMIT ${limit}`);
59
+ return rows.map(r => mapRow(r));
60
+ }
61
+ //# sourceMappingURL=nubase.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nubase.js","sourceRoot":"","sources":["../../src/db/nubase.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ export type SeparationEnergyType = 'Sn' | 'Sp' | 'S2n' | 'S2p';
2
+ export type QValueType = 'Qa' | 'Q2bm' | 'Qep' | 'Qbn' | 'Q4bm' | 'Qda' | 'Qpa' | 'Qna';
3
+ export interface ReactionResult {
4
+ Z: number;
5
+ A: number;
6
+ element: string;
7
+ [key: string]: unknown;
8
+ }
9
+ export declare function getSeparationEnergy(dbPath: string, Z: number, A: number, type?: SeparationEnergyType): Promise<Record<string, unknown> | null>;
10
+ export declare function getQValue(dbPath: string, Z: number, A: number, type?: QValueType): Promise<Record<string, unknown> | null>;
11
+ //# sourceMappingURL=reactions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reactions.d.ts","sourceRoot":"","sources":["../../src/db/reactions.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,oBAAoB,GAAG,IAAI,GAAG,IAAI,GAAG,KAAK,GAAG,KAAK,CAAC;AAC/D,MAAM,MAAM,UAAU,GAAG,IAAI,GAAG,MAAM,GAAG,KAAK,GAAG,KAAK,GAAG,MAAM,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,CAAC;AAExF,MAAM,WAAW,cAAc;IAC7B,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,OAAO,EAAE,MAAM,CAAC;IAChB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB;AAED,wBAAsB,mBAAmB,CACvC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,oBAAoB,GAChE,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAwBzC;AAED,wBAAsB,SAAS,CAC7B,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,UAAU,GACtD,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CA4BzC"}
@@ -0,0 +1,54 @@
1
+ import { sqlite3JsonQuery } from '../shared/index.js';
2
+ export async function getSeparationEnergy(dbPath, Z, A, type) {
3
+ const rows = await sqlite3JsonQuery(dbPath, `SELECT * FROM ame_reactions WHERE Z=${Z} AND A=${A}`);
4
+ if (rows.length === 0)
5
+ return null;
6
+ const r = rows[0];
7
+ if (type) {
8
+ const valKey = `${type}_keV`;
9
+ const uncKey = `${type}_unc_keV`;
10
+ return {
11
+ Z: r.Z, A: r.A, element: r.element,
12
+ type,
13
+ value_keV: r[valKey] ?? null,
14
+ uncertainty_keV: r[uncKey] ?? null,
15
+ };
16
+ }
17
+ // Return all separation energies
18
+ return {
19
+ Z: r.Z, A: r.A, element: r.element,
20
+ S2n: { value_keV: r.S2n_keV, uncertainty_keV: r.S2n_unc_keV },
21
+ S2p: { value_keV: r.S2p_keV, uncertainty_keV: r.S2p_unc_keV },
22
+ Sn: { value_keV: r.Sn_keV, uncertainty_keV: r.Sn_unc_keV },
23
+ Sp: { value_keV: r.Sp_keV, uncertainty_keV: r.Sp_unc_keV },
24
+ };
25
+ }
26
+ export async function getQValue(dbPath, Z, A, type) {
27
+ const rows = await sqlite3JsonQuery(dbPath, `SELECT * FROM ame_reactions WHERE Z=${Z} AND A=${A}`);
28
+ if (rows.length === 0)
29
+ return null;
30
+ const r = rows[0];
31
+ if (type) {
32
+ const valKey = `${type}_keV`;
33
+ const uncKey = `${type}_unc_keV`;
34
+ return {
35
+ Z: r.Z, A: r.A, element: r.element,
36
+ type,
37
+ value_keV: r[valKey] ?? null,
38
+ uncertainty_keV: r[uncKey] ?? null,
39
+ };
40
+ }
41
+ // Return all Q values
42
+ return {
43
+ Z: r.Z, A: r.A, element: r.element,
44
+ Qa: { value_keV: r.Qa_keV, uncertainty_keV: r.Qa_unc_keV },
45
+ Q2bm: { value_keV: r.Q2bm_keV, uncertainty_keV: r.Q2bm_unc_keV },
46
+ Qep: { value_keV: r.Qep_keV, uncertainty_keV: r.Qep_unc_keV },
47
+ Qbn: { value_keV: r.Qbn_keV, uncertainty_keV: r.Qbn_unc_keV },
48
+ Q4bm: { value_keV: r.Q4bm_keV, uncertainty_keV: r.Q4bm_unc_keV },
49
+ Qda: { value_keV: r.Qda_keV, uncertainty_keV: r.Qda_unc_keV },
50
+ Qpa: { value_keV: r.Qpa_keV, uncertainty_keV: r.Qpa_unc_keV },
51
+ Qna: { value_keV: r.Qna_keV, uncertainty_keV: r.Qna_unc_keV },
52
+ };
53
+ }
54
+ //# sourceMappingURL=reactions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reactions.js","sourceRoot":"","sources":["../../src/db/reactions.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ export interface EnsdfReferenceResult {
2
+ A: number;
3
+ keynumber: string;
4
+ type: string | null;
5
+ reference: string | null;
6
+ }
7
+ export declare function lookupReference(dbPath: string, params: {
8
+ keynumber?: string;
9
+ A?: number;
10
+ }): Promise<EnsdfReferenceResult[]>;
11
+ //# sourceMappingURL=references.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"references.d.ts","sourceRoot":"","sources":["../../src/db/references.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,oBAAoB;IACnC,CAAC,EAAE,MAAM,CAAC;IACV,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACpB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;CAC1B;AAWD,wBAAsB,eAAe,CACnC,MAAM,EAAE,MAAM,EACd,MAAM,EAAE;IAAE,SAAS,CAAC,EAAE,MAAM,CAAC;IAAC,CAAC,CAAC,EAAE,MAAM,CAAA;CAAE,GACzC,OAAO,CAAC,oBAAoB,EAAE,CAAC,CAejC"}