agentdb 1.0.12 → 1.1.1

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 (503) hide show
  1. package/README.md +196 -838
  2. package/dist/benchmarks/comprehensive-benchmark.js +664 -0
  3. package/dist/benchmarks/frontier-benchmark.js +419 -0
  4. package/dist/benchmarks/reflexion-benchmark.js +370 -0
  5. package/dist/cli/agentdb-cli.d.ts +117 -0
  6. package/dist/cli/agentdb-cli.d.ts.map +1 -0
  7. package/dist/cli/agentdb-cli.js +724 -0
  8. package/dist/cli/agentdb-cli.js.map +1 -0
  9. package/dist/controllers/CausalMemoryGraph.d.ts +125 -0
  10. package/dist/controllers/CausalMemoryGraph.d.ts.map +1 -0
  11. package/dist/controllers/CausalMemoryGraph.js +323 -0
  12. package/dist/controllers/CausalMemoryGraph.js.map +1 -0
  13. package/dist/controllers/CausalRecall.d.ts +111 -0
  14. package/dist/controllers/CausalRecall.d.ts.map +1 -0
  15. package/dist/controllers/CausalRecall.js +282 -0
  16. package/dist/controllers/CausalRecall.js.map +1 -0
  17. package/dist/controllers/EmbeddingService.d.ts +37 -0
  18. package/dist/controllers/EmbeddingService.d.ts.map +1 -0
  19. package/dist/controllers/EmbeddingService.js +119 -0
  20. package/dist/controllers/EmbeddingService.js.map +1 -0
  21. package/dist/controllers/ExplainableRecall.d.ts +138 -0
  22. package/dist/controllers/ExplainableRecall.d.ts.map +1 -0
  23. package/dist/controllers/ExplainableRecall.js +388 -0
  24. package/dist/controllers/ExplainableRecall.js.map +1 -0
  25. package/dist/controllers/NightlyLearner.d.ts +113 -0
  26. package/dist/controllers/NightlyLearner.d.ts.map +1 -0
  27. package/dist/controllers/NightlyLearner.js +383 -0
  28. package/dist/controllers/NightlyLearner.js.map +1 -0
  29. package/dist/controllers/ReflexionMemory.d.ts +84 -0
  30. package/dist/controllers/ReflexionMemory.d.ts.map +1 -0
  31. package/dist/controllers/ReflexionMemory.js +240 -0
  32. package/dist/controllers/ReflexionMemory.js.map +1 -0
  33. package/dist/controllers/SkillLibrary.d.ts +96 -0
  34. package/dist/controllers/SkillLibrary.d.ts.map +1 -0
  35. package/dist/controllers/SkillLibrary.js +277 -0
  36. package/dist/controllers/SkillLibrary.js.map +1 -0
  37. package/dist/controllers/frontier-index.d.ts +14 -0
  38. package/dist/controllers/frontier-index.d.ts.map +1 -0
  39. package/dist/controllers/frontier-index.js +10 -0
  40. package/dist/controllers/frontier-index.js.map +1 -0
  41. package/dist/controllers/index.d.ts +12 -0
  42. package/dist/controllers/index.d.ts.map +1 -0
  43. package/dist/controllers/index.js +9 -0
  44. package/dist/controllers/index.js.map +1 -0
  45. package/dist/optimizations/BatchOperations.d.ts +61 -0
  46. package/dist/optimizations/BatchOperations.d.ts.map +1 -0
  47. package/dist/optimizations/BatchOperations.js +199 -0
  48. package/dist/optimizations/BatchOperations.js.map +1 -0
  49. package/dist/optimizations/QueryOptimizer.d.ts +82 -0
  50. package/dist/optimizations/QueryOptimizer.d.ts.map +1 -0
  51. package/dist/optimizations/QueryOptimizer.js +226 -0
  52. package/dist/optimizations/QueryOptimizer.js.map +1 -0
  53. package/dist/optimizations/index.d.ts +10 -0
  54. package/dist/optimizations/index.d.ts.map +1 -0
  55. package/dist/optimizations/index.js +8 -0
  56. package/dist/optimizations/index.js.map +1 -0
  57. package/dist/schemas/frontier-schema.sql +341 -0
  58. package/dist/schemas/schema.sql +382 -0
  59. package/dist/tests/frontier-features.test.js +665 -0
  60. package/package.json +54 -117
  61. package/src/cli/agentdb-cli.ts +861 -0
  62. package/src/cli/examples.sh +83 -0
  63. package/src/controllers/CausalMemoryGraph.ts +504 -0
  64. package/src/controllers/CausalRecall.ts +395 -0
  65. package/src/controllers/EmbeddingService.ts +141 -0
  66. package/src/controllers/ExplainableRecall.ts +577 -0
  67. package/src/controllers/NightlyLearner.ts +475 -0
  68. package/src/controllers/ReflexionMemory.ts +349 -0
  69. package/src/controllers/SkillLibrary.ts +391 -0
  70. package/src/controllers/frontier-index.ts +35 -0
  71. package/src/controllers/index.ts +13 -0
  72. package/src/optimizations/BatchOperations.ts +292 -0
  73. package/src/optimizations/QueryOptimizer.ts +294 -0
  74. package/src/optimizations/index.ts +11 -0
  75. package/src/schemas/frontier-schema.sql +341 -0
  76. package/src/schemas/schema.sql +382 -0
  77. package/CHANGELOG.md +0 -166
  78. package/LICENSE +0 -38
  79. package/LICENSE-APACHE +0 -190
  80. package/LICENSE-MIT +0 -21
  81. package/bin/agentdb.js +0 -733
  82. package/bin/benchmark.js +0 -165
  83. package/bin/plugin-cli-wrapper.mjs +0 -21
  84. package/dist/agentdb.js +0 -5352
  85. package/dist/agentdb.js.map +0 -7
  86. package/dist/agentdb.min.js +0 -143
  87. package/dist/agentdb.min.js.map +0 -7
  88. package/dist/cache/query-cache.d.ts +0 -105
  89. package/dist/cache/query-cache.d.ts.map +0 -1
  90. package/dist/cache/query-cache.js +0 -224
  91. package/dist/cache/query-cache.js.map +0 -1
  92. package/dist/cache/query-cache.mjs +0 -219
  93. package/dist/cli/cache/query-cache.d.ts +0 -104
  94. package/dist/cli/cache/query-cache.js +0 -244
  95. package/dist/cli/cli/db-commands.d.ts +0 -48
  96. package/dist/cli/cli/db-commands.js +0 -613
  97. package/dist/cli/commands.d.ts +0 -7
  98. package/dist/cli/commands.d.ts.map +0 -1
  99. package/dist/cli/commands.js +0 -113
  100. package/dist/cli/commands.js.map +0 -1
  101. package/dist/cli/commands.mjs +0 -104
  102. package/dist/cli/core/backend-interface.d.ts +0 -70
  103. package/dist/cli/core/backend-interface.js +0 -15
  104. package/dist/cli/core/native-backend.d.ts +0 -140
  105. package/dist/cli/core/native-backend.js +0 -432
  106. package/dist/cli/core/vector-db.d.ts +0 -126
  107. package/dist/cli/core/vector-db.js +0 -338
  108. package/dist/cli/core/wasm-backend.d.ts +0 -95
  109. package/dist/cli/core/wasm-backend.js +0 -418
  110. package/dist/cli/db-commands.d.ts +0 -49
  111. package/dist/cli/db-commands.d.ts.map +0 -1
  112. package/dist/cli/db-commands.js +0 -533
  113. package/dist/cli/db-commands.js.map +0 -1
  114. package/dist/cli/db-commands.mjs +0 -522
  115. package/dist/cli/generator.d.ts +0 -11
  116. package/dist/cli/generator.d.ts.map +0 -1
  117. package/dist/cli/generator.js +0 -567
  118. package/dist/cli/generator.js.map +0 -1
  119. package/dist/cli/generator.mjs +0 -527
  120. package/dist/cli/help.d.ts +0 -18
  121. package/dist/cli/help.d.ts.map +0 -1
  122. package/dist/cli/help.js +0 -676
  123. package/dist/cli/help.js.map +0 -1
  124. package/dist/cli/help.mjs +0 -667
  125. package/dist/cli/index/hnsw.d.ts +0 -164
  126. package/dist/cli/index/hnsw.js +0 -558
  127. package/dist/cli/plugin-cli.d.ts +0 -7
  128. package/dist/cli/plugin-cli.d.ts.map +0 -1
  129. package/dist/cli/plugin-cli.js +0 -295
  130. package/dist/cli/plugin-cli.js.map +0 -1
  131. package/dist/cli/plugin-cli.mjs +0 -289
  132. package/dist/cli/quantization/product-quantization.d.ts +0 -108
  133. package/dist/cli/quantization/product-quantization.js +0 -350
  134. package/dist/cli/query/query-builder.d.ts +0 -322
  135. package/dist/cli/query/query-builder.js +0 -600
  136. package/dist/cli/templates.d.ts +0 -14
  137. package/dist/cli/templates.d.ts.map +0 -1
  138. package/dist/cli/templates.js +0 -182
  139. package/dist/cli/templates.js.map +0 -1
  140. package/dist/cli/templates.mjs +0 -176
  141. package/dist/cli/types/index.d.ts +0 -116
  142. package/dist/cli/types/index.js +0 -5
  143. package/dist/cli/types.d.ts +0 -91
  144. package/dist/cli/types.d.ts.map +0 -1
  145. package/dist/cli/types.js +0 -6
  146. package/dist/cli/types.js.map +0 -1
  147. package/dist/cli/types.mjs +0 -4
  148. package/dist/cli/wizard/index.d.ts +0 -6
  149. package/dist/cli/wizard/index.d.ts.map +0 -1
  150. package/dist/cli/wizard/index.js +0 -138
  151. package/dist/cli/wizard/index.js.map +0 -1
  152. package/dist/cli/wizard/index.mjs +0 -131
  153. package/dist/cli/wizard/prompts.d.ts +0 -11
  154. package/dist/cli/wizard/prompts.d.ts.map +0 -1
  155. package/dist/cli/wizard/prompts.js +0 -482
  156. package/dist/cli/wizard/prompts.js.map +0 -1
  157. package/dist/cli/wizard/prompts.mjs +0 -470
  158. package/dist/cli/wizard/validator.d.ts +0 -13
  159. package/dist/cli/wizard/validator.d.ts.map +0 -1
  160. package/dist/cli/wizard/validator.js +0 -234
  161. package/dist/cli/wizard/validator.js.map +0 -1
  162. package/dist/cli/wizard/validator.mjs +0 -224
  163. package/dist/core/backend-interface.d.ts +0 -71
  164. package/dist/core/backend-interface.d.ts.map +0 -1
  165. package/dist/core/backend-interface.js +0 -16
  166. package/dist/core/backend-interface.js.map +0 -1
  167. package/dist/core/backend-interface.mjs +0 -12
  168. package/dist/core/native-backend.d.ts +0 -141
  169. package/dist/core/native-backend.d.ts.map +0 -1
  170. package/dist/core/native-backend.js +0 -457
  171. package/dist/core/native-backend.js.map +0 -1
  172. package/dist/core/native-backend.mjs +0 -449
  173. package/dist/core/vector-db.d.ts +0 -127
  174. package/dist/core/vector-db.d.ts.map +0 -1
  175. package/dist/core/vector-db.js +0 -270
  176. package/dist/core/vector-db.js.map +0 -1
  177. package/dist/core/vector-db.mjs +0 -265
  178. package/dist/core/wasm-backend.d.ts +0 -96
  179. package/dist/core/wasm-backend.d.ts.map +0 -1
  180. package/dist/core/wasm-backend.js +0 -393
  181. package/dist/core/wasm-backend.js.map +0 -1
  182. package/dist/core/wasm-backend.mjs +0 -385
  183. package/dist/index/hnsw-optimized.d.ts +0 -75
  184. package/dist/index/hnsw-optimized.d.ts.map +0 -1
  185. package/dist/index/hnsw-optimized.js +0 -412
  186. package/dist/index/hnsw-optimized.js.map +0 -1
  187. package/dist/index/hnsw-optimized.mjs +0 -407
  188. package/dist/index/hnsw.d.ts +0 -165
  189. package/dist/index/hnsw.d.ts.map +0 -1
  190. package/dist/index/hnsw.js +0 -521
  191. package/dist/index/hnsw.js.map +0 -1
  192. package/dist/index/hnsw.mjs +0 -516
  193. package/dist/index.browser.d.ts +0 -47
  194. package/dist/index.browser.d.ts.map +0 -1
  195. package/dist/index.browser.js +0 -72
  196. package/dist/index.browser.js.map +0 -1
  197. package/dist/index.browser.mjs +0 -54
  198. package/dist/index.d.ts +0 -59
  199. package/dist/index.d.ts.map +0 -1
  200. package/dist/index.js +0 -84
  201. package/dist/index.js.map +0 -1
  202. package/dist/index.mjs +0 -65
  203. package/dist/mcp/learning/core/experience-buffer.d.ts +0 -61
  204. package/dist/mcp/learning/core/experience-buffer.d.ts.map +0 -1
  205. package/dist/mcp/learning/core/experience-buffer.js +0 -175
  206. package/dist/mcp/learning/core/experience-buffer.js.map +0 -1
  207. package/dist/mcp/learning/core/experience-buffer.mjs +0 -170
  208. package/dist/mcp/learning/core/experience-recorder.d.ts +0 -40
  209. package/dist/mcp/learning/core/experience-recorder.d.ts.map +0 -1
  210. package/dist/mcp/learning/core/experience-recorder.js +0 -200
  211. package/dist/mcp/learning/core/experience-recorder.js.map +0 -1
  212. package/dist/mcp/learning/core/experience-recorder.mjs +0 -195
  213. package/dist/mcp/learning/core/learning-manager.d.ts +0 -66
  214. package/dist/mcp/learning/core/learning-manager.d.ts.map +0 -1
  215. package/dist/mcp/learning/core/learning-manager.js +0 -252
  216. package/dist/mcp/learning/core/learning-manager.js.map +0 -1
  217. package/dist/mcp/learning/core/learning-manager.mjs +0 -247
  218. package/dist/mcp/learning/core/policy-optimizer.d.ts +0 -53
  219. package/dist/mcp/learning/core/policy-optimizer.d.ts.map +0 -1
  220. package/dist/mcp/learning/core/policy-optimizer.js +0 -251
  221. package/dist/mcp/learning/core/policy-optimizer.js.map +0 -1
  222. package/dist/mcp/learning/core/policy-optimizer.mjs +0 -246
  223. package/dist/mcp/learning/core/reward-estimator.d.ts +0 -44
  224. package/dist/mcp/learning/core/reward-estimator.d.ts.map +0 -1
  225. package/dist/mcp/learning/core/reward-estimator.js +0 -158
  226. package/dist/mcp/learning/core/reward-estimator.js.map +0 -1
  227. package/dist/mcp/learning/core/reward-estimator.mjs +0 -153
  228. package/dist/mcp/learning/core/session-manager.d.ts +0 -63
  229. package/dist/mcp/learning/core/session-manager.d.ts.map +0 -1
  230. package/dist/mcp/learning/core/session-manager.js +0 -202
  231. package/dist/mcp/learning/core/session-manager.js.map +0 -1
  232. package/dist/mcp/learning/core/session-manager.mjs +0 -197
  233. package/dist/mcp/learning/index.d.ts +0 -19
  234. package/dist/mcp/learning/index.d.ts.map +0 -1
  235. package/dist/mcp/learning/index.js +0 -30
  236. package/dist/mcp/learning/index.js.map +0 -1
  237. package/dist/mcp/learning/index.mjs +0 -19
  238. package/dist/mcp/learning/tools/mcp-learning-tools.d.ts +0 -369
  239. package/dist/mcp/learning/tools/mcp-learning-tools.d.ts.map +0 -1
  240. package/dist/mcp/learning/tools/mcp-learning-tools.js +0 -361
  241. package/dist/mcp/learning/tools/mcp-learning-tools.js.map +0 -1
  242. package/dist/mcp/learning/tools/mcp-learning-tools.mjs +0 -356
  243. package/dist/mcp/learning/types/index.d.ts +0 -138
  244. package/dist/mcp/learning/types/index.d.ts.map +0 -1
  245. package/dist/mcp/learning/types/index.js +0 -6
  246. package/dist/mcp/learning/types/index.js.map +0 -1
  247. package/dist/mcp/learning/types/index.mjs +0 -4
  248. package/dist/mcp-server.d.ts +0 -29
  249. package/dist/mcp-server.d.ts.map +0 -1
  250. package/dist/mcp-server.js +0 -862
  251. package/dist/mcp-server.js.map +0 -1
  252. package/dist/mcp-server.mjs +0 -857
  253. package/dist/plugins/base-plugin.d.ts +0 -114
  254. package/dist/plugins/base-plugin.d.ts.map +0 -1
  255. package/dist/plugins/base-plugin.js +0 -313
  256. package/dist/plugins/base-plugin.js.map +0 -1
  257. package/dist/plugins/base-plugin.mjs +0 -275
  258. package/dist/plugins/implementations/active-learning.d.ts +0 -135
  259. package/dist/plugins/implementations/active-learning.d.ts.map +0 -1
  260. package/dist/plugins/implementations/active-learning.js +0 -372
  261. package/dist/plugins/implementations/active-learning.js.map +0 -1
  262. package/dist/plugins/implementations/active-learning.mjs +0 -367
  263. package/dist/plugins/implementations/actor-critic.d.ts +0 -64
  264. package/dist/plugins/implementations/actor-critic.d.ts.map +0 -1
  265. package/dist/plugins/implementations/actor-critic.js +0 -363
  266. package/dist/plugins/implementations/actor-critic.js.map +0 -1
  267. package/dist/plugins/implementations/actor-critic.mjs +0 -358
  268. package/dist/plugins/implementations/adversarial-training.d.ts +0 -133
  269. package/dist/plugins/implementations/adversarial-training.d.ts.map +0 -1
  270. package/dist/plugins/implementations/adversarial-training.js +0 -409
  271. package/dist/plugins/implementations/adversarial-training.js.map +0 -1
  272. package/dist/plugins/implementations/adversarial-training.mjs +0 -404
  273. package/dist/plugins/implementations/curriculum-learning.d.ts +0 -132
  274. package/dist/plugins/implementations/curriculum-learning.d.ts.map +0 -1
  275. package/dist/plugins/implementations/curriculum-learning.js +0 -354
  276. package/dist/plugins/implementations/curriculum-learning.js.map +0 -1
  277. package/dist/plugins/implementations/curriculum-learning.mjs +0 -349
  278. package/dist/plugins/implementations/decision-transformer.d.ts +0 -77
  279. package/dist/plugins/implementations/decision-transformer.d.ts.map +0 -1
  280. package/dist/plugins/implementations/decision-transformer.js +0 -422
  281. package/dist/plugins/implementations/decision-transformer.js.map +0 -1
  282. package/dist/plugins/implementations/decision-transformer.mjs +0 -417
  283. package/dist/plugins/implementations/federated-learning.d.ts +0 -126
  284. package/dist/plugins/implementations/federated-learning.d.ts.map +0 -1
  285. package/dist/plugins/implementations/federated-learning.js +0 -436
  286. package/dist/plugins/implementations/federated-learning.js.map +0 -1
  287. package/dist/plugins/implementations/federated-learning.mjs +0 -431
  288. package/dist/plugins/implementations/index.d.ts +0 -30
  289. package/dist/plugins/implementations/index.d.ts.map +0 -1
  290. package/dist/plugins/implementations/index.js +0 -45
  291. package/dist/plugins/implementations/index.js.map +0 -1
  292. package/dist/plugins/implementations/index.mjs +0 -31
  293. package/dist/plugins/implementations/multi-task-learning.d.ts +0 -115
  294. package/dist/plugins/implementations/multi-task-learning.d.ts.map +0 -1
  295. package/dist/plugins/implementations/multi-task-learning.js +0 -369
  296. package/dist/plugins/implementations/multi-task-learning.js.map +0 -1
  297. package/dist/plugins/implementations/multi-task-learning.mjs +0 -364
  298. package/dist/plugins/implementations/neural-architecture-search.d.ts +0 -148
  299. package/dist/plugins/implementations/neural-architecture-search.d.ts.map +0 -1
  300. package/dist/plugins/implementations/neural-architecture-search.js +0 -379
  301. package/dist/plugins/implementations/neural-architecture-search.js.map +0 -1
  302. package/dist/plugins/implementations/neural-architecture-search.mjs +0 -374
  303. package/dist/plugins/implementations/q-learning.d.ts +0 -98
  304. package/dist/plugins/implementations/q-learning.d.ts.map +0 -1
  305. package/dist/plugins/implementations/q-learning.js +0 -435
  306. package/dist/plugins/implementations/q-learning.js.map +0 -1
  307. package/dist/plugins/implementations/q-learning.mjs +0 -430
  308. package/dist/plugins/implementations/sarsa.d.ts +0 -103
  309. package/dist/plugins/implementations/sarsa.d.ts.map +0 -1
  310. package/dist/plugins/implementations/sarsa.js +0 -347
  311. package/dist/plugins/implementations/sarsa.js.map +0 -1
  312. package/dist/plugins/implementations/sarsa.mjs +0 -342
  313. package/dist/plugins/index.d.ts +0 -107
  314. package/dist/plugins/index.d.ts.map +0 -1
  315. package/dist/plugins/index.js +0 -179
  316. package/dist/plugins/index.js.map +0 -1
  317. package/dist/plugins/index.mjs +0 -168
  318. package/dist/plugins/interface.d.ts +0 -439
  319. package/dist/plugins/interface.d.ts.map +0 -1
  320. package/dist/plugins/interface.js +0 -12
  321. package/dist/plugins/interface.js.map +0 -1
  322. package/dist/plugins/interface.mjs +0 -10
  323. package/dist/plugins/learning-plugin.interface.d.ts +0 -257
  324. package/dist/plugins/learning-plugin.interface.d.ts.map +0 -1
  325. package/dist/plugins/learning-plugin.interface.js +0 -7
  326. package/dist/plugins/learning-plugin.interface.js.map +0 -1
  327. package/dist/plugins/learning-plugin.interface.mjs +0 -5
  328. package/dist/plugins/plugin-exports.d.ts +0 -71
  329. package/dist/plugins/plugin-exports.d.ts.map +0 -1
  330. package/dist/plugins/plugin-exports.js +0 -78
  331. package/dist/plugins/plugin-exports.js.map +0 -1
  332. package/dist/plugins/plugin-exports.mjs +0 -69
  333. package/dist/plugins/registry.d.ts +0 -206
  334. package/dist/plugins/registry.d.ts.map +0 -1
  335. package/dist/plugins/registry.js +0 -365
  336. package/dist/plugins/registry.js.map +0 -1
  337. package/dist/plugins/registry.mjs +0 -356
  338. package/dist/plugins/validator.d.ts +0 -63
  339. package/dist/plugins/validator.d.ts.map +0 -1
  340. package/dist/plugins/validator.js +0 -464
  341. package/dist/plugins/validator.js.map +0 -1
  342. package/dist/plugins/validator.mjs +0 -458
  343. package/dist/presets.d.ts +0 -65
  344. package/dist/presets.d.ts.map +0 -1
  345. package/dist/presets.js +0 -145
  346. package/dist/presets.js.map +0 -1
  347. package/dist/presets.mjs +0 -140
  348. package/dist/quantization/binary-quantization.d.ts +0 -104
  349. package/dist/quantization/binary-quantization.d.ts.map +0 -1
  350. package/dist/quantization/binary-quantization.js +0 -246
  351. package/dist/quantization/binary-quantization.js.map +0 -1
  352. package/dist/quantization/binary-quantization.mjs +0 -240
  353. package/dist/quantization/optimized-pq.d.ts +0 -138
  354. package/dist/quantization/optimized-pq.d.ts.map +0 -1
  355. package/dist/quantization/optimized-pq.js +0 -320
  356. package/dist/quantization/optimized-pq.js.map +0 -1
  357. package/dist/quantization/optimized-pq.mjs +0 -313
  358. package/dist/quantization/product-quantization.d.ts +0 -109
  359. package/dist/quantization/product-quantization.d.ts.map +0 -1
  360. package/dist/quantization/product-quantization.js +0 -287
  361. package/dist/quantization/product-quantization.js.map +0 -1
  362. package/dist/quantization/product-quantization.mjs +0 -282
  363. package/dist/quantization/scalar-quantization.d.ts +0 -100
  364. package/dist/quantization/scalar-quantization.d.ts.map +0 -1
  365. package/dist/quantization/scalar-quantization.js +0 -324
  366. package/dist/quantization/scalar-quantization.js.map +0 -1
  367. package/dist/quantization/scalar-quantization.mjs +0 -319
  368. package/dist/query/index.d.ts +0 -6
  369. package/dist/query/index.d.ts.map +0 -1
  370. package/dist/query/index.js +0 -9
  371. package/dist/query/index.js.map +0 -1
  372. package/dist/query/index.mjs +0 -4
  373. package/dist/query/query-builder.d.ts +0 -323
  374. package/dist/query/query-builder.d.ts.map +0 -1
  375. package/dist/query/query-builder.js +0 -524
  376. package/dist/query/query-builder.js.map +0 -1
  377. package/dist/query/query-builder.mjs +0 -519
  378. package/dist/reasoning/context-synthesizer.d.ts +0 -57
  379. package/dist/reasoning/context-synthesizer.d.ts.map +0 -1
  380. package/dist/reasoning/context-synthesizer.js +0 -224
  381. package/dist/reasoning/context-synthesizer.js.map +0 -1
  382. package/dist/reasoning/context-synthesizer.mjs +0 -219
  383. package/dist/reasoning/experience-curator.d.ts +0 -66
  384. package/dist/reasoning/experience-curator.d.ts.map +0 -1
  385. package/dist/reasoning/experience-curator.js +0 -288
  386. package/dist/reasoning/experience-curator.js.map +0 -1
  387. package/dist/reasoning/experience-curator.mjs +0 -283
  388. package/dist/reasoning/memory-optimizer.d.ts +0 -69
  389. package/dist/reasoning/memory-optimizer.d.ts.map +0 -1
  390. package/dist/reasoning/memory-optimizer.js +0 -331
  391. package/dist/reasoning/memory-optimizer.js.map +0 -1
  392. package/dist/reasoning/memory-optimizer.mjs +0 -326
  393. package/dist/reasoning/pattern-matcher.d.ts +0 -59
  394. package/dist/reasoning/pattern-matcher.d.ts.map +0 -1
  395. package/dist/reasoning/pattern-matcher.js +0 -229
  396. package/dist/reasoning/pattern-matcher.js.map +0 -1
  397. package/dist/reasoning/pattern-matcher.mjs +0 -224
  398. package/dist/reasoningbank/adapter/agentdb-adapter.d.ts +0 -118
  399. package/dist/reasoningbank/adapter/agentdb-adapter.d.ts.map +0 -1
  400. package/dist/reasoningbank/adapter/agentdb-adapter.js +0 -477
  401. package/dist/reasoningbank/adapter/agentdb-adapter.js.map +0 -1
  402. package/dist/reasoningbank/adapter/types.d.ts +0 -113
  403. package/dist/reasoningbank/adapter/types.d.ts.map +0 -1
  404. package/dist/reasoningbank/adapter/types.js +0 -9
  405. package/dist/reasoningbank/adapter/types.js.map +0 -1
  406. package/dist/reasoningbank/cli/commands.d.ts +0 -16
  407. package/dist/reasoningbank/cli/commands.d.ts.map +0 -1
  408. package/dist/reasoningbank/cli/commands.js +0 -272
  409. package/dist/reasoningbank/cli/commands.js.map +0 -1
  410. package/dist/reasoningbank/mcp/agentdb-tools.d.ts +0 -319
  411. package/dist/reasoningbank/mcp/agentdb-tools.d.ts.map +0 -1
  412. package/dist/reasoningbank/mcp/agentdb-tools.js +0 -301
  413. package/dist/reasoningbank/mcp/agentdb-tools.js.map +0 -1
  414. package/dist/reasoningbank/migration/migrate.d.ts +0 -25
  415. package/dist/reasoningbank/migration/migrate.d.ts.map +0 -1
  416. package/dist/reasoningbank/migration/migrate.js +0 -178
  417. package/dist/reasoningbank/migration/migrate.js.map +0 -1
  418. package/dist/reasoningbank/reasoning/context-synthesizer.d.ts +0 -37
  419. package/dist/reasoningbank/reasoning/context-synthesizer.d.ts.map +0 -1
  420. package/dist/reasoningbank/reasoning/context-synthesizer.js +0 -114
  421. package/dist/reasoningbank/reasoning/context-synthesizer.js.map +0 -1
  422. package/dist/reasoningbank/reasoning/experience-curator.d.ts +0 -39
  423. package/dist/reasoningbank/reasoning/experience-curator.d.ts.map +0 -1
  424. package/dist/reasoningbank/reasoning/experience-curator.js +0 -98
  425. package/dist/reasoningbank/reasoning/experience-curator.js.map +0 -1
  426. package/dist/reasoningbank/reasoning/memory-optimizer.d.ts +0 -44
  427. package/dist/reasoningbank/reasoning/memory-optimizer.d.ts.map +0 -1
  428. package/dist/reasoningbank/reasoning/memory-optimizer.js +0 -184
  429. package/dist/reasoningbank/reasoning/memory-optimizer.js.map +0 -1
  430. package/dist/reasoningbank/reasoning/pattern-matcher.d.ts +0 -40
  431. package/dist/reasoningbank/reasoning/pattern-matcher.d.ts.map +0 -1
  432. package/dist/reasoningbank/reasoning/pattern-matcher.js +0 -87
  433. package/dist/reasoningbank/reasoning/pattern-matcher.js.map +0 -1
  434. package/dist/reasoningbank/sync/quic-sync.d.ts +0 -77
  435. package/dist/reasoningbank/sync/quic-sync.d.ts.map +0 -1
  436. package/dist/reasoningbank/sync/quic-sync.js +0 -165
  437. package/dist/reasoningbank/sync/quic-sync.js.map +0 -1
  438. package/dist/sync/conflict.d.ts +0 -78
  439. package/dist/sync/conflict.d.ts.map +0 -1
  440. package/dist/sync/conflict.js +0 -202
  441. package/dist/sync/conflict.js.map +0 -1
  442. package/dist/sync/conflict.mjs +0 -196
  443. package/dist/sync/coordinator.d.ts +0 -111
  444. package/dist/sync/coordinator.d.ts.map +0 -1
  445. package/dist/sync/coordinator.js +0 -256
  446. package/dist/sync/coordinator.js.map +0 -1
  447. package/dist/sync/coordinator.mjs +0 -250
  448. package/dist/sync/delta.d.ts +0 -81
  449. package/dist/sync/delta.d.ts.map +0 -1
  450. package/dist/sync/delta.js +0 -245
  451. package/dist/sync/delta.js.map +0 -1
  452. package/dist/sync/delta.mjs +0 -238
  453. package/dist/sync/index.d.ts +0 -11
  454. package/dist/sync/index.d.ts.map +0 -1
  455. package/dist/sync/index.js +0 -22
  456. package/dist/sync/index.js.map +0 -1
  457. package/dist/sync/index.mjs +0 -9
  458. package/dist/sync/quic-sync.d.ts +0 -81
  459. package/dist/sync/quic-sync.d.ts.map +0 -1
  460. package/dist/sync/quic-sync.js +0 -329
  461. package/dist/sync/quic-sync.js.map +0 -1
  462. package/dist/sync/quic-sync.mjs +0 -323
  463. package/dist/sync/types.d.ts +0 -168
  464. package/dist/sync/types.d.ts.map +0 -1
  465. package/dist/sync/types.js +0 -8
  466. package/dist/sync/types.js.map +0 -1
  467. package/dist/sync/types.mjs +0 -6
  468. package/dist/types/index.d.ts +0 -117
  469. package/dist/types/index.d.ts.map +0 -1
  470. package/dist/types/index.js +0 -6
  471. package/dist/types/index.js.map +0 -1
  472. package/dist/types/index.mjs +0 -4
  473. package/dist/wasm/sql-wasm-debug.js +0 -6989
  474. package/dist/wasm/sql-wasm-debug.wasm +0 -0
  475. package/dist/wasm/sql-wasm.js +0 -188
  476. package/dist/wasm/sql-wasm.wasm +0 -0
  477. package/dist/wasm-loader.d.ts +0 -32
  478. package/dist/wasm-loader.d.ts.map +0 -1
  479. package/dist/wasm-loader.js +0 -78
  480. package/dist/wasm-loader.js.map +0 -1
  481. package/dist/wasm-loader.mjs +0 -67
  482. package/examples/adaptive-learning.ts +0 -284
  483. package/examples/browser/README.md +0 -732
  484. package/examples/browser/adaptive-recommendations/index.html +0 -427
  485. package/examples/browser/collaborative-filtering/index.html +0 -310
  486. package/examples/browser/continual-learning/index.html +0 -736
  487. package/examples/browser/experience-replay/index.html +0 -616
  488. package/examples/browser/index.html +0 -369
  489. package/examples/browser/meta-learning/index.html +0 -789
  490. package/examples/browser/neuro-symbolic/index.html +0 -692
  491. package/examples/browser/pattern-learning/index.html +0 -620
  492. package/examples/browser/quantum-inspired/index.html +0 -728
  493. package/examples/browser/rag/index.html +0 -624
  494. package/examples/browser/swarm-intelligence/index.html +0 -811
  495. package/examples/browser-basic.html +0 -170
  496. package/examples/browser-wasm-real.html +0 -231
  497. package/examples/hnsw-example.ts +0 -148
  498. package/examples/mcp-learning-example.ts +0 -220
  499. package/examples/node-basic.js +0 -70
  500. package/examples/quic-sync-example.ts +0 -310
  501. package/examples/quick-start.js +0 -68
  502. package/examples/test-v1.0.7-cdn.html +0 -190
  503. package/examples/wasm-example.ts +0 -222
@@ -1,287 +0,0 @@
1
- "use strict";
2
- /**
3
- * Product Quantization (PQ) for 4-32x vector compression
4
- *
5
- * Reduces storage requirements while maintaining 95%+ search accuracy.
6
- * Splits vectors into subvectors and quantizes each independently.
7
- *
8
- * @example
9
- * ```typescript
10
- * const pq = new ProductQuantizer({ dimensions: 768, subvectors: 8, bits: 8 });
11
- * await pq.train(trainingVectors); // Train codebooks
12
- *
13
- * // Compress vectors (768 floats → 8 bytes = 96x reduction)
14
- * const codes = pq.encode(vector);
15
- *
16
- * // Decompress for similarity search
17
- * const approximation = pq.decode(codes);
18
- * ```
19
- */
20
- Object.defineProperty(exports, "__esModule", { value: true });
21
- exports.ProductQuantizer = void 0;
22
- class ProductQuantizer {
23
- constructor(config) {
24
- this.codebooks = [];
25
- this.trained = false;
26
- // Statistics
27
- this.stats = {
28
- encodeCount: 0,
29
- decodeCount: 0,
30
- totalEncodeTime: 0,
31
- totalDecodeTime: 0
32
- };
33
- this.config = {
34
- dimensions: config.dimensions,
35
- subvectors: config.subvectors,
36
- bits: config.bits,
37
- kmeansIterations: config.kmeansIterations ?? 20,
38
- enableStats: config.enableStats ?? true
39
- };
40
- if (config.dimensions % config.subvectors !== 0) {
41
- throw new Error(`Dimensions (${config.dimensions}) must be divisible by subvectors (${config.subvectors})`);
42
- }
43
- this.subvectorDim = config.dimensions / config.subvectors;
44
- }
45
- /**
46
- * Train codebooks using k-means clustering on training vectors
47
- */
48
- async train(trainingVectors) {
49
- if (trainingVectors.length === 0) {
50
- throw new Error('Training vectors cannot be empty');
51
- }
52
- const numCentroids = Math.pow(2, this.config.bits);
53
- this.codebooks = [];
54
- // Train one codebook per subvector
55
- for (let m = 0; m < this.config.subvectors; m++) {
56
- const subvectors = this.extractSubvectors(trainingVectors, m);
57
- const centroids = this.trainKMeans(subvectors, numCentroids);
58
- this.codebooks.push({ centroids });
59
- }
60
- this.trained = true;
61
- }
62
- /**
63
- * Extract subvectors for a specific segment
64
- */
65
- extractSubvectors(vectors, segmentIndex) {
66
- const start = segmentIndex * this.subvectorDim;
67
- const end = start + this.subvectorDim;
68
- return vectors.map(v => v.slice(start, end));
69
- }
70
- /**
71
- * Train k-means clustering to create centroids
72
- */
73
- trainKMeans(vectors, k) {
74
- const n = vectors.length;
75
- const d = vectors[0].length;
76
- // Initialize centroids randomly
77
- const centroids = [];
78
- const indices = new Set();
79
- while (centroids.length < Math.min(k, n)) {
80
- const idx = Math.floor(Math.random() * n);
81
- if (!indices.has(idx)) {
82
- centroids.push([...vectors[idx]]);
83
- indices.add(idx);
84
- }
85
- }
86
- // K-means iterations
87
- for (let iter = 0; iter < this.config.kmeansIterations; iter++) {
88
- // Assignment step
89
- const assignments = new Array(n).fill(0);
90
- for (let i = 0; i < n; i++) {
91
- let minDist = Infinity;
92
- let bestCluster = 0;
93
- for (let c = 0; c < centroids.length; c++) {
94
- const dist = this.euclideanDistance(vectors[i], centroids[c]);
95
- if (dist < minDist) {
96
- minDist = dist;
97
- bestCluster = c;
98
- }
99
- }
100
- assignments[i] = bestCluster;
101
- }
102
- // Update step
103
- const clusterSums = Array(centroids.length)
104
- .fill(0)
105
- .map(() => Array(d).fill(0));
106
- const clusterCounts = Array(centroids.length).fill(0);
107
- for (let i = 0; i < n; i++) {
108
- const cluster = assignments[i];
109
- clusterCounts[cluster]++;
110
- for (let j = 0; j < d; j++) {
111
- clusterSums[cluster][j] += vectors[i][j];
112
- }
113
- }
114
- // Update centroids
115
- for (let c = 0; c < centroids.length; c++) {
116
- if (clusterCounts[c] > 0) {
117
- for (let j = 0; j < d; j++) {
118
- centroids[c][j] = clusterSums[c][j] / clusterCounts[c];
119
- }
120
- }
121
- }
122
- }
123
- // Fill remaining centroids if k > n
124
- while (centroids.length < k) {
125
- centroids.push(Array(d).fill(0));
126
- }
127
- return centroids;
128
- }
129
- /**
130
- * Encode vector into quantized codes
131
- */
132
- encode(vector) {
133
- if (!this.trained) {
134
- throw new Error('Quantizer must be trained before encoding');
135
- }
136
- if (vector.length !== this.config.dimensions) {
137
- throw new Error(`Vector dimension (${vector.length}) does not match config (${this.config.dimensions})`);
138
- }
139
- const startTime = performance.now();
140
- const codes = new Uint8Array(this.config.subvectors);
141
- for (let m = 0; m < this.config.subvectors; m++) {
142
- const start = m * this.subvectorDim;
143
- const end = start + this.subvectorDim;
144
- const subvector = vector.slice(start, end);
145
- // Find nearest centroid
146
- let minDist = Infinity;
147
- let bestCode = 0;
148
- for (let c = 0; c < this.codebooks[m].centroids.length; c++) {
149
- const dist = this.euclideanDistance(subvector, this.codebooks[m].centroids[c]);
150
- if (dist < minDist) {
151
- minDist = dist;
152
- bestCode = c;
153
- }
154
- }
155
- codes[m] = bestCode;
156
- }
157
- if (this.config.enableStats) {
158
- this.stats.encodeCount++;
159
- this.stats.totalEncodeTime += performance.now() - startTime;
160
- }
161
- return codes;
162
- }
163
- /**
164
- * Decode quantized codes back to approximate vector
165
- */
166
- decode(codes) {
167
- if (!this.trained) {
168
- throw new Error('Quantizer must be trained before decoding');
169
- }
170
- if (codes.length !== this.config.subvectors) {
171
- throw new Error(`Code length (${codes.length}) does not match subvectors (${this.config.subvectors})`);
172
- }
173
- const startTime = performance.now();
174
- const vector = [];
175
- for (let m = 0; m < this.config.subvectors; m++) {
176
- const code = codes[m];
177
- const centroid = this.codebooks[m].centroids[code];
178
- vector.push(...centroid);
179
- }
180
- if (this.config.enableStats) {
181
- this.stats.decodeCount++;
182
- this.stats.totalDecodeTime += performance.now() - startTime;
183
- }
184
- return vector;
185
- }
186
- /**
187
- * Compute asymmetric distance for faster search
188
- * Compare query vector directly with quantized database vectors
189
- */
190
- asymmetricDistance(query, codes) {
191
- if (!this.trained) {
192
- throw new Error('Quantizer must be trained before computing distances');
193
- }
194
- let distance = 0;
195
- for (let m = 0; m < this.config.subvectors; m++) {
196
- const start = m * this.subvectorDim;
197
- const end = start + this.subvectorDim;
198
- const querySubvector = query.slice(start, end);
199
- const code = codes[m];
200
- const centroid = this.codebooks[m].centroids[code];
201
- distance += this.euclideanDistanceSquared(querySubvector, centroid);
202
- }
203
- return Math.sqrt(distance);
204
- }
205
- /**
206
- * Euclidean distance between two vectors
207
- */
208
- euclideanDistance(a, b) {
209
- return Math.sqrt(this.euclideanDistanceSquared(a, b));
210
- }
211
- /**
212
- * Squared Euclidean distance (faster, no sqrt)
213
- */
214
- euclideanDistanceSquared(a, b) {
215
- let sum = 0;
216
- for (let i = 0; i < a.length; i++) {
217
- const diff = a[i] - b[i];
218
- sum += diff * diff;
219
- }
220
- return sum;
221
- }
222
- /**
223
- * Get compression statistics
224
- */
225
- getStats() {
226
- const originalSize = this.config.dimensions * 4; // 4 bytes per float32
227
- const compressedSize = this.config.subvectors; // 1 byte per subvector
228
- return {
229
- originalSize,
230
- compressedSize,
231
- compressionRatio: originalSize / compressedSize,
232
- encodeCount: this.stats.encodeCount,
233
- decodeCount: this.stats.decodeCount,
234
- avgEncodeTime: this.stats.encodeCount > 0
235
- ? this.stats.totalEncodeTime / this.stats.encodeCount
236
- : 0,
237
- avgDecodeTime: this.stats.decodeCount > 0
238
- ? this.stats.totalDecodeTime / this.stats.decodeCount
239
- : 0
240
- };
241
- }
242
- /**
243
- * Reset statistics
244
- */
245
- resetStats() {
246
- this.stats = {
247
- encodeCount: 0,
248
- decodeCount: 0,
249
- totalEncodeTime: 0,
250
- totalDecodeTime: 0
251
- };
252
- }
253
- /**
254
- * Check if quantizer is trained
255
- */
256
- isTrained() {
257
- return this.trained;
258
- }
259
- /**
260
- * Export codebooks for persistence
261
- */
262
- exportCodebooks() {
263
- return this.codebooks.map(cb => ({
264
- centroids: cb.centroids.map(c => [...c])
265
- }));
266
- }
267
- /**
268
- * Import codebooks from persistence
269
- */
270
- importCodebooks(codebooks) {
271
- if (codebooks.length !== this.config.subvectors) {
272
- throw new Error(`Codebook count (${codebooks.length}) does not match subvectors (${this.config.subvectors})`);
273
- }
274
- this.codebooks = codebooks.map(cb => ({
275
- centroids: cb.centroids.map(c => [...c])
276
- }));
277
- this.trained = true;
278
- }
279
- /**
280
- * Get configuration
281
- */
282
- getConfig() {
283
- return { ...this.config };
284
- }
285
- }
286
- exports.ProductQuantizer = ProductQuantizer;
287
- //# sourceMappingURL=product-quantization.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"product-quantization.js","sourceRoot":"","sources":["../../src/quantization/product-quantization.ts"],"names":[],"mappings":"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"}
@@ -1,282 +0,0 @@
1
- /**
2
- * Product Quantization (PQ) for 4-32x vector compression
3
- *
4
- * Reduces storage requirements while maintaining 95%+ search accuracy.
5
- * Splits vectors into subvectors and quantizes each independently.
6
- *
7
- * @example
8
- * ```typescript
9
- * const pq = new ProductQuantizer({ dimensions: 768, subvectors: 8, bits: 8 });
10
- * await pq.train(trainingVectors); // Train codebooks
11
- *
12
- * // Compress vectors (768 floats → 8 bytes = 96x reduction)
13
- * const codes = pq.encode(vector);
14
- *
15
- * // Decompress for similarity search
16
- * const approximation = pq.decode(codes);
17
- * ```
18
- */
19
- export class ProductQuantizer {
20
- constructor(config) {
21
- this.codebooks = [];
22
- this.trained = false;
23
- // Statistics
24
- this.stats = {
25
- encodeCount: 0,
26
- decodeCount: 0,
27
- totalEncodeTime: 0,
28
- totalDecodeTime: 0
29
- };
30
- this.config = {
31
- dimensions: config.dimensions,
32
- subvectors: config.subvectors,
33
- bits: config.bits,
34
- kmeansIterations: config.kmeansIterations ?? 20,
35
- enableStats: config.enableStats ?? true
36
- };
37
- if (config.dimensions % config.subvectors !== 0) {
38
- throw new Error(`Dimensions (${config.dimensions}) must be divisible by subvectors (${config.subvectors})`);
39
- }
40
- this.subvectorDim = config.dimensions / config.subvectors;
41
- }
42
- /**
43
- * Train codebooks using k-means clustering on training vectors
44
- */
45
- async train(trainingVectors) {
46
- if (trainingVectors.length === 0) {
47
- throw new Error('Training vectors cannot be empty');
48
- }
49
- const numCentroids = Math.pow(2, this.config.bits);
50
- this.codebooks = [];
51
- // Train one codebook per subvector
52
- for (let m = 0; m < this.config.subvectors; m++) {
53
- const subvectors = this.extractSubvectors(trainingVectors, m);
54
- const centroids = this.trainKMeans(subvectors, numCentroids);
55
- this.codebooks.push({ centroids });
56
- }
57
- this.trained = true;
58
- }
59
- /**
60
- * Extract subvectors for a specific segment
61
- */
62
- extractSubvectors(vectors, segmentIndex) {
63
- const start = segmentIndex * this.subvectorDim;
64
- const end = start + this.subvectorDim;
65
- return vectors.map(v => v.slice(start, end));
66
- }
67
- /**
68
- * Train k-means clustering to create centroids
69
- */
70
- trainKMeans(vectors, k) {
71
- const n = vectors.length;
72
- const d = vectors[0].length;
73
- // Initialize centroids randomly
74
- const centroids = [];
75
- const indices = new Set();
76
- while (centroids.length < Math.min(k, n)) {
77
- const idx = Math.floor(Math.random() * n);
78
- if (!indices.has(idx)) {
79
- centroids.push([...vectors[idx]]);
80
- indices.add(idx);
81
- }
82
- }
83
- // K-means iterations
84
- for (let iter = 0; iter < this.config.kmeansIterations; iter++) {
85
- // Assignment step
86
- const assignments = new Array(n).fill(0);
87
- for (let i = 0; i < n; i++) {
88
- let minDist = Infinity;
89
- let bestCluster = 0;
90
- for (let c = 0; c < centroids.length; c++) {
91
- const dist = this.euclideanDistance(vectors[i], centroids[c]);
92
- if (dist < minDist) {
93
- minDist = dist;
94
- bestCluster = c;
95
- }
96
- }
97
- assignments[i] = bestCluster;
98
- }
99
- // Update step
100
- const clusterSums = Array(centroids.length)
101
- .fill(0)
102
- .map(() => Array(d).fill(0));
103
- const clusterCounts = Array(centroids.length).fill(0);
104
- for (let i = 0; i < n; i++) {
105
- const cluster = assignments[i];
106
- clusterCounts[cluster]++;
107
- for (let j = 0; j < d; j++) {
108
- clusterSums[cluster][j] += vectors[i][j];
109
- }
110
- }
111
- // Update centroids
112
- for (let c = 0; c < centroids.length; c++) {
113
- if (clusterCounts[c] > 0) {
114
- for (let j = 0; j < d; j++) {
115
- centroids[c][j] = clusterSums[c][j] / clusterCounts[c];
116
- }
117
- }
118
- }
119
- }
120
- // Fill remaining centroids if k > n
121
- while (centroids.length < k) {
122
- centroids.push(Array(d).fill(0));
123
- }
124
- return centroids;
125
- }
126
- /**
127
- * Encode vector into quantized codes
128
- */
129
- encode(vector) {
130
- if (!this.trained) {
131
- throw new Error('Quantizer must be trained before encoding');
132
- }
133
- if (vector.length !== this.config.dimensions) {
134
- throw new Error(`Vector dimension (${vector.length}) does not match config (${this.config.dimensions})`);
135
- }
136
- const startTime = performance.now();
137
- const codes = new Uint8Array(this.config.subvectors);
138
- for (let m = 0; m < this.config.subvectors; m++) {
139
- const start = m * this.subvectorDim;
140
- const end = start + this.subvectorDim;
141
- const subvector = vector.slice(start, end);
142
- // Find nearest centroid
143
- let minDist = Infinity;
144
- let bestCode = 0;
145
- for (let c = 0; c < this.codebooks[m].centroids.length; c++) {
146
- const dist = this.euclideanDistance(subvector, this.codebooks[m].centroids[c]);
147
- if (dist < minDist) {
148
- minDist = dist;
149
- bestCode = c;
150
- }
151
- }
152
- codes[m] = bestCode;
153
- }
154
- if (this.config.enableStats) {
155
- this.stats.encodeCount++;
156
- this.stats.totalEncodeTime += performance.now() - startTime;
157
- }
158
- return codes;
159
- }
160
- /**
161
- * Decode quantized codes back to approximate vector
162
- */
163
- decode(codes) {
164
- if (!this.trained) {
165
- throw new Error('Quantizer must be trained before decoding');
166
- }
167
- if (codes.length !== this.config.subvectors) {
168
- throw new Error(`Code length (${codes.length}) does not match subvectors (${this.config.subvectors})`);
169
- }
170
- const startTime = performance.now();
171
- const vector = [];
172
- for (let m = 0; m < this.config.subvectors; m++) {
173
- const code = codes[m];
174
- const centroid = this.codebooks[m].centroids[code];
175
- vector.push(...centroid);
176
- }
177
- if (this.config.enableStats) {
178
- this.stats.decodeCount++;
179
- this.stats.totalDecodeTime += performance.now() - startTime;
180
- }
181
- return vector;
182
- }
183
- /**
184
- * Compute asymmetric distance for faster search
185
- * Compare query vector directly with quantized database vectors
186
- */
187
- asymmetricDistance(query, codes) {
188
- if (!this.trained) {
189
- throw new Error('Quantizer must be trained before computing distances');
190
- }
191
- let distance = 0;
192
- for (let m = 0; m < this.config.subvectors; m++) {
193
- const start = m * this.subvectorDim;
194
- const end = start + this.subvectorDim;
195
- const querySubvector = query.slice(start, end);
196
- const code = codes[m];
197
- const centroid = this.codebooks[m].centroids[code];
198
- distance += this.euclideanDistanceSquared(querySubvector, centroid);
199
- }
200
- return Math.sqrt(distance);
201
- }
202
- /**
203
- * Euclidean distance between two vectors
204
- */
205
- euclideanDistance(a, b) {
206
- return Math.sqrt(this.euclideanDistanceSquared(a, b));
207
- }
208
- /**
209
- * Squared Euclidean distance (faster, no sqrt)
210
- */
211
- euclideanDistanceSquared(a, b) {
212
- let sum = 0;
213
- for (let i = 0; i < a.length; i++) {
214
- const diff = a[i] - b[i];
215
- sum += diff * diff;
216
- }
217
- return sum;
218
- }
219
- /**
220
- * Get compression statistics
221
- */
222
- getStats() {
223
- const originalSize = this.config.dimensions * 4; // 4 bytes per float32
224
- const compressedSize = this.config.subvectors; // 1 byte per subvector
225
- return {
226
- originalSize,
227
- compressedSize,
228
- compressionRatio: originalSize / compressedSize,
229
- encodeCount: this.stats.encodeCount,
230
- decodeCount: this.stats.decodeCount,
231
- avgEncodeTime: this.stats.encodeCount > 0
232
- ? this.stats.totalEncodeTime / this.stats.encodeCount
233
- : 0,
234
- avgDecodeTime: this.stats.decodeCount > 0
235
- ? this.stats.totalDecodeTime / this.stats.decodeCount
236
- : 0
237
- };
238
- }
239
- /**
240
- * Reset statistics
241
- */
242
- resetStats() {
243
- this.stats = {
244
- encodeCount: 0,
245
- decodeCount: 0,
246
- totalEncodeTime: 0,
247
- totalDecodeTime: 0
248
- };
249
- }
250
- /**
251
- * Check if quantizer is trained
252
- */
253
- isTrained() {
254
- return this.trained;
255
- }
256
- /**
257
- * Export codebooks for persistence
258
- */
259
- exportCodebooks() {
260
- return this.codebooks.map(cb => ({
261
- centroids: cb.centroids.map(c => [...c])
262
- }));
263
- }
264
- /**
265
- * Import codebooks from persistence
266
- */
267
- importCodebooks(codebooks) {
268
- if (codebooks.length !== this.config.subvectors) {
269
- throw new Error(`Codebook count (${codebooks.length}) does not match subvectors (${this.config.subvectors})`);
270
- }
271
- this.codebooks = codebooks.map(cb => ({
272
- centroids: cb.centroids.map(c => [...c])
273
- }));
274
- this.trained = true;
275
- }
276
- /**
277
- * Get configuration
278
- */
279
- getConfig() {
280
- return { ...this.config };
281
- }
282
- }
@@ -1,100 +0,0 @@
1
- /**
2
- * Scalar Quantization - Simple yet powerful vector compression
3
- *
4
- * Achieves 85-95% accuracy with 4-16x compression by quantizing each dimension independently.
5
- * Unlike Product Quantization, works excellently with ANY data distribution including random data.
6
- *
7
- * Key advantages:
8
- * 1. Simple per-dimension min/max scaling
9
- * 2. No clustering required (faster training)
10
- * 3. Better accuracy on random/diverse data
11
- * 4. Fast encode/decode (< 1ms per vector)
12
- * 5. Guaranteed compression ratio
13
- *
14
- * Supported bit depths:
15
- * - 4-bit: 16 levels per dimension, 8x compression
16
- * - 8-bit: 256 levels per dimension, 4x compression
17
- * - 16-bit: 65536 levels per dimension, 2x compression
18
- */
19
- export interface ScalarQuantizerConfig {
20
- dimensions: number;
21
- bits: 4 | 8 | 16;
22
- normalize?: boolean;
23
- }
24
- export interface AccuracyMetrics {
25
- avgError: number;
26
- maxError: number;
27
- minError: number;
28
- rmse: number;
29
- accuracy: number;
30
- recall10: number;
31
- }
32
- export interface ScalarQuantizationStats {
33
- dimensions: number;
34
- bits: 4 | 8 | 16;
35
- levels: number;
36
- compressionRatio: number;
37
- bytesPerVector: number;
38
- trained: boolean;
39
- minValues: number[];
40
- maxValues: number[];
41
- ranges: number[];
42
- }
43
- /**
44
- * Scalar Quantizer - Per-dimension quantization for guaranteed accuracy
45
- *
46
- * Works by tracking min/max for each dimension independently, then
47
- * mapping values to discrete levels (16, 256, or 65536 levels).
48
- */
49
- export declare class ScalarQuantizer {
50
- private dimensions;
51
- private bits;
52
- private normalize;
53
- private levels;
54
- private minValues;
55
- private maxValues;
56
- private ranges;
57
- private trained;
58
- constructor(config: ScalarQuantizerConfig);
59
- /**
60
- * Train the quantizer by finding min/max for each dimension
61
- */
62
- train(vectors: number[][]): Promise<void>;
63
- /**
64
- * Encode a vector to quantized codes
65
- */
66
- encode(vector: number[]): Uint8Array | Uint16Array;
67
- /**
68
- * Decode quantized codes back to a vector
69
- */
70
- decode(codes: Uint8Array | Uint16Array): number[];
71
- /**
72
- * Calculate asymmetric distance between query vector and quantized codes
73
- * This is more accurate than symmetric distance for search
74
- */
75
- asymmetricDistance(query: number[], codes: Uint8Array | Uint16Array): number;
76
- /**
77
- * Evaluate accuracy on test vectors
78
- */
79
- evaluateAccuracy(testVectors: number[][]): AccuracyMetrics;
80
- /**
81
- * Get quantizer statistics
82
- */
83
- getStats(): ScalarQuantizationStats;
84
- /**
85
- * Check if quantizer is trained
86
- */
87
- isTrained(): boolean;
88
- private encode4Bit;
89
- private decode4Bit;
90
- private encode8Bit;
91
- private decode8Bit;
92
- private encode16Bit;
93
- private decode16Bit;
94
- private normalizeVector;
95
- private euclideanDistance;
96
- private calculateRecall10;
97
- private getCompressionRatio;
98
- private getBytesPerVector;
99
- }
100
- //# sourceMappingURL=scalar-quantization.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"scalar-quantization.d.ts","sourceRoot":"","sources":["../../src/quantization/scalar-quantization.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,MAAM,WAAW,qBAAqB;IACpC,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;IACjB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,MAAM,WAAW,eAAe;IAC9B,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,uBAAuB;IACtC,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,gBAAgB,EAAE,MAAM,CAAC;IACzB,cAAc,EAAE,MAAM,CAAC;IACvB,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED;;;;;GAKG;AACH,qBAAa,eAAe;IAC1B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,IAAI,CAAa;IACzB,OAAO,CAAC,SAAS,CAAU;IAC3B,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,SAAS,CAAW;IAC5B,OAAO,CAAC,SAAS,CAAW;IAC5B,OAAO,CAAC,MAAM,CAAW;IACzB,OAAO,CAAC,OAAO,CAAkB;gBAErB,MAAM,EAAE,qBAAqB;IAUzC;;OAEG;IACG,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAuC/C;;OAEG;IACH,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,GAAG,WAAW;IAsBlD;;OAEG;IACH,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,WAAW,GAAG,MAAM,EAAE;IAejD;;;OAGG;IACH,kBAAkB,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,UAAU,GAAG,WAAW,GAAG,MAAM;IAK5E;;OAEG;IACH,gBAAgB,CAAC,WAAW,EAAE,MAAM,EAAE,EAAE,GAAG,eAAe;IAiD1D;;OAEG;IACH,QAAQ,IAAI,uBAAuB;IAcnC;;OAEG;IACH,SAAS,IAAI,OAAO;IAMpB,OAAO,CAAC,UAAU;IAsBlB,OAAO,CAAC,UAAU;IAkBlB,OAAO,CAAC,UAAU;IAYlB,OAAO,CAAC,UAAU;IAWlB,OAAO,CAAC,WAAW;IAYnB,OAAO,CAAC,WAAW;IAWnB,OAAO,CAAC,eAAe;IAYvB,OAAO,CAAC,iBAAiB;IASzB,OAAO,CAAC,iBAAiB;IAuCzB,OAAO,CAAC,mBAAmB;IAM3B,OAAO,CAAC,iBAAiB;CAS1B"}