memento-mcp-server 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.cursor/rules/cache-management.mdc +171 -0
- package/.cursor/rules/database-schema.mdc +344 -0
- package/.cursor/rules/deployment.mdc +596 -0
- package/.cursor/rules/error-logging.mdc +298 -0
- package/.cursor/rules/forgetting-algorithms.mdc +426 -0
- package/.cursor/rules/http-server.mdc +432 -0
- package/.cursor/rules/hybrid-search.mdc +424 -0
- package/.cursor/rules/implementation.mdc +369 -0
- package/.cursor/rules/lightweight-embedding.mdc +178 -0
- package/.cursor/rules/mcp-client-development.mdc +0 -0
- package/.cursor/rules/mcp-server-development.mdc +0 -0
- package/.cursor/rules/mcp-tools-architecture.mdc +205 -0
- package/.cursor/rules/memento-memory-rule.mdc +8 -0
- package/.cursor/rules/memento-project-overview.mdc +0 -0
- package/.cursor/rules/memory-algorithms.mdc +502 -0
- package/.cursor/rules/monitoring.mdc +622 -0
- package/.cursor/rules/performance-alerts.mdc +537 -0
- package/.cursor/rules/performance-monitoring.mdc +345 -0
- package/.cursor/rules/performance-optimization.mdc +563 -0
- package/.cursor/rules/project-structure.mdc +310 -0
- package/.cursor/rules/testing.mdc +473 -0
- package/.dockerignore +15 -0
- package/.eslintrc.json +34 -0
- package/.github/ISSUE_TEMPLATE/bug_report.md +51 -0
- package/.github/ISSUE_TEMPLATE/feature_request.md +45 -0
- package/.github/ISSUE_TEMPLATE/question.md +31 -0
- package/.github/PULL_REQUEST_TEMPLATE.md +97 -0
- package/AGENTS.md +28 -0
- package/CHANGELOG.md +416 -0
- package/CODE_OF_CONDUCT.md +62 -0
- package/CONTRIBUTING.md +165 -0
- package/DOCKER_SETUP_GUIDE.md +84 -0
- package/Dockerfile +90 -0
- package/INSTALL.en.md +303 -0
- package/INSTALL.md +303 -0
- package/README.en.md +330 -0
- package/README.md +427 -0
- package/backup/legacy-removal-20250930-201816/http-server-legacy.ts +1068 -0
- package/backup/legacy-removal-20250930-201816/rollback-to-legacy.ps1 +46 -0
- package/backup/legacy-removal-20250930-201816/rollback-to-legacy.sh +48 -0
- package/dist/algorithms/forgetting-algorithm.d.ts +90 -0
- package/dist/algorithms/forgetting-algorithm.d.ts.map +1 -0
- package/dist/algorithms/forgetting-algorithm.js +160 -0
- package/dist/algorithms/forgetting-algorithm.js.map +1 -0
- package/dist/algorithms/hybrid-search-engine.d.ts +108 -0
- package/dist/algorithms/hybrid-search-engine.d.ts.map +1 -0
- package/dist/algorithms/hybrid-search-engine.js +384 -0
- package/dist/algorithms/hybrid-search-engine.js.map +1 -0
- package/dist/algorithms/search-engine.d.ts +64 -0
- package/dist/algorithms/search-engine.d.ts.map +1 -0
- package/dist/algorithms/search-engine.js +304 -0
- package/dist/algorithms/search-engine.js.map +1 -0
- package/dist/algorithms/search-ranking.d.ts +145 -0
- package/dist/algorithms/search-ranking.d.ts.map +1 -0
- package/dist/algorithms/search-ranking.js +311 -0
- package/dist/algorithms/search-ranking.js.map +1 -0
- package/dist/algorithms/spaced-repetition.d.ts +83 -0
- package/dist/algorithms/spaced-repetition.d.ts.map +1 -0
- package/dist/algorithms/spaced-repetition.js +153 -0
- package/dist/algorithms/spaced-repetition.js.map +1 -0
- package/dist/algorithms/vector-search-engine.d.ts +96 -0
- package/dist/algorithms/vector-search-engine.d.ts.map +1 -0
- package/dist/algorithms/vector-search-engine.js +410 -0
- package/dist/algorithms/vector-search-engine.js.map +1 -0
- package/dist/client/index.d.ts +55 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +179 -0
- package/dist/client/index.js.map +1 -0
- package/dist/config/index.d.ts +20 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +87 -0
- package/dist/config/index.js.map +1 -0
- package/dist/database/init.d.ts +7 -0
- package/dist/database/init.d.ts.map +1 -0
- package/dist/database/init.js +117 -0
- package/dist/database/init.js.map +1 -0
- package/dist/database/migrate.d.ts +6 -0
- package/dist/database/migrate.d.ts.map +1 -0
- package/dist/database/migrate.js +84 -0
- package/dist/database/migrate.js.map +1 -0
- package/dist/database/schema.sql +159 -0
- package/dist/npm-client/context-injector.d.ts +106 -0
- package/dist/npm-client/context-injector.d.ts.map +1 -0
- package/dist/npm-client/context-injector.js +296 -0
- package/dist/npm-client/context-injector.js.map +1 -0
- package/dist/npm-client/index.d.ts +42 -0
- package/dist/npm-client/index.d.ts.map +1 -0
- package/dist/npm-client/index.js +43 -0
- package/dist/npm-client/index.js.map +1 -0
- package/dist/npm-client/memento-client.d.ts +114 -0
- package/dist/npm-client/memento-client.d.ts.map +1 -0
- package/dist/npm-client/memento-client.js +391 -0
- package/dist/npm-client/memento-client.js.map +1 -0
- package/dist/npm-client/memory-manager.d.ts +137 -0
- package/dist/npm-client/memory-manager.d.ts.map +1 -0
- package/dist/npm-client/memory-manager.js +341 -0
- package/dist/npm-client/memory-manager.js.map +1 -0
- package/dist/npm-client/types.d.ts +216 -0
- package/dist/npm-client/types.d.ts.map +1 -0
- package/dist/npm-client/types.js +44 -0
- package/dist/npm-client/types.js.map +1 -0
- package/dist/npm-client/utils.d.ts +91 -0
- package/dist/npm-client/utils.d.ts.map +1 -0
- package/dist/npm-client/utils.js +351 -0
- package/dist/npm-client/utils.js.map +1 -0
- package/dist/scripts/copy-assets.d.ts +3 -0
- package/dist/scripts/copy-assets.d.ts.map +1 -0
- package/dist/scripts/copy-assets.js +31 -0
- package/dist/scripts/copy-assets.js.map +1 -0
- package/dist/server/http-server.d.ts +28 -0
- package/dist/server/http-server.d.ts.map +1 -0
- package/dist/server/http-server.js +930 -0
- package/dist/server/http-server.js.map +1 -0
- package/dist/server/index-backup.d.ts +5 -0
- package/dist/server/index-backup.d.ts.map +1 -0
- package/dist/server/index-backup.js +793 -0
- package/dist/server/index-backup.js.map +1 -0
- package/dist/server/index-refactored.d.ts +6 -0
- package/dist/server/index-refactored.d.ts.map +1 -0
- package/dist/server/index-refactored.js +206 -0
- package/dist/server/index-refactored.js.map +1 -0
- package/dist/server/index.d.ts +12 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +301 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/simple-mcp-server.d.ts +8 -0
- package/dist/server/simple-mcp-server.d.ts.map +1 -0
- package/dist/server/simple-mcp-server.js +152 -0
- package/dist/server/simple-mcp-server.js.map +1 -0
- package/dist/services/async-optimizer.d.ts +136 -0
- package/dist/services/async-optimizer.d.ts.map +1 -0
- package/dist/services/async-optimizer.js +406 -0
- package/dist/services/async-optimizer.js.map +1 -0
- package/dist/services/batch-scheduler.d.ts +156 -0
- package/dist/services/batch-scheduler.d.ts.map +1 -0
- package/dist/services/batch-scheduler.js +612 -0
- package/dist/services/batch-scheduler.js.map +1 -0
- package/dist/services/cache-service.d.ts +168 -0
- package/dist/services/cache-service.d.ts.map +1 -0
- package/dist/services/cache-service.js +360 -0
- package/dist/services/cache-service.js.map +1 -0
- package/dist/services/database-optimizer.d.ts +110 -0
- package/dist/services/database-optimizer.d.ts.map +1 -0
- package/dist/services/database-optimizer.js +369 -0
- package/dist/services/database-optimizer.js.map +1 -0
- package/dist/services/embedding-provider-factory.d.ts +62 -0
- package/dist/services/embedding-provider-factory.d.ts.map +1 -0
- package/dist/services/embedding-provider-factory.js +152 -0
- package/dist/services/embedding-provider-factory.js.map +1 -0
- package/dist/services/embedding-service.d.ts +95 -0
- package/dist/services/embedding-service.d.ts.map +1 -0
- package/dist/services/embedding-service.js +276 -0
- package/dist/services/embedding-service.js.map +1 -0
- package/dist/services/error-logging-service.d.ts +134 -0
- package/dist/services/error-logging-service.d.ts.map +1 -0
- package/dist/services/error-logging-service.js +271 -0
- package/dist/services/error-logging-service.js.map +1 -0
- package/dist/services/forgetting-policy-service.d.ts +94 -0
- package/dist/services/forgetting-policy-service.d.ts.map +1 -0
- package/dist/services/forgetting-policy-service.js +233 -0
- package/dist/services/forgetting-policy-service.js.map +1 -0
- package/dist/services/gemini-embedding-service.d.ts +82 -0
- package/dist/services/gemini-embedding-service.d.ts.map +1 -0
- package/dist/services/gemini-embedding-service.js +232 -0
- package/dist/services/gemini-embedding-service.js.map +1 -0
- package/dist/services/lightweight-embedding-service.d.ts +95 -0
- package/dist/services/lightweight-embedding-service.d.ts.map +1 -0
- package/dist/services/lightweight-embedding-service.js +263 -0
- package/dist/services/lightweight-embedding-service.js.map +1 -0
- package/dist/services/memory-embedding-service.d.ts +69 -0
- package/dist/services/memory-embedding-service.d.ts.map +1 -0
- package/dist/services/memory-embedding-service.js +223 -0
- package/dist/services/memory-embedding-service.js.map +1 -0
- package/dist/services/minilm-embedding-service.d.ts +92 -0
- package/dist/services/minilm-embedding-service.d.ts.map +1 -0
- package/dist/services/minilm-embedding-service.js +216 -0
- package/dist/services/minilm-embedding-service.js.map +1 -0
- package/dist/services/performance-alert-service.d.ts +142 -0
- package/dist/services/performance-alert-service.d.ts.map +1 -0
- package/dist/services/performance-alert-service.js +366 -0
- package/dist/services/performance-alert-service.js.map +1 -0
- package/dist/services/performance-monitor.d.ts +144 -0
- package/dist/services/performance-monitor.d.ts.map +1 -0
- package/dist/services/performance-monitor.js +416 -0
- package/dist/services/performance-monitor.js.map +1 -0
- package/dist/services/performance-monitoring-integration.d.ts +77 -0
- package/dist/services/performance-monitoring-integration.d.ts.map +1 -0
- package/dist/services/performance-monitoring-integration.js +177 -0
- package/dist/services/performance-monitoring-integration.js.map +1 -0
- package/dist/services/unified-embedding-service.d.ts +75 -0
- package/dist/services/unified-embedding-service.d.ts.map +1 -0
- package/dist/services/unified-embedding-service.js +211 -0
- package/dist/services/unified-embedding-service.js.map +1 -0
- package/dist/test/debug-http-v2.d.ts +5 -0
- package/dist/test/debug-http-v2.d.ts.map +1 -0
- package/dist/test/debug-http-v2.js +28 -0
- package/dist/test/debug-http-v2.js.map +1 -0
- package/dist/test/performance-benchmark.d.ts +57 -0
- package/dist/test/performance-benchmark.d.ts.map +1 -0
- package/dist/test/performance-benchmark.js +427 -0
- package/dist/test/performance-benchmark.js.map +1 -0
- package/dist/test/test-alerts-direct.d.ts +7 -0
- package/dist/test/test-alerts-direct.d.ts.map +1 -0
- package/dist/test/test-alerts-direct.js +101 -0
- package/dist/test/test-alerts-direct.js.map +1 -0
- package/dist/test/test-batch-scheduler.d.ts +2 -0
- package/dist/test/test-batch-scheduler.d.ts.map +1 -0
- package/dist/test/test-batch-scheduler.js +156 -0
- package/dist/test/test-batch-scheduler.js.map +1 -0
- package/dist/test/test-client.d.ts +5 -0
- package/dist/test/test-client.d.ts.map +1 -0
- package/dist/test/test-client.js +86 -0
- package/dist/test/test-client.js.map +1 -0
- package/dist/test/test-embedding.d.ts +6 -0
- package/dist/test/test-embedding.d.ts.map +1 -0
- package/dist/test/test-embedding.js +142 -0
- package/dist/test/test-embedding.js.map +1 -0
- package/dist/test/test-error-logging.d.ts +7 -0
- package/dist/test/test-error-logging.d.ts.map +1 -0
- package/dist/test/test-error-logging.js +105 -0
- package/dist/test/test-error-logging.js.map +1 -0
- package/dist/test/test-forgetting.d.ts +6 -0
- package/dist/test/test-forgetting.d.ts.map +1 -0
- package/dist/test/test-forgetting.js +154 -0
- package/dist/test/test-forgetting.js.map +1 -0
- package/dist/test/test-gemini-embedding.d.ts +7 -0
- package/dist/test/test-gemini-embedding.d.ts.map +1 -0
- package/dist/test/test-gemini-embedding.js +134 -0
- package/dist/test/test-gemini-embedding.js.map +1 -0
- package/dist/test/test-http-server-v2-simple.d.ts +6 -0
- package/dist/test/test-http-server-v2-simple.d.ts.map +1 -0
- package/dist/test/test-http-server-v2-simple.js +131 -0
- package/dist/test/test-http-server-v2-simple.js.map +1 -0
- package/dist/test/test-http-server-v2.d.ts +7 -0
- package/dist/test/test-http-server-v2.d.ts.map +1 -0
- package/dist/test/test-http-server-v2.js +529 -0
- package/dist/test/test-http-server-v2.js.map +1 -0
- package/dist/test/test-lightweight-embedding.d.ts +6 -0
- package/dist/test/test-lightweight-embedding.d.ts.map +1 -0
- package/dist/test/test-lightweight-embedding.js +189 -0
- package/dist/test/test-lightweight-embedding.js.map +1 -0
- package/dist/test/test-m1-completion.d.ts +7 -0
- package/dist/test/test-m1-completion.d.ts.map +1 -0
- package/dist/test/test-m1-completion.js +124 -0
- package/dist/test/test-m1-completion.js.map +1 -0
- package/dist/test/test-memory-injection-prompt.d.ts +2 -0
- package/dist/test/test-memory-injection-prompt.d.ts.map +1 -0
- package/dist/test/test-memory-injection-prompt.js +299 -0
- package/dist/test/test-memory-injection-prompt.js.map +1 -0
- package/dist/test/test-performance-alerts.d.ts +7 -0
- package/dist/test/test-performance-alerts.d.ts.map +1 -0
- package/dist/test/test-performance-alerts.js +109 -0
- package/dist/test/test-performance-alerts.js.map +1 -0
- package/dist/test/test-performance-monitor.d.ts +2 -0
- package/dist/test/test-performance-monitor.d.ts.map +1 -0
- package/dist/test/test-performance-monitor.js +182 -0
- package/dist/test/test-performance-monitor.js.map +1 -0
- package/dist/test/test-performance-monitoring.d.ts +6 -0
- package/dist/test/test-performance-monitoring.d.ts.map +1 -0
- package/dist/test/test-performance-monitoring.js +156 -0
- package/dist/test/test-performance-monitoring.js.map +1 -0
- package/dist/test/test-search.d.ts +5 -0
- package/dist/test/test-search.d.ts.map +1 -0
- package/dist/test/test-search.js +141 -0
- package/dist/test/test-search.js.map +1 -0
- package/dist/test/test-simple-alerts.d.ts +6 -0
- package/dist/test/test-simple-alerts.d.ts.map +1 -0
- package/dist/test/test-simple-alerts.js +106 -0
- package/dist/test/test-simple-alerts.js.map +1 -0
- package/dist/test/test-vector-search-engine.d.ts +2 -0
- package/dist/test/test-vector-search-engine.d.ts.map +1 -0
- package/dist/test/test-vector-search-engine.js +225 -0
- package/dist/test/test-vector-search-engine.js.map +1 -0
- package/dist/tools/base-tool.d.ts +64 -0
- package/dist/tools/base-tool.d.ts.map +1 -0
- package/dist/tools/base-tool.js +158 -0
- package/dist/tools/base-tool.js.map +1 -0
- package/dist/tools/cleanup-memory-tool.d.ts +10 -0
- package/dist/tools/cleanup-memory-tool.d.ts.map +1 -0
- package/dist/tools/cleanup-memory-tool.js +66 -0
- package/dist/tools/cleanup-memory-tool.js.map +1 -0
- package/dist/tools/database-optimize-tool.d.ts +10 -0
- package/dist/tools/database-optimize-tool.d.ts.map +1 -0
- package/dist/tools/database-optimize-tool.js +64 -0
- package/dist/tools/database-optimize-tool.js.map +1 -0
- package/dist/tools/error-stats.d.ts +93 -0
- package/dist/tools/error-stats.d.ts.map +1 -0
- package/dist/tools/error-stats.js +115 -0
- package/dist/tools/error-stats.js.map +1 -0
- package/dist/tools/forget-tool.d.ts +63 -0
- package/dist/tools/forget-tool.d.ts.map +1 -0
- package/dist/tools/forget-tool.js +340 -0
- package/dist/tools/forget-tool.js.map +1 -0
- package/dist/tools/forgetting-stats-tool.d.ts +10 -0
- package/dist/tools/forgetting-stats-tool.d.ts.map +1 -0
- package/dist/tools/forgetting-stats-tool.js +37 -0
- package/dist/tools/forgetting-stats-tool.js.map +1 -0
- package/dist/tools/index.d.ts +33 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +55 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/memory-injection-prompt.d.ts +31 -0
- package/dist/tools/memory-injection-prompt.d.ts.map +1 -0
- package/dist/tools/memory-injection-prompt.js +203 -0
- package/dist/tools/memory-injection-prompt.js.map +1 -0
- package/dist/tools/performance-alerts.d.ts +127 -0
- package/dist/tools/performance-alerts.d.ts.map +1 -0
- package/dist/tools/performance-alerts.js +208 -0
- package/dist/tools/performance-alerts.js.map +1 -0
- package/dist/tools/performance-stats-tool.d.ts +10 -0
- package/dist/tools/performance-stats-tool.d.ts.map +1 -0
- package/dist/tools/performance-stats-tool.js +38 -0
- package/dist/tools/performance-stats-tool.js.map +1 -0
- package/dist/tools/pin-tool.d.ts +39 -0
- package/dist/tools/pin-tool.d.ts.map +1 -0
- package/dist/tools/pin-tool.js +211 -0
- package/dist/tools/pin-tool.js.map +1 -0
- package/dist/tools/recall-tool.d.ts +27 -0
- package/dist/tools/recall-tool.d.ts.map +1 -0
- package/dist/tools/recall-tool.js +335 -0
- package/dist/tools/recall-tool.js.map +1 -0
- package/dist/tools/remember-tool.d.ts +10 -0
- package/dist/tools/remember-tool.d.ts.map +1 -0
- package/dist/tools/remember-tool.js +101 -0
- package/dist/tools/remember-tool.js.map +1 -0
- package/dist/tools/resolve-error.d.ts +54 -0
- package/dist/tools/resolve-error.d.ts.map +1 -0
- package/dist/tools/resolve-error.js +63 -0
- package/dist/tools/resolve-error.js.map +1 -0
- package/dist/tools/tool-registry.d.ts +134 -0
- package/dist/tools/tool-registry.d.ts.map +1 -0
- package/dist/tools/tool-registry.js +337 -0
- package/dist/tools/tool-registry.js.map +1 -0
- package/dist/tools/types.d.ts +56 -0
- package/dist/tools/types.d.ts.map +1 -0
- package/dist/tools/types.js +23 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/tools/unpin-tool.d.ts +43 -0
- package/dist/tools/unpin-tool.d.ts.map +1 -0
- package/dist/tools/unpin-tool.js +233 -0
- package/dist/tools/unpin-tool.js.map +1 -0
- package/dist/types/embedding.types.d.ts +65 -0
- package/dist/types/embedding.types.d.ts.map +1 -0
- package/dist/types/embedding.types.js +6 -0
- package/dist/types/embedding.types.js.map +1 -0
- package/dist/types/index.d.ts +103 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +5 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/database.d.ts +62 -0
- package/dist/utils/database.d.ts.map +1 -0
- package/dist/utils/database.js +399 -0
- package/dist/utils/database.js.map +1 -0
- package/dist/utils/stopwords.d.ts +18 -0
- package/dist/utils/stopwords.d.ts.map +1 -0
- package/dist/utils/stopwords.js +117 -0
- package/dist/utils/stopwords.js.map +1 -0
- package/docker-compose.dev.yml +50 -0
- package/docker-compose.prod.yml +77 -0
- package/docker-compose.yml +43 -0
- package/docs/en/Memento-Goals.md +217 -0
- package/docs/en/Memento-M1-DetailSpecs.md +130 -0
- package/docs/en/Memento-Milestones.md +135 -0
- package/docs/en/Search-Ranking-Memory-Decay-Formulas.md +177 -0
- package/docs/en/api-reference.md +658 -0
- package/docs/en/architecture.md +1302 -0
- package/docs/en/developer-guide.md +1005 -0
- package/docs/en/user-manual.md +595 -0
- package/docs/ko/Memento-Goals.md +217 -0
- package/docs/ko/Memento-M1-DetailSpecs.md +130 -0
- package/docs/ko/Memento-Milestones.md +134 -0
- package/docs/ko/Search-Ranking-Memory-Decay-Formulas.md +177 -0
- package/docs/ko/api-reference.md +658 -0
- package/docs/ko/architecture.md +1302 -0
- package/docs/ko/developer-guide.md +1006 -0
- package/docs/ko/embedding-api-reference.md +122 -0
- package/docs/ko/embedding-configuration.md +62 -0
- package/docs/ko/embedding-performance-benchmark.md +62 -0
- package/docs/ko/embedding-service-guide.md +314 -0
- package/docs/ko/user-manual.md +595 -0
- package/env.example +49 -0
- package/install.sh +191 -0
- package/mcp-http-client.js +218 -0
- package/mcp.json +0 -0
- package/package.json +125 -0
- package/packages/mcp-client/docs/API-REFERENCE.md +560 -0
- package/packages/mcp-client/docs/BEST-PRACTICES.md +564 -0
- package/packages/mcp-client/docs/MIGRATION-GUIDE.md +344 -0
- package/packages/mcp-client/docs/PERFORMANCE-GUIDE.md +476 -0
- package/packages/mcp-client/docs/TROUBLESHOOTING.md +564 -0
- package/packages/mcp-client/package-lock.json +907 -0
- package/packages/mcp-client/package.json +58 -0
- package/packages/mcp-client/performance-optimizer.js +428 -0
- package/packages/mcp-client/test-basic.js +65 -0
- package/packages/mcp-client/test-integration.js +366 -0
- package/scripts/auto-setup.js +234 -0
- package/scripts/backup-daily.bat +28 -0
- package/scripts/backup-embeddings.js +108 -0
- package/scripts/check-db-integrity.js +93 -0
- package/scripts/debug-embeddings.js +184 -0
- package/scripts/direct-sql-migration.sql +36 -0
- package/scripts/docker-migration.sh +105 -0
- package/scripts/fix-migration.js +93 -0
- package/scripts/fix-vector-dimensions.js +206 -0
- package/scripts/migrate-embedding-data.js +307 -0
- package/scripts/regenerate-embeddings.js +144 -0
- package/scripts/restore-legacy.ps1 +60 -0
- package/scripts/restore-legacy.sh +62 -0
- package/scripts/run-migration.js +122 -0
- package/scripts/safe-migration.js +150 -0
- package/scripts/simple-migrate.js +41 -0
- package/scripts/simple-update.js +123 -0
- package/scripts/start-container.sh +10 -0
- package/src/algorithms/forgetting-algorithm.spec.ts +538 -0
- package/src/algorithms/forgetting-algorithm.ts +243 -0
- package/src/algorithms/hybrid-search-engine.spec.ts +484 -0
- package/src/algorithms/hybrid-search-engine.ts +489 -0
- package/src/algorithms/search-engine.spec.ts +429 -0
- package/src/algorithms/search-engine.ts +392 -0
- package/src/algorithms/search-ranking.spec.ts +293 -0
- package/src/algorithms/search-ranking.ts +407 -0
- package/src/algorithms/spaced-repetition.spec.ts +510 -0
- package/src/algorithms/spaced-repetition.ts +238 -0
- package/src/algorithms/vector-search-engine.ts +505 -0
- package/src/client/index.spec.ts +427 -0
- package/src/client/index.ts +222 -0
- package/src/config/index.spec.ts +339 -0
- package/src/config/index.ts +106 -0
- package/src/database/init.spec.ts +239 -0
- package/src/database/init.ts +130 -0
- package/src/database/migrate.spec.ts +293 -0
- package/src/database/migrate.ts +94 -0
- package/src/database/migrations/001_add_embedding_metadata.sql +29 -0
- package/src/database/schema.sql +159 -0
- package/src/npm-client/context-injector.spec.ts +335 -0
- package/src/npm-client/context-injector.ts +412 -0
- package/src/npm-client/index.spec.ts +108 -0
- package/src/npm-client/index.ts +96 -0
- package/src/npm-client/memento-client.spec.ts +549 -0
- package/src/npm-client/memento-client.ts +501 -0
- package/src/npm-client/memory-manager.spec.ts +374 -0
- package/src/npm-client/memory-manager.ts +414 -0
- package/src/npm-client/types.spec.ts +427 -0
- package/src/npm-client/types.ts +296 -0
- package/src/npm-client/utils.spec.ts +355 -0
- package/src/npm-client/utils.ts +423 -0
- package/src/scripts/copy-assets.js +37 -0
- package/src/server/http-server.spec.ts +648 -0
- package/src/server/http-server.ts +1030 -0
- package/src/server/index-backup.ts +875 -0
- package/src/server/index-refactored.ts +237 -0
- package/src/server/index.spec.ts +281 -0
- package/src/server/index.ts +347 -0
- package/src/server/simple-mcp-server.spec.ts +207 -0
- package/src/server/simple-mcp-server.ts +173 -0
- package/src/services/async-optimizer.spec.ts +569 -0
- package/src/services/async-optimizer.ts +484 -0
- package/src/services/batch-scheduler.ts +759 -0
- package/src/services/cache-service.spec.ts +372 -0
- package/src/services/cache-service.ts +434 -0
- package/src/services/database-optimizer.spec.ts +344 -0
- package/src/services/database-optimizer.ts +450 -0
- package/src/services/embedding-provider-factory.ts +173 -0
- package/src/services/embedding-service.spec.ts +342 -0
- package/src/services/embedding-service.ts +333 -0
- package/src/services/error-logging-service.spec.ts +416 -0
- package/src/services/error-logging-service.ts +383 -0
- package/src/services/forgetting-policy-service.spec.ts +140 -0
- package/src/services/forgetting-policy-service.ts +334 -0
- package/src/services/gemini-embedding-service.spec.ts +463 -0
- package/src/services/gemini-embedding-service.ts +283 -0
- package/src/services/lightweight-embedding-service.spec.ts +458 -0
- package/src/services/lightweight-embedding-service.ts +324 -0
- package/src/services/memory-embedding-service.spec.ts +417 -0
- package/src/services/memory-embedding-service.ts +289 -0
- package/src/services/minilm-embedding-service.spec.ts +104 -0
- package/src/services/minilm-embedding-service.ts +262 -0
- package/src/services/performance-alert-service.spec.ts +517 -0
- package/src/services/performance-alert-service.ts +477 -0
- package/src/services/performance-monitor.spec.ts +401 -0
- package/src/services/performance-monitor.ts +532 -0
- package/src/services/performance-monitoring-integration.spec.ts +478 -0
- package/src/services/performance-monitoring-integration.ts.bak +276 -0
- package/src/services/unified-embedding-service.spec.ts +224 -0
- package/src/services/unified-embedding-service.ts +255 -0
- package/src/test/debug-http-v2.ts +30 -0
- package/src/test/embedding-integration-test.spec.ts +295 -0
- package/src/test/embedding-integration-test.ts +295 -0
- package/src/test/embedding-performance-benchmark.spec.ts +354 -0
- package/src/test/embedding-performance-benchmark.ts +312 -0
- package/src/test/performance-benchmark.ts +565 -0
- package/src/test/test-alerts-direct.ts +136 -0
- package/src/test/test-batch-scheduler-simple.spec.ts +122 -0
- package/src/test/test-batch-scheduler.spec.ts +453 -0
- package/src/test/test-batch-scheduler.ts +182 -0
- package/src/test/test-client.ts +97 -0
- package/src/test/test-embedding.ts +153 -0
- package/src/test/test-error-handling.spec.ts +575 -0
- package/src/test/test-error-logging.ts +117 -0
- package/src/test/test-forgetting.ts +162 -0
- package/src/test/test-gemini-embedding.ts +159 -0
- package/src/test/test-http-server-v2-simple.ts +147 -0
- package/src/test/test-http-server-v2.ts +586 -0
- package/src/test/test-hybrid-search-engine.spec.ts +521 -0
- package/src/test/test-integration-fixed.spec.ts +612 -0
- package/src/test/test-integration.spec.ts +463 -0
- package/src/test/test-lightweight-embedding.ts +208 -0
- package/src/test/test-m1-completion.spec.ts +614 -0
- package/src/test/test-m1-completion.ts +141 -0
- package/src/test/test-m1-integration.spec.ts +514 -0
- package/src/test/test-memory-injection-prompt.spec.ts +650 -0
- package/src/test/test-memory-injection-prompt.ts +391 -0
- package/src/test/test-performance-alerts.ts +125 -0
- package/src/test/test-performance-monitor-updates.spec.ts +490 -0
- package/src/test/test-performance-monitor.spec.ts +284 -0
- package/src/test/test-performance-monitor.ts +228 -0
- package/src/test/test-performance-monitoring.ts +171 -0
- package/src/test/test-search.ts +151 -0
- package/src/test/test-simple-alerts.ts +136 -0
- package/src/test/test-vector-search-engine.spec.ts +408 -0
- package/src/test/test-vector-search-engine.ts +303 -0
- package/src/tools/base-tool.ts +189 -0
- package/src/tools/cleanup-memory-tool.ts +77 -0
- package/src/tools/database-optimize-tool.ts +79 -0
- package/src/tools/error-stats.ts +119 -0
- package/src/tools/forget-tool.spec.ts +613 -0
- package/src/tools/forget-tool.ts +454 -0
- package/src/tools/forgetting-stats-tool.ts +47 -0
- package/src/tools/index.ts +71 -0
- package/src/tools/memory-injection-prompt.ts +257 -0
- package/src/tools/performance-alerts.ts +226 -0
- package/src/tools/performance-stats-tool.ts +48 -0
- package/src/tools/pin-tool.spec.ts +497 -0
- package/src/tools/pin-tool.ts +277 -0
- package/src/tools/recall-tool.spec.ts +475 -0
- package/src/tools/recall-tool.ts +389 -0
- package/src/tools/remember-tool.spec.ts +469 -0
- package/src/tools/remember-tool.ts +112 -0
- package/src/tools/resolve-error.ts +69 -0
- package/src/tools/tool-registry.ts +417 -0
- package/src/tools/types.ts +63 -0
- package/src/tools/unpin-tool.spec.ts +549 -0
- package/src/tools/unpin-tool.ts +306 -0
- package/src/types/embedding.types.ts +78 -0
- package/src/types/index.spec.ts +420 -0
- package/src/types/index.ts +117 -0
- package/src/utils/database.spec.ts +77 -0
- package/src/utils/database.ts +458 -0
- package/src/utils/stopwords.ts +128 -0
- package/start-docker-setup.bat +38 -0
- package/static/logo.png +0 -0
- package/static/memento_logo.svg +2 -0
- package/test-docker.js +103 -0
- package/tsconfig.json +46 -0
- package/vitest.config.ts +23 -0
|
@@ -0,0 +1,311 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 검색 랭킹 알고리즘 구현
|
|
3
|
+
* Memento-Goals.md의 검색 랭킹 공식 구현
|
|
4
|
+
*/
|
|
5
|
+
export class SearchRanking {
|
|
6
|
+
weights;
|
|
7
|
+
constructor(weights) {
|
|
8
|
+
this.weights = {
|
|
9
|
+
relevance: 0.50,
|
|
10
|
+
recency: 0.20,
|
|
11
|
+
importance: 0.20,
|
|
12
|
+
usage: 0.10,
|
|
13
|
+
duplication_penalty: 0.15,
|
|
14
|
+
...weights
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* 최종 검색 점수 계산
|
|
19
|
+
* S = α * relevance + β * recency + γ * importance + δ * usage - ε * duplication_penalty
|
|
20
|
+
*/
|
|
21
|
+
calculateFinalScore(features) {
|
|
22
|
+
return this.weights.relevance * features.relevance +
|
|
23
|
+
this.weights.recency * features.recency +
|
|
24
|
+
this.weights.importance * features.importance +
|
|
25
|
+
this.weights.usage * features.usage -
|
|
26
|
+
this.weights.duplication_penalty * features.duplication_penalty;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* 관련성 점수 계산 (실제 구현)
|
|
30
|
+
* 임베딩 유사도(60%) + BM25(30%) + 태그 매칭(5%) + 타이틀 히트(5%)
|
|
31
|
+
*/
|
|
32
|
+
calculateRelevance(input) {
|
|
33
|
+
const { query, content, title, tags, embeddingSimilarity, bm25Result } = input;
|
|
34
|
+
// 입력 검증
|
|
35
|
+
if (!query || !content)
|
|
36
|
+
return 0;
|
|
37
|
+
// 1. 임베딩 유사도 (60% 가중치)
|
|
38
|
+
const embeddingScore = embeddingSimilarity
|
|
39
|
+
? this.calculateEmbeddingSimilarity(embeddingSimilarity.queryEmbedding, embeddingSimilarity.docEmbedding)
|
|
40
|
+
: 0;
|
|
41
|
+
// 2. BM25 점수 (30% 가중치)
|
|
42
|
+
const bm25Score = bm25Result
|
|
43
|
+
? this.normalizeBM25(bm25Result.score)
|
|
44
|
+
: this.calculateSimpleBM25(query, content);
|
|
45
|
+
// 3. 태그 매칭 (5% 가중치)
|
|
46
|
+
const tagScore = this.calculateTagMatch(query, tags);
|
|
47
|
+
// 4. 타이틀 히트 (5% 가중치)
|
|
48
|
+
const titleScore = title ? this.calculateTitleHit(query, title) : 0;
|
|
49
|
+
// 가중치 적용
|
|
50
|
+
return 0.60 * embeddingScore +
|
|
51
|
+
0.30 * bm25Score +
|
|
52
|
+
0.05 * tagScore +
|
|
53
|
+
0.05 * titleScore;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* 임베딩 유사도 계산 (코사인 유사도)
|
|
57
|
+
*/
|
|
58
|
+
calculateEmbeddingSimilarity(queryEmbedding, docEmbedding) {
|
|
59
|
+
if (queryEmbedding.length !== docEmbedding.length)
|
|
60
|
+
return 0;
|
|
61
|
+
const dotProduct = this.dotProduct(queryEmbedding, docEmbedding);
|
|
62
|
+
const magnitudeA = this.magnitude(queryEmbedding);
|
|
63
|
+
const magnitudeB = this.magnitude(docEmbedding);
|
|
64
|
+
if (magnitudeA === 0 || magnitudeB === 0)
|
|
65
|
+
return 0;
|
|
66
|
+
const cosine = dotProduct / (magnitudeA * magnitudeB);
|
|
67
|
+
return Math.max(0, cosine); // 음수 방지
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* BM25 점수 정규화
|
|
71
|
+
*/
|
|
72
|
+
normalizeBM25(bm25Score, kNorm = 2.0) {
|
|
73
|
+
return bm25Score / (bm25Score + kNorm);
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* 간단한 BM25 구현 (실제 BM25가 없는 경우)
|
|
77
|
+
*/
|
|
78
|
+
calculateSimpleBM25(query, content) {
|
|
79
|
+
// 입력 검증
|
|
80
|
+
if (!query || !content)
|
|
81
|
+
return 0;
|
|
82
|
+
const queryTerms = query.toLowerCase().split(/\s+/);
|
|
83
|
+
const contentTerms = content.toLowerCase().split(/\s+/);
|
|
84
|
+
const termFreq = new Map();
|
|
85
|
+
// 용어 빈도 계산
|
|
86
|
+
for (const term of contentTerms) {
|
|
87
|
+
termFreq.set(term, (termFreq.get(term) || 0) + 1);
|
|
88
|
+
}
|
|
89
|
+
let score = 0;
|
|
90
|
+
const k1 = 1.2;
|
|
91
|
+
const b = 0.75;
|
|
92
|
+
const docLength = contentTerms.length;
|
|
93
|
+
const avgDocLength = 100; // 평균 문서 길이 (추정값)
|
|
94
|
+
for (const term of queryTerms) {
|
|
95
|
+
const tf = termFreq.get(term) || 0;
|
|
96
|
+
if (tf > 0) {
|
|
97
|
+
const idf = Math.log(2); // 간단한 IDF (실제로는 전체 문서 수 필요)
|
|
98
|
+
const normalizedTf = (tf * (k1 + 1)) / (tf + k1 * (1 - b + b * (docLength / avgDocLength)));
|
|
99
|
+
score += idf * normalizedTf;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
return Math.min(1.0, score / 10); // 정규화
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* 태그 매칭 (자카드 유사도)
|
|
106
|
+
*/
|
|
107
|
+
calculateTagMatch(query, tags) {
|
|
108
|
+
if (tags.length === 0)
|
|
109
|
+
return 0;
|
|
110
|
+
const queryTerms = new Set(query.toLowerCase().split(/\s+/));
|
|
111
|
+
const tagTerms = new Set(tags.map(tag => tag.toLowerCase()));
|
|
112
|
+
const intersection = new Set([...queryTerms].filter(x => tagTerms.has(x)));
|
|
113
|
+
const union = new Set([...queryTerms, ...tagTerms]);
|
|
114
|
+
return union.size > 0 ? intersection.size / union.size : 0;
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* 타이틀 히트 계산
|
|
118
|
+
*/
|
|
119
|
+
calculateTitleHit(query, title) {
|
|
120
|
+
const queryLower = query.toLowerCase();
|
|
121
|
+
const titleLower = title.toLowerCase();
|
|
122
|
+
let score = 0;
|
|
123
|
+
// 정확 매치
|
|
124
|
+
if (titleLower === queryLower)
|
|
125
|
+
score += 1.0;
|
|
126
|
+
// 접두 매치
|
|
127
|
+
else if (titleLower.startsWith(queryLower))
|
|
128
|
+
score += 0.5;
|
|
129
|
+
// N-gram 매치
|
|
130
|
+
else if (this.hasNgramMatch(queryLower, titleLower))
|
|
131
|
+
score += 0.2;
|
|
132
|
+
return Math.min(1.0, score);
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* N-gram 매치 확인
|
|
136
|
+
*/
|
|
137
|
+
hasNgramMatch(query, text, n = 3) {
|
|
138
|
+
if (query.length < n || text.length < n)
|
|
139
|
+
return false;
|
|
140
|
+
const queryNgrams = this.generateNgrams(query, n);
|
|
141
|
+
const textNgrams = this.generateNgrams(text, n);
|
|
142
|
+
for (const ngram of queryNgrams) {
|
|
143
|
+
if (textNgrams.has(ngram))
|
|
144
|
+
return true;
|
|
145
|
+
}
|
|
146
|
+
return false;
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* N-gram 생성
|
|
150
|
+
*/
|
|
151
|
+
generateNgrams(text, n) {
|
|
152
|
+
const ngrams = new Set();
|
|
153
|
+
for (let i = 0; i <= text.length - n; i++) {
|
|
154
|
+
ngrams.add(text.substring(i, i + n));
|
|
155
|
+
}
|
|
156
|
+
return ngrams;
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* 벡터 내적 계산
|
|
160
|
+
*/
|
|
161
|
+
dotProduct(a, b) {
|
|
162
|
+
return a.reduce((sum, val, i) => sum + val * (b[i] || 0), 0);
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* 벡터 크기 계산
|
|
166
|
+
*/
|
|
167
|
+
magnitude(vector) {
|
|
168
|
+
return Math.sqrt(vector.reduce((sum, val) => sum + val * val, 0));
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* 최근성 점수 계산
|
|
172
|
+
* 반감기 기반 지수 감쇠
|
|
173
|
+
*/
|
|
174
|
+
calculateRecency(createdAt, type) {
|
|
175
|
+
const ageDays = this.getAgeInDays(createdAt);
|
|
176
|
+
const halfLife = this.getHalfLife(type);
|
|
177
|
+
return Math.exp(-Math.log(2) * ageDays / halfLife);
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* 중요도 점수 계산
|
|
181
|
+
*/
|
|
182
|
+
calculateImportance(userImportance, isPinned, type) {
|
|
183
|
+
const pinnedBoost = isPinned ? 0.2 : 0;
|
|
184
|
+
const typeBoost = this.getTypeBoost(type);
|
|
185
|
+
return Math.max(0, Math.min(1, userImportance + pinnedBoost + typeBoost));
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* 사용성 점수 계산 (실제 구현)
|
|
189
|
+
* viewCount + citeCount(2배) + editCount(0.5배) 로그 스케일 집계
|
|
190
|
+
*/
|
|
191
|
+
calculateUsage(metrics, batchMin, batchMax) {
|
|
192
|
+
// 입력 검증
|
|
193
|
+
if (!metrics)
|
|
194
|
+
return 0;
|
|
195
|
+
const { viewCount, citeCount, editCount } = metrics;
|
|
196
|
+
// 로그 스케일 집계
|
|
197
|
+
const rawUsage = Math.log(1 + viewCount) +
|
|
198
|
+
2 * Math.log(1 + citeCount) +
|
|
199
|
+
0.5 * Math.log(1 + editCount);
|
|
200
|
+
// 모든 값이 0인 경우 기본값 제공
|
|
201
|
+
if (rawUsage === 0) {
|
|
202
|
+
return 0.1; // 기본 사용성 점수
|
|
203
|
+
}
|
|
204
|
+
// 배치 정규화 (전체 배치에서 정규화)
|
|
205
|
+
if (batchMin !== undefined && batchMax !== undefined) {
|
|
206
|
+
return this.normalize(rawUsage, batchMin, batchMax);
|
|
207
|
+
}
|
|
208
|
+
// 개별 정규화 (기본값)
|
|
209
|
+
return Math.min(1.0, rawUsage / 10);
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* 배치 사용성 점수 계산 (여러 메모리에 대해)
|
|
213
|
+
*/
|
|
214
|
+
calculateBatchUsage(metricsList) {
|
|
215
|
+
const rawUsages = metricsList.map(metrics => {
|
|
216
|
+
const { viewCount, citeCount, editCount } = metrics;
|
|
217
|
+
return Math.log(1 + viewCount) +
|
|
218
|
+
2 * Math.log(1 + citeCount) +
|
|
219
|
+
0.5 * Math.log(1 + editCount);
|
|
220
|
+
});
|
|
221
|
+
const min = Math.min(...rawUsages);
|
|
222
|
+
const max = Math.max(...rawUsages);
|
|
223
|
+
const normalized = rawUsages.map(usage => this.normalize(usage, min, max));
|
|
224
|
+
return { normalized, min, max };
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* 정규화 함수
|
|
228
|
+
*/
|
|
229
|
+
normalize(value, min, max, epsilon = 1e-6) {
|
|
230
|
+
if (max === min)
|
|
231
|
+
return 0.5; // 모든 값이 같을 때
|
|
232
|
+
return (value - min) / (max - min + epsilon);
|
|
233
|
+
}
|
|
234
|
+
/**
|
|
235
|
+
* 중복 패널티 계산 (MMR 구현)
|
|
236
|
+
*/
|
|
237
|
+
calculateDuplicationPenalty(candidateContent, selectedContents) {
|
|
238
|
+
if (selectedContents.length === 0)
|
|
239
|
+
return 0;
|
|
240
|
+
let maxSimilarity = 0;
|
|
241
|
+
for (const selectedContent of selectedContents) {
|
|
242
|
+
const similarity = this.calculateTextSimilarity(candidateContent, selectedContent);
|
|
243
|
+
maxSimilarity = Math.max(maxSimilarity, similarity);
|
|
244
|
+
}
|
|
245
|
+
return maxSimilarity;
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* 텍스트 유사도 계산 (자카드 유사도)
|
|
249
|
+
*/
|
|
250
|
+
calculateTextSimilarity(text1, text2) {
|
|
251
|
+
const words1 = new Set(text1.toLowerCase().split(/\s+/));
|
|
252
|
+
const words2 = new Set(text2.toLowerCase().split(/\s+/));
|
|
253
|
+
const intersection = new Set([...words1].filter(x => words2.has(x)));
|
|
254
|
+
const union = new Set([...words1, ...words2]);
|
|
255
|
+
return union.size > 0 ? intersection.size / union.size : 0;
|
|
256
|
+
}
|
|
257
|
+
/**
|
|
258
|
+
* 하위 호환성을 위한 간단한 관련성 계산 (기존 API)
|
|
259
|
+
*/
|
|
260
|
+
calculateRelevanceSimple(query, content, tags = []) {
|
|
261
|
+
return this.calculateRelevance({
|
|
262
|
+
query,
|
|
263
|
+
content,
|
|
264
|
+
tags,
|
|
265
|
+
embeddingSimilarity: undefined,
|
|
266
|
+
bm25Result: undefined
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
/**
|
|
270
|
+
* 하위 호환성을 위한 간단한 사용성 계산 (기존 API)
|
|
271
|
+
*/
|
|
272
|
+
calculateUsageSimple(lastAccessed) {
|
|
273
|
+
if (!lastAccessed)
|
|
274
|
+
return 0.1;
|
|
275
|
+
const daysSinceAccess = this.getAgeInDays(lastAccessed);
|
|
276
|
+
return Math.exp(-daysSinceAccess / 30);
|
|
277
|
+
}
|
|
278
|
+
/**
|
|
279
|
+
* 나이 계산 (일 단위)
|
|
280
|
+
*/
|
|
281
|
+
getAgeInDays(date) {
|
|
282
|
+
const now = new Date();
|
|
283
|
+
const diffTime = now.getTime() - date.getTime();
|
|
284
|
+
return diffTime / (1000 * 60 * 60 * 24);
|
|
285
|
+
}
|
|
286
|
+
/**
|
|
287
|
+
* 타입별 반감기 (일 단위)
|
|
288
|
+
*/
|
|
289
|
+
getHalfLife(type) {
|
|
290
|
+
switch (type) {
|
|
291
|
+
case 'working': return 2;
|
|
292
|
+
case 'episodic': return 30;
|
|
293
|
+
case 'semantic': return 180;
|
|
294
|
+
case 'procedural': return 90;
|
|
295
|
+
default: return 30;
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
/**
|
|
299
|
+
* 타입별 부스트 점수
|
|
300
|
+
*/
|
|
301
|
+
getTypeBoost(type) {
|
|
302
|
+
switch (type) {
|
|
303
|
+
case 'semantic': return 0.1;
|
|
304
|
+
case 'episodic': return 0.0;
|
|
305
|
+
case 'working': return -0.05;
|
|
306
|
+
case 'procedural': return 0.05;
|
|
307
|
+
default: return 0.0;
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
//# sourceMappingURL=search-ranking.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search-ranking.js","sourceRoot":"","sources":["../../src/algorithms/search-ranking.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 간격 반복 알고리즘 구현
|
|
3
|
+
* Memento-Goals.md의 간격 반복 공식 구현
|
|
4
|
+
*/
|
|
5
|
+
export interface SpacedRepetitionFeatures {
|
|
6
|
+
importance: number;
|
|
7
|
+
usage: number;
|
|
8
|
+
helpful_feedback: number;
|
|
9
|
+
bad_feedback: number;
|
|
10
|
+
}
|
|
11
|
+
export interface SpacedRepetitionWeights {
|
|
12
|
+
importance: number;
|
|
13
|
+
usage: number;
|
|
14
|
+
helpful_feedback: number;
|
|
15
|
+
bad_feedback: number;
|
|
16
|
+
}
|
|
17
|
+
export interface ReviewSchedule {
|
|
18
|
+
memory_id: string;
|
|
19
|
+
current_interval: number;
|
|
20
|
+
next_review: Date;
|
|
21
|
+
recall_probability: number;
|
|
22
|
+
needs_review: boolean;
|
|
23
|
+
multiplier: number;
|
|
24
|
+
}
|
|
25
|
+
export declare class SpacedRepetitionAlgorithm {
|
|
26
|
+
private readonly weights;
|
|
27
|
+
private readonly recallThreshold;
|
|
28
|
+
constructor(weights?: Partial<SpacedRepetitionWeights>);
|
|
29
|
+
/**
|
|
30
|
+
* 다음 리뷰 간격 계산
|
|
31
|
+
* interval = current_interval * (1 + A1*importance + A2*usage + A3*helpful - A4*bad)
|
|
32
|
+
*/
|
|
33
|
+
calculateNextInterval(currentInterval: number, features: SpacedRepetitionFeatures): number;
|
|
34
|
+
/**
|
|
35
|
+
* 리콜 확률 계산
|
|
36
|
+
* P = exp(-time_since_last_review / interval)
|
|
37
|
+
*/
|
|
38
|
+
calculateRecallProbability(timeSinceLastReview: number, // 일 단위
|
|
39
|
+
interval: number): number;
|
|
40
|
+
/**
|
|
41
|
+
* 리뷰 필요 여부 판단
|
|
42
|
+
*/
|
|
43
|
+
needsReview(timeSinceLastReview: number, interval: number, threshold?: number): boolean;
|
|
44
|
+
/**
|
|
45
|
+
* 리뷰 스케줄 생성
|
|
46
|
+
*/
|
|
47
|
+
createReviewSchedule(memoryId: string, currentInterval: number, lastReviewDate: Date, features: SpacedRepetitionFeatures): ReviewSchedule;
|
|
48
|
+
/**
|
|
49
|
+
* 배치 리뷰 스케줄 생성
|
|
50
|
+
*/
|
|
51
|
+
createBatchReviewSchedules(memories: Array<{
|
|
52
|
+
id: string;
|
|
53
|
+
current_interval: number;
|
|
54
|
+
last_review: Date;
|
|
55
|
+
importance: number;
|
|
56
|
+
usage: number;
|
|
57
|
+
helpful_feedback: number;
|
|
58
|
+
bad_feedback: number;
|
|
59
|
+
}>): ReviewSchedule[];
|
|
60
|
+
/**
|
|
61
|
+
* 리뷰 우선순위 계산
|
|
62
|
+
*/
|
|
63
|
+
calculateReviewPriority(schedule: ReviewSchedule): number;
|
|
64
|
+
/**
|
|
65
|
+
* 리뷰 성과 분석
|
|
66
|
+
*/
|
|
67
|
+
analyzeReviewPerformance(schedules: ReviewSchedule[], actualRecall: Map<string, boolean>): {
|
|
68
|
+
totalMemories: number;
|
|
69
|
+
reviewedMemories: number;
|
|
70
|
+
averageRecallRate: number;
|
|
71
|
+
performanceByInterval: Map<number, number>;
|
|
72
|
+
};
|
|
73
|
+
/**
|
|
74
|
+
* 최적 간격 추천
|
|
75
|
+
*/
|
|
76
|
+
recommendOptimalInterval(currentInterval: number, recallHistory: boolean[], // 최근 리콜 성공/실패 기록
|
|
77
|
+
features: SpacedRepetitionFeatures): number;
|
|
78
|
+
/**
|
|
79
|
+
* 일수 계산
|
|
80
|
+
*/
|
|
81
|
+
private getDaysSince;
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=spaced-repetition.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spaced-repetition.d.ts","sourceRoot":"","sources":["../../src/algorithms/spaced-repetition.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,wBAAwB;IACvC,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,gBAAgB,EAAE,MAAM,CAAC;IACzB,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,uBAAuB;IACtC,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,gBAAgB,EAAE,MAAM,CAAC;IACzB,YAAY,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,gBAAgB,EAAE,MAAM,CAAC;IACzB,WAAW,EAAE,IAAI,CAAC;IAClB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,YAAY,EAAE,OAAO,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,qBAAa,yBAAyB;IACpC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA0B;IAClD,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAe;gBAEnC,OAAO,CAAC,EAAE,OAAO,CAAC,uBAAuB,CAAC;IAUtD;;;OAGG;IACH,qBAAqB,CACnB,eAAe,EAAE,MAAM,EACvB,QAAQ,EAAE,wBAAwB,GACjC,MAAM;IAYT;;;OAGG;IACH,0BAA0B,CACxB,mBAAmB,EAAE,MAAM,EAAE,OAAO;IACpC,QAAQ,EAAE,MAAM,GACf,MAAM;IAIT;;OAEG;IACH,WAAW,CACT,mBAAmB,EAAE,MAAM,EAC3B,QAAQ,EAAE,MAAM,EAChB,SAAS,GAAE,MAA6B,GACvC,OAAO;IAKV;;OAEG;IACH,oBAAoB,CAClB,QAAQ,EAAE,MAAM,EAChB,eAAe,EAAE,MAAM,EACvB,cAAc,EAAE,IAAI,EACpB,QAAQ,EAAE,wBAAwB,GACjC,cAAc;IAkBjB;;OAEG;IACH,0BAA0B,CACxB,QAAQ,EAAE,KAAK,CAAC;QACd,EAAE,EAAE,MAAM,CAAC;QACX,gBAAgB,EAAE,MAAM,CAAC;QACzB,WAAW,EAAE,IAAI,CAAC;QAClB,UAAU,EAAE,MAAM,CAAC;QACnB,KAAK,EAAE,MAAM,CAAC;QACd,gBAAgB,EAAE,MAAM,CAAC;QACzB,YAAY,EAAE,MAAM,CAAC;KACtB,CAAC,GACD,cAAc,EAAE;IAkBnB;;OAEG;IACH,uBAAuB,CAAC,QAAQ,EAAE,cAAc,GAAG,MAAM;IAQzD;;OAEG;IACH,wBAAwB,CACtB,SAAS,EAAE,cAAc,EAAE,EAC3B,YAAY,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,GACjC;QACD,aAAa,EAAE,MAAM,CAAC;QACtB,gBAAgB,EAAE,MAAM,CAAC;QACzB,iBAAiB,EAAE,MAAM,CAAC;QAC1B,qBAAqB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KAC5C;IAsCD;;OAEG;IACH,wBAAwB,CACtB,eAAe,EAAE,MAAM,EACvB,aAAa,EAAE,OAAO,EAAE,EAAE,iBAAiB;IAC3C,QAAQ,EAAE,wBAAwB,GACjC,MAAM;IAqBT;;OAEG;IACH,OAAO,CAAC,YAAY;CAKrB"}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 간격 반복 알고리즘 구현
|
|
3
|
+
* Memento-Goals.md의 간격 반복 공식 구현
|
|
4
|
+
*/
|
|
5
|
+
export class SpacedRepetitionAlgorithm {
|
|
6
|
+
weights;
|
|
7
|
+
recallThreshold = 0.7; // 리콜 임계값
|
|
8
|
+
constructor(weights) {
|
|
9
|
+
this.weights = {
|
|
10
|
+
importance: 0.6, // A1: 중요도 가중치
|
|
11
|
+
usage: 0.4, // A2: 사용성 가중치
|
|
12
|
+
helpful_feedback: 0.5, // A3: 도움됨 피드백 가중치
|
|
13
|
+
bad_feedback: 0.7, // A4: 나쁨 피드백 가중치
|
|
14
|
+
...weights
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* 다음 리뷰 간격 계산
|
|
19
|
+
* interval = current_interval * (1 + A1*importance + A2*usage + A3*helpful - A4*bad)
|
|
20
|
+
*/
|
|
21
|
+
calculateNextInterval(currentInterval, features) {
|
|
22
|
+
const { importance, usage, helpful_feedback, bad_feedback } = features;
|
|
23
|
+
const multiplier = 1 +
|
|
24
|
+
this.weights.importance * importance +
|
|
25
|
+
this.weights.usage * usage +
|
|
26
|
+
this.weights.helpful_feedback * helpful_feedback -
|
|
27
|
+
this.weights.bad_feedback * bad_feedback;
|
|
28
|
+
return Math.ceil(currentInterval * multiplier);
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* 리콜 확률 계산
|
|
32
|
+
* P = exp(-time_since_last_review / interval)
|
|
33
|
+
*/
|
|
34
|
+
calculateRecallProbability(timeSinceLastReview, // 일 단위
|
|
35
|
+
interval) {
|
|
36
|
+
return Math.exp(-timeSinceLastReview / interval);
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* 리뷰 필요 여부 판단
|
|
40
|
+
*/
|
|
41
|
+
needsReview(timeSinceLastReview, interval, threshold = this.recallThreshold) {
|
|
42
|
+
const recallProb = this.calculateRecallProbability(timeSinceLastReview, interval);
|
|
43
|
+
return recallProb <= threshold;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* 리뷰 스케줄 생성
|
|
47
|
+
*/
|
|
48
|
+
createReviewSchedule(memoryId, currentInterval, lastReviewDate, features) {
|
|
49
|
+
const nextInterval = this.calculateNextInterval(currentInterval, features);
|
|
50
|
+
const nextReview = new Date(lastReviewDate.getTime() + nextInterval * 24 * 60 * 60 * 1000);
|
|
51
|
+
const timeSinceLastReview = this.getDaysSince(lastReviewDate);
|
|
52
|
+
const recallProb = this.calculateRecallProbability(timeSinceLastReview, nextInterval);
|
|
53
|
+
const needsReview = this.needsReview(timeSinceLastReview, nextInterval);
|
|
54
|
+
return {
|
|
55
|
+
memory_id: memoryId,
|
|
56
|
+
current_interval: nextInterval,
|
|
57
|
+
next_review: nextReview,
|
|
58
|
+
recall_probability: recallProb,
|
|
59
|
+
needs_review: needsReview,
|
|
60
|
+
multiplier: nextInterval / currentInterval
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* 배치 리뷰 스케줄 생성
|
|
65
|
+
*/
|
|
66
|
+
createBatchReviewSchedules(memories) {
|
|
67
|
+
return memories.map(memory => {
|
|
68
|
+
const features = {
|
|
69
|
+
importance: memory.importance,
|
|
70
|
+
usage: memory.usage,
|
|
71
|
+
helpful_feedback: memory.helpful_feedback,
|
|
72
|
+
bad_feedback: memory.bad_feedback
|
|
73
|
+
};
|
|
74
|
+
return this.createReviewSchedule(memory.id, memory.current_interval, memory.last_review, features);
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* 리뷰 우선순위 계산
|
|
79
|
+
*/
|
|
80
|
+
calculateReviewPriority(schedule) {
|
|
81
|
+
// 리콜 확률이 낮을수록, 간격이 길수록 우선순위 높음
|
|
82
|
+
const urgencyScore = 1 - schedule.recall_probability;
|
|
83
|
+
const intervalScore = Math.log(schedule.current_interval + 1) / 10; // 정규화
|
|
84
|
+
return urgencyScore + intervalScore;
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* 리뷰 성과 분석
|
|
88
|
+
*/
|
|
89
|
+
analyzeReviewPerformance(schedules, actualRecall // memory_id -> recall_success
|
|
90
|
+
) {
|
|
91
|
+
const totalMemories = schedules.length;
|
|
92
|
+
const reviewedMemories = schedules.filter(s => s.needs_review).length;
|
|
93
|
+
let totalRecallRate = 0;
|
|
94
|
+
let recallCount = 0;
|
|
95
|
+
const performanceByInterval = new Map();
|
|
96
|
+
for (const schedule of schedules) {
|
|
97
|
+
if (actualRecall.has(schedule.memory_id)) {
|
|
98
|
+
const recalled = actualRecall.get(schedule.memory_id);
|
|
99
|
+
totalRecallRate += recalled ? 1 : 0;
|
|
100
|
+
recallCount++;
|
|
101
|
+
const interval = Math.floor(schedule.current_interval / 7) * 7; // 주 단위로 그룹화
|
|
102
|
+
const current = performanceByInterval.get(interval) || { total: 0, successful: 0 };
|
|
103
|
+
current.total++;
|
|
104
|
+
if (recalled)
|
|
105
|
+
current.successful++;
|
|
106
|
+
performanceByInterval.set(interval, current);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
const averageRecallRate = recallCount > 0 ? totalRecallRate / recallCount : 0;
|
|
110
|
+
// 간격별 성과 계산
|
|
111
|
+
const performanceByIntervalRate = new Map();
|
|
112
|
+
for (const [interval, stats] of performanceByInterval) {
|
|
113
|
+
performanceByIntervalRate.set(interval, stats.successful / stats.total);
|
|
114
|
+
}
|
|
115
|
+
return {
|
|
116
|
+
totalMemories,
|
|
117
|
+
reviewedMemories,
|
|
118
|
+
averageRecallRate,
|
|
119
|
+
performanceByInterval: performanceByIntervalRate
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* 최적 간격 추천
|
|
124
|
+
*/
|
|
125
|
+
recommendOptimalInterval(currentInterval, recallHistory, // 최근 리콜 성공/실패 기록
|
|
126
|
+
features) {
|
|
127
|
+
if (recallHistory.length === 0) {
|
|
128
|
+
return currentInterval;
|
|
129
|
+
}
|
|
130
|
+
// 최근 성과 기반 조정
|
|
131
|
+
const recentPerformance = recallHistory.slice(-5); // 최근 5회
|
|
132
|
+
const successRate = recentPerformance.filter(success => success).length / recentPerformance.length;
|
|
133
|
+
// 성과에 따른 조정 계수
|
|
134
|
+
let adjustmentFactor = 1.0;
|
|
135
|
+
if (successRate > 0.8) {
|
|
136
|
+
adjustmentFactor = 1.2; // 성과 좋으면 간격 늘림
|
|
137
|
+
}
|
|
138
|
+
else if (successRate < 0.6) {
|
|
139
|
+
adjustmentFactor = 0.8; // 성과 나쁘면 간격 줄임
|
|
140
|
+
}
|
|
141
|
+
const baseInterval = this.calculateNextInterval(currentInterval, features);
|
|
142
|
+
return Math.ceil(baseInterval * adjustmentFactor);
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* 일수 계산
|
|
146
|
+
*/
|
|
147
|
+
getDaysSince(date) {
|
|
148
|
+
const now = new Date();
|
|
149
|
+
const diffTime = now.getTime() - date.getTime();
|
|
150
|
+
return diffTime / (1000 * 60 * 60 * 24);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
//# sourceMappingURL=spaced-repetition.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spaced-repetition.js","sourceRoot":"","sources":["../../src/algorithms/spaced-repetition.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 벡터 검색 엔진
|
|
3
|
+
* sqlite-vec를 사용한 벡터 유사도 검색
|
|
4
|
+
* Memento MCP Server의 핵심 벡터 검색 컴포넌트
|
|
5
|
+
*/
|
|
6
|
+
import Database from 'better-sqlite3';
|
|
7
|
+
export interface VectorSearchResult {
|
|
8
|
+
memory_id: string;
|
|
9
|
+
similarity: number;
|
|
10
|
+
content: string;
|
|
11
|
+
type: string;
|
|
12
|
+
importance: number;
|
|
13
|
+
created_at: string;
|
|
14
|
+
last_accessed?: string;
|
|
15
|
+
pinned: boolean;
|
|
16
|
+
tags?: string[];
|
|
17
|
+
}
|
|
18
|
+
export interface VectorSearchOptions {
|
|
19
|
+
limit?: number;
|
|
20
|
+
threshold?: number;
|
|
21
|
+
type?: string;
|
|
22
|
+
includeContent?: boolean;
|
|
23
|
+
includeMetadata?: boolean;
|
|
24
|
+
}
|
|
25
|
+
export interface VectorIndexStatus {
|
|
26
|
+
available: boolean;
|
|
27
|
+
tableExists: boolean;
|
|
28
|
+
recordCount: number;
|
|
29
|
+
dimensions: number;
|
|
30
|
+
vecExtensionLoaded: boolean;
|
|
31
|
+
}
|
|
32
|
+
export declare class VectorSearchEngine {
|
|
33
|
+
private db;
|
|
34
|
+
private isVecAvailable;
|
|
35
|
+
private vecExtensionLoaded;
|
|
36
|
+
private readonly defaultDimensions;
|
|
37
|
+
private readonly defaultThreshold;
|
|
38
|
+
private readonly defaultLimit;
|
|
39
|
+
constructor();
|
|
40
|
+
/**
|
|
41
|
+
* 제공자별 vec0 테이블명 반환
|
|
42
|
+
*/
|
|
43
|
+
private getVectorTableName;
|
|
44
|
+
/**
|
|
45
|
+
* 데이터베이스 초기화
|
|
46
|
+
*/
|
|
47
|
+
initialize(db: Database.Database): void;
|
|
48
|
+
/**
|
|
49
|
+
* VEC 사용 가능 여부 확인
|
|
50
|
+
* sqlite-vec 확장 로드 여부와 테이블 존재를 모두 확인
|
|
51
|
+
*/
|
|
52
|
+
private checkVecAvailability;
|
|
53
|
+
/**
|
|
54
|
+
* 벡터 검색 실행
|
|
55
|
+
*/
|
|
56
|
+
search(queryVector: number[], options?: VectorSearchOptions, provider?: string): Promise<VectorSearchResult[]>;
|
|
57
|
+
/**
|
|
58
|
+
* 하이브리드 검색 (벡터 + 메타데이터)
|
|
59
|
+
* SQLite 호환성을 위해 LEFT JOIN 사용
|
|
60
|
+
*/
|
|
61
|
+
hybridSearch(queryVector: number[], textQuery: string, options?: VectorSearchOptions, provider?: string): Promise<VectorSearchResult[]>;
|
|
62
|
+
/**
|
|
63
|
+
* 벡터 인덱스 상태 확인
|
|
64
|
+
*/
|
|
65
|
+
getIndexStatus(): VectorIndexStatus;
|
|
66
|
+
/**
|
|
67
|
+
* 벡터 인덱스 재구성
|
|
68
|
+
*/
|
|
69
|
+
rebuildIndex(): Promise<boolean>;
|
|
70
|
+
/**
|
|
71
|
+
* 벡터 검색 성능 테스트
|
|
72
|
+
*/
|
|
73
|
+
performanceTest(queryVector: number[], iterations?: number): Promise<{
|
|
74
|
+
averageTime: number;
|
|
75
|
+
minTime: number;
|
|
76
|
+
maxTime: number;
|
|
77
|
+
results: number;
|
|
78
|
+
successRate: number;
|
|
79
|
+
}>;
|
|
80
|
+
/**
|
|
81
|
+
* 벡터 차원 확인
|
|
82
|
+
*/
|
|
83
|
+
getDimensions(): number;
|
|
84
|
+
/**
|
|
85
|
+
* VEC 사용 가능 여부 확인
|
|
86
|
+
*/
|
|
87
|
+
isAvailable(): boolean;
|
|
88
|
+
/**
|
|
89
|
+
* 데이터베이스 연결 상태 확인
|
|
90
|
+
*/
|
|
91
|
+
isConnected(): boolean;
|
|
92
|
+
}
|
|
93
|
+
export declare function getVectorSearchEngine(): VectorSearchEngine;
|
|
94
|
+
export declare function createVectorSearchEngine(): VectorSearchEngine;
|
|
95
|
+
export declare function resetVectorSearchEngine(): void;
|
|
96
|
+
//# sourceMappingURL=vector-search-engine.d.ts.map
|