@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,261 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
// ---------------------------------------------------------------------------
|
|
3
|
+
// USCS Classification (ASTM D2487)
|
|
4
|
+
// ---------------------------------------------------------------------------
|
|
5
|
+
export const USCSInputSchema = z.object({
|
|
6
|
+
gravelPercent: z.number().min(0).max(100).describe('% retained on #4 sieve'),
|
|
7
|
+
sandPercent: z.number().min(0).max(100).describe('% passing #4 retained on #200'),
|
|
8
|
+
finesPercent: z.number().min(0).max(100).describe('% passing #200 sieve'),
|
|
9
|
+
liquidLimit: z.number().min(0).max(200).optional().describe('Liquid Limit (%)'),
|
|
10
|
+
plasticityIndex: z.number().min(0).max(100).optional().describe('Plasticity Index (%)'),
|
|
11
|
+
d10: z.number().positive().optional().describe('D10 particle size (mm)'),
|
|
12
|
+
d30: z.number().positive().optional().describe('D30 particle size (mm)'),
|
|
13
|
+
d60: z.number().positive().optional().describe('D60 particle size (mm)'),
|
|
14
|
+
});
|
|
15
|
+
export function classifyUSCS(input) {
|
|
16
|
+
const v = USCSInputSchema.parse(input);
|
|
17
|
+
const steps = [];
|
|
18
|
+
const { gravelPercent, sandPercent, finesPercent, liquidLimit: LL, plasticityIndex: PI } = v;
|
|
19
|
+
steps.push(`Gravel: ${gravelPercent}%, Sand: ${sandPercent}%, Fines: ${finesPercent}%`);
|
|
20
|
+
if (LL !== undefined)
|
|
21
|
+
steps.push(`LL = ${LL}%, PI = ${PI ?? 'N/A'}%`);
|
|
22
|
+
const coarsePercent = gravelPercent + sandPercent;
|
|
23
|
+
// Fine-grained soil (≥50% fines)
|
|
24
|
+
if (finesPercent >= 50) {
|
|
25
|
+
steps.push(`Fines ≥ 50% → Fine-grained soil`);
|
|
26
|
+
if (LL === undefined || PI === undefined) {
|
|
27
|
+
return { symbol: 'ML/CL', name: 'Fine-grained (Atterberg limits needed)', group: 'fine-grained', steps };
|
|
28
|
+
}
|
|
29
|
+
if (LL < 50) {
|
|
30
|
+
// Low plasticity
|
|
31
|
+
const aLine = 0.73 * (LL - 20);
|
|
32
|
+
if (PI > aLine && PI > 7) {
|
|
33
|
+
steps.push(`PI (${PI}) above A-line (${aLine.toFixed(1)}) and > 7 → CL`);
|
|
34
|
+
return { symbol: 'CL', name: 'Lean Clay', group: 'fine-grained', steps };
|
|
35
|
+
}
|
|
36
|
+
else if (PI < 4 || PI < aLine) {
|
|
37
|
+
steps.push(`PI (${PI}) below A-line or < 4 → ML`);
|
|
38
|
+
return { symbol: 'ML', name: 'Silt', group: 'fine-grained', steps };
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
return { symbol: 'CL-ML', name: 'Silty Clay', group: 'fine-grained', steps };
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
// High plasticity
|
|
46
|
+
const aLine = 0.73 * (LL - 20);
|
|
47
|
+
if (PI > aLine) {
|
|
48
|
+
steps.push(`LL ≥ 50, PI above A-line → CH`);
|
|
49
|
+
return { symbol: 'CH', name: 'Fat Clay', group: 'fine-grained', steps };
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
steps.push(`LL ≥ 50, PI below A-line → MH`);
|
|
53
|
+
return { symbol: 'MH', name: 'Elastic Silt', group: 'fine-grained', steps };
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
// Coarse-grained soil
|
|
58
|
+
steps.push(`Fines < 50% → Coarse-grained soil`);
|
|
59
|
+
const isGravel = gravelPercent > sandPercent;
|
|
60
|
+
const prefix = isGravel ? 'G' : 'S';
|
|
61
|
+
const baseName = isGravel ? 'Gravel' : 'Sand';
|
|
62
|
+
steps.push(`${isGravel ? 'Gravel > Sand' : 'Sand ≥ Gravel'} → ${baseName}-based`);
|
|
63
|
+
// Gradation coefficients
|
|
64
|
+
let Cu;
|
|
65
|
+
let Cc;
|
|
66
|
+
if (v.d10 && v.d30 && v.d60) {
|
|
67
|
+
Cu = v.d60 / v.d10;
|
|
68
|
+
Cc = (v.d30 * v.d30) / (v.d60 * v.d10);
|
|
69
|
+
steps.push(`Cu = ${Cu.toFixed(1)}, Cc = ${Cc.toFixed(2)}`);
|
|
70
|
+
}
|
|
71
|
+
if (finesPercent < 5) {
|
|
72
|
+
// Clean
|
|
73
|
+
const wellGraded = Cu !== undefined && Cc !== undefined &&
|
|
74
|
+
((isGravel && Cu >= 4 && Cc >= 1 && Cc <= 3) ||
|
|
75
|
+
(!isGravel && Cu >= 6 && Cc >= 1 && Cc <= 3));
|
|
76
|
+
if (wellGraded) {
|
|
77
|
+
return { symbol: `${prefix}W`, name: `Well-graded ${baseName}`, group: 'coarse-grained', steps };
|
|
78
|
+
}
|
|
79
|
+
return { symbol: `${prefix}P`, name: `Poorly-graded ${baseName}`, group: 'coarse-grained', steps };
|
|
80
|
+
}
|
|
81
|
+
else if (finesPercent <= 12) {
|
|
82
|
+
// Dual symbol
|
|
83
|
+
return { symbol: `${prefix}W-${prefix}M`, name: `${baseName} with fines (borderline)`, group: 'coarse-grained', steps };
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
// >12% fines
|
|
87
|
+
if (PI !== undefined && PI > 7) {
|
|
88
|
+
return { symbol: `${prefix}C`, name: `Clayey ${baseName}`, group: 'coarse-grained', steps };
|
|
89
|
+
}
|
|
90
|
+
return { symbol: `${prefix}M`, name: `Silty ${baseName}`, group: 'coarse-grained', steps };
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
// ---------------------------------------------------------------------------
|
|
94
|
+
// RMR89 (Bieniawski 1989)
|
|
95
|
+
// ---------------------------------------------------------------------------
|
|
96
|
+
export const RMR89InputSchema = z.object({
|
|
97
|
+
ucs: z.number().positive().describe('Uniaxial Compressive Strength (MPa)'),
|
|
98
|
+
rqd: z.number().min(0).max(100).describe('Rock Quality Designation (%)'),
|
|
99
|
+
spacing: z.number().positive().describe('Discontinuity spacing (m)'),
|
|
100
|
+
condition: z.enum(['very_good', 'good', 'fair', 'poor', 'very_poor']).describe('Joint condition'),
|
|
101
|
+
groundwater: z.enum(['dry', 'damp', 'wet', 'dripping', 'flowing']).describe('Groundwater condition'),
|
|
102
|
+
orientationAdjustment: z.number().min(-60).max(0).default(0).describe('Orientation adjustment'),
|
|
103
|
+
});
|
|
104
|
+
function rateUCS(ucs) {
|
|
105
|
+
if (ucs > 250)
|
|
106
|
+
return 15;
|
|
107
|
+
if (ucs > 100)
|
|
108
|
+
return 12;
|
|
109
|
+
if (ucs > 50)
|
|
110
|
+
return 7;
|
|
111
|
+
if (ucs > 25)
|
|
112
|
+
return 4;
|
|
113
|
+
if (ucs > 5)
|
|
114
|
+
return 2;
|
|
115
|
+
if (ucs > 1)
|
|
116
|
+
return 1;
|
|
117
|
+
return 0;
|
|
118
|
+
}
|
|
119
|
+
function rateRQD(rqd) {
|
|
120
|
+
if (rqd > 90)
|
|
121
|
+
return 20;
|
|
122
|
+
if (rqd > 75)
|
|
123
|
+
return 17;
|
|
124
|
+
if (rqd > 50)
|
|
125
|
+
return 13;
|
|
126
|
+
if (rqd > 25)
|
|
127
|
+
return 8;
|
|
128
|
+
return 3;
|
|
129
|
+
}
|
|
130
|
+
function rateSpacing(spacing) {
|
|
131
|
+
if (spacing > 2)
|
|
132
|
+
return 20;
|
|
133
|
+
if (spacing > 0.6)
|
|
134
|
+
return 15;
|
|
135
|
+
if (spacing > 0.2)
|
|
136
|
+
return 10;
|
|
137
|
+
if (spacing > 0.06)
|
|
138
|
+
return 8;
|
|
139
|
+
return 5;
|
|
140
|
+
}
|
|
141
|
+
function rateCondition(cond) {
|
|
142
|
+
const map = {
|
|
143
|
+
very_good: 30, good: 25, fair: 20, poor: 10, very_poor: 0,
|
|
144
|
+
};
|
|
145
|
+
return map[cond] ?? 10;
|
|
146
|
+
}
|
|
147
|
+
function rateGroundwater(gw) {
|
|
148
|
+
const map = {
|
|
149
|
+
dry: 15, damp: 10, wet: 7, dripping: 4, flowing: 0,
|
|
150
|
+
};
|
|
151
|
+
return map[gw] ?? 7;
|
|
152
|
+
}
|
|
153
|
+
export function classifyRMR89(input) {
|
|
154
|
+
const v = RMR89InputSchema.parse(input);
|
|
155
|
+
const steps = [];
|
|
156
|
+
const ratings = {
|
|
157
|
+
ucs: rateUCS(v.ucs),
|
|
158
|
+
rqd: rateRQD(v.rqd),
|
|
159
|
+
spacing: rateSpacing(v.spacing),
|
|
160
|
+
condition: rateCondition(v.condition),
|
|
161
|
+
groundwater: rateGroundwater(v.groundwater),
|
|
162
|
+
orientation: v.orientationAdjustment,
|
|
163
|
+
};
|
|
164
|
+
steps.push(`UCS (${v.ucs} MPa) → ${ratings.ucs}`);
|
|
165
|
+
steps.push(`RQD (${v.rqd}%) → ${ratings.rqd}`);
|
|
166
|
+
steps.push(`Spacing (${v.spacing} m) → ${ratings.spacing}`);
|
|
167
|
+
steps.push(`Joint condition (${v.condition}) → ${ratings.condition}`);
|
|
168
|
+
steps.push(`Groundwater (${v.groundwater}) → ${ratings.groundwater}`);
|
|
169
|
+
steps.push(`Orientation adjustment → ${ratings.orientation}`);
|
|
170
|
+
const total = ratings.ucs + ratings.rqd + ratings.spacing +
|
|
171
|
+
ratings.condition + ratings.groundwater + ratings.orientation;
|
|
172
|
+
let rockClass;
|
|
173
|
+
let classNumber;
|
|
174
|
+
let support;
|
|
175
|
+
if (total > 80) {
|
|
176
|
+
rockClass = 'Very Good Rock';
|
|
177
|
+
classNumber = 'I';
|
|
178
|
+
support = 'Generally no support required except spot bolting.';
|
|
179
|
+
}
|
|
180
|
+
else if (total > 60) {
|
|
181
|
+
rockClass = 'Good Rock';
|
|
182
|
+
classNumber = 'II';
|
|
183
|
+
support = 'Locally, bolts in crown 3m long, spaced 2.5m, with occasional wire mesh. 50mm shotcrete in crown where required.';
|
|
184
|
+
}
|
|
185
|
+
else if (total > 40) {
|
|
186
|
+
rockClass = 'Fair Rock';
|
|
187
|
+
classNumber = 'III';
|
|
188
|
+
support = 'Systematic bolts 4m long, spaced 1.5-2m in crown and walls. 50-100mm shotcrete in crown and 30mm on sides.';
|
|
189
|
+
}
|
|
190
|
+
else if (total > 20) {
|
|
191
|
+
rockClass = 'Poor Rock';
|
|
192
|
+
classNumber = 'IV';
|
|
193
|
+
support = 'Systematic bolts 4-5m long, spaced 1-1.5m in crown and walls. 100-150mm shotcrete with wire mesh. Light to medium steel sets where required.';
|
|
194
|
+
}
|
|
195
|
+
else {
|
|
196
|
+
rockClass = 'Very Poor Rock';
|
|
197
|
+
classNumber = 'V';
|
|
198
|
+
support = 'Systematic bolts 5-6m long, spaced 1-1.5m. 150-200mm shotcrete with wire mesh. Medium to heavy steel sets. Close invert. Forepoling may be needed.';
|
|
199
|
+
}
|
|
200
|
+
steps.push(`Total RMR = ${total} → Class ${classNumber}: ${rockClass}`);
|
|
201
|
+
return {
|
|
202
|
+
totalRating: total,
|
|
203
|
+
rockClass,
|
|
204
|
+
classNumber,
|
|
205
|
+
ratings,
|
|
206
|
+
supportRecommendation: support,
|
|
207
|
+
steps,
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
// ---------------------------------------------------------------------------
|
|
211
|
+
// Q-system (Barton et al. 1974)
|
|
212
|
+
// ---------------------------------------------------------------------------
|
|
213
|
+
export const QSystemInputSchema = z.object({
|
|
214
|
+
rqd: z.number().min(0).max(100).describe('Rock Quality Designation (%)'),
|
|
215
|
+
jn: z.number().positive().describe('Joint set number Jn'),
|
|
216
|
+
jr: z.number().positive().describe('Joint roughness number Jr'),
|
|
217
|
+
ja: z.number().positive().describe('Joint alteration number Ja'),
|
|
218
|
+
jw: z.number().positive().max(1).describe('Joint water reduction factor Jw'),
|
|
219
|
+
srf: z.number().positive().describe('Stress reduction factor SRF'),
|
|
220
|
+
});
|
|
221
|
+
export function classifyQSystem(input) {
|
|
222
|
+
const v = QSystemInputSchema.parse(input);
|
|
223
|
+
const steps = [];
|
|
224
|
+
const Q = (v.rqd / v.jn) * (v.jr / v.ja) * (v.jw / v.srf);
|
|
225
|
+
steps.push(`Q = (RQD/Jn) × (Jr/Ja) × (Jw/SRF)`);
|
|
226
|
+
steps.push(`Q = (${v.rqd}/${v.jn}) × (${v.jr}/${v.ja}) × (${v.jw}/${v.srf})`);
|
|
227
|
+
steps.push(`Q = ${Q.toFixed(3)}`);
|
|
228
|
+
let category;
|
|
229
|
+
let support;
|
|
230
|
+
if (Q > 40) {
|
|
231
|
+
category = 'Exceptionally to extremely good';
|
|
232
|
+
support = 'Unsupported or spot bolting.';
|
|
233
|
+
}
|
|
234
|
+
else if (Q > 10) {
|
|
235
|
+
category = 'Very good to good';
|
|
236
|
+
support = 'Spot to systematic bolting.';
|
|
237
|
+
}
|
|
238
|
+
else if (Q > 4) {
|
|
239
|
+
category = 'Fair';
|
|
240
|
+
support = 'Systematic bolting with 40-100mm unreinforced shotcrete.';
|
|
241
|
+
}
|
|
242
|
+
else if (Q > 1) {
|
|
243
|
+
category = 'Poor';
|
|
244
|
+
support = 'Systematic bolting with 100-150mm fiber-reinforced shotcrete.';
|
|
245
|
+
}
|
|
246
|
+
else if (Q > 0.1) {
|
|
247
|
+
category = 'Very poor';
|
|
248
|
+
support = 'Fiber-reinforced shotcrete 150-200mm and bolting with steel ribs.';
|
|
249
|
+
}
|
|
250
|
+
else if (Q > 0.01) {
|
|
251
|
+
category = 'Extremely poor';
|
|
252
|
+
support = 'Cast concrete lining or heavy steel sets with shotcrete.';
|
|
253
|
+
}
|
|
254
|
+
else {
|
|
255
|
+
category = 'Exceptionally poor';
|
|
256
|
+
support = 'Special methods required: ground freezing, jet grouting, or pre-reinforcement.';
|
|
257
|
+
}
|
|
258
|
+
steps.push(`Category: ${category}`);
|
|
259
|
+
return { qValue: Math.round(Q * 1000) / 1000, category, supportRecommendation: support, steps };
|
|
260
|
+
}
|
|
261
|
+
//# sourceMappingURL=classification.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"classification.js","sourceRoot":"","sources":["../../src/geo/classification.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { calculateBearingCapacity, type BearingCapacityResult, type BearingCapacityInput } from './bearing-capacity.js';
|
|
2
|
+
export { classifyUSCS, classifyRMR89, classifyQSystem, type USCSResult, type RMR89Result, type QSystemResult } from './classification.js';
|
|
3
|
+
export { calculateLiquefaction, type LiquefactionResult } from './liquefaction.js';
|
|
4
|
+
export { calculateConsolidation, calculateSchmertmann, calculatePeckSettlement, type ConsolidationResult, type SchmertmannResult, type PeckSettlementResult, } from './settlement.js';
|
|
5
|
+
export { predictTBMPerformance, selectTBMType, predictCutterWear } from './tunnel/index.js';
|
|
6
|
+
export { calculatePileCapacity, type PileCapacityResult, type PileCapacityInput } from './pile-capacity.js';
|
|
7
|
+
export { calculateSlopeStability, type SlopeStabilityResult, type SlopeStabilityInput } from './slope-stability.js';
|
|
8
|
+
export { calculateLateralEarthPressure, type LateralEarthPressureResult, type LateralEarthPressureInput } from './lateral-earth-pressure.js';
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/geo/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAE,KAAK,qBAAqB,EAAE,KAAK,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AACxH,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,eAAe,EAAE,KAAK,UAAU,EAAE,KAAK,WAAW,EAAE,KAAK,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAC1I,OAAO,EAAE,qBAAqB,EAAE,KAAK,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AACnF,OAAO,EACL,sBAAsB,EACtB,oBAAoB,EACpB,uBAAuB,EACvB,KAAK,mBAAmB,EACxB,KAAK,iBAAiB,EACtB,KAAK,oBAAoB,GAC1B,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,qBAAqB,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAC5F,OAAO,EAAE,qBAAqB,EAAE,KAAK,kBAAkB,EAAE,KAAK,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAC5G,OAAO,EAAE,uBAAuB,EAAE,KAAK,oBAAoB,EAAE,KAAK,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AACpH,OAAO,EAAE,6BAA6B,EAAE,KAAK,0BAA0B,EAAE,KAAK,yBAAyB,EAAE,MAAM,6BAA6B,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { calculateBearingCapacity } from './bearing-capacity.js';
|
|
2
|
+
export { classifyUSCS, classifyRMR89, classifyQSystem } from './classification.js';
|
|
3
|
+
export { calculateLiquefaction } from './liquefaction.js';
|
|
4
|
+
export { calculateConsolidation, calculateSchmertmann, calculatePeckSettlement, } from './settlement.js';
|
|
5
|
+
export { predictTBMPerformance, selectTBMType, predictCutterWear } from './tunnel/index.js';
|
|
6
|
+
export { calculatePileCapacity } from './pile-capacity.js';
|
|
7
|
+
export { calculateSlopeStability } from './slope-stability.js';
|
|
8
|
+
export { calculateLateralEarthPressure } from './lateral-earth-pressure.js';
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/geo/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,wBAAwB,EAAyD,MAAM,uBAAuB,CAAC;AACxH,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,eAAe,EAAyD,MAAM,qBAAqB,CAAC;AAC1I,OAAO,EAAE,qBAAqB,EAA2B,MAAM,mBAAmB,CAAC;AACnF,OAAO,EACL,sBAAsB,EACtB,oBAAoB,EACpB,uBAAuB,GAIxB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,qBAAqB,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAC5F,OAAO,EAAE,qBAAqB,EAAmD,MAAM,oBAAoB,CAAC;AAC5G,OAAO,EAAE,uBAAuB,EAAuD,MAAM,sBAAsB,CAAC;AACpH,OAAO,EAAE,6BAA6B,EAAmE,MAAM,6BAA6B,CAAC"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
export declare const LateralEarthPressureInputSchema: z.ZodObject<{
|
|
3
|
+
wallHeight: z.ZodNumber;
|
|
4
|
+
soilLayers: z.ZodArray<z.ZodObject<{
|
|
5
|
+
thickness: z.ZodNumber;
|
|
6
|
+
unitWeight: z.ZodNumber;
|
|
7
|
+
cohesion: z.ZodDefault<z.ZodNumber>;
|
|
8
|
+
frictionAngle: z.ZodNumber;
|
|
9
|
+
}, "strip", z.ZodTypeAny, {
|
|
10
|
+
unitWeight: number;
|
|
11
|
+
cohesion: number;
|
|
12
|
+
frictionAngle: number;
|
|
13
|
+
thickness: number;
|
|
14
|
+
}, {
|
|
15
|
+
unitWeight: number;
|
|
16
|
+
frictionAngle: number;
|
|
17
|
+
thickness: number;
|
|
18
|
+
cohesion?: number | undefined;
|
|
19
|
+
}>, "many">;
|
|
20
|
+
method: z.ZodDefault<z.ZodEnum<["rankine", "coulomb"]>>;
|
|
21
|
+
pressureState: z.ZodDefault<z.ZodEnum<["active", "passive", "at_rest"]>>;
|
|
22
|
+
wallFrictionAngle: z.ZodDefault<z.ZodNumber>;
|
|
23
|
+
backfillAngle: z.ZodDefault<z.ZodNumber>;
|
|
24
|
+
wallInclination: z.ZodDefault<z.ZodNumber>;
|
|
25
|
+
waterTableDepth: z.ZodDefault<z.ZodNumber>;
|
|
26
|
+
surcharge: z.ZodDefault<z.ZodNumber>;
|
|
27
|
+
}, "strip", z.ZodTypeAny, {
|
|
28
|
+
method: "rankine" | "coulomb";
|
|
29
|
+
waterTableDepth: number;
|
|
30
|
+
soilLayers: {
|
|
31
|
+
unitWeight: number;
|
|
32
|
+
cohesion: number;
|
|
33
|
+
frictionAngle: number;
|
|
34
|
+
thickness: number;
|
|
35
|
+
}[];
|
|
36
|
+
surcharge: number;
|
|
37
|
+
wallHeight: number;
|
|
38
|
+
pressureState: "active" | "passive" | "at_rest";
|
|
39
|
+
wallFrictionAngle: number;
|
|
40
|
+
backfillAngle: number;
|
|
41
|
+
wallInclination: number;
|
|
42
|
+
}, {
|
|
43
|
+
soilLayers: {
|
|
44
|
+
unitWeight: number;
|
|
45
|
+
frictionAngle: number;
|
|
46
|
+
thickness: number;
|
|
47
|
+
cohesion?: number | undefined;
|
|
48
|
+
}[];
|
|
49
|
+
wallHeight: number;
|
|
50
|
+
method?: "rankine" | "coulomb" | undefined;
|
|
51
|
+
waterTableDepth?: number | undefined;
|
|
52
|
+
surcharge?: number | undefined;
|
|
53
|
+
pressureState?: "active" | "passive" | "at_rest" | undefined;
|
|
54
|
+
wallFrictionAngle?: number | undefined;
|
|
55
|
+
backfillAngle?: number | undefined;
|
|
56
|
+
wallInclination?: number | undefined;
|
|
57
|
+
}>;
|
|
58
|
+
export type LateralEarthPressureInput = z.infer<typeof LateralEarthPressureInputSchema>;
|
|
59
|
+
export interface LateralEarthPressureResult {
|
|
60
|
+
method: string;
|
|
61
|
+
pressureState: string;
|
|
62
|
+
coefficient: number;
|
|
63
|
+
totalForce: number;
|
|
64
|
+
pointOfApplication: number;
|
|
65
|
+
overturningMoment: number;
|
|
66
|
+
pressureDistribution: Array<{
|
|
67
|
+
depth: number;
|
|
68
|
+
pressure: number;
|
|
69
|
+
waterPressure: number;
|
|
70
|
+
totalPressure: number;
|
|
71
|
+
}>;
|
|
72
|
+
steps: string[];
|
|
73
|
+
}
|
|
74
|
+
export declare function calculateLateralEarthPressure(input: LateralEarthPressureInput): LateralEarthPressureResult;
|
|
75
|
+
//# sourceMappingURL=lateral-earth-pressure.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lateral-earth-pressure.d.ts","sourceRoot":"","sources":["../../src/geo/lateral-earth-pressure.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAexB,eAAO,MAAM,+BAA+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAe1C,CAAC;AAEH,MAAM,MAAM,yBAAyB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,+BAA+B,CAAC,CAAC;AAExF,MAAM,WAAW,0BAA0B;IACzC,MAAM,EAAE,MAAM,CAAC;IACf,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,oBAAoB,EAAE,KAAK,CAAC;QAC1B,KAAK,EAAE,MAAM,CAAC;QACd,QAAQ,EAAE,MAAM,CAAC;QACjB,aAAa,EAAE,MAAM,CAAC;QACtB,aAAa,EAAE,MAAM,CAAC;KACvB,CAAC,CAAC;IACH,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AA6FD,wBAAgB,6BAA6B,CAAC,KAAK,EAAE,yBAAyB,GAAG,0BAA0B,CA8H1G"}
|
|
@@ -0,0 +1,219 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
// ---------------------------------------------------------------------------
|
|
3
|
+
// Lateral Earth Pressure — Rankine & Coulomb Methods
|
|
4
|
+
//
|
|
5
|
+
// Calculates active (Ka), passive (Kp), and at-rest (K0) earth pressure
|
|
6
|
+
// coefficients and resultant forces for retaining wall design.
|
|
7
|
+
//
|
|
8
|
+
// References:
|
|
9
|
+
// - Rankine, W.J.M. (1857). "On the stability of loose earth."
|
|
10
|
+
// - Coulomb, C.A. (1776). "Essai sur une application des règles de maximis et minimis."
|
|
11
|
+
// - Jaky, J. (1944). "The coefficient of earth pressure at rest." K0 = 1 - sin(φ)
|
|
12
|
+
// - Eurocode 7 (EN 1997-1:2004), Section 9
|
|
13
|
+
// ---------------------------------------------------------------------------
|
|
14
|
+
export const LateralEarthPressureInputSchema = z.object({
|
|
15
|
+
wallHeight: z.number().positive().describe('Retaining wall height H (m)'),
|
|
16
|
+
soilLayers: z.array(z.object({
|
|
17
|
+
thickness: z.number().positive().describe('Layer thickness (m)'),
|
|
18
|
+
unitWeight: z.number().positive().describe('Unit weight γ (kN/m³)'),
|
|
19
|
+
cohesion: z.number().min(0).default(0).describe('Cohesion c (kPa)'),
|
|
20
|
+
frictionAngle: z.number().min(0).max(50).describe('Friction angle φ (degrees)'),
|
|
21
|
+
})).min(1),
|
|
22
|
+
method: z.enum(['rankine', 'coulomb']).default('rankine'),
|
|
23
|
+
pressureState: z.enum(['active', 'passive', 'at_rest']).default('active'),
|
|
24
|
+
wallFrictionAngle: z.number().min(0).max(40).default(0).describe('Wall friction angle δ (degrees) — Coulomb only'),
|
|
25
|
+
backfillAngle: z.number().min(0).max(45).default(0).describe('Backfill slope angle β (degrees)'),
|
|
26
|
+
wallInclination: z.number().min(0).max(30).default(0).describe('Wall inclination from vertical α (degrees)'),
|
|
27
|
+
waterTableDepth: z.number().min(0).default(999).describe('Water table depth from top of wall (m)'),
|
|
28
|
+
surcharge: z.number().min(0).default(0).describe('Uniform surcharge on backfill (kPa)'),
|
|
29
|
+
});
|
|
30
|
+
function degToRad(deg) {
|
|
31
|
+
return (deg * Math.PI) / 180;
|
|
32
|
+
}
|
|
33
|
+
// ---------------------------------------------------------------------------
|
|
34
|
+
// Rankine coefficients
|
|
35
|
+
// ---------------------------------------------------------------------------
|
|
36
|
+
function rankineKa(phi, beta = 0) {
|
|
37
|
+
const phiRad = degToRad(phi);
|
|
38
|
+
const betaRad = degToRad(beta);
|
|
39
|
+
if (beta === 0) {
|
|
40
|
+
return Math.tan(degToRad(45 - phi / 2)) ** 2;
|
|
41
|
+
}
|
|
42
|
+
// General Rankine with sloping backfill
|
|
43
|
+
const cosBeta = Math.cos(betaRad);
|
|
44
|
+
const cosPhi = Math.cos(phiRad);
|
|
45
|
+
return cosBeta * (cosBeta - Math.sqrt(cosBeta ** 2 - cosPhi ** 2)) /
|
|
46
|
+
(cosBeta + Math.sqrt(cosBeta ** 2 - cosPhi ** 2));
|
|
47
|
+
}
|
|
48
|
+
function rankineKp(phi, beta = 0) {
|
|
49
|
+
const phiRad = degToRad(phi);
|
|
50
|
+
const betaRad = degToRad(beta);
|
|
51
|
+
if (beta === 0) {
|
|
52
|
+
return Math.tan(degToRad(45 + phi / 2)) ** 2;
|
|
53
|
+
}
|
|
54
|
+
const cosBeta = Math.cos(betaRad);
|
|
55
|
+
const cosPhi = Math.cos(phiRad);
|
|
56
|
+
return cosBeta * (cosBeta + Math.sqrt(cosBeta ** 2 - cosPhi ** 2)) /
|
|
57
|
+
(cosBeta - Math.sqrt(cosBeta ** 2 - cosPhi ** 2));
|
|
58
|
+
}
|
|
59
|
+
// ---------------------------------------------------------------------------
|
|
60
|
+
// Coulomb coefficients
|
|
61
|
+
// ---------------------------------------------------------------------------
|
|
62
|
+
function coulombKa(phi, delta, alpha, beta) {
|
|
63
|
+
const phiRad = degToRad(phi);
|
|
64
|
+
const deltaRad = degToRad(delta);
|
|
65
|
+
const alphaRad = degToRad(alpha);
|
|
66
|
+
const betaRad = degToRad(beta);
|
|
67
|
+
const cosDeltaAlpha = Math.cos(deltaRad + alphaRad);
|
|
68
|
+
const cosAlphaBeta = Math.cos(alphaRad - betaRad);
|
|
69
|
+
const rootTermDenom = cosDeltaAlpha * cosAlphaBeta;
|
|
70
|
+
if (cosDeltaAlpha <= 0 || cosAlphaBeta <= 0 || rootTermDenom <= 0) {
|
|
71
|
+
return 0;
|
|
72
|
+
}
|
|
73
|
+
const rootTerm = (Math.sin(phiRad + deltaRad) * Math.sin(phiRad - betaRad)) / rootTermDenom;
|
|
74
|
+
if (rootTerm < 0) {
|
|
75
|
+
return 0;
|
|
76
|
+
}
|
|
77
|
+
const numerator = Math.cos(phiRad - alphaRad) ** 2;
|
|
78
|
+
const denominator = Math.cos(alphaRad) ** 2 * cosDeltaAlpha *
|
|
79
|
+
(1 + Math.sqrt(rootTerm)) ** 2;
|
|
80
|
+
return denominator > 0 ? numerator / denominator : 0;
|
|
81
|
+
}
|
|
82
|
+
function coulombKp(phi, delta, alpha, beta) {
|
|
83
|
+
const phiRad = degToRad(phi);
|
|
84
|
+
const deltaRad = degToRad(delta);
|
|
85
|
+
const alphaRad = degToRad(alpha);
|
|
86
|
+
const betaRad = degToRad(beta);
|
|
87
|
+
const cosDeltaAlpha = Math.cos(deltaRad - alphaRad);
|
|
88
|
+
const cosAlphaBeta = Math.cos(alphaRad - betaRad);
|
|
89
|
+
const rootTermDenom = cosDeltaAlpha * cosAlphaBeta;
|
|
90
|
+
if (cosDeltaAlpha <= 0 || cosAlphaBeta <= 0 || rootTermDenom <= 0) {
|
|
91
|
+
return 999;
|
|
92
|
+
}
|
|
93
|
+
const rootTerm = (Math.sin(phiRad + deltaRad) * Math.sin(phiRad + betaRad)) / rootTermDenom;
|
|
94
|
+
if (rootTerm < 0 || rootTerm >= 1) {
|
|
95
|
+
return 999;
|
|
96
|
+
}
|
|
97
|
+
const numerator = Math.cos(phiRad + alphaRad) ** 2;
|
|
98
|
+
const denominator = Math.cos(alphaRad) ** 2 * cosDeltaAlpha *
|
|
99
|
+
(1 - Math.sqrt(rootTerm)) ** 2;
|
|
100
|
+
return denominator > 0 ? numerator / denominator : 999;
|
|
101
|
+
}
|
|
102
|
+
// ---------------------------------------------------------------------------
|
|
103
|
+
// Main calculation
|
|
104
|
+
// ---------------------------------------------------------------------------
|
|
105
|
+
export function calculateLateralEarthPressure(input) {
|
|
106
|
+
const v = LateralEarthPressureInputSchema.parse(input);
|
|
107
|
+
const steps = [];
|
|
108
|
+
const { wallHeight: H, soilLayers, method, pressureState, wallFrictionAngle: delta, backfillAngle: beta, wallInclination: alpha, waterTableDepth: gwt, surcharge: q } = v;
|
|
109
|
+
steps.push(`Wall: H=${H}m, method=${method}, state=${pressureState}`);
|
|
110
|
+
// Use weighted average soil properties for coefficient calculation
|
|
111
|
+
let totalWeight = 0;
|
|
112
|
+
let weightedPhi = 0;
|
|
113
|
+
let weightedC = 0;
|
|
114
|
+
let weightedGamma = 0;
|
|
115
|
+
let cumThickness = 0;
|
|
116
|
+
for (const layer of soilLayers) {
|
|
117
|
+
const effectiveThickness = Math.min(layer.thickness, H - cumThickness);
|
|
118
|
+
if (effectiveThickness <= 0)
|
|
119
|
+
break;
|
|
120
|
+
totalWeight += effectiveThickness;
|
|
121
|
+
weightedPhi += layer.frictionAngle * effectiveThickness;
|
|
122
|
+
weightedC += layer.cohesion * effectiveThickness;
|
|
123
|
+
weightedGamma += layer.unitWeight * effectiveThickness;
|
|
124
|
+
cumThickness += effectiveThickness;
|
|
125
|
+
}
|
|
126
|
+
const avgPhi = weightedPhi / totalWeight;
|
|
127
|
+
const avgC = weightedC / totalWeight;
|
|
128
|
+
const avgGamma = weightedGamma / totalWeight;
|
|
129
|
+
steps.push(`Weighted avg: φ=${avgPhi.toFixed(1)}°, c=${avgC.toFixed(1)} kPa, γ=${avgGamma.toFixed(1)} kN/m³`);
|
|
130
|
+
// Calculate coefficient
|
|
131
|
+
let K;
|
|
132
|
+
if (pressureState === 'at_rest') {
|
|
133
|
+
// Jaky (1944): K0 = 1 - sin(φ)
|
|
134
|
+
K = 1 - Math.sin(degToRad(avgPhi));
|
|
135
|
+
steps.push(`K0 = 1 - sin(${avgPhi.toFixed(1)}°) = ${K.toFixed(4)} (Jaky 1944)`);
|
|
136
|
+
}
|
|
137
|
+
else if (method === 'rankine') {
|
|
138
|
+
K = pressureState === 'active' ? rankineKa(avgPhi, beta) : rankineKp(avgPhi, beta);
|
|
139
|
+
steps.push(`${pressureState === 'active' ? 'Ka' : 'Kp'} = ${K.toFixed(4)} (Rankine${beta > 0 ? `, β=${beta}°` : ''})`);
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
K = pressureState === 'active'
|
|
143
|
+
? coulombKa(avgPhi, delta, alpha, beta)
|
|
144
|
+
: coulombKp(avgPhi, delta, alpha, beta);
|
|
145
|
+
steps.push(`${pressureState === 'active' ? 'Ka' : 'Kp'} = ${K.toFixed(4)} (Coulomb, δ=${delta}°, α=${alpha}°, β=${beta}°)`);
|
|
146
|
+
}
|
|
147
|
+
// Pressure distribution (10 points)
|
|
148
|
+
const nPoints = 20;
|
|
149
|
+
const pressureDistribution = [];
|
|
150
|
+
let totalForce = 0;
|
|
151
|
+
let totalMoment = 0;
|
|
152
|
+
for (let i = 0; i <= nPoints; i++) {
|
|
153
|
+
const depth = (i / nPoints) * H;
|
|
154
|
+
// Determine layer properties at this depth
|
|
155
|
+
let layerGamma = soilLayers[0].unitWeight;
|
|
156
|
+
let layerC = soilLayers[0].cohesion;
|
|
157
|
+
let cumD = 0;
|
|
158
|
+
for (const layer of soilLayers) {
|
|
159
|
+
cumD += layer.thickness;
|
|
160
|
+
if (depth <= cumD) {
|
|
161
|
+
layerGamma = layer.unitWeight;
|
|
162
|
+
layerC = layer.cohesion;
|
|
163
|
+
break;
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
// Vertical stress
|
|
167
|
+
const sigma_v = layerGamma * depth + q;
|
|
168
|
+
// Water pressure
|
|
169
|
+
const u = depth > gwt ? 9.81 * (depth - gwt) : 0;
|
|
170
|
+
const sigma_v_eff = sigma_v - u;
|
|
171
|
+
// Lateral earth pressure
|
|
172
|
+
let lateralPressure;
|
|
173
|
+
if (pressureState === 'active') {
|
|
174
|
+
lateralPressure = K * sigma_v_eff - 2 * layerC * Math.sqrt(K);
|
|
175
|
+
lateralPressure = Math.max(0, lateralPressure); // tension crack
|
|
176
|
+
}
|
|
177
|
+
else if (pressureState === 'passive') {
|
|
178
|
+
lateralPressure = K * sigma_v_eff + 2 * layerC * Math.sqrt(K);
|
|
179
|
+
}
|
|
180
|
+
else {
|
|
181
|
+
lateralPressure = K * sigma_v_eff;
|
|
182
|
+
}
|
|
183
|
+
const totalPressure = lateralPressure + u;
|
|
184
|
+
pressureDistribution.push({
|
|
185
|
+
depth: Math.round(depth * 100) / 100,
|
|
186
|
+
pressure: Math.round(lateralPressure * 10) / 10,
|
|
187
|
+
waterPressure: Math.round(u * 10) / 10,
|
|
188
|
+
totalPressure: Math.round(totalPressure * 10) / 10,
|
|
189
|
+
});
|
|
190
|
+
// Trapezoidal integration
|
|
191
|
+
if (i > 0) {
|
|
192
|
+
const prevP = pressureDistribution[i - 1].totalPressure;
|
|
193
|
+
const dz = H / nPoints;
|
|
194
|
+
const avgP = (prevP + totalPressure) / 2;
|
|
195
|
+
const dF = avgP * dz;
|
|
196
|
+
totalForce += dF;
|
|
197
|
+
totalMoment += dF * (H - depth + dz / 2);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
const pointOfApplication = totalMoment / Math.max(totalForce, 0.001);
|
|
201
|
+
steps.push(`Total force: ${totalForce.toFixed(1)} kN/m`);
|
|
202
|
+
steps.push(`Point of application: ${pointOfApplication.toFixed(2)} m from base`);
|
|
203
|
+
steps.push(`Overturning moment: ${totalMoment.toFixed(1)} kN·m/m about base`);
|
|
204
|
+
if (q > 0)
|
|
205
|
+
steps.push(`Surcharge q=${q} kPa included in vertical stress`);
|
|
206
|
+
if (gwt < H)
|
|
207
|
+
steps.push(`Water table at ${gwt}m — hydrostatic pressure added to lateral earth pressure`);
|
|
208
|
+
return {
|
|
209
|
+
method: method.charAt(0).toUpperCase() + method.slice(1),
|
|
210
|
+
pressureState,
|
|
211
|
+
coefficient: Math.round(K * 10000) / 10000,
|
|
212
|
+
totalForce: Math.round(totalForce * 10) / 10,
|
|
213
|
+
pointOfApplication: Math.round(pointOfApplication * 100) / 100,
|
|
214
|
+
overturningMoment: Math.round(totalMoment * 10) / 10,
|
|
215
|
+
pressureDistribution,
|
|
216
|
+
steps,
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
//# sourceMappingURL=lateral-earth-pressure.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lateral-earth-pressure.js","sourceRoot":"","sources":["../../src/geo/lateral-earth-pressure.ts"],"names":[],"mappings":"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"}
|