@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.
- package/dist/agents/brain.d.ts +39 -0
- package/dist/agents/brain.d.ts.map +1 -0
- package/dist/agents/brain.js +339 -0
- package/dist/agents/brain.js.map +1 -0
- package/dist/agents/bridge-tools.d.ts +2 -0
- package/dist/agents/bridge-tools.d.ts.map +1 -0
- package/dist/agents/bridge-tools.js +170 -0
- package/dist/agents/bridge-tools.js.map +1 -0
- package/dist/agents/data-tools.d.ts +2 -0
- package/dist/agents/data-tools.d.ts.map +1 -0
- package/dist/agents/data-tools.js +309 -0
- package/dist/agents/data-tools.js.map +1 -0
- package/dist/agents/filesystem-tools.d.ts +2 -0
- package/dist/agents/filesystem-tools.d.ts.map +1 -0
- package/dist/agents/filesystem-tools.js +267 -0
- package/dist/agents/filesystem-tools.js.map +1 -0
- package/dist/agents/guardrails.d.ts +17 -0
- package/dist/agents/guardrails.d.ts.map +1 -0
- package/dist/agents/guardrails.js +260 -0
- package/dist/agents/guardrails.js.map +1 -0
- package/dist/agents/orchestrator.d.ts +9 -0
- package/dist/agents/orchestrator.d.ts.map +1 -0
- package/dist/agents/orchestrator.js +136 -0
- package/dist/agents/orchestrator.js.map +1 -0
- package/dist/agents/safety.d.ts +9 -0
- package/dist/agents/safety.d.ts.map +1 -0
- package/dist/agents/safety.js +40 -0
- package/dist/agents/safety.js.map +1 -0
- package/dist/agents/sandbox.d.ts +34 -0
- package/dist/agents/sandbox.d.ts.map +1 -0
- package/dist/agents/sandbox.js +235 -0
- package/dist/agents/sandbox.js.map +1 -0
- package/dist/agents/swarm.d.ts +25 -0
- package/dist/agents/swarm.d.ts.map +1 -0
- package/dist/agents/swarm.js +434 -0
- package/dist/agents/swarm.js.map +1 -0
- package/dist/agents/tools.d.ts +37 -0
- package/dist/agents/tools.d.ts.map +1 -0
- package/dist/agents/tools.js +451 -0
- package/dist/agents/tools.js.map +1 -0
- package/dist/bridge/index.d.ts +52 -0
- package/dist/bridge/index.d.ts.map +1 -0
- package/dist/bridge/index.js +195 -0
- package/dist/bridge/index.js.map +1 -0
- package/dist/config/index.d.ts +106 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +217 -0
- package/dist/config/index.js.map +1 -0
- package/dist/db/index.d.ts +4 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +4 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/redis.d.ts +14 -0
- package/dist/db/redis.d.ts.map +1 -0
- package/dist/db/redis.js +204 -0
- package/dist/db/redis.js.map +1 -0
- package/dist/db/supabase.d.ts +57 -0
- package/dist/db/supabase.d.ts.map +1 -0
- package/dist/db/supabase.js +156 -0
- package/dist/db/supabase.js.map +1 -0
- package/dist/db/users.d.ts +50 -0
- package/dist/db/users.d.ts.map +1 -0
- package/dist/db/users.js +132 -0
- package/dist/db/users.js.map +1 -0
- package/dist/export/index.d.ts +51 -0
- package/dist/export/index.d.ts.map +1 -0
- package/dist/export/index.js +126 -0
- package/dist/export/index.js.map +1 -0
- package/dist/geo/bearing-capacity.d.ts +60 -0
- package/dist/geo/bearing-capacity.d.ts.map +1 -0
- package/dist/geo/bearing-capacity.js +195 -0
- package/dist/geo/bearing-capacity.js.map +1 -0
- package/dist/geo/classification.d.ts +107 -0
- package/dist/geo/classification.d.ts.map +1 -0
- package/dist/geo/classification.js +261 -0
- package/dist/geo/classification.js.map +1 -0
- package/dist/geo/index.d.ts +9 -0
- package/dist/geo/index.d.ts.map +1 -0
- package/dist/geo/index.js +9 -0
- package/dist/geo/index.js.map +1 -0
- package/dist/geo/lateral-earth-pressure.d.ts +75 -0
- package/dist/geo/lateral-earth-pressure.d.ts.map +1 -0
- package/dist/geo/lateral-earth-pressure.js +219 -0
- package/dist/geo/lateral-earth-pressure.js.map +1 -0
- package/dist/geo/liquefaction.d.ts +65 -0
- package/dist/geo/liquefaction.d.ts.map +1 -0
- package/dist/geo/liquefaction.js +163 -0
- package/dist/geo/liquefaction.js.map +1 -0
- package/dist/geo/pile-capacity.d.ts +91 -0
- package/dist/geo/pile-capacity.d.ts.map +1 -0
- package/dist/geo/pile-capacity.js +233 -0
- package/dist/geo/pile-capacity.js.map +1 -0
- package/dist/geo/settlement.d.ts +119 -0
- package/dist/geo/settlement.d.ts.map +1 -0
- package/dist/geo/settlement.js +184 -0
- package/dist/geo/settlement.js.map +1 -0
- package/dist/geo/slope-stability.d.ts +82 -0
- package/dist/geo/slope-stability.d.ts.map +1 -0
- package/dist/geo/slope-stability.js +214 -0
- package/dist/geo/slope-stability.js.map +1 -0
- package/dist/geo/tunnel/index.d.ts +2 -0
- package/dist/geo/tunnel/index.d.ts.map +1 -0
- package/dist/geo/tunnel/index.js +2 -0
- package/dist/geo/tunnel/index.js.map +1 -0
- package/dist/geo/tunnel/tbm.d.ts +135 -0
- package/dist/geo/tunnel/tbm.d.ts.map +1 -0
- package/dist/geo/tunnel/tbm.js +268 -0
- package/dist/geo/tunnel/tbm.js.map +1 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +33 -0
- package/dist/index.js.map +1 -0
- package/dist/ingest/ags.d.ts +42 -0
- package/dist/ingest/ags.d.ts.map +1 -0
- package/dist/ingest/ags.js +133 -0
- package/dist/ingest/ags.js.map +1 -0
- package/dist/ingest/cpt.d.ts +47 -0
- package/dist/ingest/cpt.d.ts.map +1 -0
- package/dist/ingest/cpt.js +112 -0
- package/dist/ingest/cpt.js.map +1 -0
- package/dist/ingest/index.d.ts +3 -0
- package/dist/ingest/index.d.ts.map +1 -0
- package/dist/ingest/index.js +3 -0
- package/dist/ingest/index.js.map +1 -0
- package/dist/llm/index.d.ts +5 -0
- package/dist/llm/index.d.ts.map +1 -0
- package/dist/llm/index.js +4 -0
- package/dist/llm/index.js.map +1 -0
- package/dist/llm/middleware/metering.d.ts +55 -0
- package/dist/llm/middleware/metering.d.ts.map +1 -0
- package/dist/llm/middleware/metering.js +191 -0
- package/dist/llm/middleware/metering.js.map +1 -0
- package/dist/llm/middleware/persistent-usage.d.ts +7 -0
- package/dist/llm/middleware/persistent-usage.d.ts.map +1 -0
- package/dist/llm/middleware/persistent-usage.js +108 -0
- package/dist/llm/middleware/persistent-usage.js.map +1 -0
- package/dist/llm/middleware/retry.d.ts +7 -0
- package/dist/llm/middleware/retry.d.ts.map +1 -0
- package/dist/llm/middleware/retry.js +29 -0
- package/dist/llm/middleware/retry.js.map +1 -0
- package/dist/llm/providers/anthropic.d.ts +10 -0
- package/dist/llm/providers/anthropic.d.ts.map +1 -0
- package/dist/llm/providers/anthropic.js +107 -0
- package/dist/llm/providers/anthropic.js.map +1 -0
- package/dist/llm/providers/hosted-beta.d.ts +10 -0
- package/dist/llm/providers/hosted-beta.d.ts.map +1 -0
- package/dist/llm/providers/hosted-beta.js +106 -0
- package/dist/llm/providers/hosted-beta.js.map +1 -0
- package/dist/llm/providers/huggingface.d.ts +37 -0
- package/dist/llm/providers/huggingface.d.ts.map +1 -0
- package/dist/llm/providers/huggingface.js +133 -0
- package/dist/llm/providers/huggingface.js.map +1 -0
- package/dist/llm/providers/openai-compatible.d.ts +27 -0
- package/dist/llm/providers/openai-compatible.d.ts.map +1 -0
- package/dist/llm/providers/openai-compatible.js +99 -0
- package/dist/llm/providers/openai-compatible.js.map +1 -0
- package/dist/llm/providers/zhipu.d.ts +10 -0
- package/dist/llm/providers/zhipu.d.ts.map +1 -0
- package/dist/llm/providers/zhipu.js +81 -0
- package/dist/llm/providers/zhipu.js.map +1 -0
- package/dist/llm/router.d.ts +35 -0
- package/dist/llm/router.d.ts.map +1 -0
- package/dist/llm/router.js +109 -0
- package/dist/llm/router.js.map +1 -0
- package/dist/llm/types.d.ts +63 -0
- package/dist/llm/types.d.ts.map +1 -0
- package/dist/llm/types.js +38 -0
- package/dist/llm/types.js.map +1 -0
- package/dist/meta/index.d.ts +12 -0
- package/dist/meta/index.d.ts.map +1 -0
- package/dist/meta/index.js +8 -0
- package/dist/meta/index.js.map +1 -0
- package/dist/meta/metadata.json +46 -0
- package/dist/report/index.d.ts +20 -0
- package/dist/report/index.d.ts.map +1 -0
- package/dist/report/index.js +58 -0
- package/dist/report/index.js.map +1 -0
- package/dist/standards/index.d.ts +23 -0
- package/dist/standards/index.d.ts.map +1 -0
- package/dist/standards/index.js +89 -0
- package/dist/standards/index.js.map +1 -0
- package/dist/storage/index.d.ts +114 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +465 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/vision/index.d.ts +80 -0
- package/dist/vision/index.d.ts.map +1 -0
- package/dist/vision/index.js +298 -0
- package/dist/vision/index.js.map +1 -0
- package/dist/vision/parse.d.ts +20 -0
- package/dist/vision/parse.d.ts.map +1 -0
- package/dist/vision/parse.js +75 -0
- package/dist/vision/parse.js.map +1 -0
- 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"}
|