agentic-flow 2.0.2 → 2.0.4

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.
Files changed (324) hide show
  1. package/.claude/agents/test-neural.md +14 -0
  2. package/.claude/settings.json +9 -133
  3. package/README.md +622 -1862
  4. package/dist/.tsbuildinfo +1 -1
  5. package/dist/billing/mcp/tools.js +0 -1
  6. package/dist/billing/mcp/tools.js.map +1 -1
  7. package/dist/cli/commands/hooks.d.ts.map +1 -1
  8. package/dist/cli/commands/hooks.js +4 -79
  9. package/dist/cli/commands/hooks.js.map +1 -1
  10. package/dist/cli-proxy.js +1 -89
  11. package/dist/cli-proxy.js.map +1 -1
  12. package/dist/core/agentdb-fast.js +3 -3
  13. package/dist/core/agentdb-fast.js.map +1 -1
  14. package/dist/core/agentdb-wrapper-enhanced.d.ts.map +1 -1
  15. package/dist/core/agentdb-wrapper-enhanced.js +4 -20
  16. package/dist/core/agentdb-wrapper-enhanced.js.map +1 -1
  17. package/dist/core/agentdb-wrapper.d.ts +2 -3
  18. package/dist/core/agentdb-wrapper.d.ts.map +1 -1
  19. package/dist/core/agentdb-wrapper.js +1 -15
  20. package/dist/core/agentdb-wrapper.js.map +1 -1
  21. package/dist/core/attention-native.d.ts +0 -4
  22. package/dist/core/attention-native.d.ts.map +1 -1
  23. package/dist/core/attention-native.js +2 -14
  24. package/dist/core/attention-native.js.map +1 -1
  25. package/dist/federation/SecurityManager.d.ts +2 -11
  26. package/dist/federation/SecurityManager.d.ts.map +1 -1
  27. package/dist/federation/SecurityManager.js +17 -50
  28. package/dist/federation/SecurityManager.js.map +1 -1
  29. package/dist/federation/integrations/supabase-adapter-debug.js +3 -3
  30. package/dist/federation/integrations/supabase-adapter-debug.js.map +1 -1
  31. package/dist/hooks/swarm-learning-optimizer.js +5 -5
  32. package/dist/hooks/swarm-learning-optimizer.js.map +1 -1
  33. package/dist/intelligence/IntelligenceStore.d.ts +26 -35
  34. package/dist/intelligence/IntelligenceStore.d.ts.map +1 -1
  35. package/dist/intelligence/IntelligenceStore.js +123 -308
  36. package/dist/intelligence/IntelligenceStore.js.map +1 -1
  37. package/dist/intelligence/RuVectorIntelligence.d.ts +1 -26
  38. package/dist/intelligence/RuVectorIntelligence.d.ts.map +1 -1
  39. package/dist/intelligence/RuVectorIntelligence.js +10 -49
  40. package/dist/intelligence/RuVectorIntelligence.js.map +1 -1
  41. package/dist/intelligence/agent-booster-enhanced.d.ts +0 -1
  42. package/dist/intelligence/agent-booster-enhanced.d.ts.map +1 -1
  43. package/dist/intelligence/agent-booster-enhanced.js +3 -24
  44. package/dist/intelligence/agent-booster-enhanced.js.map +1 -1
  45. package/dist/intelligence/index.d.ts +3 -29
  46. package/dist/intelligence/index.d.ts.map +1 -1
  47. package/dist/intelligence/index.js +3 -13
  48. package/dist/intelligence/index.js.map +1 -1
  49. package/dist/mcp/claudeFlowSdkServer.d.ts.map +1 -1
  50. package/dist/mcp/claudeFlowSdkServer.js +3 -9
  51. package/dist/mcp/claudeFlowSdkServer.js.map +1 -1
  52. package/dist/mcp/fastmcp/tools/hooks/intelligence-bridge.js +5 -5
  53. package/dist/mcp/fastmcp/tools/hooks/intelligence-bridge.js.map +1 -1
  54. package/dist/mcp/fastmcp/tools/swarm/init.d.ts.map +1 -1
  55. package/dist/mcp/fastmcp/tools/swarm/init.js +7 -36
  56. package/dist/mcp/fastmcp/tools/swarm/init.js.map +1 -1
  57. package/dist/mcp/fastmcp/tools/swarm/spawn.d.ts.map +1 -1
  58. package/dist/mcp/fastmcp/tools/swarm/spawn.js +8 -47
  59. package/dist/mcp/fastmcp/tools/swarm/spawn.js.map +1 -1
  60. package/dist/mcp/tools/agent-booster-tools.d.ts +1 -1
  61. package/dist/mcp/tools/agent-booster-tools.d.ts.map +1 -1
  62. package/dist/mcp/tools/agent-booster-tools.js +4 -10
  63. package/dist/mcp/tools/agent-booster-tools.js.map +1 -1
  64. package/dist/mcp/tools/sona-tools.d.ts.map +1 -1
  65. package/dist/mcp/tools/sona-tools.js +0 -6
  66. package/dist/mcp/tools/sona-tools.js.map +1 -1
  67. package/dist/optimizations/agent-booster-migration.d.ts.map +1 -1
  68. package/dist/optimizations/agent-booster-migration.js +2 -5
  69. package/dist/optimizations/agent-booster-migration.js.map +1 -1
  70. package/dist/proxy/anthropic-to-openrouter.js.map +1 -1
  71. package/dist/proxy/anthropic-to-requesty.js.map +1 -1
  72. package/dist/proxy/quic-proxy.d.ts +1 -0
  73. package/dist/proxy/quic-proxy.d.ts.map +1 -1
  74. package/dist/proxy/quic-proxy.js +2 -2
  75. package/dist/proxy/quic-proxy.js.map +1 -1
  76. package/dist/reasoningbank/AdvancedMemory.js +1 -1
  77. package/dist/reasoningbank/AdvancedMemory.js.map +1 -1
  78. package/dist/reasoningbank/HybridBackend.d.ts.map +1 -1
  79. package/dist/reasoningbank/HybridBackend.js +5 -2
  80. package/dist/reasoningbank/HybridBackend.js.map +1 -1
  81. package/dist/reasoningbank/backend-selector.d.ts +1 -11
  82. package/dist/reasoningbank/backend-selector.d.ts.map +1 -1
  83. package/dist/reasoningbank/backend-selector.js +5 -45
  84. package/dist/reasoningbank/backend-selector.js.map +1 -1
  85. package/dist/reasoningbank/core/consolidate.d.ts.map +1 -1
  86. package/dist/reasoningbank/core/consolidate.js +45 -113
  87. package/dist/reasoningbank/core/consolidate.js.map +1 -1
  88. package/dist/reasoningbank/index-new.d.ts +6 -1
  89. package/dist/reasoningbank/index-new.d.ts.map +1 -1
  90. package/dist/reasoningbank/index-new.js +6 -1
  91. package/dist/reasoningbank/index-new.js.map +1 -1
  92. package/dist/reasoningbank/index.d.ts +6 -2
  93. package/dist/reasoningbank/index.d.ts.map +1 -1
  94. package/dist/reasoningbank/index.js +6 -2
  95. package/dist/reasoningbank/index.js.map +1 -1
  96. package/dist/reasoningbank/utils/embeddings.d.ts +0 -1
  97. package/dist/reasoningbank/utils/embeddings.d.ts.map +1 -1
  98. package/dist/reasoningbank/utils/embeddings.js +26 -53
  99. package/dist/reasoningbank/utils/embeddings.js.map +1 -1
  100. package/dist/router/index.d.ts +17 -0
  101. package/dist/router/index.d.ts.map +1 -0
  102. package/dist/router/index.js +19 -0
  103. package/dist/router/index.js.map +1 -0
  104. package/dist/router/providers/onnx-local-optimized.d.ts +0 -2
  105. package/dist/router/providers/onnx-local-optimized.d.ts.map +1 -1
  106. package/dist/router/providers/onnx-local-optimized.js +0 -10
  107. package/dist/router/providers/onnx-local-optimized.js.map +1 -1
  108. package/dist/router/providers/onnx-local.d.ts +0 -1
  109. package/dist/router/providers/onnx-local.d.ts.map +1 -1
  110. package/dist/router/providers/onnx-local.js +5 -22
  111. package/dist/router/providers/onnx-local.js.map +1 -1
  112. package/dist/services/embedding-service.js.map +1 -1
  113. package/dist/services/sona-agent-training.d.ts +0 -1
  114. package/dist/services/sona-agent-training.d.ts.map +1 -1
  115. package/dist/services/sona-agent-training.js.map +1 -1
  116. package/dist/services/sona-agentdb-integration.d.ts.map +1 -1
  117. package/dist/services/sona-agentdb-integration.js +6 -9
  118. package/dist/services/sona-agentdb-integration.js.map +1 -1
  119. package/dist/services/sona-service.d.ts.map +1 -1
  120. package/dist/services/sona-service.js +5 -6
  121. package/dist/services/sona-service.js.map +1 -1
  122. package/dist/utils/cli.d.ts +1 -1
  123. package/dist/utils/cli.d.ts.map +1 -1
  124. package/dist/utils/cli.js +0 -21
  125. package/dist/utils/cli.js.map +1 -1
  126. package/package.json +7 -19
  127. package/scripts/postinstall.js +4 -45
  128. package/wasm/reasoningbank/reasoningbank_wasm_bg.js +2 -2
  129. package/wasm/reasoningbank/reasoningbank_wasm_bg.wasm +0 -0
  130. package/.claude/agents/.claude-flow/metrics/agent-metrics.json +0 -1
  131. package/.claude/agents/.claude-flow/metrics/performance.json +0 -87
  132. package/.claude/agents/.claude-flow/metrics/task-metrics.json +0 -10
  133. package/.claude/skills/.claude-flow/metrics/agent-metrics.json +0 -1
  134. package/.claude/skills/.claude-flow/metrics/performance.json +0 -87
  135. package/.claude/skills/.claude-flow/metrics/task-metrics.json +0 -10
  136. package/.claude/skills/agentic-flow-quickstart/skill.md +0 -69
  137. package/.claude/skills/hooks-automation/skill.md +0 -155
  138. package/.claude/skills/memory-patterns/skill.md +0 -110
  139. package/.claude/skills/skill-builder/.claude-flow/metrics/agent-metrics.json +0 -1
  140. package/.claude/skills/skill-builder/.claude-flow/metrics/performance.json +0 -87
  141. package/.claude/skills/skill-builder/.claude-flow/metrics/task-metrics.json +0 -10
  142. package/.claude/skills/sparc-methodology/skill.md +0 -137
  143. package/.claude/skills/swarm-coordination/skill.md +0 -94
  144. package/.claude/skills/worker-benchmarks/skill.md +0 -135
  145. package/.claude/skills/worker-integration/skill.md +0 -154
  146. package/.claude/statusline.mjs +0 -109
  147. package/.claude/statusline.sh +0 -71
  148. package/dist/agentdb/benchmarks/comprehensive-benchmark.js +0 -664
  149. package/dist/agentdb/benchmarks/frontier-benchmark.js +0 -419
  150. package/dist/agentdb/benchmarks/reflexion-benchmark.js +0 -370
  151. package/dist/agentdb/cli/agentdb-cli.js +0 -717
  152. package/dist/agentdb/controllers/CausalMemoryGraph.js +0 -322
  153. package/dist/agentdb/controllers/CausalRecall.js +0 -281
  154. package/dist/agentdb/controllers/EmbeddingService.d.ts +0 -37
  155. package/dist/agentdb/controllers/EmbeddingService.d.ts.map +0 -1
  156. package/dist/agentdb/controllers/EmbeddingService.js +0 -119
  157. package/dist/agentdb/controllers/EmbeddingService.js.map +0 -1
  158. package/dist/agentdb/controllers/ExplainableRecall.js +0 -387
  159. package/dist/agentdb/controllers/NightlyLearner.js +0 -382
  160. package/dist/agentdb/controllers/ReflexionMemory.js +0 -239
  161. package/dist/agentdb/controllers/SkillLibrary.js +0 -276
  162. package/dist/agentdb/controllers/frontier-index.js +0 -9
  163. package/dist/agentdb/controllers/index.js +0 -8
  164. package/dist/agentdb/optimizations/BatchOperations.js +0 -198
  165. package/dist/agentdb/optimizations/QueryOptimizer.js +0 -225
  166. package/dist/agentdb/optimizations/index.js +0 -7
  167. package/dist/agentdb/tests/frontier-features.test.js +0 -665
  168. package/dist/benchmarks/embeddings-benchmark.d.ts +0 -38
  169. package/dist/benchmarks/embeddings-benchmark.d.ts.map +0 -1
  170. package/dist/benchmarks/embeddings-benchmark.js +0 -282
  171. package/dist/benchmarks/embeddings-benchmark.js.map +0 -1
  172. package/dist/cli/commands/embeddings.d.ts +0 -12
  173. package/dist/cli/commands/embeddings.d.ts.map +0 -1
  174. package/dist/cli/commands/embeddings.js +0 -386
  175. package/dist/cli/commands/embeddings.js.map +0 -1
  176. package/dist/cli/commands/init.d.ts +0 -8
  177. package/dist/cli/commands/init.d.ts.map +0 -1
  178. package/dist/cli/commands/init.js +0 -514
  179. package/dist/cli/commands/init.js.map +0 -1
  180. package/dist/cli/commands/workers.d.ts +0 -9
  181. package/dist/cli/commands/workers.d.ts.map +0 -1
  182. package/dist/cli/commands/workers.js +0 -991
  183. package/dist/cli/commands/workers.js.map +0 -1
  184. package/dist/cli/skills-manager.js +0 -1297
  185. package/dist/cli/update-message.js +0 -175
  186. package/dist/embeddings/index.d.ts +0 -17
  187. package/dist/embeddings/index.d.ts.map +0 -1
  188. package/dist/embeddings/index.js +0 -17
  189. package/dist/embeddings/index.js.map +0 -1
  190. package/dist/embeddings/neural-substrate.d.ts +0 -206
  191. package/dist/embeddings/neural-substrate.d.ts.map +0 -1
  192. package/dist/embeddings/neural-substrate.js +0 -629
  193. package/dist/embeddings/neural-substrate.js.map +0 -1
  194. package/dist/embeddings/optimized-embedder.d.ts +0 -103
  195. package/dist/embeddings/optimized-embedder.d.ts.map +0 -1
  196. package/dist/embeddings/optimized-embedder.js +0 -730
  197. package/dist/embeddings/optimized-embedder.js.map +0 -1
  198. package/dist/examples/embedding-geometry.d.ts +0 -105
  199. package/dist/examples/embedding-geometry.d.ts.map +0 -1
  200. package/dist/examples/embedding-geometry.js +0 -528
  201. package/dist/examples/embedding-geometry.js.map +0 -1
  202. package/dist/memory/SharedMemoryPool.d.ts +0 -129
  203. package/dist/memory/SharedMemoryPool.d.ts.map +0 -1
  204. package/dist/memory/SharedMemoryPool.js +0 -243
  205. package/dist/memory/SharedMemoryPool.js.map +0 -1
  206. package/dist/memory/index.d.ts +0 -8
  207. package/dist/memory/index.d.ts.map +0 -1
  208. package/dist/memory/index.js +0 -7
  209. package/dist/memory/index.js.map +0 -1
  210. package/dist/proxy/http3-proxy-old.js +0 -331
  211. package/dist/proxy/proxy/anthropic-to-gemini.js +0 -439
  212. package/dist/proxy/utils/logger.js +0 -59
  213. package/dist/reasoningbank/agentdb-adapter.js +0 -125
  214. package/dist/reasoningbank/core/database.js +0 -250
  215. package/dist/reasoningbank/core/memory-engine.js +0 -335
  216. package/dist/swarm/ipfs-swarm.d.ts +0 -265
  217. package/dist/swarm/ipfs-swarm.d.ts.map +0 -1
  218. package/dist/swarm/ipfs-swarm.js +0 -508
  219. package/dist/swarm/ipfs-swarm.js.map +0 -1
  220. package/dist/swarm/p2p-free-swarm.d.ts +0 -344
  221. package/dist/swarm/p2p-free-swarm.d.ts.map +0 -1
  222. package/dist/swarm/p2p-free-swarm.js +0 -603
  223. package/dist/swarm/p2p-free-swarm.js.map +0 -1
  224. package/dist/swarm/real-p2p-swarm.d.ts +0 -183
  225. package/dist/swarm/real-p2p-swarm.d.ts.map +0 -1
  226. package/dist/swarm/real-p2p-swarm.js +0 -469
  227. package/dist/swarm/real-p2p-swarm.js.map +0 -1
  228. package/dist/utils/adaptive-pool-sizing.js +0 -414
  229. package/dist/utils/agentdbCommands.js +0 -175
  230. package/dist/utils/circular-rate-limiter.js +0 -391
  231. package/dist/utils/dynamic-compression.js +0 -298
  232. package/dist/utils/http2-multiplexing.js +0 -319
  233. package/dist/utils/index.d.ts +0 -6
  234. package/dist/utils/index.d.ts.map +0 -1
  235. package/dist/utils/index.js +0 -6
  236. package/dist/utils/index.js.map +0 -1
  237. package/dist/utils/lazy-auth.js +0 -311
  238. package/dist/utils/model-cache.d.ts +0 -61
  239. package/dist/utils/model-cache.d.ts.map +0 -1
  240. package/dist/utils/model-cache.js +0 -176
  241. package/dist/utils/model-cache.js.map +0 -1
  242. package/dist/utils/server-push.js +0 -251
  243. package/dist/utils/suppress-warnings.d.ts +0 -19
  244. package/dist/utils/suppress-warnings.d.ts.map +0 -1
  245. package/dist/utils/suppress-warnings.js +0 -59
  246. package/dist/utils/suppress-warnings.js.map +0 -1
  247. package/dist/utils/zero-copy-buffer.js +0 -286
  248. package/dist/workers/consolidated-phases.d.ts +0 -40
  249. package/dist/workers/consolidated-phases.d.ts.map +0 -1
  250. package/dist/workers/consolidated-phases.js +0 -497
  251. package/dist/workers/consolidated-phases.js.map +0 -1
  252. package/dist/workers/custom-worker-config.d.ts +0 -133
  253. package/dist/workers/custom-worker-config.d.ts.map +0 -1
  254. package/dist/workers/custom-worker-config.js +0 -215
  255. package/dist/workers/custom-worker-config.js.map +0 -1
  256. package/dist/workers/custom-worker-factory.d.ts +0 -89
  257. package/dist/workers/custom-worker-factory.d.ts.map +0 -1
  258. package/dist/workers/custom-worker-factory.js +0 -404
  259. package/dist/workers/custom-worker-factory.js.map +0 -1
  260. package/dist/workers/dispatch-service.d.ts +0 -123
  261. package/dist/workers/dispatch-service.d.ts.map +0 -1
  262. package/dist/workers/dispatch-service.js +0 -1024
  263. package/dist/workers/dispatch-service.js.map +0 -1
  264. package/dist/workers/hooks-integration.d.ts +0 -79
  265. package/dist/workers/hooks-integration.d.ts.map +0 -1
  266. package/dist/workers/hooks-integration.js +0 -286
  267. package/dist/workers/hooks-integration.js.map +0 -1
  268. package/dist/workers/index.d.ts +0 -42
  269. package/dist/workers/index.d.ts.map +0 -1
  270. package/dist/workers/index.js +0 -52
  271. package/dist/workers/index.js.map +0 -1
  272. package/dist/workers/mcp-tools.d.ts +0 -56
  273. package/dist/workers/mcp-tools.d.ts.map +0 -1
  274. package/dist/workers/mcp-tools.js +0 -359
  275. package/dist/workers/mcp-tools.js.map +0 -1
  276. package/dist/workers/phase-executors.d.ts +0 -22
  277. package/dist/workers/phase-executors.d.ts.map +0 -1
  278. package/dist/workers/phase-executors.js +0 -445
  279. package/dist/workers/phase-executors.js.map +0 -1
  280. package/dist/workers/resource-governor.d.ts +0 -75
  281. package/dist/workers/resource-governor.d.ts.map +0 -1
  282. package/dist/workers/resource-governor.js +0 -187
  283. package/dist/workers/resource-governor.js.map +0 -1
  284. package/dist/workers/ruvector-integration.d.ts +0 -163
  285. package/dist/workers/ruvector-integration.d.ts.map +0 -1
  286. package/dist/workers/ruvector-integration.js +0 -543
  287. package/dist/workers/ruvector-integration.js.map +0 -1
  288. package/dist/workers/ruvector-native-integration.d.ts +0 -91
  289. package/dist/workers/ruvector-native-integration.d.ts.map +0 -1
  290. package/dist/workers/ruvector-native-integration.js +0 -254
  291. package/dist/workers/ruvector-native-integration.js.map +0 -1
  292. package/dist/workers/trigger-detector.d.ts +0 -68
  293. package/dist/workers/trigger-detector.d.ts.map +0 -1
  294. package/dist/workers/trigger-detector.js +0 -281
  295. package/dist/workers/trigger-detector.js.map +0 -1
  296. package/dist/workers/types.d.ts +0 -145
  297. package/dist/workers/types.d.ts.map +0 -1
  298. package/dist/workers/types.js +0 -6
  299. package/dist/workers/types.js.map +0 -1
  300. package/dist/workers/worker-agent-integration.d.ts +0 -140
  301. package/dist/workers/worker-agent-integration.d.ts.map +0 -1
  302. package/dist/workers/worker-agent-integration.js +0 -471
  303. package/dist/workers/worker-agent-integration.js.map +0 -1
  304. package/dist/workers/worker-benchmarks.d.ts +0 -88
  305. package/dist/workers/worker-benchmarks.d.ts.map +0 -1
  306. package/dist/workers/worker-benchmarks.js +0 -452
  307. package/dist/workers/worker-benchmarks.js.map +0 -1
  308. package/dist/workers/worker-registry.d.ts +0 -85
  309. package/dist/workers/worker-registry.d.ts.map +0 -1
  310. package/dist/workers/worker-registry.js +0 -547
  311. package/dist/workers/worker-registry.js.map +0 -1
  312. package/docs/.claude-flow/metrics/agent-metrics.json +0 -1
  313. package/docs/.claude-flow/metrics/performance.json +0 -87
  314. package/docs/.claude-flow/metrics/task-metrics.json +0 -10
  315. package/docs/embeddings/EMBEDDING_GEOMETRY.md +0 -935
  316. /package/.claude/agents/analysis/{analyze-code-quality.md → code-review/analyze-code-quality.md} +0 -0
  317. /package/.claude/agents/architecture/{arch-system-design.md → system-design/arch-system-design.md} +0 -0
  318. /package/.claude/agents/data/{data-ml-model.md → ml/data-ml-model.md} +0 -0
  319. /package/.claude/agents/development/{dev-backend-api.md → backend/dev-backend-api.md} +0 -0
  320. /package/.claude/agents/devops/{ops-cicd-github.md → ci-cd/ops-cicd-github.md} +0 -0
  321. /package/.claude/agents/documentation/{docs-api-openapi.md → api-docs/docs-api-openapi.md} +0 -0
  322. /package/.claude/agents/specialized/{spec-mobile-react-native.md → mobile/spec-mobile-react-native.md} +0 -0
  323. /package/.claude/agents/testing/{tdd-london-swarm.md → unit/tdd-london-swarm.md} +0 -0
  324. /package/.claude/agents/testing/{production-validator.md → validation/production-validator.md} +0 -0
@@ -1,419 +0,0 @@
1
- /**
2
- * Frontier Features Performance Benchmark
3
- *
4
- * Benchmarks:
5
- * 1. Causal edge operations (insert, query, chain traversal)
6
- * 2. A/B experiment tracking (observation recording, uplift calculation)
7
- * 3. Certificate creation (minimal hitting set, Merkle trees)
8
- * 4. Provenance tracking (lineage queries, verification)
9
- *
10
- * Performance Targets:
11
- * - Causal edge insertion: < 5ms p95
12
- * - Uplift calculation (1000 obs): < 100ms p95
13
- * - Certificate creation: < 50ms p95
14
- * - Certificate verification: < 10ms p95
15
- * - Concurrent operations: No degradation vs sequential
16
- */
17
- import Database from 'better-sqlite3';
18
- import * as fs from 'fs';
19
- import * as path from 'path';
20
- import { CausalMemoryGraph } from '../controllers/CausalMemoryGraph';
21
- import { ExplainableRecall } from '../controllers/ExplainableRecall';
22
- class FrontierBenchmark {
23
- db;
24
- causalGraph;
25
- explainableRecall;
26
- constructor() {
27
- // Use file-based database for realistic performance
28
- const dbPath = path.join(__dirname, 'frontier-benchmark.db');
29
- if (fs.existsSync(dbPath)) {
30
- fs.unlinkSync(dbPath);
31
- }
32
- this.db = new Database(dbPath);
33
- // Enable optimizations
34
- this.db.pragma('journal_mode = WAL');
35
- this.db.pragma('synchronous = NORMAL');
36
- this.db.pragma('cache_size = -64000'); // 64MB
37
- this.db.pragma('temp_store = MEMORY');
38
- // Load schemas
39
- const coreSchema = fs.readFileSync(path.join(__dirname, '../schemas/schema.sql'), 'utf-8');
40
- this.db.exec(coreSchema);
41
- const frontierSchema = fs.readFileSync(path.join(__dirname, '../schemas/frontier-schema.sql'), 'utf-8');
42
- this.db.exec(frontierSchema);
43
- this.causalGraph = new CausalMemoryGraph(this.db);
44
- this.explainableRecall = new ExplainableRecall(this.db);
45
- }
46
- cleanup() {
47
- this.db.close();
48
- const dbPath = path.join(__dirname, 'frontier-benchmark.db');
49
- if (fs.existsSync(dbPath)) {
50
- fs.unlinkSync(dbPath);
51
- }
52
- }
53
- calculatePercentile(sorted, percentile) {
54
- const index = Math.ceil((percentile / 100) * sorted.length) - 1;
55
- return sorted[index];
56
- }
57
- createResult(operation, latencies, target) {
58
- const sorted = [...latencies].sort((a, b) => a - b);
59
- const totalTimeMs = latencies.reduce((sum, t) => sum + t, 0);
60
- const avgTimeMs = totalTimeMs / latencies.length;
61
- const result = {
62
- operation,
63
- count: latencies.length,
64
- totalTimeMs,
65
- avgTimeMs,
66
- p50Ms: this.calculatePercentile(sorted, 50),
67
- p95Ms: this.calculatePercentile(sorted, 95),
68
- p99Ms: this.calculatePercentile(sorted, 99),
69
- minMs: sorted[0],
70
- maxMs: sorted[sorted.length - 1],
71
- throughput: (latencies.length / totalTimeMs) * 1000,
72
- passed: target ? this.calculatePercentile(sorted, 95) <= target : true,
73
- target
74
- };
75
- return result;
76
- }
77
- /**
78
- * Benchmark 1: Causal Edge Insertion
79
- * Target: < 5ms p95
80
- */
81
- async benchmarkCausalEdgeInsertion() {
82
- console.log('\nšŸ“Š Benchmark 1: Causal Edge Insertion');
83
- // Setup: Insert test episodes
84
- for (let i = 1; i <= 100; i++) {
85
- this.db.prepare(`
86
- INSERT INTO episodes (session_id, task, reward, success)
87
- VALUES (?, ?, ?, ?)
88
- `).run(`session${i}`, `task${i}`, 0.7 + Math.random() * 0.3, 1);
89
- }
90
- const latencies = [];
91
- const iterations = 1000;
92
- for (let i = 0; i < iterations; i++) {
93
- const fromId = (i % 100) + 1;
94
- const toId = ((i + 1) % 100) + 1;
95
- const edge = {
96
- fromMemoryId: fromId,
97
- fromMemoryType: 'episode',
98
- toMemoryId: toId,
99
- toMemoryType: 'episode',
100
- similarity: 0.7 + Math.random() * 0.3,
101
- uplift: Math.random() * 0.3 - 0.1,
102
- confidence: 0.5 + Math.random() * 0.5,
103
- sampleSize: Math.floor(Math.random() * 200) + 50,
104
- mechanism: 'automated test edge'
105
- };
106
- const start = Date.now();
107
- this.causalGraph.addCausalEdge(edge);
108
- latencies.push(Date.now() - start);
109
- }
110
- return this.createResult('Causal Edge Insertion', latencies, 5);
111
- }
112
- /**
113
- * Benchmark 2: Causal Effect Query
114
- * Target: < 20ms p95
115
- */
116
- async benchmarkCausalQuery() {
117
- console.log('\nšŸ“Š Benchmark 2: Causal Effect Query');
118
- const latencies = [];
119
- const iterations = 500;
120
- for (let i = 0; i < iterations; i++) {
121
- const memoryId = (i % 100) + 1;
122
- const start = Date.now();
123
- this.causalGraph.queryCausalEffects({
124
- interventionMemoryId: memoryId,
125
- interventionMemoryType: 'episode',
126
- minConfidence: 0.7,
127
- minUplift: 0.05
128
- });
129
- latencies.push(Date.now() - start);
130
- }
131
- return this.createResult('Causal Effect Query', latencies, 20);
132
- }
133
- /**
134
- * Benchmark 3: Causal Chain Discovery
135
- * Target: < 50ms p95
136
- */
137
- async benchmarkCausalChain() {
138
- console.log('\nšŸ“Š Benchmark 3: Causal Chain Discovery');
139
- const latencies = [];
140
- const iterations = 200;
141
- for (let i = 0; i < iterations; i++) {
142
- const fromId = (i % 50) + 1;
143
- const toId = (i % 50) + 26;
144
- const start = Date.now();
145
- this.causalGraph.getCausalChain(fromId, toId, 5);
146
- latencies.push(Date.now() - start);
147
- }
148
- return this.createResult('Causal Chain Discovery', latencies, 50);
149
- }
150
- /**
151
- * Benchmark 4: A/B Experiment Observation Recording
152
- * Target: < 3ms p95
153
- */
154
- async benchmarkExperimentObservation() {
155
- console.log('\nšŸ“Š Benchmark 4: A/B Experiment Observation Recording');
156
- // Create experiment
157
- const expId = this.causalGraph.createExperiment({
158
- name: 'Benchmark Experiment',
159
- hypothesis: 'Treatment improves outcome',
160
- treatmentId: 1,
161
- treatmentType: 'episode',
162
- startTime: Date.now(),
163
- sampleSize: 0,
164
- status: 'running'
165
- });
166
- const latencies = [];
167
- const iterations = 2000;
168
- for (let i = 0; i < iterations; i++) {
169
- const start = Date.now();
170
- this.causalGraph.recordObservation({
171
- experimentId: expId,
172
- episodeId: (i % 100) + 1,
173
- isTreatment: i % 2 === 0,
174
- outcomeValue: Math.random(),
175
- outcomeType: 'reward'
176
- });
177
- latencies.push(Date.now() - start);
178
- }
179
- return this.createResult('Experiment Observation Recording', latencies, 3);
180
- }
181
- /**
182
- * Benchmark 5: Uplift Calculation
183
- * Target: < 100ms p95 for 1000 observations
184
- */
185
- async benchmarkUpliftCalculation() {
186
- console.log('\nšŸ“Š Benchmark 5: Uplift Calculation');
187
- const latencies = [];
188
- const iterations = 50;
189
- for (let i = 0; i < iterations; i++) {
190
- // Create experiment with 1000 observations
191
- const expId = this.causalGraph.createExperiment({
192
- name: `Uplift Test ${i}`,
193
- hypothesis: 'Treatment improves outcome',
194
- treatmentId: 1,
195
- treatmentType: 'episode',
196
- startTime: Date.now(),
197
- sampleSize: 0,
198
- status: 'running'
199
- });
200
- // Record 1000 observations
201
- for (let j = 0; j < 1000; j++) {
202
- this.causalGraph.recordObservation({
203
- experimentId: expId,
204
- episodeId: (j % 100) + 1,
205
- isTreatment: j % 2 === 0,
206
- outcomeValue: (j % 2 === 0 ? 0.7 : 0.5) + Math.random() * 0.2,
207
- outcomeType: 'reward'
208
- });
209
- }
210
- // Measure uplift calculation
211
- const start = Date.now();
212
- this.causalGraph.calculateUplift(expId);
213
- latencies.push(Date.now() - start);
214
- }
215
- return this.createResult('Uplift Calculation (1000 obs)', latencies, 100);
216
- }
217
- /**
218
- * Benchmark 6: Certificate Creation
219
- * Target: < 50ms p95
220
- */
221
- async benchmarkCertificateCreation() {
222
- console.log('\nšŸ“Š Benchmark 6: Certificate Creation');
223
- const latencies = [];
224
- const iterations = 500;
225
- for (let i = 0; i < iterations; i++) {
226
- const numChunks = 10 + (i % 20); // 10-30 chunks
227
- const chunks = Array.from({ length: numChunks }, (_, idx) => ({
228
- id: `${idx + 1}`,
229
- type: 'episode',
230
- content: `Test content ${idx}`,
231
- relevance: 0.9 - idx * 0.02
232
- }));
233
- const requirements = Array.from({ length: 5 }, (_, idx) => `req${idx}`);
234
- const start = Date.now();
235
- this.explainableRecall.createCertificate({
236
- queryId: `bench_q${i}`,
237
- queryText: `Benchmark query ${i}`,
238
- chunks,
239
- requirements,
240
- accessLevel: 'internal'
241
- });
242
- latencies.push(Date.now() - start);
243
- }
244
- return this.createResult('Certificate Creation', latencies, 50);
245
- }
246
- /**
247
- * Benchmark 7: Certificate Verification
248
- * Target: < 10ms p95
249
- */
250
- async benchmarkCertificateVerification() {
251
- console.log('\nšŸ“Š Benchmark 7: Certificate Verification');
252
- // Create certificates to verify
253
- const certificateIds = [];
254
- for (let i = 0; i < 100; i++) {
255
- const chunks = Array.from({ length: 10 }, (_, idx) => ({
256
- id: `${idx + 1}`,
257
- type: 'episode',
258
- content: `Content ${idx}`,
259
- relevance: 0.9
260
- }));
261
- const cert = this.explainableRecall.createCertificate({
262
- queryId: `verify_q${i}`,
263
- queryText: `Verification test ${i}`,
264
- chunks,
265
- requirements: ['test'],
266
- accessLevel: 'internal'
267
- });
268
- certificateIds.push(cert.id);
269
- }
270
- const latencies = [];
271
- const iterations = 500;
272
- for (let i = 0; i < iterations; i++) {
273
- const certId = certificateIds[i % certificateIds.length];
274
- const start = Date.now();
275
- this.explainableRecall.verifyCertificate(certId);
276
- latencies.push(Date.now() - start);
277
- }
278
- return this.createResult('Certificate Verification', latencies, 10);
279
- }
280
- /**
281
- * Benchmark 8: Provenance Lineage Query
282
- * Target: < 15ms p95
283
- */
284
- async benchmarkProvenanceLineage() {
285
- console.log('\nšŸ“Š Benchmark 8: Provenance Lineage Query');
286
- // Create provenance sources
287
- const hashes = [];
288
- for (let i = 0; i < 100; i++) {
289
- const sourceId = this.explainableRecall.createProvenance({
290
- sourceType: 'episode',
291
- sourceId: i + 1,
292
- creator: 'benchmark_test'
293
- });
294
- const source = this.db.prepare('SELECT content_hash FROM provenance_sources WHERE id = ?').get(sourceId);
295
- hashes.push(source.content_hash);
296
- }
297
- const latencies = [];
298
- const iterations = 500;
299
- for (let i = 0; i < iterations; i++) {
300
- const hash = hashes[i % hashes.length];
301
- const start = Date.now();
302
- this.explainableRecall.getProvenanceLineage(hash);
303
- latencies.push(Date.now() - start);
304
- }
305
- return this.createResult('Provenance Lineage Query', latencies, 15);
306
- }
307
- /**
308
- * Benchmark 9: Concurrent Certificate Creation
309
- * Target: No degradation vs sequential
310
- */
311
- async benchmarkConcurrentOperations() {
312
- console.log('\nšŸ“Š Benchmark 9: Concurrent Certificate Creation');
313
- const latencies = [];
314
- const iterations = 100;
315
- const concurrency = 10;
316
- for (let i = 0; i < iterations; i++) {
317
- const start = Date.now();
318
- // Create 10 certificates concurrently (simulate with sequential for now)
319
- for (let j = 0; j < concurrency; j++) {
320
- const chunks = Array.from({ length: 10 }, (_, idx) => ({
321
- id: `${idx + 1}`,
322
- type: 'episode',
323
- content: `Concurrent content ${idx}`,
324
- relevance: 0.9
325
- }));
326
- this.explainableRecall.createCertificate({
327
- queryId: `concurrent_q${i}_${j}`,
328
- queryText: `Concurrent query ${i} ${j}`,
329
- chunks,
330
- requirements: ['test'],
331
- accessLevel: 'internal'
332
- });
333
- }
334
- latencies.push(Date.now() - start);
335
- }
336
- return this.createResult('Concurrent Operations (10x)', latencies, 500);
337
- }
338
- /**
339
- * Benchmark 10: Database Size and Memory
340
- */
341
- async benchmarkDatabaseMetrics() {
342
- console.log('\nšŸ“Š Benchmark 10: Database Metrics');
343
- const stats = this.db.prepare(`
344
- SELECT
345
- (page_count * page_size) / 1024 / 1024 as size_mb
346
- FROM pragma_page_count(), pragma_page_size()
347
- `).get();
348
- const tableStats = this.db.prepare(`
349
- SELECT
350
- name,
351
- (SELECT COUNT(*) FROM sqlite_master WHERE type='table' AND name=m.name) as table_count
352
- FROM sqlite_master m
353
- WHERE type='table'
354
- AND name IN ('causal_edges', 'causal_experiments', 'causal_observations',
355
- 'recall_certificates', 'provenance_sources', 'justification_paths')
356
- `).all();
357
- console.log(`\n Database Size: ${stats.size_mb.toFixed(2)} MB`);
358
- console.log(` Tables Created: ${tableStats.length}`);
359
- // Count records
360
- const causalEdges = this.db.prepare('SELECT COUNT(*) as count FROM causal_edges').get();
361
- const certificates = this.db.prepare('SELECT COUNT(*) as count FROM recall_certificates').get();
362
- const provenance = this.db.prepare('SELECT COUNT(*) as count FROM provenance_sources').get();
363
- console.log(`\n Causal Edges: ${causalEdges.count.toLocaleString()}`);
364
- console.log(` Certificates: ${certificates.count.toLocaleString()}`);
365
- console.log(` Provenance Sources: ${provenance.count.toLocaleString()}`);
366
- }
367
- async runAll() {
368
- console.log('═══════════════════════════════════════════════════════════');
369
- console.log(' AgentDB Frontier Features Performance Benchmark');
370
- console.log('═══════════════════════════════════════════════════════════');
371
- const results = [];
372
- try {
373
- results.push(await this.benchmarkCausalEdgeInsertion());
374
- results.push(await this.benchmarkCausalQuery());
375
- results.push(await this.benchmarkCausalChain());
376
- results.push(await this.benchmarkExperimentObservation());
377
- results.push(await this.benchmarkUpliftCalculation());
378
- results.push(await this.benchmarkCertificateCreation());
379
- results.push(await this.benchmarkCertificateVerification());
380
- results.push(await this.benchmarkProvenanceLineage());
381
- results.push(await this.benchmarkConcurrentOperations());
382
- await this.benchmarkDatabaseMetrics();
383
- // Print summary
384
- console.log('\n═══════════════════════════════════════════════════════════');
385
- console.log(' Summary');
386
- console.log('═══════════════════════════════════════════════════════════\n');
387
- results.forEach(result => {
388
- const status = result.passed ? 'āœ…' : 'āŒ';
389
- const target = result.target ? ` (target: ${result.target}ms)` : '';
390
- console.log(`${status} ${result.operation}`);
391
- console.log(` Count: ${result.count.toLocaleString()}`);
392
- console.log(` p50: ${result.p50Ms.toFixed(2)}ms | p95: ${result.p95Ms.toFixed(2)}ms | p99: ${result.p99Ms.toFixed(2)}ms${target}`);
393
- console.log(` Throughput: ${result.throughput.toFixed(0)} ops/sec`);
394
- console.log('');
395
- });
396
- // Overall pass/fail
397
- const allPassed = results.every(r => r.passed);
398
- console.log('═══════════════════════════════════════════════════════════');
399
- if (allPassed) {
400
- console.log('āœ… ALL BENCHMARKS PASSED');
401
- }
402
- else {
403
- const failed = results.filter(r => !r.passed);
404
- console.log(`āŒ ${failed.length} BENCHMARK(S) FAILED:`);
405
- failed.forEach(r => console.log(` - ${r.operation} (p95: ${r.p95Ms.toFixed(2)}ms > target: ${r.target}ms)`));
406
- }
407
- console.log('═══════════════════════════════════════════════════════════\n');
408
- }
409
- finally {
410
- this.cleanup();
411
- }
412
- }
413
- }
414
- // Run if called directly
415
- if (require.main === module) {
416
- const benchmark = new FrontierBenchmark();
417
- benchmark.runAll().catch(console.error);
418
- }
419
- export { FrontierBenchmark };