agentdb 2.0.0-alpha.2 → 2.0.0-alpha.2.2
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/agentdb.min.js +4 -4
- package/dist/simulation/cli.js +0 -0
- package/dist/src/cli/agentdb-cli.d.ts.map +1 -1
- package/dist/src/cli/agentdb-cli.js +78 -0
- package/dist/src/cli/agentdb-cli.js.map +1 -1
- package/dist/src/cli/commands/init.js +3 -3
- package/dist/src/cli/commands/init.js.map +1 -1
- package/package.json +3 -3
- package/src/cli/agentdb-cli.ts +78 -0
- package/src/cli/commands/init.ts +3 -3
- package/dist/agentdb-advanced.js +0 -2110
- package/dist/agentdb-advanced.min.js +0 -1
- package/dist/backends/GraphBackend.d.ts +0 -196
- package/dist/backends/GraphBackend.d.ts.map +0 -1
- package/dist/backends/GraphBackend.js +0 -33
- package/dist/backends/GraphBackend.js.map +0 -1
- package/dist/backends/LearningBackend.d.ts +0 -148
- package/dist/backends/LearningBackend.d.ts.map +0 -1
- package/dist/backends/LearningBackend.js +0 -27
- package/dist/backends/LearningBackend.js.map +0 -1
- package/dist/backends/VectorBackend.d.ts +0 -119
- package/dist/backends/VectorBackend.d.ts.map +0 -1
- package/dist/backends/VectorBackend.js +0 -14
- package/dist/backends/VectorBackend.js.map +0 -1
- package/dist/backends/detector.d.ts +0 -81
- package/dist/backends/detector.d.ts.map +0 -1
- package/dist/backends/detector.js +0 -192
- package/dist/backends/detector.js.map +0 -1
- package/dist/backends/factory.d.ts +0 -50
- package/dist/backends/factory.d.ts.map +0 -1
- package/dist/backends/factory.js +0 -161
- package/dist/backends/factory.js.map +0 -1
- package/dist/backends/graph/GraphDatabaseAdapter.d.ts +0 -139
- package/dist/backends/graph/GraphDatabaseAdapter.d.ts.map +0 -1
- package/dist/backends/graph/GraphDatabaseAdapter.js +0 -194
- package/dist/backends/graph/GraphDatabaseAdapter.js.map +0 -1
- package/dist/backends/hnswlib/HNSWLibBackend.d.ts +0 -92
- package/dist/backends/hnswlib/HNSWLibBackend.d.ts.map +0 -1
- package/dist/backends/hnswlib/HNSWLibBackend.js +0 -316
- package/dist/backends/hnswlib/HNSWLibBackend.js.map +0 -1
- package/dist/backends/hnswlib/index.d.ts +0 -7
- package/dist/backends/hnswlib/index.d.ts.map +0 -1
- package/dist/backends/hnswlib/index.js +0 -7
- package/dist/backends/hnswlib/index.js.map +0 -1
- package/dist/backends/index.d.ts +0 -14
- package/dist/backends/index.d.ts.map +0 -1
- package/dist/backends/index.js +0 -13
- package/dist/backends/index.js.map +0 -1
- package/dist/backends/ruvector/RuVectorBackend.d.ts +0 -75
- package/dist/backends/ruvector/RuVectorBackend.d.ts.map +0 -1
- package/dist/backends/ruvector/RuVectorBackend.js +0 -198
- package/dist/backends/ruvector/RuVectorBackend.js.map +0 -1
- package/dist/backends/ruvector/RuVectorLearning.d.ts +0 -104
- package/dist/backends/ruvector/RuVectorLearning.d.ts.map +0 -1
- package/dist/backends/ruvector/RuVectorLearning.js +0 -177
- package/dist/backends/ruvector/RuVectorLearning.js.map +0 -1
- package/dist/backends/ruvector/index.d.ts +0 -9
- package/dist/backends/ruvector/index.d.ts.map +0 -1
- package/dist/backends/ruvector/index.js +0 -8
- package/dist/backends/ruvector/index.js.map +0 -1
- package/dist/benchmarks/wasm-vector-benchmark.d.ts +0 -10
- package/dist/benchmarks/wasm-vector-benchmark.d.ts.map +0 -1
- package/dist/benchmarks/wasm-vector-benchmark.js +0 -196
- package/dist/benchmarks/wasm-vector-benchmark.js.map +0 -1
- package/dist/browser/AdvancedFeatures.d.ts +0 -144
- package/dist/browser/AdvancedFeatures.d.ts.map +0 -1
- package/dist/browser/AdvancedFeatures.js +0 -430
- package/dist/browser/AdvancedFeatures.js.map +0 -1
- package/dist/browser/HNSWIndex.d.ts +0 -117
- package/dist/browser/HNSWIndex.d.ts.map +0 -1
- package/dist/browser/HNSWIndex.js +0 -402
- package/dist/browser/HNSWIndex.js.map +0 -1
- package/dist/browser/ProductQuantization.d.ts +0 -107
- package/dist/browser/ProductQuantization.d.ts.map +0 -1
- package/dist/browser/ProductQuantization.js +0 -337
- package/dist/browser/ProductQuantization.js.map +0 -1
- package/dist/browser/browser/AdvancedFeatures.d.ts +0 -144
- package/dist/browser/browser/AdvancedFeatures.d.ts.map +0 -1
- package/dist/browser/browser/AdvancedFeatures.js +0 -427
- package/dist/browser/browser/HNSWIndex.d.ts +0 -117
- package/dist/browser/browser/HNSWIndex.d.ts.map +0 -1
- package/dist/browser/browser/HNSWIndex.js +0 -402
- package/dist/browser/browser/ProductQuantization.d.ts +0 -107
- package/dist/browser/browser/ProductQuantization.d.ts.map +0 -1
- package/dist/browser/browser/ProductQuantization.js +0 -348
- package/dist/browser/browser/index.d.ts +0 -223
- package/dist/browser/browser/index.d.ts.map +0 -1
- package/dist/browser/browser/index.js +0 -233
- package/dist/browser/index.d.ts +0 -223
- package/dist/browser/index.d.ts.map +0 -1
- package/dist/browser/index.js +0 -225
- package/dist/browser/index.js.map +0 -1
- package/dist/cli/agentdb-cli.d.ts +0 -154
- package/dist/cli/agentdb-cli.d.ts.map +0 -1
- package/dist/cli/agentdb-cli.js +0 -2273
- package/dist/cli/agentdb-cli.js.map +0 -1
- package/dist/cli/agentdb.db +0 -0
- package/dist/cli/commands/init.d.ts +0 -12
- package/dist/cli/commands/init.d.ts.map +0 -1
- package/dist/cli/commands/init.js +0 -115
- package/dist/cli/commands/init.js.map +0 -1
- package/dist/cli/commands/install-embeddings.d.ts +0 -10
- package/dist/cli/commands/install-embeddings.d.ts.map +0 -1
- package/dist/cli/commands/install-embeddings.js +0 -68
- package/dist/cli/commands/install-embeddings.js.map +0 -1
- package/dist/cli/commands/migrate.d.ts +0 -15
- package/dist/cli/commands/migrate.d.ts.map +0 -1
- package/dist/cli/commands/migrate.js +0 -425
- package/dist/cli/commands/migrate.js.map +0 -1
- package/dist/cli/commands/status.d.ts +0 -10
- package/dist/cli/commands/status.d.ts.map +0 -1
- package/dist/cli/commands/status.js +0 -129
- package/dist/cli/commands/status.js.map +0 -1
- package/dist/controllers/CausalMemoryGraph.d.ts +0 -126
- package/dist/controllers/CausalMemoryGraph.d.ts.map +0 -1
- package/dist/controllers/CausalMemoryGraph.js +0 -323
- package/dist/controllers/CausalMemoryGraph.js.map +0 -1
- package/dist/controllers/CausalRecall.d.ts +0 -139
- package/dist/controllers/CausalRecall.d.ts.map +0 -1
- package/dist/controllers/CausalRecall.js +0 -356
- package/dist/controllers/CausalRecall.js.map +0 -1
- package/dist/controllers/ContextSynthesizer.d.ts +0 -65
- package/dist/controllers/ContextSynthesizer.d.ts.map +0 -1
- package/dist/controllers/ContextSynthesizer.js +0 -208
- package/dist/controllers/ContextSynthesizer.js.map +0 -1
- package/dist/controllers/EmbeddingService.d.ts +0 -37
- package/dist/controllers/EmbeddingService.d.ts.map +0 -1
- package/dist/controllers/EmbeddingService.js +0 -136
- package/dist/controllers/EmbeddingService.js.map +0 -1
- package/dist/controllers/EnhancedEmbeddingService.d.ts +0 -50
- package/dist/controllers/EnhancedEmbeddingService.d.ts.map +0 -1
- package/dist/controllers/EnhancedEmbeddingService.js +0 -119
- package/dist/controllers/EnhancedEmbeddingService.js.map +0 -1
- package/dist/controllers/ExplainableRecall.d.ts +0 -163
- package/dist/controllers/ExplainableRecall.d.ts.map +0 -1
- package/dist/controllers/ExplainableRecall.js +0 -485
- package/dist/controllers/ExplainableRecall.js.map +0 -1
- package/dist/controllers/HNSWIndex.d.ts +0 -128
- package/dist/controllers/HNSWIndex.d.ts.map +0 -1
- package/dist/controllers/HNSWIndex.js +0 -361
- package/dist/controllers/HNSWIndex.js.map +0 -1
- package/dist/controllers/LearningSystem.d.ts +0 -195
- package/dist/controllers/LearningSystem.d.ts.map +0 -1
- package/dist/controllers/LearningSystem.js +0 -929
- package/dist/controllers/LearningSystem.js.map +0 -1
- package/dist/controllers/MMRDiversityRanker.d.ts +0 -50
- package/dist/controllers/MMRDiversityRanker.d.ts.map +0 -1
- package/dist/controllers/MMRDiversityRanker.js +0 -130
- package/dist/controllers/MMRDiversityRanker.js.map +0 -1
- package/dist/controllers/MetadataFilter.d.ts +0 -70
- package/dist/controllers/MetadataFilter.d.ts.map +0 -1
- package/dist/controllers/MetadataFilter.js +0 -243
- package/dist/controllers/MetadataFilter.js.map +0 -1
- package/dist/controllers/NightlyLearner.d.ts +0 -114
- package/dist/controllers/NightlyLearner.d.ts.map +0 -1
- package/dist/controllers/NightlyLearner.js +0 -394
- package/dist/controllers/NightlyLearner.js.map +0 -1
- package/dist/controllers/QUICClient.d.ts +0 -109
- package/dist/controllers/QUICClient.d.ts.map +0 -1
- package/dist/controllers/QUICClient.js +0 -299
- package/dist/controllers/QUICClient.js.map +0 -1
- package/dist/controllers/QUICServer.d.ts +0 -121
- package/dist/controllers/QUICServer.d.ts.map +0 -1
- package/dist/controllers/QUICServer.js +0 -383
- package/dist/controllers/QUICServer.js.map +0 -1
- package/dist/controllers/ReasoningBank.d.ts +0 -196
- package/dist/controllers/ReasoningBank.d.ts.map +0 -1
- package/dist/controllers/ReasoningBank.js +0 -494
- package/dist/controllers/ReasoningBank.js.map +0 -1
- package/dist/controllers/ReflexionMemory.d.ts +0 -125
- package/dist/controllers/ReflexionMemory.d.ts.map +0 -1
- package/dist/controllers/ReflexionMemory.js +0 -521
- package/dist/controllers/ReflexionMemory.js.map +0 -1
- package/dist/controllers/SkillLibrary.d.ts +0 -149
- package/dist/controllers/SkillLibrary.d.ts.map +0 -1
- package/dist/controllers/SkillLibrary.js +0 -547
- package/dist/controllers/SkillLibrary.js.map +0 -1
- package/dist/controllers/SyncCoordinator.d.ts +0 -120
- package/dist/controllers/SyncCoordinator.d.ts.map +0 -1
- package/dist/controllers/SyncCoordinator.js +0 -441
- package/dist/controllers/SyncCoordinator.js.map +0 -1
- package/dist/controllers/WASMVectorSearch.d.ts +0 -89
- package/dist/controllers/WASMVectorSearch.d.ts.map +0 -1
- package/dist/controllers/WASMVectorSearch.js +0 -234
- package/dist/controllers/WASMVectorSearch.js.map +0 -1
- package/dist/controllers/frontier-index.d.ts +0 -14
- package/dist/controllers/frontier-index.d.ts.map +0 -1
- package/dist/controllers/frontier-index.js +0 -10
- package/dist/controllers/frontier-index.js.map +0 -1
- package/dist/controllers/index.d.ts +0 -30
- package/dist/controllers/index.d.ts.map +0 -1
- package/dist/controllers/index.js +0 -18
- package/dist/controllers/index.js.map +0 -1
- package/dist/db-fallback.d.ts +0 -26
- package/dist/db-fallback.d.ts.map +0 -1
- package/dist/db-fallback.js +0 -264
- package/dist/db-fallback.js.map +0 -1
- package/dist/db-test.d.ts +0 -13
- package/dist/db-test.d.ts.map +0 -1
- package/dist/db-test.js +0 -55
- package/dist/db-test.js.map +0 -1
- package/dist/db-unified.d.ts +0 -76
- package/dist/db-unified.d.ts.map +0 -1
- package/dist/db-unified.js +0 -278
- package/dist/db-unified.js.map +0 -1
- package/dist/examples/quic-sync-example.d.ts +0 -9
- package/dist/examples/quic-sync-example.d.ts.map +0 -1
- package/dist/examples/quic-sync-example.js +0 -169
- package/dist/examples/quic-sync-example.js.map +0 -1
- package/dist/examples/wasm-vector-usage.d.ts +0 -12
- package/dist/examples/wasm-vector-usage.d.ts.map +0 -1
- package/dist/examples/wasm-vector-usage.js +0 -190
- package/dist/examples/wasm-vector-usage.js.map +0 -1
- package/dist/index.d.ts +0 -28
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -35
- package/dist/index.js.map +0 -1
- package/dist/malp/core/ccc.d.ts +0 -99
- package/dist/malp/core/ccc.d.ts.map +0 -1
- package/dist/malp/core/ccc.js +0 -181
- package/dist/malp/core/ccc.js.map +0 -1
- package/dist/malp/core/index.d.ts +0 -9
- package/dist/malp/core/index.d.ts.map +0 -1
- package/dist/malp/core/index.js +0 -9
- package/dist/malp/core/index.js.map +0 -1
- package/dist/malp/core/linalg.d.ts +0 -101
- package/dist/malp/core/linalg.d.ts.map +0 -1
- package/dist/malp/core/linalg.js +0 -278
- package/dist/malp/core/linalg.js.map +0 -1
- package/dist/malp/core/optimizer.d.ts +0 -68
- package/dist/malp/core/optimizer.d.ts.map +0 -1
- package/dist/malp/core/optimizer.js +0 -160
- package/dist/malp/core/optimizer.js.map +0 -1
- package/dist/malp/index.d.ts +0 -33
- package/dist/malp/index.d.ts.map +0 -1
- package/dist/malp/index.js +0 -37
- package/dist/malp/index.js.map +0 -1
- package/dist/malp/metrics/agreement.d.ts +0 -106
- package/dist/malp/metrics/agreement.d.ts.map +0 -1
- package/dist/malp/metrics/agreement.js +0 -199
- package/dist/malp/metrics/agreement.js.map +0 -1
- package/dist/malp/metrics/comparison.d.ts +0 -93
- package/dist/malp/metrics/comparison.d.ts.map +0 -1
- package/dist/malp/metrics/comparison.js +0 -256
- package/dist/malp/metrics/comparison.js.map +0 -1
- package/dist/malp/metrics/index.d.ts +0 -8
- package/dist/malp/metrics/index.d.ts.map +0 -1
- package/dist/malp/metrics/index.js +0 -8
- package/dist/malp/metrics/index.js.map +0 -1
- package/dist/malp/metrics/performance.d.ts +0 -61
- package/dist/malp/metrics/performance.d.ts.map +0 -1
- package/dist/malp/metrics/performance.js +0 -190
- package/dist/malp/metrics/performance.js.map +0 -1
- package/dist/malp/models/index.d.ts +0 -7
- package/dist/malp/models/index.d.ts.map +0 -1
- package/dist/malp/models/index.js +0 -7
- package/dist/malp/models/index.js.map +0 -1
- package/dist/malp/models/malp.d.ts +0 -116
- package/dist/malp/models/malp.d.ts.map +0 -1
- package/dist/malp/models/malp.js +0 -206
- package/dist/malp/models/malp.js.map +0 -1
- package/dist/malp/models/regressor.d.ts +0 -80
- package/dist/malp/models/regressor.d.ts.map +0 -1
- package/dist/malp/models/regressor.js +0 -229
- package/dist/malp/models/regressor.js.map +0 -1
- package/dist/malp/reasoningbank_validator.d.ts +0 -187
- package/dist/malp/reasoningbank_validator.d.ts.map +0 -1
- package/dist/malp/reasoningbank_validator.js +0 -246
- package/dist/malp/reasoningbank_validator.js.map +0 -1
- package/dist/malp/wasm_bindings.d.ts +0 -344
- package/dist/malp/wasm_bindings.d.ts.map +0 -1
- package/dist/malp/wasm_bindings.js +0 -9
- package/dist/malp/wasm_bindings.js.map +0 -1
- package/dist/mcp/agentdb-mcp-server.d.ts +0 -8
- package/dist/mcp/agentdb-mcp-server.d.ts.map +0 -1
- package/dist/mcp/agentdb-mcp-server.js +0 -2116
- package/dist/mcp/agentdb-mcp-server.js.map +0 -1
- package/dist/mcp/learning-tools-handlers.d.ts +0 -16
- package/dist/mcp/learning-tools-handlers.d.ts.map +0 -1
- package/dist/mcp/learning-tools-handlers.js +0 -105
- package/dist/mcp/learning-tools-handlers.js.map +0 -1
- package/dist/optimizations/BatchOperations.d.ts +0 -109
- package/dist/optimizations/BatchOperations.d.ts.map +0 -1
- package/dist/optimizations/BatchOperations.js +0 -407
- package/dist/optimizations/BatchOperations.js.map +0 -1
- package/dist/optimizations/QueryOptimizer.d.ts +0 -83
- package/dist/optimizations/QueryOptimizer.d.ts.map +0 -1
- package/dist/optimizations/QueryOptimizer.js +0 -228
- package/dist/optimizations/QueryOptimizer.js.map +0 -1
- package/dist/optimizations/ToolCache.d.ts +0 -137
- package/dist/optimizations/ToolCache.d.ts.map +0 -1
- package/dist/optimizations/ToolCache.js +0 -281
- package/dist/optimizations/ToolCache.js.map +0 -1
- package/dist/optimizations/index.d.ts +0 -10
- package/dist/optimizations/index.d.ts.map +0 -1
- package/dist/optimizations/index.js +0 -8
- package/dist/optimizations/index.js.map +0 -1
- package/dist/security/input-validation.d.ts +0 -109
- package/dist/security/input-validation.d.ts.map +0 -1
- package/dist/security/input-validation.js +0 -398
- package/dist/security/input-validation.js.map +0 -1
- package/dist/security/limits.d.ts +0 -150
- package/dist/security/limits.d.ts.map +0 -1
- package/dist/security/limits.js +0 -288
- package/dist/security/limits.js.map +0 -1
- package/dist/security/path-security.d.ts +0 -100
- package/dist/security/path-security.d.ts.map +0 -1
- package/dist/security/path-security.js +0 -337
- package/dist/security/path-security.js.map +0 -1
- package/dist/security/validation.d.ts +0 -95
- package/dist/security/validation.d.ts.map +0 -1
- package/dist/security/validation.js +0 -315
- package/dist/security/validation.js.map +0 -1
- package/dist/types/quic.d.ts +0 -518
- package/dist/types/quic.d.ts.map +0 -1
- package/dist/types/quic.js +0 -272
- package/dist/types/quic.js.map +0 -1
package/dist/malp/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/malp/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAGH,OAAO,EAEL,KAAK,MAAM,EACX,KAAK,MAAM,EACX,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,cAAc,EACd,SAAS,EACT,YAAY,EACZ,IAAI,EACJ,GAAG,EACH,QAAQ,EACR,UAAU,EACV,WAAW,EACX,GAAG,EACH,IAAI,EACJ,SAAS,EACT,cAAc,EACd,cAAc,EACd,YAAY,EACZ,OAAO,EACR,MAAM,eAAe,CAAC;AAEvB,OAAO,EAEL,KAAK,aAAa,EAClB,UAAU,EACV,kBAAkB,EAClB,yBAAyB,EACzB,OAAO,EACP,YAAY,EACZ,WAAW,EACZ,MAAM,YAAY,CAAC;AAEpB,OAAO,EAEL,KAAK,eAAe,EACpB,KAAK,gBAAgB,EACrB,KAAK,kBAAkB,EACvB,uBAAuB,EACvB,YAAY,EACZ,wBAAwB,EACzB,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EACL,KAAK,UAAU,EACf,KAAK,mBAAmB,EACxB,KAAK,SAAS,EACd,aAAa,EACb,OAAO,EACP,iBAAiB,EACjB,mBAAmB,EACpB,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EACL,KAAK,gBAAgB,EACrB,KAAK,mBAAmB,EACxB,uBAAuB,EACvB,mBAAmB,EACnB,uBAAuB,EACvB,kBAAkB,EAClB,qBAAqB,EACrB,uBAAuB,EACxB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,iBAAiB,EACtB,YAAY,EACZ,wBAAwB,EACxB,gBAAgB,EAChB,uBAAuB,EACxB,MAAM,sBAAsB,CAAC;AAG9B,eAAO,MAAM,YAAY,UAAU,CAAC"}
|
package/dist/malp/index.js
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* MALP - Maximum Agreement Linear Predictor
|
|
3
|
-
*
|
|
4
|
-
* A regression library that maximizes the Concordance Correlation Coefficient (CCC)
|
|
5
|
-
* instead of minimizing squared error. Optimized for measurement validation,
|
|
6
|
-
* method comparison, and scenarios requiring high agreement between predictions
|
|
7
|
-
* and observations.
|
|
8
|
-
*
|
|
9
|
-
* @module malp
|
|
10
|
-
*
|
|
11
|
-
* @example
|
|
12
|
-
* ```typescript
|
|
13
|
-
* import { MALPRegressor, compareMALPvsOLS } from 'agentdb/malp';
|
|
14
|
-
*
|
|
15
|
-
* // Fit MALP model
|
|
16
|
-
* const model = new MALPRegressor();
|
|
17
|
-
* model.fit(X, y);
|
|
18
|
-
* const predictions = model.predict(X);
|
|
19
|
-
* const cccScore = model.score(X, y);
|
|
20
|
-
*
|
|
21
|
-
* // Compare with OLS
|
|
22
|
-
* const comparison = compareMALPvsOLS(X_train, y_train, X_test, y_test);
|
|
23
|
-
* console.log(comparison.summary);
|
|
24
|
-
* ```
|
|
25
|
-
*/
|
|
26
|
-
// Core functionality
|
|
27
|
-
export { createMatrix, createVector, matVecMultiply, matMatMultiply, transpose, leastSquares, mean, std, variance, covariance, pearsonCorr, dot, norm, vectorAdd, vectorSubtract, scalarMultiply, addIntercept, EPSILON } from './core/linalg';
|
|
28
|
-
export { computeCCC, computeCCCGradient, computeCCCHessianDiagonal, cccLoss, interpretCCC, validateCCC } from './core/ccc';
|
|
29
|
-
export { GradientAscentOptimizer, optimizeMALP, DEFAULT_OPTIMIZER_CONFIG } from './core/optimizer';
|
|
30
|
-
// Models
|
|
31
|
-
export { MALPRegressor, fitMALP, crossValidateMALP, DEFAULT_MALP_CONFIG } from './models/regressor';
|
|
32
|
-
// Metrics
|
|
33
|
-
export { computeAgreementMetrics, blandAltmanAnalysis, computePrecisionMetrics, computeBiasMetrics, isAgreementAcceptable, generateAgreementReport } from './metrics/agreement';
|
|
34
|
-
export { OLSRegressor, computeRegressionMetrics, compareMALPvsOLS, crossValidateComparison } from './metrics/comparison';
|
|
35
|
-
// Version info
|
|
36
|
-
export const MALP_VERSION = '1.0.0';
|
|
37
|
-
//# sourceMappingURL=index.js.map
|
package/dist/malp/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/malp/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AAEH,qBAAqB;AACrB,OAAO,EAIL,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,cAAc,EACd,SAAS,EACT,YAAY,EACZ,IAAI,EACJ,GAAG,EACH,QAAQ,EACR,UAAU,EACV,WAAW,EACX,GAAG,EACH,IAAI,EACJ,SAAS,EACT,cAAc,EACd,cAAc,EACd,YAAY,EACZ,OAAO,EACR,MAAM,eAAe,CAAC;AAEvB,OAAO,EAGL,UAAU,EACV,kBAAkB,EAClB,yBAAyB,EACzB,OAAO,EACP,YAAY,EACZ,WAAW,EACZ,MAAM,YAAY,CAAC;AAEpB,OAAO,EAKL,uBAAuB,EACvB,YAAY,EACZ,wBAAwB,EACzB,MAAM,kBAAkB,CAAC;AAE1B,SAAS;AACT,OAAO,EAIL,aAAa,EACb,OAAO,EACP,iBAAiB,EACjB,mBAAmB,EACpB,MAAM,oBAAoB,CAAC;AAE5B,UAAU;AACV,OAAO,EAGL,uBAAuB,EACvB,mBAAmB,EACnB,uBAAuB,EACvB,kBAAkB,EAClB,qBAAqB,EACrB,uBAAuB,EACxB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAGL,YAAY,EACZ,wBAAwB,EACxB,gBAAgB,EAChB,uBAAuB,EACxB,MAAM,sBAAsB,CAAC;AAE9B,eAAe;AACf,MAAM,CAAC,MAAM,YAAY,GAAG,OAAO,CAAC"}
|
|
@@ -1,106 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Agreement Metrics for Method Comparison
|
|
3
|
-
*
|
|
4
|
-
* Provides comprehensive metrics for assessing agreement between two measurement methods,
|
|
5
|
-
* with focus on CCC and related statistics.
|
|
6
|
-
*/
|
|
7
|
-
import { Vector } from '../core/linalg';
|
|
8
|
-
import { CCCComponents } from '../core/ccc';
|
|
9
|
-
/**
|
|
10
|
-
* Complete agreement metrics suite
|
|
11
|
-
*/
|
|
12
|
-
export interface AgreementMetrics {
|
|
13
|
-
/** Concordance Correlation Coefficient */
|
|
14
|
-
ccc: number;
|
|
15
|
-
/** CCC interpretation */
|
|
16
|
-
cccInterpretation: string;
|
|
17
|
-
/** Pearson correlation coefficient */
|
|
18
|
-
pearsonCorr: number;
|
|
19
|
-
/** Mean difference (bias) */
|
|
20
|
-
meanDifference: number;
|
|
21
|
-
/** Standard deviation of differences */
|
|
22
|
-
sdDifference: number;
|
|
23
|
-
/** 95% Limits of Agreement (Bland-Altman) */
|
|
24
|
-
limitsOfAgreement: [number, number];
|
|
25
|
-
/** Mean of the two methods */
|
|
26
|
-
overallMean: number;
|
|
27
|
-
/** Coefficient of variation */
|
|
28
|
-
coefficientOfVariation: number;
|
|
29
|
-
/** Total Deviation Index (TDI) at 90% coverage */
|
|
30
|
-
tdi90: number;
|
|
31
|
-
/** Coverage Probability (CP) */
|
|
32
|
-
coverageProbability: number;
|
|
33
|
-
/** CCC components breakdown */
|
|
34
|
-
cccComponents: CCCComponents;
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Bland-Altman analysis results
|
|
38
|
-
*/
|
|
39
|
-
export interface BlandAltmanAnalysis {
|
|
40
|
-
/** Mean difference (bias) */
|
|
41
|
-
meanDifference: number;
|
|
42
|
-
/** Standard deviation of differences */
|
|
43
|
-
sdDifference: number;
|
|
44
|
-
/** Lower limit of agreement (mean - 1.96*SD) */
|
|
45
|
-
lowerLimit: number;
|
|
46
|
-
/** Upper limit of agreement (mean + 1.96*SD) */
|
|
47
|
-
upperLimit: number;
|
|
48
|
-
/** Differences vector */
|
|
49
|
-
differences: number[];
|
|
50
|
-
/** Means vector */
|
|
51
|
-
means: number[];
|
|
52
|
-
/** Whether differences are within acceptable range */
|
|
53
|
-
withinLimits: boolean[];
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Compute comprehensive agreement metrics
|
|
57
|
-
*
|
|
58
|
-
* @param x - First method (reference/gold standard)
|
|
59
|
-
* @param y - Second method (new/test method)
|
|
60
|
-
* @param acceptableLimit - Optional acceptable difference limit
|
|
61
|
-
* @returns Complete set of agreement metrics
|
|
62
|
-
*/
|
|
63
|
-
export declare function computeAgreementMetrics(x: number[] | Vector, y: number[] | Vector, acceptableLimit?: number): AgreementMetrics;
|
|
64
|
-
/**
|
|
65
|
-
* Perform Bland-Altman analysis
|
|
66
|
-
*
|
|
67
|
-
* @param x - First method measurements
|
|
68
|
-
* @param y - Second method measurements
|
|
69
|
-
* @param acceptableLimit - Optional acceptable difference limit
|
|
70
|
-
* @returns Bland-Altman analysis results
|
|
71
|
-
*/
|
|
72
|
-
export declare function blandAltmanAnalysis(x: number[] | Vector, y: number[] | Vector, acceptableLimit?: number): BlandAltmanAnalysis;
|
|
73
|
-
/**
|
|
74
|
-
* Compute precision (repeatability) metrics
|
|
75
|
-
*/
|
|
76
|
-
export declare function computePrecisionMetrics(x: Vector, y: Vector): {
|
|
77
|
-
withinSubjectSD: number;
|
|
78
|
-
repeatabilityCoefficient: number;
|
|
79
|
-
withinSubjectCV: number;
|
|
80
|
-
};
|
|
81
|
-
/**
|
|
82
|
-
* Compute bias and accuracy metrics
|
|
83
|
-
*/
|
|
84
|
-
export declare function computeBiasMetrics(x: Vector, y: Vector): {
|
|
85
|
-
meanBias: number;
|
|
86
|
-
proportionalBias: number;
|
|
87
|
-
fixedBias: number;
|
|
88
|
-
relativeAccuracy: number;
|
|
89
|
-
};
|
|
90
|
-
/**
|
|
91
|
-
* Check if agreement is acceptable based on predefined criteria
|
|
92
|
-
*/
|
|
93
|
-
export declare function isAgreementAcceptable(metrics: AgreementMetrics, criteria?: {
|
|
94
|
-
minCCC?: number;
|
|
95
|
-
maxMeanDifference?: number;
|
|
96
|
-
maxSDDifference?: number;
|
|
97
|
-
minCoverageProbability?: number;
|
|
98
|
-
}): {
|
|
99
|
-
acceptable: boolean;
|
|
100
|
-
reasons: string[];
|
|
101
|
-
};
|
|
102
|
-
/**
|
|
103
|
-
* Generate agreement report
|
|
104
|
-
*/
|
|
105
|
-
export declare function generateAgreementReport(metrics: AgreementMetrics): string;
|
|
106
|
-
//# sourceMappingURL=agreement.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"agreement.d.ts","sourceRoot":"","sources":["../../../src/malp/metrics/agreement.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,MAAM,EAAqC,MAAM,gBAAgB,CAAC;AAC3E,OAAO,EAAc,aAAa,EAAgB,MAAM,aAAa,CAAC;AAEtE;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,0CAA0C;IAC1C,GAAG,EAAE,MAAM,CAAC;IACZ,yBAAyB;IACzB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,sCAAsC;IACtC,WAAW,EAAE,MAAM,CAAC;IACpB,6BAA6B;IAC7B,cAAc,EAAE,MAAM,CAAC;IACvB,wCAAwC;IACxC,YAAY,EAAE,MAAM,CAAC;IACrB,6CAA6C;IAC7C,iBAAiB,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACpC,8BAA8B;IAC9B,WAAW,EAAE,MAAM,CAAC;IACpB,+BAA+B;IAC/B,sBAAsB,EAAE,MAAM,CAAC;IAC/B,kDAAkD;IAClD,KAAK,EAAE,MAAM,CAAC;IACd,gCAAgC;IAChC,mBAAmB,EAAE,MAAM,CAAC;IAC5B,+BAA+B;IAC/B,aAAa,EAAE,aAAa,CAAC;CAC9B;AAED;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,6BAA6B;IAC7B,cAAc,EAAE,MAAM,CAAC;IACvB,wCAAwC;IACxC,YAAY,EAAE,MAAM,CAAC;IACrB,gDAAgD;IAChD,UAAU,EAAE,MAAM,CAAC;IACnB,gDAAgD;IAChD,UAAU,EAAE,MAAM,CAAC;IACnB,yBAAyB;IACzB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,mBAAmB;IACnB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,sDAAsD;IACtD,YAAY,EAAE,OAAO,EAAE,CAAC;CACzB;AAED;;;;;;;GAOG;AACH,wBAAgB,uBAAuB,CACrC,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM,EACpB,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM,EACpB,eAAe,CAAC,EAAE,MAAM,GACvB,gBAAgB,CAqDlB;AAED;;;;;;;GAOG;AACH,wBAAgB,mBAAmB,CACjC,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM,EACpB,CAAC,EAAE,MAAM,EAAE,GAAG,MAAM,EACpB,eAAe,CAAC,EAAE,MAAM,GACvB,mBAAmB,CAwCrB;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG;IAC7D,eAAe,EAAE,MAAM,CAAC;IACxB,wBAAwB,EAAE,MAAM,CAAC;IACjC,eAAe,EAAE,MAAM,CAAC;CACzB,CAmBA;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,GAAG;IACxD,QAAQ,EAAE,MAAM,CAAC;IACjB,gBAAgB,EAAE,MAAM,CAAC;IACzB,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;CAC1B,CAqBA;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,gBAAgB,EACzB,QAAQ,GAAE;IACR,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,sBAAsB,CAAC,EAAE,MAAM,CAAC;CAC5B,GACL;IAAE,UAAU,EAAE,OAAO,CAAC;IAAC,OAAO,EAAE,MAAM,EAAE,CAAA;CAAE,CAyB5C;AAED;;GAEG;AACH,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,gBAAgB,GAAG,MAAM,CA2BzE"}
|
|
@@ -1,199 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Agreement Metrics for Method Comparison
|
|
3
|
-
*
|
|
4
|
-
* Provides comprehensive metrics for assessing agreement between two measurement methods,
|
|
5
|
-
* with focus on CCC and related statistics.
|
|
6
|
-
*/
|
|
7
|
-
import { createVector, mean, std } from '../core/linalg';
|
|
8
|
-
import { computeCCC, interpretCCC } from '../core/ccc';
|
|
9
|
-
/**
|
|
10
|
-
* Compute comprehensive agreement metrics
|
|
11
|
-
*
|
|
12
|
-
* @param x - First method (reference/gold standard)
|
|
13
|
-
* @param y - Second method (new/test method)
|
|
14
|
-
* @param acceptableLimit - Optional acceptable difference limit
|
|
15
|
-
* @returns Complete set of agreement metrics
|
|
16
|
-
*/
|
|
17
|
-
export function computeAgreementMetrics(x, y, acceptableLimit) {
|
|
18
|
-
const xVec = Array.isArray(x) ? createVector(x) : x;
|
|
19
|
-
const yVec = Array.isArray(y) ? createVector(y) : y;
|
|
20
|
-
if (xVec.length !== yVec.length) {
|
|
21
|
-
throw new Error(`Vector length mismatch: ${xVec.length} !== ${yVec.length}`);
|
|
22
|
-
}
|
|
23
|
-
// Compute CCC and components
|
|
24
|
-
const { ccc, components } = computeCCC(xVec, yVec);
|
|
25
|
-
const cccInterpretation = interpretCCC(ccc);
|
|
26
|
-
// Compute differences
|
|
27
|
-
const differences = xVec.data.map((val, i) => val - yVec.data[i]);
|
|
28
|
-
const diffVec = createVector(differences);
|
|
29
|
-
// Bland-Altman metrics
|
|
30
|
-
const meanDifference = mean(diffVec);
|
|
31
|
-
const sdDifference = std(diffVec, meanDifference);
|
|
32
|
-
const limitsOfAgreement = [
|
|
33
|
-
meanDifference - 1.96 * sdDifference,
|
|
34
|
-
meanDifference + 1.96 * sdDifference
|
|
35
|
-
];
|
|
36
|
-
// Overall statistics
|
|
37
|
-
const overallMean = (components.muX + components.muY) / 2;
|
|
38
|
-
const coefficientOfVariation = (Math.sqrt((components.sigmaX ** 2 + components.sigmaY ** 2) / 2) / overallMean) * 100;
|
|
39
|
-
// Total Deviation Index (TDI) - 90th percentile of absolute differences
|
|
40
|
-
const sortedAbsDiffs = differences.map(Math.abs).sort((a, b) => a - b);
|
|
41
|
-
const tdi90Index = Math.floor(0.9 * sortedAbsDiffs.length);
|
|
42
|
-
const tdi90 = sortedAbsDiffs[tdi90Index];
|
|
43
|
-
// Coverage Probability - proportion within acceptable limit
|
|
44
|
-
let coverageProbability = 1.0;
|
|
45
|
-
if (acceptableLimit !== undefined) {
|
|
46
|
-
const withinLimit = differences.filter(d => Math.abs(d) <= acceptableLimit).length;
|
|
47
|
-
coverageProbability = withinLimit / differences.length;
|
|
48
|
-
}
|
|
49
|
-
return {
|
|
50
|
-
ccc,
|
|
51
|
-
cccInterpretation,
|
|
52
|
-
pearsonCorr: components.rho,
|
|
53
|
-
meanDifference,
|
|
54
|
-
sdDifference,
|
|
55
|
-
limitsOfAgreement,
|
|
56
|
-
overallMean,
|
|
57
|
-
coefficientOfVariation,
|
|
58
|
-
tdi90,
|
|
59
|
-
coverageProbability,
|
|
60
|
-
cccComponents: components
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* Perform Bland-Altman analysis
|
|
65
|
-
*
|
|
66
|
-
* @param x - First method measurements
|
|
67
|
-
* @param y - Second method measurements
|
|
68
|
-
* @param acceptableLimit - Optional acceptable difference limit
|
|
69
|
-
* @returns Bland-Altman analysis results
|
|
70
|
-
*/
|
|
71
|
-
export function blandAltmanAnalysis(x, y, acceptableLimit) {
|
|
72
|
-
const xVec = Array.isArray(x) ? createVector(x) : x;
|
|
73
|
-
const yVec = Array.isArray(y) ? createVector(y) : y;
|
|
74
|
-
if (xVec.length !== yVec.length) {
|
|
75
|
-
throw new Error(`Vector length mismatch: ${xVec.length} !== ${yVec.length}`);
|
|
76
|
-
}
|
|
77
|
-
// Compute differences and means
|
|
78
|
-
const differences = [];
|
|
79
|
-
const means = [];
|
|
80
|
-
const withinLimits = [];
|
|
81
|
-
for (let i = 0; i < xVec.length; i++) {
|
|
82
|
-
const diff = xVec.data[i] - yVec.data[i];
|
|
83
|
-
const mean = (xVec.data[i] + yVec.data[i]) / 2;
|
|
84
|
-
differences.push(diff);
|
|
85
|
-
means.push(mean);
|
|
86
|
-
if (acceptableLimit !== undefined) {
|
|
87
|
-
withinLimits.push(Math.abs(diff) <= acceptableLimit);
|
|
88
|
-
}
|
|
89
|
-
else {
|
|
90
|
-
withinLimits.push(true);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
const diffVec = createVector(differences);
|
|
94
|
-
const meanDifference = mean(diffVec);
|
|
95
|
-
const sdDifference = std(diffVec, meanDifference);
|
|
96
|
-
return {
|
|
97
|
-
meanDifference,
|
|
98
|
-
sdDifference,
|
|
99
|
-
lowerLimit: meanDifference - 1.96 * sdDifference,
|
|
100
|
-
upperLimit: meanDifference + 1.96 * sdDifference,
|
|
101
|
-
differences,
|
|
102
|
-
means,
|
|
103
|
-
withinLimits
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* Compute precision (repeatability) metrics
|
|
108
|
-
*/
|
|
109
|
-
export function computePrecisionMetrics(x, y) {
|
|
110
|
-
const differences = x.data.map((val, i) => val - y.data[i]);
|
|
111
|
-
const diffVec = createVector(differences);
|
|
112
|
-
// Within-subject standard deviation (SD of differences / sqrt(2))
|
|
113
|
-
const withinSubjectSD = std(diffVec) / Math.sqrt(2);
|
|
114
|
-
// Repeatability coefficient (1.96 * sqrt(2) * SD_within)
|
|
115
|
-
const repeatabilityCoefficient = 1.96 * Math.sqrt(2) * withinSubjectSD;
|
|
116
|
-
// Within-subject coefficient of variation
|
|
117
|
-
const overallMean = (mean(x) + mean(y)) / 2;
|
|
118
|
-
const withinSubjectCV = (withinSubjectSD / overallMean) * 100;
|
|
119
|
-
return {
|
|
120
|
-
withinSubjectSD,
|
|
121
|
-
repeatabilityCoefficient,
|
|
122
|
-
withinSubjectCV
|
|
123
|
-
};
|
|
124
|
-
}
|
|
125
|
-
/**
|
|
126
|
-
* Compute bias and accuracy metrics
|
|
127
|
-
*/
|
|
128
|
-
export function computeBiasMetrics(x, y) {
|
|
129
|
-
const { components } = computeCCC(x, y);
|
|
130
|
-
// Mean bias (average difference)
|
|
131
|
-
const meanBias = components.muX - components.muY;
|
|
132
|
-
// Proportional bias (slope of regression line - 1)
|
|
133
|
-
const proportionalBias = (components.sigmaY / components.sigmaX) * components.rho - 1;
|
|
134
|
-
// Fixed bias (intercept of regression line)
|
|
135
|
-
const fixedBias = components.muY - (components.muY / components.muX) * components.muX;
|
|
136
|
-
// Relative accuracy (ratio of means)
|
|
137
|
-
const relativeAccuracy = components.muY / components.muX;
|
|
138
|
-
return {
|
|
139
|
-
meanBias,
|
|
140
|
-
proportionalBias,
|
|
141
|
-
fixedBias,
|
|
142
|
-
relativeAccuracy
|
|
143
|
-
};
|
|
144
|
-
}
|
|
145
|
-
/**
|
|
146
|
-
* Check if agreement is acceptable based on predefined criteria
|
|
147
|
-
*/
|
|
148
|
-
export function isAgreementAcceptable(metrics, criteria = {}) {
|
|
149
|
-
const reasons = [];
|
|
150
|
-
let acceptable = true;
|
|
151
|
-
if (criteria.minCCC !== undefined && metrics.ccc < criteria.minCCC) {
|
|
152
|
-
acceptable = false;
|
|
153
|
-
reasons.push(`CCC (${metrics.ccc.toFixed(3)}) below minimum (${criteria.minCCC})`);
|
|
154
|
-
}
|
|
155
|
-
if (criteria.maxMeanDifference !== undefined && Math.abs(metrics.meanDifference) > criteria.maxMeanDifference) {
|
|
156
|
-
acceptable = false;
|
|
157
|
-
reasons.push(`Mean difference (${metrics.meanDifference.toFixed(3)}) exceeds maximum (${criteria.maxMeanDifference})`);
|
|
158
|
-
}
|
|
159
|
-
if (criteria.maxSDDifference !== undefined && metrics.sdDifference > criteria.maxSDDifference) {
|
|
160
|
-
acceptable = false;
|
|
161
|
-
reasons.push(`SD of differences (${metrics.sdDifference.toFixed(3)}) exceeds maximum (${criteria.maxSDDifference})`);
|
|
162
|
-
}
|
|
163
|
-
if (criteria.minCoverageProbability !== undefined && metrics.coverageProbability < criteria.minCoverageProbability) {
|
|
164
|
-
acceptable = false;
|
|
165
|
-
reasons.push(`Coverage probability (${metrics.coverageProbability.toFixed(3)}) below minimum (${criteria.minCoverageProbability})`);
|
|
166
|
-
}
|
|
167
|
-
return { acceptable, reasons };
|
|
168
|
-
}
|
|
169
|
-
/**
|
|
170
|
-
* Generate agreement report
|
|
171
|
-
*/
|
|
172
|
-
export function generateAgreementReport(metrics) {
|
|
173
|
-
const lines = [
|
|
174
|
-
'=== Agreement Analysis Report ===',
|
|
175
|
-
'',
|
|
176
|
-
'Primary Metrics:',
|
|
177
|
-
` CCC: ${metrics.ccc.toFixed(4)} (${metrics.cccInterpretation})`,
|
|
178
|
-
` Pearson r: ${metrics.pearsonCorr.toFixed(4)}`,
|
|
179
|
-
'',
|
|
180
|
-
'Bland-Altman Analysis:',
|
|
181
|
-
` Mean Difference (Bias): ${metrics.meanDifference.toFixed(4)}`,
|
|
182
|
-
` SD of Differences: ${metrics.sdDifference.toFixed(4)}`,
|
|
183
|
-
` 95% Limits of Agreement: [${metrics.limitsOfAgreement[0].toFixed(4)}, ${metrics.limitsOfAgreement[1].toFixed(4)}]`,
|
|
184
|
-
'',
|
|
185
|
-
'Precision Metrics:',
|
|
186
|
-
` Coefficient of Variation: ${metrics.coefficientOfVariation.toFixed(2)}%`,
|
|
187
|
-
` TDI (90%): ${metrics.tdi90.toFixed(4)}`,
|
|
188
|
-
` Coverage Probability: ${(metrics.coverageProbability * 100).toFixed(2)}%`,
|
|
189
|
-
'',
|
|
190
|
-
'CCC Components:',
|
|
191
|
-
` Location Shift: ${metrics.cccComponents.locationShift.toFixed(4)}`,
|
|
192
|
-
` Scale Shift: ${metrics.cccComponents.scaleShift.toFixed(4)}`,
|
|
193
|
-
` Precision: ${metrics.cccComponents.precision.toFixed(4)}`,
|
|
194
|
-
` Accuracy: ${metrics.cccComponents.accuracy.toFixed(4)}`,
|
|
195
|
-
''
|
|
196
|
-
];
|
|
197
|
-
return lines.join('\n');
|
|
198
|
-
}
|
|
199
|
-
//# sourceMappingURL=agreement.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"agreement.js","sourceRoot":"","sources":["../../../src/malp/metrics/agreement.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Model Comparison Utilities
|
|
3
|
-
*
|
|
4
|
-
* Compare MALP regression with Ordinary Least Squares (OLS)
|
|
5
|
-
* and other regression methods.
|
|
6
|
-
*/
|
|
7
|
-
import { Vector, Matrix } from '../core/linalg';
|
|
8
|
-
/**
|
|
9
|
-
* Regression model performance metrics
|
|
10
|
-
*/
|
|
11
|
-
export interface RegressionMetrics {
|
|
12
|
-
/** Model name */
|
|
13
|
-
name: string;
|
|
14
|
-
/** Concordance Correlation Coefficient */
|
|
15
|
-
ccc: number;
|
|
16
|
-
/** Mean Squared Error */
|
|
17
|
-
mse: number;
|
|
18
|
-
/** Root Mean Squared Error */
|
|
19
|
-
rmse: number;
|
|
20
|
-
/** Mean Absolute Error */
|
|
21
|
-
mae: number;
|
|
22
|
-
/** R-squared (coefficient of determination) */
|
|
23
|
-
r2: number;
|
|
24
|
-
/** Adjusted R-squared */
|
|
25
|
-
adjustedR2: number;
|
|
26
|
-
/** Akaike Information Criterion */
|
|
27
|
-
aic: number;
|
|
28
|
-
/** Bayesian Information Criterion */
|
|
29
|
-
bic: number;
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* Winner types for metric comparisons
|
|
33
|
-
*/
|
|
34
|
-
export type Winner = 'MALP' | 'OLS' | 'Tie';
|
|
35
|
-
/**
|
|
36
|
-
* Comparison results between two models
|
|
37
|
-
*/
|
|
38
|
-
export interface ComparisonResults {
|
|
39
|
-
/** MALP model metrics */
|
|
40
|
-
malp: RegressionMetrics;
|
|
41
|
-
/** OLS model metrics */
|
|
42
|
-
ols: RegressionMetrics;
|
|
43
|
-
/** Performance differences (MALP - OLS) */
|
|
44
|
-
differences: {
|
|
45
|
-
ccc: number;
|
|
46
|
-
mse: number;
|
|
47
|
-
rmse: number;
|
|
48
|
-
mae: number;
|
|
49
|
-
r2: number;
|
|
50
|
-
};
|
|
51
|
-
/** Which model is better for each metric */
|
|
52
|
-
winner: {
|
|
53
|
-
ccc: Winner;
|
|
54
|
-
mse: Winner;
|
|
55
|
-
agreement: Winner;
|
|
56
|
-
overall: Winner;
|
|
57
|
-
};
|
|
58
|
-
/** Summary message */
|
|
59
|
-
summary: string;
|
|
60
|
-
}
|
|
61
|
-
/**
|
|
62
|
-
* Ordinary Least Squares Regressor
|
|
63
|
-
*/
|
|
64
|
-
export declare class OLSRegressor {
|
|
65
|
-
private coefficients;
|
|
66
|
-
private intercept;
|
|
67
|
-
private isFitted;
|
|
68
|
-
fit(X: number[][] | Matrix, y: number[] | Vector): this;
|
|
69
|
-
predict(X: number[][] | Matrix): number[];
|
|
70
|
-
private addInterceptColumn;
|
|
71
|
-
getCoefficients(): number[] | null;
|
|
72
|
-
getIntercept(): number;
|
|
73
|
-
}
|
|
74
|
-
/**
|
|
75
|
-
* Compute comprehensive metrics for a regression model
|
|
76
|
-
*/
|
|
77
|
-
export declare function computeRegressionMetrics(name: string, yTrue: number[] | Vector, yPred: number[] | Vector, nFeatures: number): RegressionMetrics;
|
|
78
|
-
/**
|
|
79
|
-
* Compare MALP and OLS models
|
|
80
|
-
*/
|
|
81
|
-
export declare function compareMALPvsOLS(XTrain: number[][] | Matrix, yTrain: number[] | Vector, XTest?: number[][] | Matrix, yTest?: number[] | Vector): ComparisonResults;
|
|
82
|
-
/**
|
|
83
|
-
* Cross-validation comparison
|
|
84
|
-
*/
|
|
85
|
-
export declare function crossValidateComparison(X: number[][] | Matrix, y: number[] | Vector, nFolds?: number): {
|
|
86
|
-
malpScores: number[];
|
|
87
|
-
olsScores: number[];
|
|
88
|
-
malpMean: number;
|
|
89
|
-
olsMean: number;
|
|
90
|
-
malpStd: number;
|
|
91
|
-
olsStd: number;
|
|
92
|
-
};
|
|
93
|
-
//# sourceMappingURL=comparison.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"comparison.d.ts","sourceRoot":"","sources":["../../../src/malp/metrics/comparison.ts"],"names":[],"mappings":"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"}
|