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.
- package/README.md +186 -0
- package/bin/nds-mcp.js +33 -0
- package/dist/constants.d.ts +14 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +13 -0
- package/dist/constants.js.map +1 -0
- package/dist/db/chargeRadii.d.ts +22 -0
- package/dist/db/chargeRadii.d.ts.map +1 -0
- package/dist/db/chargeRadii.js +75 -0
- package/dist/db/chargeRadii.js.map +1 -0
- package/dist/db/decayFeedings.d.ts +31 -0
- package/dist/db/decayFeedings.d.ts.map +1 -0
- package/dist/db/decayFeedings.js +41 -0
- package/dist/db/decayFeedings.js.map +1 -0
- package/dist/db/ensureDb.d.ts +20 -0
- package/dist/db/ensureDb.d.ts.map +1 -0
- package/dist/db/ensureDb.js +148 -0
- package/dist/db/ensureDb.js.map +1 -0
- package/dist/db/gammas.d.ts +39 -0
- package/dist/db/gammas.d.ts.map +1 -0
- package/dist/db/gammas.js +53 -0
- package/dist/db/gammas.js.map +1 -0
- package/dist/db/levels.d.ts +68 -0
- package/dist/db/levels.d.ts.map +1 -0
- package/dist/db/levels.js +121 -0
- package/dist/db/levels.js.map +1 -0
- package/dist/db/masses.d.ts +16 -0
- package/dist/db/masses.d.ts.map +1 -0
- package/dist/db/masses.js +22 -0
- package/dist/db/masses.js.map +1 -0
- package/dist/db/ndsDb.d.ts +10 -0
- package/dist/db/ndsDb.d.ts.map +1 -0
- package/dist/db/ndsDb.js +61 -0
- package/dist/db/ndsDb.js.map +1 -0
- package/dist/db/nubase.d.ts +21 -0
- package/dist/db/nubase.d.ts.map +1 -0
- package/dist/db/nubase.js +61 -0
- package/dist/db/nubase.js.map +1 -0
- package/dist/db/reactions.d.ts +11 -0
- package/dist/db/reactions.d.ts.map +1 -0
- package/dist/db/reactions.js +54 -0
- package/dist/db/reactions.js.map +1 -0
- package/dist/db/references.d.ts +11 -0
- package/dist/db/references.d.ts.map +1 -0
- package/dist/db/references.js +24 -0
- package/dist/db/references.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +55 -0
- package/dist/index.js.map +1 -0
- package/dist/ingest/buildDb.d.ts +36 -0
- package/dist/ingest/buildDb.d.ts.map +1 -0
- package/dist/ingest/buildDb.js +933 -0
- package/dist/ingest/buildDb.js.map +1 -0
- package/dist/ingest/parseAme.d.ts +79 -0
- package/dist/ingest/parseAme.d.ts.map +1 -0
- package/dist/ingest/parseAme.js +186 -0
- package/dist/ingest/parseAme.js.map +1 -0
- package/dist/ingest/parseEnsdf.d.ts +210 -0
- package/dist/ingest/parseEnsdf.d.ts.map +1 -0
- package/dist/ingest/parseEnsdf.js +469 -0
- package/dist/ingest/parseEnsdf.js.map +1 -0
- package/dist/ingest/parseLaserRadii.d.ts +33 -0
- package/dist/ingest/parseLaserRadii.d.ts.map +1 -0
- package/dist/ingest/parseLaserRadii.js +210 -0
- package/dist/ingest/parseLaserRadii.js.map +1 -0
- package/dist/ingest/parseNubase.d.ts +40 -0
- package/dist/ingest/parseNubase.d.ts.map +1 -0
- package/dist/ingest/parseNubase.js +146 -0
- package/dist/ingest/parseNubase.js.map +1 -0
- package/dist/ingest/parseRadii.d.ts +17 -0
- package/dist/ingest/parseRadii.d.ts.map +1 -0
- package/dist/ingest/parseRadii.js +42 -0
- package/dist/ingest/parseRadii.js.map +1 -0
- package/dist/ingest/parseTunl.d.ts +48 -0
- package/dist/ingest/parseTunl.d.ts.map +1 -0
- package/dist/ingest/parseTunl.js +773 -0
- package/dist/ingest/parseTunl.js.map +1 -0
- package/dist/shared/errors.d.ts +20 -0
- package/dist/shared/errors.d.ts.map +1 -0
- package/dist/shared/errors.js +45 -0
- package/dist/shared/errors.js.map +1 -0
- package/dist/shared/index.d.ts +4 -0
- package/dist/shared/index.d.ts.map +1 -0
- package/dist/shared/index.js +3 -0
- package/dist/shared/index.js.map +1 -0
- package/dist/shared/sqlite3Cli.d.ts +3 -0
- package/dist/shared/sqlite3Cli.d.ts.map +1 -0
- package/dist/shared/sqlite3Cli.js +106 -0
- package/dist/shared/sqlite3Cli.js.map +1 -0
- package/dist/tooling.d.ts +2 -0
- package/dist/tooling.d.ts.map +1 -0
- package/dist/tooling.js +2 -0
- package/dist/tooling.js.map +1 -0
- package/dist/tools/dispatcher.d.ts +11 -0
- package/dist/tools/dispatcher.d.ts.map +1 -0
- package/dist/tools/dispatcher.js +64 -0
- package/dist/tools/dispatcher.js.map +1 -0
- package/dist/tools/index.d.ts +3 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +3 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/mcpSchema.d.ts +3 -0
- package/dist/tools/mcpSchema.d.ts.map +1 -0
- package/dist/tools/mcpSchema.js +21 -0
- package/dist/tools/mcpSchema.js.map +1 -0
- package/dist/tools/registry.d.ts +22 -0
- package/dist/tools/registry.d.ts.map +1 -0
- package/dist/tools/registry.js +309 -0
- package/dist/tools/registry.js.map +1 -0
- package/dist/utils/stdioHygiene.d.ts +7 -0
- package/dist/utils/stdioHygiene.d.ts.map +1 -0
- package/dist/utils/stdioHygiene.js +16 -0
- package/dist/utils/stdioHygiene.js.map +1 -0
- 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"}
|
package/dist/db/ndsDb.js
ADDED
|
@@ -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"}
|