@geotechcli/core 0.4.54 → 0.4.56
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/fem-tools.d.ts +2 -0
- package/dist/agents/fem-tools.d.ts.map +1 -0
- package/dist/agents/fem-tools.js +157 -0
- package/dist/agents/fem-tools.js.map +1 -0
- package/dist/agents/provider-operating-contract.js +3 -2
- package/dist/agents/provider-operating-contract.js.map +1 -1
- package/dist/agents/runtime-bootstrap.d.ts +1 -0
- package/dist/agents/runtime-bootstrap.d.ts.map +1 -1
- package/dist/agents/runtime-bootstrap.js +1 -0
- package/dist/agents/runtime-bootstrap.js.map +1 -1
- package/dist/agents/swarm-planner.js +3 -3
- package/dist/agents/swarm-planner.js.map +1 -1
- package/dist/agents/swarm.d.ts.map +1 -1
- package/dist/agents/swarm.js +8 -0
- package/dist/agents/swarm.js.map +1 -1
- package/dist/fem/demo.d.ts +4 -0
- package/dist/fem/demo.d.ts.map +1 -0
- package/dist/fem/demo.js +274 -0
- package/dist/fem/demo.js.map +1 -0
- package/dist/fem/index.d.ts +6 -0
- package/dist/fem/index.d.ts.map +1 -0
- package/dist/fem/index.js +6 -0
- package/dist/fem/index.js.map +1 -0
- package/dist/fem/routing.d.ts +62 -0
- package/dist/fem/routing.d.ts.map +1 -0
- package/dist/fem/routing.js +202 -0
- package/dist/fem/routing.js.map +1 -0
- package/dist/fem/types.d.ts +154 -0
- package/dist/fem/types.d.ts.map +1 -0
- package/dist/fem/types.js +2 -0
- package/dist/fem/types.js.map +1 -0
- package/dist/fem/validation.d.ts +4 -0
- package/dist/fem/validation.d.ts.map +1 -0
- package/dist/fem/validation.js +195 -0
- package/dist/fem/validation.js.map +1 -0
- package/dist/fem/webgl.d.ts +3 -0
- package/dist/fem/webgl.d.ts.map +1 -0
- package/dist/fem/webgl.js +120 -0
- package/dist/fem/webgl.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/ingest/document-evidence-packet.d.ts +32 -32
- package/dist/meta/metadata.json +1 -1
- package/dist/verifier/findings.d.ts +1 -1
- package/dist/verifier/findings.d.ts.map +1 -1
- package/dist/verifier/findings.js +46 -0
- package/dist/verifier/findings.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
export type FemObjective = 'foundation_settlement';
|
|
2
|
+
export type FemAnalysisType = 'static_3d_small_strain';
|
|
3
|
+
export type FemAssumptionConfidence = 'measured' | 'inferred' | 'review';
|
|
4
|
+
export type FemFindingSeverity = 'info' | 'review' | 'blocker';
|
|
5
|
+
export interface FemUnits {
|
|
6
|
+
length: 'm';
|
|
7
|
+
force: 'kN';
|
|
8
|
+
stress: 'kPa';
|
|
9
|
+
density: 'kN/m3';
|
|
10
|
+
displacement: 'mm';
|
|
11
|
+
}
|
|
12
|
+
export interface FemEvidenceRef {
|
|
13
|
+
id: string;
|
|
14
|
+
source?: string;
|
|
15
|
+
page?: number;
|
|
16
|
+
note?: string;
|
|
17
|
+
}
|
|
18
|
+
export interface FemAssumption {
|
|
19
|
+
id: string;
|
|
20
|
+
parameter: string;
|
|
21
|
+
value: string | number;
|
|
22
|
+
unit?: string;
|
|
23
|
+
basis: string;
|
|
24
|
+
confidence: FemAssumptionConfidence;
|
|
25
|
+
reviewRequired: boolean;
|
|
26
|
+
}
|
|
27
|
+
export interface FemMaterial {
|
|
28
|
+
id: string;
|
|
29
|
+
name: string;
|
|
30
|
+
model: 'linear_elastic';
|
|
31
|
+
elasticModulusKpa: number;
|
|
32
|
+
poissonRatio: number;
|
|
33
|
+
unitWeightKnM3: number;
|
|
34
|
+
evidenceRefs: FemEvidenceRef[];
|
|
35
|
+
assumptions: FemAssumption[];
|
|
36
|
+
}
|
|
37
|
+
export interface FemBoxDomain {
|
|
38
|
+
type: 'box';
|
|
39
|
+
lengthM: number;
|
|
40
|
+
widthM: number;
|
|
41
|
+
depthM: number;
|
|
42
|
+
}
|
|
43
|
+
export interface FemRaftGeometry {
|
|
44
|
+
type: 'raft';
|
|
45
|
+
lengthM: number;
|
|
46
|
+
widthM: number;
|
|
47
|
+
thicknessM: number;
|
|
48
|
+
centerXM: number;
|
|
49
|
+
centerYM: number;
|
|
50
|
+
}
|
|
51
|
+
export interface FemPressureLoad {
|
|
52
|
+
id: string;
|
|
53
|
+
type: 'uniform_pressure';
|
|
54
|
+
target: 'raft';
|
|
55
|
+
pressureKpa: number;
|
|
56
|
+
evidenceRefs: FemEvidenceRef[];
|
|
57
|
+
assumptions: FemAssumption[];
|
|
58
|
+
}
|
|
59
|
+
export interface FemBoundaryCondition {
|
|
60
|
+
id: string;
|
|
61
|
+
type: 'fixed_base' | 'side_rollers';
|
|
62
|
+
description: string;
|
|
63
|
+
}
|
|
64
|
+
export interface FemMeshSettings {
|
|
65
|
+
elementType: 'hex8';
|
|
66
|
+
divisionsX: number;
|
|
67
|
+
divisionsY: number;
|
|
68
|
+
divisionsZ: number;
|
|
69
|
+
}
|
|
70
|
+
export interface FemGroundwaterAssumption {
|
|
71
|
+
condition: 'not_modelled' | 'below_domain' | 'specified';
|
|
72
|
+
depthM?: number;
|
|
73
|
+
note: string;
|
|
74
|
+
reviewRequired: boolean;
|
|
75
|
+
}
|
|
76
|
+
export interface FemAnalysisCase {
|
|
77
|
+
schemaVersion: 'fem-analysis-case.v0';
|
|
78
|
+
caseId: string;
|
|
79
|
+
title: string;
|
|
80
|
+
createdBy: string;
|
|
81
|
+
createdAt: string;
|
|
82
|
+
experimental: true;
|
|
83
|
+
objective: FemObjective;
|
|
84
|
+
analysisType: FemAnalysisType;
|
|
85
|
+
units: FemUnits;
|
|
86
|
+
geometry: {
|
|
87
|
+
domain: FemBoxDomain;
|
|
88
|
+
raft: FemRaftGeometry;
|
|
89
|
+
};
|
|
90
|
+
materials: FemMaterial[];
|
|
91
|
+
loads: FemPressureLoad[];
|
|
92
|
+
boundaryConditions: FemBoundaryCondition[];
|
|
93
|
+
mesh: FemMeshSettings;
|
|
94
|
+
groundwater: FemGroundwaterAssumption;
|
|
95
|
+
assumptions: FemAssumption[];
|
|
96
|
+
evidenceRefs: FemEvidenceRef[];
|
|
97
|
+
limitations: string[];
|
|
98
|
+
}
|
|
99
|
+
export interface FemValidationFinding {
|
|
100
|
+
severity: FemFindingSeverity;
|
|
101
|
+
code: string;
|
|
102
|
+
message: string;
|
|
103
|
+
}
|
|
104
|
+
export interface FemValidationSummary {
|
|
105
|
+
status: 'ready' | 'review' | 'blocked';
|
|
106
|
+
blockers: number;
|
|
107
|
+
reviewItems: number;
|
|
108
|
+
findings: FemValidationFinding[];
|
|
109
|
+
}
|
|
110
|
+
export interface FemVisualizationMesh {
|
|
111
|
+
base: number[];
|
|
112
|
+
disp: number[];
|
|
113
|
+
color: number[];
|
|
114
|
+
tri: number[];
|
|
115
|
+
edge: number[];
|
|
116
|
+
outlineBase: number[];
|
|
117
|
+
outlineDisp: number[];
|
|
118
|
+
outlineIdx: number[];
|
|
119
|
+
}
|
|
120
|
+
export interface FemResultEnvelope {
|
|
121
|
+
maxSettlementMm: number;
|
|
122
|
+
minSettlementMm: number;
|
|
123
|
+
totalLoadKn: number;
|
|
124
|
+
reactionKn: number;
|
|
125
|
+
reactionBalanceRatio: number;
|
|
126
|
+
}
|
|
127
|
+
export interface FemResultManifest {
|
|
128
|
+
schemaVersion: 'fem-result-manifest.v0';
|
|
129
|
+
caseId: string;
|
|
130
|
+
title: string;
|
|
131
|
+
generatedAt: string;
|
|
132
|
+
backend: {
|
|
133
|
+
id: 'builtin-elastic3d-demo';
|
|
134
|
+
label: string;
|
|
135
|
+
deterministic: true;
|
|
136
|
+
version: string;
|
|
137
|
+
};
|
|
138
|
+
analysisCase: FemAnalysisCase;
|
|
139
|
+
validation: FemValidationSummary;
|
|
140
|
+
mesh: {
|
|
141
|
+
nodes: number;
|
|
142
|
+
elements: number;
|
|
143
|
+
elementType: 'hex8';
|
|
144
|
+
divisions: [number, number, number];
|
|
145
|
+
visualizationNodes: number;
|
|
146
|
+
visualizationTriangles: number;
|
|
147
|
+
visualizationEdges: number;
|
|
148
|
+
};
|
|
149
|
+
envelope: FemResultEnvelope;
|
|
150
|
+
visualization: FemVisualizationMesh;
|
|
151
|
+
assumptions: FemAssumption[];
|
|
152
|
+
limitations: string[];
|
|
153
|
+
}
|
|
154
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/fem/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/fem/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { FemAnalysisCase, FemResultManifest, FemValidationSummary } from './types.js';
|
|
2
|
+
export declare function validateFemAnalysisCase(caseFile: FemAnalysisCase): FemValidationSummary;
|
|
3
|
+
export declare function validateFemResultManifest(manifest: FemResultManifest): FemValidationSummary;
|
|
4
|
+
//# sourceMappingURL=validation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../src/fem/validation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,eAAe,EACf,iBAAiB,EAEjB,oBAAoB,EACrB,MAAM,YAAY,CAAC;AAoEpB,wBAAgB,uBAAuB,CAAC,QAAQ,EAAE,eAAe,GAAG,oBAAoB,CAiFvF;AAsDD,wBAAgB,yBAAyB,CAAC,QAAQ,EAAE,iBAAiB,GAAG,oBAAoB,CAuD3F"}
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
function finding(severity, code, message) {
|
|
2
|
+
return { severity, code, message };
|
|
3
|
+
}
|
|
4
|
+
function summary(findings) {
|
|
5
|
+
const blockers = findings.filter((item) => item.severity === 'blocker').length;
|
|
6
|
+
const reviewItems = findings.filter((item) => item.severity === 'review').length;
|
|
7
|
+
return {
|
|
8
|
+
status: blockers > 0 ? 'blocked' : reviewItems > 0 ? 'review' : 'ready',
|
|
9
|
+
blockers,
|
|
10
|
+
reviewItems,
|
|
11
|
+
findings,
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
function isRecord(value) {
|
|
15
|
+
return typeof value === 'object' && value !== null;
|
|
16
|
+
}
|
|
17
|
+
function isFemAnalysisCaseShape(value) {
|
|
18
|
+
if (!isRecord(value))
|
|
19
|
+
return false;
|
|
20
|
+
const geometry = value.geometry;
|
|
21
|
+
const mesh = value.mesh;
|
|
22
|
+
const groundwater = value.groundwater;
|
|
23
|
+
return (isRecord(geometry) &&
|
|
24
|
+
isRecord(geometry.domain) &&
|
|
25
|
+
isRecord(geometry.raft) &&
|
|
26
|
+
isRecord(mesh) &&
|
|
27
|
+
isRecord(groundwater) &&
|
|
28
|
+
Array.isArray(value.materials) &&
|
|
29
|
+
Array.isArray(value.loads) &&
|
|
30
|
+
Array.isArray(value.assumptions) &&
|
|
31
|
+
Array.isArray(value.limitations) &&
|
|
32
|
+
Array.isArray(value.evidenceRefs));
|
|
33
|
+
}
|
|
34
|
+
function isFemResultManifestShape(value) {
|
|
35
|
+
if (!isRecord(value))
|
|
36
|
+
return false;
|
|
37
|
+
const visualization = value.visualization;
|
|
38
|
+
const envelope = value.envelope;
|
|
39
|
+
const mesh = value.mesh;
|
|
40
|
+
return (isFemAnalysisCaseShape(value.analysisCase) &&
|
|
41
|
+
isRecord(envelope) &&
|
|
42
|
+
isRecord(mesh) &&
|
|
43
|
+
isRecord(visualization) &&
|
|
44
|
+
Array.isArray(visualization.base) &&
|
|
45
|
+
Array.isArray(visualization.disp) &&
|
|
46
|
+
Array.isArray(visualization.color) &&
|
|
47
|
+
Array.isArray(visualization.tri) &&
|
|
48
|
+
Array.isArray(visualization.edge) &&
|
|
49
|
+
Array.isArray(visualization.outlineBase) &&
|
|
50
|
+
Array.isArray(visualization.outlineDisp) &&
|
|
51
|
+
Array.isArray(visualization.outlineIdx) &&
|
|
52
|
+
Array.isArray(value.assumptions) &&
|
|
53
|
+
Array.isArray(value.limitations));
|
|
54
|
+
}
|
|
55
|
+
export function validateFemAnalysisCase(caseFile) {
|
|
56
|
+
const findings = [];
|
|
57
|
+
if (!isFemAnalysisCaseShape(caseFile)) {
|
|
58
|
+
return summary([
|
|
59
|
+
finding('blocker', 'schema.shape-invalid', 'FEM analysis case is missing required geometry, mesh, groundwater, or array fields.'),
|
|
60
|
+
]);
|
|
61
|
+
}
|
|
62
|
+
const { domain, raft } = caseFile.geometry;
|
|
63
|
+
const material = caseFile.materials[0];
|
|
64
|
+
const load = caseFile.loads[0];
|
|
65
|
+
if (caseFile.schemaVersion !== 'fem-analysis-case.v0') {
|
|
66
|
+
findings.push(finding('blocker', 'schema.unsupported', 'Only fem-analysis-case.v0 is supported.'));
|
|
67
|
+
}
|
|
68
|
+
if (!caseFile.experimental) {
|
|
69
|
+
findings.push(finding('blocker', 'mode.experimental-required', 'FEM cases must be explicitly marked experimental.'));
|
|
70
|
+
}
|
|
71
|
+
if (caseFile.objective !== 'foundation_settlement') {
|
|
72
|
+
findings.push(finding('blocker', 'objective.unsupported', `Unsupported FEM objective: ${caseFile.objective}.`));
|
|
73
|
+
}
|
|
74
|
+
if (caseFile.analysisType !== 'static_3d_small_strain') {
|
|
75
|
+
findings.push(finding('blocker', 'analysis.unsupported', `Unsupported analysis type: ${caseFile.analysisType}.`));
|
|
76
|
+
}
|
|
77
|
+
if (domain.lengthM <= 0 || domain.widthM <= 0 || domain.depthM <= 0) {
|
|
78
|
+
findings.push(finding('blocker', 'geometry.domain-invalid', 'Domain dimensions must be positive.'));
|
|
79
|
+
}
|
|
80
|
+
if (raft.lengthM <= 0 || raft.widthM <= 0 || raft.thicknessM <= 0) {
|
|
81
|
+
findings.push(finding('blocker', 'geometry.raft-invalid', 'Raft dimensions must be positive.'));
|
|
82
|
+
}
|
|
83
|
+
if (domain.lengthM < raft.lengthM * 3 || domain.widthM < raft.widthM * 3) {
|
|
84
|
+
findings.push(finding('review', 'geometry.domain-small', 'Domain is less than three raft widths in plan; boundary influence should be reviewed.'));
|
|
85
|
+
}
|
|
86
|
+
if (domain.depthM < Math.max(raft.lengthM, raft.widthM)) {
|
|
87
|
+
findings.push(finding('review', 'geometry.depth-shallow', 'Domain depth is less than the controlling raft dimension; settlement influence depth should be reviewed.'));
|
|
88
|
+
}
|
|
89
|
+
if (!material) {
|
|
90
|
+
findings.push(finding('blocker', 'material.missing', 'At least one material is required.'));
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
if (material.model !== 'linear_elastic') {
|
|
94
|
+
findings.push(finding('blocker', 'material.unsupported', `Unsupported material model: ${material.model}.`));
|
|
95
|
+
}
|
|
96
|
+
if (!Number.isFinite(material.elasticModulusKpa) || material.elasticModulusKpa <= 0) {
|
|
97
|
+
findings.push(finding('blocker', 'material.elastic-modulus-invalid', 'Elastic modulus must be positive.'));
|
|
98
|
+
}
|
|
99
|
+
if (!Number.isFinite(material.poissonRatio) || material.poissonRatio <= 0 || material.poissonRatio >= 0.5) {
|
|
100
|
+
findings.push(finding('blocker', 'material.poisson-invalid', 'Poisson ratio must be between 0 and 0.5.'));
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
if (!load) {
|
|
104
|
+
findings.push(finding('blocker', 'load.missing', 'A raft pressure load is required.'));
|
|
105
|
+
}
|
|
106
|
+
else if (!Number.isFinite(load.pressureKpa) || load.pressureKpa <= 0) {
|
|
107
|
+
findings.push(finding('blocker', 'load.pressure-invalid', 'Uniform pressure must be positive.'));
|
|
108
|
+
}
|
|
109
|
+
const { divisionsX, divisionsY, divisionsZ } = caseFile.mesh;
|
|
110
|
+
if (divisionsX < 2 || divisionsY < 2 || divisionsZ < 1) {
|
|
111
|
+
findings.push(finding('blocker', 'mesh.too-coarse', 'Mesh divisions must be at least 2 x 2 x 1.'));
|
|
112
|
+
}
|
|
113
|
+
if (caseFile.groundwater.reviewRequired) {
|
|
114
|
+
findings.push(finding('review', 'groundwater.review-required', caseFile.groundwater.note));
|
|
115
|
+
}
|
|
116
|
+
for (const assumption of caseFile.assumptions) {
|
|
117
|
+
if (assumption.reviewRequired || assumption.confidence === 'review') {
|
|
118
|
+
findings.push(finding('review', `assumption.${assumption.id}`, `${assumption.parameter} is an engineering assumption requiring review.`));
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
return summary(findings);
|
|
122
|
+
}
|
|
123
|
+
function pushFiniteArrayFindings(findings, name, values, multipleOf) {
|
|
124
|
+
if (values.length === 0) {
|
|
125
|
+
findings.push(finding('blocker', `result.${name}.empty`, `${name} must not be empty.`));
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
if (values.length % multipleOf !== 0) {
|
|
129
|
+
findings.push(finding('blocker', `result.${name}.stride-invalid`, `${name} length must be divisible by ${multipleOf}.`));
|
|
130
|
+
}
|
|
131
|
+
if (values.some((value) => !Number.isFinite(value))) {
|
|
132
|
+
findings.push(finding('blocker', `result.${name}.non-finite`, `${name} contains non-finite values.`));
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
function pushIndexArrayFindings(findings, name, values, nodeCount, multipleOf) {
|
|
136
|
+
if (values.length === 0) {
|
|
137
|
+
findings.push(finding('blocker', `result.${name}.empty`, `${name} must not be empty.`));
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
if (values.length % multipleOf !== 0) {
|
|
141
|
+
findings.push(finding('blocker', `result.${name}.stride-invalid`, `${name} length must be divisible by ${multipleOf}.`));
|
|
142
|
+
}
|
|
143
|
+
for (const value of values) {
|
|
144
|
+
if (!Number.isInteger(value) || value < 0 || value >= nodeCount) {
|
|
145
|
+
findings.push(finding('blocker', `result.${name}.index-invalid`, `${name} references node index ${value}, outside the 0-${Math.max(0, nodeCount - 1)} range.`));
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
export function validateFemResultManifest(manifest) {
|
|
151
|
+
const findings = [];
|
|
152
|
+
if (!isFemResultManifestShape(manifest)) {
|
|
153
|
+
return summary([
|
|
154
|
+
finding('blocker', 'result.schema.shape-invalid', 'FEM result manifest is missing required analysis case, envelope, mesh, visualization, or array fields.'),
|
|
155
|
+
]);
|
|
156
|
+
}
|
|
157
|
+
if (manifest.schemaVersion !== 'fem-result-manifest.v0') {
|
|
158
|
+
findings.push(finding('blocker', 'result.schema.unsupported', 'Only fem-result-manifest.v0 is supported.'));
|
|
159
|
+
}
|
|
160
|
+
if (!manifest.analysisCase.experimental) {
|
|
161
|
+
findings.push(finding('blocker', 'result.experimental-required', 'FEM result manifests must be tied to an experimental case.'));
|
|
162
|
+
}
|
|
163
|
+
for (const [key, value] of Object.entries(manifest.envelope)) {
|
|
164
|
+
if (!Number.isFinite(value)) {
|
|
165
|
+
findings.push(finding('blocker', `result.envelope.${key}.non-finite`, `Envelope value ${key} must be finite.`));
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
if (manifest.envelope.reactionBalanceRatio < 0.95 || manifest.envelope.reactionBalanceRatio > 1.05) {
|
|
169
|
+
findings.push(finding('review', 'result.envelope.balance-review', 'Reaction balance is outside the 0.95-1.05 review band.'));
|
|
170
|
+
}
|
|
171
|
+
const { visualization } = manifest;
|
|
172
|
+
pushFiniteArrayFindings(findings, 'base', visualization.base, 3);
|
|
173
|
+
pushFiniteArrayFindings(findings, 'disp', visualization.disp, 3);
|
|
174
|
+
pushFiniteArrayFindings(findings, 'color', visualization.color, 3);
|
|
175
|
+
pushFiniteArrayFindings(findings, 'outlineBase', visualization.outlineBase, 3);
|
|
176
|
+
pushFiniteArrayFindings(findings, 'outlineDisp', visualization.outlineDisp, 3);
|
|
177
|
+
const nodeCount = visualization.base.length / 3;
|
|
178
|
+
if (visualization.disp.length / 3 !== nodeCount) {
|
|
179
|
+
findings.push(finding('blocker', 'result.disp.node-count-mismatch', 'Displacement vectors must match base nodes.'));
|
|
180
|
+
}
|
|
181
|
+
if (visualization.color.length / 3 !== nodeCount) {
|
|
182
|
+
findings.push(finding('blocker', 'result.color.node-count-mismatch', 'Color vectors must match base nodes.'));
|
|
183
|
+
}
|
|
184
|
+
pushIndexArrayFindings(findings, 'tri', visualization.tri, nodeCount, 3);
|
|
185
|
+
pushIndexArrayFindings(findings, 'edge', visualization.edge, nodeCount, 2);
|
|
186
|
+
const outlineNodeCount = visualization.outlineBase.length / 3;
|
|
187
|
+
if (visualization.outlineDisp.length / 3 !== outlineNodeCount) {
|
|
188
|
+
findings.push(finding('blocker', 'result.outline.node-count-mismatch', 'Outline displacement vectors must match outline nodes.'));
|
|
189
|
+
}
|
|
190
|
+
pushIndexArrayFindings(findings, 'outlineIdx', visualization.outlineIdx, outlineNodeCount, 2);
|
|
191
|
+
const caseValidation = validateFemAnalysisCase(manifest.analysisCase);
|
|
192
|
+
findings.push(...caseValidation.findings);
|
|
193
|
+
return summary(findings);
|
|
194
|
+
}
|
|
195
|
+
//# sourceMappingURL=validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/fem/validation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webgl.d.ts","sourceRoot":"","sources":["../../src/fem/webgl.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAepD,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,iBAAiB,GAAG,MAAM,CA4GtE"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
function escapeHtml(value) {
|
|
2
|
+
return value
|
|
3
|
+
.replaceAll('&', '&')
|
|
4
|
+
.replaceAll('<', '<')
|
|
5
|
+
.replaceAll('>', '>')
|
|
6
|
+
.replaceAll('"', '"')
|
|
7
|
+
.replaceAll("'", ''');
|
|
8
|
+
}
|
|
9
|
+
function safeJson(value) {
|
|
10
|
+
return JSON.stringify(value).replaceAll('</', '<\\/');
|
|
11
|
+
}
|
|
12
|
+
export function renderFemWebglHtml(manifest) {
|
|
13
|
+
const data = safeJson(manifest);
|
|
14
|
+
const title = escapeHtml(manifest.title);
|
|
15
|
+
const status = manifest.validation.status.toUpperCase();
|
|
16
|
+
const findingRows = manifest.validation.findings.length > 0
|
|
17
|
+
? manifest.validation.findings.map((finding) => `
|
|
18
|
+
<li><strong>${escapeHtml(finding.severity)}</strong> ${escapeHtml(finding.message)}</li>`).join('')
|
|
19
|
+
: '<li>No blocking validation issues. Review assumptions before design use.</li>';
|
|
20
|
+
const assumptionRows = manifest.assumptions.map((assumption) => `
|
|
21
|
+
<li><strong>${escapeHtml(assumption.parameter)}</strong>: ${escapeHtml(String(assumption.value))}${assumption.unit ? ` ${escapeHtml(assumption.unit)}` : ''}<br><span>${escapeHtml(assumption.basis)}</span></li>`).join('');
|
|
22
|
+
const limitationRows = manifest.limitations.map((item) => `<li>${escapeHtml(item)}</li>`).join('');
|
|
23
|
+
return `<!doctype html>
|
|
24
|
+
<html lang="en">
|
|
25
|
+
<head>
|
|
26
|
+
<meta charset="utf-8">
|
|
27
|
+
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
28
|
+
<title>${title} - geotechCLI FEM</title>
|
|
29
|
+
<style>
|
|
30
|
+
:root{color-scheme:dark;--bg:#07111f;--panel:#0f1b2d;--panel2:#142238;--text:#e8eef8;--muted:#a8b3c7;--line:#29405f;--accent:#38bdf8;--warn:#f59e0b;--good:#22c55e}
|
|
31
|
+
*{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
|
|
32
|
+
#app{position:fixed;inset:0;display:grid;grid-template-columns:minmax(0,1fr) 380px}
|
|
33
|
+
main{position:relative;min-width:0;background:radial-gradient(circle at 50% 34%,rgba(56,189,248,.14),transparent 36%),linear-gradient(180deg,#020617,#07111f 55%,#0b1220)}
|
|
34
|
+
canvas{width:100%;height:100%;display:block;cursor:grab}canvas:active{cursor:grabbing}
|
|
35
|
+
aside{border-left:1px solid var(--line);background:linear-gradient(180deg,rgba(15,27,45,.96),rgba(7,17,31,.98));padding:20px;overflow:auto;box-shadow:-18px 0 44px rgba(0,0,0,.34)}
|
|
36
|
+
h1{font-size:20px;line-height:1.2;margin:0 0 8px}.sub{font-size:13px;line-height:1.45;color:var(--muted);margin:0 0 14px}
|
|
37
|
+
.badge{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(56,189,248,.28);background:rgba(56,189,248,.11);color:#dff7ff;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:700;margin-bottom:12px}
|
|
38
|
+
.dot{width:8px;height:8px;border-radius:99px;background:var(--good);box-shadow:0 0 16px var(--good)}
|
|
39
|
+
.card{border:1px solid var(--line);background:rgba(20,34,56,.82);border-radius:14px;padding:14px;margin:12px 0}
|
|
40
|
+
.card h2{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#bae6fd;margin:0 0 10px}
|
|
41
|
+
.kv{display:grid;grid-template-columns:1fr auto;gap:8px 12px;font-size:12.5px}.kv span:nth-child(odd){color:var(--muted)}.kv span:nth-child(even){font-variant-numeric:tabular-nums;text-align:right}
|
|
42
|
+
label{display:block;color:var(--muted);font-size:12.5px;margin:10px 0 6px}input[type=range]{width:100%;accent-color:var(--accent)}
|
|
43
|
+
.row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}button{border:1px solid rgba(148,163,184,.28);background:#1e3a5f;color:#eff6ff;border-radius:9px;padding:7px 10px;font-size:12px;cursor:pointer}button:hover{background:#25638e}
|
|
44
|
+
ul{margin:0;padding-left:18px;color:#dbeafe;font-size:12.5px;line-height:1.45}li{margin:8px 0}li span{color:var(--muted)}
|
|
45
|
+
.legend{display:grid;grid-template-columns:52px 1fr 56px;gap:8px;align-items:center;color:var(--muted);font-size:11.5px}.bar{height:12px;border-radius:99px;background:linear-gradient(90deg,rgb(43,62,154),rgb(47,107,205),rgb(56,170,210),rgb(80,200,120),rgb(235,210,75),rgb(220,83,44),rgb(170,25,55));border:1px solid rgba(255,255,255,.22)}
|
|
46
|
+
#fallback{display:none;position:absolute;left:20px;bottom:20px;max-width:380px;border:1px solid rgba(245,158,11,.45);background:rgba(7,17,31,.92);border-radius:14px;padding:12px 14px;color:#fde68a;z-index:2;box-shadow:0 14px 40px rgba(0,0,0,.28);font-size:12px;line-height:1.4}
|
|
47
|
+
.warn{color:#fbbf24}.small{font-size:11.5px;line-height:1.45;color:#94a3b8}
|
|
48
|
+
@media(max-width:900px){#app{grid-template-columns:1fr;grid-template-rows:1fr 42vh}aside{border-left:0;border-top:1px solid var(--line)}}
|
|
49
|
+
</style>
|
|
50
|
+
</head>
|
|
51
|
+
<body>
|
|
52
|
+
<div id="app">
|
|
53
|
+
<main>
|
|
54
|
+
<canvas id="glcanvas" aria-label="Interactive WebGL FEM settlement visualization"></canvas>
|
|
55
|
+
<div id="fallback">WebGL could not be started in this browser. Try recent Chrome, Edge, Firefox, or Safari with hardware acceleration enabled.</div>
|
|
56
|
+
</main>
|
|
57
|
+
<aside>
|
|
58
|
+
<div class="badge"><span class="dot"></span><span>Experimental deterministic FEM preview</span></div>
|
|
59
|
+
<h1>${title}</h1>
|
|
60
|
+
<p class="sub">Self-contained geotechCLI WebGL artifact. The model is deterministic and replayable from the embedded result manifest. It is an experimental screening demo, not a design model.</p>
|
|
61
|
+
<div class="card"><h2>Controls</h2>
|
|
62
|
+
<label for="scale">Deformation scale: <b id="scaleLabel">120x</b></label>
|
|
63
|
+
<input id="scale" type="range" min="0" max="300" value="120" step="1">
|
|
64
|
+
<div class="row" style="margin-top:10px"><button data-scale="0">0x</button><button data-scale="60">60x</button><button data-scale="120">120x</button><button data-scale="240">240x</button><button id="reset">Reset view</button></div>
|
|
65
|
+
<label class="row"><input id="wire" type="checkbox" checked> <span>Show mesh wireframe</span></label>
|
|
66
|
+
<label class="row"><input id="patch" type="checkbox" checked> <span>Show raft load patch</span></label>
|
|
67
|
+
</div>
|
|
68
|
+
<div class="card"><h2>Result envelope</h2><div class="kv" id="stats"></div></div>
|
|
69
|
+
<div class="card"><h2>Validation status</h2><p class="sub"><strong class="${manifest.validation.status === 'blocked' ? 'warn' : ''}">${escapeHtml(status)}</strong> - ${manifest.validation.blockers} blockers, ${manifest.validation.reviewItems} review items</p><ul>${findingRows}</ul></div>
|
|
70
|
+
<div class="card"><h2>Vertical settlement color</h2><div class="legend"><span>low</span><div class="bar"></div><span>high</span></div><p class="small">Warm colors show greater downward settlement. Displayed deformation is exaggerated by the slider.</p></div>
|
|
71
|
+
<div class="card"><h2>Assumptions</h2><ul>${assumptionRows}</ul></div>
|
|
72
|
+
<div class="card"><h2>Limitations</h2><ul>${limitationRows}</ul></div>
|
|
73
|
+
</aside>
|
|
74
|
+
</div>
|
|
75
|
+
<script>
|
|
76
|
+
const MANIFEST = ${data};
|
|
77
|
+
const DATA = MANIFEST.visualization;
|
|
78
|
+
let canvas = document.getElementById('glcanvas');
|
|
79
|
+
const fallback = document.getElementById('fallback');
|
|
80
|
+
document.body.dataset.renderer = 'initializing';
|
|
81
|
+
let gl=null, triProgram=null, lineProgram=null, baseBuf=null, dispBuf=null, colorBuf=null, triBuf=null, edgeBuf=null, obaseBuf=null, odispBuf=null, oidxBuf=null;
|
|
82
|
+
function ident(){return[1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1]}
|
|
83
|
+
function mul(a,b){const r=new Array(16).fill(0);for(let c=0;c<4;c++){for(let row=0;row<4;row++){for(let k=0;k<4;k++){r[c*4+row]+=a[k*4+row]*b[c*4+k];}}}return r}
|
|
84
|
+
function perspective(fovy,aspect,near,far){const f=1/Math.tan(fovy/2),nf=1/(near-far);return[f/aspect,0,0,0,0,f,0,0,0,0,(far+near)*nf,-1,0,0,2*far*near*nf,0]}
|
|
85
|
+
function translate(m,x,y,z){const t=ident();t[12]=x;t[13]=y;t[14]=z;return mul(m,t)}
|
|
86
|
+
function rotateX(m,a){const c=Math.cos(a),s=Math.sin(a);return mul(m,[1,0,0,0,0,c,s,0,0,-s,c,0,0,0,0,1])}
|
|
87
|
+
function rotateZ(m,a){const c=Math.cos(a),s=Math.sin(a);return mul(m,[c,s,0,0,-s,c,0,0,0,0,1,0,0,0,0,1])}
|
|
88
|
+
function scaleM(m,s){return mul(m,[s,0,0,0,0,s,0,0,0,0,s,0,0,0,0,1])}
|
|
89
|
+
let rx=-0.92, rz=-0.72, zoom=0.052, deform=120, dragging=false, lx=0, ly=0;
|
|
90
|
+
function resizeCanvas(){const dpr=Math.min(window.devicePixelRatio||1,2);const rect=canvas.getBoundingClientRect();const w=Math.max(1,Math.floor((rect.width||canvas.clientWidth||window.innerWidth)*dpr)),h=Math.max(1,Math.floor((rect.height||canvas.clientHeight||window.innerHeight)*dpr));if(canvas.width!==w||canvas.height!==h){canvas.width=w;canvas.height=h;}}
|
|
91
|
+
function markRenderer(name,message){document.body.dataset.renderer=name;if(message){fallback.textContent=message;fallback.style.display='block';}else{fallback.style.display='none';}}
|
|
92
|
+
function shader(type, src){ const s=gl.createShader(type); gl.shaderSource(s,src); gl.compileShader(s); if(!gl.getShaderParameter(s,gl.COMPILE_STATUS)){ throw new Error(gl.getShaderInfoLog(s)||'shader compile failed'); } return s; }
|
|
93
|
+
function program(vs, fs){ const p=gl.createProgram(); gl.attachShader(p,shader(gl.VERTEX_SHADER,vs)); gl.attachShader(p,shader(gl.FRAGMENT_SHADER,fs)); gl.linkProgram(p); if(!gl.getProgramParameter(p,gl.LINK_STATUS)){ throw new Error(gl.getProgramInfoLog(p)||'program link failed'); } return p; }
|
|
94
|
+
function buf(data,target){ const b=gl.createBuffer(); gl.bindBuffer(target,b); gl.bufferData(target,data,gl.STATIC_DRAW); return b; }
|
|
95
|
+
function attr(p,name,b,size){ const l=gl.getAttribLocation(p,name); if(l<0)return; gl.bindBuffer(gl.ARRAY_BUFFER,b); gl.enableVertexAttribArray(l); gl.vertexAttribPointer(l,size,gl.FLOAT,false,0,0); }
|
|
96
|
+
function initWebgl(){try{if(navigator.webdriver){return false;}gl=canvas.getContext('webgl',{antialias:true,alpha:false})||canvas.getContext('experimental-webgl',{antialias:true,alpha:false});if(!gl)return false;triProgram=program('attribute vec3 aBase;attribute vec3 aDisp;attribute vec3 aColor;uniform mat4 uMvp;uniform float uScale;varying vec3 vColor;void main(){vec3 p=aBase+aDisp*uScale;vColor=aColor;gl_Position=uMvp*vec4(p,1.0);}','precision mediump float;varying vec3 vColor;void main(){gl_FragColor=vec4(vColor,1.0);}');lineProgram=program('attribute vec3 aBase;attribute vec3 aDisp;uniform mat4 uMvp;uniform float uScale;void main(){vec3 p=aBase+aDisp*uScale;gl_Position=uMvp*vec4(p,1.0);}','precision mediump float;uniform vec4 uColor;void main(){gl_FragColor=uColor;}');baseBuf=buf(new Float32Array(DATA.base),gl.ARRAY_BUFFER);dispBuf=buf(new Float32Array(DATA.disp),gl.ARRAY_BUFFER);colorBuf=buf(new Float32Array(DATA.color),gl.ARRAY_BUFFER);triBuf=buf(new Uint16Array(DATA.tri),gl.ELEMENT_ARRAY_BUFFER);edgeBuf=buf(new Uint16Array(DATA.edge),gl.ELEMENT_ARRAY_BUFFER);obaseBuf=buf(new Float32Array(DATA.outlineBase),gl.ARRAY_BUFFER);odispBuf=buf(new Float32Array(DATA.outlineDisp),gl.ARRAY_BUFFER);oidxBuf=buf(new Uint16Array(DATA.outlineIdx),gl.ELEMENT_ARRAY_BUFFER);return true;}catch(error){console.warn('WebGL FEM renderer unavailable; using canvas fallback.',error);return false;}}
|
|
97
|
+
function mvp(){let m=ident();m=translate(m,0,0,-3.2);m=rotateX(m,rx);m=rotateZ(m,rz);m=scaleM(m,zoom);return mul(perspective(Math.PI/4,canvas.width/canvas.height,0.1,100),m)}
|
|
98
|
+
function drawWebgl(){resizeCanvas();if(!gl||gl.drawingBufferWidth<1||gl.drawingBufferHeight<1){drawCanvasFallback('Canvas fallback: WebGL context returned a zero-size drawing buffer.');return;}markRenderer('webgl','');gl.viewport(0,0,canvas.width,canvas.height);gl.clearColor(0.02,0.06,0.12,1);gl.clear(gl.COLOR_BUFFER_BIT|gl.DEPTH_BUFFER_BIT);gl.enable(gl.DEPTH_TEST);const matrix=new Float32Array(mvp());gl.useProgram(triProgram);attr(triProgram,'aBase',baseBuf,3);attr(triProgram,'aDisp',dispBuf,3);attr(triProgram,'aColor',colorBuf,3);gl.uniformMatrix4fv(gl.getUniformLocation(triProgram,'uMvp'),false,matrix);gl.uniform1f(gl.getUniformLocation(triProgram,'uScale'),deform);gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER,triBuf);gl.drawElements(gl.TRIANGLES,DATA.tri.length,gl.UNSIGNED_SHORT,0);if(document.getElementById('wire').checked){gl.useProgram(lineProgram);attr(lineProgram,'aBase',baseBuf,3);attr(lineProgram,'aDisp',dispBuf,3);gl.uniformMatrix4fv(gl.getUniformLocation(lineProgram,'uMvp'),false,matrix);gl.uniform1f(gl.getUniformLocation(lineProgram,'uScale'),deform);gl.uniform4f(gl.getUniformLocation(lineProgram,'uColor'),0.82,0.9,1,0.42);gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER,edgeBuf);gl.drawElements(gl.LINES,DATA.edge.length,gl.UNSIGNED_SHORT,0);}if(document.getElementById('patch').checked){gl.useProgram(lineProgram);attr(lineProgram,'aBase',obaseBuf,3);attr(lineProgram,'aDisp',odispBuf,3);gl.uniformMatrix4fv(gl.getUniformLocation(lineProgram,'uMvp'),false,matrix);gl.uniform1f(gl.getUniformLocation(lineProgram,'uScale'),0);gl.uniform4f(gl.getUniformLocation(lineProgram,'uColor'),1,0.78,0.24,1);gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER,oidxBuf);gl.drawElements(gl.LINES,DATA.outlineIdx.length,gl.UNSIGNED_SHORT,0);}}
|
|
99
|
+
function colorAt(i){return [DATA.color[i*3]||0,DATA.color[i*3+1]||0,DATA.color[i*3+2]||0];}
|
|
100
|
+
function cssRgb(rgb,alpha){return 'rgba('+Math.round(rgb[0]*255)+','+Math.round(rgb[1]*255)+','+Math.round(rgb[2]*255)+','+alpha+')';}
|
|
101
|
+
function pointFrom(base,disp,i,scale){return [base[i*3]+(disp[i*3]||0)*scale,base[i*3+1]+(disp[i*3+1]||0)*scale,base[i*3+2]+(disp[i*3+2]||0)*scale];}
|
|
102
|
+
function projectPoint(p){const cz=Math.cos(rz),sz=Math.sin(rz),cx=Math.cos(rx),sx=Math.sin(rx);const x1=p[0]*cz-p[1]*sz,y1=p[0]*sz+p[1]*cz,z1=p[2];const y2=y1*cx-z1*sx;const fit=Math.min(canvas.width,canvas.height)*zoom*0.95;return [canvas.width/2+x1*fit,canvas.height*0.50-y2*fit];}
|
|
103
|
+
function drawEdge(ctx,base,disp,a,b,scale,color,width){const p1=projectPoint(pointFrom(base,disp,a,scale)),p2=projectPoint(pointFrom(base,disp,b,scale));ctx.strokeStyle=color;ctx.lineWidth=width;ctx.beginPath();ctx.moveTo(p1[0],p1[1]);ctx.lineTo(p2[0],p2[1]);ctx.stroke();}
|
|
104
|
+
function drawCanvasFallback(message){resizeCanvas();markRenderer('canvas2d-fallback',message||'Canvas fallback: WebGL unavailable in this browser.');let ctx=canvas.getContext('2d');if(!ctx){const replacement=document.createElement('canvas');replacement.id='glcanvas';replacement.setAttribute('aria-label','Canvas FEM settlement visualization fallback');canvas.replaceWith(replacement);canvas=replacement;bindCanvasEvents(canvas);resizeCanvas();ctx=canvas.getContext('2d');}if(!ctx){fallback.textContent='Canvas fallback could not be started in this browser.';return;}const w=canvas.width,h=canvas.height;const grad=ctx.createLinearGradient(0,0,0,h);grad.addColorStop(0,'#020617');grad.addColorStop(0.58,'#07111f');grad.addColorStop(1,'#0b1220');ctx.fillStyle=grad;ctx.fillRect(0,0,w,h);const glow=ctx.createRadialGradient(w*0.52,h*0.34,0,w*0.52,h*0.34,Math.min(w,h)*0.48);glow.addColorStop(0,'rgba(56,189,248,.16)');glow.addColorStop(1,'rgba(56,189,248,0)');ctx.fillStyle=glow;ctx.fillRect(0,0,w,h);for(let i=0;i<DATA.tri.length;i+=3){const a=DATA.tri[i],b=DATA.tri[i+1],c=DATA.tri[i+2];const pa=projectPoint(pointFrom(DATA.base,DATA.disp,a,deform)),pb=projectPoint(pointFrom(DATA.base,DATA.disp,b,deform)),pc=projectPoint(pointFrom(DATA.base,DATA.disp,c,deform));const ca=colorAt(a),cb=colorAt(b),cc=colorAt(c);ctx.fillStyle=cssRgb([(ca[0]+cb[0]+cc[0])/3,(ca[1]+cb[1]+cc[1])/3,(ca[2]+cb[2]+cc[2])/3],0.92);ctx.beginPath();ctx.moveTo(pa[0],pa[1]);ctx.lineTo(pb[0],pb[1]);ctx.lineTo(pc[0],pc[1]);ctx.closePath();ctx.fill();}if(document.getElementById('wire').checked){for(let i=0;i<DATA.edge.length;i+=2){drawEdge(ctx,DATA.base,DATA.disp,DATA.edge[i],DATA.edge[i+1],deform,'rgba(226,232,240,.32)',1);}}if(document.getElementById('patch').checked){for(let i=0;i<DATA.outlineIdx.length;i+=2){drawEdge(ctx,DATA.outlineBase,DATA.outlineDisp,DATA.outlineIdx[i],DATA.outlineIdx[i+1],0,'rgba(251,191,36,.95)',2);}}ctx.fillStyle='rgba(186,230,253,.9)';ctx.font='600 14px Inter, system-ui, sans-serif';ctx.fillText('3D FEM settlement surface',24,32);ctx.fillStyle='rgba(148,163,184,.9)';ctx.font='12px Inter, system-ui, sans-serif';ctx.fillText('Renderer: Canvas fallback; deformation scale '+deform+'x',24,52);}
|
|
105
|
+
const webglReady=initWebgl();
|
|
106
|
+
function draw(){if(webglReady){try{drawWebgl();return;}catch(error){console.warn('WebGL draw failed; using canvas fallback.',error);}}drawCanvasFallback('Canvas fallback: WebGL unavailable in this browser.');}
|
|
107
|
+
function updateScale(v){deform=Number(v);document.getElementById('scale').value=String(deform);document.getElementById('scaleLabel').textContent=String(deform)+'x';draw();}
|
|
108
|
+
function bindCanvasEvents(target){target.addEventListener('pointerdown',e=>{dragging=true;lx=e.clientX;ly=e.clientY;target.setPointerCapture(e.pointerId);});target.addEventListener('pointermove',e=>{if(!dragging)return;rz+=(e.clientX-lx)*0.008;rx+=(e.clientY-ly)*0.008;lx=e.clientX;ly=e.clientY;draw();});target.addEventListener('pointerup',()=>{dragging=false;});target.addEventListener('wheel',e=>{e.preventDefault();zoom*=e.deltaY>0?0.9:1.1;zoom=Math.max(0.025,Math.min(0.12,zoom));draw();},{passive:false});}
|
|
109
|
+
bindCanvasEvents(canvas);
|
|
110
|
+
document.getElementById('scale').addEventListener('input',e=>updateScale(e.target.value));
|
|
111
|
+
document.querySelectorAll('button[data-scale]').forEach(b=>b.addEventListener('click',()=>updateScale(b.dataset.scale)));
|
|
112
|
+
document.getElementById('reset').addEventListener('click',()=>{rx=-0.92;rz=-0.72;zoom=0.052;updateScale(120);});
|
|
113
|
+
document.getElementById('wire').addEventListener('change',draw);document.getElementById('patch').addEventListener('change',draw);window.addEventListener('resize',draw);
|
|
114
|
+
document.getElementById('stats').innerHTML='<span>Max settlement</span><span>'+MANIFEST.envelope.maxSettlementMm.toFixed(2)+' mm</span><span>Total load</span><span>'+MANIFEST.envelope.totalLoadKn.toFixed(0)+' kN</span><span>Reaction</span><span>'+MANIFEST.envelope.reactionKn.toFixed(0)+' kN</span><span>Balance</span><span>'+MANIFEST.envelope.reactionBalanceRatio.toFixed(3)+'</span><span>Mesh</span><span>'+MANIFEST.mesh.divisions.join(' x ')+' hex8</span><span>Nodes / elements</span><span>'+MANIFEST.mesh.nodes+' / '+MANIFEST.mesh.elements+'</span>';
|
|
115
|
+
requestAnimationFrame(draw);
|
|
116
|
+
</script>
|
|
117
|
+
</body>
|
|
118
|
+
</html>`;
|
|
119
|
+
}
|
|
120
|
+
//# sourceMappingURL=webgl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webgl.js","sourceRoot":"","sources":["../../src/fem/webgl.ts"],"names":[],"mappings":"AAEA,SAAS,UAAU,CAAC,KAAa;IAC/B,OAAO,KAAK;SACT,UAAU,CAAC,GAAG,EAAE,OAAO,CAAC;SACxB,UAAU,CAAC,GAAG,EAAE,MAAM,CAAC;SACvB,UAAU,CAAC,GAAG,EAAE,MAAM,CAAC;SACvB,UAAU,CAAC,GAAG,EAAE,QAAQ,CAAC;SACzB,UAAU,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;AAC9B,CAAC;AAED,SAAS,QAAQ,CAAC,KAAc;IAC9B,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,UAAU,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,QAA2B;IAC5D,MAAM,IAAI,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAChC,MAAM,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzC,MAAM,MAAM,GAAG,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;IACxD,MAAM,WAAW,GAAG,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;QACzD,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC;sBAC9B,UAAU,CAAC,OAAO,CAAC,QAAQ,CAAC,aAAa,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;QACvG,CAAC,CAAC,+EAA+E,CAAC;IACpF,MAAM,cAAc,GAAG,QAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC;sBAC5C,UAAU,CAAC,UAAU,CAAC,SAAS,CAAC,cAAc,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,aAAa,UAAU,CAAC,UAAU,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACnO,MAAM,cAAc,GAAG,QAAQ,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEnG,OAAO;;;;;SAKA,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UA+BJ,KAAK;;;;;;;;;;gFAUiE,QAAQ,CAAC,UAAU,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,UAAU,CAAC,MAAM,CAAC,eAAe,QAAQ,CAAC,UAAU,CAAC,QAAQ,cAAc,QAAQ,CAAC,UAAU,CAAC,WAAW,wBAAwB,WAAW;;gDAExO,cAAc;gDACd,cAAc;;;;mBAI3C,IAAI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;QA0Cf,CAAC;AACT,CAAC"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/index.js
CHANGED
|
@@ -4,6 +4,8 @@ export * from './llm/index.js';
|
|
|
4
4
|
export { sanitizeUpstreamError } from './llm/util.js';
|
|
5
5
|
// Geotechnical computation engines
|
|
6
6
|
export * from './geo/index.js';
|
|
7
|
+
// Experimental finite-element previews
|
|
8
|
+
export * from './fem/index.js';
|
|
7
9
|
// Configuration
|
|
8
10
|
export * from './config/index.js';
|
|
9
11
|
export * from './meta/index.js';
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|