{ "summary": { "timestamp": "2026-02-10 12:46:47", "source": "src", "k": 10, "coarse_k": 100, "query_count": 7, "avg_jaccard_topk": 0.11350467619264612, "avg_rbo_topk": 0.09062624799510204, "staged": { "success": 7, "avg_latency_ms": 5670.9065000244545 }, "dense_rerank": { "success": 7, "avg_latency_ms": 3047.475757143327 } }, "comparisons": [ { "query": "class Config", "staged": { "strategy": "staged", "query": "class Config", "latency_ms": 2971.5892000496387, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\path_mapper.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\api\\references.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\index_tree.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\api\\semantic.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\lsp\\server.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\parsers\\factory.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\__init__.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\chain_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\watcher\\file_watcher.py" ], "stage_stats": { "stage_times": { "stage1_binary_ms": 108.11758041381836, "stage1_fallback_search_ms": 230.96132278442383, "stage2_expand_ms": 18.60976219177246, "stage3_cluster_ms": 1.100301742553711, "stage4_rerank_ms": 2528.761625289917 }, "stage_counts": { "stage1_candidates": 37, "stage1_fallback_used": 1, "stage2_expanded": 86, "stage2_unique_paths": 53, "stage2_duplicate_paths": 33, "stage3_clustered": 20, "stage3_strategy": "dir_rr", "stage4_reranked": 20 } }, "error": null }, "dense_rerank": { "strategy": "dense_rerank", "query": "class Config", "latency_ms": 2937.113800019026, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\dir_index.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\chunker.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\vector_store.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\query_parser.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\code_extractor.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\embedding_manager.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\migration_manager.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\registry.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\sqlite_store.py" ], "stage_stats": null, "error": null }, "jaccard_topk": 0.05263157894736842, "rbo_topk": 0.014635885139999999, "staged_unique_files_topk": 10, "dense_unique_files_topk": 10, "staged_unique_dirs_topk": 8, "dense_unique_dirs_topk": 4 }, { "query": "def search", "staged": { "strategy": "staged", "query": "def search", "latency_ms": 10065.153400033712, "num_results": 3, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\entities.py" ], "stage_stats": { "stage_times": { "stage1_binary_ms": 127.17461585998535, "stage2_expand_ms": 7361.833810806274, "stage3_cluster_ms": 0.001430511474609375, "stage4_rerank_ms": 2472.7542400360107 }, "stage_counts": { "stage1_candidates": 3, "stage2_expanded": 4, "stage2_unique_paths": 3, "stage2_duplicate_paths": 1, "stage3_clustered": 4, "stage3_strategy": "dir_rr", "stage4_reranked": 4 } }, "error": null }, "dense_rerank": { "strategy": "dense_rerank", "query": "def search", "latency_ms": 3059.5018000006676, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\query_parser.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\vector_store.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\hybrid_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\index_tree.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\registry.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\dir_index.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\code_extractor.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\chain_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\chunker.py" ], "stage_stats": null, "error": null }, "jaccard_topk": 0.09090909090909091, "rbo_topk": 0.23541639942571424, "staged_unique_files_topk": 2, "dense_unique_files_topk": 10, "staged_unique_dirs_topk": 2, "dense_unique_dirs_topk": 4 }, { "query": "LspBridge", "staged": { "strategy": "staged", "query": "LspBridge", "latency_ms": 5557.314100056887, "num_results": 7, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\hybrid_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\lsp\\keepalive_bridge.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\chain_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\lsp\\lsp_bridge.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\lsp\\lsp_graph_builder.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\lsp\\__init__.py" ], "stage_stats": { "stage_times": { "stage1_binary_ms": 133.9263916015625, "stage1_fallback_search_ms": 242.1243190765381, "stage2_expand_ms": 2106.602430343628, "stage3_cluster_ms": 0.47016143798828125, "stage4_rerank_ms": 2967.3829078674316 }, "stage_counts": { "stage1_candidates": 5, "stage1_fallback_used": 1, "stage2_expanded": 31, "stage2_unique_paths": 11, "stage2_duplicate_paths": 20, "stage3_clustered": 20, "stage3_strategy": "dir_rr", "stage4_reranked": 20 } }, "error": null }, "dense_rerank": { "strategy": "dense_rerank", "query": "LspBridge", "latency_ms": 3157.7918999791145, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\vector_meta_store.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\graph_expander.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\registry.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\hybrid_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\dir_index.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\index_tree.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\sqlite_store.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\code_extractor.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\chunker.py" ], "stage_stats": null, "error": null }, "jaccard_topk": 0.06666666666666667, "rbo_topk": 0.045191399425714276, "staged_unique_files_topk": 6, "dense_unique_files_topk": 10, "staged_unique_dirs_topk": 2, "dense_unique_dirs_topk": 4 }, { "query": "graph expansion", "staged": { "strategy": "staged", "query": "graph expansion", "latency_ms": 5458.670999974012, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\migrations\\migration_007_add_graph_neighbors.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\dir_index.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\lsp\\lsp_graph_builder.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\ann_index.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\config.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\graph_expander.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\hybrid_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\enrichment.py" ], "stage_stats": { "stage_times": { "stage1_binary_ms": 113.62957954406738, "stage1_fallback_search_ms": 204.56886291503906, "stage2_expand_ms": 2166.4509773254395, "stage3_cluster_ms": 0.0011920928955078125, "stage4_rerank_ms": 2872.969627380371 }, "stage_counts": { "stage1_candidates": 11, "stage1_fallback_used": 1, "stage2_expanded": 16, "stage2_unique_paths": 13, "stage2_duplicate_paths": 3, "stage3_clustered": 16, "stage3_strategy": "dir_rr", "stage4_reranked": 16 } }, "error": null }, "dense_rerank": { "strategy": "dense_rerank", "query": "graph expansion", "latency_ms": 2896.5341999828815, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\index_tree.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\migration_manager.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\hybrid_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\chain_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\global_index.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\dir_index.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\registry.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\sqlite_store.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\vector_store.py" ], "stage_stats": null, "error": null }, "jaccard_topk": 0.1875, "rbo_topk": 0.06134116970571428, "staged_unique_files_topk": 9, "dense_unique_files_topk": 10, "staged_unique_dirs_topk": 7, "dense_unique_dirs_topk": 4 }, { "query": "clustering strategy", "staged": { "strategy": "staged", "query": "clustering strategy", "latency_ms": 5028.861099988222, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\config.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\__init__.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\chain_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\clustering\\noop_strategy.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\clustering\\dbscan_strategy.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\clustering\\base.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\clustering\\hdbscan_strategy.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\clustering\\frequency_strategy.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\clustering\\factory.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\clustering\\__init__.py" ], "stage_stats": { "stage_times": { "stage1_binary_ms": 111.71293258666992, "stage1_fallback_search_ms": 192.02208518981934, "stage2_expand_ms": 2054.065465927124, "stage3_cluster_ms": 0.0007152557373046875, "stage4_rerank_ms": 2579.0507793426514 }, "stage_counts": { "stage1_candidates": 10, "stage1_fallback_used": 1, "stage2_expanded": 10, "stage2_unique_paths": 10, "stage2_duplicate_paths": 0, "stage3_clustered": 10, "stage3_strategy": "dir_rr", "stage4_reranked": 10 } }, "error": null }, "dense_rerank": { "strategy": "dense_rerank", "query": "clustering strategy", "latency_ms": 3627.1755999922752, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\index_tree.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\hybrid_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\code_extractor.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\vector_store.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\__init__.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\gpu_support.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\chain_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\enrichment.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\chunker.py" ], "stage_stats": null, "error": null }, "jaccard_topk": 0.1111111111111111, "rbo_topk": 0.04670528456571428, "staged_unique_files_topk": 10, "dense_unique_files_topk": 10, "staged_unique_dirs_topk": 3, "dense_unique_dirs_topk": 4 }, { "query": "error handling", "staged": { "strategy": "staged", "query": "error handling", "latency_ms": 5114.356300055981, "num_results": 6, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\lsp\\lsp_bridge.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\gpu_support.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\rotational_embedder.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\watcher\\manager.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py" ], "stage_stats": { "stage_times": { "stage1_binary_ms": 135.76626777648926, "stage1_fallback_search_ms": 211.12942695617676, "stage2_expand_ms": 2151.059150695801, "stage3_cluster_ms": 0.00095367431640625, "stage4_rerank_ms": 2519.892692565918 }, "stage_counts": { "stage1_candidates": 5, "stage1_fallback_used": 1, "stage2_expanded": 13, "stage2_unique_paths": 6, "stage2_duplicate_paths": 7, "stage3_clustered": 13, "stage3_strategy": "dir_rr", "stage4_reranked": 13 } }, "error": null }, "dense_rerank": { "strategy": "dense_rerank", "query": "error handling", "latency_ms": 2853.594000041485, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\__init__.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\registry.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\hybrid_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\index_tree.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\dir_index.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\chain_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\chunker.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\code_extractor.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\embedding_manager.py" ], "stage_stats": null, "error": null }, "jaccard_topk": 0.07142857142857142, "rbo_topk": 0.045191399425714276, "staged_unique_files_topk": 5, "dense_unique_files_topk": 10, "staged_unique_dirs_topk": 4, "dense_unique_dirs_topk": 4 }, { "query": "how to parse json", "staged": { "strategy": "staged", "query": "how to parse json", "latency_ms": 5500.400400012732, "num_results": 7, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\lsp\\standalone_manager.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\hybrid_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\chain_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\parsers\\factory.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\indexing\\symbol_extractor.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\parsers\\treesitter_parser.py" ], "stage_stats": { "stage_times": { "stage1_binary_ms": 96.66872024536133, "stage1_fallback_search_ms": 176.37205123901367, "stage2_expand_ms": 2137.751340866089, "stage3_cluster_ms": 0.00095367431640625, "stage4_rerank_ms": 2991.840124130249 }, "stage_counts": { "stage1_candidates": 4, "stage1_fallback_used": 1, "stage2_expanded": 9, "stage2_unique_paths": 7, "stage2_duplicate_paths": 2, "stage3_clustered": 9, "stage3_strategy": "dir_rr", "stage4_reranked": 9 } }, "error": null }, "dense_rerank": { "strategy": "dense_rerank", "query": "how to parse json", "latency_ms": 2800.6189999878407, "num_results": 10, "topk_paths": [ "d:\\claude_dms3\\codex-lens\\src\\codexlens\\cli\\commands.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\chain_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\index_tree.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\code_extractor.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\dir_index.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\hybrid_search.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\search\\ranking.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\chunker.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\storage\\sqlite_store.py", "d:\\claude_dms3\\codex-lens\\src\\codexlens\\semantic\\ann_index.py" ], "stage_stats": null, "error": null }, "jaccard_topk": 0.21428571428571427, "rbo_topk": 0.18590219827714285, "staged_unique_files_topk": 7, "dense_unique_files_topk": 10, "staged_unique_dirs_topk": 5, "dense_unique_dirs_topk": 4 } ] }