memento-mcp-server 1.6.0 → 1.7.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 (560) hide show
  1. package/INSTALL.en.md +303 -303
  2. package/INSTALL.md +303 -303
  3. package/README.en.md +331 -330
  4. package/README.md +432 -432
  5. package/dist/algorithms/hybrid-search-engine.d.ts +114 -44
  6. package/dist/algorithms/hybrid-search-engine.d.ts.map +1 -1
  7. package/dist/algorithms/hybrid-search-engine.js +261 -235
  8. package/dist/algorithms/hybrid-search-engine.js.map +1 -1
  9. package/dist/algorithms/search-engine.d.ts +2 -14
  10. package/dist/algorithms/search-engine.d.ts.map +1 -1
  11. package/dist/algorithms/search-engine.js +43 -35
  12. package/dist/algorithms/search-engine.js.map +1 -1
  13. package/dist/algorithms/vector-search-engine-migration.d.ts +67 -0
  14. package/dist/algorithms/vector-search-engine-migration.d.ts.map +1 -0
  15. package/dist/algorithms/vector-search-engine-migration.js +196 -0
  16. package/dist/algorithms/vector-search-engine-migration.js.map +1 -0
  17. package/dist/algorithms/vector-search-engine-refactored.d.ts +56 -0
  18. package/dist/algorithms/vector-search-engine-refactored.d.ts.map +1 -0
  19. package/dist/algorithms/vector-search-engine-refactored.js +101 -0
  20. package/dist/algorithms/vector-search-engine-refactored.js.map +1 -0
  21. package/dist/algorithms/vector-search-engine.d.ts +9 -2
  22. package/dist/algorithms/vector-search-engine.d.ts.map +1 -1
  23. package/dist/algorithms/vector-search-engine.js +245 -121
  24. package/dist/algorithms/vector-search-engine.js.map +1 -1
  25. package/dist/client/index.d.ts.map +1 -1
  26. package/dist/client/index.js +34 -11
  27. package/dist/client/index.js.map +1 -1
  28. package/dist/config/environment.d.ts +26 -0
  29. package/dist/config/environment.d.ts.map +1 -0
  30. package/dist/config/environment.js +103 -0
  31. package/dist/config/environment.js.map +1 -0
  32. package/dist/config/index.d.ts.map +1 -1
  33. package/dist/config/index.js +29 -50
  34. package/dist/config/index.js.map +1 -1
  35. package/dist/config/vector-search.config.d.ts +25 -0
  36. package/dist/config/vector-search.config.d.ts.map +1 -0
  37. package/dist/config/vector-search.config.js +40 -0
  38. package/dist/config/vector-search.config.js.map +1 -0
  39. package/dist/database/init.d.ts.map +1 -1
  40. package/dist/database/init.js +154 -17
  41. package/dist/database/init.js.map +1 -1
  42. package/dist/database/migrate.d.ts +2 -1
  43. package/dist/database/migrate.d.ts.map +1 -1
  44. package/dist/database/migrate.js +191 -18
  45. package/dist/database/migrate.js.map +1 -1
  46. package/dist/database/schema.sql +234 -159
  47. package/dist/factories/hybrid-search.factory.d.ts +20 -0
  48. package/dist/factories/hybrid-search.factory.d.ts.map +1 -0
  49. package/dist/factories/hybrid-search.factory.js +57 -0
  50. package/dist/factories/hybrid-search.factory.js.map +1 -0
  51. package/dist/factories/spaced-repetition.factory.d.ts +48 -0
  52. package/dist/factories/spaced-repetition.factory.d.ts.map +1 -0
  53. package/dist/factories/spaced-repetition.factory.js +187 -0
  54. package/dist/factories/spaced-repetition.factory.js.map +1 -0
  55. package/dist/factories/vector-search.factory.d.ts +25 -0
  56. package/dist/factories/vector-search.factory.d.ts.map +1 -0
  57. package/dist/factories/vector-search.factory.js +47 -0
  58. package/dist/factories/vector-search.factory.js.map +1 -0
  59. package/dist/interfaces/database.interface.d.ts +36 -0
  60. package/dist/interfaces/database.interface.d.ts.map +1 -0
  61. package/dist/interfaces/database.interface.js +6 -0
  62. package/dist/interfaces/database.interface.js.map +1 -0
  63. package/dist/interfaces/spaced-repetition.interface.d.ts +63 -0
  64. package/dist/interfaces/spaced-repetition.interface.d.ts.map +1 -0
  65. package/dist/interfaces/spaced-repetition.interface.js +6 -0
  66. package/dist/interfaces/spaced-repetition.interface.js.map +1 -0
  67. package/dist/repositories/vector-performance.repository.d.ts +25 -0
  68. package/dist/repositories/vector-performance.repository.d.ts.map +1 -0
  69. package/dist/repositories/vector-performance.repository.js +134 -0
  70. package/dist/repositories/vector-performance.repository.js.map +1 -0
  71. package/dist/repositories/vector-search.repository.d.ts +43 -0
  72. package/dist/repositories/vector-search.repository.d.ts.map +1 -0
  73. package/dist/repositories/vector-search.repository.js +377 -0
  74. package/dist/repositories/vector-search.repository.js.map +1 -0
  75. package/dist/server/http-server.d.ts.map +1 -1
  76. package/dist/server/http-server.js +25 -24
  77. package/dist/server/http-server.js.map +1 -1
  78. package/dist/server/index.d.ts +1 -0
  79. package/dist/server/index.d.ts.map +1 -1
  80. package/dist/server/index.js +3 -1
  81. package/dist/server/index.js.map +1 -1
  82. package/dist/services/alert-notification-service.d.ts +16 -0
  83. package/dist/services/alert-notification-service.d.ts.map +1 -0
  84. package/dist/services/alert-notification-service.js +44 -0
  85. package/dist/services/alert-notification-service.js.map +1 -0
  86. package/dist/services/async-optimizer.d.ts +62 -8
  87. package/dist/services/async-optimizer.d.ts.map +1 -1
  88. package/dist/services/async-optimizer.js +137 -8
  89. package/dist/services/async-optimizer.js.map +1 -1
  90. package/dist/services/batch-scheduler.d.ts +6 -0
  91. package/dist/services/batch-scheduler.d.ts.map +1 -1
  92. package/dist/services/batch-scheduler.js +59 -19
  93. package/dist/services/batch-scheduler.js.map +1 -1
  94. package/dist/services/cache-service.d.ts +32 -0
  95. package/dist/services/cache-service.d.ts.map +1 -1
  96. package/dist/services/cache-service.js +81 -6
  97. package/dist/services/cache-service.js.map +1 -1
  98. package/dist/services/database-optimizer.js +63 -63
  99. package/dist/services/database-optimizer.js.map +1 -1
  100. package/dist/services/embedding-migration-service.d.ts +24 -0
  101. package/dist/services/embedding-migration-service.d.ts.map +1 -0
  102. package/dist/services/embedding-migration-service.js +360 -0
  103. package/dist/services/embedding-migration-service.js.map +1 -0
  104. package/dist/services/embedding-provider-factory.d.ts +12 -5
  105. package/dist/services/embedding-provider-factory.d.ts.map +1 -1
  106. package/dist/services/embedding-provider-factory.js +107 -26
  107. package/dist/services/embedding-provider-factory.js.map +1 -1
  108. package/dist/services/forgetting-policy-service.js +17 -17
  109. package/dist/services/gemini-embedding-service.d.ts +1 -1
  110. package/dist/services/gemini-embedding-service.d.ts.map +1 -1
  111. package/dist/services/gemini-embedding-service.js +25 -18
  112. package/dist/services/gemini-embedding-service.js.map +1 -1
  113. package/dist/services/memory-embedding-service.d.ts +8 -0
  114. package/dist/services/memory-embedding-service.d.ts.map +1 -1
  115. package/dist/services/memory-embedding-service.js +180 -71
  116. package/dist/services/memory-embedding-service.js.map +1 -1
  117. package/dist/services/migration-history-service.d.ts +14 -0
  118. package/dist/services/migration-history-service.d.ts.map +1 -0
  119. package/dist/services/migration-history-service.js +270 -0
  120. package/dist/services/migration-history-service.js.map +1 -0
  121. package/dist/services/migration-monitor-service.d.ts +24 -0
  122. package/dist/services/migration-monitor-service.d.ts.map +1 -0
  123. package/dist/services/migration-monitor-service.js +93 -0
  124. package/dist/services/migration-monitor-service.js.map +1 -0
  125. package/dist/services/model-availability-service.d.ts +22 -0
  126. package/dist/services/model-availability-service.d.ts.map +1 -0
  127. package/dist/services/model-availability-service.js +140 -0
  128. package/dist/services/model-availability-service.js.map +1 -0
  129. package/dist/services/openai-embedding-service.d.ts +36 -0
  130. package/dist/services/openai-embedding-service.d.ts.map +1 -0
  131. package/dist/services/openai-embedding-service.js +192 -0
  132. package/dist/services/openai-embedding-service.js.map +1 -0
  133. package/dist/services/performance-monitor.d.ts +154 -10
  134. package/dist/services/performance-monitor.d.ts.map +1 -1
  135. package/dist/services/performance-monitor.js +446 -60
  136. package/dist/services/performance-monitor.js.map +1 -1
  137. package/dist/services/spaced-repetition/interval-calculation.service.d.ts +38 -0
  138. package/dist/services/spaced-repetition/interval-calculation.service.d.ts.map +1 -0
  139. package/dist/services/spaced-repetition/interval-calculation.service.js +105 -0
  140. package/dist/services/spaced-repetition/interval-calculation.service.js.map +1 -0
  141. package/dist/services/spaced-repetition/optimal-interval.service.d.ts +56 -0
  142. package/dist/services/spaced-repetition/optimal-interval.service.d.ts.map +1 -0
  143. package/dist/services/spaced-repetition/optimal-interval.service.js +163 -0
  144. package/dist/services/spaced-repetition/optimal-interval.service.js.map +1 -0
  145. package/dist/services/spaced-repetition/performance-analysis.service.d.ts +48 -0
  146. package/dist/services/spaced-repetition/performance-analysis.service.d.ts.map +1 -0
  147. package/dist/services/spaced-repetition/performance-analysis.service.js +174 -0
  148. package/dist/services/spaced-repetition/performance-analysis.service.js.map +1 -0
  149. package/dist/services/spaced-repetition/priority-calculation.service.d.ts +53 -0
  150. package/dist/services/spaced-repetition/priority-calculation.service.d.ts.map +1 -0
  151. package/dist/services/spaced-repetition/priority-calculation.service.js +161 -0
  152. package/dist/services/spaced-repetition/priority-calculation.service.js.map +1 -0
  153. package/dist/services/spaced-repetition/recall-probability.service.d.ts +36 -0
  154. package/dist/services/spaced-repetition/recall-probability.service.d.ts.map +1 -0
  155. package/dist/services/spaced-repetition/recall-probability.service.js +88 -0
  156. package/dist/services/spaced-repetition/recall-probability.service.js.map +1 -0
  157. package/dist/services/spaced-repetition/review-scheduling.service.d.ts +43 -0
  158. package/dist/services/spaced-repetition/review-scheduling.service.d.ts.map +1 -0
  159. package/dist/services/spaced-repetition/review-scheduling.service.js +130 -0
  160. package/dist/services/spaced-repetition/review-scheduling.service.js.map +1 -0
  161. package/dist/services/spaced-repetition/spaced-repetition-container.d.ts +69 -0
  162. package/dist/services/spaced-repetition/spaced-repetition-container.d.ts.map +1 -0
  163. package/dist/services/spaced-repetition/spaced-repetition-container.js +136 -0
  164. package/dist/services/spaced-repetition/spaced-repetition-container.js.map +1 -0
  165. package/dist/services/unified-embedding-service.d.ts +3 -0
  166. package/dist/services/unified-embedding-service.d.ts.map +1 -1
  167. package/dist/services/unified-embedding-service.js +58 -62
  168. package/dist/services/unified-embedding-service.js.map +1 -1
  169. package/dist/services/vector-compatibility-service.d.ts +68 -0
  170. package/dist/services/vector-compatibility-service.d.ts.map +1 -0
  171. package/dist/services/vector-compatibility-service.js +373 -0
  172. package/dist/services/vector-compatibility-service.js.map +1 -0
  173. package/dist/services/vector-search/vector-index-manager.d.ts +27 -0
  174. package/dist/services/vector-search/vector-index-manager.d.ts.map +1 -0
  175. package/dist/services/vector-search/vector-index-manager.js +66 -0
  176. package/dist/services/vector-search/vector-index-manager.js.map +1 -0
  177. package/dist/services/vector-search/vector-performance-tester.d.ts +30 -0
  178. package/dist/services/vector-search/vector-performance-tester.d.ts.map +1 -0
  179. package/dist/services/vector-search/vector-performance-tester.js +87 -0
  180. package/dist/services/vector-search/vector-performance-tester.js.map +1 -0
  181. package/dist/services/vector-search/vector-search-container.d.ts +41 -0
  182. package/dist/services/vector-search/vector-search-container.d.ts.map +1 -0
  183. package/dist/services/vector-search/vector-search-container.js +74 -0
  184. package/dist/services/vector-search/vector-search-container.js.map +1 -0
  185. package/dist/services/vector-search/vector-search-facade.d.ts +63 -0
  186. package/dist/services/vector-search/vector-search-facade.d.ts.map +1 -0
  187. package/dist/services/vector-search/vector-search-facade.js +91 -0
  188. package/dist/services/vector-search/vector-search-facade.js.map +1 -0
  189. package/dist/services/vector-search/vector-search-result-normalizer.d.ts +6 -0
  190. package/dist/services/vector-search/vector-search-result-normalizer.d.ts.map +1 -0
  191. package/dist/services/vector-search/vector-search-result-normalizer.js +65 -0
  192. package/dist/services/vector-search/vector-search-result-normalizer.js.map +1 -0
  193. package/dist/services/vector-search/vector-search.service.d.ts +33 -0
  194. package/dist/services/vector-search/vector-search.service.d.ts.map +1 -0
  195. package/dist/services/vector-search/vector-search.service.js +149 -0
  196. package/dist/services/vector-search/vector-search.service.js.map +1 -0
  197. package/dist/tools/forget-tool.js +14 -14
  198. package/dist/tools/pin-tool.js +14 -14
  199. package/dist/tools/unpin-tool.js +21 -21
  200. package/dist/types/alerts.types.d.ts +26 -0
  201. package/dist/types/alerts.types.d.ts.map +1 -0
  202. package/dist/types/alerts.types.js +2 -0
  203. package/dist/types/alerts.types.js.map +1 -0
  204. package/dist/types/embedding-provider-monitoring.types.d.ts +24 -0
  205. package/dist/types/embedding-provider-monitoring.types.d.ts.map +1 -0
  206. package/dist/types/embedding-provider-monitoring.types.js +2 -0
  207. package/dist/types/embedding-provider-monitoring.types.js.map +1 -0
  208. package/dist/types/embedding.types.d.ts +36 -1
  209. package/dist/types/embedding.types.d.ts.map +1 -1
  210. package/dist/types/migration.types.d.ts +131 -0
  211. package/dist/types/migration.types.d.ts.map +1 -0
  212. package/dist/types/migration.types.js +6 -0
  213. package/dist/types/migration.types.js.map +1 -0
  214. package/dist/types/spaced-repetition.types.d.ts +61 -0
  215. package/dist/types/spaced-repetition.types.d.ts.map +1 -0
  216. package/dist/types/spaced-repetition.types.js +6 -0
  217. package/dist/types/spaced-repetition.types.js.map +1 -0
  218. package/dist/types/vector-search.types.d.ts +96 -0
  219. package/dist/types/vector-search.types.d.ts.map +1 -0
  220. package/dist/types/vector-search.types.js +2 -0
  221. package/dist/types/vector-search.types.js.map +1 -0
  222. package/dist/utils/configuration-validator.d.ts +23 -0
  223. package/dist/utils/configuration-validator.d.ts.map +1 -0
  224. package/dist/utils/configuration-validator.js +102 -0
  225. package/dist/utils/configuration-validator.js.map +1 -0
  226. package/dist/utils/database.d.ts.map +1 -1
  227. package/dist/utils/database.js +101 -95
  228. package/dist/utils/database.js.map +1 -1
  229. package/dist/utils/environment-check.d.ts +8 -0
  230. package/dist/utils/environment-check.d.ts.map +1 -0
  231. package/dist/utils/environment-check.js +25 -0
  232. package/dist/utils/environment-check.js.map +1 -0
  233. package/dist/utils/logger.d.ts +8 -0
  234. package/dist/utils/logger.d.ts.map +1 -0
  235. package/dist/utils/logger.js +33 -0
  236. package/dist/utils/logger.js.map +1 -0
  237. package/package.json +139 -125
  238. package/scripts/auto-setup.js +233 -233
  239. package/scripts/backup-daily.bat +28 -28
  240. package/scripts/backup-embeddings.js +108 -108
  241. package/scripts/check-db-integrity.js +93 -93
  242. package/scripts/debug-embeddings.js +184 -184
  243. package/scripts/direct-sql-migration.sql +36 -36
  244. package/scripts/docker-migration.sh +105 -105
  245. package/scripts/fix-migration.js +93 -93
  246. package/scripts/fix-vector-dimensions.js +206 -206
  247. package/scripts/migrate-embedding-data.js +307 -307
  248. package/scripts/regenerate-embeddings.js +144 -144
  249. package/scripts/restore-legacy.ps1 +60 -60
  250. package/scripts/run-migration.js +122 -122
  251. package/scripts/safe-migration.js +150 -150
  252. package/scripts/simple-migrate.js +41 -41
  253. package/scripts/simple-update.js +123 -123
  254. package/src/database/schema.sql +234 -159
  255. package/.cursor/rules/cache-management.mdc +0 -171
  256. package/.cursor/rules/database-schema.mdc +0 -344
  257. package/.cursor/rules/deployment.mdc +0 -596
  258. package/.cursor/rules/error-logging.mdc +0 -298
  259. package/.cursor/rules/forgetting-algorithms.mdc +0 -426
  260. package/.cursor/rules/http-server.mdc +0 -432
  261. package/.cursor/rules/hybrid-search.mdc +0 -424
  262. package/.cursor/rules/implementation.mdc +0 -369
  263. package/.cursor/rules/lightweight-embedding.mdc +0 -178
  264. package/.cursor/rules/mcp-client-development.mdc +0 -0
  265. package/.cursor/rules/mcp-server-development.mdc +0 -0
  266. package/.cursor/rules/mcp-tools-architecture.mdc +0 -205
  267. package/.cursor/rules/memento-memory-rule.mdc +0 -8
  268. package/.cursor/rules/memento-project-overview.mdc +0 -0
  269. package/.cursor/rules/memory-algorithms.mdc +0 -502
  270. package/.cursor/rules/monitoring.mdc +0 -622
  271. package/.cursor/rules/performance-alerts.mdc +0 -537
  272. package/.cursor/rules/performance-monitoring.mdc +0 -345
  273. package/.cursor/rules/performance-optimization.mdc +0 -563
  274. package/.cursor/rules/project-structure.mdc +0 -310
  275. package/.cursor/rules/testing.mdc +0 -473
  276. package/.dockerignore +0 -15
  277. package/.eslintrc.json +0 -34
  278. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -51
  279. package/.github/ISSUE_TEMPLATE/feature_request.md +0 -45
  280. package/.github/ISSUE_TEMPLATE/question.md +0 -31
  281. package/.github/PULL_REQUEST_TEMPLATE.md +0 -97
  282. package/AGENTS.md +0 -28
  283. package/CHANGELOG.md +0 -416
  284. package/CODE_OF_CONDUCT.md +0 -62
  285. package/CONTRIBUTING.md +0 -165
  286. package/DOCKER_SETUP_GUIDE.md +0 -84
  287. package/Dockerfile +0 -90
  288. package/backup/legacy-removal-20250930-201816/http-server-legacy.ts +0 -1068
  289. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.ps1 +0 -46
  290. package/backup/legacy-removal-20250930-201816/rollback-to-legacy.sh +0 -48
  291. package/dist/server/index-backup.d.ts +0 -5
  292. package/dist/server/index-backup.d.ts.map +0 -1
  293. package/dist/server/index-backup.js +0 -793
  294. package/dist/server/index-backup.js.map +0 -1
  295. package/dist/server/index-refactored.d.ts +0 -6
  296. package/dist/server/index-refactored.d.ts.map +0 -1
  297. package/dist/server/index-refactored.js +0 -206
  298. package/dist/server/index-refactored.js.map +0 -1
  299. package/dist/services/performance-monitoring-integration.d.ts +0 -77
  300. package/dist/services/performance-monitoring-integration.d.ts.map +0 -1
  301. package/dist/services/performance-monitoring-integration.js +0 -177
  302. package/dist/services/performance-monitoring-integration.js.map +0 -1
  303. package/dist/test/debug-http-v2.d.ts +0 -5
  304. package/dist/test/debug-http-v2.d.ts.map +0 -1
  305. package/dist/test/debug-http-v2.js +0 -28
  306. package/dist/test/debug-http-v2.js.map +0 -1
  307. package/dist/test/performance-benchmark.d.ts +0 -57
  308. package/dist/test/performance-benchmark.d.ts.map +0 -1
  309. package/dist/test/performance-benchmark.js +0 -427
  310. package/dist/test/performance-benchmark.js.map +0 -1
  311. package/dist/test/test-alerts-direct.d.ts +0 -7
  312. package/dist/test/test-alerts-direct.d.ts.map +0 -1
  313. package/dist/test/test-alerts-direct.js +0 -101
  314. package/dist/test/test-alerts-direct.js.map +0 -1
  315. package/dist/test/test-batch-scheduler.d.ts +0 -2
  316. package/dist/test/test-batch-scheduler.d.ts.map +0 -1
  317. package/dist/test/test-batch-scheduler.js +0 -156
  318. package/dist/test/test-batch-scheduler.js.map +0 -1
  319. package/dist/test/test-client.d.ts +0 -5
  320. package/dist/test/test-client.d.ts.map +0 -1
  321. package/dist/test/test-client.js +0 -86
  322. package/dist/test/test-client.js.map +0 -1
  323. package/dist/test/test-embedding.d.ts +0 -6
  324. package/dist/test/test-embedding.d.ts.map +0 -1
  325. package/dist/test/test-embedding.js +0 -142
  326. package/dist/test/test-embedding.js.map +0 -1
  327. package/dist/test/test-error-logging.d.ts +0 -7
  328. package/dist/test/test-error-logging.d.ts.map +0 -1
  329. package/dist/test/test-error-logging.js +0 -105
  330. package/dist/test/test-error-logging.js.map +0 -1
  331. package/dist/test/test-forgetting.d.ts +0 -6
  332. package/dist/test/test-forgetting.d.ts.map +0 -1
  333. package/dist/test/test-forgetting.js +0 -154
  334. package/dist/test/test-forgetting.js.map +0 -1
  335. package/dist/test/test-gemini-embedding.d.ts +0 -7
  336. package/dist/test/test-gemini-embedding.d.ts.map +0 -1
  337. package/dist/test/test-gemini-embedding.js +0 -134
  338. package/dist/test/test-gemini-embedding.js.map +0 -1
  339. package/dist/test/test-http-server-v2-simple.d.ts +0 -6
  340. package/dist/test/test-http-server-v2-simple.d.ts.map +0 -1
  341. package/dist/test/test-http-server-v2-simple.js +0 -131
  342. package/dist/test/test-http-server-v2-simple.js.map +0 -1
  343. package/dist/test/test-http-server-v2.d.ts +0 -7
  344. package/dist/test/test-http-server-v2.d.ts.map +0 -1
  345. package/dist/test/test-http-server-v2.js +0 -529
  346. package/dist/test/test-http-server-v2.js.map +0 -1
  347. package/dist/test/test-lightweight-embedding.d.ts +0 -6
  348. package/dist/test/test-lightweight-embedding.d.ts.map +0 -1
  349. package/dist/test/test-lightweight-embedding.js +0 -189
  350. package/dist/test/test-lightweight-embedding.js.map +0 -1
  351. package/dist/test/test-m1-completion.d.ts +0 -7
  352. package/dist/test/test-m1-completion.d.ts.map +0 -1
  353. package/dist/test/test-m1-completion.js +0 -124
  354. package/dist/test/test-m1-completion.js.map +0 -1
  355. package/dist/test/test-memory-injection-prompt.d.ts +0 -2
  356. package/dist/test/test-memory-injection-prompt.d.ts.map +0 -1
  357. package/dist/test/test-memory-injection-prompt.js +0 -299
  358. package/dist/test/test-memory-injection-prompt.js.map +0 -1
  359. package/dist/test/test-performance-alerts.d.ts +0 -7
  360. package/dist/test/test-performance-alerts.d.ts.map +0 -1
  361. package/dist/test/test-performance-alerts.js +0 -109
  362. package/dist/test/test-performance-alerts.js.map +0 -1
  363. package/dist/test/test-performance-monitor.d.ts +0 -2
  364. package/dist/test/test-performance-monitor.d.ts.map +0 -1
  365. package/dist/test/test-performance-monitor.js +0 -182
  366. package/dist/test/test-performance-monitor.js.map +0 -1
  367. package/dist/test/test-performance-monitoring.d.ts +0 -6
  368. package/dist/test/test-performance-monitoring.d.ts.map +0 -1
  369. package/dist/test/test-performance-monitoring.js +0 -156
  370. package/dist/test/test-performance-monitoring.js.map +0 -1
  371. package/dist/test/test-search.d.ts +0 -5
  372. package/dist/test/test-search.d.ts.map +0 -1
  373. package/dist/test/test-search.js +0 -141
  374. package/dist/test/test-search.js.map +0 -1
  375. package/dist/test/test-simple-alerts.d.ts +0 -6
  376. package/dist/test/test-simple-alerts.d.ts.map +0 -1
  377. package/dist/test/test-simple-alerts.js +0 -106
  378. package/dist/test/test-simple-alerts.js.map +0 -1
  379. package/dist/test/test-vector-search-engine.d.ts +0 -2
  380. package/dist/test/test-vector-search-engine.d.ts.map +0 -1
  381. package/dist/test/test-vector-search-engine.js +0 -225
  382. package/dist/test/test-vector-search-engine.js.map +0 -1
  383. package/docker-compose.dev.yml +0 -50
  384. package/docker-compose.prod.yml +0 -77
  385. package/docker-compose.yml +0 -43
  386. package/docs/en/Memento-Goals.md +0 -217
  387. package/docs/en/Memento-M1-DetailSpecs.md +0 -130
  388. package/docs/en/Memento-Milestones.md +0 -135
  389. package/docs/en/Search-Ranking-Memory-Decay-Formulas.md +0 -177
  390. package/docs/en/api-reference.md +0 -658
  391. package/docs/en/architecture.md +0 -1302
  392. package/docs/en/developer-guide.md +0 -1005
  393. package/docs/en/user-manual.md +0 -595
  394. package/docs/ko/Memento-Goals.md +0 -217
  395. package/docs/ko/Memento-M1-DetailSpecs.md +0 -130
  396. package/docs/ko/Memento-Milestones.md +0 -134
  397. package/docs/ko/Search-Ranking-Memory-Decay-Formulas.md +0 -177
  398. package/docs/ko/api-reference.md +0 -658
  399. package/docs/ko/architecture.md +0 -1302
  400. package/docs/ko/developer-guide.md +0 -1006
  401. package/docs/ko/embedding-api-reference.md +0 -122
  402. package/docs/ko/embedding-configuration.md +0 -62
  403. package/docs/ko/embedding-performance-benchmark.md +0 -62
  404. package/docs/ko/embedding-service-guide.md +0 -314
  405. package/docs/ko/user-manual.md +0 -595
  406. package/env.example +0 -49
  407. package/install.sh +0 -191
  408. package/mcp-http-client.js +0 -218
  409. package/mcp.json +0 -0
  410. package/packages/mcp-client/docs/API-REFERENCE.md +0 -560
  411. package/packages/mcp-client/docs/BEST-PRACTICES.md +0 -564
  412. package/packages/mcp-client/docs/MIGRATION-GUIDE.md +0 -344
  413. package/packages/mcp-client/docs/PERFORMANCE-GUIDE.md +0 -476
  414. package/packages/mcp-client/docs/TROUBLESHOOTING.md +0 -564
  415. package/packages/mcp-client/package-lock.json +0 -907
  416. package/packages/mcp-client/package.json +0 -58
  417. package/packages/mcp-client/performance-optimizer.js +0 -428
  418. package/packages/mcp-client/test-basic.js +0 -65
  419. package/packages/mcp-client/test-integration.js +0 -366
  420. package/src/algorithms/forgetting-algorithm.spec.ts +0 -538
  421. package/src/algorithms/forgetting-algorithm.ts +0 -243
  422. package/src/algorithms/hybrid-search-engine.spec.ts +0 -484
  423. package/src/algorithms/hybrid-search-engine.ts +0 -489
  424. package/src/algorithms/search-engine.spec.ts +0 -429
  425. package/src/algorithms/search-engine.ts +0 -392
  426. package/src/algorithms/search-ranking.spec.ts +0 -293
  427. package/src/algorithms/search-ranking.ts +0 -407
  428. package/src/algorithms/spaced-repetition.spec.ts +0 -510
  429. package/src/algorithms/spaced-repetition.ts +0 -238
  430. package/src/algorithms/vector-search-engine.ts +0 -505
  431. package/src/client/index.spec.ts +0 -427
  432. package/src/client/index.ts +0 -222
  433. package/src/config/index.spec.ts +0 -339
  434. package/src/config/index.ts +0 -106
  435. package/src/database/init.spec.ts +0 -239
  436. package/src/database/init.ts +0 -130
  437. package/src/database/migrate.spec.ts +0 -293
  438. package/src/database/migrate.ts +0 -94
  439. package/src/database/migrations/001_add_embedding_metadata.sql +0 -29
  440. package/src/npm-client/context-injector.spec.ts +0 -335
  441. package/src/npm-client/context-injector.ts +0 -412
  442. package/src/npm-client/index.spec.ts +0 -108
  443. package/src/npm-client/index.ts +0 -96
  444. package/src/npm-client/memento-client.spec.ts +0 -549
  445. package/src/npm-client/memento-client.ts +0 -501
  446. package/src/npm-client/memory-manager.spec.ts +0 -374
  447. package/src/npm-client/memory-manager.ts +0 -414
  448. package/src/npm-client/types.spec.ts +0 -427
  449. package/src/npm-client/types.ts +0 -296
  450. package/src/npm-client/utils.spec.ts +0 -355
  451. package/src/npm-client/utils.ts +0 -423
  452. package/src/scripts/copy-assets.js +0 -37
  453. package/src/server/http-server.spec.ts +0 -648
  454. package/src/server/http-server.ts +0 -1030
  455. package/src/server/index-backup.ts +0 -875
  456. package/src/server/index-refactored.ts +0 -237
  457. package/src/server/index.spec.ts +0 -281
  458. package/src/server/index.ts +0 -347
  459. package/src/server/simple-mcp-server.spec.ts +0 -207
  460. package/src/server/simple-mcp-server.ts +0 -173
  461. package/src/services/async-optimizer.spec.ts +0 -569
  462. package/src/services/async-optimizer.ts +0 -484
  463. package/src/services/batch-scheduler.ts +0 -759
  464. package/src/services/cache-service.spec.ts +0 -372
  465. package/src/services/cache-service.ts +0 -434
  466. package/src/services/database-optimizer.spec.ts +0 -344
  467. package/src/services/database-optimizer.ts +0 -450
  468. package/src/services/embedding-provider-factory.ts +0 -173
  469. package/src/services/embedding-service.spec.ts +0 -342
  470. package/src/services/embedding-service.ts +0 -333
  471. package/src/services/error-logging-service.spec.ts +0 -416
  472. package/src/services/error-logging-service.ts +0 -383
  473. package/src/services/forgetting-policy-service.spec.ts +0 -140
  474. package/src/services/forgetting-policy-service.ts +0 -334
  475. package/src/services/gemini-embedding-service.spec.ts +0 -463
  476. package/src/services/gemini-embedding-service.ts +0 -283
  477. package/src/services/lightweight-embedding-service.spec.ts +0 -458
  478. package/src/services/lightweight-embedding-service.ts +0 -324
  479. package/src/services/memory-embedding-service.spec.ts +0 -417
  480. package/src/services/memory-embedding-service.ts +0 -289
  481. package/src/services/minilm-embedding-service.spec.ts +0 -104
  482. package/src/services/minilm-embedding-service.ts +0 -262
  483. package/src/services/performance-alert-service.spec.ts +0 -517
  484. package/src/services/performance-alert-service.ts +0 -477
  485. package/src/services/performance-monitor.spec.ts +0 -401
  486. package/src/services/performance-monitor.ts +0 -532
  487. package/src/services/performance-monitoring-integration.spec.ts +0 -478
  488. package/src/services/performance-monitoring-integration.ts.bak +0 -276
  489. package/src/services/unified-embedding-service.spec.ts +0 -224
  490. package/src/services/unified-embedding-service.ts +0 -255
  491. package/src/test/debug-http-v2.ts +0 -30
  492. package/src/test/embedding-integration-test.spec.ts +0 -295
  493. package/src/test/embedding-integration-test.ts +0 -295
  494. package/src/test/embedding-performance-benchmark.spec.ts +0 -354
  495. package/src/test/embedding-performance-benchmark.ts +0 -312
  496. package/src/test/performance-benchmark.ts +0 -565
  497. package/src/test/test-alerts-direct.ts +0 -136
  498. package/src/test/test-batch-scheduler-simple.spec.ts +0 -122
  499. package/src/test/test-batch-scheduler.spec.ts +0 -453
  500. package/src/test/test-batch-scheduler.ts +0 -182
  501. package/src/test/test-client.ts +0 -97
  502. package/src/test/test-embedding.ts +0 -153
  503. package/src/test/test-error-handling.spec.ts +0 -575
  504. package/src/test/test-error-logging.ts +0 -117
  505. package/src/test/test-forgetting.ts +0 -162
  506. package/src/test/test-gemini-embedding.ts +0 -159
  507. package/src/test/test-http-server-v2-simple.ts +0 -147
  508. package/src/test/test-http-server-v2.ts +0 -586
  509. package/src/test/test-hybrid-search-engine.spec.ts +0 -521
  510. package/src/test/test-integration-fixed.spec.ts +0 -612
  511. package/src/test/test-integration.spec.ts +0 -463
  512. package/src/test/test-lightweight-embedding.ts +0 -208
  513. package/src/test/test-m1-completion.spec.ts +0 -614
  514. package/src/test/test-m1-completion.ts +0 -141
  515. package/src/test/test-m1-integration.spec.ts +0 -514
  516. package/src/test/test-memory-injection-prompt.spec.ts +0 -650
  517. package/src/test/test-memory-injection-prompt.ts +0 -391
  518. package/src/test/test-performance-alerts.ts +0 -125
  519. package/src/test/test-performance-monitor-updates.spec.ts +0 -490
  520. package/src/test/test-performance-monitor.spec.ts +0 -284
  521. package/src/test/test-performance-monitor.ts +0 -228
  522. package/src/test/test-performance-monitoring.ts +0 -171
  523. package/src/test/test-search.ts +0 -151
  524. package/src/test/test-simple-alerts.ts +0 -136
  525. package/src/test/test-vector-search-engine.spec.ts +0 -408
  526. package/src/test/test-vector-search-engine.ts +0 -303
  527. package/src/tools/base-tool.ts +0 -189
  528. package/src/tools/cleanup-memory-tool.ts +0 -77
  529. package/src/tools/database-optimize-tool.ts +0 -79
  530. package/src/tools/error-stats.ts +0 -119
  531. package/src/tools/forget-tool.spec.ts +0 -613
  532. package/src/tools/forget-tool.ts +0 -454
  533. package/src/tools/forgetting-stats-tool.ts +0 -47
  534. package/src/tools/index.ts +0 -71
  535. package/src/tools/memory-injection-prompt.ts +0 -257
  536. package/src/tools/performance-alerts.ts +0 -226
  537. package/src/tools/performance-stats-tool.ts +0 -48
  538. package/src/tools/pin-tool.spec.ts +0 -497
  539. package/src/tools/pin-tool.ts +0 -277
  540. package/src/tools/recall-tool.spec.ts +0 -475
  541. package/src/tools/recall-tool.ts +0 -389
  542. package/src/tools/remember-tool.spec.ts +0 -469
  543. package/src/tools/remember-tool.ts +0 -112
  544. package/src/tools/resolve-error.ts +0 -69
  545. package/src/tools/tool-registry.ts +0 -417
  546. package/src/tools/types.ts +0 -63
  547. package/src/tools/unpin-tool.spec.ts +0 -549
  548. package/src/tools/unpin-tool.ts +0 -306
  549. package/src/types/embedding.types.ts +0 -78
  550. package/src/types/index.spec.ts +0 -420
  551. package/src/types/index.ts +0 -117
  552. package/src/utils/database.spec.ts +0 -77
  553. package/src/utils/database.ts +0 -458
  554. package/src/utils/stopwords.ts +0 -128
  555. package/start-docker-setup.bat +0 -38
  556. package/static/logo.png +0 -0
  557. package/static/memento_logo.svg +0 -2
  558. package/test-docker.js +0 -103
  559. package/tsconfig.json +0 -46
  560. package/vitest.config.ts +0 -23
@@ -1,205 +0,0 @@
1
- ---
2
- globs: *.ts,*.js
3
- description: MCP 도구 아키텍처 분리 가이드라인
4
- ---
5
-
6
- # MCP 도구 아키텍처 분리 가이드라인
7
-
8
- ## 🎯 아키텍처 원칙
9
-
10
- ### 핵심 분리 원칙
11
- - **MCP 클라이언트**: AI Agent가 직접 사용하는 핵심 기능만 노출
12
- - **HTTP 관리 API**: 시스템 관리자용 기능은 별도 엔드포인트로 분리
13
- - **보안성**: 관리 기능이 클라이언트에 노출되지 않음
14
- - **단순성**: AI Agent는 핵심 기능에만 집중
15
-
16
- ## 🛠️ MCP 클라이언트 도구 (5개만)
17
-
18
- ### 핵심 메모리 관리
19
- ```typescript
20
- // 1. remember - 기억 저장
21
- {
22
- name: "remember",
23
- description: "기억을 저장합니다",
24
- inputSchema: {
25
- content: { type: "string", required: true },
26
- type: { type: "string", enum: ["working", "episodic", "semantic", "procedural"] },
27
- tags: { type: "array", items: { type: "string" } },
28
- importance: { type: "number", minimum: 0, maximum: 1 },
29
- source: { type: "string" },
30
- privacy_scope: { type: "string", enum: ["private", "team", "public"] }
31
- }
32
- }
33
-
34
- // 2. recall - 기억 검색
35
- {
36
- name: "recall",
37
- description: "기억을 검색합니다",
38
- inputSchema: {
39
- query: { type: "string", required: true },
40
- filters: { type: "object" },
41
- limit: { type: "number", minimum: 1, maximum: 50 }
42
- }
43
- }
44
-
45
- // 3. pin - 기억 고정
46
- {
47
- name: "pin",
48
- description: "기억을 고정합니다",
49
- inputSchema: {
50
- id: { type: "string", required: true }
51
- }
52
- }
53
-
54
- // 4. unpin - 기억 고정 해제
55
- {
56
- name: "unpin",
57
- description: "기억 고정을 해제합니다",
58
- inputSchema: {
59
- id: { type: "string", required: true }
60
- }
61
- }
62
-
63
- // 5. forget - 기억 삭제
64
- {
65
- name: "forget",
66
- description: "기억을 삭제합니다",
67
- inputSchema: {
68
- id: { type: "string", required: true },
69
- hard: { type: "boolean", default: false }
70
- }
71
- }
72
- ```
73
-
74
- ## 🌐 HTTP 관리 API 엔드포인트
75
-
76
- ### 메모리 관리
77
- ```typescript
78
- // 메모리 정리
79
- POST /admin/memory/cleanup
80
- Response: { message: "메모리 정리 완료" }
81
-
82
- // 망각 통계
83
- GET /admin/stats/forgetting
84
- Response: { message: "망각 통계 조회 완료" }
85
- ```
86
-
87
- ### 성능 모니터링
88
- ```typescript
89
- // 성능 통계
90
- GET /admin/stats/performance
91
- Response: { message: "성능 통계 조회 완료" }
92
-
93
- // 성능 알림
94
- GET /admin/alerts/performance
95
- Response: { message: "성능 알림 조회 완료" }
96
- ```
97
-
98
- ### 에러 관리
99
- ```typescript
100
- // 에러 통계
101
- GET /admin/stats/errors
102
- Response: { message: "에러 통계 조회 완료" }
103
-
104
- // 에러 해결
105
- POST /admin/errors/resolve
106
- Body: { errorId: string, resolvedBy: string, reason?: string }
107
- Response: { message: "에러 해결 완료" }
108
- ```
109
-
110
- ### 데이터베이스 관리
111
- ```typescript
112
- // 데이터베이스 최적화
113
- POST /admin/database/optimize
114
- Response: { message: "데이터베이스 최적화 완료" }
115
- ```
116
-
117
- ## 🔧 구현 가이드라인
118
-
119
- ### MCP 서버 구현
120
- ```typescript
121
- // src/tools/index.ts
122
- const coreTools = [
123
- new RememberTool(),
124
- new RecallTool(),
125
- new ForgetTool(),
126
- new PinTool(),
127
- new UnpinTool(),
128
- ];
129
-
130
- // 핵심 도구들만 등록
131
- toolRegistry.registerAll(coreTools.map(tool => tool.getDefinition()));
132
- ```
133
-
134
- ### HTTP 서버 구현
135
- ```typescript
136
- // src/server/http-server.ts
137
- // 관리자 API 엔드포인트들
138
- app.post('/admin/memory/cleanup', async (req, res) => {
139
- // 메모리 정리 로직
140
- });
141
-
142
- app.get('/admin/stats/performance', async (req, res) => {
143
- // 성능 통계 로직
144
- });
145
- ```
146
-
147
- ## 📋 도구 분류 기준
148
-
149
- ### MCP 클라이언트 도구 (포함)
150
- - ✅ AI Agent가 직접 사용하는 기능
151
- - ✅ 기억의 CRUD 작업
152
- - ✅ 사용자 인터랙션과 직접 관련
153
- - ✅ 실시간으로 자주 호출되는 기능
154
-
155
- ### HTTP 관리 API (제외)
156
- - ❌ 시스템 관리자용 기능
157
- - ❌ 성능 모니터링 및 통계
158
- - ❌ 에러 로깅 및 디버깅
159
- - ❌ 데이터베이스 최적화
160
- - ❌ 배치 작업 및 유지보수
161
-
162
- ## 🚀 마이그레이션 가이드
163
-
164
- ### 기존 코드에서 제거할 도구들
165
- ```typescript
166
- // 제거된 관리 도구들
167
- - cleanup_memory
168
- - forgetting_stats
169
- - performance_stats
170
- - database_optimize
171
- - error_stats
172
- - resolve_error
173
- - performance_alerts
174
- ```
175
-
176
- ### 새로운 HTTP API 사용법
177
- ```typescript
178
- // 기존 MCP 도구 대신 HTTP API 사용
179
- const response = await fetch('/admin/stats/performance');
180
- const stats = await response.json();
181
- ```
182
-
183
- ## 🔒 보안 고려사항
184
-
185
- ### MCP 클라이언트 보안
186
- - 핵심 기능만 노출하여 공격 표면 최소화
187
- - AI Agent가 불필요한 시스템 접근 불가
188
- - 민감한 관리 기능 격리
189
-
190
- ### HTTP 관리 API 보안
191
- - 별도 인증 메커니즘 필요 (향후)
192
- - 관리자 권한 검증
193
- - 로그 및 감사 추적
194
-
195
- ## 📊 성능 최적화
196
-
197
- ### MCP 클라이언트 최적화
198
- - 도구 수 감소로 응답 시간 단축
199
- - 메모리 사용량 감소
200
- - 네트워크 오버헤드 감소
201
-
202
- ### HTTP 관리 API 최적화
203
- - 별도 스레드에서 처리
204
- - 캐싱 전략 적용
205
- - 비동기 처리로 메인 서비스 영향 최소화
@@ -1,8 +0,0 @@
1
- ---
2
- description:
3
- globs:
4
- alwaysApply: true
5
- ---
6
- 해야 하는 일과 처리해낸 일에 대한 정보를 memento를 이용하여 기억으로 저장해야 합니다.
7
-
8
- 답변을 제공하거나 작업을 진행하기 전에 저장되어있는 관련 기억이 있는지 확인해보고 참고해야 합니다.
@@ -1,502 +0,0 @@
1
- ---
2
- globs: *.ts,*.js
3
- description: 기억 알고리즘 및 검색 랭킹 수식 구현 규칙
4
- ---
5
-
6
- # 기억 알고리즘 및 검색 랭킹 수식 규칙
7
-
8
- ## 📊 검색 랭킹 공식 구현
9
-
10
- ### 최종 점수 계산
11
- ```typescript
12
- interface SearchScore {
13
- relevance: number;
14
- recency: number;
15
- importance: number;
16
- usage: number;
17
- duplication_penalty: number;
18
- final_score: number;
19
- }
20
-
21
- class SearchRanking {
22
- // 기본 계수 (M1 추천값)
23
- private readonly ALPHA = 0.50; // relevance
24
- private readonly BETA = 0.20; // recency
25
- private readonly GAMMA = 0.20; // importance
26
- private readonly DELTA = 0.10; // usage
27
- private readonly EPSILON = 0.15; // duplication_penalty
28
-
29
- calculateFinalScore(score: Omit<SearchScore, 'final_score'>): number {
30
- return this.ALPHA * score.relevance +
31
- this.BETA * score.recency +
32
- this.GAMMA * score.importance +
33
- this.DELTA * score.usage -
34
- this.EPSILON * score.duplication_penalty;
35
- }
36
- }
37
- ```
38
-
39
- ### 관련성(relevance) 계산
40
- ```typescript
41
- class RelevanceCalculator {
42
- // 관련성 가중치 (M1 추천값)
43
- private readonly WEIGHT_EMBEDDING = 0.60;
44
- private readonly WEIGHT_KEYWORD = 0.30;
45
- private readonly WEIGHT_TAG = 0.05;
46
- private readonly WEIGHT_TITLE = 0.05;
47
-
48
- calculateRelevance(
49
- embeddingSimilarity: number,
50
- bm25Score: number,
51
- tagMatch: number,
52
- titleHit: number
53
- ): number {
54
- return this.WEIGHT_EMBEDDING * embeddingSimilarity +
55
- this.WEIGHT_KEYWORD * this.normalizeBM25(bm25Score) +
56
- this.WEIGHT_TAG * tagMatch +
57
- this.WEIGHT_TITLE * titleHit;
58
- }
59
-
60
- // BM25 정규화
61
- private normalizeBM25(bm25Score: number, kNorm: number = 2.0): number {
62
- return bm25Score / (bm25Score + kNorm);
63
- }
64
-
65
- // 임베딩 유사도 (코사인)
66
- calculateEmbeddingSimilarity(queryEmbedding: number[], docEmbedding: number[]): number {
67
- const dotProduct = this.dotProduct(queryEmbedding, docEmbedding);
68
- const magnitudeA = this.magnitude(queryEmbedding);
69
- const magnitudeB = this.magnitude(docEmbedding);
70
-
71
- const cosine = dotProduct / (magnitudeA * magnitudeB);
72
- return Math.max(0, cosine); // 음수 방지
73
- }
74
-
75
- // 태그 매칭 (자카드 유사도)
76
- calculateTagMatch(queryTags: string[], docTags: string[]): number {
77
- const intersection = new Set(queryTags.filter(tag => docTags.includes(tag)));
78
- const union = new Set([...queryTags, ...docTags]);
79
-
80
- return intersection.size / union.size;
81
- }
82
-
83
- // 타이틀 히트
84
- calculateTitleHit(query: string, title: string): number {
85
- const queryLower = query.toLowerCase();
86
- const titleLower = title.toLowerCase();
87
-
88
- let score = 0;
89
-
90
- // 정확 매치
91
- if (titleLower === queryLower) score += 1.0;
92
- // 접두 매치
93
- else if (titleLower.startsWith(queryLower)) score += 0.5;
94
- // N-gram 매치
95
- else if (this.hasNgramMatch(queryLower, titleLower)) score += 0.2;
96
-
97
- return score;
98
- }
99
- }
100
- ```
101
-
102
- ### 최근성(recency) 계산
103
- ```typescript
104
- class RecencyCalculator {
105
- // 반감기 설정 (일 단위)
106
- private readonly HALF_LIFE = {
107
- working: 2,
108
- episodic: 30,
109
- semantic: 180
110
- };
111
-
112
- calculateRecency(createdAt: Date, type: string): number {
113
- const ageDays = this.getAgeInDays(createdAt);
114
- const halfLife = this.HALF_LIFE[type as keyof typeof this.HALF_LIFE] || 30;
115
-
116
- return Math.exp(-Math.log(2) * ageDays / halfLife);
117
- }
118
-
119
- private getAgeInDays(date: Date): number {
120
- const now = new Date();
121
- const diffTime = now.getTime() - date.getTime();
122
- return diffTime / (1000 * 60 * 60 * 24);
123
- }
124
- }
125
- ```
126
-
127
- ### 중요도(importance) 계산
128
- ```typescript
129
- class ImportanceCalculator {
130
- calculateImportance(
131
- userImportance: number,
132
- isPinned: boolean,
133
- type: string
134
- ): number {
135
- const pinnedBoost = isPinned ? 0.20 : 0;
136
- const typeBoost = this.getTypeBoost(type);
137
-
138
- return Math.max(0, Math.min(1,
139
- userImportance + pinnedBoost + typeBoost
140
- ));
141
- }
142
-
143
- private getTypeBoost(type: string): number {
144
- switch (type) {
145
- case 'semantic': return 0.10;
146
- case 'episodic': return 0.00;
147
- case 'working': return -0.05;
148
- case 'procedural': return 0.05;
149
- default: return 0.00;
150
- }
151
- }
152
- }
153
- ```
154
-
155
- ### 사용성(usage) 계산
156
- ```typescript
157
- class UsageCalculator {
158
- calculateUsage(
159
- viewCount: number,
160
- citeCount: number,
161
- editCount: number,
162
- batchMin: number,
163
- batchMax: number
164
- ): number {
165
- const rawUsage =
166
- Math.log(1 + viewCount) +
167
- 2 * Math.log(1 + citeCount) +
168
- 0.5 * Math.log(1 + editCount);
169
-
170
- return this.normalize(rawUsage, batchMin, batchMax);
171
- }
172
-
173
- private normalize(value: number, min: number, max: number, epsilon: number = 1e-6): number {
174
- return (value - min) / (max - min + epsilon);
175
- }
176
- }
177
- ```
178
-
179
- ### 중복 패널티(duplication_penalty) 계산
180
- ```typescript
181
- class DuplicationPenaltyCalculator {
182
- calculateDuplicationPenalty(
183
- candidateEmbedding: number[],
184
- selectedEmbeddings: number[][]
185
- ): number {
186
- if (selectedEmbeddings.length === 0) return 0;
187
-
188
- let maxSimilarity = 0;
189
-
190
- for (const selectedEmbedding of selectedEmbeddings) {
191
- const similarity = this.cosineSimilarity(candidateEmbedding, selectedEmbedding);
192
- maxSimilarity = Math.max(maxSimilarity, similarity);
193
- }
194
-
195
- return maxSimilarity;
196
- }
197
-
198
- private cosineSimilarity(a: number[], b: number[]): number {
199
- const dotProduct = this.dotProduct(a, b);
200
- const magnitudeA = this.magnitude(a);
201
- const magnitudeB = this.magnitude(b);
202
-
203
- return dotProduct / (magnitudeA * magnitudeB);
204
- }
205
- }
206
- ```
207
-
208
- ## 🧠 망각 알고리즘 구현
209
-
210
- ### 망각 점수 계산
211
- ```typescript
212
- class ForgetScoreCalculator {
213
- // 망각 점수 계수 (M1 추천값)
214
- private readonly U1 = 0.35; // recency 가중치
215
- private readonly U2 = 0.25; // usage 가중치
216
- private readonly U3 = 0.20; // duplication 가중치
217
- private readonly U4 = 0.15; // importance 가중치
218
- private readonly U5 = 0.30; // pinned 가중치
219
-
220
- calculateForgetScore(
221
- recency: number,
222
- usage: number,
223
- dupRatio: number,
224
- importance: number,
225
- isPinned: boolean
226
- ): number {
227
- return this.U1 * (1 - recency) +
228
- this.U2 * (1 - usage) +
229
- this.U3 * dupRatio -
230
- this.U4 * importance -
231
- this.U5 * (isPinned ? 1 : 0);
232
- }
233
- }
234
- ```
235
-
236
- ### 망각 정책 적용
237
- ```typescript
238
- class ForgetPolicy {
239
- // TTL 설정 (일 단위)
240
- private readonly TTL_SOFT = {
241
- working: 2,
242
- episodic: 30,
243
- semantic: Infinity
244
- };
245
-
246
- private readonly TTL_HARD = {
247
- working: 7,
248
- episodic: 180,
249
- semantic: Infinity
250
- };
251
-
252
- // 소프트 삭제 후보 선정
253
- isSoftDeleteCandidate(
254
- memory: MemoryItem,
255
- forgetScore: number
256
- ): boolean {
257
- const ageDays = this.getAgeInDays(memory.created_at);
258
- const ttl = this.TTL_SOFT[memory.type as keyof typeof this.TTL_SOFT];
259
-
260
- return forgetScore >= 0.6 &&
261
- ageDays >= ttl &&
262
- !memory.pinned;
263
- }
264
-
265
- // 하드 삭제 후보 선정
266
- isHardDeleteCandidate(
267
- memory: MemoryItem,
268
- forgetScore: number
269
- ): boolean {
270
- const ageDays = this.getAgeInDays(memory.created_at);
271
- const ttl = this.TTL_HARD[memory.type as keyof typeof this.TTL_HARD];
272
-
273
- return forgetScore >= 0.8 &&
274
- ageDays >= ttl &&
275
- !memory.pinned;
276
- }
277
- }
278
- ```
279
-
280
- ## 🔄 간격 반복 알고리즘
281
-
282
- ### 간격 반복 스케줄러
283
- ```typescript
284
- class SpacedReviewScheduler {
285
- // 간격 반복 계수
286
- private readonly A1 = 0.6; // importance 가중치
287
- private readonly A2 = 0.4; // usage 가중치
288
- private readonly A3 = 0.5; // helpful feedback 가중치
289
- private readonly A4 = 0.7; // bad feedback 가중치
290
-
291
- calculateNextReviewInterval(
292
- currentInterval: number,
293
- importance: number,
294
- usage: number,
295
- helpfulFeedback: number,
296
- badFeedback: number
297
- ): number {
298
- const multiplier = 1 +
299
- this.A1 * importance +
300
- this.A2 * usage +
301
- this.A3 * helpfulFeedback -
302
- this.A4 * badFeedback;
303
-
304
- return Math.ceil(currentInterval * multiplier);
305
- }
306
-
307
- // 리뷰 확률 계산
308
- calculateRecallProbability(
309
- timeSinceLastReview: number,
310
- interval: number
311
- ): number {
312
- return Math.exp(-timeSinceLastReview / interval);
313
- }
314
-
315
- // 리뷰 필요 여부 판단
316
- needsReview(
317
- timeSinceLastReview: number,
318
- interval: number,
319
- threshold: number = 0.7
320
- ): boolean {
321
- const recallProb = this.calculateRecallProbability(timeSinceLastReview, interval);
322
- return recallProb <= threshold;
323
- }
324
- }
325
- ```
326
-
327
- ## 🔍 2단계 검색 파이프라인
328
-
329
- ### 검색 파이프라인 구현
330
- ```typescript
331
- class SearchPipeline {
332
- constructor(
333
- private vectorSearch: VectorSearchService,
334
- private textSearch: TextSearchService,
335
- private rankingCalculator: SearchRanking
336
- ) {}
337
-
338
- async search(
339
- query: string,
340
- filters: SearchFilters,
341
- limit: number = 10
342
- ): Promise<SearchResult[]> {
343
- // 1. 후보 생성
344
- const candidates = await this.generateCandidates(query, filters);
345
-
346
- // 2. 특징 계산
347
- const features = await this.computeFeatures(candidates, query);
348
-
349
- // 3. 점수 계산
350
- const scoredResults = this.calculateScores(candidates, features);
351
-
352
- // 4. 다양화 (MMR)
353
- const diversifiedResults = this.diversifyResults(scoredResults, limit);
354
-
355
- // 5. 임계값 필터링
356
- return this.filterByThreshold(diversifiedResults, 0.35);
357
- }
358
-
359
- private async generateCandidates(
360
- query: string,
361
- filters: SearchFilters
362
- ): Promise<MemoryItem[]> {
363
- // 벡터 검색 (ANN)
364
- const vectorResults = await this.vectorSearch.search(query, 50);
365
-
366
- // 텍스트 검색 (BM25)
367
- const textResults = await this.textSearch.search(query, 50);
368
-
369
- // 합집합 생성
370
- const candidateMap = new Map<string, MemoryItem>();
371
-
372
- vectorResults.forEach(item => candidateMap.set(item.id, item));
373
- textResults.forEach(item => candidateMap.set(item.id, item));
374
-
375
- return Array.from(candidateMap.values());
376
- }
377
-
378
- private async computeFeatures(
379
- candidates: MemoryItem[],
380
- query: string
381
- ): Promise<FeatureVector[]> {
382
- // 각 후보에 대해 특징 계산
383
- return Promise.all(candidates.map(async (candidate) => {
384
- const relevance = await this.calculateRelevance(candidate, query);
385
- const recency = this.calculateRecency(candidate.created_at, candidate.type);
386
- const importance = this.calculateImportance(candidate);
387
- const usage = await this.calculateUsage(candidate.id);
388
-
389
- return {
390
- memory_id: candidate.id,
391
- relevance,
392
- recency,
393
- importance,
394
- usage,
395
- duplication_penalty: 0 // 초기값
396
- };
397
- }));
398
- }
399
- }
400
- ```
401
-
402
- ## 📈 성능 최적화
403
-
404
- ### 배치 정규화
405
- ```typescript
406
- class BatchNormalizer {
407
- normalizeFeatures(features: FeatureVector[]): FeatureVector[] {
408
- const normalized = [...features];
409
-
410
- // usage 정규화
411
- const usageValues = features.map(f => f.usage);
412
- const usageMin = Math.min(...usageValues);
413
- const usageMax = Math.max(...usageValues);
414
-
415
- normalized.forEach(feature => {
416
- feature.usage = this.normalize(feature.usage, usageMin, usageMax);
417
- });
418
-
419
- return normalized;
420
- }
421
-
422
- private normalize(value: number, min: number, max: number): number {
423
- return (value - min) / (max - min + 1e-6);
424
- }
425
- }
426
- ```
427
-
428
- ### MMR 다양화
429
- ```typescript
430
- class MMRDiversifier {
431
- diversify(
432
- results: ScoredResult[],
433
- limit: number,
434
- lambda: number = 0.8
435
- ): ScoredResult[] {
436
- const selected: ScoredResult[] = [];
437
- const remaining = [...results];
438
-
439
- while (selected.length < limit && remaining.length > 0) {
440
- let bestIndex = 0;
441
- let bestScore = -Infinity;
442
-
443
- remaining.forEach((candidate, index) => {
444
- const mmrScore = this.calculateMMRScore(
445
- candidate,
446
- selected,
447
- lambda
448
- );
449
-
450
- if (mmrScore > bestScore) {
451
- bestScore = mmrScore;
452
- bestIndex = index;
453
- }
454
- });
455
-
456
- selected.push(remaining[bestIndex]);
457
- remaining.splice(bestIndex, 1);
458
- }
459
-
460
- return selected;
461
- }
462
-
463
- private calculateMMRScore(
464
- candidate: ScoredResult,
465
- selected: ScoredResult[],
466
- lambda: number
467
- ): number {
468
- const relevanceScore = candidate.final_score;
469
- const maxSimilarity = this.getMaxSimilarity(candidate, selected);
470
-
471
- return lambda * relevanceScore - (1 - lambda) * maxSimilarity;
472
- }
473
- }
474
- ```
475
-
476
- ## 🧪 테스트 가이드
477
-
478
- ### 단위 테스트 예시
479
- ```typescript
480
- describe('SearchRanking', () => {
481
- let ranking: SearchRanking;
482
-
483
- beforeEach(() => {
484
- ranking = new SearchRanking();
485
- });
486
-
487
- it('should calculate final score correctly', () => {
488
- const score = {
489
- relevance: 0.8,
490
- recency: 0.6,
491
- importance: 0.7,
492
- usage: 0.5,
493
- duplication_penalty: 0.2
494
- };
495
-
496
- const result = ranking.calculateFinalScore(score);
497
- expect(result).toBeCloseTo(0.8 * 0.5 + 0.6 * 0.2 + 0.7 * 0.2 + 0.5 * 0.1 - 0.2 * 0.15);
498
- });
499
- });
500
- ```
501
-
502
-