@geotechcli/core 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (194) hide show
  1. package/dist/agents/brain.d.ts +39 -0
  2. package/dist/agents/brain.d.ts.map +1 -0
  3. package/dist/agents/brain.js +339 -0
  4. package/dist/agents/brain.js.map +1 -0
  5. package/dist/agents/bridge-tools.d.ts +2 -0
  6. package/dist/agents/bridge-tools.d.ts.map +1 -0
  7. package/dist/agents/bridge-tools.js +170 -0
  8. package/dist/agents/bridge-tools.js.map +1 -0
  9. package/dist/agents/data-tools.d.ts +2 -0
  10. package/dist/agents/data-tools.d.ts.map +1 -0
  11. package/dist/agents/data-tools.js +309 -0
  12. package/dist/agents/data-tools.js.map +1 -0
  13. package/dist/agents/filesystem-tools.d.ts +2 -0
  14. package/dist/agents/filesystem-tools.d.ts.map +1 -0
  15. package/dist/agents/filesystem-tools.js +267 -0
  16. package/dist/agents/filesystem-tools.js.map +1 -0
  17. package/dist/agents/guardrails.d.ts +17 -0
  18. package/dist/agents/guardrails.d.ts.map +1 -0
  19. package/dist/agents/guardrails.js +260 -0
  20. package/dist/agents/guardrails.js.map +1 -0
  21. package/dist/agents/orchestrator.d.ts +9 -0
  22. package/dist/agents/orchestrator.d.ts.map +1 -0
  23. package/dist/agents/orchestrator.js +136 -0
  24. package/dist/agents/orchestrator.js.map +1 -0
  25. package/dist/agents/safety.d.ts +9 -0
  26. package/dist/agents/safety.d.ts.map +1 -0
  27. package/dist/agents/safety.js +40 -0
  28. package/dist/agents/safety.js.map +1 -0
  29. package/dist/agents/sandbox.d.ts +34 -0
  30. package/dist/agents/sandbox.d.ts.map +1 -0
  31. package/dist/agents/sandbox.js +235 -0
  32. package/dist/agents/sandbox.js.map +1 -0
  33. package/dist/agents/swarm.d.ts +25 -0
  34. package/dist/agents/swarm.d.ts.map +1 -0
  35. package/dist/agents/swarm.js +434 -0
  36. package/dist/agents/swarm.js.map +1 -0
  37. package/dist/agents/tools.d.ts +37 -0
  38. package/dist/agents/tools.d.ts.map +1 -0
  39. package/dist/agents/tools.js +451 -0
  40. package/dist/agents/tools.js.map +1 -0
  41. package/dist/bridge/index.d.ts +52 -0
  42. package/dist/bridge/index.d.ts.map +1 -0
  43. package/dist/bridge/index.js +195 -0
  44. package/dist/bridge/index.js.map +1 -0
  45. package/dist/config/index.d.ts +106 -0
  46. package/dist/config/index.d.ts.map +1 -0
  47. package/dist/config/index.js +217 -0
  48. package/dist/config/index.js.map +1 -0
  49. package/dist/db/index.d.ts +4 -0
  50. package/dist/db/index.d.ts.map +1 -0
  51. package/dist/db/index.js +4 -0
  52. package/dist/db/index.js.map +1 -0
  53. package/dist/db/redis.d.ts +14 -0
  54. package/dist/db/redis.d.ts.map +1 -0
  55. package/dist/db/redis.js +204 -0
  56. package/dist/db/redis.js.map +1 -0
  57. package/dist/db/supabase.d.ts +57 -0
  58. package/dist/db/supabase.d.ts.map +1 -0
  59. package/dist/db/supabase.js +156 -0
  60. package/dist/db/supabase.js.map +1 -0
  61. package/dist/db/users.d.ts +50 -0
  62. package/dist/db/users.d.ts.map +1 -0
  63. package/dist/db/users.js +132 -0
  64. package/dist/db/users.js.map +1 -0
  65. package/dist/export/index.d.ts +51 -0
  66. package/dist/export/index.d.ts.map +1 -0
  67. package/dist/export/index.js +126 -0
  68. package/dist/export/index.js.map +1 -0
  69. package/dist/geo/bearing-capacity.d.ts +60 -0
  70. package/dist/geo/bearing-capacity.d.ts.map +1 -0
  71. package/dist/geo/bearing-capacity.js +195 -0
  72. package/dist/geo/bearing-capacity.js.map +1 -0
  73. package/dist/geo/classification.d.ts +107 -0
  74. package/dist/geo/classification.d.ts.map +1 -0
  75. package/dist/geo/classification.js +261 -0
  76. package/dist/geo/classification.js.map +1 -0
  77. package/dist/geo/index.d.ts +9 -0
  78. package/dist/geo/index.d.ts.map +1 -0
  79. package/dist/geo/index.js +9 -0
  80. package/dist/geo/index.js.map +1 -0
  81. package/dist/geo/lateral-earth-pressure.d.ts +75 -0
  82. package/dist/geo/lateral-earth-pressure.d.ts.map +1 -0
  83. package/dist/geo/lateral-earth-pressure.js +219 -0
  84. package/dist/geo/lateral-earth-pressure.js.map +1 -0
  85. package/dist/geo/liquefaction.d.ts +65 -0
  86. package/dist/geo/liquefaction.d.ts.map +1 -0
  87. package/dist/geo/liquefaction.js +163 -0
  88. package/dist/geo/liquefaction.js.map +1 -0
  89. package/dist/geo/pile-capacity.d.ts +91 -0
  90. package/dist/geo/pile-capacity.d.ts.map +1 -0
  91. package/dist/geo/pile-capacity.js +233 -0
  92. package/dist/geo/pile-capacity.js.map +1 -0
  93. package/dist/geo/settlement.d.ts +119 -0
  94. package/dist/geo/settlement.d.ts.map +1 -0
  95. package/dist/geo/settlement.js +184 -0
  96. package/dist/geo/settlement.js.map +1 -0
  97. package/dist/geo/slope-stability.d.ts +82 -0
  98. package/dist/geo/slope-stability.d.ts.map +1 -0
  99. package/dist/geo/slope-stability.js +214 -0
  100. package/dist/geo/slope-stability.js.map +1 -0
  101. package/dist/geo/tunnel/index.d.ts +2 -0
  102. package/dist/geo/tunnel/index.d.ts.map +1 -0
  103. package/dist/geo/tunnel/index.js +2 -0
  104. package/dist/geo/tunnel/index.js.map +1 -0
  105. package/dist/geo/tunnel/tbm.d.ts +135 -0
  106. package/dist/geo/tunnel/tbm.d.ts.map +1 -0
  107. package/dist/geo/tunnel/tbm.js +268 -0
  108. package/dist/geo/tunnel/tbm.js.map +1 -0
  109. package/dist/index.d.ts +20 -0
  110. package/dist/index.d.ts.map +1 -0
  111. package/dist/index.js +33 -0
  112. package/dist/index.js.map +1 -0
  113. package/dist/ingest/ags.d.ts +42 -0
  114. package/dist/ingest/ags.d.ts.map +1 -0
  115. package/dist/ingest/ags.js +133 -0
  116. package/dist/ingest/ags.js.map +1 -0
  117. package/dist/ingest/cpt.d.ts +47 -0
  118. package/dist/ingest/cpt.d.ts.map +1 -0
  119. package/dist/ingest/cpt.js +112 -0
  120. package/dist/ingest/cpt.js.map +1 -0
  121. package/dist/ingest/index.d.ts +3 -0
  122. package/dist/ingest/index.d.ts.map +1 -0
  123. package/dist/ingest/index.js +3 -0
  124. package/dist/ingest/index.js.map +1 -0
  125. package/dist/llm/index.d.ts +5 -0
  126. package/dist/llm/index.d.ts.map +1 -0
  127. package/dist/llm/index.js +4 -0
  128. package/dist/llm/index.js.map +1 -0
  129. package/dist/llm/middleware/metering.d.ts +55 -0
  130. package/dist/llm/middleware/metering.d.ts.map +1 -0
  131. package/dist/llm/middleware/metering.js +191 -0
  132. package/dist/llm/middleware/metering.js.map +1 -0
  133. package/dist/llm/middleware/persistent-usage.d.ts +7 -0
  134. package/dist/llm/middleware/persistent-usage.d.ts.map +1 -0
  135. package/dist/llm/middleware/persistent-usage.js +108 -0
  136. package/dist/llm/middleware/persistent-usage.js.map +1 -0
  137. package/dist/llm/middleware/retry.d.ts +7 -0
  138. package/dist/llm/middleware/retry.d.ts.map +1 -0
  139. package/dist/llm/middleware/retry.js +29 -0
  140. package/dist/llm/middleware/retry.js.map +1 -0
  141. package/dist/llm/providers/anthropic.d.ts +10 -0
  142. package/dist/llm/providers/anthropic.d.ts.map +1 -0
  143. package/dist/llm/providers/anthropic.js +107 -0
  144. package/dist/llm/providers/anthropic.js.map +1 -0
  145. package/dist/llm/providers/hosted-beta.d.ts +10 -0
  146. package/dist/llm/providers/hosted-beta.d.ts.map +1 -0
  147. package/dist/llm/providers/hosted-beta.js +106 -0
  148. package/dist/llm/providers/hosted-beta.js.map +1 -0
  149. package/dist/llm/providers/huggingface.d.ts +37 -0
  150. package/dist/llm/providers/huggingface.d.ts.map +1 -0
  151. package/dist/llm/providers/huggingface.js +133 -0
  152. package/dist/llm/providers/huggingface.js.map +1 -0
  153. package/dist/llm/providers/openai-compatible.d.ts +27 -0
  154. package/dist/llm/providers/openai-compatible.d.ts.map +1 -0
  155. package/dist/llm/providers/openai-compatible.js +99 -0
  156. package/dist/llm/providers/openai-compatible.js.map +1 -0
  157. package/dist/llm/providers/zhipu.d.ts +10 -0
  158. package/dist/llm/providers/zhipu.d.ts.map +1 -0
  159. package/dist/llm/providers/zhipu.js +81 -0
  160. package/dist/llm/providers/zhipu.js.map +1 -0
  161. package/dist/llm/router.d.ts +35 -0
  162. package/dist/llm/router.d.ts.map +1 -0
  163. package/dist/llm/router.js +109 -0
  164. package/dist/llm/router.js.map +1 -0
  165. package/dist/llm/types.d.ts +63 -0
  166. package/dist/llm/types.d.ts.map +1 -0
  167. package/dist/llm/types.js +38 -0
  168. package/dist/llm/types.js.map +1 -0
  169. package/dist/meta/index.d.ts +12 -0
  170. package/dist/meta/index.d.ts.map +1 -0
  171. package/dist/meta/index.js +8 -0
  172. package/dist/meta/index.js.map +1 -0
  173. package/dist/meta/metadata.json +46 -0
  174. package/dist/report/index.d.ts +20 -0
  175. package/dist/report/index.d.ts.map +1 -0
  176. package/dist/report/index.js +58 -0
  177. package/dist/report/index.js.map +1 -0
  178. package/dist/standards/index.d.ts +23 -0
  179. package/dist/standards/index.d.ts.map +1 -0
  180. package/dist/standards/index.js +89 -0
  181. package/dist/standards/index.js.map +1 -0
  182. package/dist/storage/index.d.ts +114 -0
  183. package/dist/storage/index.d.ts.map +1 -0
  184. package/dist/storage/index.js +465 -0
  185. package/dist/storage/index.js.map +1 -0
  186. package/dist/vision/index.d.ts +80 -0
  187. package/dist/vision/index.d.ts.map +1 -0
  188. package/dist/vision/index.js +298 -0
  189. package/dist/vision/index.js.map +1 -0
  190. package/dist/vision/parse.d.ts +20 -0
  191. package/dist/vision/parse.d.ts.map +1 -0
  192. package/dist/vision/parse.js +75 -0
  193. package/dist/vision/parse.js.map +1 -0
  194. package/package.json +55 -0
@@ -0,0 +1,119 @@
1
+ import { z } from 'zod';
2
+ export declare const ConsolidationInputSchema: z.ZodObject<{
3
+ compressionIndex: z.ZodNumber;
4
+ recompressionIndex: z.ZodOptional<z.ZodNumber>;
5
+ voidRatio: z.ZodNumber;
6
+ layerThickness: z.ZodNumber;
7
+ stressIncrease: z.ZodNumber;
8
+ initialEffectiveStress: z.ZodNumber;
9
+ preconsolidationPressure: z.ZodOptional<z.ZodNumber>;
10
+ drainagePath: z.ZodDefault<z.ZodEnum<["single", "double"]>>;
11
+ coefficientOfConsolidation: z.ZodOptional<z.ZodNumber>;
12
+ }, "strip", z.ZodTypeAny, {
13
+ compressionIndex: number;
14
+ voidRatio: number;
15
+ layerThickness: number;
16
+ stressIncrease: number;
17
+ initialEffectiveStress: number;
18
+ drainagePath: "single" | "double";
19
+ recompressionIndex?: number | undefined;
20
+ preconsolidationPressure?: number | undefined;
21
+ coefficientOfConsolidation?: number | undefined;
22
+ }, {
23
+ compressionIndex: number;
24
+ voidRatio: number;
25
+ layerThickness: number;
26
+ stressIncrease: number;
27
+ initialEffectiveStress: number;
28
+ recompressionIndex?: number | undefined;
29
+ preconsolidationPressure?: number | undefined;
30
+ drainagePath?: "single" | "double" | undefined;
31
+ coefficientOfConsolidation?: number | undefined;
32
+ }>;
33
+ export type ConsolidationInput = z.infer<typeof ConsolidationInputSchema>;
34
+ export interface ConsolidationResult {
35
+ primarySettlement: number;
36
+ isOverconsolidated: boolean;
37
+ steps: string[];
38
+ timeSettlement?: Array<{
39
+ timeFactor: number;
40
+ consolidation: number;
41
+ timeYears: number;
42
+ settlement: number;
43
+ }>;
44
+ }
45
+ export declare function calculateConsolidation(input: ConsolidationInput): ConsolidationResult;
46
+ export declare const SchmertmannInputSchema: z.ZodObject<{
47
+ appliedStress: z.ZodNumber;
48
+ foundationWidth: z.ZodNumber;
49
+ layers: z.ZodArray<z.ZodObject<{
50
+ thickness: z.ZodNumber;
51
+ elasticModulus: z.ZodNumber;
52
+ }, "strip", z.ZodTypeAny, {
53
+ thickness: number;
54
+ elasticModulus: number;
55
+ }, {
56
+ thickness: number;
57
+ elasticModulus: number;
58
+ }>, "many">;
59
+ embedmentDepth: z.ZodDefault<z.ZodNumber>;
60
+ unitWeight: z.ZodDefault<z.ZodNumber>;
61
+ timeFactor: z.ZodDefault<z.ZodNumber>;
62
+ }, "strip", z.ZodTypeAny, {
63
+ unitWeight: number;
64
+ layers: {
65
+ thickness: number;
66
+ elasticModulus: number;
67
+ }[];
68
+ appliedStress: number;
69
+ foundationWidth: number;
70
+ embedmentDepth: number;
71
+ timeFactor: number;
72
+ }, {
73
+ layers: {
74
+ thickness: number;
75
+ elasticModulus: number;
76
+ }[];
77
+ appliedStress: number;
78
+ foundationWidth: number;
79
+ unitWeight?: number | undefined;
80
+ embedmentDepth?: number | undefined;
81
+ timeFactor?: number | undefined;
82
+ }>;
83
+ export type SchmertmannInput = z.infer<typeof SchmertmannInputSchema>;
84
+ export interface SchmertmannResult {
85
+ immediateSettlement: number;
86
+ creepSettlement: number;
87
+ totalSettlement: number;
88
+ steps: string[];
89
+ }
90
+ export declare function calculateSchmertmann(input: SchmertmannInput): SchmertmannResult;
91
+ export declare const PeckSettlementInputSchema: z.ZodObject<{
92
+ tunnelDiameter: z.ZodNumber;
93
+ tunnelDepth: z.ZodNumber;
94
+ volumeLoss: z.ZodDefault<z.ZodNumber>;
95
+ troughWidthParam: z.ZodDefault<z.ZodNumber>;
96
+ }, "strip", z.ZodTypeAny, {
97
+ tunnelDiameter: number;
98
+ tunnelDepth: number;
99
+ volumeLoss: number;
100
+ troughWidthParam: number;
101
+ }, {
102
+ tunnelDiameter: number;
103
+ tunnelDepth: number;
104
+ volumeLoss?: number | undefined;
105
+ troughWidthParam?: number | undefined;
106
+ }>;
107
+ export type PeckSettlementInput = z.infer<typeof PeckSettlementInputSchema>;
108
+ export interface PeckSettlementResult {
109
+ maxSettlement: number;
110
+ inflectionPoint: number;
111
+ troughWidth: number;
112
+ profile: Array<{
113
+ x: number;
114
+ settlement: number;
115
+ }>;
116
+ steps: string[];
117
+ }
118
+ export declare function calculatePeckSettlement(input: PeckSettlementInput): PeckSettlementResult;
119
+ //# sourceMappingURL=settlement.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"settlement.d.ts","sourceRoot":"","sources":["../../src/geo/settlement.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAMxB,eAAO,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAUnC,CAAC;AAEH,MAAM,MAAM,kBAAkB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,wBAAwB,CAAC,CAAC;AAE1E,MAAM,WAAW,mBAAmB;IAClC,iBAAiB,EAAE,MAAM,CAAC;IAC1B,kBAAkB,EAAE,OAAO,CAAC;IAC5B,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,cAAc,CAAC,EAAE,KAAK,CAAC;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,aAAa,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;CAC9G;AAED,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,kBAAkB,GAAG,mBAAmB,CAiErF;AAMD,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAUjC,CAAC;AAEH,MAAM,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,sBAAsB,CAAC,CAAC;AAEtE,MAAM,WAAW,iBAAiB;IAChC,mBAAmB,EAAE,MAAM,CAAC;IAC5B,eAAe,EAAE,MAAM,CAAC;IACxB,eAAe,EAAE,MAAM,CAAC;IACxB,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,gBAAgB,GAAG,iBAAiB,CA+D/E;AAMD,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;EAKpC,CAAC;AAEH,MAAM,MAAM,mBAAmB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,yBAAyB,CAAC,CAAC;AAE5E,MAAM,WAAW,oBAAoB;IACnC,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;IACxB,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,KAAK,CAAC;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAClD,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,mBAAmB,GAAG,oBAAoB,CAwCxF"}
@@ -0,0 +1,184 @@
1
+ import { z } from 'zod';
2
+ // ---------------------------------------------------------------------------
3
+ // Terzaghi 1D consolidation
4
+ // ---------------------------------------------------------------------------
5
+ export const ConsolidationInputSchema = z.object({
6
+ compressionIndex: z.number().positive().describe('Compression index Cc'),
7
+ recompressionIndex: z.number().positive().optional().describe('Recompression index Cr'),
8
+ voidRatio: z.number().positive().describe('Initial void ratio e₀'),
9
+ layerThickness: z.number().positive().describe('Clay layer thickness H (m)'),
10
+ stressIncrease: z.number().positive().describe('Stress increase Δσ (kPa)'),
11
+ initialEffectiveStress: z.number().positive().describe('Initial effective stress σ₀ (kPa)'),
12
+ preconsolidationPressure: z.number().positive().optional().describe('Preconsolidation pressure σ_p (kPa)'),
13
+ drainagePath: z.enum(['single', 'double']).default('double'),
14
+ coefficientOfConsolidation: z.number().positive().optional().describe('Cv (m²/year)'),
15
+ });
16
+ export function calculateConsolidation(input) {
17
+ const v = ConsolidationInputSchema.parse(input);
18
+ const steps = [];
19
+ const { compressionIndex: Cc, voidRatio: e0, layerThickness: H, stressIncrease: dSigma, initialEffectiveStress: sigma0 } = v;
20
+ const Cr = v.recompressionIndex ?? Cc / 5;
21
+ const sigmaP = v.preconsolidationPressure ?? sigma0;
22
+ const Hd = v.drainagePath === 'double' ? H / 2 : H;
23
+ const sigmaFinal = sigma0 + dSigma;
24
+ const isOC = sigmaP > sigma0;
25
+ steps.push(`σ₀' = ${sigma0.toFixed(1)} kPa, Δσ = ${dSigma.toFixed(1)} kPa, σ_f' = ${sigmaFinal.toFixed(1)} kPa`);
26
+ steps.push(`Cc = ${Cc}, e₀ = ${e0}, H = ${H} m, drainage = ${v.drainagePath}`);
27
+ let settlement;
28
+ if (!isOC || sigmaFinal <= sigmaP) {
29
+ // Normally consolidated or loading within recompression range
30
+ if (isOC && sigmaFinal <= sigmaP) {
31
+ settlement = (Cr / (1 + e0)) * Math.log10(sigmaFinal / sigma0) * H;
32
+ steps.push(`OC soil, σ_f' ≤ σ_p': S = Cr/(1+e₀) × log(σ_f'/σ₀') × H`);
33
+ }
34
+ else {
35
+ settlement = (Cc / (1 + e0)) * Math.log10(sigmaFinal / sigma0) * H;
36
+ steps.push(`NC soil: S = Cc/(1+e₀) × log(σ_f'/σ₀') × H`);
37
+ }
38
+ }
39
+ else {
40
+ // OC soil loaded past preconsolidation
41
+ const s1 = (Cr / (1 + e0)) * Math.log10(sigmaP / sigma0) * H;
42
+ const s2 = (Cc / (1 + e0)) * Math.log10(sigmaFinal / sigmaP) * H;
43
+ settlement = s1 + s2;
44
+ steps.push(`OC soil, σ_f' > σ_p': S = Cr/(1+e₀)×log(σ_p'/σ₀')×H + Cc/(1+e₀)×log(σ_f'/σ_p')×H`);
45
+ steps.push(`S₁ (recompression) = ${(s1 * 1000).toFixed(1)} mm`);
46
+ steps.push(`S₂ (virgin compression) = ${(s2 * 1000).toFixed(1)} mm`);
47
+ }
48
+ steps.push(`Total primary consolidation settlement = ${(settlement * 1000).toFixed(1)} mm`);
49
+ // Time-settlement curve if Cv provided
50
+ let timeSettlement;
51
+ if (v.coefficientOfConsolidation) {
52
+ const Cv = v.coefficientOfConsolidation;
53
+ timeSettlement = [];
54
+ const tvValues = [0.008, 0.031, 0.071, 0.126, 0.197, 0.287, 0.403, 0.567, 0.848, 1.0, 1.5, 2.0];
55
+ const uValues = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 0.95, 0.99, 1.0];
56
+ for (let i = 0; i < tvValues.length; i++) {
57
+ const Tv = tvValues[i];
58
+ const U = uValues[i];
59
+ const t = (Tv * Hd * Hd) / Cv;
60
+ timeSettlement.push({
61
+ timeFactor: Tv,
62
+ consolidation: U,
63
+ timeYears: Math.round(t * 100) / 100,
64
+ settlement: Math.round(settlement * U * 1000 * 10) / 10,
65
+ });
66
+ }
67
+ }
68
+ return {
69
+ primarySettlement: Math.round(settlement * 1000 * 10) / 10,
70
+ isOverconsolidated: isOC,
71
+ steps,
72
+ timeSettlement,
73
+ };
74
+ }
75
+ // ---------------------------------------------------------------------------
76
+ // Schmertmann method (immediate settlement)
77
+ // ---------------------------------------------------------------------------
78
+ export const SchmertmannInputSchema = z.object({
79
+ appliedStress: z.number().positive().describe('Net applied stress q (kPa)'),
80
+ foundationWidth: z.number().positive().describe('Foundation width B (m)'),
81
+ layers: z.array(z.object({
82
+ thickness: z.number().positive().describe('Layer thickness (m)'),
83
+ elasticModulus: z.number().positive().describe('Es from CPT or SPT (kPa)'),
84
+ })).min(1),
85
+ embedmentDepth: z.number().nonnegative().default(0),
86
+ unitWeight: z.number().positive().default(18),
87
+ timeFactor: z.number().positive().default(1).describe('Creep time factor (years)'),
88
+ });
89
+ export function calculateSchmertmann(input) {
90
+ const v = SchmertmannInputSchema.parse(input);
91
+ const steps = [];
92
+ const { appliedStress: q, foundationWidth: B, layers, embedmentDepth: D, unitWeight: gamma, timeFactor } = v;
93
+ // Influence depth = 2B for L/B=1 (square), 4B for strip
94
+ const zMax = 2 * B;
95
+ steps.push(`Influence depth z_max = 2B = ${zMax.toFixed(1)} m`);
96
+ // Peak influence factor at z = B/2
97
+ const zPeak = B / 2;
98
+ const sigmaVp = gamma * (D + zPeak);
99
+ const IzPeak = 0.5 + 0.1 * Math.sqrt(q / sigmaVp);
100
+ steps.push(`Peak Iz at z = B/2 = ${zPeak.toFixed(1)} m: Iz_peak = ${IzPeak.toFixed(3)}`);
101
+ // Embedment correction C1
102
+ const q0 = gamma * D;
103
+ const C1 = Math.max(0.5, 1 - 0.5 * (q0 / q));
104
+ steps.push(`C₁ (embedment) = 1 - 0.5(q₀/q) = ${C1.toFixed(3)}`);
105
+ // Creep correction C2
106
+ const C2 = 1 + 0.2 * Math.log10(timeFactor / 0.1);
107
+ steps.push(`C₂ (creep, t=${timeFactor} yr) = ${C2.toFixed(3)}`);
108
+ // Sum Iz/Es * dz for each sublayer
109
+ let zCurrent = 0;
110
+ let sumIzDzEs = 0;
111
+ for (const layer of layers) {
112
+ const zMid = zCurrent + layer.thickness / 2;
113
+ if (zMid > zMax)
114
+ break;
115
+ // Triangular Iz distribution: 0 at z=0, peak at z=B/2, 0 at z=2B
116
+ let Iz;
117
+ if (zMid <= zPeak) {
118
+ Iz = (zMid / zPeak) * IzPeak;
119
+ }
120
+ else {
121
+ Iz = IzPeak * (1 - (zMid - zPeak) / (zMax - zPeak));
122
+ }
123
+ Iz = Math.max(0, Iz);
124
+ const contribution = (Iz * layer.thickness) / layer.elasticModulus;
125
+ sumIzDzEs += contribution;
126
+ steps.push(` z=${zMid.toFixed(1)}m: Iz=${Iz.toFixed(3)}, Es=${layer.elasticModulus} kPa, contrib=${(contribution * 1000).toFixed(4)}`);
127
+ zCurrent += layer.thickness;
128
+ }
129
+ const immediateSettlement = C1 * q * sumIzDzEs * 1000;
130
+ const creepSettlement = immediateSettlement * (C2 - 1);
131
+ const totalSettlement = C1 * C2 * q * sumIzDzEs * 1000;
132
+ steps.push(`Immediate settlement = ${immediateSettlement.toFixed(1)} mm`);
133
+ steps.push(`Creep settlement = ${creepSettlement.toFixed(1)} mm`);
134
+ steps.push(`Total settlement = ${totalSettlement.toFixed(1)} mm`);
135
+ return {
136
+ immediateSettlement: Math.round(immediateSettlement * 10) / 10,
137
+ creepSettlement: Math.round(creepSettlement * 10) / 10,
138
+ totalSettlement: Math.round(totalSettlement * 10) / 10,
139
+ steps,
140
+ };
141
+ }
142
+ // ---------------------------------------------------------------------------
143
+ // Peck tunnel settlement trough
144
+ // ---------------------------------------------------------------------------
145
+ export const PeckSettlementInputSchema = z.object({
146
+ tunnelDiameter: z.number().positive().describe('Tunnel diameter D (m)'),
147
+ tunnelDepth: z.number().positive().describe('Depth to tunnel axis Z₀ (m)'),
148
+ volumeLoss: z.number().positive().max(10).default(1.0).describe('Volume loss Vl (%)'),
149
+ troughWidthParam: z.number().positive().default(0.5).describe('Trough width parameter K'),
150
+ });
151
+ export function calculatePeckSettlement(input) {
152
+ const v = PeckSettlementInputSchema.parse(input);
153
+ const steps = [];
154
+ const { tunnelDiameter: D, tunnelDepth: Z0, volumeLoss: Vl, troughWidthParam: K } = v;
155
+ // Trough width parameter i = K × Z₀
156
+ const i = K * Z0;
157
+ steps.push(`Trough width parameter: i = K × Z₀ = ${K} × ${Z0} = ${i.toFixed(2)} m`);
158
+ // Volume of settlement trough per unit length
159
+ const Vs = (Vl / 100) * Math.PI * (D / 2) ** 2;
160
+ steps.push(`Settlement volume: Vs = Vl × π(D/2)² = ${Vs.toFixed(4)} m³/m`);
161
+ // Maximum settlement: Smax = Vs / (i × √(2π))
162
+ const Smax = Vs / (i * Math.sqrt(2 * Math.PI));
163
+ steps.push(`Max surface settlement: Smax = Vs / (i√(2π)) = ${(Smax * 1000).toFixed(1)} mm`);
164
+ // Settlement profile: S(x) = Smax × exp(-x²/(2i²))
165
+ const profile = [];
166
+ const xRange = 3 * i;
167
+ const step = xRange / 30;
168
+ for (let x = -xRange; x <= xRange; x += step) {
169
+ const S = Smax * Math.exp(-(x * x) / (2 * i * i));
170
+ profile.push({
171
+ x: Math.round(x * 100) / 100,
172
+ settlement: Math.round(S * 1000 * 10) / 10,
173
+ });
174
+ }
175
+ steps.push(`Trough width (2.5i) = ${(2.5 * i).toFixed(1)} m`);
176
+ return {
177
+ maxSettlement: Math.round(Smax * 1000 * 10) / 10,
178
+ inflectionPoint: Math.round(i * 100) / 100,
179
+ troughWidth: Math.round(2.5 * i * 100) / 100,
180
+ profile,
181
+ steps,
182
+ };
183
+ }
184
+ //# sourceMappingURL=settlement.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"settlement.js","sourceRoot":"","sources":["../../src/geo/settlement.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,82 @@
1
+ import { z } from 'zod';
2
+ export declare const SlopeStabilityInputSchema: z.ZodObject<{
3
+ slopeHeight: z.ZodNumber;
4
+ slopeAngle: z.ZodNumber;
5
+ soilLayers: z.ZodArray<z.ZodObject<{
6
+ thickness: z.ZodNumber;
7
+ unitWeight: z.ZodNumber;
8
+ cohesion: z.ZodNumber;
9
+ frictionAngle: z.ZodNumber;
10
+ saturatedUnitWeight: z.ZodOptional<z.ZodNumber>;
11
+ }, "strip", z.ZodTypeAny, {
12
+ unitWeight: number;
13
+ cohesion: number;
14
+ frictionAngle: number;
15
+ thickness: number;
16
+ saturatedUnitWeight?: number | undefined;
17
+ }, {
18
+ unitWeight: number;
19
+ cohesion: number;
20
+ frictionAngle: number;
21
+ thickness: number;
22
+ saturatedUnitWeight?: number | undefined;
23
+ }>, "many">;
24
+ waterTableDepth: z.ZodDefault<z.ZodNumber>;
25
+ surcharge: z.ZodDefault<z.ZodNumber>;
26
+ seismicCoefficient: z.ZodDefault<z.ZodNumber>;
27
+ numberOfSlices: z.ZodDefault<z.ZodNumber>;
28
+ method: z.ZodDefault<z.ZodEnum<["bishop", "ordinary"]>>;
29
+ }, "strip", z.ZodTypeAny, {
30
+ method: "bishop" | "ordinary";
31
+ waterTableDepth: number;
32
+ slopeHeight: number;
33
+ slopeAngle: number;
34
+ soilLayers: {
35
+ unitWeight: number;
36
+ cohesion: number;
37
+ frictionAngle: number;
38
+ thickness: number;
39
+ saturatedUnitWeight?: number | undefined;
40
+ }[];
41
+ surcharge: number;
42
+ seismicCoefficient: number;
43
+ numberOfSlices: number;
44
+ }, {
45
+ slopeHeight: number;
46
+ slopeAngle: number;
47
+ soilLayers: {
48
+ unitWeight: number;
49
+ cohesion: number;
50
+ frictionAngle: number;
51
+ thickness: number;
52
+ saturatedUnitWeight?: number | undefined;
53
+ }[];
54
+ method?: "bishop" | "ordinary" | undefined;
55
+ waterTableDepth?: number | undefined;
56
+ surcharge?: number | undefined;
57
+ seismicCoefficient?: number | undefined;
58
+ numberOfSlices?: number | undefined;
59
+ }>;
60
+ export type SlopeStabilityInput = z.infer<typeof SlopeStabilityInputSchema>;
61
+ export interface SlopeStabilityResult {
62
+ method: string;
63
+ factorOfSafety: number;
64
+ criticalCircle: {
65
+ centerX: number;
66
+ centerY: number;
67
+ radius: number;
68
+ };
69
+ sliceResults: Array<{
70
+ sliceNumber: number;
71
+ width: number;
72
+ weight: number;
73
+ baseAngle: number;
74
+ normalForce: number;
75
+ shearStrength: number;
76
+ }>;
77
+ isStable: boolean;
78
+ stabilityClass: 'STABLE' | 'MARGINAL' | 'UNSTABLE' | 'CRITICAL';
79
+ steps: string[];
80
+ }
81
+ export declare function calculateSlopeStability(input: SlopeStabilityInput): SlopeStabilityResult;
82
+ //# sourceMappingURL=slope-stability.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slope-stability.d.ts","sourceRoot":"","sources":["../../src/geo/slope-stability.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAcxB,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAepC,CAAC;AAEH,MAAM,MAAM,mBAAmB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,yBAAyB,CAAC,CAAC;AAE5E,MAAM,WAAW,oBAAoB;IACnC,MAAM,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,MAAM,CAAC;IACvB,cAAc,EAAE;QACd,OAAO,EAAE,MAAM,CAAC;QAChB,OAAO,EAAE,MAAM,CAAC;QAChB,MAAM,EAAE,MAAM,CAAC;KAChB,CAAC;IACF,YAAY,EAAE,KAAK,CAAC;QAClB,WAAW,EAAE,MAAM,CAAC;QACpB,KAAK,EAAE,MAAM,CAAC;QACd,MAAM,EAAE,MAAM,CAAC;QACf,SAAS,EAAE,MAAM,CAAC;QAClB,WAAW,EAAE,MAAM,CAAC;QACpB,aAAa,EAAE,MAAM,CAAC;KACvB,CAAC,CAAC;IACH,QAAQ,EAAE,OAAO,CAAC;IAClB,cAAc,EAAE,QAAQ,GAAG,UAAU,GAAG,UAAU,GAAG,UAAU,CAAC;IAChE,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAuJD,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,mBAAmB,GAAG,oBAAoB,CA6ExF"}
@@ -0,0 +1,214 @@
1
+ import { z } from 'zod';
2
+ // ---------------------------------------------------------------------------
3
+ // Slope Stability — Bishop Simplified Method
4
+ //
5
+ // Implements the method of slices with Bishop's simplified assumption
6
+ // (normal forces on slice sides are horizontal).
7
+ //
8
+ // References:
9
+ // - Bishop, A.W. (1955). "The use of the slip circle in the stability analysis of slopes."
10
+ // - Duncan, J.M. & Wright, S.G. (2005). "Soil Strength and Slope Stability."
11
+ // - Eurocode 7 (EN 1997-1:2004), Section 11
12
+ // ---------------------------------------------------------------------------
13
+ export const SlopeStabilityInputSchema = z.object({
14
+ slopeHeight: z.number().positive().describe('Slope height H (m)'),
15
+ slopeAngle: z.number().min(1).max(89).describe('Slope angle from horizontal (degrees)'),
16
+ soilLayers: z.array(z.object({
17
+ thickness: z.number().positive().describe('Layer thickness (m)'),
18
+ unitWeight: z.number().positive().describe('Total unit weight γ (kN/m³)'),
19
+ cohesion: z.number().min(0).describe('Effective cohesion c\' (kPa)'),
20
+ frictionAngle: z.number().min(0).max(50).describe('Effective friction angle φ\' (degrees)'),
21
+ saturatedUnitWeight: z.number().positive().optional().describe('Saturated unit weight γ_sat (kN/m³)'),
22
+ })).min(1),
23
+ waterTableDepth: z.number().min(0).default(999).describe('Depth to water table from crest (m)'),
24
+ surcharge: z.number().min(0).default(0).describe('Surcharge load at crest (kPa)'),
25
+ seismicCoefficient: z.number().min(0).default(0).describe('Horizontal seismic coefficient kh'),
26
+ numberOfSlices: z.number().int().min(5).max(50).default(10),
27
+ method: z.enum(['bishop', 'ordinary']).default('bishop'),
28
+ });
29
+ function degToRad(deg) {
30
+ return (deg * Math.PI) / 180;
31
+ }
32
+ // ---------------------------------------------------------------------------
33
+ // Bishop Simplified Iteration
34
+ // ---------------------------------------------------------------------------
35
+ function bishopAnalysis(centerX, centerY, radius, slopeAngle, slopeHeight, layers, gwt, surcharge, kh, nSlices) {
36
+ const slopeAngleRad = degToRad(slopeAngle);
37
+ const slopeLength = slopeHeight / Math.sin(slopeAngleRad);
38
+ const slopeBase = slopeHeight / Math.tan(slopeAngleRad);
39
+ // Find intersection of circle with slope surface
40
+ // Simplification: use chord from left to right intersection
41
+ const leftX = centerX - radius;
42
+ const rightX = centerX + radius;
43
+ const sliceWidth = (rightX - leftX) / nSlices;
44
+ const slices = [];
45
+ // Iterative Bishop solution
46
+ let fos = 1.5; // initial guess
47
+ const maxIterations = 50;
48
+ const tolerance = 0.001;
49
+ for (let iter = 0; iter < maxIterations; iter++) {
50
+ let sumResisting = 0;
51
+ let sumDriving = 0;
52
+ const iterSlices = [];
53
+ for (let i = 0; i < nSlices; i++) {
54
+ const xMid = leftX + (i + 0.5) * sliceWidth;
55
+ const dx = xMid - centerX;
56
+ // Base of slice on circle
57
+ const yBase = centerY - Math.sqrt(Math.max(0, radius * radius - dx * dx));
58
+ // Surface elevation at this x
59
+ let ySurface;
60
+ if (xMid <= 0) {
61
+ ySurface = slopeHeight; // crest
62
+ }
63
+ else if (xMid >= slopeBase) {
64
+ ySurface = 0; // toe
65
+ }
66
+ else {
67
+ ySurface = slopeHeight - xMid * Math.tan(slopeAngleRad) * (slopeHeight / (slopeBase * Math.tan(slopeAngleRad)));
68
+ ySurface = Math.max(0, slopeHeight * (1 - xMid / slopeBase));
69
+ }
70
+ const height = Math.max(0, ySurface - yBase);
71
+ if (height <= 0.01)
72
+ continue;
73
+ // Base angle
74
+ const alpha = Math.atan2(dx, Math.sqrt(Math.max(0, radius * radius - dx * dx)));
75
+ // Determine soil properties at base of slice
76
+ let depth = ySurface - yBase;
77
+ let cumThickness = 0;
78
+ let c = layers[0].cohesion;
79
+ let phi = layers[0].frictionAngle;
80
+ let gamma = layers[0].unitWeight;
81
+ for (const layer of layers) {
82
+ cumThickness += layer.thickness;
83
+ if (yBase <= ySurface - cumThickness + layer.thickness) {
84
+ c = layer.cohesion;
85
+ phi = layer.frictionAngle;
86
+ gamma = layer.unitWeight;
87
+ break;
88
+ }
89
+ }
90
+ // Weight of slice
91
+ const W = gamma * height * sliceWidth + (xMid <= 0 ? surcharge * sliceWidth : 0);
92
+ // Pore water pressure at base
93
+ const hwAboveBase = Math.max(0, (ySurface - gwt) > 0 ? Math.min(height, ySurface - gwt) : height);
94
+ const u = yBase < (ySurface - gwt) ? 0 : 9.81 * Math.max(0, (ySurface - gwt) - yBase + height);
95
+ const uBase = yBase < ySurface - gwt ? 0 : 9.81 * Math.max(0, ySurface - gwt - yBase);
96
+ const phiRad = degToRad(phi);
97
+ const cosAlpha = Math.cos(alpha);
98
+ const sinAlpha = Math.sin(alpha);
99
+ // Bishop's m_alpha factor
100
+ const mAlpha = cosAlpha + (sinAlpha * Math.tan(phiRad)) / fos;
101
+ if (Math.abs(mAlpha) < 0.001)
102
+ continue;
103
+ // Normal force on base (Bishop simplified)
104
+ const baseLength = sliceWidth / cosAlpha;
105
+ const N = (W - uBase * baseLength * sinAlpha) / mAlpha;
106
+ // Shear strength
107
+ const S = (c * baseLength + (N - uBase * baseLength) * Math.tan(phiRad));
108
+ // Driving force
109
+ const drivingForce = W * sinAlpha + kh * W * (height / 2) / radius;
110
+ sumResisting += S / mAlpha;
111
+ sumDriving += W * sinAlpha;
112
+ iterSlices.push({
113
+ sliceNumber: i + 1,
114
+ width: Math.round(sliceWidth * 100) / 100,
115
+ weight: Math.round(W * 10) / 10,
116
+ baseAngle: Math.round(alpha * 180 / Math.PI * 10) / 10,
117
+ normalForce: Math.round(N * 10) / 10,
118
+ shearStrength: Math.round(S * 10) / 10,
119
+ });
120
+ }
121
+ if (Math.abs(sumDriving) < 0.001) {
122
+ fos = 99;
123
+ break;
124
+ }
125
+ const newFos = sumResisting / Math.abs(sumDriving);
126
+ if (Math.abs(newFos - fos) < tolerance) {
127
+ fos = newFos;
128
+ slices.push(...iterSlices);
129
+ break;
130
+ }
131
+ fos = newFos;
132
+ if (iter === maxIterations - 1) {
133
+ slices.push(...iterSlices);
134
+ }
135
+ }
136
+ return { fos, slices };
137
+ }
138
+ // ---------------------------------------------------------------------------
139
+ // Main calculation — searches for critical circle
140
+ // ---------------------------------------------------------------------------
141
+ export function calculateSlopeStability(input) {
142
+ const v = SlopeStabilityInputSchema.parse(input);
143
+ const steps = [];
144
+ const { slopeHeight: H, slopeAngle, soilLayers, waterTableDepth: gwt, surcharge, seismicCoefficient: kh, numberOfSlices } = v;
145
+ const slopeAngleRad = degToRad(slopeAngle);
146
+ const slopeBase = H / Math.tan(slopeAngleRad);
147
+ steps.push(`Slope: H=${H}m, angle=${slopeAngle}°, base=${slopeBase.toFixed(1)}m`);
148
+ steps.push(`Soil: ${soilLayers.length} layer(s), GWT=${gwt}m, kh=${kh}`);
149
+ steps.push(`Method: ${v.method === 'bishop' ? 'Bishop Simplified' : 'Ordinary Method of Slices'}`);
150
+ // Search grid for critical circle center
151
+ let minFos = Infinity;
152
+ let bestCenter = { x: slopeBase / 2, y: H * 1.5 };
153
+ let bestRadius = H;
154
+ let bestSlices = [];
155
+ // Search over circle centers above the slope
156
+ const nSearchX = 8;
157
+ const nSearchY = 6;
158
+ const nSearchR = 5;
159
+ for (let ix = 0; ix < nSearchX; ix++) {
160
+ const cx = -slopeBase * 0.3 + (ix / (nSearchX - 1)) * slopeBase * 1.3;
161
+ for (let iy = 0; iy < nSearchY; iy++) {
162
+ const cy = H * 0.8 + (iy / (nSearchY - 1)) * H * 1.5;
163
+ for (let ir = 0; ir < nSearchR; ir++) {
164
+ const rMin = Math.sqrt((cx - slopeBase) ** 2 + cy ** 2) * 0.8;
165
+ const rMax = Math.sqrt(cx ** 2 + cy ** 2) * 1.2;
166
+ const r = rMin + (ir / Math.max(1, nSearchR - 1)) * (rMax - rMin);
167
+ if (r <= 0 || r < H * 0.3)
168
+ continue;
169
+ try {
170
+ const result = bishopAnalysis(cx, cy, r, slopeAngle, H, soilLayers, gwt, surcharge, kh, numberOfSlices);
171
+ if (result.fos > 0 && result.fos < minFos && result.fos < 50) {
172
+ minFos = result.fos;
173
+ bestCenter = { x: cx, y: cy };
174
+ bestRadius = r;
175
+ bestSlices = result.slices;
176
+ }
177
+ }
178
+ catch {
179
+ // Skip invalid geometry
180
+ }
181
+ }
182
+ }
183
+ }
184
+ // Stability classification
185
+ let stabilityClass;
186
+ if (minFos >= 1.5)
187
+ stabilityClass = 'STABLE';
188
+ else if (minFos >= 1.25)
189
+ stabilityClass = 'MARGINAL';
190
+ else if (minFos >= 1.0)
191
+ stabilityClass = 'UNSTABLE';
192
+ else
193
+ stabilityClass = 'CRITICAL';
194
+ steps.push(`Critical circle: center (${bestCenter.x.toFixed(1)}, ${bestCenter.y.toFixed(1)}), R=${bestRadius.toFixed(1)}m`);
195
+ steps.push(`Factor of Safety: ${minFos.toFixed(3)}`);
196
+ steps.push(`Classification: ${stabilityClass} (EC7 min FOS=1.25 with partial factors, global FOS=1.5)`);
197
+ if (kh > 0) {
198
+ steps.push(`Pseudo-static seismic coefficient kh=${kh} applied (Mononobe-Okabe simplified)`);
199
+ }
200
+ return {
201
+ method: v.method === 'bishop' ? 'Bishop Simplified' : 'Ordinary Method of Slices',
202
+ factorOfSafety: Math.round(minFos * 1000) / 1000,
203
+ criticalCircle: {
204
+ centerX: Math.round(bestCenter.x * 100) / 100,
205
+ centerY: Math.round(bestCenter.y * 100) / 100,
206
+ radius: Math.round(bestRadius * 100) / 100,
207
+ },
208
+ sliceResults: bestSlices,
209
+ isStable: minFos >= 1.5,
210
+ stabilityClass,
211
+ steps,
212
+ };
213
+ }
214
+ //# sourceMappingURL=slope-stability.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slope-stability.js","sourceRoot":"","sources":["../../src/geo/slope-stability.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export { predictTBMPerformance, selectTBMType, predictCutterWear, TBMPredictInputSchema, TBMSelectInputSchema, CutterWearInputSchema, type TBMPredictInput, type TBMPredictResult, type TBMSelectInput, type TBMSelectResult, type CutterWearInput, type CutterWearResult, } from './tbm.js';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/geo/tunnel/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,qBAAqB,EACrB,aAAa,EACb,iBAAiB,EACjB,qBAAqB,EACrB,oBAAoB,EACpB,qBAAqB,EACrB,KAAK,eAAe,EACpB,KAAK,gBAAgB,EACrB,KAAK,cAAc,EACnB,KAAK,eAAe,EACpB,KAAK,eAAe,EACpB,KAAK,gBAAgB,GACtB,MAAM,UAAU,CAAC"}