causantic 0.2.0 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +53 -66
- package/config.schema.json +12 -87
- package/dist/cli/commands/archive.d.ts.map +1 -1
- package/dist/cli/commands/archive.js.map +1 -1
- package/dist/cli/commands/benchmark-collection.d.ts.map +1 -1
- package/dist/cli/commands/benchmark-collection.js.map +1 -1
- package/dist/cli/commands/encryption.d.ts.map +1 -1
- package/dist/cli/commands/encryption.js.map +1 -1
- package/dist/cli/commands/hook.d.ts.map +1 -1
- package/dist/cli/commands/hook.js +8 -2
- package/dist/cli/commands/hook.js.map +1 -1
- package/dist/cli/commands/init.d.ts.map +1 -1
- package/dist/cli/commands/init.js +39 -32
- package/dist/cli/commands/init.js.map +1 -1
- package/dist/cli/commands/maintenance.d.ts.map +1 -1
- package/dist/cli/commands/maintenance.js +10 -3
- package/dist/cli/commands/maintenance.js.map +1 -1
- package/dist/cli/commands/serve.d.ts.map +1 -1
- package/dist/cli/commands/serve.js +3 -3
- package/dist/cli/commands/serve.js.map +1 -1
- package/dist/cli/index.js +1 -1
- package/dist/cli/skill-templates.d.ts.map +1 -1
- package/dist/cli/skill-templates.js +223 -153
- package/dist/cli/skill-templates.js.map +1 -1
- package/dist/cli/uninstall.d.ts.map +1 -1
- package/dist/cli/uninstall.js +4 -1
- package/dist/cli/uninstall.js.map +1 -1
- package/dist/clusters/cluster-manager.d.ts +23 -0
- package/dist/clusters/cluster-manager.d.ts.map +1 -1
- package/dist/clusters/cluster-manager.js +69 -2
- package/dist/clusters/cluster-manager.js.map +1 -1
- package/dist/clusters/cluster-refresh.d.ts.map +1 -1
- package/dist/clusters/cluster-refresh.js +5 -1
- package/dist/clusters/cluster-refresh.js.map +1 -1
- package/dist/clusters/hdbscan/cluster-extraction.d.ts.map +1 -1
- package/dist/clusters/hdbscan/cluster-extraction.js +1 -2
- package/dist/clusters/hdbscan/cluster-extraction.js.map +1 -1
- package/dist/clusters/hdbscan/hierarchy.d.ts.map +1 -1
- package/dist/clusters/hdbscan/hierarchy.js +1 -3
- package/dist/clusters/hdbscan/hierarchy.js.map +1 -1
- package/dist/clusters/hdbscan/incremental.d.ts.map +1 -1
- package/dist/clusters/hdbscan/incremental.js.map +1 -1
- package/dist/clusters/hdbscan/probabilities.d.ts +1 -1
- package/dist/clusters/hdbscan/probabilities.d.ts.map +1 -1
- package/dist/clusters/hdbscan/probabilities.js +1 -1
- package/dist/clusters/hdbscan/probabilities.js.map +1 -1
- package/dist/clusters/hdbscan.d.ts.map +1 -1
- package/dist/clusters/hdbscan.js +3 -5
- package/dist/clusters/hdbscan.js.map +1 -1
- package/dist/config/loader.d.ts +10 -15
- package/dist/config/loader.d.ts.map +1 -1
- package/dist/config/loader.js +40 -71
- package/dist/config/loader.js.map +1 -1
- package/dist/config/memory-config.d.ts +2 -45
- package/dist/config/memory-config.d.ts.map +1 -1
- package/dist/config/memory-config.js +6 -109
- package/dist/config/memory-config.js.map +1 -1
- package/dist/core/index.d.ts +1 -1
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/lexical-features.d.ts.map +1 -1
- package/dist/core/lexical-features.js +141 -20
- package/dist/core/lexical-features.js.map +1 -1
- package/dist/dashboard/client/assets/index-DdImwNQ0.css +1 -0
- package/dist/dashboard/client/assets/index-Ofx8zngH.js +166 -0
- package/dist/dashboard/client/index.html +2 -2
- package/dist/dashboard/routes/benchmark-collection.d.ts.map +1 -1
- package/dist/dashboard/routes/benchmark-collection.js +2 -6
- package/dist/dashboard/routes/benchmark-collection.js.map +1 -1
- package/dist/dashboard/routes/chain.d.ts +3 -0
- package/dist/dashboard/routes/chain.d.ts.map +1 -0
- package/dist/dashboard/routes/chain.js +74 -0
- package/dist/dashboard/routes/chain.js.map +1 -0
- package/dist/dashboard/routes/chunks.d.ts.map +1 -1
- package/dist/dashboard/routes/chunks.js +16 -1
- package/dist/dashboard/routes/chunks.js.map +1 -1
- package/dist/dashboard/routes/graph.d.ts.map +1 -1
- package/dist/dashboard/routes/graph.js.map +1 -1
- package/dist/dashboard/routes/search.d.ts.map +1 -1
- package/dist/dashboard/routes/search.js.map +1 -1
- package/dist/dashboard/routes/stats.d.ts.map +1 -1
- package/dist/dashboard/routes/stats.js +8 -6
- package/dist/dashboard/routes/stats.js.map +1 -1
- package/dist/dashboard/routes/timeline.d.ts +3 -0
- package/dist/dashboard/routes/timeline.d.ts.map +1 -0
- package/dist/dashboard/routes/timeline.js +90 -0
- package/dist/dashboard/routes/timeline.js.map +1 -0
- package/dist/dashboard/server.d.ts.map +1 -1
- package/dist/dashboard/server.js +4 -0
- package/dist/dashboard/server.js.map +1 -1
- package/dist/eval/annotation-schema.d.ts.map +1 -1
- package/dist/eval/annotation-schema.js +2 -5
- package/dist/eval/annotation-schema.js.map +1 -1
- package/dist/eval/benchmark-runner.d.ts.map +1 -1
- package/dist/eval/benchmark-runner.js +2 -2
- package/dist/eval/benchmark-runner.js.map +1 -1
- package/dist/eval/cluster-evaluator.d.ts.map +1 -1
- package/dist/eval/cluster-evaluator.js.map +1 -1
- package/dist/eval/collection-benchmark/chain-quality.d.ts +15 -0
- package/dist/eval/collection-benchmark/chain-quality.d.ts.map +1 -0
- package/dist/eval/collection-benchmark/chain-quality.js +60 -0
- package/dist/eval/collection-benchmark/chain-quality.js.map +1 -0
- package/dist/eval/collection-benchmark/health.d.ts.map +1 -1
- package/dist/eval/collection-benchmark/health.js +2 -2
- package/dist/eval/collection-benchmark/health.js.map +1 -1
- package/dist/eval/collection-benchmark/history.d.ts.map +1 -1
- package/dist/eval/collection-benchmark/history.js +14 -11
- package/dist/eval/collection-benchmark/history.js.map +1 -1
- package/dist/eval/collection-benchmark/latency.d.ts.map +1 -1
- package/dist/eval/collection-benchmark/latency.js +14 -11
- package/dist/eval/collection-benchmark/latency.js.map +1 -1
- package/dist/eval/collection-benchmark/reporter.d.ts.map +1 -1
- package/dist/eval/collection-benchmark/reporter.js +18 -28
- package/dist/eval/collection-benchmark/reporter.js.map +1 -1
- package/dist/eval/collection-benchmark/retrieval.d.ts.map +1 -1
- package/dist/eval/collection-benchmark/retrieval.js +14 -8
- package/dist/eval/collection-benchmark/retrieval.js.map +1 -1
- package/dist/eval/collection-benchmark/runner.d.ts +3 -3
- package/dist/eval/collection-benchmark/runner.d.ts.map +1 -1
- package/dist/eval/collection-benchmark/runner.js +46 -37
- package/dist/eval/collection-benchmark/runner.js.map +1 -1
- package/dist/eval/collection-benchmark/sampler.d.ts.map +1 -1
- package/dist/eval/collection-benchmark/sampler.js +14 -12
- package/dist/eval/collection-benchmark/sampler.js.map +1 -1
- package/dist/eval/collection-benchmark/tuning.d.ts.map +1 -1
- package/dist/eval/collection-benchmark/tuning.js +56 -71
- package/dist/eval/collection-benchmark/tuning.js.map +1 -1
- package/dist/eval/collection-benchmark/types.d.ts +12 -24
- package/dist/eval/collection-benchmark/types.d.ts.map +1 -1
- package/dist/eval/corpus-builder.d.ts.map +1 -1
- package/dist/eval/corpus-builder.js.map +1 -1
- package/dist/eval/experiments/boilerplate-filter.d.ts.map +1 -1
- package/dist/eval/experiments/boilerplate-filter.js.map +1 -1
- package/dist/eval/experiments/cluster-threshold/run-threshold-sweep.d.ts.map +1 -1
- package/dist/eval/experiments/cluster-threshold/run-threshold-sweep.js +3 -5
- package/dist/eval/experiments/cluster-threshold/run-threshold-sweep.js.map +1 -1
- package/dist/eval/experiments/code-focused-mode.d.ts.map +1 -1
- package/dist/eval/experiments/code-focused-mode.js +1 -1
- package/dist/eval/experiments/code-focused-mode.js.map +1 -1
- package/dist/eval/experiments/edge-decay/decay-curves.d.ts +25 -19
- package/dist/eval/experiments/edge-decay/decay-curves.d.ts.map +1 -1
- package/dist/eval/experiments/edge-decay/decay-curves.js +47 -40
- package/dist/eval/experiments/edge-decay/decay-curves.js.map +1 -1
- package/dist/eval/experiments/edge-decay/index.d.ts +6 -4
- package/dist/eval/experiments/edge-decay/index.d.ts.map +1 -1
- package/dist/eval/experiments/edge-decay/index.js +5 -3
- package/dist/eval/experiments/edge-decay/index.js.map +1 -1
- package/dist/eval/experiments/edge-decay/presets.d.ts +14 -4
- package/dist/eval/experiments/edge-decay/presets.d.ts.map +1 -1
- package/dist/eval/experiments/edge-decay/presets.js +73 -68
- package/dist/eval/experiments/edge-decay/presets.js.map +1 -1
- package/dist/eval/experiments/edge-decay/reference-extractor.d.ts +2 -1
- package/dist/eval/experiments/edge-decay/reference-extractor.d.ts.map +1 -1
- package/dist/eval/experiments/edge-decay/reference-extractor.js +26 -40
- package/dist/eval/experiments/edge-decay/reference-extractor.js.map +1 -1
- package/dist/eval/experiments/edge-decay/reference-types.d.ts +24 -17
- package/dist/eval/experiments/edge-decay/reference-types.d.ts.map +1 -1
- package/dist/eval/experiments/edge-decay/reference-types.js +3 -0
- package/dist/eval/experiments/edge-decay/reference-types.js.map +1 -1
- package/dist/eval/experiments/edge-decay/retrieval-ranking.d.ts +8 -8
- package/dist/eval/experiments/edge-decay/retrieval-ranking.d.ts.map +1 -1
- package/dist/eval/experiments/edge-decay/retrieval-ranking.js +77 -133
- package/dist/eval/experiments/edge-decay/retrieval-ranking.js.map +1 -1
- package/dist/eval/experiments/edge-decay/run-experiments.d.ts +7 -3
- package/dist/eval/experiments/edge-decay/run-experiments.d.ts.map +1 -1
- package/dist/eval/experiments/edge-decay/run-experiments.js +71 -52
- package/dist/eval/experiments/edge-decay/run-experiments.js.map +1 -1
- package/dist/eval/experiments/edge-decay/simulate.d.ts +1 -1
- package/dist/eval/experiments/edge-decay/simulate.d.ts.map +1 -1
- package/dist/eval/experiments/edge-decay/simulate.js +7 -19
- package/dist/eval/experiments/edge-decay/simulate.js.map +1 -1
- package/dist/eval/experiments/hdbscan-sweep.d.ts.map +1 -1
- package/dist/eval/experiments/hdbscan-sweep.js +2 -6
- package/dist/eval/experiments/hdbscan-sweep.js.map +1 -1
- package/dist/eval/experiments/single-model-run.d.ts.map +1 -1
- package/dist/eval/experiments/single-model-run.js +2 -2
- package/dist/eval/experiments/single-model-run.js.map +1 -1
- package/dist/eval/experiments/thinking-ablation.d.ts.map +1 -1
- package/dist/eval/experiments/thinking-ablation.js +1 -1
- package/dist/eval/experiments/thinking-ablation.js.map +1 -1
- package/dist/eval/experiments/topic-continuity/hybrid-classifier.d.ts.map +1 -1
- package/dist/eval/experiments/topic-continuity/hybrid-classifier.js +54 -6
- package/dist/eval/experiments/topic-continuity/hybrid-classifier.js.map +1 -1
- package/dist/eval/experiments/topic-continuity/labeler.d.ts.map +1 -1
- package/dist/eval/experiments/topic-continuity/labeler.js +1 -4
- package/dist/eval/experiments/topic-continuity/labeler.js.map +1 -1
- package/dist/eval/experiments/topic-continuity/run-experiment.d.ts.map +1 -1
- package/dist/eval/experiments/topic-continuity/run-experiment.js +5 -13
- package/dist/eval/experiments/topic-continuity/run-experiment.js.map +1 -1
- package/dist/eval/experiments/truncation.d.ts.map +1 -1
- package/dist/eval/experiments/truncation.js.map +1 -1
- package/dist/eval/experiments/types.d.ts.map +1 -1
- package/dist/eval/experiments/types.js.map +1 -1
- package/dist/eval/metrics.d.ts.map +1 -1
- package/dist/eval/metrics.js.map +1 -1
- package/dist/hooks/claudemd-generator.d.ts.map +1 -1
- package/dist/hooks/claudemd-generator.js +3 -4
- package/dist/hooks/claudemd-generator.js.map +1 -1
- package/dist/hooks/hook-utils.d.ts +16 -0
- package/dist/hooks/hook-utils.d.ts.map +1 -1
- package/dist/hooks/hook-utils.js +51 -2
- package/dist/hooks/hook-utils.js.map +1 -1
- package/dist/hooks/index.d.ts +4 -2
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +3 -1
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/pre-compact.d.ts.map +1 -1
- package/dist/hooks/pre-compact.js +6 -51
- package/dist/hooks/pre-compact.js.map +1 -1
- package/dist/hooks/session-end.d.ts +58 -0
- package/dist/hooks/session-end.d.ts.map +1 -0
- package/dist/hooks/session-end.js +82 -0
- package/dist/hooks/session-end.js.map +1 -0
- package/dist/hooks/session-start.d.ts.map +1 -1
- package/dist/hooks/session-start.js +3 -5
- package/dist/hooks/session-start.js.map +1 -1
- package/dist/index.d.ts +1 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -3
- package/dist/index.js.map +1 -1
- package/dist/ingest/batch-ingest.d.ts.map +1 -1
- package/dist/ingest/batch-ingest.js.map +1 -1
- package/dist/ingest/brief-debrief-detector.d.ts +6 -13
- package/dist/ingest/brief-debrief-detector.d.ts.map +1 -1
- package/dist/ingest/brief-debrief-detector.js +9 -16
- package/dist/ingest/brief-debrief-detector.js.map +1 -1
- package/dist/ingest/cross-session-linker.d.ts +2 -1
- package/dist/ingest/cross-session-linker.d.ts.map +1 -1
- package/dist/ingest/cross-session-linker.js +17 -7
- package/dist/ingest/cross-session-linker.js.map +1 -1
- package/dist/ingest/edge-creator.d.ts +14 -40
- package/dist/ingest/edge-creator.d.ts.map +1 -1
- package/dist/ingest/edge-creator.js +34 -132
- package/dist/ingest/edge-creator.js.map +1 -1
- package/dist/ingest/edge-detector.d.ts +27 -12
- package/dist/ingest/edge-detector.d.ts.map +1 -1
- package/dist/ingest/edge-detector.js +68 -200
- package/dist/ingest/edge-detector.js.map +1 -1
- package/dist/ingest/index.d.ts +3 -3
- package/dist/ingest/index.d.ts.map +1 -1
- package/dist/ingest/index.js +3 -3
- package/dist/ingest/index.js.map +1 -1
- package/dist/ingest/ingest-session.d.ts +1 -8
- package/dist/ingest/ingest-session.d.ts.map +1 -1
- package/dist/ingest/ingest-session.js +54 -107
- package/dist/ingest/ingest-session.js.map +1 -1
- package/dist/ingest/rebuild-edges.d.ts +17 -0
- package/dist/ingest/rebuild-edges.d.ts.map +1 -0
- package/dist/ingest/rebuild-edges.js +97 -0
- package/dist/ingest/rebuild-edges.js.map +1 -0
- package/dist/maintenance/scheduler.d.ts +2 -3
- package/dist/maintenance/scheduler.d.ts.map +1 -1
- package/dist/maintenance/scheduler.js +14 -23
- package/dist/maintenance/scheduler.js.map +1 -1
- package/dist/maintenance/tasks/cleanup-vectors.d.ts +3 -1
- package/dist/maintenance/tasks/cleanup-vectors.d.ts.map +1 -1
- package/dist/maintenance/tasks/cleanup-vectors.js +6 -4
- package/dist/maintenance/tasks/cleanup-vectors.js.map +1 -1
- package/dist/maintenance/tasks/index.d.ts +0 -1
- package/dist/maintenance/tasks/index.d.ts.map +1 -1
- package/dist/maintenance/tasks/index.js +0 -1
- package/dist/maintenance/tasks/index.js.map +1 -1
- package/dist/mcp/index.d.ts +1 -1
- package/dist/mcp/index.d.ts.map +1 -1
- package/dist/mcp/index.js +1 -1
- package/dist/mcp/index.js.map +1 -1
- package/dist/mcp/server.d.ts.map +1 -1
- package/dist/mcp/server.js +9 -8
- package/dist/mcp/server.js.map +1 -1
- package/dist/mcp/tools.d.ts +5 -5
- package/dist/mcp/tools.d.ts.map +1 -1
- package/dist/mcp/tools.js +42 -36
- package/dist/mcp/tools.js.map +1 -1
- package/dist/models/device-detector.d.ts.map +1 -1
- package/dist/models/device-detector.js +20 -10
- package/dist/models/device-detector.js.map +1 -1
- package/dist/models/embedder.d.ts.map +1 -1
- package/dist/models/embedder.js +5 -2
- package/dist/models/embedder.js.map +1 -1
- package/dist/models/model-registry.d.ts.map +1 -1
- package/dist/models/model-registry.js.map +1 -1
- package/dist/parser/chunker.d.ts +5 -40
- package/dist/parser/chunker.d.ts.map +1 -1
- package/dist/parser/chunker.js +5 -111
- package/dist/parser/chunker.js.map +1 -1
- package/dist/parser/session-reader.d.ts.map +1 -1
- package/dist/parser/session-reader.js +3 -6
- package/dist/parser/session-reader.js.map +1 -1
- package/dist/parser/turn-assembler.d.ts.map +1 -1
- package/dist/parser/turn-assembler.js +0 -1
- package/dist/parser/turn-assembler.js.map +1 -1
- package/dist/parser/types.d.ts.map +1 -1
- package/dist/report/reporter.d.ts.map +1 -1
- package/dist/report/reporter.js +1 -3
- package/dist/report/reporter.js.map +1 -1
- package/dist/retrieval/chain-assembler.d.ts +58 -0
- package/dist/retrieval/chain-assembler.d.ts.map +1 -0
- package/dist/retrieval/chain-assembler.js +126 -0
- package/dist/retrieval/chain-assembler.js.map +1 -0
- package/dist/retrieval/chain-walker.d.ts +57 -0
- package/dist/retrieval/chain-walker.d.ts.map +1 -0
- package/dist/retrieval/chain-walker.js +121 -0
- package/dist/retrieval/chain-walker.js.map +1 -0
- package/dist/retrieval/cluster-expander.d.ts.map +1 -1
- package/dist/retrieval/cluster-expander.js +3 -3
- package/dist/retrieval/cluster-expander.js.map +1 -1
- package/dist/retrieval/context-assembler.d.ts +13 -36
- package/dist/retrieval/context-assembler.d.ts.map +1 -1
- package/dist/retrieval/context-assembler.js +50 -287
- package/dist/retrieval/context-assembler.js.map +1 -1
- package/dist/retrieval/index.d.ts +8 -4
- package/dist/retrieval/index.d.ts.map +1 -1
- package/dist/retrieval/index.js +7 -3
- package/dist/retrieval/index.js.map +1 -1
- package/dist/retrieval/rrf.d.ts.map +1 -1
- package/dist/retrieval/rrf.js +4 -2
- package/dist/retrieval/rrf.js.map +1 -1
- package/dist/retrieval/search-assembler.d.ts +59 -0
- package/dist/retrieval/search-assembler.d.ts.map +1 -0
- package/dist/retrieval/search-assembler.js +209 -0
- package/dist/retrieval/search-assembler.js.map +1 -0
- package/dist/retrieval/session-reconstructor.d.ts.map +1 -1
- package/dist/retrieval/session-reconstructor.js +9 -7
- package/dist/retrieval/session-reconstructor.js.map +1 -1
- package/dist/storage/archive.d.ts +0 -2
- package/dist/storage/archive.d.ts.map +1 -1
- package/dist/storage/archive.js +18 -12
- package/dist/storage/archive.js.map +1 -1
- package/dist/storage/checkpoint-store.d.ts +0 -1
- package/dist/storage/checkpoint-store.d.ts.map +1 -1
- package/dist/storage/checkpoint-store.js +5 -7
- package/dist/storage/checkpoint-store.js.map +1 -1
- package/dist/storage/chunk-store.d.ts.map +1 -1
- package/dist/storage/chunk-store.js +15 -17
- package/dist/storage/chunk-store.js.map +1 -1
- package/dist/storage/cluster-store.d.ts.map +1 -1
- package/dist/storage/cluster-store.js.map +1 -1
- package/dist/storage/db.d.ts.map +1 -1
- package/dist/storage/db.js.map +1 -1
- package/dist/storage/edge-store.d.ts +17 -30
- package/dist/storage/edge-store.d.ts.map +1 -1
- package/dist/storage/edge-store.js +43 -123
- package/dist/storage/edge-store.js.map +1 -1
- package/dist/storage/embedding-cache.d.ts.map +1 -1
- package/dist/storage/embedding-cache.js +1 -3
- package/dist/storage/embedding-cache.js.map +1 -1
- package/dist/storage/encryption.d.ts.map +1 -1
- package/dist/storage/encryption.js +4 -15
- package/dist/storage/encryption.js.map +1 -1
- package/dist/storage/index.d.ts +1 -4
- package/dist/storage/index.d.ts.map +1 -1
- package/dist/storage/index.js +1 -5
- package/dist/storage/index.js.map +1 -1
- package/dist/storage/keyword-store.d.ts.map +1 -1
- package/dist/storage/keyword-store.js +11 -7
- package/dist/storage/keyword-store.js.map +1 -1
- package/dist/storage/migrations.d.ts.map +1 -1
- package/dist/storage/migrations.js +56 -4
- package/dist/storage/migrations.js.map +1 -1
- package/dist/storage/schema.sql +8 -20
- package/dist/storage/types.d.ts +12 -26
- package/dist/storage/types.d.ts.map +1 -1
- package/dist/storage/types.js +1 -2
- package/dist/storage/types.js.map +1 -1
- package/dist/storage/vector-store.d.ts +9 -15
- package/dist/storage/vector-store.d.ts.map +1 -1
- package/dist/storage/vector-store.js +64 -43
- package/dist/storage/vector-store.js.map +1 -1
- package/dist/utils/angular-distance.d.ts.map +1 -1
- package/dist/utils/angular-distance.js.map +1 -1
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js.map +1 -1
- package/dist/utils/secret-store.d.ts.map +1 -1
- package/dist/utils/secret-store.js +17 -13
- package/dist/utils/secret-store.js.map +1 -1
- package/dist/utils/secure-buffer.d.ts.map +1 -1
- package/dist/utils/secure-buffer.js.map +1 -1
- package/package.json +7 -6
- package/src/dashboard/client/package-lock.json +3 -3
- package/src/dashboard/client/package.json +3 -3
- package/dist/dashboard/client/assets/index-CMUKy4f9.css +0 -1
- package/dist/dashboard/client/assets/index-esv8TpCN.js +0 -168
- package/dist/eval/collection-benchmark/graph-value.d.ts +0 -16
- package/dist/eval/collection-benchmark/graph-value.d.ts.map +0 -1
- package/dist/eval/collection-benchmark/graph-value.js +0 -162
- package/dist/eval/collection-benchmark/graph-value.js.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/curve-shapes-experiment.d.ts +0 -10
- package/dist/eval/experiments/vector-decay-shapes/curve-shapes-experiment.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/curve-shapes-experiment.js +0 -229
- package/dist/eval/experiments/vector-decay-shapes/curve-shapes-experiment.js.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/graph-range-experiment.d.ts +0 -12
- package/dist/eval/experiments/vector-decay-shapes/graph-range-experiment.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/graph-range-experiment.js +0 -316
- package/dist/eval/experiments/vector-decay-shapes/graph-range-experiment.js.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/hop-decay.d.ts +0 -19
- package/dist/eval/experiments/vector-decay-shapes/hop-decay.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/hop-decay.js +0 -127
- package/dist/eval/experiments/vector-decay-shapes/hop-decay.js.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/index.d.ts +0 -11
- package/dist/eval/experiments/vector-decay-shapes/index.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/index.js +0 -11
- package/dist/eval/experiments/vector-decay-shapes/index.js.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/path-traversal-experiment.d.ts +0 -14
- package/dist/eval/experiments/vector-decay-shapes/path-traversal-experiment.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/path-traversal-experiment.js +0 -274
- package/dist/eval/experiments/vector-decay-shapes/path-traversal-experiment.js.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/presets.d.ts +0 -36
- package/dist/eval/experiments/vector-decay-shapes/presets.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/presets.js +0 -157
- package/dist/eval/experiments/vector-decay-shapes/presets.js.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/run-experiment.d.ts +0 -20
- package/dist/eval/experiments/vector-decay-shapes/run-experiment.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/run-experiment.js +0 -504
- package/dist/eval/experiments/vector-decay-shapes/run-experiment.js.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/types.d.ts +0 -111
- package/dist/eval/experiments/vector-decay-shapes/types.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-shapes/types.js +0 -15
- package/dist/eval/experiments/vector-decay-shapes/types.js.map +0 -1
- package/dist/eval/experiments/vector-decay-sweep/index.d.ts +0 -7
- package/dist/eval/experiments/vector-decay-sweep/index.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-sweep/index.js +0 -7
- package/dist/eval/experiments/vector-decay-sweep/index.js.map +0 -1
- package/dist/eval/experiments/vector-decay-sweep/run-sweep.d.ts +0 -30
- package/dist/eval/experiments/vector-decay-sweep/run-sweep.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-sweep/run-sweep.js +0 -378
- package/dist/eval/experiments/vector-decay-sweep/run-sweep.js.map +0 -1
- package/dist/eval/experiments/vector-decay-sweep/types.d.ts +0 -109
- package/dist/eval/experiments/vector-decay-sweep/types.d.ts.map +0 -1
- package/dist/eval/experiments/vector-decay-sweep/types.js +0 -16
- package/dist/eval/experiments/vector-decay-sweep/types.js.map +0 -1
- package/dist/maintenance/tasks/prune-graph.d.ts +0 -12
- package/dist/maintenance/tasks/prune-graph.d.ts.map +0 -1
- package/dist/maintenance/tasks/prune-graph.js +0 -23
- package/dist/maintenance/tasks/prune-graph.js.map +0 -1
- package/dist/retrieval/traverser.d.ts +0 -66
- package/dist/retrieval/traverser.d.ts.map +0 -1
- package/dist/retrieval/traverser.js +0 -160
- package/dist/retrieval/traverser.js.map +0 -1
- package/dist/storage/clock-store.d.ts +0 -80
- package/dist/storage/clock-store.d.ts.map +0 -1
- package/dist/storage/clock-store.js +0 -155
- package/dist/storage/clock-store.js.map +0 -1
- package/dist/storage/decay.d.ts +0 -125
- package/dist/storage/decay.d.ts.map +0 -1
- package/dist/storage/decay.js +0 -276
- package/dist/storage/decay.js.map +0 -1
- package/dist/storage/pruner.d.ts +0 -111
- package/dist/storage/pruner.d.ts.map +0 -1
- package/dist/storage/pruner.js +0 -280
- package/dist/storage/pruner.js.map +0 -1
- package/dist/temporal/clock-compactor.d.ts +0 -65
- package/dist/temporal/clock-compactor.d.ts.map +0 -1
- package/dist/temporal/clock-compactor.js +0 -157
- package/dist/temporal/clock-compactor.js.map +0 -1
- package/dist/temporal/index.d.ts +0 -6
- package/dist/temporal/index.d.ts.map +0 -1
- package/dist/temporal/index.js +0 -6
- package/dist/temporal/index.js.map +0 -1
- package/dist/temporal/vector-clock.d.ts +0 -143
- package/dist/temporal/vector-clock.d.ts.map +0 -1
- package/dist/temporal/vector-clock.js +0 -231
- package/dist/temporal/vector-clock.js.map +0 -1
- package/dist/utils/keychain.d.ts +0 -43
- package/dist/utils/keychain.d.ts.map +0 -1
- package/dist/utils/keychain.js +0 -82
- package/dist/utils/keychain.js.map +0 -1
|
@@ -1,504 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Run hop-based decay shape experiments.
|
|
3
|
-
*
|
|
4
|
-
* Tests different decay curve shapes (exponential, linear, delayed-linear, multi-linear)
|
|
5
|
-
* for both backward (retrieval) and forward (prediction) traversal.
|
|
6
|
-
*/
|
|
7
|
-
import { getDb } from '../../../storage/db.js';
|
|
8
|
-
import { deserialize, hopCount } from '../../../temporal/vector-clock.js';
|
|
9
|
-
import { getReferenceClock } from '../../../storage/clock-store.js';
|
|
10
|
-
import { calculateHopDecayWeight } from './hop-decay.js';
|
|
11
|
-
import { ALL_HOP_DECAY_CONFIGS } from './presets.js';
|
|
12
|
-
/** Number of negative samples per query */
|
|
13
|
-
const NEGATIVE_SAMPLE_COUNT = 10;
|
|
14
|
-
/**
|
|
15
|
-
* Hop bin boundaries for stratification.
|
|
16
|
-
*/
|
|
17
|
-
const HOP_BINS = {
|
|
18
|
-
near: { min: 0, max: 3 },
|
|
19
|
-
medium: { min: 4, max: 7 },
|
|
20
|
-
far: { min: 8, max: Infinity },
|
|
21
|
-
};
|
|
22
|
-
/**
|
|
23
|
-
* Get hop bin for a given hop count.
|
|
24
|
-
*/
|
|
25
|
-
function getHopBin(hops) {
|
|
26
|
-
if (hops <= HOP_BINS.near.max)
|
|
27
|
-
return 'near';
|
|
28
|
-
if (hops <= HOP_BINS.medium.max)
|
|
29
|
-
return 'medium';
|
|
30
|
-
return 'far';
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Load edges with vector clocks from database.
|
|
34
|
-
*/
|
|
35
|
-
function loadEdges(edgeType) {
|
|
36
|
-
const db = getDb();
|
|
37
|
-
return db.prepare(`
|
|
38
|
-
SELECT id, source_chunk_id as sourceChunkId, target_chunk_id as targetChunkId,
|
|
39
|
-
vector_clock as vectorClock, initial_weight as initialWeight,
|
|
40
|
-
reference_type as referenceType, edge_type as edgeType
|
|
41
|
-
FROM edges
|
|
42
|
-
WHERE vector_clock IS NOT NULL AND edge_type = ?
|
|
43
|
-
`).all(edgeType);
|
|
44
|
-
}
|
|
45
|
-
/**
|
|
46
|
-
* Load chunk metadata.
|
|
47
|
-
*/
|
|
48
|
-
function loadChunks() {
|
|
49
|
-
const db = getDb();
|
|
50
|
-
const rows = db.prepare(`
|
|
51
|
-
SELECT id, session_slug as sessionSlug, vector_clock as vectorClock
|
|
52
|
-
FROM chunks
|
|
53
|
-
`).all();
|
|
54
|
-
return new Map(rows.map((r) => [r.id, r]));
|
|
55
|
-
}
|
|
56
|
-
/**
|
|
57
|
-
* Group edges by source chunk for backward evaluation.
|
|
58
|
-
*/
|
|
59
|
-
function groupEdgesBySource(edges) {
|
|
60
|
-
const groups = new Map();
|
|
61
|
-
for (const edge of edges) {
|
|
62
|
-
const existing = groups.get(edge.sourceChunkId) ?? [];
|
|
63
|
-
existing.push(edge);
|
|
64
|
-
groups.set(edge.sourceChunkId, existing);
|
|
65
|
-
}
|
|
66
|
-
return groups;
|
|
67
|
-
}
|
|
68
|
-
/**
|
|
69
|
-
* Group edges by target chunk for forward evaluation.
|
|
70
|
-
*/
|
|
71
|
-
function groupEdgesByTarget(edges) {
|
|
72
|
-
const groups = new Map();
|
|
73
|
-
for (const edge of edges) {
|
|
74
|
-
const existing = groups.get(edge.targetChunkId) ?? [];
|
|
75
|
-
existing.push(edge);
|
|
76
|
-
groups.set(edge.targetChunkId, existing);
|
|
77
|
-
}
|
|
78
|
-
return groups;
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* Sample random chunks from a project to use as negative samples.
|
|
82
|
-
*/
|
|
83
|
-
function sampleNegativeChunks(projectSlug, excludeChunkIds, count, projectChunks) {
|
|
84
|
-
const available = projectChunks.get(projectSlug) ?? [];
|
|
85
|
-
const candidates = available.filter((c) => !excludeChunkIds.has(c.id) && c.vectorClock);
|
|
86
|
-
if (candidates.length === 0)
|
|
87
|
-
return [];
|
|
88
|
-
// Fisher-Yates shuffle and take first `count`
|
|
89
|
-
const shuffled = [...candidates];
|
|
90
|
-
for (let i = shuffled.length - 1; i > 0; i--) {
|
|
91
|
-
const j = Math.floor(Math.random() * (i + 1));
|
|
92
|
-
[shuffled[i], shuffled[j]] = [shuffled[j], shuffled[i]];
|
|
93
|
-
}
|
|
94
|
-
return shuffled.slice(0, count);
|
|
95
|
-
}
|
|
96
|
-
/**
|
|
97
|
-
* Evaluate a backward query (retrieval: what context led to this chunk?).
|
|
98
|
-
*/
|
|
99
|
-
function evaluateBackwardQuery(sourceChunkId, positiveEdges, projectSlug, referenceClock, config, projectChunks) {
|
|
100
|
-
// Filter to edges with explicit references (not just adjacent)
|
|
101
|
-
const relevantTypes = ['file-path', 'code-entity', 'explicit-backref', 'error-fragment', 'tool-output'];
|
|
102
|
-
const relevantEdges = positiveEdges.filter((e) => relevantTypes.includes(e.referenceType ?? ''));
|
|
103
|
-
if (relevantEdges.length === 0) {
|
|
104
|
-
return null;
|
|
105
|
-
}
|
|
106
|
-
// Get the positive target chunk IDs
|
|
107
|
-
const positiveTargetIds = new Set(relevantEdges.map((e) => e.targetChunkId));
|
|
108
|
-
// Sample negative chunks
|
|
109
|
-
const excludeIds = new Set([sourceChunkId, ...positiveTargetIds]);
|
|
110
|
-
const negativeChunks = sampleNegativeChunks(projectSlug, excludeIds, NEGATIVE_SAMPLE_COUNT, projectChunks);
|
|
111
|
-
if (negativeChunks.length === 0) {
|
|
112
|
-
return null;
|
|
113
|
-
}
|
|
114
|
-
const candidates = [];
|
|
115
|
-
// Add positive samples (from edges)
|
|
116
|
-
for (const edge of relevantEdges) {
|
|
117
|
-
if (!edge.vectorClock)
|
|
118
|
-
continue;
|
|
119
|
-
const edgeClock = deserialize(edge.vectorClock);
|
|
120
|
-
const hops = hopCount(edgeClock, referenceClock);
|
|
121
|
-
const weight = calculateHopDecayWeight(config, hops);
|
|
122
|
-
candidates.push({
|
|
123
|
-
chunkId: edge.targetChunkId,
|
|
124
|
-
isPositive: true,
|
|
125
|
-
hops,
|
|
126
|
-
weight,
|
|
127
|
-
});
|
|
128
|
-
}
|
|
129
|
-
// Add negative samples
|
|
130
|
-
for (const chunk of negativeChunks) {
|
|
131
|
-
if (!chunk.vectorClock)
|
|
132
|
-
continue;
|
|
133
|
-
const chunkClock = deserialize(chunk.vectorClock);
|
|
134
|
-
const hops = hopCount(chunkClock, referenceClock);
|
|
135
|
-
const weight = calculateHopDecayWeight(config, hops);
|
|
136
|
-
candidates.push({
|
|
137
|
-
chunkId: chunk.id,
|
|
138
|
-
isPositive: false,
|
|
139
|
-
hops,
|
|
140
|
-
weight,
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
if (candidates.filter((c) => c.isPositive).length === 0) {
|
|
144
|
-
return null;
|
|
145
|
-
}
|
|
146
|
-
// Sort by weight descending (best candidates first)
|
|
147
|
-
candidates.sort((a, b) => b.weight - a.weight);
|
|
148
|
-
// Find rank of first positive (relevant) sample
|
|
149
|
-
let firstRelevantRank = 0;
|
|
150
|
-
for (let i = 0; i < candidates.length; i++) {
|
|
151
|
-
if (candidates[i].isPositive) {
|
|
152
|
-
firstRelevantRank = i + 1;
|
|
153
|
-
break;
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
const reciprocalRank = firstRelevantRank > 0 ? 1 / firstRelevantRank : 0;
|
|
157
|
-
return {
|
|
158
|
-
sourceChunkId,
|
|
159
|
-
projectSlug,
|
|
160
|
-
relevantHops: candidates.filter((c) => c.isPositive).map((c) => c.hops),
|
|
161
|
-
allHops: candidates.map((c) => c.hops),
|
|
162
|
-
reciprocalRank,
|
|
163
|
-
firstRelevantRank,
|
|
164
|
-
direction: 'backward',
|
|
165
|
-
};
|
|
166
|
-
}
|
|
167
|
-
/**
|
|
168
|
-
* Evaluate a forward query (prediction: which future chunks will reference this source?).
|
|
169
|
-
*
|
|
170
|
-
* Forward semantics: Given source chunk S, predict which future targets T will reference S.
|
|
171
|
-
* We rank candidates by "forward decay" - how much does relevance decay as we look further into the future.
|
|
172
|
-
*/
|
|
173
|
-
function evaluateForwardQuery(sourceChunkId, positiveEdges, // These are forward edges FROM this source
|
|
174
|
-
projectSlug, referenceClock, config, projectChunks, chunks) {
|
|
175
|
-
// Filter to edges with explicit references
|
|
176
|
-
const relevantTypes = ['file-path', 'code-entity', 'explicit-backref', 'error-fragment', 'tool-output'];
|
|
177
|
-
const relevantEdges = positiveEdges.filter((e) => relevantTypes.includes(e.referenceType ?? ''));
|
|
178
|
-
if (relevantEdges.length === 0) {
|
|
179
|
-
return null;
|
|
180
|
-
}
|
|
181
|
-
// Get the positive target chunk IDs (future chunks that reference this source)
|
|
182
|
-
const positiveTargetIds = new Set(relevantEdges.map((e) => e.targetChunkId));
|
|
183
|
-
// Sample negative chunks (potential future chunks that don't reference source)
|
|
184
|
-
const excludeIds = new Set([sourceChunkId, ...positiveTargetIds]);
|
|
185
|
-
const negativeChunks = sampleNegativeChunks(projectSlug, excludeIds, NEGATIVE_SAMPLE_COUNT, projectChunks);
|
|
186
|
-
if (negativeChunks.length === 0) {
|
|
187
|
-
return null;
|
|
188
|
-
}
|
|
189
|
-
const candidates = [];
|
|
190
|
-
// Get source chunk clock
|
|
191
|
-
const sourceChunk = chunks.get(sourceChunkId);
|
|
192
|
-
if (!sourceChunk?.vectorClock)
|
|
193
|
-
return null;
|
|
194
|
-
const sourceClock = deserialize(sourceChunk.vectorClock);
|
|
195
|
-
// Add positive samples (future chunks that DO reference this source)
|
|
196
|
-
for (const edge of relevantEdges) {
|
|
197
|
-
const targetChunk = chunks.get(edge.targetChunkId);
|
|
198
|
-
if (!targetChunk?.vectorClock)
|
|
199
|
-
continue;
|
|
200
|
-
const targetClock = deserialize(targetChunk.vectorClock);
|
|
201
|
-
// Hops from source to target: how far "ahead" is the referencing chunk
|
|
202
|
-
// This measures the forward distance: target is newer than source
|
|
203
|
-
const hops = hopCount(sourceClock, targetClock);
|
|
204
|
-
const weight = calculateHopDecayWeight(config, hops);
|
|
205
|
-
candidates.push({
|
|
206
|
-
chunkId: edge.targetChunkId,
|
|
207
|
-
isPositive: true,
|
|
208
|
-
hops,
|
|
209
|
-
weight,
|
|
210
|
-
});
|
|
211
|
-
}
|
|
212
|
-
// Add negative samples (chunks that don't reference source)
|
|
213
|
-
for (const chunk of negativeChunks) {
|
|
214
|
-
if (!chunk.vectorClock)
|
|
215
|
-
continue;
|
|
216
|
-
const chunkClock = deserialize(chunk.vectorClock);
|
|
217
|
-
// Same calculation: hops from source to candidate
|
|
218
|
-
const hops = hopCount(sourceClock, chunkClock);
|
|
219
|
-
const weight = calculateHopDecayWeight(config, hops);
|
|
220
|
-
candidates.push({
|
|
221
|
-
chunkId: chunk.id,
|
|
222
|
-
isPositive: false,
|
|
223
|
-
hops,
|
|
224
|
-
weight,
|
|
225
|
-
});
|
|
226
|
-
}
|
|
227
|
-
if (candidates.filter((c) => c.isPositive).length === 0) {
|
|
228
|
-
return null;
|
|
229
|
-
}
|
|
230
|
-
// Sort by weight descending (higher weight = predicted to be more likely to reference)
|
|
231
|
-
candidates.sort((a, b) => b.weight - a.weight);
|
|
232
|
-
let firstRelevantRank = 0;
|
|
233
|
-
for (let i = 0; i < candidates.length; i++) {
|
|
234
|
-
if (candidates[i].isPositive) {
|
|
235
|
-
firstRelevantRank = i + 1;
|
|
236
|
-
break;
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
const reciprocalRank = firstRelevantRank > 0 ? 1 / firstRelevantRank : 0;
|
|
240
|
-
return {
|
|
241
|
-
sourceChunkId,
|
|
242
|
-
projectSlug,
|
|
243
|
-
relevantHops: candidates.filter((c) => c.isPositive).map((c) => c.hops),
|
|
244
|
-
allHops: candidates.map((c) => c.hops),
|
|
245
|
-
reciprocalRank,
|
|
246
|
-
firstRelevantRank,
|
|
247
|
-
direction: 'forward',
|
|
248
|
-
};
|
|
249
|
-
}
|
|
250
|
-
/**
|
|
251
|
-
* Calculate result metrics from evaluations.
|
|
252
|
-
*/
|
|
253
|
-
function calculateResult(config, evaluations, direction) {
|
|
254
|
-
const mrr = evaluations.length > 0
|
|
255
|
-
? evaluations.reduce((sum, e) => sum + e.reciprocalRank, 0) / evaluations.length
|
|
256
|
-
: 0;
|
|
257
|
-
const rankDistribution = {
|
|
258
|
-
rank1: 0,
|
|
259
|
-
rank2_5: 0,
|
|
260
|
-
rank6_10: 0,
|
|
261
|
-
rank11_plus: 0,
|
|
262
|
-
};
|
|
263
|
-
for (const e of evaluations) {
|
|
264
|
-
if (e.firstRelevantRank === 1)
|
|
265
|
-
rankDistribution.rank1++;
|
|
266
|
-
else if (e.firstRelevantRank <= 5)
|
|
267
|
-
rankDistribution.rank2_5++;
|
|
268
|
-
else if (e.firstRelevantRank <= 10)
|
|
269
|
-
rankDistribution.rank6_10++;
|
|
270
|
-
else
|
|
271
|
-
rankDistribution.rank11_plus++;
|
|
272
|
-
}
|
|
273
|
-
// Stratified by hop distance
|
|
274
|
-
const stratified = {
|
|
275
|
-
near: [],
|
|
276
|
-
medium: [],
|
|
277
|
-
far: [],
|
|
278
|
-
};
|
|
279
|
-
for (const e of evaluations) {
|
|
280
|
-
if (e.relevantHops.length === 0)
|
|
281
|
-
continue;
|
|
282
|
-
const minHop = Math.min(...e.relevantHops);
|
|
283
|
-
const bin = getHopBin(minHop);
|
|
284
|
-
stratified[bin].push(e);
|
|
285
|
-
}
|
|
286
|
-
const stratifiedMRR = {
|
|
287
|
-
near: stratified.near.length > 0
|
|
288
|
-
? stratified.near.reduce((s, e) => s + e.reciprocalRank, 0) / stratified.near.length
|
|
289
|
-
: 0,
|
|
290
|
-
medium: stratified.medium.length > 0
|
|
291
|
-
? stratified.medium.reduce((s, e) => s + e.reciprocalRank, 0) / stratified.medium.length
|
|
292
|
-
: 0,
|
|
293
|
-
far: stratified.far.length > 0
|
|
294
|
-
? stratified.far.reduce((s, e) => s + e.reciprocalRank, 0) / stratified.far.length
|
|
295
|
-
: 0,
|
|
296
|
-
};
|
|
297
|
-
return {
|
|
298
|
-
configId: config.id,
|
|
299
|
-
configName: config.name,
|
|
300
|
-
direction,
|
|
301
|
-
mrr,
|
|
302
|
-
queryCount: evaluations.length,
|
|
303
|
-
rankDistribution,
|
|
304
|
-
stratifiedMRR,
|
|
305
|
-
stratifiedCounts: {
|
|
306
|
-
near: stratified.near.length,
|
|
307
|
-
medium: stratified.medium.length,
|
|
308
|
-
far: stratified.far.length,
|
|
309
|
-
},
|
|
310
|
-
};
|
|
311
|
-
}
|
|
312
|
-
/**
|
|
313
|
-
* Run the hop decay shape experiment.
|
|
314
|
-
*/
|
|
315
|
-
export async function runHopDecayShapeExperiment(options = {}) {
|
|
316
|
-
const { configs = ALL_HOP_DECAY_CONFIGS, verbose = true, maxQueries = Infinity, } = options;
|
|
317
|
-
if (verbose) {
|
|
318
|
-
console.log('=== Hop-Based Decay Shape Experiment ===\n');
|
|
319
|
-
}
|
|
320
|
-
// Load data
|
|
321
|
-
if (verbose)
|
|
322
|
-
console.log('Loading edges...');
|
|
323
|
-
const backwardEdges = loadEdges('backward');
|
|
324
|
-
const forwardEdges = loadEdges('forward');
|
|
325
|
-
const chunks = loadChunks();
|
|
326
|
-
if (verbose) {
|
|
327
|
-
console.log(` Backward edges: ${backwardEdges.length}`);
|
|
328
|
-
console.log(` Forward edges: ${forwardEdges.length}`);
|
|
329
|
-
console.log(` Chunks: ${chunks.size}`);
|
|
330
|
-
console.log();
|
|
331
|
-
}
|
|
332
|
-
// Group edges by source for both backward and forward eval
|
|
333
|
-
const backwardEdgesBySource = groupEdgesBySource(backwardEdges);
|
|
334
|
-
const forwardEdgesBySource = groupEdgesBySource(forwardEdges);
|
|
335
|
-
// Get project slugs and chunks
|
|
336
|
-
const projectSlugs = new Set();
|
|
337
|
-
for (const chunk of chunks.values()) {
|
|
338
|
-
projectSlugs.add(chunk.sessionSlug);
|
|
339
|
-
}
|
|
340
|
-
const referenceClocks = new Map();
|
|
341
|
-
for (const slug of projectSlugs) {
|
|
342
|
-
referenceClocks.set(slug, getReferenceClock(slug));
|
|
343
|
-
}
|
|
344
|
-
const projectChunks = new Map();
|
|
345
|
-
for (const chunk of chunks.values()) {
|
|
346
|
-
const existing = projectChunks.get(chunk.sessionSlug) ?? [];
|
|
347
|
-
existing.push(chunk);
|
|
348
|
-
projectChunks.set(chunk.sessionSlug, existing);
|
|
349
|
-
}
|
|
350
|
-
const results = [];
|
|
351
|
-
// Test each config
|
|
352
|
-
for (const config of configs) {
|
|
353
|
-
if (verbose) {
|
|
354
|
-
console.log(`Testing ${config.name}...`);
|
|
355
|
-
}
|
|
356
|
-
// Backward evaluation
|
|
357
|
-
const backwardEvals = [];
|
|
358
|
-
let backwardQueries = 0;
|
|
359
|
-
for (const [sourceChunkId, edges] of backwardEdgesBySource) {
|
|
360
|
-
if (backwardQueries >= maxQueries)
|
|
361
|
-
break;
|
|
362
|
-
const chunk = chunks.get(sourceChunkId);
|
|
363
|
-
if (!chunk)
|
|
364
|
-
continue;
|
|
365
|
-
const refClock = referenceClocks.get(chunk.sessionSlug);
|
|
366
|
-
if (!refClock)
|
|
367
|
-
continue;
|
|
368
|
-
const evaluation = evaluateBackwardQuery(sourceChunkId, edges, chunk.sessionSlug, refClock, config, projectChunks);
|
|
369
|
-
if (evaluation) {
|
|
370
|
-
backwardEvals.push(evaluation);
|
|
371
|
-
backwardQueries++;
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
const backwardResult = calculateResult(config, backwardEvals, 'backward');
|
|
375
|
-
results.push(backwardResult);
|
|
376
|
-
if (verbose) {
|
|
377
|
-
console.log(` Backward: MRR=${backwardResult.mrr.toFixed(3)}, n=${backwardResult.queryCount}`);
|
|
378
|
-
console.log(` Near: ${backwardResult.stratifiedMRR.near.toFixed(3)} (${backwardResult.stratifiedCounts.near})`);
|
|
379
|
-
console.log(` Far: ${backwardResult.stratifiedMRR.far.toFixed(3)} (${backwardResult.stratifiedCounts.far})`);
|
|
380
|
-
}
|
|
381
|
-
// Forward evaluation
|
|
382
|
-
const forwardEvals = [];
|
|
383
|
-
let forwardQueries = 0;
|
|
384
|
-
for (const [sourceChunkId, edges] of forwardEdgesBySource) {
|
|
385
|
-
if (forwardQueries >= maxQueries)
|
|
386
|
-
break;
|
|
387
|
-
const chunk = chunks.get(sourceChunkId);
|
|
388
|
-
if (!chunk)
|
|
389
|
-
continue;
|
|
390
|
-
const refClock = referenceClocks.get(chunk.sessionSlug);
|
|
391
|
-
if (!refClock)
|
|
392
|
-
continue;
|
|
393
|
-
const evaluation = evaluateForwardQuery(sourceChunkId, edges, chunk.sessionSlug, refClock, config, projectChunks, chunks);
|
|
394
|
-
if (evaluation) {
|
|
395
|
-
forwardEvals.push(evaluation);
|
|
396
|
-
forwardQueries++;
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
const forwardResult = calculateResult(config, forwardEvals, 'forward');
|
|
400
|
-
results.push(forwardResult);
|
|
401
|
-
if (verbose) {
|
|
402
|
-
console.log(` Forward: MRR=${forwardResult.mrr.toFixed(3)}, n=${forwardResult.queryCount}`);
|
|
403
|
-
console.log(` Near: ${forwardResult.stratifiedMRR.near.toFixed(3)} (${forwardResult.stratifiedCounts.near})`);
|
|
404
|
-
console.log(` Far: ${forwardResult.stratifiedMRR.far.toFixed(3)} (${forwardResult.stratifiedCounts.far})`);
|
|
405
|
-
console.log();
|
|
406
|
-
}
|
|
407
|
-
}
|
|
408
|
-
// Find best variants
|
|
409
|
-
const backwardResults = results.filter((r) => r.direction === 'backward');
|
|
410
|
-
const forwardResults = results.filter((r) => r.direction === 'forward');
|
|
411
|
-
const bestBackward = [...backwardResults].sort((a, b) => b.mrr - a.mrr)[0];
|
|
412
|
-
const bestForward = [...forwardResults].sort((a, b) => b.mrr - a.mrr)[0];
|
|
413
|
-
const bestFarBackward = [...backwardResults].sort((a, b) => b.stratifiedMRR.far - a.stratifiedMRR.far)[0];
|
|
414
|
-
const bestFarForward = [...forwardResults].sort((a, b) => b.stratifiedMRR.far - a.stratifiedMRR.far)[0];
|
|
415
|
-
const sweepResults = {
|
|
416
|
-
generatedAt: new Date().toISOString(),
|
|
417
|
-
edgeCount: backwardEdges.length + forwardEdges.length,
|
|
418
|
-
results,
|
|
419
|
-
bestBackwardId: bestBackward?.configId ?? '',
|
|
420
|
-
bestForwardId: bestForward?.configId ?? '',
|
|
421
|
-
bestFarBackwardId: bestFarBackward?.configId ?? '',
|
|
422
|
-
bestFarForwardId: bestFarForward?.configId ?? '',
|
|
423
|
-
};
|
|
424
|
-
if (verbose) {
|
|
425
|
-
console.log(formatResults(sweepResults));
|
|
426
|
-
}
|
|
427
|
-
return sweepResults;
|
|
428
|
-
}
|
|
429
|
-
/**
|
|
430
|
-
* Format results as a comparison table.
|
|
431
|
-
*/
|
|
432
|
-
export function formatResults(results) {
|
|
433
|
-
const lines = [];
|
|
434
|
-
lines.push('='.repeat(100));
|
|
435
|
-
lines.push(' HOP-BASED DECAY SHAPE EXPERIMENT RESULTS');
|
|
436
|
-
lines.push('='.repeat(100));
|
|
437
|
-
lines.push(`\nEdges analyzed: ${results.edgeCount}\n`);
|
|
438
|
-
// Backward results
|
|
439
|
-
lines.push('BACKWARD (Retrieval): What context led to this chunk?');
|
|
440
|
-
lines.push('-'.repeat(100));
|
|
441
|
-
lines.push(formatDirectionTable(results.results.filter((r) => r.direction === 'backward'), results.bestBackwardId, results.bestFarBackwardId));
|
|
442
|
-
lines.push('\nFORWARD (Prediction): Which future chunks reference this?');
|
|
443
|
-
lines.push('-'.repeat(100));
|
|
444
|
-
lines.push(formatDirectionTable(results.results.filter((r) => r.direction === 'forward'), results.bestForwardId, results.bestFarForwardId));
|
|
445
|
-
// Recommendations
|
|
446
|
-
lines.push('\n' + '='.repeat(100));
|
|
447
|
-
lines.push('RECOMMENDATIONS:');
|
|
448
|
-
const bestBackward = results.results.find((r) => r.configId === results.bestBackwardId && r.direction === 'backward');
|
|
449
|
-
const bestForward = results.results.find((r) => r.configId === results.bestForwardId && r.direction === 'forward');
|
|
450
|
-
const bestFarBackward = results.results.find((r) => r.configId === results.bestFarBackwardId && r.direction === 'backward');
|
|
451
|
-
const bestFarForward = results.results.find((r) => r.configId === results.bestFarForwardId && r.direction === 'forward');
|
|
452
|
-
if (bestBackward) {
|
|
453
|
-
lines.push(` Backward overall: ${bestBackward.configName} (MRR=${bestBackward.mrr.toFixed(3)})`);
|
|
454
|
-
}
|
|
455
|
-
if (bestFarBackward && bestFarBackward.configId !== results.bestBackwardId) {
|
|
456
|
-
lines.push(` Backward far-hop: ${bestFarBackward.configName} (Far MRR=${bestFarBackward.stratifiedMRR.far.toFixed(3)})`);
|
|
457
|
-
}
|
|
458
|
-
if (bestForward) {
|
|
459
|
-
lines.push(` Forward overall: ${bestForward.configName} (MRR=${bestForward.mrr.toFixed(3)})`);
|
|
460
|
-
}
|
|
461
|
-
if (bestFarForward && bestFarForward.configId !== results.bestForwardId) {
|
|
462
|
-
lines.push(` Forward far-hop: ${bestFarForward.configName} (Far MRR=${bestFarForward.stratifiedMRR.far.toFixed(3)})`);
|
|
463
|
-
}
|
|
464
|
-
lines.push('='.repeat(100));
|
|
465
|
-
return lines.join('\n');
|
|
466
|
-
}
|
|
467
|
-
function formatDirectionTable(results, bestId, bestFarId) {
|
|
468
|
-
const lines = [];
|
|
469
|
-
const header = [
|
|
470
|
-
'Config'.padEnd(25),
|
|
471
|
-
'MRR'.padEnd(8),
|
|
472
|
-
'Near'.padEnd(8),
|
|
473
|
-
'Medium'.padEnd(8),
|
|
474
|
-
'Far'.padEnd(8),
|
|
475
|
-
'Rank@1'.padEnd(8),
|
|
476
|
-
'n'.padEnd(6),
|
|
477
|
-
].join(' | ');
|
|
478
|
-
lines.push(header);
|
|
479
|
-
lines.push('-'.repeat(80));
|
|
480
|
-
const sorted = [...results].sort((a, b) => b.mrr - a.mrr);
|
|
481
|
-
for (const r of sorted) {
|
|
482
|
-
const row = [
|
|
483
|
-
r.configName.slice(0, 25).padEnd(25),
|
|
484
|
-
r.mrr.toFixed(3).padEnd(8),
|
|
485
|
-
r.stratifiedMRR.near.toFixed(3).padEnd(8),
|
|
486
|
-
r.stratifiedMRR.medium.toFixed(3).padEnd(8),
|
|
487
|
-
r.stratifiedMRR.far.toFixed(3).padEnd(8),
|
|
488
|
-
r.rankDistribution.rank1.toString().padEnd(8),
|
|
489
|
-
r.queryCount.toString().padEnd(6),
|
|
490
|
-
].join(' | ');
|
|
491
|
-
let suffix = '';
|
|
492
|
-
if (r.configId === bestId)
|
|
493
|
-
suffix = ' *BEST*';
|
|
494
|
-
if (r.configId === bestFarId && r.configId !== bestId)
|
|
495
|
-
suffix = ' *BEST-FAR*';
|
|
496
|
-
lines.push(row + suffix);
|
|
497
|
-
}
|
|
498
|
-
return lines.join('\n');
|
|
499
|
-
}
|
|
500
|
-
// CLI entry point
|
|
501
|
-
if (import.meta.url === `file://${process.argv[1]}`) {
|
|
502
|
-
runHopDecayShapeExperiment({ verbose: true }).catch(console.error);
|
|
503
|
-
}
|
|
504
|
-
//# sourceMappingURL=run-experiment.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"run-experiment.js","sourceRoot":"","sources":["../../../../src/eval/experiments/vector-decay-shapes/run-experiment.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Types for vector decay shape experiments.
|
|
3
|
-
*
|
|
4
|
-
* Tests different decay curve shapes using hop count (D-T-D cycles)
|
|
5
|
-
* instead of wall-clock time.
|
|
6
|
-
*/
|
|
7
|
-
/**
|
|
8
|
-
* Decay curve types for hop-based decay.
|
|
9
|
-
*/
|
|
10
|
-
export type HopDecayType = 'exponential' | 'linear' | 'delayed-linear' | 'multi-linear';
|
|
11
|
-
/**
|
|
12
|
-
* Configuration for hop-based decay curves.
|
|
13
|
-
*/
|
|
14
|
-
export interface HopDecayConfig {
|
|
15
|
-
id: string;
|
|
16
|
-
name: string;
|
|
17
|
-
type: HopDecayType;
|
|
18
|
-
/** Initial weight at hop 0 */
|
|
19
|
-
initialWeight: number;
|
|
20
|
-
/** For exponential: weight multiplier per hop (e.g., 0.8) */
|
|
21
|
-
weightPerHop?: number;
|
|
22
|
-
/** For linear/delayed-linear: weight reduction per hop */
|
|
23
|
-
decayPerHop?: number;
|
|
24
|
-
/** For delayed-linear: number of hops before decay starts */
|
|
25
|
-
holdHops?: number;
|
|
26
|
-
/** For multi-linear: multiple tiers */
|
|
27
|
-
tiers?: HopDecayTier[];
|
|
28
|
-
/** Minimum weight before considered dead */
|
|
29
|
-
minWeight: number;
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* A tier in multi-linear hop decay.
|
|
33
|
-
*/
|
|
34
|
-
export interface HopDecayTier {
|
|
35
|
-
name: string;
|
|
36
|
-
initialWeight: number;
|
|
37
|
-
holdHops: number;
|
|
38
|
-
decayPerHop: number;
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Result for a single query evaluation.
|
|
42
|
-
*/
|
|
43
|
-
export interface HopQueryEvaluation {
|
|
44
|
-
sourceChunkId: string;
|
|
45
|
-
projectSlug: string;
|
|
46
|
-
/** Hop distances of relevant (positive) edges */
|
|
47
|
-
relevantHops: number[];
|
|
48
|
-
/** All candidate hop distances */
|
|
49
|
-
allHops: number[];
|
|
50
|
-
reciprocalRank: number;
|
|
51
|
-
firstRelevantRank: number;
|
|
52
|
-
/** Direction of traversal */
|
|
53
|
-
direction: 'backward' | 'forward';
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Result for a decay shape experiment.
|
|
57
|
-
*/
|
|
58
|
-
export interface HopDecayShapeResult {
|
|
59
|
-
configId: string;
|
|
60
|
-
configName: string;
|
|
61
|
-
direction: 'backward' | 'forward';
|
|
62
|
-
mrr: number;
|
|
63
|
-
queryCount: number;
|
|
64
|
-
rankDistribution: {
|
|
65
|
-
rank1: number;
|
|
66
|
-
rank2_5: number;
|
|
67
|
-
rank6_10: number;
|
|
68
|
-
rank11_plus: number;
|
|
69
|
-
};
|
|
70
|
-
stratifiedMRR: {
|
|
71
|
-
near: number;
|
|
72
|
-
medium: number;
|
|
73
|
-
far: number;
|
|
74
|
-
};
|
|
75
|
-
stratifiedCounts: {
|
|
76
|
-
near: number;
|
|
77
|
-
medium: number;
|
|
78
|
-
far: number;
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
/**
|
|
82
|
-
* Combined results for all shapes.
|
|
83
|
-
*/
|
|
84
|
-
export interface HopDecayShapeResults {
|
|
85
|
-
generatedAt: string;
|
|
86
|
-
edgeCount: number;
|
|
87
|
-
results: HopDecayShapeResult[];
|
|
88
|
-
bestBackwardId: string;
|
|
89
|
-
bestForwardId: string;
|
|
90
|
-
bestFarBackwardId: string;
|
|
91
|
-
bestFarForwardId: string;
|
|
92
|
-
}
|
|
93
|
-
/**
|
|
94
|
-
* Hop bin boundaries.
|
|
95
|
-
*/
|
|
96
|
-
export declare const HOP_BIN_BOUNDARIES: {
|
|
97
|
-
near: {
|
|
98
|
-
min: number;
|
|
99
|
-
max: number;
|
|
100
|
-
};
|
|
101
|
-
medium: {
|
|
102
|
-
min: number;
|
|
103
|
-
max: number;
|
|
104
|
-
};
|
|
105
|
-
far: {
|
|
106
|
-
min: number;
|
|
107
|
-
max: number;
|
|
108
|
-
};
|
|
109
|
-
};
|
|
110
|
-
export type HopBin = 'near' | 'medium' | 'far';
|
|
111
|
-
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/eval/experiments/vector-decay-shapes/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH;;GAEG;AACH,MAAM,MAAM,YAAY,GAAG,aAAa,GAAG,QAAQ,GAAG,gBAAgB,GAAG,cAAc,CAAC;AAExF;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,YAAY,CAAC;IACnB,8BAA8B;IAC9B,aAAa,EAAE,MAAM,CAAC;IACtB,6DAA6D;IAC7D,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,0DAA0D;IAC1D,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,6DAA6D;IAC7D,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,uCAAuC;IACvC,KAAK,CAAC,EAAE,YAAY,EAAE,CAAC;IACvB,4CAA4C;IAC5C,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,aAAa,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE,MAAM,CAAC;IACpB,iDAAiD;IACjD,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,kCAAkC;IAClC,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,cAAc,EAAE,MAAM,CAAC;IACvB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,6BAA6B;IAC7B,SAAS,EAAE,UAAU,GAAG,SAAS,CAAC;CACnC;AAED;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,UAAU,GAAG,SAAS,CAAC;IAClC,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,EAAE,MAAM,CAAC;IACnB,gBAAgB,EAAE;QAChB,KAAK,EAAE,MAAM,CAAC;QACd,OAAO,EAAE,MAAM,CAAC;QAChB,QAAQ,EAAE,MAAM,CAAC;QACjB,WAAW,EAAE,MAAM,CAAC;KACrB,CAAC;IACF,aAAa,EAAE;QACb,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;QACf,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;IACF,gBAAgB,EAAE;QAChB,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;QACf,GAAG,EAAE,MAAM,CAAC;KACb,CAAC;CACH;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,mBAAmB,EAAE,CAAC;IAC/B,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED;;GAEG;AACH,eAAO,MAAM,kBAAkB;;;;;;;;;;;;;CAI9B,CAAC;AAEF,MAAM,MAAM,MAAM,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,CAAC"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Types for vector decay shape experiments.
|
|
3
|
-
*
|
|
4
|
-
* Tests different decay curve shapes using hop count (D-T-D cycles)
|
|
5
|
-
* instead of wall-clock time.
|
|
6
|
-
*/
|
|
7
|
-
/**
|
|
8
|
-
* Hop bin boundaries.
|
|
9
|
-
*/
|
|
10
|
-
export const HOP_BIN_BOUNDARIES = {
|
|
11
|
-
near: { min: 0, max: 3 },
|
|
12
|
-
medium: { min: 4, max: 7 },
|
|
13
|
-
far: { min: 8, max: Infinity },
|
|
14
|
-
};
|
|
15
|
-
//# sourceMappingURL=types.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/eval/experiments/vector-decay-shapes/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAgGH;;GAEG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,IAAI,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;IACxB,MAAM,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE;IAC1B,GAAG,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE;CAC/B,CAAC"}
|