@geotechcli/core 0.4.106 → 0.4.108
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/fem/demo.d.ts.map +1 -1
- package/dist/fem/demo.js +4 -0
- package/dist/fem/demo.js.map +1 -1
- package/dist/fem/engineering-evidence.d.ts +65 -0
- package/dist/fem/engineering-evidence.d.ts.map +1 -1
- package/dist/fem/engineering-evidence.js +295 -15
- package/dist/fem/engineering-evidence.js.map +1 -1
- package/dist/fem/index.d.ts +3 -2
- package/dist/fem/index.d.ts.map +1 -1
- package/dist/fem/index.js +2 -1
- package/dist/fem/index.js.map +1 -1
- package/dist/fem/nonlinear-column-solver.d.ts.map +1 -1
- package/dist/fem/nonlinear-column-solver.js +137 -6
- package/dist/fem/nonlinear-column-solver.js.map +1 -1
- package/dist/fem/plane-strain-assembly.d.ts +69 -3
- package/dist/fem/plane-strain-assembly.d.ts.map +1 -1
- package/dist/fem/plane-strain-assembly.js +267 -21
- package/dist/fem/plane-strain-assembly.js.map +1 -1
- package/dist/fem/production-readiness.d.ts.map +1 -1
- package/dist/fem/production-readiness.js +8 -2
- package/dist/fem/production-readiness.js.map +1 -1
- package/dist/fem/routing.js +4 -4
- package/dist/fem/routing.js.map +1 -1
- package/dist/fem/sparse-linear-algebra.d.ts +47 -0
- package/dist/fem/sparse-linear-algebra.d.ts.map +1 -0
- package/dist/fem/sparse-linear-algebra.js +290 -0
- package/dist/fem/sparse-linear-algebra.js.map +1 -0
- package/dist/fem/types.d.ts +49 -0
- package/dist/fem/types.d.ts.map +1 -1
- package/dist/fem/validation.d.ts.map +1 -1
- package/dist/fem/validation.js +166 -2
- package/dist/fem/validation.js.map +1 -1
- package/dist/meta/metadata.json +1 -1
- package/package.json +1 -1
package/dist/fem/routing.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"routing.js","sourceRoot":"","sources":["../../src/fem/routing.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"routing.js","sourceRoot":"","sources":["../../src/fem/routing.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
export interface FemSparseTriplet {
|
|
2
|
+
row: number;
|
|
3
|
+
col: number;
|
|
4
|
+
value: number;
|
|
5
|
+
}
|
|
6
|
+
export interface FemSparseCsrMatrix {
|
|
7
|
+
schemaVersion: 'fem-sparse-csr-matrix.v1';
|
|
8
|
+
rowCount: number;
|
|
9
|
+
colCount: number;
|
|
10
|
+
rowPointers: number[];
|
|
11
|
+
columnIndices: number[];
|
|
12
|
+
values: number[];
|
|
13
|
+
nonzeroCount: number;
|
|
14
|
+
duplicateTripletCount: number;
|
|
15
|
+
droppedEntryCount: number;
|
|
16
|
+
}
|
|
17
|
+
export interface FemSparseCsrBuildInput {
|
|
18
|
+
rowCount: number;
|
|
19
|
+
colCount: number;
|
|
20
|
+
triplets: readonly FemSparseTriplet[];
|
|
21
|
+
dropTolerance?: number;
|
|
22
|
+
}
|
|
23
|
+
export interface FemCsrConjugateGradientOptions {
|
|
24
|
+
tolerance?: number;
|
|
25
|
+
maxIterations?: number;
|
|
26
|
+
initialGuess?: readonly number[];
|
|
27
|
+
preconditioner?: 'jacobi' | 'none';
|
|
28
|
+
}
|
|
29
|
+
export interface FemCsrConjugateGradientResult {
|
|
30
|
+
schemaVersion: 'fem-csr-conjugate-gradient-result.v1';
|
|
31
|
+
solution: number[];
|
|
32
|
+
converged: boolean;
|
|
33
|
+
iterations: number;
|
|
34
|
+
tolerance: number;
|
|
35
|
+
maxIterations: number;
|
|
36
|
+
initialResidualNorm: number;
|
|
37
|
+
finalResidualNorm: number;
|
|
38
|
+
residualNormRatio: number;
|
|
39
|
+
rhsNorm: number;
|
|
40
|
+
correctionNorm: number;
|
|
41
|
+
preconditioner: 'jacobi' | 'none';
|
|
42
|
+
failureReason?: 'zero_or_negative_preconditioner_diagonal' | 'singular_or_indefinite_matrix' | 'max_iterations';
|
|
43
|
+
}
|
|
44
|
+
export declare function buildCsrFromTriplets(input: FemSparseCsrBuildInput): FemSparseCsrMatrix;
|
|
45
|
+
export declare function csrMatVec(matrix: FemSparseCsrMatrix, vector: readonly number[]): number[];
|
|
46
|
+
export declare function solveCsrConjugateGradient(matrix: FemSparseCsrMatrix, rhs: readonly number[], options?: FemCsrConjugateGradientOptions): FemCsrConjugateGradientResult;
|
|
47
|
+
//# sourceMappingURL=sparse-linear-algebra.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sparse-linear-algebra.d.ts","sourceRoot":"","sources":["../../src/fem/sparse-linear-algebra.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB;IAC/B,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,kBAAkB;IACjC,aAAa,EAAE,0BAA0B,CAAC;IAC1C,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,aAAa,EAAE,MAAM,EAAE,CAAC;IACxB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,iBAAiB,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,sBAAsB;IACrC,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,SAAS,gBAAgB,EAAE,CAAC;IACtC,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,8BAA8B;IAC7C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,CAAC,EAAE,SAAS,MAAM,EAAE,CAAC;IACjC,cAAc,CAAC,EAAE,QAAQ,GAAG,MAAM,CAAC;CACpC;AAED,MAAM,WAAW,6BAA6B;IAC5C,aAAa,EAAE,sCAAsC,CAAC;IACtD,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,OAAO,EAAE,MAAM,CAAC;IAChB,cAAc,EAAE,MAAM,CAAC;IACvB,cAAc,EAAE,QAAQ,GAAG,MAAM,CAAC;IAClC,aAAa,CAAC,EAAE,0CAA0C,GAAG,+BAA+B,GAAG,gBAAgB,CAAC;CACjH;AA0BD,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,sBAAsB,GAAG,kBAAkB,CAsDtF;AAED,wBAAgB,SAAS,CAAC,MAAM,EAAE,kBAAkB,EAAE,MAAM,EAAE,SAAS,MAAM,EAAE,GAAG,MAAM,EAAE,CAiCzF;AAmBD,wBAAgB,yBAAyB,CACvC,MAAM,EAAE,kBAAkB,EAC1B,GAAG,EAAE,SAAS,MAAM,EAAE,EACtB,OAAO,GAAE,8BAAmC,GAC3C,6BAA6B,CAuK/B"}
|
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
function assertFinite(value, label) {
|
|
2
|
+
if (!Number.isFinite(value))
|
|
3
|
+
throw new Error(`${label} must be finite.`);
|
|
4
|
+
}
|
|
5
|
+
function assertNonNegativeInteger(value, label) {
|
|
6
|
+
if (!Number.isInteger(value) || value < 0) {
|
|
7
|
+
throw new Error(`${label} must be a non-negative integer.`);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
function assertPositiveInteger(value, label) {
|
|
11
|
+
if (!Number.isInteger(value) || value < 1) {
|
|
12
|
+
throw new Error(`${label} must be a positive integer.`);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
function vectorNorm(values) {
|
|
16
|
+
return Math.sqrt(values.reduce((sum, value) => sum + value * value, 0));
|
|
17
|
+
}
|
|
18
|
+
function dot(a, b) {
|
|
19
|
+
return a.reduce((sum, value, index) => sum + value * b[index], 0);
|
|
20
|
+
}
|
|
21
|
+
export function buildCsrFromTriplets(input) {
|
|
22
|
+
assertPositiveInteger(input.rowCount, 'rowCount');
|
|
23
|
+
assertPositiveInteger(input.colCount, 'colCount');
|
|
24
|
+
if (!Array.isArray(input.triplets))
|
|
25
|
+
throw new Error('triplets must be an array.');
|
|
26
|
+
const dropTolerance = input.dropTolerance ?? 0;
|
|
27
|
+
if (!Number.isFinite(dropTolerance) || dropTolerance < 0) {
|
|
28
|
+
throw new Error('dropTolerance must be a finite non-negative number.');
|
|
29
|
+
}
|
|
30
|
+
const rows = Array.from({ length: input.rowCount }, () => new Map());
|
|
31
|
+
let duplicateTripletCount = 0;
|
|
32
|
+
let droppedEntryCount = 0;
|
|
33
|
+
for (const [index, triplet] of input.triplets.entries()) {
|
|
34
|
+
assertNonNegativeInteger(triplet.row, `triplets.${index}.row`);
|
|
35
|
+
assertNonNegativeInteger(triplet.col, `triplets.${index}.col`);
|
|
36
|
+
if (triplet.row >= input.rowCount)
|
|
37
|
+
throw new Error(`triplets.${index}.row is outside rowCount.`);
|
|
38
|
+
if (triplet.col >= input.colCount)
|
|
39
|
+
throw new Error(`triplets.${index}.col is outside colCount.`);
|
|
40
|
+
assertFinite(triplet.value, `triplets.${index}.value`);
|
|
41
|
+
if (Math.abs(triplet.value) <= dropTolerance) {
|
|
42
|
+
droppedEntryCount += 1;
|
|
43
|
+
continue;
|
|
44
|
+
}
|
|
45
|
+
const row = rows[triplet.row];
|
|
46
|
+
const existing = row.get(triplet.col);
|
|
47
|
+
if (existing != null)
|
|
48
|
+
duplicateTripletCount += 1;
|
|
49
|
+
row.set(triplet.col, (existing ?? 0) + triplet.value);
|
|
50
|
+
}
|
|
51
|
+
const rowPointers = new Array(input.rowCount + 1).fill(0);
|
|
52
|
+
const columnIndices = [];
|
|
53
|
+
const values = [];
|
|
54
|
+
for (let rowIndex = 0; rowIndex < input.rowCount; rowIndex += 1) {
|
|
55
|
+
const rowEntries = Array.from(rows[rowIndex].entries())
|
|
56
|
+
.filter(([, value]) => Math.abs(value) > dropTolerance)
|
|
57
|
+
.sort(([left], [right]) => left - right);
|
|
58
|
+
for (const [col, value] of rowEntries) {
|
|
59
|
+
columnIndices.push(col);
|
|
60
|
+
values.push(value);
|
|
61
|
+
}
|
|
62
|
+
rowPointers[rowIndex + 1] = columnIndices.length;
|
|
63
|
+
}
|
|
64
|
+
return {
|
|
65
|
+
schemaVersion: 'fem-sparse-csr-matrix.v1',
|
|
66
|
+
rowCount: input.rowCount,
|
|
67
|
+
colCount: input.colCount,
|
|
68
|
+
rowPointers,
|
|
69
|
+
columnIndices,
|
|
70
|
+
values,
|
|
71
|
+
nonzeroCount: values.length,
|
|
72
|
+
duplicateTripletCount,
|
|
73
|
+
droppedEntryCount,
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
export function csrMatVec(matrix, vector) {
|
|
77
|
+
if (matrix.schemaVersion !== 'fem-sparse-csr-matrix.v1') {
|
|
78
|
+
throw new Error('matrix.schemaVersion must be fem-sparse-csr-matrix.v1.');
|
|
79
|
+
}
|
|
80
|
+
if (vector.length !== matrix.colCount) {
|
|
81
|
+
throw new Error(`CSR vector length ${vector.length} does not match matrix colCount ${matrix.colCount}.`);
|
|
82
|
+
}
|
|
83
|
+
if (matrix.rowPointers.length !== matrix.rowCount + 1) {
|
|
84
|
+
throw new Error('CSR rowPointers length is inconsistent with rowCount.');
|
|
85
|
+
}
|
|
86
|
+
if (matrix.columnIndices.length !== matrix.values.length) {
|
|
87
|
+
throw new Error('CSR columnIndices length must match values length.');
|
|
88
|
+
}
|
|
89
|
+
const output = new Array(matrix.rowCount).fill(0);
|
|
90
|
+
for (let row = 0; row < matrix.rowCount; row += 1) {
|
|
91
|
+
const start = matrix.rowPointers[row];
|
|
92
|
+
const end = matrix.rowPointers[row + 1];
|
|
93
|
+
if (start > end || start < 0 || end > matrix.values.length) {
|
|
94
|
+
throw new Error(`CSR rowPointers are invalid at row ${row}.`);
|
|
95
|
+
}
|
|
96
|
+
let sum = 0;
|
|
97
|
+
for (let index = start; index < end; index += 1) {
|
|
98
|
+
const col = matrix.columnIndices[index];
|
|
99
|
+
if (!Number.isInteger(col) || col < 0 || col >= matrix.colCount) {
|
|
100
|
+
throw new Error(`CSR column index ${index} is outside matrix colCount.`);
|
|
101
|
+
}
|
|
102
|
+
const value = matrix.values[index];
|
|
103
|
+
assertFinite(value, `matrix.values.${index}`);
|
|
104
|
+
sum += value * vector[col];
|
|
105
|
+
}
|
|
106
|
+
output[row] = sum;
|
|
107
|
+
}
|
|
108
|
+
return output;
|
|
109
|
+
}
|
|
110
|
+
function residual(matrix, x, rhs) {
|
|
111
|
+
const ax = csrMatVec(matrix, x);
|
|
112
|
+
return rhs.map((value, index) => value - ax[index]);
|
|
113
|
+
}
|
|
114
|
+
function diagonal(matrix) {
|
|
115
|
+
const diag = new Array(matrix.rowCount).fill(0);
|
|
116
|
+
for (let row = 0; row < matrix.rowCount; row += 1) {
|
|
117
|
+
for (let index = matrix.rowPointers[row]; index < matrix.rowPointers[row + 1]; index += 1) {
|
|
118
|
+
if (matrix.columnIndices[index] === row) {
|
|
119
|
+
diag[row] += matrix.values[index];
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return diag;
|
|
124
|
+
}
|
|
125
|
+
export function solveCsrConjugateGradient(matrix, rhs, options = {}) {
|
|
126
|
+
if (matrix.rowCount !== matrix.colCount) {
|
|
127
|
+
throw new Error('Conjugate Gradient requires a square CSR matrix.');
|
|
128
|
+
}
|
|
129
|
+
if (rhs.length !== matrix.rowCount) {
|
|
130
|
+
throw new Error(`CSR rhs length ${rhs.length} does not match matrix rowCount ${matrix.rowCount}.`);
|
|
131
|
+
}
|
|
132
|
+
const tolerance = options.tolerance ?? 1e-10;
|
|
133
|
+
if (!Number.isFinite(tolerance) || tolerance <= 0) {
|
|
134
|
+
throw new Error('tolerance must be a finite positive number.');
|
|
135
|
+
}
|
|
136
|
+
const maxIterations = options.maxIterations ?? Math.max(100, matrix.rowCount * 10);
|
|
137
|
+
assertPositiveInteger(maxIterations, 'maxIterations');
|
|
138
|
+
const preconditioner = options.preconditioner ?? 'jacobi';
|
|
139
|
+
if (preconditioner !== 'jacobi' && preconditioner !== 'none') {
|
|
140
|
+
throw new Error('preconditioner must be jacobi or none.');
|
|
141
|
+
}
|
|
142
|
+
const x = options.initialGuess != null ? [...options.initialGuess] : new Array(rhs.length).fill(0);
|
|
143
|
+
if (x.length !== rhs.length) {
|
|
144
|
+
throw new Error(`initialGuess length ${x.length} does not match rhs length ${rhs.length}.`);
|
|
145
|
+
}
|
|
146
|
+
for (const [index, value] of rhs.entries())
|
|
147
|
+
assertFinite(value, `rhs.${index}`);
|
|
148
|
+
for (const [index, value] of x.entries())
|
|
149
|
+
assertFinite(value, `initialGuess.${index}`);
|
|
150
|
+
const rhsNorm = Math.max(vectorNorm(rhs), 1);
|
|
151
|
+
let r = residual(matrix, x, rhs);
|
|
152
|
+
const initialResidualNorm = vectorNorm(r);
|
|
153
|
+
if (initialResidualNorm / rhsNorm <= tolerance) {
|
|
154
|
+
return {
|
|
155
|
+
schemaVersion: 'fem-csr-conjugate-gradient-result.v1',
|
|
156
|
+
solution: x,
|
|
157
|
+
converged: true,
|
|
158
|
+
iterations: 0,
|
|
159
|
+
tolerance,
|
|
160
|
+
maxIterations,
|
|
161
|
+
initialResidualNorm,
|
|
162
|
+
finalResidualNorm: initialResidualNorm,
|
|
163
|
+
residualNormRatio: initialResidualNorm / rhsNorm,
|
|
164
|
+
rhsNorm,
|
|
165
|
+
correctionNorm: vectorNorm(x),
|
|
166
|
+
preconditioner,
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
const diag = preconditioner === 'jacobi' ? diagonal(matrix) : new Array(matrix.rowCount).fill(1);
|
|
170
|
+
if (preconditioner === 'jacobi' && diag.some((value) => !Number.isFinite(value) || value <= 0)) {
|
|
171
|
+
return {
|
|
172
|
+
schemaVersion: 'fem-csr-conjugate-gradient-result.v1',
|
|
173
|
+
solution: x,
|
|
174
|
+
converged: false,
|
|
175
|
+
iterations: 0,
|
|
176
|
+
tolerance,
|
|
177
|
+
maxIterations,
|
|
178
|
+
initialResidualNorm,
|
|
179
|
+
finalResidualNorm: initialResidualNorm,
|
|
180
|
+
residualNormRatio: initialResidualNorm / rhsNorm,
|
|
181
|
+
rhsNorm,
|
|
182
|
+
correctionNorm: vectorNorm(x),
|
|
183
|
+
preconditioner,
|
|
184
|
+
failureReason: 'zero_or_negative_preconditioner_diagonal',
|
|
185
|
+
};
|
|
186
|
+
}
|
|
187
|
+
let z = r.map((value, index) => value / diag[index]);
|
|
188
|
+
let p = [...z];
|
|
189
|
+
let rz = dot(r, z);
|
|
190
|
+
if (!Number.isFinite(rz) || rz <= 0) {
|
|
191
|
+
return {
|
|
192
|
+
schemaVersion: 'fem-csr-conjugate-gradient-result.v1',
|
|
193
|
+
solution: x,
|
|
194
|
+
converged: false,
|
|
195
|
+
iterations: 0,
|
|
196
|
+
tolerance,
|
|
197
|
+
maxIterations,
|
|
198
|
+
initialResidualNorm,
|
|
199
|
+
finalResidualNorm: initialResidualNorm,
|
|
200
|
+
residualNormRatio: initialResidualNorm / rhsNorm,
|
|
201
|
+
rhsNorm,
|
|
202
|
+
correctionNorm: vectorNorm(x),
|
|
203
|
+
preconditioner,
|
|
204
|
+
failureReason: 'singular_or_indefinite_matrix',
|
|
205
|
+
};
|
|
206
|
+
}
|
|
207
|
+
for (let iteration = 1; iteration <= maxIterations; iteration += 1) {
|
|
208
|
+
const ap = csrMatVec(matrix, p);
|
|
209
|
+
const denominator = dot(p, ap);
|
|
210
|
+
if (!Number.isFinite(denominator) || denominator <= 0) {
|
|
211
|
+
const finalResidualNorm = vectorNorm(r);
|
|
212
|
+
return {
|
|
213
|
+
schemaVersion: 'fem-csr-conjugate-gradient-result.v1',
|
|
214
|
+
solution: x,
|
|
215
|
+
converged: false,
|
|
216
|
+
iterations: iteration - 1,
|
|
217
|
+
tolerance,
|
|
218
|
+
maxIterations,
|
|
219
|
+
initialResidualNorm,
|
|
220
|
+
finalResidualNorm,
|
|
221
|
+
residualNormRatio: finalResidualNorm / rhsNorm,
|
|
222
|
+
rhsNorm,
|
|
223
|
+
correctionNorm: vectorNorm(x),
|
|
224
|
+
preconditioner,
|
|
225
|
+
failureReason: 'singular_or_indefinite_matrix',
|
|
226
|
+
};
|
|
227
|
+
}
|
|
228
|
+
const alpha = rz / denominator;
|
|
229
|
+
for (let index = 0; index < x.length; index += 1) {
|
|
230
|
+
x[index] += alpha * p[index];
|
|
231
|
+
r[index] -= alpha * ap[index];
|
|
232
|
+
}
|
|
233
|
+
const finalResidualNorm = vectorNorm(r);
|
|
234
|
+
if (finalResidualNorm / rhsNorm <= tolerance) {
|
|
235
|
+
return {
|
|
236
|
+
schemaVersion: 'fem-csr-conjugate-gradient-result.v1',
|
|
237
|
+
solution: x,
|
|
238
|
+
converged: true,
|
|
239
|
+
iterations: iteration,
|
|
240
|
+
tolerance,
|
|
241
|
+
maxIterations,
|
|
242
|
+
initialResidualNorm,
|
|
243
|
+
finalResidualNorm,
|
|
244
|
+
residualNormRatio: finalResidualNorm / rhsNorm,
|
|
245
|
+
rhsNorm,
|
|
246
|
+
correctionNorm: vectorNorm(x),
|
|
247
|
+
preconditioner,
|
|
248
|
+
};
|
|
249
|
+
}
|
|
250
|
+
z = r.map((value, index) => value / diag[index]);
|
|
251
|
+
const nextRz = dot(r, z);
|
|
252
|
+
if (!Number.isFinite(nextRz) || nextRz <= 0) {
|
|
253
|
+
return {
|
|
254
|
+
schemaVersion: 'fem-csr-conjugate-gradient-result.v1',
|
|
255
|
+
solution: x,
|
|
256
|
+
converged: false,
|
|
257
|
+
iterations: iteration,
|
|
258
|
+
tolerance,
|
|
259
|
+
maxIterations,
|
|
260
|
+
initialResidualNorm,
|
|
261
|
+
finalResidualNorm,
|
|
262
|
+
residualNormRatio: finalResidualNorm / rhsNorm,
|
|
263
|
+
rhsNorm,
|
|
264
|
+
correctionNorm: vectorNorm(x),
|
|
265
|
+
preconditioner,
|
|
266
|
+
failureReason: 'singular_or_indefinite_matrix',
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
const beta = nextRz / rz;
|
|
270
|
+
p = z.map((value, index) => value + beta * p[index]);
|
|
271
|
+
rz = nextRz;
|
|
272
|
+
}
|
|
273
|
+
const finalResidualNorm = vectorNorm(r);
|
|
274
|
+
return {
|
|
275
|
+
schemaVersion: 'fem-csr-conjugate-gradient-result.v1',
|
|
276
|
+
solution: x,
|
|
277
|
+
converged: false,
|
|
278
|
+
iterations: maxIterations,
|
|
279
|
+
tolerance,
|
|
280
|
+
maxIterations,
|
|
281
|
+
initialResidualNorm,
|
|
282
|
+
finalResidualNorm,
|
|
283
|
+
residualNormRatio: finalResidualNorm / rhsNorm,
|
|
284
|
+
rhsNorm,
|
|
285
|
+
correctionNorm: vectorNorm(x),
|
|
286
|
+
preconditioner,
|
|
287
|
+
failureReason: 'max_iterations',
|
|
288
|
+
};
|
|
289
|
+
}
|
|
290
|
+
//# sourceMappingURL=sparse-linear-algebra.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sparse-linear-algebra.js","sourceRoot":"","sources":["../../src/fem/sparse-linear-algebra.ts"],"names":[],"mappings":"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"}
|
package/dist/fem/types.d.ts
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import type { FemConvergencePolicy } from './engineering-evidence.js';
|
|
1
2
|
export type FemObjective = 'foundation_settlement' | 'excavation_deformation' | 'tunnel_volume_loss_settlement' | 'staged_settlement_consolidation' | 'seepage_groundwater_coupling';
|
|
2
3
|
export type FemAnalysisType = 'static_3d_small_strain' | 'static_3d_staged_elastic' | 'empirical_3d_settlement_surface' | 'time_dependent_1d_consolidation' | 'time_dependent_2d_biot_consolidation';
|
|
3
4
|
export type FemAssumptionConfidence = 'measured' | 'inferred' | 'review';
|
|
@@ -254,6 +255,10 @@ export interface FemResultEnvelope {
|
|
|
254
255
|
maxFreePorePressureResidualM3PerS?: number;
|
|
255
256
|
freePorePressureResidualL1M3PerS?: number;
|
|
256
257
|
prescribedPorePressureResidualL1M3PerS?: number;
|
|
258
|
+
averagePorePressureKpa?: number;
|
|
259
|
+
averageFreePorePressureKpa?: number;
|
|
260
|
+
porePressureDissipationRatio?: number;
|
|
261
|
+
maxPorePressureChangeRateKpaPerS?: number;
|
|
257
262
|
coupledUnknownCount?: number;
|
|
258
263
|
displacementDofCount?: number;
|
|
259
264
|
porePressureDofCount?: number;
|
|
@@ -274,6 +279,49 @@ export interface FemResultPressureAudit {
|
|
|
274
279
|
couplingRateSumM3PerS: number;
|
|
275
280
|
darcyFlowRateSumM3PerS: number;
|
|
276
281
|
}
|
|
282
|
+
export type FemSolverConvergenceStatus = 'converged' | 'nonconverged';
|
|
283
|
+
export type FemSolverTerminationReason = 'converged' | 'max_iterations' | 'force_residual_exceeded' | 'yield_residual_exceeded' | 'material_nonconvergence' | 'consolidation_nonconvergence';
|
|
284
|
+
export interface FemSolverResidualHistoryEntry {
|
|
285
|
+
iteration: number;
|
|
286
|
+
residualRatio: number;
|
|
287
|
+
forceBalanceTolerance: number;
|
|
288
|
+
yieldResidualRatio?: number;
|
|
289
|
+
residualTolerance?: number;
|
|
290
|
+
maxFreeResidualKn?: number;
|
|
291
|
+
axialStrain?: number;
|
|
292
|
+
verticalStressKpa?: number;
|
|
293
|
+
converged: boolean;
|
|
294
|
+
}
|
|
295
|
+
export interface FemSolverLoadStepConvergence {
|
|
296
|
+
step: number;
|
|
297
|
+
stageId?: string;
|
|
298
|
+
stageLabel?: string;
|
|
299
|
+
loadFactor?: number;
|
|
300
|
+
cumulativeLoadKpa?: number;
|
|
301
|
+
iterations: number;
|
|
302
|
+
residualRatio: number;
|
|
303
|
+
forceBalanceTolerance: number;
|
|
304
|
+
yieldResidualRatio?: number;
|
|
305
|
+
residualTolerance?: number;
|
|
306
|
+
converged: boolean;
|
|
307
|
+
terminationReason: FemSolverTerminationReason;
|
|
308
|
+
residualHistory: FemSolverResidualHistoryEntry[];
|
|
309
|
+
}
|
|
310
|
+
export interface FemSolverConvergenceFailure {
|
|
311
|
+
step: number;
|
|
312
|
+
stageId?: string;
|
|
313
|
+
terminationReason: FemSolverTerminationReason;
|
|
314
|
+
residualRatio: number;
|
|
315
|
+
yieldResidualRatio?: number;
|
|
316
|
+
message: string;
|
|
317
|
+
}
|
|
318
|
+
export interface FemSolverConvergenceReport {
|
|
319
|
+
schemaVersion: 'fem-solver-convergence-report.v1';
|
|
320
|
+
status: FemSolverConvergenceStatus;
|
|
321
|
+
policy: FemConvergencePolicy;
|
|
322
|
+
loadSteps: FemSolverLoadStepConvergence[];
|
|
323
|
+
failure?: FemSolverConvergenceFailure;
|
|
324
|
+
}
|
|
277
325
|
export interface FemResultManifest {
|
|
278
326
|
schemaVersion: 'fem-result-manifest.v0';
|
|
279
327
|
caseId: string;
|
|
@@ -298,6 +346,7 @@ export interface FemResultManifest {
|
|
|
298
346
|
};
|
|
299
347
|
envelope: FemResultEnvelope;
|
|
300
348
|
pressureAudit?: FemResultPressureAudit;
|
|
349
|
+
solverConvergence?: FemSolverConvergenceReport;
|
|
301
350
|
visualization: FemVisualizationMesh;
|
|
302
351
|
resultFields?: FemResultField[];
|
|
303
352
|
steps?: FemResultStep[];
|