agentdb 1.0.11 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +196 -838
- package/dist/benchmarks/comprehensive-benchmark.js +664 -0
- package/dist/benchmarks/frontier-benchmark.js +419 -0
- package/dist/benchmarks/reflexion-benchmark.js +370 -0
- package/dist/cli/agentdb-cli.d.ts +117 -0
- package/dist/cli/agentdb-cli.d.ts.map +1 -0
- package/dist/cli/agentdb-cli.js +718 -0
- package/dist/cli/agentdb-cli.js.map +1 -0
- package/dist/controllers/CausalMemoryGraph.d.ts +125 -0
- package/dist/controllers/CausalMemoryGraph.d.ts.map +1 -0
- package/dist/controllers/CausalMemoryGraph.js +323 -0
- package/dist/controllers/CausalMemoryGraph.js.map +1 -0
- package/dist/controllers/CausalRecall.d.ts +111 -0
- package/dist/controllers/CausalRecall.d.ts.map +1 -0
- package/dist/controllers/CausalRecall.js +282 -0
- package/dist/controllers/CausalRecall.js.map +1 -0
- package/dist/controllers/EmbeddingService.d.ts +37 -0
- package/dist/controllers/EmbeddingService.d.ts.map +1 -0
- package/dist/controllers/EmbeddingService.js +119 -0
- package/dist/controllers/EmbeddingService.js.map +1 -0
- package/dist/controllers/ExplainableRecall.d.ts +138 -0
- package/dist/controllers/ExplainableRecall.d.ts.map +1 -0
- package/dist/controllers/ExplainableRecall.js +388 -0
- package/dist/controllers/ExplainableRecall.js.map +1 -0
- package/dist/controllers/NightlyLearner.d.ts +113 -0
- package/dist/controllers/NightlyLearner.d.ts.map +1 -0
- package/dist/controllers/NightlyLearner.js +383 -0
- package/dist/controllers/NightlyLearner.js.map +1 -0
- package/dist/controllers/ReflexionMemory.d.ts +84 -0
- package/dist/controllers/ReflexionMemory.d.ts.map +1 -0
- package/dist/controllers/ReflexionMemory.js +240 -0
- package/dist/controllers/ReflexionMemory.js.map +1 -0
- package/dist/controllers/SkillLibrary.d.ts +96 -0
- package/dist/controllers/SkillLibrary.d.ts.map +1 -0
- package/dist/controllers/SkillLibrary.js +277 -0
- package/dist/controllers/SkillLibrary.js.map +1 -0
- package/dist/controllers/frontier-index.d.ts +14 -0
- package/dist/controllers/frontier-index.d.ts.map +1 -0
- package/dist/controllers/frontier-index.js +10 -0
- package/dist/controllers/frontier-index.js.map +1 -0
- package/dist/controllers/index.d.ts +12 -0
- package/dist/controllers/index.d.ts.map +1 -0
- package/dist/controllers/index.js +9 -0
- package/dist/controllers/index.js.map +1 -0
- package/dist/optimizations/BatchOperations.d.ts +61 -0
- package/dist/optimizations/BatchOperations.d.ts.map +1 -0
- package/dist/optimizations/BatchOperations.js +199 -0
- package/dist/optimizations/BatchOperations.js.map +1 -0
- package/dist/optimizations/QueryOptimizer.d.ts +82 -0
- package/dist/optimizations/QueryOptimizer.d.ts.map +1 -0
- package/dist/optimizations/QueryOptimizer.js +226 -0
- package/dist/optimizations/QueryOptimizer.js.map +1 -0
- package/dist/optimizations/index.d.ts +10 -0
- package/dist/optimizations/index.d.ts.map +1 -0
- package/dist/optimizations/index.js +8 -0
- package/dist/optimizations/index.js.map +1 -0
- package/dist/schemas/frontier-schema.sql +341 -0
- package/dist/schemas/schema.sql +382 -0
- package/dist/tests/frontier-features.test.js +665 -0
- package/package.json +54 -117
- package/src/cli/agentdb-cli.ts +861 -0
- package/src/cli/examples.sh +83 -0
- package/src/controllers/CausalMemoryGraph.ts +504 -0
- package/src/controllers/CausalRecall.ts +395 -0
- package/src/controllers/EmbeddingService.ts +141 -0
- package/src/controllers/ExplainableRecall.ts +577 -0
- package/src/controllers/NightlyLearner.ts +475 -0
- package/src/controllers/ReflexionMemory.ts +349 -0
- package/src/controllers/SkillLibrary.ts +391 -0
- package/src/controllers/frontier-index.ts +35 -0
- package/src/controllers/index.ts +13 -0
- package/src/optimizations/BatchOperations.ts +292 -0
- package/src/optimizations/QueryOptimizer.ts +294 -0
- package/src/optimizations/index.ts +11 -0
- package/src/schemas/frontier-schema.sql +341 -0
- package/src/schemas/schema.sql +382 -0
- package/CHANGELOG.md +0 -166
- package/LICENSE +0 -38
- package/LICENSE-APACHE +0 -190
- package/LICENSE-MIT +0 -21
- package/bin/agentdb.js +0 -733
- package/bin/benchmark.js +0 -162
- package/bin/plugin-cli-wrapper.mjs +0 -21
- package/dist/agentdb.js +0 -5352
- package/dist/agentdb.js.map +0 -7
- package/dist/agentdb.min.js +0 -143
- package/dist/agentdb.min.js.map +0 -7
- package/dist/cache/query-cache.d.ts +0 -105
- package/dist/cache/query-cache.d.ts.map +0 -1
- package/dist/cache/query-cache.js +0 -224
- package/dist/cache/query-cache.js.map +0 -1
- package/dist/cache/query-cache.mjs +0 -219
- package/dist/cli/cache/query-cache.d.ts +0 -104
- package/dist/cli/cache/query-cache.js +0 -244
- package/dist/cli/cli/db-commands.d.ts +0 -48
- package/dist/cli/cli/db-commands.js +0 -613
- package/dist/cli/commands.d.ts +0 -7
- package/dist/cli/commands.d.ts.map +0 -1
- package/dist/cli/commands.js +0 -113
- package/dist/cli/commands.js.map +0 -1
- package/dist/cli/commands.mjs +0 -104
- package/dist/cli/core/backend-interface.d.ts +0 -70
- package/dist/cli/core/backend-interface.js +0 -15
- package/dist/cli/core/native-backend.d.ts +0 -140
- package/dist/cli/core/native-backend.js +0 -432
- package/dist/cli/core/vector-db.d.ts +0 -126
- package/dist/cli/core/vector-db.js +0 -338
- package/dist/cli/core/wasm-backend.d.ts +0 -95
- package/dist/cli/core/wasm-backend.js +0 -418
- package/dist/cli/db-commands.d.ts +0 -49
- package/dist/cli/db-commands.d.ts.map +0 -1
- package/dist/cli/db-commands.js +0 -533
- package/dist/cli/db-commands.js.map +0 -1
- package/dist/cli/db-commands.mjs +0 -522
- package/dist/cli/generator.d.ts +0 -11
- package/dist/cli/generator.d.ts.map +0 -1
- package/dist/cli/generator.js +0 -567
- package/dist/cli/generator.js.map +0 -1
- package/dist/cli/generator.mjs +0 -527
- package/dist/cli/help.d.ts +0 -18
- package/dist/cli/help.d.ts.map +0 -1
- package/dist/cli/help.js +0 -676
- package/dist/cli/help.js.map +0 -1
- package/dist/cli/help.mjs +0 -667
- package/dist/cli/index/hnsw.d.ts +0 -164
- package/dist/cli/index/hnsw.js +0 -558
- package/dist/cli/plugin-cli.d.ts +0 -7
- package/dist/cli/plugin-cli.d.ts.map +0 -1
- package/dist/cli/plugin-cli.js +0 -295
- package/dist/cli/plugin-cli.js.map +0 -1
- package/dist/cli/plugin-cli.mjs +0 -289
- package/dist/cli/quantization/product-quantization.d.ts +0 -108
- package/dist/cli/quantization/product-quantization.js +0 -350
- package/dist/cli/query/query-builder.d.ts +0 -322
- package/dist/cli/query/query-builder.js +0 -600
- package/dist/cli/templates.d.ts +0 -14
- package/dist/cli/templates.d.ts.map +0 -1
- package/dist/cli/templates.js +0 -182
- package/dist/cli/templates.js.map +0 -1
- package/dist/cli/templates.mjs +0 -176
- package/dist/cli/types/index.d.ts +0 -116
- package/dist/cli/types/index.js +0 -5
- package/dist/cli/types.d.ts +0 -91
- package/dist/cli/types.d.ts.map +0 -1
- package/dist/cli/types.js +0 -6
- package/dist/cli/types.js.map +0 -1
- package/dist/cli/types.mjs +0 -4
- package/dist/cli/wizard/index.d.ts +0 -6
- package/dist/cli/wizard/index.d.ts.map +0 -1
- package/dist/cli/wizard/index.js +0 -138
- package/dist/cli/wizard/index.js.map +0 -1
- package/dist/cli/wizard/index.mjs +0 -131
- package/dist/cli/wizard/prompts.d.ts +0 -11
- package/dist/cli/wizard/prompts.d.ts.map +0 -1
- package/dist/cli/wizard/prompts.js +0 -482
- package/dist/cli/wizard/prompts.js.map +0 -1
- package/dist/cli/wizard/prompts.mjs +0 -470
- package/dist/cli/wizard/validator.d.ts +0 -13
- package/dist/cli/wizard/validator.d.ts.map +0 -1
- package/dist/cli/wizard/validator.js +0 -234
- package/dist/cli/wizard/validator.js.map +0 -1
- package/dist/cli/wizard/validator.mjs +0 -224
- package/dist/core/backend-interface.d.ts +0 -71
- package/dist/core/backend-interface.d.ts.map +0 -1
- package/dist/core/backend-interface.js +0 -16
- package/dist/core/backend-interface.js.map +0 -1
- package/dist/core/backend-interface.mjs +0 -12
- package/dist/core/native-backend.d.ts +0 -141
- package/dist/core/native-backend.d.ts.map +0 -1
- package/dist/core/native-backend.js +0 -457
- package/dist/core/native-backend.js.map +0 -1
- package/dist/core/native-backend.mjs +0 -449
- package/dist/core/vector-db.d.ts +0 -127
- package/dist/core/vector-db.d.ts.map +0 -1
- package/dist/core/vector-db.js +0 -270
- package/dist/core/vector-db.js.map +0 -1
- package/dist/core/vector-db.mjs +0 -265
- package/dist/core/wasm-backend.d.ts +0 -96
- package/dist/core/wasm-backend.d.ts.map +0 -1
- package/dist/core/wasm-backend.js +0 -393
- package/dist/core/wasm-backend.js.map +0 -1
- package/dist/core/wasm-backend.mjs +0 -385
- package/dist/index/hnsw-optimized.d.ts +0 -75
- package/dist/index/hnsw-optimized.d.ts.map +0 -1
- package/dist/index/hnsw-optimized.js +0 -412
- package/dist/index/hnsw-optimized.js.map +0 -1
- package/dist/index/hnsw-optimized.mjs +0 -407
- package/dist/index/hnsw.d.ts +0 -165
- package/dist/index/hnsw.d.ts.map +0 -1
- package/dist/index/hnsw.js +0 -521
- package/dist/index/hnsw.js.map +0 -1
- package/dist/index/hnsw.mjs +0 -516
- package/dist/index.browser.d.ts +0 -47
- package/dist/index.browser.d.ts.map +0 -1
- package/dist/index.browser.js +0 -72
- package/dist/index.browser.js.map +0 -1
- package/dist/index.browser.mjs +0 -54
- package/dist/index.d.ts +0 -59
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -84
- package/dist/index.js.map +0 -1
- package/dist/index.mjs +0 -65
- package/dist/mcp/learning/core/experience-buffer.d.ts +0 -61
- package/dist/mcp/learning/core/experience-buffer.d.ts.map +0 -1
- package/dist/mcp/learning/core/experience-buffer.js +0 -175
- package/dist/mcp/learning/core/experience-buffer.js.map +0 -1
- package/dist/mcp/learning/core/experience-buffer.mjs +0 -170
- package/dist/mcp/learning/core/experience-recorder.d.ts +0 -40
- package/dist/mcp/learning/core/experience-recorder.d.ts.map +0 -1
- package/dist/mcp/learning/core/experience-recorder.js +0 -200
- package/dist/mcp/learning/core/experience-recorder.js.map +0 -1
- package/dist/mcp/learning/core/experience-recorder.mjs +0 -195
- package/dist/mcp/learning/core/learning-manager.d.ts +0 -66
- package/dist/mcp/learning/core/learning-manager.d.ts.map +0 -1
- package/dist/mcp/learning/core/learning-manager.js +0 -252
- package/dist/mcp/learning/core/learning-manager.js.map +0 -1
- package/dist/mcp/learning/core/learning-manager.mjs +0 -247
- package/dist/mcp/learning/core/policy-optimizer.d.ts +0 -53
- package/dist/mcp/learning/core/policy-optimizer.d.ts.map +0 -1
- package/dist/mcp/learning/core/policy-optimizer.js +0 -251
- package/dist/mcp/learning/core/policy-optimizer.js.map +0 -1
- package/dist/mcp/learning/core/policy-optimizer.mjs +0 -246
- package/dist/mcp/learning/core/reward-estimator.d.ts +0 -44
- package/dist/mcp/learning/core/reward-estimator.d.ts.map +0 -1
- package/dist/mcp/learning/core/reward-estimator.js +0 -158
- package/dist/mcp/learning/core/reward-estimator.js.map +0 -1
- package/dist/mcp/learning/core/reward-estimator.mjs +0 -153
- package/dist/mcp/learning/core/session-manager.d.ts +0 -63
- package/dist/mcp/learning/core/session-manager.d.ts.map +0 -1
- package/dist/mcp/learning/core/session-manager.js +0 -202
- package/dist/mcp/learning/core/session-manager.js.map +0 -1
- package/dist/mcp/learning/core/session-manager.mjs +0 -197
- package/dist/mcp/learning/index.d.ts +0 -19
- package/dist/mcp/learning/index.d.ts.map +0 -1
- package/dist/mcp/learning/index.js +0 -30
- package/dist/mcp/learning/index.js.map +0 -1
- package/dist/mcp/learning/index.mjs +0 -19
- package/dist/mcp/learning/tools/mcp-learning-tools.d.ts +0 -369
- package/dist/mcp/learning/tools/mcp-learning-tools.d.ts.map +0 -1
- package/dist/mcp/learning/tools/mcp-learning-tools.js +0 -361
- package/dist/mcp/learning/tools/mcp-learning-tools.js.map +0 -1
- package/dist/mcp/learning/tools/mcp-learning-tools.mjs +0 -356
- package/dist/mcp/learning/types/index.d.ts +0 -138
- package/dist/mcp/learning/types/index.d.ts.map +0 -1
- package/dist/mcp/learning/types/index.js +0 -6
- package/dist/mcp/learning/types/index.js.map +0 -1
- package/dist/mcp/learning/types/index.mjs +0 -4
- package/dist/mcp-server.d.ts +0 -29
- package/dist/mcp-server.d.ts.map +0 -1
- package/dist/mcp-server.js +0 -862
- package/dist/mcp-server.js.map +0 -1
- package/dist/mcp-server.mjs +0 -857
- package/dist/plugins/base-plugin.d.ts +0 -114
- package/dist/plugins/base-plugin.d.ts.map +0 -1
- package/dist/plugins/base-plugin.js +0 -313
- package/dist/plugins/base-plugin.js.map +0 -1
- package/dist/plugins/base-plugin.mjs +0 -275
- package/dist/plugins/implementations/active-learning.d.ts +0 -135
- package/dist/plugins/implementations/active-learning.d.ts.map +0 -1
- package/dist/plugins/implementations/active-learning.js +0 -372
- package/dist/plugins/implementations/active-learning.js.map +0 -1
- package/dist/plugins/implementations/active-learning.mjs +0 -367
- package/dist/plugins/implementations/actor-critic.d.ts +0 -64
- package/dist/plugins/implementations/actor-critic.d.ts.map +0 -1
- package/dist/plugins/implementations/actor-critic.js +0 -363
- package/dist/plugins/implementations/actor-critic.js.map +0 -1
- package/dist/plugins/implementations/actor-critic.mjs +0 -358
- package/dist/plugins/implementations/adversarial-training.d.ts +0 -133
- package/dist/plugins/implementations/adversarial-training.d.ts.map +0 -1
- package/dist/plugins/implementations/adversarial-training.js +0 -409
- package/dist/plugins/implementations/adversarial-training.js.map +0 -1
- package/dist/plugins/implementations/adversarial-training.mjs +0 -404
- package/dist/plugins/implementations/curriculum-learning.d.ts +0 -132
- package/dist/plugins/implementations/curriculum-learning.d.ts.map +0 -1
- package/dist/plugins/implementations/curriculum-learning.js +0 -354
- package/dist/plugins/implementations/curriculum-learning.js.map +0 -1
- package/dist/plugins/implementations/curriculum-learning.mjs +0 -349
- package/dist/plugins/implementations/decision-transformer.d.ts +0 -77
- package/dist/plugins/implementations/decision-transformer.d.ts.map +0 -1
- package/dist/plugins/implementations/decision-transformer.js +0 -422
- package/dist/plugins/implementations/decision-transformer.js.map +0 -1
- package/dist/plugins/implementations/decision-transformer.mjs +0 -417
- package/dist/plugins/implementations/federated-learning.d.ts +0 -126
- package/dist/plugins/implementations/federated-learning.d.ts.map +0 -1
- package/dist/plugins/implementations/federated-learning.js +0 -436
- package/dist/plugins/implementations/federated-learning.js.map +0 -1
- package/dist/plugins/implementations/federated-learning.mjs +0 -431
- package/dist/plugins/implementations/index.d.ts +0 -30
- package/dist/plugins/implementations/index.d.ts.map +0 -1
- package/dist/plugins/implementations/index.js +0 -45
- package/dist/plugins/implementations/index.js.map +0 -1
- package/dist/plugins/implementations/index.mjs +0 -31
- package/dist/plugins/implementations/multi-task-learning.d.ts +0 -115
- package/dist/plugins/implementations/multi-task-learning.d.ts.map +0 -1
- package/dist/plugins/implementations/multi-task-learning.js +0 -369
- package/dist/plugins/implementations/multi-task-learning.js.map +0 -1
- package/dist/plugins/implementations/multi-task-learning.mjs +0 -364
- package/dist/plugins/implementations/neural-architecture-search.d.ts +0 -148
- package/dist/plugins/implementations/neural-architecture-search.d.ts.map +0 -1
- package/dist/plugins/implementations/neural-architecture-search.js +0 -379
- package/dist/plugins/implementations/neural-architecture-search.js.map +0 -1
- package/dist/plugins/implementations/neural-architecture-search.mjs +0 -374
- package/dist/plugins/implementations/q-learning.d.ts +0 -98
- package/dist/plugins/implementations/q-learning.d.ts.map +0 -1
- package/dist/plugins/implementations/q-learning.js +0 -435
- package/dist/plugins/implementations/q-learning.js.map +0 -1
- package/dist/plugins/implementations/q-learning.mjs +0 -430
- package/dist/plugins/implementations/sarsa.d.ts +0 -103
- package/dist/plugins/implementations/sarsa.d.ts.map +0 -1
- package/dist/plugins/implementations/sarsa.js +0 -347
- package/dist/plugins/implementations/sarsa.js.map +0 -1
- package/dist/plugins/implementations/sarsa.mjs +0 -342
- package/dist/plugins/index.d.ts +0 -107
- package/dist/plugins/index.d.ts.map +0 -1
- package/dist/plugins/index.js +0 -179
- package/dist/plugins/index.js.map +0 -1
- package/dist/plugins/index.mjs +0 -168
- package/dist/plugins/interface.d.ts +0 -439
- package/dist/plugins/interface.d.ts.map +0 -1
- package/dist/plugins/interface.js +0 -12
- package/dist/plugins/interface.js.map +0 -1
- package/dist/plugins/interface.mjs +0 -10
- package/dist/plugins/learning-plugin.interface.d.ts +0 -257
- package/dist/plugins/learning-plugin.interface.d.ts.map +0 -1
- package/dist/plugins/learning-plugin.interface.js +0 -7
- package/dist/plugins/learning-plugin.interface.js.map +0 -1
- package/dist/plugins/learning-plugin.interface.mjs +0 -5
- package/dist/plugins/plugin-exports.d.ts +0 -71
- package/dist/plugins/plugin-exports.d.ts.map +0 -1
- package/dist/plugins/plugin-exports.js +0 -78
- package/dist/plugins/plugin-exports.js.map +0 -1
- package/dist/plugins/plugin-exports.mjs +0 -69
- package/dist/plugins/registry.d.ts +0 -206
- package/dist/plugins/registry.d.ts.map +0 -1
- package/dist/plugins/registry.js +0 -365
- package/dist/plugins/registry.js.map +0 -1
- package/dist/plugins/registry.mjs +0 -356
- package/dist/plugins/validator.d.ts +0 -63
- package/dist/plugins/validator.d.ts.map +0 -1
- package/dist/plugins/validator.js +0 -464
- package/dist/plugins/validator.js.map +0 -1
- package/dist/plugins/validator.mjs +0 -458
- package/dist/presets.d.ts +0 -65
- package/dist/presets.d.ts.map +0 -1
- package/dist/presets.js +0 -145
- package/dist/presets.js.map +0 -1
- package/dist/presets.mjs +0 -140
- package/dist/quantization/binary-quantization.d.ts +0 -104
- package/dist/quantization/binary-quantization.d.ts.map +0 -1
- package/dist/quantization/binary-quantization.js +0 -246
- package/dist/quantization/binary-quantization.js.map +0 -1
- package/dist/quantization/binary-quantization.mjs +0 -240
- package/dist/quantization/optimized-pq.d.ts +0 -138
- package/dist/quantization/optimized-pq.d.ts.map +0 -1
- package/dist/quantization/optimized-pq.js +0 -320
- package/dist/quantization/optimized-pq.js.map +0 -1
- package/dist/quantization/optimized-pq.mjs +0 -313
- package/dist/quantization/product-quantization.d.ts +0 -109
- package/dist/quantization/product-quantization.d.ts.map +0 -1
- package/dist/quantization/product-quantization.js +0 -287
- package/dist/quantization/product-quantization.js.map +0 -1
- package/dist/quantization/product-quantization.mjs +0 -282
- package/dist/quantization/scalar-quantization.d.ts +0 -100
- package/dist/quantization/scalar-quantization.d.ts.map +0 -1
- package/dist/quantization/scalar-quantization.js +0 -324
- package/dist/quantization/scalar-quantization.js.map +0 -1
- package/dist/quantization/scalar-quantization.mjs +0 -319
- package/dist/query/index.d.ts +0 -6
- package/dist/query/index.d.ts.map +0 -1
- package/dist/query/index.js +0 -9
- package/dist/query/index.js.map +0 -1
- package/dist/query/index.mjs +0 -4
- package/dist/query/query-builder.d.ts +0 -323
- package/dist/query/query-builder.d.ts.map +0 -1
- package/dist/query/query-builder.js +0 -524
- package/dist/query/query-builder.js.map +0 -1
- package/dist/query/query-builder.mjs +0 -519
- package/dist/reasoning/context-synthesizer.d.ts +0 -57
- package/dist/reasoning/context-synthesizer.d.ts.map +0 -1
- package/dist/reasoning/context-synthesizer.js +0 -224
- package/dist/reasoning/context-synthesizer.js.map +0 -1
- package/dist/reasoning/context-synthesizer.mjs +0 -219
- package/dist/reasoning/experience-curator.d.ts +0 -66
- package/dist/reasoning/experience-curator.d.ts.map +0 -1
- package/dist/reasoning/experience-curator.js +0 -288
- package/dist/reasoning/experience-curator.js.map +0 -1
- package/dist/reasoning/experience-curator.mjs +0 -283
- package/dist/reasoning/memory-optimizer.d.ts +0 -69
- package/dist/reasoning/memory-optimizer.d.ts.map +0 -1
- package/dist/reasoning/memory-optimizer.js +0 -331
- package/dist/reasoning/memory-optimizer.js.map +0 -1
- package/dist/reasoning/memory-optimizer.mjs +0 -326
- package/dist/reasoning/pattern-matcher.d.ts +0 -59
- package/dist/reasoning/pattern-matcher.d.ts.map +0 -1
- package/dist/reasoning/pattern-matcher.js +0 -229
- package/dist/reasoning/pattern-matcher.js.map +0 -1
- package/dist/reasoning/pattern-matcher.mjs +0 -224
- package/dist/reasoningbank/adapter/agentdb-adapter.d.ts +0 -118
- package/dist/reasoningbank/adapter/agentdb-adapter.d.ts.map +0 -1
- package/dist/reasoningbank/adapter/agentdb-adapter.js +0 -477
- package/dist/reasoningbank/adapter/agentdb-adapter.js.map +0 -1
- package/dist/reasoningbank/adapter/types.d.ts +0 -113
- package/dist/reasoningbank/adapter/types.d.ts.map +0 -1
- package/dist/reasoningbank/adapter/types.js +0 -9
- package/dist/reasoningbank/adapter/types.js.map +0 -1
- package/dist/reasoningbank/cli/commands.d.ts +0 -16
- package/dist/reasoningbank/cli/commands.d.ts.map +0 -1
- package/dist/reasoningbank/cli/commands.js +0 -272
- package/dist/reasoningbank/cli/commands.js.map +0 -1
- package/dist/reasoningbank/mcp/agentdb-tools.d.ts +0 -319
- package/dist/reasoningbank/mcp/agentdb-tools.d.ts.map +0 -1
- package/dist/reasoningbank/mcp/agentdb-tools.js +0 -301
- package/dist/reasoningbank/mcp/agentdb-tools.js.map +0 -1
- package/dist/reasoningbank/migration/migrate.d.ts +0 -25
- package/dist/reasoningbank/migration/migrate.d.ts.map +0 -1
- package/dist/reasoningbank/migration/migrate.js +0 -178
- package/dist/reasoningbank/migration/migrate.js.map +0 -1
- package/dist/reasoningbank/reasoning/context-synthesizer.d.ts +0 -37
- package/dist/reasoningbank/reasoning/context-synthesizer.d.ts.map +0 -1
- package/dist/reasoningbank/reasoning/context-synthesizer.js +0 -114
- package/dist/reasoningbank/reasoning/context-synthesizer.js.map +0 -1
- package/dist/reasoningbank/reasoning/experience-curator.d.ts +0 -39
- package/dist/reasoningbank/reasoning/experience-curator.d.ts.map +0 -1
- package/dist/reasoningbank/reasoning/experience-curator.js +0 -98
- package/dist/reasoningbank/reasoning/experience-curator.js.map +0 -1
- package/dist/reasoningbank/reasoning/memory-optimizer.d.ts +0 -44
- package/dist/reasoningbank/reasoning/memory-optimizer.d.ts.map +0 -1
- package/dist/reasoningbank/reasoning/memory-optimizer.js +0 -184
- package/dist/reasoningbank/reasoning/memory-optimizer.js.map +0 -1
- package/dist/reasoningbank/reasoning/pattern-matcher.d.ts +0 -40
- package/dist/reasoningbank/reasoning/pattern-matcher.d.ts.map +0 -1
- package/dist/reasoningbank/reasoning/pattern-matcher.js +0 -87
- package/dist/reasoningbank/reasoning/pattern-matcher.js.map +0 -1
- package/dist/reasoningbank/sync/quic-sync.d.ts +0 -77
- package/dist/reasoningbank/sync/quic-sync.d.ts.map +0 -1
- package/dist/reasoningbank/sync/quic-sync.js +0 -165
- package/dist/reasoningbank/sync/quic-sync.js.map +0 -1
- package/dist/sync/conflict.d.ts +0 -78
- package/dist/sync/conflict.d.ts.map +0 -1
- package/dist/sync/conflict.js +0 -202
- package/dist/sync/conflict.js.map +0 -1
- package/dist/sync/conflict.mjs +0 -196
- package/dist/sync/coordinator.d.ts +0 -111
- package/dist/sync/coordinator.d.ts.map +0 -1
- package/dist/sync/coordinator.js +0 -256
- package/dist/sync/coordinator.js.map +0 -1
- package/dist/sync/coordinator.mjs +0 -250
- package/dist/sync/delta.d.ts +0 -81
- package/dist/sync/delta.d.ts.map +0 -1
- package/dist/sync/delta.js +0 -245
- package/dist/sync/delta.js.map +0 -1
- package/dist/sync/delta.mjs +0 -238
- package/dist/sync/index.d.ts +0 -11
- package/dist/sync/index.d.ts.map +0 -1
- package/dist/sync/index.js +0 -22
- package/dist/sync/index.js.map +0 -1
- package/dist/sync/index.mjs +0 -9
- package/dist/sync/quic-sync.d.ts +0 -81
- package/dist/sync/quic-sync.d.ts.map +0 -1
- package/dist/sync/quic-sync.js +0 -329
- package/dist/sync/quic-sync.js.map +0 -1
- package/dist/sync/quic-sync.mjs +0 -323
- package/dist/sync/types.d.ts +0 -168
- package/dist/sync/types.d.ts.map +0 -1
- package/dist/sync/types.js +0 -8
- package/dist/sync/types.js.map +0 -1
- package/dist/sync/types.mjs +0 -6
- package/dist/types/index.d.ts +0 -117
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js +0 -6
- package/dist/types/index.js.map +0 -1
- package/dist/types/index.mjs +0 -4
- package/dist/wasm/sql-wasm-debug.js +0 -6989
- package/dist/wasm/sql-wasm-debug.wasm +0 -0
- package/dist/wasm/sql-wasm.js +0 -188
- package/dist/wasm/sql-wasm.wasm +0 -0
- package/dist/wasm-loader.d.ts +0 -32
- package/dist/wasm-loader.d.ts.map +0 -1
- package/dist/wasm-loader.js +0 -78
- package/dist/wasm-loader.js.map +0 -1
- package/dist/wasm-loader.mjs +0 -67
- package/examples/adaptive-learning.ts +0 -284
- package/examples/browser/README.md +0 -732
- package/examples/browser/adaptive-recommendations/index.html +0 -427
- package/examples/browser/collaborative-filtering/index.html +0 -310
- package/examples/browser/continual-learning/index.html +0 -736
- package/examples/browser/experience-replay/index.html +0 -616
- package/examples/browser/index.html +0 -369
- package/examples/browser/meta-learning/index.html +0 -789
- package/examples/browser/neuro-symbolic/index.html +0 -692
- package/examples/browser/pattern-learning/index.html +0 -620
- package/examples/browser/quantum-inspired/index.html +0 -728
- package/examples/browser/rag/index.html +0 -624
- package/examples/browser/swarm-intelligence/index.html +0 -811
- package/examples/browser-basic.html +0 -170
- package/examples/browser-wasm-real.html +0 -231
- package/examples/hnsw-example.ts +0 -148
- package/examples/mcp-learning-example.ts +0 -220
- package/examples/node-basic.js +0 -70
- package/examples/quic-sync-example.ts +0 -310
- package/examples/quick-start.js +0 -68
- package/examples/test-v1.0.7-cdn.html +0 -190
- package/examples/wasm-example.ts +0 -222
|
@@ -1,170 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ExperienceBuffer - Manages experience replay buffer with prioritization
|
|
3
|
-
*/
|
|
4
|
-
export class ExperienceBuffer {
|
|
5
|
-
constructor(maxSize = 10000) {
|
|
6
|
-
this.buffer = [];
|
|
7
|
-
this.priorities = new Map();
|
|
8
|
-
this.maxSize = maxSize;
|
|
9
|
-
}
|
|
10
|
-
/**
|
|
11
|
-
* Add experience to buffer
|
|
12
|
-
*/
|
|
13
|
-
add(experience) {
|
|
14
|
-
this.buffer.push(experience);
|
|
15
|
-
// Calculate priority based on reward and recency
|
|
16
|
-
const priority = this.calculatePriority(experience);
|
|
17
|
-
const actionId = experience.metadata.actionId || experience.timestamp.toString();
|
|
18
|
-
this.priorities.set(actionId, priority);
|
|
19
|
-
// Prune if buffer exceeds max size
|
|
20
|
-
if (this.buffer.length > this.maxSize) {
|
|
21
|
-
this.prune();
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Sample random batch from buffer
|
|
26
|
-
*/
|
|
27
|
-
sample(batchSize) {
|
|
28
|
-
if (this.buffer.length === 0) {
|
|
29
|
-
return [];
|
|
30
|
-
}
|
|
31
|
-
const samples = [];
|
|
32
|
-
const size = Math.min(batchSize, this.buffer.length);
|
|
33
|
-
for (let i = 0; i < size; i++) {
|
|
34
|
-
const idx = Math.floor(Math.random() * this.buffer.length);
|
|
35
|
-
samples.push(this.buffer[idx]);
|
|
36
|
-
}
|
|
37
|
-
return samples;
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Sample batch with prioritized experience replay
|
|
41
|
-
*/
|
|
42
|
-
samplePrioritized(batchSize, alpha = 0.6) {
|
|
43
|
-
if (this.buffer.length === 0) {
|
|
44
|
-
return [];
|
|
45
|
-
}
|
|
46
|
-
const size = Math.min(batchSize, this.buffer.length);
|
|
47
|
-
const samples = [];
|
|
48
|
-
// Calculate probability distribution based on priorities
|
|
49
|
-
const priorities = this.buffer.map((exp) => {
|
|
50
|
-
const actionId = exp.metadata.actionId || exp.timestamp.toString();
|
|
51
|
-
const priority = this.priorities.get(actionId) || 1.0;
|
|
52
|
-
return Math.pow(priority, alpha);
|
|
53
|
-
});
|
|
54
|
-
const totalPriority = priorities.reduce((sum, p) => sum + p, 0);
|
|
55
|
-
const probabilities = priorities.map((p) => p / totalPriority);
|
|
56
|
-
// Sample using probability distribution
|
|
57
|
-
for (let i = 0; i < size; i++) {
|
|
58
|
-
const rand = Math.random();
|
|
59
|
-
let cumulative = 0;
|
|
60
|
-
for (let j = 0; j < probabilities.length; j++) {
|
|
61
|
-
cumulative += probabilities[j];
|
|
62
|
-
if (rand <= cumulative) {
|
|
63
|
-
samples.push(this.buffer[j]);
|
|
64
|
-
break;
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
return samples;
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Get recent experiences
|
|
72
|
-
*/
|
|
73
|
-
getRecent(count) {
|
|
74
|
-
const start = Math.max(0, this.buffer.length - count);
|
|
75
|
-
return this.buffer.slice(start);
|
|
76
|
-
}
|
|
77
|
-
/**
|
|
78
|
-
* Get high-reward experiences
|
|
79
|
-
*/
|
|
80
|
-
getTopRewarded(count) {
|
|
81
|
-
const sorted = [...this.buffer].sort((a, b) => b.reward - a.reward);
|
|
82
|
-
return sorted.slice(0, count);
|
|
83
|
-
}
|
|
84
|
-
/**
|
|
85
|
-
* Get experiences by task type
|
|
86
|
-
*/
|
|
87
|
-
getByTaskType(taskType) {
|
|
88
|
-
return this.buffer.filter((exp) => exp.metadata.taskType === taskType);
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Get buffer statistics
|
|
92
|
-
*/
|
|
93
|
-
getStats() {
|
|
94
|
-
if (this.buffer.length === 0) {
|
|
95
|
-
return {
|
|
96
|
-
size: 0,
|
|
97
|
-
avgReward: 0,
|
|
98
|
-
maxReward: 0,
|
|
99
|
-
minReward: 0,
|
|
100
|
-
taskDistribution: {},
|
|
101
|
-
};
|
|
102
|
-
}
|
|
103
|
-
const rewards = this.buffer.map((exp) => exp.reward);
|
|
104
|
-
const avgReward = rewards.reduce((sum, r) => sum + r, 0) / rewards.length;
|
|
105
|
-
const maxReward = Math.max(...rewards);
|
|
106
|
-
const minReward = Math.min(...rewards);
|
|
107
|
-
const taskDistribution = {};
|
|
108
|
-
for (const exp of this.buffer) {
|
|
109
|
-
const taskType = exp.metadata.taskType;
|
|
110
|
-
taskDistribution[taskType] = (taskDistribution[taskType] || 0) + 1;
|
|
111
|
-
}
|
|
112
|
-
return {
|
|
113
|
-
size: this.buffer.length,
|
|
114
|
-
avgReward,
|
|
115
|
-
maxReward,
|
|
116
|
-
minReward,
|
|
117
|
-
taskDistribution,
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
/**
|
|
121
|
-
* Clear buffer
|
|
122
|
-
*/
|
|
123
|
-
clear() {
|
|
124
|
-
this.buffer = [];
|
|
125
|
-
this.priorities.clear();
|
|
126
|
-
}
|
|
127
|
-
/**
|
|
128
|
-
* Get buffer size
|
|
129
|
-
*/
|
|
130
|
-
size() {
|
|
131
|
-
return this.buffer.length;
|
|
132
|
-
}
|
|
133
|
-
/**
|
|
134
|
-
* Calculate priority for experience
|
|
135
|
-
*/
|
|
136
|
-
calculatePriority(experience) {
|
|
137
|
-
// Priority based on:
|
|
138
|
-
// 1. Reward magnitude (higher reward = higher priority)
|
|
139
|
-
// 2. Recency (more recent = higher priority)
|
|
140
|
-
// 3. Uniqueness (rare task types = higher priority)
|
|
141
|
-
const rewardComponent = Math.abs(experience.reward);
|
|
142
|
-
const recencyComponent = 1.0 / (1.0 + (Date.now() - experience.timestamp) / 1000000);
|
|
143
|
-
// Simple priority: weighted sum
|
|
144
|
-
return rewardComponent * 0.7 + recencyComponent * 0.3;
|
|
145
|
-
}
|
|
146
|
-
/**
|
|
147
|
-
* Prune buffer to maintain max size
|
|
148
|
-
*/
|
|
149
|
-
prune() {
|
|
150
|
-
// Strategy: Remove lowest priority experiences
|
|
151
|
-
const withPriorities = this.buffer.map((exp) => {
|
|
152
|
-
const actionId = exp.metadata.actionId || exp.timestamp.toString();
|
|
153
|
-
const priority = this.priorities.get(actionId) || 0;
|
|
154
|
-
return { experience: exp, priority };
|
|
155
|
-
});
|
|
156
|
-
// Sort by priority (descending)
|
|
157
|
-
withPriorities.sort((a, b) => b.priority - a.priority);
|
|
158
|
-
// Keep top maxSize experiences
|
|
159
|
-
this.buffer = withPriorities
|
|
160
|
-
.slice(0, this.maxSize)
|
|
161
|
-
.map((item) => item.experience);
|
|
162
|
-
// Clean up priorities map
|
|
163
|
-
const validActionIds = new Set(this.buffer.map((exp) => exp.metadata.actionId || exp.timestamp.toString()));
|
|
164
|
-
for (const actionId of this.priorities.keys()) {
|
|
165
|
-
if (!validActionIds.has(actionId)) {
|
|
166
|
-
this.priorities.delete(actionId);
|
|
167
|
-
}
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ExperienceRecorder - Captures and stores learning experiences
|
|
3
|
-
*/
|
|
4
|
-
import type { SQLiteVectorDB } from '../../../core/vector-db.js';
|
|
5
|
-
import type { Experience, ExecutionContext, State, Outcome } from '../types/index.js';
|
|
6
|
-
export declare class ExperienceRecorder {
|
|
7
|
-
private db;
|
|
8
|
-
private rewardEstimator;
|
|
9
|
-
private actionCounter;
|
|
10
|
-
constructor(db: SQLiteVectorDB);
|
|
11
|
-
/**
|
|
12
|
-
* Record a tool execution as a learning experience
|
|
13
|
-
*/
|
|
14
|
-
recordToolExecution(toolName: string, args: any, result: any, context: ExecutionContext, outcome: Outcome): Promise<Experience>;
|
|
15
|
-
/**
|
|
16
|
-
* Capture current state representation
|
|
17
|
-
*/
|
|
18
|
-
private captureState;
|
|
19
|
-
/**
|
|
20
|
-
* Generate vector embedding for state
|
|
21
|
-
*/
|
|
22
|
-
private generateStateEmbedding;
|
|
23
|
-
/**
|
|
24
|
-
* Store experience in vector database
|
|
25
|
-
*/
|
|
26
|
-
private storeExperience;
|
|
27
|
-
/**
|
|
28
|
-
* Retrieve similar experiences
|
|
29
|
-
*/
|
|
30
|
-
retrieveSimilarExperiences(state: State, k?: number): Promise<Experience[]>;
|
|
31
|
-
/**
|
|
32
|
-
* Get experiences by session
|
|
33
|
-
*/
|
|
34
|
-
getSessionExperiences(sessionId: string): Promise<Experience[]>;
|
|
35
|
-
/**
|
|
36
|
-
* Update experience with feedback
|
|
37
|
-
*/
|
|
38
|
-
updateExperienceReward(actionId: string, feedbackReward: number): Promise<void>;
|
|
39
|
-
}
|
|
40
|
-
//# sourceMappingURL=experience-recorder.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"experience-recorder.d.ts","sourceRoot":"","sources":["../../../../src/mcp/learning/core/experience-recorder.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,KAAK,EACV,UAAU,EACV,gBAAgB,EAEhB,KAAK,EACL,OAAO,EACR,MAAM,mBAAmB,CAAC;AAG3B,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,EAAE,CAAiB;IAC3B,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,aAAa,CAAa;gBAEtB,EAAE,EAAE,cAAc;IAK9B;;OAEG;IACG,mBAAmB,CACvB,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,GAAG,EACT,MAAM,EAAE,GAAG,EACX,OAAO,EAAE,gBAAgB,EACzB,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,UAAU,CAAC;IAyCtB;;OAEG;YACW,YAAY;IAmB1B;;OAEG;YACW,sBAAsB;IA4BpC;;OAEG;YACW,eAAe;IA4B7B;;OAEG;IACG,0BAA0B,CAC9B,KAAK,EAAE,KAAK,EACZ,CAAC,GAAE,MAAW,GACb,OAAO,CAAC,UAAU,EAAE,CAAC;IAgCxB;;OAEG;IACG,qBAAqB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAkCrE;;OAEG;IACG,sBAAsB,CAC1B,QAAQ,EAAE,MAAM,EAChB,cAAc,EAAE,MAAM,GACrB,OAAO,CAAC,IAAI,CAAC;CAKjB"}
|
|
@@ -1,200 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/**
|
|
3
|
-
* ExperienceRecorder - Captures and stores learning experiences
|
|
4
|
-
*/
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.ExperienceRecorder = void 0;
|
|
7
|
-
const reward_estimator_js_1 = require("./reward-estimator.js");
|
|
8
|
-
class ExperienceRecorder {
|
|
9
|
-
constructor(db) {
|
|
10
|
-
this.actionCounter = 0;
|
|
11
|
-
this.db = db;
|
|
12
|
-
this.rewardEstimator = new reward_estimator_js_1.RewardEstimator();
|
|
13
|
-
}
|
|
14
|
-
/**
|
|
15
|
-
* Record a tool execution as a learning experience
|
|
16
|
-
*/
|
|
17
|
-
async recordToolExecution(toolName, args, result, context, outcome) {
|
|
18
|
-
const state = await this.captureState(context);
|
|
19
|
-
const action = {
|
|
20
|
-
tool: toolName,
|
|
21
|
-
params: args,
|
|
22
|
-
timestamp: Date.now(),
|
|
23
|
-
};
|
|
24
|
-
const reward = await this.rewardEstimator.calculateReward(outcome, context);
|
|
25
|
-
const nextState = await this.captureState({
|
|
26
|
-
...context,
|
|
27
|
-
isTerminal: outcome.success || !!outcome.error,
|
|
28
|
-
});
|
|
29
|
-
const experience = {
|
|
30
|
-
state,
|
|
31
|
-
action,
|
|
32
|
-
reward: reward.combined,
|
|
33
|
-
nextState,
|
|
34
|
-
done: context.isTerminal,
|
|
35
|
-
timestamp: Date.now(),
|
|
36
|
-
metadata: {
|
|
37
|
-
userId: context.userId,
|
|
38
|
-
sessionId: context.sessionId,
|
|
39
|
-
taskType: context.taskType,
|
|
40
|
-
actionId: `action_${this.actionCounter++}`,
|
|
41
|
-
rewardBreakdown: reward,
|
|
42
|
-
outcome: {
|
|
43
|
-
success: outcome.success,
|
|
44
|
-
executionTime: outcome.executionTime,
|
|
45
|
-
tokensUsed: outcome.tokensUsed,
|
|
46
|
-
},
|
|
47
|
-
},
|
|
48
|
-
};
|
|
49
|
-
// Store experience in vector database
|
|
50
|
-
await this.storeExperience(experience);
|
|
51
|
-
return experience;
|
|
52
|
-
}
|
|
53
|
-
/**
|
|
54
|
-
* Capture current state representation
|
|
55
|
-
*/
|
|
56
|
-
async captureState(context) {
|
|
57
|
-
const state = {
|
|
58
|
-
taskDescription: context.metadata?.taskDescription || '',
|
|
59
|
-
availableTools: context.metadata?.availableTools || [],
|
|
60
|
-
previousActions: context.metadata?.previousActions || [],
|
|
61
|
-
constraints: context.metadata?.constraints,
|
|
62
|
-
context: {
|
|
63
|
-
sessionId: context.sessionId,
|
|
64
|
-
taskType: context.taskType,
|
|
65
|
-
timestamp: context.timestamp,
|
|
66
|
-
},
|
|
67
|
-
};
|
|
68
|
-
// Generate state embedding for similarity search
|
|
69
|
-
state.embedding = await this.generateStateEmbedding(state);
|
|
70
|
-
return state;
|
|
71
|
-
}
|
|
72
|
-
/**
|
|
73
|
-
* Generate vector embedding for state
|
|
74
|
-
*/
|
|
75
|
-
async generateStateEmbedding(state) {
|
|
76
|
-
// Simple hash-based embedding (in production, use a proper embedding model)
|
|
77
|
-
const text = JSON.stringify({
|
|
78
|
-
task: state.taskDescription,
|
|
79
|
-
tools: state.availableTools,
|
|
80
|
-
type: state.context?.taskType,
|
|
81
|
-
});
|
|
82
|
-
// Create a simple hash-based embedding (768 dimensions)
|
|
83
|
-
const embedding = new Float32Array(768);
|
|
84
|
-
for (let i = 0; i < text.length; i++) {
|
|
85
|
-
const index = text.charCodeAt(i) % 768;
|
|
86
|
-
embedding[index] += 1;
|
|
87
|
-
}
|
|
88
|
-
// Normalize
|
|
89
|
-
const magnitude = Math.sqrt(embedding.reduce((sum, val) => sum + val * val, 0));
|
|
90
|
-
if (magnitude > 0) {
|
|
91
|
-
for (let i = 0; i < embedding.length; i++) {
|
|
92
|
-
embedding[i] /= magnitude;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
return embedding;
|
|
96
|
-
}
|
|
97
|
-
/**
|
|
98
|
-
* Store experience in vector database
|
|
99
|
-
*/
|
|
100
|
-
async storeExperience(experience) {
|
|
101
|
-
if (!experience.state.embedding) {
|
|
102
|
-
throw new Error('State embedding is required');
|
|
103
|
-
}
|
|
104
|
-
await this.db.insert({
|
|
105
|
-
embedding: Array.from(experience.state.embedding),
|
|
106
|
-
metadata: {
|
|
107
|
-
type: 'learning_experience',
|
|
108
|
-
sessionId: experience.metadata.sessionId,
|
|
109
|
-
userId: experience.metadata.userId,
|
|
110
|
-
taskType: experience.metadata.taskType,
|
|
111
|
-
actionId: experience.metadata.actionId,
|
|
112
|
-
action: experience.action,
|
|
113
|
-
reward: experience.reward,
|
|
114
|
-
done: experience.done,
|
|
115
|
-
timestamp: experience.timestamp,
|
|
116
|
-
state: {
|
|
117
|
-
taskDescription: experience.state.taskDescription,
|
|
118
|
-
availableTools: experience.state.availableTools,
|
|
119
|
-
previousActionsCount: experience.state.previousActions.length,
|
|
120
|
-
},
|
|
121
|
-
outcome: experience.metadata.outcome,
|
|
122
|
-
rewardBreakdown: experience.metadata.rewardBreakdown,
|
|
123
|
-
},
|
|
124
|
-
});
|
|
125
|
-
}
|
|
126
|
-
/**
|
|
127
|
-
* Retrieve similar experiences
|
|
128
|
-
*/
|
|
129
|
-
async retrieveSimilarExperiences(state, k = 10) {
|
|
130
|
-
if (!state.embedding) {
|
|
131
|
-
state.embedding = await this.generateStateEmbedding(state);
|
|
132
|
-
}
|
|
133
|
-
const results = await this.db.search(Array.from(state.embedding), k);
|
|
134
|
-
return results.map((result) => ({
|
|
135
|
-
state: {
|
|
136
|
-
taskDescription: result.metadata.state.taskDescription,
|
|
137
|
-
availableTools: result.metadata.state.availableTools,
|
|
138
|
-
previousActions: [],
|
|
139
|
-
embedding: result.embedding,
|
|
140
|
-
},
|
|
141
|
-
action: result.metadata.action,
|
|
142
|
-
reward: result.metadata.reward,
|
|
143
|
-
nextState: {
|
|
144
|
-
taskDescription: '',
|
|
145
|
-
availableTools: [],
|
|
146
|
-
previousActions: [],
|
|
147
|
-
},
|
|
148
|
-
done: result.metadata.done,
|
|
149
|
-
timestamp: result.metadata.timestamp,
|
|
150
|
-
metadata: {
|
|
151
|
-
userId: result.metadata.userId,
|
|
152
|
-
sessionId: result.metadata.sessionId,
|
|
153
|
-
taskType: result.metadata.taskType,
|
|
154
|
-
actionId: result.metadata.actionId,
|
|
155
|
-
},
|
|
156
|
-
}));
|
|
157
|
-
}
|
|
158
|
-
/**
|
|
159
|
-
* Get experiences by session
|
|
160
|
-
*/
|
|
161
|
-
async getSessionExperiences(sessionId) {
|
|
162
|
-
// Query by metadata filter
|
|
163
|
-
const allResults = await this.db.search(Array(768).fill(0), 1000);
|
|
164
|
-
// Filter by session ID
|
|
165
|
-
const sessionResults = allResults.filter((result) => result.metadata.sessionId === sessionId);
|
|
166
|
-
return sessionResults.map((result) => ({
|
|
167
|
-
state: {
|
|
168
|
-
taskDescription: result.metadata.state.taskDescription,
|
|
169
|
-
availableTools: result.metadata.state.availableTools,
|
|
170
|
-
previousActions: [],
|
|
171
|
-
embedding: result.embedding,
|
|
172
|
-
},
|
|
173
|
-
action: result.metadata.action,
|
|
174
|
-
reward: result.metadata.reward,
|
|
175
|
-
nextState: {
|
|
176
|
-
taskDescription: '',
|
|
177
|
-
availableTools: [],
|
|
178
|
-
previousActions: [],
|
|
179
|
-
},
|
|
180
|
-
done: result.metadata.done,
|
|
181
|
-
timestamp: result.metadata.timestamp,
|
|
182
|
-
metadata: {
|
|
183
|
-
userId: result.metadata.userId,
|
|
184
|
-
sessionId: result.metadata.sessionId,
|
|
185
|
-
taskType: result.metadata.taskType,
|
|
186
|
-
actionId: result.metadata.actionId,
|
|
187
|
-
},
|
|
188
|
-
}));
|
|
189
|
-
}
|
|
190
|
-
/**
|
|
191
|
-
* Update experience with feedback
|
|
192
|
-
*/
|
|
193
|
-
async updateExperienceReward(actionId, feedbackReward) {
|
|
194
|
-
// In a real implementation, this would update the stored experience
|
|
195
|
-
// For now, we log the feedback
|
|
196
|
-
console.log(`Updated reward for ${actionId}: ${feedbackReward}`);
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
exports.ExperienceRecorder = ExperienceRecorder;
|
|
200
|
-
//# sourceMappingURL=experience-recorder.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"experience-recorder.js","sourceRoot":"","sources":["../../../../src/mcp/learning/core/experience-recorder.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,195 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* ExperienceRecorder - Captures and stores learning experiences
|
|
3
|
-
*/
|
|
4
|
-
import { RewardEstimator } from './reward-estimator.mjs';
|
|
5
|
-
export class ExperienceRecorder {
|
|
6
|
-
constructor(db) {
|
|
7
|
-
this.actionCounter = 0;
|
|
8
|
-
this.db = db;
|
|
9
|
-
this.rewardEstimator = new RewardEstimator();
|
|
10
|
-
}
|
|
11
|
-
/**
|
|
12
|
-
* Record a tool execution as a learning experience
|
|
13
|
-
*/
|
|
14
|
-
async recordToolExecution(toolName, args, result, context, outcome) {
|
|
15
|
-
const state = await this.captureState(context);
|
|
16
|
-
const action = {
|
|
17
|
-
tool: toolName,
|
|
18
|
-
params: args,
|
|
19
|
-
timestamp: Date.now(),
|
|
20
|
-
};
|
|
21
|
-
const reward = await this.rewardEstimator.calculateReward(outcome, context);
|
|
22
|
-
const nextState = await this.captureState({
|
|
23
|
-
...context,
|
|
24
|
-
isTerminal: outcome.success || !!outcome.error,
|
|
25
|
-
});
|
|
26
|
-
const experience = {
|
|
27
|
-
state,
|
|
28
|
-
action,
|
|
29
|
-
reward: reward.combined,
|
|
30
|
-
nextState,
|
|
31
|
-
done: context.isTerminal,
|
|
32
|
-
timestamp: Date.now(),
|
|
33
|
-
metadata: {
|
|
34
|
-
userId: context.userId,
|
|
35
|
-
sessionId: context.sessionId,
|
|
36
|
-
taskType: context.taskType,
|
|
37
|
-
actionId: `action_${this.actionCounter++}`,
|
|
38
|
-
rewardBreakdown: reward,
|
|
39
|
-
outcome: {
|
|
40
|
-
success: outcome.success,
|
|
41
|
-
executionTime: outcome.executionTime,
|
|
42
|
-
tokensUsed: outcome.tokensUsed,
|
|
43
|
-
},
|
|
44
|
-
},
|
|
45
|
-
};
|
|
46
|
-
// Store experience in vector database
|
|
47
|
-
await this.storeExperience(experience);
|
|
48
|
-
return experience;
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* Capture current state representation
|
|
52
|
-
*/
|
|
53
|
-
async captureState(context) {
|
|
54
|
-
const state = {
|
|
55
|
-
taskDescription: context.metadata?.taskDescription || '',
|
|
56
|
-
availableTools: context.metadata?.availableTools || [],
|
|
57
|
-
previousActions: context.metadata?.previousActions || [],
|
|
58
|
-
constraints: context.metadata?.constraints,
|
|
59
|
-
context: {
|
|
60
|
-
sessionId: context.sessionId,
|
|
61
|
-
taskType: context.taskType,
|
|
62
|
-
timestamp: context.timestamp,
|
|
63
|
-
},
|
|
64
|
-
};
|
|
65
|
-
// Generate state embedding for similarity search
|
|
66
|
-
state.embedding = await this.generateStateEmbedding(state);
|
|
67
|
-
return state;
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* Generate vector embedding for state
|
|
71
|
-
*/
|
|
72
|
-
async generateStateEmbedding(state) {
|
|
73
|
-
// Simple hash-based embedding (in production, use a proper embedding model)
|
|
74
|
-
const text = JSON.stringify({
|
|
75
|
-
task: state.taskDescription,
|
|
76
|
-
tools: state.availableTools,
|
|
77
|
-
type: state.context?.taskType,
|
|
78
|
-
});
|
|
79
|
-
// Create a simple hash-based embedding (768 dimensions)
|
|
80
|
-
const embedding = new Float32Array(768);
|
|
81
|
-
for (let i = 0; i < text.length; i++) {
|
|
82
|
-
const index = text.charCodeAt(i) % 768;
|
|
83
|
-
embedding[index] += 1;
|
|
84
|
-
}
|
|
85
|
-
// Normalize
|
|
86
|
-
const magnitude = Math.sqrt(embedding.reduce((sum, val) => sum + val * val, 0));
|
|
87
|
-
if (magnitude > 0) {
|
|
88
|
-
for (let i = 0; i < embedding.length; i++) {
|
|
89
|
-
embedding[i] /= magnitude;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
return embedding;
|
|
93
|
-
}
|
|
94
|
-
/**
|
|
95
|
-
* Store experience in vector database
|
|
96
|
-
*/
|
|
97
|
-
async storeExperience(experience) {
|
|
98
|
-
if (!experience.state.embedding) {
|
|
99
|
-
throw new Error('State embedding is required');
|
|
100
|
-
}
|
|
101
|
-
await this.db.insert({
|
|
102
|
-
embedding: Array.from(experience.state.embedding),
|
|
103
|
-
metadata: {
|
|
104
|
-
type: 'learning_experience',
|
|
105
|
-
sessionId: experience.metadata.sessionId,
|
|
106
|
-
userId: experience.metadata.userId,
|
|
107
|
-
taskType: experience.metadata.taskType,
|
|
108
|
-
actionId: experience.metadata.actionId,
|
|
109
|
-
action: experience.action,
|
|
110
|
-
reward: experience.reward,
|
|
111
|
-
done: experience.done,
|
|
112
|
-
timestamp: experience.timestamp,
|
|
113
|
-
state: {
|
|
114
|
-
taskDescription: experience.state.taskDescription,
|
|
115
|
-
availableTools: experience.state.availableTools,
|
|
116
|
-
previousActionsCount: experience.state.previousActions.length,
|
|
117
|
-
},
|
|
118
|
-
outcome: experience.metadata.outcome,
|
|
119
|
-
rewardBreakdown: experience.metadata.rewardBreakdown,
|
|
120
|
-
},
|
|
121
|
-
});
|
|
122
|
-
}
|
|
123
|
-
/**
|
|
124
|
-
* Retrieve similar experiences
|
|
125
|
-
*/
|
|
126
|
-
async retrieveSimilarExperiences(state, k = 10) {
|
|
127
|
-
if (!state.embedding) {
|
|
128
|
-
state.embedding = await this.generateStateEmbedding(state);
|
|
129
|
-
}
|
|
130
|
-
const results = await this.db.search(Array.from(state.embedding), k);
|
|
131
|
-
return results.map((result) => ({
|
|
132
|
-
state: {
|
|
133
|
-
taskDescription: result.metadata.state.taskDescription,
|
|
134
|
-
availableTools: result.metadata.state.availableTools,
|
|
135
|
-
previousActions: [],
|
|
136
|
-
embedding: result.embedding,
|
|
137
|
-
},
|
|
138
|
-
action: result.metadata.action,
|
|
139
|
-
reward: result.metadata.reward,
|
|
140
|
-
nextState: {
|
|
141
|
-
taskDescription: '',
|
|
142
|
-
availableTools: [],
|
|
143
|
-
previousActions: [],
|
|
144
|
-
},
|
|
145
|
-
done: result.metadata.done,
|
|
146
|
-
timestamp: result.metadata.timestamp,
|
|
147
|
-
metadata: {
|
|
148
|
-
userId: result.metadata.userId,
|
|
149
|
-
sessionId: result.metadata.sessionId,
|
|
150
|
-
taskType: result.metadata.taskType,
|
|
151
|
-
actionId: result.metadata.actionId,
|
|
152
|
-
},
|
|
153
|
-
}));
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* Get experiences by session
|
|
157
|
-
*/
|
|
158
|
-
async getSessionExperiences(sessionId) {
|
|
159
|
-
// Query by metadata filter
|
|
160
|
-
const allResults = await this.db.search(Array(768).fill(0), 1000);
|
|
161
|
-
// Filter by session ID
|
|
162
|
-
const sessionResults = allResults.filter((result) => result.metadata.sessionId === sessionId);
|
|
163
|
-
return sessionResults.map((result) => ({
|
|
164
|
-
state: {
|
|
165
|
-
taskDescription: result.metadata.state.taskDescription,
|
|
166
|
-
availableTools: result.metadata.state.availableTools,
|
|
167
|
-
previousActions: [],
|
|
168
|
-
embedding: result.embedding,
|
|
169
|
-
},
|
|
170
|
-
action: result.metadata.action,
|
|
171
|
-
reward: result.metadata.reward,
|
|
172
|
-
nextState: {
|
|
173
|
-
taskDescription: '',
|
|
174
|
-
availableTools: [],
|
|
175
|
-
previousActions: [],
|
|
176
|
-
},
|
|
177
|
-
done: result.metadata.done,
|
|
178
|
-
timestamp: result.metadata.timestamp,
|
|
179
|
-
metadata: {
|
|
180
|
-
userId: result.metadata.userId,
|
|
181
|
-
sessionId: result.metadata.sessionId,
|
|
182
|
-
taskType: result.metadata.taskType,
|
|
183
|
-
actionId: result.metadata.actionId,
|
|
184
|
-
},
|
|
185
|
-
}));
|
|
186
|
-
}
|
|
187
|
-
/**
|
|
188
|
-
* Update experience with feedback
|
|
189
|
-
*/
|
|
190
|
-
async updateExperienceReward(actionId, feedbackReward) {
|
|
191
|
-
// In a real implementation, this would update the stored experience
|
|
192
|
-
// For now, we log the feedback
|
|
193
|
-
console.log(`Updated reward for ${actionId}: ${feedbackReward}`);
|
|
194
|
-
}
|
|
195
|
-
}
|
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* LearningManager - Main orchestration layer for MCP learning integration
|
|
3
|
-
*/
|
|
4
|
-
import type { SQLiteVectorDB } from '../../../core/vector-db.js';
|
|
5
|
-
import type { Experience, Outcome, ActionPrediction, TrainingOptions, TrainingMetrics, LearningSession, FeedbackInput, LearningMetrics, TransferMetrics, State } from '../types/index.js';
|
|
6
|
-
export declare class LearningManager {
|
|
7
|
-
private db;
|
|
8
|
-
private experienceRecorder;
|
|
9
|
-
private rewardEstimator;
|
|
10
|
-
private sessionManager;
|
|
11
|
-
private policyOptimizers;
|
|
12
|
-
constructor(db: SQLiteVectorDB);
|
|
13
|
-
/**
|
|
14
|
-
* Start a new learning session
|
|
15
|
-
*/
|
|
16
|
-
startSession(userId: string, sessionType: 'coding' | 'research' | 'debugging' | 'general', plugin?: string, config?: Record<string, any>): Promise<LearningSession>;
|
|
17
|
-
/**
|
|
18
|
-
* End a learning session
|
|
19
|
-
*/
|
|
20
|
-
endSession(sessionId: string): Promise<LearningSession>;
|
|
21
|
-
/**
|
|
22
|
-
* Record a tool execution as learning experience
|
|
23
|
-
*/
|
|
24
|
-
recordExperience(sessionId: string, toolName: string, args: any, result: any, outcome: Outcome): Promise<Experience>;
|
|
25
|
-
/**
|
|
26
|
-
* Predict next best action
|
|
27
|
-
*/
|
|
28
|
-
predictAction(sessionId: string, currentState: State, availableTools: string[]): Promise<ActionPrediction>;
|
|
29
|
-
/**
|
|
30
|
-
* Provide user feedback on action
|
|
31
|
-
*/
|
|
32
|
-
provideFeedback(sessionId: string, actionId: string, feedback: FeedbackInput): Promise<void>;
|
|
33
|
-
/**
|
|
34
|
-
* Train policy on collected experiences
|
|
35
|
-
*/
|
|
36
|
-
train(sessionId: string, options?: TrainingOptions): Promise<TrainingMetrics>;
|
|
37
|
-
/**
|
|
38
|
-
* Get learning metrics
|
|
39
|
-
*/
|
|
40
|
-
getMetrics(sessionId: string, period?: 'session' | 'day' | 'week' | 'month' | 'all'): Promise<LearningMetrics>;
|
|
41
|
-
/**
|
|
42
|
-
* Transfer learning between tasks
|
|
43
|
-
*/
|
|
44
|
-
transferLearning(sourceSessionId: string, targetSessionId: string, similarity?: number): Promise<TransferMetrics>;
|
|
45
|
-
/**
|
|
46
|
-
* Explain a prediction
|
|
47
|
-
*/
|
|
48
|
-
explainPrediction(sessionId: string, state: State): Promise<{
|
|
49
|
-
reasoning: string;
|
|
50
|
-
similarExperiences: Experience[];
|
|
51
|
-
confidenceFactors: Record<string, number>;
|
|
52
|
-
}>;
|
|
53
|
-
/**
|
|
54
|
-
* Calculate consistency of actions in similar experiences
|
|
55
|
-
*/
|
|
56
|
-
private calculateConsistency;
|
|
57
|
-
/**
|
|
58
|
-
* Get session info
|
|
59
|
-
*/
|
|
60
|
-
getSessionInfo(sessionId: string): LearningSession | undefined;
|
|
61
|
-
/**
|
|
62
|
-
* Restore sessions from database
|
|
63
|
-
*/
|
|
64
|
-
restoreSessions(userId?: string): Promise<LearningSession[]>;
|
|
65
|
-
}
|
|
66
|
-
//# sourceMappingURL=learning-manager.d.ts.map
|