{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3984513a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import re\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "3226b95e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import csv\n",
    "import logging\n",
    "from typing import Dict, List, Tuple\n",
    "\n",
    "import numpy as np\n",
    "import pytrec_eval\n",
    "\n",
    "def evaluate(\n",
    "    qrels: Dict[str, Dict[str, int]],\n",
    "    results: Dict[str, Dict[str, float]],\n",
    "    k_values: List[int],\n",
    ") -> Tuple[Dict[str, float], Dict[str, float], Dict[str, float], Dict[str, float]]:\n",
    "    \"\"\"\n",
    "    仿照 beir.retrieval.evaluation.EvaluateRetrieval.evaluate 编写的评估函数。\n",
    "    \"\"\"\n",
    "    ndcg = {}\n",
    "    _map = {}\n",
    "    recall = {}\n",
    "    precision = {}\n",
    "\n",
    "    for k in k_values:\n",
    "        ndcg[f\"NDCG@{k}\"] = 0.0\n",
    "        _map[f\"MAP@{k}\"] = 0.0\n",
    "        recall[f\"Recall@{k}\"] = 0.0\n",
    "        precision[f\"P@{k}\"] = 0.0\n",
    "\n",
    "    map_string = \"map_cut.\" + \",\".join([str(k) for k in k_values])\n",
    "    ndcg_string = \"ndcg_cut.\" + \",\".join([str(k) for k in k_values])\n",
    "    recall_string = \"recall.\" + \",\".join([str(k) for k in k_values])\n",
    "    precision_string = \"P.\" + \",\".join([str(k) for k in k_values])\n",
    "    evaluator = pytrec_eval.RelevanceEvaluator(\n",
    "        qrels, {map_string, ndcg_string, recall_string, precision_string}\n",
    "    )\n",
    "    scores = evaluator.evaluate(results)\n",
    "\n",
    "    for query_id in scores.keys():\n",
    "        for k in k_values:\n",
    "            ndcg[f\"NDCG@{k}\"] += scores[query_id][\"ndcg_cut_\" + str(k)]\n",
    "            _map[f\"MAP@{k}\"] += scores[query_id][\"map_cut_\" + str(k)]\n",
    "            recall[f\"Recall@{k}\"] += scores[query_id][\"recall_\" + str(k)]\n",
    "            precision[f\"P@{k}\"] += scores[query_id][\"P_\" + str(k)]\n",
    "\n",
    "    for k in k_values:\n",
    "        ndcg[f\"NDCG@{k}\"] = round(ndcg[f\"NDCG@{k}\"] / len(scores), 5)\n",
    "        _map[f\"MAP@{k}\"] = round(_map[f\"MAP@{k}\"] / len(scores), 5)\n",
    "        recall[f\"Recall@{k}\"] = round(recall[f\"Recall@{k}\"] / len(scores), 5)\n",
    "        precision[f\"P@{k}\"] = round(precision[f\"P@{k}\"] / len(scores), 5)\n",
    "\n",
    "    # for eval_metric in [ndcg, _map, recall, precision]:\n",
    "    #     logging.info(\"\\n\")\n",
    "    #     for k, v in eval_metric.items():\n",
    "    #         logging.info(f\"{k}: {v:.4f}\")\n",
    "\n",
    "    return recall\n",
    "\n",
    "\n",
    "def load_gt(gt_path: str) -> Dict[str, Dict[str, int]]:\n",
    "    \"\"\"\n",
    "    加载 ground-truth npy 文件并转换为 pytrec_eval 所需的 qrels 格式。\n",
    "    查询ID将使用其在npy文件中的索引（0, 1, 2, ...）。\n",
    "    \"\"\"\n",
    "    gt_data = np.load(gt_path, allow_pickle=True)\n",
    "    gt_data = gt_data.reshape(-1, 1)\n",
    "    # gt_data = gt_data[:1000]\n",
    "    qrels = {}\n",
    "    for i, gt_list in enumerate(gt_data):\n",
    "        query_id = str(i)\n",
    "        qrels[query_id] = {}\n",
    "        for passage_id in gt_list:\n",
    "            qrels[query_id][str(passage_id)] = 1  # 假设相关性得分为1\n",
    "    return qrels\n",
    "\n",
    "\n",
    "def load_results(results_path: str) -> Dict[str, Dict[str, float]]:\n",
    "    \"\"\"\n",
    "    加载检索结果的tsv文件并转换为 pytrec_eval 所需的 results 格式。\n",
    "    - 如果文件有4列 (query_id, passage_id, rank, score)，则使用第四列的分数。\n",
    "    - 如果文件只有3列 (query_id, passage_id, rank)，则使用 1/rank 作为分数。\n",
    "    \"\"\"\n",
    "    results = {}\n",
    "    with open(results_path, \"r\", encoding=\"utf-8\") as f:\n",
    "        reader = csv.reader(f, delimiter=\"\\t\")\n",
    "        for row in reader:\n",
    "            if not row: continue # Skip empty lines\n",
    "\n",
    "            query_id, passage_id = row[0], row[1]\n",
    "            \n",
    "            if query_id not in results:\n",
    "                results[query_id] = {}\n",
    "            \n",
    "            # 判断使用真实分数还是生成代理分数\n",
    "            if len(row) == 4:\n",
    "                score = float(row[3])\n",
    "            elif len(row) == 3:\n",
    "                rank = int(row[2])\n",
    "                score = 1.0 / rank\n",
    "            else:\n",
    "                logging.warning(f\"Skipping malformed line with {len(row)} columns: {row}\")\n",
    "                continue\n",
    "            \n",
    "            results[query_id][passage_id] = score\n",
    "            \n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "e7ba3ccd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found 20 files for dataset 'clip-multi-clustering-IGP':\n",
      "\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_1000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_1000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_10000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_1000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_10000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_100000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_1000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_10000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_1000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_10000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_100000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_1000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_10000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_100000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_2000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_20000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_200000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_2000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_20000.tsv\n",
      "/data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_200000.tsv\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "\n",
    "# Base directory\n",
    "base_dir = \"/data/lijunlin/sigmod2025-results/answer\"\n",
    "\n",
    "# Dataset keyword to filter by (e.g., \"clip\", \"clerc\", \"multiqa_med\")\n",
    "dataset_keyword = \"clip-multi-clustering-IGP\"\n",
    "\n",
    "# Collect full paths for matching files\n",
    "matching_paths = [\n",
    "    os.path.join(base_dir, f)\n",
    "    for f in os.listdir(base_dir)\n",
    "    if f.startswith(dataset_keyword + \"-\") and f.endswith(\".tsv\")\n",
    "]\n",
    "\n",
    "# Print results\n",
    "if matching_paths:\n",
    "    print(f\"Found {len(matching_paths)} files for dataset '{dataset_keyword}':\\n\")\n",
    "    for path in sorted(matching_paths):\n",
    "        print(path)\n",
    "else:\n",
    "    print(f\"No files found for dataset '{dataset_keyword}'.\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "e842b785",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-10-18 01:55:09 - Loading ground-truth file /home/ali/hnswlib/evaluation/clerc_gt.npy...\n",
      "2025-10-18 01:55:10 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_1000.tsv ...\n",
      "2025-10-18 01:55:10 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_1000.tsv\n",
      "2025-10-18 01:55:10 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_1000.tsv ...\n",
      "2025-10-18 01:55:10 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_1000.tsv\n",
      "2025-10-18 01:55:10 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_10000.tsv ...\n",
      "2025-10-18 01:55:10 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_256-probe_topk_10000.tsv\n",
      "2025-10-18 01:55:10 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_1000.tsv ...\n",
      "2025-10-18 01:55:11 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_1000.tsv\n",
      "2025-10-18 01:55:11 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_10000.tsv ...\n",
      "2025-10-18 01:55:11 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_10000.tsv\n",
      "2025-10-18 01:55:11 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_100000.tsv ...\n",
      "2025-10-18 01:55:11 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_16384-n_bit_2-nprobe_32-probe_topk_100000.tsv\n",
      "2025-10-18 01:55:11 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_1000.tsv ...\n",
      "2025-10-18 01:55:11 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_1000.tsv\n",
      "2025-10-18 01:55:11 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_10000.tsv ...\n",
      "2025-10-18 01:55:12 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_1024-probe_topk_10000.tsv\n",
      "2025-10-18 01:55:12 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_1000.tsv ...\n",
      "2025-10-18 01:55:12 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_1000.tsv\n",
      "2025-10-18 01:55:12 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_10000.tsv ...\n",
      "2025-10-18 01:55:12 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_10000.tsv\n",
      "2025-10-18 01:55:12 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_100000.tsv ...\n",
      "2025-10-18 01:55:12 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_256-probe_topk_100000.tsv\n",
      "2025-10-18 01:55:12 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_1000.tsv ...\n",
      "2025-10-18 01:55:12 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_1000.tsv\n",
      "2025-10-18 01:55:12 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_10000.tsv ...\n",
      "2025-10-18 01:55:13 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_10000.tsv\n",
      "2025-10-18 01:55:13 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_100000.tsv ...\n",
      "2025-10-18 01:55:13 - ✅ Finished evaluating clip-multi-clustering-IGP-top10-n_centroid_32768-n_bit_4-nprobe_32-probe_topk_100000.tsv\n",
      "2025-10-18 01:55:13 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_2000.tsv ...\n",
      "2025-10-18 01:55:13 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_2000.tsv\n",
      "2025-10-18 01:55:13 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_20000.tsv ...\n",
      "2025-10-18 01:55:13 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_20000.tsv\n",
      "2025-10-18 01:55:13 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_200000.tsv ...\n",
      "2025-10-18 01:55:14 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_1024-probe_topk_200000.tsv\n",
      "2025-10-18 01:55:14 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_2000.tsv ...\n",
      "2025-10-18 01:55:14 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_2000.tsv\n",
      "2025-10-18 01:55:14 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_20000.tsv ...\n",
      "2025-10-18 01:55:14 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_20000.tsv\n",
      "2025-10-18 01:55:14 - Evaluating results file: /data/lijunlin/sigmod2025-results/answer/clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_200000.tsv ...\n",
      "2025-10-18 01:55:15 - ✅ Finished evaluating clip-multi-clustering-IGP-top100-n_centroid_16384-n_bit_2-nprobe_128-probe_topk_200000.tsv\n",
      "2025-10-18 01:55:15 - 🎯 All evaluations completed.\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import logging\n",
    "\n",
    "# --- Logging setup ---\n",
    "logging.basicConfig(\n",
    "    format=\"%(asctime)s - %(message)s\",\n",
    "    datefmt=\"%Y-%m-%d %H:%M:%S\",\n",
    "    level=logging.INFO,\n",
    ")\n",
    "\n",
    "# --- Ground-truth file ---\n",
    "GT_FILE_PATH = \"/home/ali/hnswlib/evaluation/clerc_gt.npy\"\n",
    "\n",
    "# --- Base results folder ---\n",
    "BASE_RESULTS_DIR = \"/data/lijunlin/sigmod2025-results/answer\"\n",
    "\n",
    "# --- Dataset filter ---\n",
    "DATASET_KEYWORD = \"clip-multi-clustering-IGP\"  # Change to e.g. \"clerc\", \"multiqa_med\", etc.\n",
    "\n",
    "# --- Evaluation parameters ---\n",
    "K_VALUES = [10]\n",
    "\n",
    "# --- Your existing functions (assumed imported) ---\n",
    "# from your_module import load_gt, load_results, evaluate\n",
    "\n",
    "# --- Step 1: Collect all matching result files ---\n",
    "result_paths = [\n",
    "    os.path.join(BASE_RESULTS_DIR, f)\n",
    "    for f in os.listdir(BASE_RESULTS_DIR)\n",
    "    if f.startswith(DATASET_KEYWORD + \"-\") and f.endswith(\".tsv\")\n",
    "]\n",
    "\n",
    "if not result_paths:\n",
    "    logging.warning(f\"No result files found for dataset '{DATASET_KEYWORD}'.\")\n",
    "    exit()\n",
    "\n",
    "# --- Step 2: Load GT once ---\n",
    "logging.info(f\"Loading ground-truth file {GT_FILE_PATH}...\")\n",
    "qrels_data = load_gt(GT_FILE_PATH)\n",
    "\n",
    "# --- Step 3: Iterate over all result files ---\n",
    "for path in sorted(result_paths):\n",
    "    logging.info(f\"Evaluating results file: {path} ...\")\n",
    "    try:\n",
    "        results_data = load_results(path)\n",
    "        evaluate(qrels=qrels_data, results=results_data, k_values=K_VALUES)\n",
    "        logging.info(f\"✅ Finished evaluating {os.path.basename(path)}\")\n",
    "    except Exception as e:\n",
    "        logging.error(f\"❌ Failed to evaluate {path}: {e}\")\n",
    "\n",
    "logging.info(\"🎯 All evaluations completed.\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "71f13dfe",
   "metadata": {},
   "outputs": [],
   "source": [
    "algorithms = [\"IGP\", \"Dessert\", \"Plaid\", \"MUVERA\", \"Multi-HNSW\", \"HNSW-D\", \"C-Multi-HNSW\"]\n",
    "datasets = [\"DBpedia-entity\", \"CLERC\", \"CLEF\", \"MultiModalQA\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "a3cdff95",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_425683/2749718256.py:76: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_425683/2749718256.py:76: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_425683/2749718256.py:76: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_425683/2749718256.py:76: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_425683/2749718256.py:76: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
      "/tmp/ipykernel_425683/2749718256.py:76: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>QPS</th>\n",
       "      <th>Dataset</th>\n",
       "      <th>Recall</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>1.145095</td>\n",
       "      <td>CLERC</td>\n",
       "      <td>0.094</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>0.800839</td>\n",
       "      <td>CLERC</td>\n",
       "      <td>0.105</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>0.419865</td>\n",
       "      <td>CLERC</td>\n",
       "      <td>0.193</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>1.623482</td>\n",
       "      <td>CLERC</td>\n",
       "      <td>0.035</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>0.860585</td>\n",
       "      <td>CLERC</td>\n",
       "      <td>0.108</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>MVR-HNSW</td>\n",
       "      <td>1.064294</td>\n",
       "      <td>CLERC</td>\n",
       "      <td>0.087</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  Algorithm       QPS Dataset  Recall\n",
       "0  MVR-HNSW  1.145095   CLERC   0.094\n",
       "1  MVR-HNSW  0.800839   CLERC   0.105\n",
       "2  MVR-HNSW  0.419865   CLERC   0.193\n",
       "3  MVR-HNSW  1.623482   CLERC   0.035\n",
       "4  MVR-HNSW  0.860585   CLERC   0.108\n",
       "5  MVR-HNSW  1.064294   CLERC   0.087"
      ]
     },
     "execution_count": 105,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "import re\n",
    "import pandas as pd\n",
    "\n",
    "# REQUIRED: you should already have these defined in your notebook\n",
    "# - qrels_data  (from your load_gt)\n",
    "# - K_VALUES    (e.g., [10])\n",
    "# - evaluate(qrels, results, k_values) -> dict of metrics (e.g., {'Recall@10': 0.736})\n",
    "\n",
    "# ----------------------------\n",
    "# Config\n",
    "# ----------------------------\n",
    "directory = \"/data/lijunlin/sigmod2025-results/multi-hnsw-result\"\n",
    "# keyword = \"clip-multi-clustering_HNSW\"\n",
    "keyword = \"clerc_HNSW\"\n",
    "# keyword = \"clef_med_HNSW\"\n",
    "# keyword = \"multiqa_med_HNSW\"\n",
    "\n",
    "# ----------------------------\n",
    "# File pairing\n",
    "# ----------------------------\n",
    "all_files = os.listdir(directory)\n",
    "txt_files = [\n",
    "    f for f in all_files\n",
    "    if f.endswith(\".txt\") and keyword in f and \"metadata\" not in f\n",
    "]\n",
    "\n",
    "file_pairs = {}\n",
    "for f in txt_files:\n",
    "    if f.endswith(\"_summary.txt\"):\n",
    "        base_name = f[:-len(\"_summary.txt\")]\n",
    "        file_pairs.setdefault(base_name, {})[\"summary\"] = os.path.join(directory, f)\n",
    "    else:\n",
    "        base_name = f[:-len(\".txt\")]\n",
    "        file_pairs.setdefault(base_name, {})[\"results\"] = os.path.join(directory, f)\n",
    "\n",
    "# ----------------------------\n",
    "# Helpers\n",
    "# ----------------------------\n",
    "def load_results_tsv(path: str) -> pd.DataFrame:\n",
    "    # Results: query_id, passage_id, rank, score (tab-separated, no header)\n",
    "    return pd.read_csv(\n",
    "        path,\n",
    "        sep=\"\\t\",\n",
    "        header=None,\n",
    "        names=[\"query_id\", \"passage_id\", \"rank\", \"score\"],\n",
    "        dtype={\"query_id\": int, \"passage_id\": int, \"rank\": int, \"score\": float}\n",
    "    )\n",
    "\n",
    "def extract_avg_retrieval_time(summary_text: str) -> float | None:\n",
    "    # Robust parser for avg retrieval time (ms)\n",
    "    patterns = [\n",
    "        r\"Average\\s+Query\\s+Time:\\s*([\\d.]+)\\s*ms\",\n",
    "        r\"Avg\\s*retrieval\\s*time\\s*[:=]\\s*([\\d.]+)\\s*ms\",\n",
    "        r\"retrieval_time_single_query_average\\(ms\\)\\s*[:=]\\s*([\\d.]+)\",\n",
    "        r\"avg.*?ms\\s*[:=]\\s*([\\d.]+)\",\n",
    "    ]\n",
    "    for pat in patterns:\n",
    "        m = re.search(pat, summary_text, flags=re.IGNORECASE)\n",
    "        if m:\n",
    "            try:\n",
    "                return float(m.group(1))\n",
    "            except ValueError:\n",
    "                pass\n",
    "    return None\n",
    "\n",
    "def df_results_to_dict(df_res: pd.DataFrame) -> dict:\n",
    "    # Drop duplicates (query, passage) keeping highest score; cast IDs to str\n",
    "    df = (\n",
    "        df_res.sort_values('score', ascending=False)\n",
    "              .drop_duplicates(['query_id', 'passage_id'])\n",
    "              .astype({'query_id': str, 'passage_id': str})\n",
    "    )\n",
    "    return (\n",
    "        df.groupby('query_id')\n",
    "          .apply(lambda g: dict(zip(g['passage_id'], g['score'])))\n",
    "          .to_dict()\n",
    "    )\n",
    "\n",
    "# ----------------------------\n",
    "# Build final DataFrame: one row per base with qps + metrics\n",
    "# ----------------------------\n",
    "rows = []\n",
    "for base, pair in file_pairs.items():\n",
    "    # Summary → avg_ms → qps\n",
    "    avg_ms = None\n",
    "    if 'summary' in pair and pair['summary']:\n",
    "        with open(pair['summary'], 'r', encoding='utf-8', errors='ignore') as f:\n",
    "            avg_ms = extract_avg_retrieval_time(f.read())\n",
    "    qps = (1000.0 / avg_ms) if (avg_ms is not None and avg_ms > 0) else None\n",
    "\n",
    "    # Results → metrics via evaluate\n",
    "    metrics = {}\n",
    "    if 'results' in pair and pair['results']:\n",
    "        df_res = load_results_tsv(pair['results'])\n",
    "        results_dict = df_results_to_dict(df_res)\n",
    "        metrics = evaluate(qrels=qrels_data, results=results_dict, k_values=K_VALUES) or {}\n",
    "\n",
    "    row = {'Algorithm': algorithms[4], 'QPS': qps, \"Dataset\": datasets[1], \"Recall\": metrics[\"Recall@10\"]}\n",
    "    # row.update(metrics)  # adds e.g. 'Recall@10', etc.\n",
    "    rows.append(row)\n",
    "\n",
    "mvrhnsw_df = pd.DataFrame(rows).reset_index(drop=True)\n",
    "mvrhnsw_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "c111e196",
   "metadata": {},
   "outputs": [],
   "source": [
    "def extract_limit(row):\n",
    "    identifier = row['Identifier']\n",
    "    name = row['Algorithm']\n",
    "    \n",
    "    # Default to None\n",
    "    match = None\n",
    "\n",
    "    if name == \"IGP\":\n",
    "        # Extract probe_topk\n",
    "        match = re.search(r'probe_topk_(\\d+)', identifier)\n",
    "    \n",
    "    if match:\n",
    "        return int(match.group(1))\n",
    "    else:\n",
    "        return 0  # If pattern not found, assume safe to keep\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "635d46e9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# --- Configuration ---\n",
    "JSON_ROOT_DIR = \"/data/lijunlin/sigmod2025-results/performance\"\n",
    "TSV_ROOT_DIR = \"/data/lijunlin/sigmod2025-results/answer/\"\n",
    "KEYWORD_JSON = \"clip-multi-clustering-retrieval-IGP\"\n",
    "KEYWORD_TSV = \"clip-multi-clustering-IGP\"\n",
    "\n",
    "# --- Find files with keyword ---\n",
    "def find_files_with_keyword(root_dir, keyword, ext):\n",
    "    matched_files = []\n",
    "    for dirpath, _, filenames in os.walk(root_dir):\n",
    "        for filename in filenames:\n",
    "            if filename.endswith(ext) and keyword in filename:\n",
    "                matched_files.append(os.path.join(dirpath, filename))\n",
    "    return matched_files\n",
    "\n",
    "# --- Load JSON file safely ---\n",
    "def load_json_file(filepath):\n",
    "    try:\n",
    "        with open(filepath, \"r\") as f:\n",
    "            return json.load(f)\n",
    "    except Exception as e:\n",
    "        logging.error(f\"Failed to read {filepath}: {e}\")\n",
    "        return None\n",
    "\n",
    "# --- Extract identifier from filename ---\n",
    "def get_identifier(filename, keyword):\n",
    "    base = os.path.basename(filename)\n",
    "    return base.replace(keyword, \"\").replace(\".json\", \"\").replace(\".tsv\", \"\")\n",
    "\n",
    "# --- Pair JSON and TSV files by shared identifier ---\n",
    "def pair_json_tsv(json_files, tsv_files, keyword_json, keyword_tsv):\n",
    "    json_map = {get_identifier(f, keyword_json): f for f in json_files}\n",
    "    tsv_map = {get_identifier(f, keyword_tsv): f for f in tsv_files}\n",
    "\n",
    "    pairs = []\n",
    "    for identifier, json_path in json_map.items():\n",
    "        if identifier in tsv_map:\n",
    "            pairs.append((identifier, json_path, tsv_map[identifier]))\n",
    "    return pairs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "bda3a584",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-10-18 01:55:57 - Processing keyword pair: JSON='clerc-retrieval-dessert', TSV='clerc-dessert' (Name='Dessert')\n",
      "2025-10-18 01:55:57 - Processing pair: -top10-n_table_64-initial_filter_k_1024-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:57 - Processing pair: -top10-n_table_512-initial_filter_k_128-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:57 - Processing pair: -top10-n_table_64-initial_filter_k_1024-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:57 - Processing pair: -top10-n_table_64-initial_filter_k_512-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:57 - Processing pair: -top10-n_table_512-initial_filter_k_128-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:58 - Processing pair: -top10-n_table_512-initial_filter_k_512-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:58 - Processing pair: -top10-n_table_512-initial_filter_k_1024-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:58 - Processing pair: -top10-n_table_64-initial_filter_k_128-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:58 - Processing pair: -top10-n_table_64-initial_filter_k_512-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:58 - Processing pair: -top10-n_table_64-initial_filter_k_128-nprobe_query_4-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:59 - Processing pair: -top10-n_table_512-initial_filter_k_1024-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:59 - Processing pair: -top10-n_table_512-initial_filter_k_512-nprobe_query_2-remove_centroid_dupes_True-n_thread_1\n",
      "2025-10-18 01:55:59 - Processing keyword pair: JSON='clerc-retrieval-plaid', TSV='clerc-plaid' (Name='Plaid')\n",
      "2025-10-18 01:55:59 - Processing pair: -top100--ndocs_800-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:55:59 - Processing pair: -top100--ndocs_1200-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:00 - Processing pair: -top10--ndocs_400-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:00 - Processing pair: -top10--ndocs_2000-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:00 - Processing pair: -top10--ndocs_200-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:00 - Processing pair: -top10--ndocs_8000-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:00 - Processing pair: -top10--ndocs_40-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:01 - Processing pair: -top10--ndocs_4000-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:01 - Processing pair: -top10--ndocs_800-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:01 - Processing pair: -top100--ndocs_400-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:01 - Processing pair: -top100--ndocs_2000-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:02 - Processing pair: -top100--ndocs_4000-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:02 - Processing pair: -top100--ndocs_200-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:02 - Processing pair: -top10--ndocs_1200-ncells_4-centroid_score_threshold_0.50-n_thread_1\n",
      "2025-10-18 01:56:02 - Processing keyword pair: JSON='clerc-retrieval-IGP', TSV='clerc-IGP' (Name='IGP')\n",
      "2025-10-18 01:56:02 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_50\n",
      "2025-10-18 01:56:03 - Processing pair: -top100-n_centroid_1024-n_bit_2-nprobe_128-probe_topk_2000\n",
      "2025-10-18 01:56:03 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_10\n",
      "2025-10-18 01:56:03 - Processing pair: -top100-n_centroid_1024-n_bit_2-nprobe_128-probe_topk_20000\n",
      "2025-10-18 01:56:03 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_500\n",
      "2025-10-18 01:56:04 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_100\n",
      "2025-10-18 01:56:04 - Processing pair: -top10-n_centroid_1024-n_bit_2-nprobe_32-probe_topk_1000\n",
      "/tmp/ipykernel_425683/490679234.py:81: FutureWarning: DataFrameGroupBy.apply operated on the grouping columns. This behavior is deprecated, and in a future version of pandas the grouping columns will be excluded from the operation. Either pass `include_groups=False` to exclude the groupings or explicitly select the grouping columns after groupby to silence this warning.\n",
      "  df_sorted = df_filtered.groupby(\"Algorithm\", group_keys=False).apply(\n"
     ]
    }
   ],
   "source": [
    "# --- Define multiple keyword pairs with names ---\n",
    "\n",
    "import json\n",
    "keyword_pairs = [\n",
    "    # (\"clip-multi-clustering-retrieval-IGP\", \"clip-multi-clustering-IGP\", \"IGP\"),\n",
    "    # (\"clip-multi-clustering-retrieval-dessert\", \"clip-multi-clustering-dessert\", \"Dessert\"),\n",
    "    # (\"clip-multi-clustering-retrieval-plaid\", \"clip-multi-clustering-plaid\", \"Plaid\"),\n",
    "\n",
    "    (\"clerc-retrieval-dessert\", \"clerc-dessert\",  \"Dessert\"),\n",
    "    (\"clerc-retrieval-plaid\",\"clerc-plaid\",  \"Plaid\"),\n",
    "    (\"clerc-retrieval-IGP\", \"clerc-IGP\", \"IGP\"),\n",
    "\n",
    "    # (\"clef_med-retrieval-dessert\", \"clef_med-dessert\",  \"Dessert\"),\n",
    "    # (\"clef_med-retrieval-plaid\",\"clef_med-plaid\",  \"Plaid\"),\n",
    "    # (\"clef_med-retrieval-IGP\", \"clef_med-IGP\", \"IGP\"),\n",
    "\n",
    "    # (\"multiqa_med-retrieval-dessert\", \"multiqa_med-dessert\",  \"Dessert\"),\n",
    "    # (\"multiqa_med-retrieval-plaid\",\"multiqa_med-plaid\",  \"Plaid\"),\n",
    "    # (\"multiqa_med-retrieval-IGP\", \"multiqa_med-IGP\", \"IGP\"),\n",
    "\n",
    "    \n",
    "    \n",
    "]\n",
    "\n",
    "all_results = []\n",
    "\n",
    "for KEYWORD_JSON, KEYWORD_TSV, name in keyword_pairs:\n",
    "\n",
    "    logging.info(f\"Processing keyword pair: JSON='{KEYWORD_JSON}', TSV='{KEYWORD_TSV}' (Name='{name}')\")\n",
    "    \n",
    "    # Find files\n",
    "    json_files = find_files_with_keyword(JSON_ROOT_DIR, KEYWORD_JSON, \".json\")\n",
    "    tsv_files = [\n",
    "        os.path.join(TSV_ROOT_DIR, f)\n",
    "        for f in os.listdir(TSV_ROOT_DIR)\n",
    "        if f.startswith(KEYWORD_TSV + \"-\") and f.endswith(\".tsv\")\n",
    "    ]\n",
    "\n",
    "    # Pair files by identifier\n",
    "    pairs = pair_json_tsv(json_files, tsv_files, KEYWORD_JSON, KEYWORD_TSV)\n",
    "\n",
    "    # Process each pair\n",
    "    for identifier, json_file, tsv_file in pairs:\n",
    "        logging.info(f\"Processing pair: {identifier}\")\n",
    "\n",
    "        data = load_json_file(json_file)\n",
    "        if data is None:\n",
    "            continue\n",
    "        \n",
    "        if name == 'IGP':\n",
    "            avg_ms = float(data['search_time']['retrieval_time_single_query_average(ms)'])\n",
    "        else:\n",
    "            avg_ms = float(data['search_time']['average_query_time_ms'])\n",
    "        qps = 1000 / avg_ms\n",
    "\n",
    "        results_data = load_results(tsv_file)\n",
    "        recall = evaluate(qrels=qrels_data, results=results_data, k_values=K_VALUES)\n",
    "\n",
    "        all_results.append({\n",
    "            \"Identifier\":identifier,\n",
    "            'Recall': recall['Recall@10'],\n",
    "            'QPS': qps,\n",
    "            'Algorithm': name,  # <-- Add name here\n",
    "            \"Dataset\": datasets[1]\n",
    "        })\n",
    "\n",
    "# Convert to DataFrame\n",
    "df_all_results = pd.DataFrame(all_results)\n",
    "\n",
    "df_all_results['limit_value'] = df_all_results.apply(extract_limit, axis=1)\n",
    "\n",
    "# Filter rows where limit_value <= 10000\n",
    "df_filtered = df_all_results[df_all_results['limit_value'] <= 200000]\n",
    "\n",
    "\n",
    "# Drop the temporary column\n",
    "df_filtered.drop(columns=['limit_value'], inplace=True)\n",
    "# df_filtered = df_all_results.copy()\n",
    "\n",
    "\n",
    "df_sorted = df_filtered.groupby(\"Algorithm\", group_keys=False).apply(\n",
    "    lambda x: x.sort_values(by=\"Recall\", ascending=True)\n",
    ")\n",
    "\n",
    "df_filtered =df_sorted"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "721d5ccb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Identifier</th>\n",
       "      <th>Recall</th>\n",
       "      <th>QPS</th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>Dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_512-nprobe_...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>19.231279</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_1024-nprobe...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>10.478064</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>-top10-n_table_512-initial_filter_k_512-nprobe...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>3.194202</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>-top10-n_table_512-initial_filter_k_128-nprobe...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>6.249412</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_128-nprobe_...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>33.134141</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_512-nprobe_...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>16.482772</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_128-nprobe_...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>27.589393</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-top10-n_table_64-initial_filter_k_1024-nprobe...</td>\n",
       "      <td>0.001</td>\n",
       "      <td>12.399150</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>-top10-n_table_512-initial_filter_k_1024-nprob...</td>\n",
       "      <td>0.002</td>\n",
       "      <td>1.982454</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>-top10-n_table_512-initial_filter_k_128-nprobe...</td>\n",
       "      <td>0.002</td>\n",
       "      <td>6.649789</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>-top10-n_table_512-initial_filter_k_1024-nprob...</td>\n",
       "      <td>0.002</td>\n",
       "      <td>2.109820</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>-top10-n_table_512-initial_filter_k_512-nprobe...</td>\n",
       "      <td>0.002</td>\n",
       "      <td>3.411940</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.007</td>\n",
       "      <td>1.838736</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.016</td>\n",
       "      <td>1.798930</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.021</td>\n",
       "      <td>1.753635</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.032</td>\n",
       "      <td>1.465193</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>-top10-n_centroid_1024-n_bit_2-nprobe_32-probe...</td>\n",
       "      <td>0.045</td>\n",
       "      <td>1.211877</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>-top100-n_centroid_1024-n_bit_2-nprobe_128-pro...</td>\n",
       "      <td>0.120</td>\n",
       "      <td>0.297235</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>-top100-n_centroid_1024-n_bit_2-nprobe_128-pro...</td>\n",
       "      <td>0.167</td>\n",
       "      <td>0.097224</td>\n",
       "      <td>IGP</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>-top10--ndocs_40-ncells_4-centroid_score_thres...</td>\n",
       "      <td>0.000</td>\n",
       "      <td>1.155965</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>-top10--ndocs_200-ncells_4-centroid_score_thre...</td>\n",
       "      <td>0.006</td>\n",
       "      <td>1.751807</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>-top100--ndocs_200-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.006</td>\n",
       "      <td>0.879879</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>-top10--ndocs_400-ncells_4-centroid_score_thre...</td>\n",
       "      <td>0.008</td>\n",
       "      <td>2.185472</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>-top100--ndocs_400-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.008</td>\n",
       "      <td>2.096542</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>-top10--ndocs_800-ncells_4-centroid_score_thre...</td>\n",
       "      <td>0.014</td>\n",
       "      <td>1.914865</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>-top100--ndocs_800-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.014</td>\n",
       "      <td>1.975800</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>-top100--ndocs_1200-ncells_4-centroid_score_th...</td>\n",
       "      <td>0.023</td>\n",
       "      <td>1.804129</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>-top10--ndocs_1200-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.023</td>\n",
       "      <td>1.843410</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>-top100--ndocs_2000-ncells_4-centroid_score_th...</td>\n",
       "      <td>0.026</td>\n",
       "      <td>1.455973</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>-top10--ndocs_2000-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.026</td>\n",
       "      <td>1.495989</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>-top10--ndocs_4000-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.039</td>\n",
       "      <td>1.274488</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>-top100--ndocs_4000-ncells_4-centroid_score_th...</td>\n",
       "      <td>0.039</td>\n",
       "      <td>1.209433</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>-top10--ndocs_8000-ncells_4-centroid_score_thr...</td>\n",
       "      <td>0.065</td>\n",
       "      <td>0.528278</td>\n",
       "      <td>Plaid</td>\n",
       "      <td>CLERC</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                           Identifier  Recall        QPS  \\\n",
       "3   -top10-n_table_64-initial_filter_k_512-nprobe_...   0.000  19.231279   \n",
       "2   -top10-n_table_64-initial_filter_k_1024-nprobe...   0.000  10.478064   \n",
       "5   -top10-n_table_512-initial_filter_k_512-nprobe...   0.000   3.194202   \n",
       "4   -top10-n_table_512-initial_filter_k_128-nprobe...   0.000   6.249412   \n",
       "7   -top10-n_table_64-initial_filter_k_128-nprobe_...   0.000  33.134141   \n",
       "8   -top10-n_table_64-initial_filter_k_512-nprobe_...   0.000  16.482772   \n",
       "9   -top10-n_table_64-initial_filter_k_128-nprobe_...   0.000  27.589393   \n",
       "0   -top10-n_table_64-initial_filter_k_1024-nprobe...   0.001  12.399150   \n",
       "6   -top10-n_table_512-initial_filter_k_1024-nprob...   0.002   1.982454   \n",
       "1   -top10-n_table_512-initial_filter_k_128-nprobe...   0.002   6.649789   \n",
       "10  -top10-n_table_512-initial_filter_k_1024-nprob...   0.002   2.109820   \n",
       "11  -top10-n_table_512-initial_filter_k_512-nprobe...   0.002   3.411940   \n",
       "28  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.007   1.838736   \n",
       "26  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.016   1.798930   \n",
       "31  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.021   1.753635   \n",
       "30  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.032   1.465193   \n",
       "32  -top10-n_centroid_1024-n_bit_2-nprobe_32-probe...   0.045   1.211877   \n",
       "27  -top100-n_centroid_1024-n_bit_2-nprobe_128-pro...   0.120   0.297235   \n",
       "29  -top100-n_centroid_1024-n_bit_2-nprobe_128-pro...   0.167   0.097224   \n",
       "18  -top10--ndocs_40-ncells_4-centroid_score_thres...   0.000   1.155965   \n",
       "16  -top10--ndocs_200-ncells_4-centroid_score_thre...   0.006   1.751807   \n",
       "24  -top100--ndocs_200-ncells_4-centroid_score_thr...   0.006   0.879879   \n",
       "14  -top10--ndocs_400-ncells_4-centroid_score_thre...   0.008   2.185472   \n",
       "21  -top100--ndocs_400-ncells_4-centroid_score_thr...   0.008   2.096542   \n",
       "20  -top10--ndocs_800-ncells_4-centroid_score_thre...   0.014   1.914865   \n",
       "12  -top100--ndocs_800-ncells_4-centroid_score_thr...   0.014   1.975800   \n",
       "13  -top100--ndocs_1200-ncells_4-centroid_score_th...   0.023   1.804129   \n",
       "25  -top10--ndocs_1200-ncells_4-centroid_score_thr...   0.023   1.843410   \n",
       "22  -top100--ndocs_2000-ncells_4-centroid_score_th...   0.026   1.455973   \n",
       "15  -top10--ndocs_2000-ncells_4-centroid_score_thr...   0.026   1.495989   \n",
       "19  -top10--ndocs_4000-ncells_4-centroid_score_thr...   0.039   1.274488   \n",
       "23  -top100--ndocs_4000-ncells_4-centroid_score_th...   0.039   1.209433   \n",
       "17  -top10--ndocs_8000-ncells_4-centroid_score_thr...   0.065   0.528278   \n",
       "\n",
       "   Algorithm Dataset  \n",
       "3    Dessert   CLERC  \n",
       "2    Dessert   CLERC  \n",
       "5    Dessert   CLERC  \n",
       "4    Dessert   CLERC  \n",
       "7    Dessert   CLERC  \n",
       "8    Dessert   CLERC  \n",
       "9    Dessert   CLERC  \n",
       "0    Dessert   CLERC  \n",
       "6    Dessert   CLERC  \n",
       "1    Dessert   CLERC  \n",
       "10   Dessert   CLERC  \n",
       "11   Dessert   CLERC  \n",
       "28       IGP   CLERC  \n",
       "26       IGP   CLERC  \n",
       "31       IGP   CLERC  \n",
       "30       IGP   CLERC  \n",
       "32       IGP   CLERC  \n",
       "27       IGP   CLERC  \n",
       "29       IGP   CLERC  \n",
       "18     Plaid   CLERC  \n",
       "16     Plaid   CLERC  \n",
       "24     Plaid   CLERC  \n",
       "14     Plaid   CLERC  \n",
       "21     Plaid   CLERC  \n",
       "20     Plaid   CLERC  \n",
       "12     Plaid   CLERC  \n",
       "13     Plaid   CLERC  \n",
       "25     Plaid   CLERC  \n",
       "22     Plaid   CLERC  \n",
       "15     Plaid   CLERC  \n",
       "19     Plaid   CLERC  \n",
       "23     Plaid   CLERC  \n",
       "17     Plaid   CLERC  "
      ]
     },
     "execution_count": 110,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_sorted"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fed41e3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# my_sorted_recall_list = [0.845,0.862,0.876,0.874,0.877,0.874,0.875,0.856,0.857,0.867,0.88]\n",
    "# my_sorted_qps_list = [774.494,745.388,719.843,695.595,719.843,695.595,646.601,566.891,489.971,422.421,334.579]\n",
    "# df_temp = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'Multi-HNSW',\n",
    "#     'Dataset': datasets[0]\n",
    "# })\n",
    "# # my_sorted_recall_list = [0.259,0.4,0.472,0.533,0.569,0.667,0.719,0.742,0.773,0.769,0.772]\n",
    "# # my_sorted_qps_list = [11179.2,8459.66,7024,7007.71,6994.57,4917.48,4624.73,3934.13,3012.67,3141.93,3082.59]\n",
    "# # df_temp2 = pd.DataFrame({\n",
    "# #     'Recall': my_sorted_recall_list,\n",
    "# #     'QPS': my_sorted_qps_list,\n",
    "# #     'Algorithm': 'SVR-HNSW',\n",
    "# #     'Dataset': 'DBpedia-entity'\n",
    "# # })\n",
    "\n",
    "# my_sorted_recall_list = [0.883,\n",
    "# 0.883,\n",
    "# 0.883,\n",
    "# 0.883,\n",
    "# 0.883,\n",
    "# 0.883,\n",
    "# 0.894,\n",
    "# 0.903,\n",
    "# 0.907,\n",
    "# 0.906,\n",
    "# 0.906]\n",
    "# my_sorted_qps_list = [381.605,\n",
    "# 384.45,\n",
    "# 380.318,\n",
    "# 373.251,\n",
    "# 377.382,\n",
    "# 378.154,\n",
    "# 311.384,\n",
    "# 265.433,\n",
    "# 213.847,\n",
    "# 178.324,\n",
    "# 147.744]\n",
    "# df_temp3 = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'C-Multi-HNSW',\n",
    "#     'Dataset': datasets[0]\n",
    "# })\n",
    "\n",
    "# df_combined = pd.concat([df_sorted, df_temp], ignore_index=True)\n",
    "# df_combined = pd.concat([df_combined, df_temp3], ignore_index=True)\n",
    "\n",
    "# df_combined = df_combined.drop(columns=['Identifier'])\n",
    "# df_combined = pd.concat([df_combined, mvrhnsw_df], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "6367cf7c",
   "metadata": {},
   "outputs": [],
   "source": [
    "my_sorted_recall_list = [0.189,0.249,0.268,0.273,0.273,0.272,0.268,0.265,0.266,0.265,0.264]\n",
    "my_sorted_qps_list = [671.14, 646.909,621.017,596.998,583.401,517.234,418.715,347.302,263.376,212.288,178.399]\n",
    "df_temp = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'Multi-HNSW',\n",
    "    'Dataset': datasets[1]\n",
    "})\n",
    "\n",
    "\n",
    "my_sorted_recall_list = [0.218,\n",
    "0.233,\n",
    "0.242,\n",
    "0.244,\n",
    "0.243,\n",
    "0.247,\n",
    "0.235,\n",
    "0.231,\n",
    "0.227,\n",
    "0.219,\n",
    "0.222]\n",
    "my_sorted_qps_list = [400.147,\n",
    "397.022,\n",
    "400.236,\n",
    "391.66,\n",
    "398.261,\n",
    "397.926,\n",
    "311.507,\n",
    "262.125,\n",
    "198.699,\n",
    "159.514,\n",
    "133.33]\n",
    "df_temp3 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'C-Multi-HNSW',\n",
    "    'Dataset': datasets[1]\n",
    "})\n",
    "\n",
    "\n",
    "# my_sorted_recall_list = [0.259,0.4,0.472,0.533,0.569,0.667,0.719,0.742,0.773,0.769,0.772]\n",
    "# my_sorted_qps_list = [11179.2,8459.66,7024,7007.71,6994.57,4917.48,4624.73,3934.13,3012.67,3141.93,3082.59]\n",
    "# df_temp2 = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'SVR-HNSW',\n",
    "#     'Dataset': 'DBpedia-entity'\n",
    "# })\n",
    "\n",
    "df_combined = pd.concat([df_sorted, df_temp], ignore_index=True)\n",
    "# df_combined = pd.concat([df_combined, df_temp2], ignore_index=True)\n",
    "df_combined = pd.concat([df_combined, df_temp3], ignore_index=True)\n",
    "df_combined = df_combined.drop(columns=['Identifier'])\n",
    "df_combined = pd.concat([df_combined, mvrhnsw_df], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ffa4077c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# my_sorted_recall_list = [0.094334,\n",
    "# 0.106585,\n",
    "# 0.108116,\n",
    "# 0.110873,\n",
    "# 0.108729,\n",
    "# 0.106585,\n",
    "# 0.107198,\n",
    "# 0.10536,\n",
    "# 0.103522,\n",
    "# 0.105054,\n",
    "# 0.104441]\n",
    "# my_sorted_qps_list = [254.493,\n",
    "# 217.65,\n",
    "# 191.319,\n",
    "# 171.775,\n",
    "# 157.915,\n",
    "# 111.928,\n",
    "# 84.1819,\n",
    "# 68.034,\n",
    "# 49.712,\n",
    "# 39.3898,\n",
    "# 32.676]\n",
    "# df_temp = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'Multi-HNSW',\n",
    "#     'Dataset': datasets[2]\n",
    "# })\n",
    "\n",
    "# my_sorted_recall_list = [0.107198,\n",
    "# 0.108423,\n",
    "# 0.108116,\n",
    "# 0.108116,\n",
    "# 0.10781,\n",
    "# 0.10781,\n",
    "# 0.10536,\n",
    "# 0.105972,\n",
    "# 0.104747,\n",
    "# 0.105972,\n",
    "# 0.105972]\n",
    "# my_sorted_qps_list = [ 109.379,\n",
    "# 109.121,\n",
    "# 108.866,\n",
    "# 109.753,\n",
    "# 109.11,\n",
    "# 109.069,\n",
    "# 83.1861,\n",
    "# 68.3078,\n",
    "# 50.4555,\n",
    "# 40.2429,\n",
    "# 33.6657]\n",
    "# df_temp3 = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'C-Multi-HNSW',\n",
    "#     'Dataset': datasets[2]\n",
    "# })\n",
    "# # my_sorted_recall_list = [0.259,0.4,0.472,0.533,0.569,0.667,0.719,0.742,0.773,0.769,0.772]\n",
    "# # my_sorted_qps_list = [11179.2,8459.66,7024,7007.71,6994.57,4917.48,4624.73,3934.13,3012.67,3141.93,3082.59]\n",
    "# # df_temp2 = pd.DataFrame({\n",
    "# #     'Recall': my_sorted_recall_list,\n",
    "# #     'QPS': my_sorted_qps_list,\n",
    "# #     'Algorithm': 'SVR-HNSW',\n",
    "# #     'Dataset': 'DBpedia-entity'\n",
    "# # })\n",
    "\n",
    "# df_combined = pd.concat([df_sorted, df_temp], ignore_index=True)\n",
    "# df_combined = pd.concat([df_combined, df_temp3], ignore_index=True)\n",
    "\n",
    "# df_combined = df_combined.drop(columns=['Identifier'])\n",
    "# df_combined = pd.concat([df_combined, mvrhnsw_df], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df47a660",
   "metadata": {},
   "outputs": [],
   "source": [
    "# my_sorted_recall_list = [0.332871,\n",
    "# 0.446602,\n",
    "# 0.493759,\n",
    "# 0.542302,\n",
    "# 0.568655,\n",
    "# 0.619972,\n",
    "# 0.654646,\n",
    "# 0.665742,\n",
    "# 0.690707,\n",
    "# 0.704577,\n",
    "# 0.712899]\n",
    "# my_sorted_qps_list = [3011.38,\n",
    "# 2994.4,\n",
    "# 2988.48,\n",
    "# 2958.11,\n",
    "# 2953.91,\n",
    "# 2844.78,\n",
    "# 2183.13,\n",
    "# 1724.73,\n",
    "# 1243.56,\n",
    "# 959.874,\n",
    "# 786.005]\n",
    "# df_temp = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'Multi-HNSW',\n",
    "#     'Dataset': datasets[3]\n",
    "# })\n",
    "\n",
    "# my_sorted_recall_list = [0.582524,\n",
    "# 0.582524,\n",
    "# 0.582524,\n",
    "# 0.582524,\n",
    "# 0.582524,\n",
    "# 0.582524,\n",
    "# 0.619972,\n",
    "# 0.642164,\n",
    "# 0.676838,\n",
    "# 0.699029,\n",
    "# 0.705964]\n",
    "# my_sorted_qps_list = [3841.54,\n",
    "# 3814.86,\n",
    "# 3819.65,\n",
    "# 3839.44,\n",
    "# 3840.52,\n",
    "# 3849.48,\n",
    "# 3000.94,\n",
    "# 2411.13,\n",
    "# 1783.53,\n",
    "# 1404.93,\n",
    "# 1172.06]\n",
    "# df_temp3 = pd.DataFrame({\n",
    "#     'Recall': my_sorted_recall_list,\n",
    "#     'QPS': my_sorted_qps_list,\n",
    "#     'Algorithm': 'C-Multi-HNSW',\n",
    "#     'Dataset': datasets[3]\n",
    "# })\n",
    "# # my_sorted_recall_list = [0.259,0.4,0.472,0.533,0.569,0.667,0.719,0.742,0.773,0.769,0.772]\n",
    "# # my_sorted_qps_list = [11179.2,8459.66,7024,7007.71,6994.57,4917.48,4624.73,3934.13,3012.67,3141.93,3082.59]\n",
    "# # df_temp2 = pd.DataFrame({\n",
    "# #     'Recall': my_sorted_recall_list,\n",
    "# #     'QPS': my_sorted_qps_list,\n",
    "# #     'Algorithm': 'SVR-HNSW',\n",
    "# #     'Dataset': 'DBpedia-entity'\n",
    "# # })\n",
    "\n",
    "# df_combined = pd.concat([df_sorted, df_temp], ignore_index=True)\n",
    "# df_combined = pd.concat([df_combined, df_temp3], ignore_index=True)\n",
    "\n",
    "# df_combined = df_combined.drop(columns=['Identifier'])\n",
    "# df_combined = pd.concat([df_combined, mvrhnsw_df], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "53703b17",
   "metadata": {},
   "outputs": [],
   "source": [
    "my_sorted_recall_list = [0.15, 0.158, 0.19]\n",
    "my_sorted_qps_list = [191.21, 121.1, 89.08]\n",
    "df_temp = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'MUVERA',\n",
    "    'Dataset': datasets[0]\n",
    "})\n",
    "\n",
    "my_sorted_recall_list = [0.08, 0.10, 0.11]\n",
    "my_sorted_qps_list = [170.21, 122.2, 100.16]\n",
    "df_temp1 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'MUVERA',\n",
    "    'Dataset': datasets[1]\n",
    "})\n",
    "\n",
    "\n",
    "my_sorted_recall_list = [0.01, 0.015, 0.02]\n",
    "my_sorted_qps_list = [130.21, 81.1, 60.08]\n",
    "df_temp2 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'MUVERA',\n",
    "    'Dataset': datasets[2]\n",
    "})\n",
    "\n",
    "my_sorted_recall_list = [0.15, 0.3, 0.35]\n",
    "my_sorted_qps_list = [2500.21, 1500.1, 1000.08]\n",
    "df_temp3 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'QPS': my_sorted_qps_list,\n",
    "    'Algorithm': 'MUVERA',\n",
    "    'Dataset': datasets[3]\n",
    "})\n",
    "\n",
    "df_combined = pd.concat([df, df_temp, df_temp1, df_temp2, df_temp3], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "c2da17d4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Recall</th>\n",
       "      <th>QPS</th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>Dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.001</td>\n",
       "      <td>103.870743</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.001</td>\n",
       "      <td>139.600441</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.001</td>\n",
       "      <td>69.960615</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.002</td>\n",
       "      <td>97.813804</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.002</td>\n",
       "      <td>93.546384</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>250</th>\n",
       "      <td>0.015</td>\n",
       "      <td>81.100000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLEF</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>251</th>\n",
       "      <td>0.020</td>\n",
       "      <td>60.080000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLEF</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>252</th>\n",
       "      <td>0.150</td>\n",
       "      <td>2500.210000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>MultiModalQA</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>253</th>\n",
       "      <td>0.300</td>\n",
       "      <td>1500.100000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>MultiModalQA</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>254</th>\n",
       "      <td>0.350</td>\n",
       "      <td>1000.080000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>MultiModalQA</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>255 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Recall          QPS Algorithm         Dataset\n",
       "0     0.001   103.870743   Dessert  DBpedia-entity\n",
       "1     0.001   139.600441   Dessert  DBpedia-entity\n",
       "2     0.001    69.960615   Dessert  DBpedia-entity\n",
       "3     0.002    97.813804   Dessert  DBpedia-entity\n",
       "4     0.002    93.546384   Dessert  DBpedia-entity\n",
       "..      ...          ...       ...             ...\n",
       "250   0.015    81.100000    MUVERA            CLEF\n",
       "251   0.020    60.080000    MUVERA            CLEF\n",
       "252   0.150  2500.210000    MUVERA    MultiModalQA\n",
       "253   0.300  1500.100000    MUVERA    MultiModalQA\n",
       "254   0.350  1000.080000    MUVERA    MultiModalQA\n",
       "\n",
       "[255 rows x 4 columns]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_combined"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "180f42b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = df_combined"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "id": "4bafa2be",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.concat([df, df_combined], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "36fc5360",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.to_csv(\"/home/ali/hnswlib/evaluation/results.csv\", index=False)\n",
    "df = pd.read_csv(\"/home/ali/hnswlib/evaluation/results.csv\")\n",
    "df = df[df['Algorithm'] != 'MUVERA']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d376cb09",
   "metadata": {},
   "outputs": [],
   "source": [
    "df['Algorithm'] = df['Algorithm'].replace('MVR-HNSW', 'HNSW-D')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "9fc0f151",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Recall</th>\n",
       "      <th>QPS</th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>Dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.001</td>\n",
       "      <td>103.870743</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.001</td>\n",
       "      <td>139.600441</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.001</td>\n",
       "      <td>69.960615</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.002</td>\n",
       "      <td>97.813804</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.002</td>\n",
       "      <td>93.546384</td>\n",
       "      <td>Dessert</td>\n",
       "      <td>DBpedia-entity</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>250</th>\n",
       "      <td>0.015</td>\n",
       "      <td>81.100000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLEF</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>251</th>\n",
       "      <td>0.020</td>\n",
       "      <td>60.080000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>CLEF</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>252</th>\n",
       "      <td>0.150</td>\n",
       "      <td>2500.210000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>MultiModalQA</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>253</th>\n",
       "      <td>0.300</td>\n",
       "      <td>1500.100000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>MultiModalQA</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>254</th>\n",
       "      <td>0.350</td>\n",
       "      <td>1000.080000</td>\n",
       "      <td>MUVERA</td>\n",
       "      <td>MultiModalQA</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>255 rows × 4 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     Recall          QPS Algorithm         Dataset\n",
       "0     0.001   103.870743   Dessert  DBpedia-entity\n",
       "1     0.001   139.600441   Dessert  DBpedia-entity\n",
       "2     0.001    69.960615   Dessert  DBpedia-entity\n",
       "3     0.002    97.813804   Dessert  DBpedia-entity\n",
       "4     0.002    93.546384   Dessert  DBpedia-entity\n",
       "..      ...          ...       ...             ...\n",
       "250   0.015    81.100000    MUVERA            CLEF\n",
       "251   0.020    60.080000    MUVERA            CLEF\n",
       "252   0.150  2500.210000    MUVERA    MultiModalQA\n",
       "253   0.300  1500.100000    MUVERA    MultiModalQA\n",
       "254   0.350  1000.080000    MUVERA    MultiModalQA\n",
       "\n",
       "[255 rows x 4 columns]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e890be5e",
   "metadata": {},
   "outputs": [],
   "source": [
    "MVR_wo = [0.89, 0.264, 0.1019, 0.73]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "30757bbc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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tm3b5iuYnZO0tDRduXJFp06d0vfff685c+aoW7dumj17ttLT0wv9uig5Z86cUf/+/fXcc89p7dq1+vPPP5WYmCiTyaRLly5p3759mj9/vvr161ck51uzZo0yMjKy7Y+IiMgWzC5JQUFBRtv5xBNP2K0ehbFp0yadOHGiQMekpqZqxIgReumll7R9+3ZdvHhRaWlpunr1qs6cOaN9+/Zp5cqVevXVV62Os2znrl+/rkOHDlk9f+DAASNQnVOZ3377zaqMebAZSoeVK1fS/wCgVCOgDaDIrFy5UuPGjVN8fLyxr0KFCrr99tsVFBSkwMBAVa1a1Xjuxo0bub6ev7+/evTooW7duqlhw4ZWz33wwQf65ptvirT+KF5Vq1ZVjx491LVrV/n5+cnZ+X9N0IkTJxQSEmKMFgbykpycbO8q5Jv5s9+jRw/dfvvtVh2Pv//+e7aOhqLWpUsX4/x33nlnsZ4LjiciIiJbe7tr1y79+eefxXpeyyxHk8mkr7/+2ma53bt3Ky4uzti+//77VbFiRZtlzdcFtn4sM0eyqlevnnr06KH77rtPtWvXtnpu4cKFOnPmTI7H7ty506p+Zr/99ptOnTqV43EoHez193Gz2rRpY/X5dxT79+/X9u3b813+xo0bGj9+vFXHapMmTXTfffepS5cuaty4sdX1oiXLDvQ//vhDCQkJ2epi6cSJE7py5UqOZWrVqqU6derku+4oOxYvXmwVnMnLzz//rDlz5hhBPTc3N7Vv39643zVnZGfVrl07qxmpsn5GDx06pGvXrlnty1rm999/typzM4GkO++8U927d9ddd90lHx8fY39aWpoWL16sf/7znzYDl3Acp0+f1oABA/Tbb78Z+5ydneXv76+goCDdcccd8vDwkJR330t+nTp1Srt27bLad+PGDa1Zs6ZIXr84VatWzartrFevnr2rJCnz9/f+++8X6JiPP/5Y3333nbHt7e2te+65R0FBQWrXrp3x/55V1oE1WftfbA0Qy7qPwWClW3Jysj766CN7VwMACo0pxwEUid9++03//ve/rfb94x//0NixY1W5cmWr/b/++qvCw8Pl6pr7V9DgwYONKaBu3LihyZMnW90ohYWF6f777y+id4Di1rx5c82bN8/YPnPmjN544w2j4/PatWsaM2aMvvzyy2yfGcBS1LoojQgdoUXzF6nPw33sXZ08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VKmioUOHavz48TbPUdg+SLM33nhDP/74o86fP68rV64Y9atQoYJmzpxJXx9QRMrPXQrgYDZu3KSM2i1zDGabuVWuquRaLbRp05fq3bvoLwqKQta1rS2nQpMyp200dwQfOHCgQNPA2VKnTh3NnDlTjRo1uqnXgWO4du2aVQemi4uLvL29rT4naWlpeWZg/P3332rXrp26du2qFi1a6PDhw0pLS7OaLrRixYq64447NGTIEKu16UaMGKEXXnhBUuZNmuWNWv369dW9e3cNHz7cCDxn/Qx/++23edbNFjc3t2zZRvif/ASzzRw9qG2Lq6urhg8fruHDh+dZNjExUYMGDbKa6iu3svmR9bs663R8xR34cHTmLO241FSbWdpxqan6xc1Vsx00O9ssJCTEyIQ2f3f5+vrmOX1o1oxjWx2lWTvxbWUpP/jgg3r77beNwRebNm3Sk08+WeDpxiVp2rRpRZatmpCQoKlTp2r58uWqWbNmtuctOy9cXV2tZsx48MEHjYC2uWx5DWibs7ND7sqcYq9Tq96aM2NGqcnSLuzfh6NKTk7O8Xoptw75nGZMym0wli1ubm567rnnNHnyZEmZ2St5zajk5OSkoUOH6oknntDOnTu1Z88e7du3T7/++qvVd0xCQoLWrVunp556ytjXvn17q9f66aefrD535oCfZeDv559/zvbdVd4zzEprYDswMDBbdr8kff755zkOiralU6dOVlnaX3zxRZ7H1KpVS/PmzVNMTIy+//577du3T7t37852zb9+/Xq98sorVoNXAwICjADBjRs39MsvvxiZkZUrVzauvwICArR9+3alp6fr119/tbo/qVy5stVSRDn93Rfmuyzr9WF5W+Yot0C2I6levbrVPem5c+fy3T9S2LZCkrp27apatWoZS0yYlYaBbLnZu3ev9uzZk21/bkt9jB492uYMahMnTjTWGM+vp59+WitXrjSytPv0yftetl27doqMjNSRI0e0Y8cO7du3T3v27DGCaGYrVqywCmg7Ozurbdu2Rqbp4cOHdenSJWNJLHOb6erqKn9/f+3Zs0e///67Ll26ZDXFeqkdDJaUJF24kHc5WwM0Ll/O37FZlqxTRkb+jpMkGwPWi1rWLO3clk/K2iZYtj1S9j6DnPq+blbWpWE8PDyMz7rlIOS8+jiy1t9SYfsgzby8vDRt2rRsWe8vvPBC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ExE5mB1jrz0xjns+xnAiIg/XymuElsRwJrQdQKVSAQBGjBjh4poQEVGrVVcDgwe3aleVSoUOHTrYuULkDIzhREQeqA0x2xxjuGdjHCcichI7xl57Yhz3XIzhREReopXXCLbEcInAoWt2p9frUVxcDIVCAYlE4urqEBGRkwiCAJVKhcjISEilXNXDEzGGExG1T4zh3oFxnIiofWIc93yM4URE7VNLYjgT2kRERERERERERERERERE5JY4ZI2IiIiIiIiIiIiIiIiIiNwSE9pEREREREREREREREREROSWmNAmIiIiIiIiIiIiIiIiIiK3xIQ2ERERERERERERERERERG5JSa0iYiIiIiIiIiIiIiIiIjILTGhTUREREREREREREREREREbokJbSIiIiIiIiIiIiIiIiIicktMaBMRERERERERERERERERkVuSu7oCnqygoABvvfUWvv32WxQXF0OhUKBfv36YNGkSEhMTW/x+v/32G95++218//33KC8vR3BwMAYOHIh//OMfGDp0qAM+gXuw1/d46tQpfPXVVzh8+DBOnToFpVKJmpoadOrUCYMGDcLf//533HTTTQ78JK5j799Fg+rqakyYMAEXLlwQn5s7dy7mzZtnj2q7HUd8j9999x22bt2Kn376CaWlpfDz80N4eLj4Ozlw4EA7fwrXsud3WFpaivfffx/ffPMNTp8+DbVaDT8/P8TExOD666/HjBkz0LNnTwd9EvIW7hCr6+rq8P7772PPnj04deoU9Ho94uLiMHr0aDz88MPo0KFDWz+mzVz9fTz99NPYvn17k++ZkpKCxx57rMV1aQ17fh8fffQRfvrpJ/z+++84efIkdDodAKBz587Izc21up+7/H64+rvw1t+NtlyfusvvBuD678Pdfj/IeVwdtwD3+Ft05feg1WqRm5uLw4cP45dffkFxcTFKS0vh4+OD7t27Y9SoUXjggQcQFBRkr4/bJHf4nTD2zjvv4JVXXjF57tixYy2uR2u4y3dRVVWFzZs3Izc3F4WFhaipqUHHjh3RrVs33HjjjZg7d25bPmaz3OF7yM3NxbZt23DkyBGUlpZCEASEhISgd+/eGDduHJKSkiCXO74L1tXXc4B7nDPJvbnD3yxd4errfLqC/fvuhXkC9yQRBEFwdSU80b59+zBv3jzU1dVZfP2ee+7BypUrIZFIbHq/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amqK7du3w9fXF7Vr14aJiQkaNWqEqVOnYu3atTAyMiq3siAiItI3jONERET6iTGciIhIPzGGE8mDQR7HIiAiIiIiIiIiIiIiIiIiIhniE9pERERERERERERERERERCRLbNAmIiIiIiIiIiIiIiIiIiJZYoM2ERERERERERERERERERHJEhu0iYiIiIiIiIiIiIiIiIhIltigTUREREREREREREREREREssQGbSIiIiIiIiIiIiIiIiIikiU2aBMRERERERERERERERERkSyxQZuIiIiIiIiIiIiIiIiIiGSJDdpERERERERERERERERERCRLbNAmIiIiIiIiIiIiIiIiIiJZYoM2ERERERERERERERERERHJEhu0iYiIiIiIiIiIiIiIiIhIltigTUREREREREREREREREREssQGbSIiIiIiIiIiIiIiIiIikiU2aBMRERERERERERERERERkSyxQZuIiIiIiIiIiIiIiIiIiGSJDdpERERERERERERERERERCRLbNAmIiIiIiIiIiIiIiIiIiJZYoM2ERERERERERERERERERHJknFFZ4CouLZu3YolS5YAAHx8fLB48eJSpzlv3jwEBwcDAObPn4+xY8cWOw13d3fExMSIZQMDA5iYmMDc3By1a9dG06ZN0b17d3h7e6Nq1apF5kOZkZERqlWrhvr166NDhw4YMWIEWrZsWew8VgR7e3vxevDgweJ/B0jLzNXVFdu3by/3/MnJ+fPnMXr0aLG8ePFi+Pj4VGCOiIioMIXVSfz8/HDhwgUAgK2tLU6ePKl1urqolyi7desW9u7di0uXLiE2NhYpKSmoUqUKGjVqhA4dOsDLywvt27fX+PkAsG3bNnTu3LnQz9i3bx/mz5+vVX72798PBwcHAEB0dDR69+6tcTszMzPUqlULDg4OGDRoEDw8PIpMOzQ0FEePHkV4eDieP3+O169fo0aNGmjatCm6du2KgQMHomHDhlrlk4iISJf3H5Sv9xwcHBAcHAwDA4MSp5ecnIyff/4ZYWFhuHPnDpKSkmBgYAAbGxs4OjrC3d0dffv2RZUqVdQ+H1C/Pi+I8jV9YUaPHo1///vfYlm5LlSYVq1a4cCBA1p9BhER6VZp4lxh93yVY8Dq1avx7rvvFjtvmuJPUFAQXFxc1NYfPXoUH3/8sWRdca/DC6N6jXz79u1ip7Fq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TwMA/P399fLCz93dXfSwdnV1lczZTW8mPz8/0fPQ19dXMmQMERGVXFnWSYDKUS8hIiLSZ2UR6xUdq4H8IbqPHTsmmxvfRET0Zinra9p+/fqJObQXLVqE999/X6fpEwHAunXr8O233wLIn8pl06ZNah0KqfLgE9qkVyZMmCCGwDh16lSBQ1kW171793DmzBkA+UOCT5gwQSfpElWEw4cPY8OGDZg6dapozDY0NISfn18F54yIqPIoqzoJwHoJERGRHJRFrN+6dat4PWPGDDZmExFRhSnLa9pTp06Jxmw7OzsMHjxYZ2kTKfP39xdTcWZlZeHjjz/G33//XcG5orLCBm3SKzVq1IC/vz+A/PmpNm7cqJN0N23aBMVgBVOmTEGNGjV0ki5RRfjpp5/wzTff4Pjx42LdmDFj0KJFiwrMFRFR5VJWdRKA9RIiIiI50HWsP3/+PK5duwYAcHBwwMCBA0udRyIiopIq62tahU8++YQduKhMffnll2jbti2A/LnCJ0+ejFevXlVspqhMcMhxokqEQ44T8M8w46ampmjYsCF8fX3h5+cHQ0P2YSIiIiIiIiIiIiIiIv3CBm0iIiIiIiIiIiIiIiIiIpIlPq5HRERERERERERERERERESyxAZtIiIiIiIiIiIiIiIiIiKSJTZoExERERERERERERERERGRLLFBm4iIiIiIiIiIiIiIiIiIZIkN2kREREREREREREREREREJEts0CYiIiIiIiIiIiIiIiIiIlligzYREREREREREREREREREckSG7SJiIiIiIiIiIiIiIiIiEiW2KBNRERERERERERERERERESy9P/1pnQw7ihl4wAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 2000x500 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from matplotlib import colormaps as cm\n",
    "import string\n",
    "\n",
    "# -----------------------------\n",
    "# 1. Global Plot Configuration\n",
    "# -----------------------------\n",
    "sns.set_style(\"white\")  # no gridlines\n",
    "\n",
    "plt.rcParams.update({\n",
    "    'font.size': 16,\n",
    "    'font.weight': 'bold',\n",
    "    'axes.labelweight': 'bold',\n",
    "    'axes.titlesize': 16,\n",
    "    'axes.titleweight': 'bold'\n",
    "})\n",
    "\n",
    "# -----------------------------\n",
    "# 2. Algorithm Style Map\n",
    "# -----------------------------\n",
    "markers = ['o', 's', 'D', 'v', '^', '>', '<', 'p', '*', 'h', 'H', '+', 'x']\n",
    "cmap = cm.get_cmap('tab10')\n",
    "color_list = list(getattr(cmap, 'colors', [cmap(i / 10.0) for i in range(10)]))\n",
    "\n",
    "algorithm_map = {\n",
    "    algo: {\n",
    "        'marker': markers[i % len(markers)],\n",
    "        'color': color_list[i % len(color_list)]\n",
    "    }\n",
    "    for i, algo in enumerate(algorithms)\n",
    "}\n",
    "\n",
    "# -----------------------------\n",
    "# 3. Dataset Label Map (Paper Consistency)\n",
    "# -----------------------------\n",
    "subplot_labels = {\n",
    "    'sift1m': 'SIFT1M',\n",
    "    'gist1m': 'GIST1M',\n",
    "    'deep1m': 'DEEP1M',\n",
    "    'glove1m': 'GloVe1M',\n",
    "    'msong': 'MSong',\n",
    "    'tiny5m': 'Tiny5M'\n",
    "}\n",
    "\n",
    "# -----------------------------\n",
    "# 4. Create Figure Layout (1 Row)\n",
    "# -----------------------------\n",
    "n_datasets = len(datasets)\n",
    "fig, axes = plt.subplots(nrows=1, ncols=n_datasets, figsize=(5 * n_datasets, 5))\n",
    "axes = axes.flatten() if n_datasets > 1 else [axes]\n",
    "\n",
    "# Compute QPS if missing\n",
    "if 'QPS' not in df.columns and 'Time (msec)' in df.columns:\n",
    "    df['QPS'] = 1000.0 / df['Time (msec)']\n",
    "\n",
    "# -----------------------------\n",
    "# 5. Plot Each Dataset\n",
    "# -----------------------------\n",
    "MVR_wo = [0.89, 0.264, 0.1019, 0.73]  # defined early so we can use it below\n",
    "\n",
    "for i, ds in enumerate(datasets):\n",
    "    ax = axes[i]\n",
    "    df_subset = df[df['Dataset'] == ds]\n",
    "\n",
    "    for algo in algorithms:\n",
    "        if algo == \"MVR-HNSW\":\n",
    "            continue\n",
    "        data = df_subset[df_subset['Algorithm'] == algo].copy()\n",
    "        data = data.sort_values(by='Recall')\n",
    "        style = algorithm_map[algo]\n",
    "\n",
    "        ax.scatter(\n",
    "            data['Recall'],\n",
    "            data['QPS'],\n",
    "            label=algo,\n",
    "            color=style['color'],\n",
    "            marker=style['marker'],\n",
    "            s=70,\n",
    "            edgecolor='black',\n",
    "            linewidth=0.6,\n",
    "            alpha=0.9\n",
    "        )\n",
    "\n",
    "    # Axis scaling\n",
    "    if not df_subset.empty:\n",
    "        recall_min, recall_max = df_subset['Recall'].min(), df_subset['Recall'].max()\n",
    "        qps_min, qps_max = df_subset['QPS'].min(), df_subset['QPS'].max()\n",
    "\n",
    "        # Add margins\n",
    "        x_margin = 0.02 * (recall_max - recall_min if recall_max > recall_min else 0.1)\n",
    "        y_margin = 0.05 * (qps_max - qps_min if qps_max > qps_min else 1)\n",
    "\n",
    "        # Ensure x-axis includes the red line\n",
    "        if i < len(MVR_wo):\n",
    "            recall_max = max(recall_max, MVR_wo[i] + x_margin)\n",
    "\n",
    "        ax.set_xlim(recall_min - x_margin, recall_max + x_margin)\n",
    "        ax.set_ylim(qps_min - y_margin, qps_max + y_margin)\n",
    "\n",
    "    ax.set_xlabel('Recall', fontsize=15, fontweight='bold')\n",
    "    ax.set_ylabel('QPS', fontsize=15, fontweight='bold')\n",
    "    ax.tick_params(axis='both', labelsize=14, width=1.8)\n",
    "\n",
    "    subplot_letter = f\"({string.ascii_lowercase[i]}) \"\n",
    "    ax.text(\n",
    "        0.5, -0.25,\n",
    "        subplot_letter + subplot_labels.get(ds, ds),\n",
    "        transform=ax.transAxes,\n",
    "        ha='center',\n",
    "        fontsize=15,\n",
    "        fontweight='bold'\n",
    "    )\n",
    "\n",
    "# -----------------------------\n",
    "# 5.1 Add Dotted Red Line (MVR_wo)\n",
    "# -----------------------------\n",
    "for i, ax in enumerate(axes):\n",
    "    if i < len(MVR_wo):\n",
    "        ax.axvline(\n",
    "            x=MVR_wo[i],\n",
    "            color='red',\n",
    "            linestyle='--',\n",
    "            linewidth=2,\n",
    "            alpha=0.8,\n",
    "            label='No Index' if i == 0 else None  # add label only once\n",
    "        )\n",
    "\n",
    "# -----------------------------\n",
    "# 6. Legend (Top Center)\n",
    "# -----------------------------\n",
    "handles, labels = axes[0].get_legend_handles_labels()\n",
    "fig.legend(\n",
    "    handles, labels,\n",
    "    loc='upper center',\n",
    "    bbox_to_anchor=(0.5, 1.08),\n",
    "    ncol=len(algorithms) + 1,  # +1 for the MVR_wo line\n",
    "    fontsize=15,\n",
    "    frameon=False\n",
    ")\n",
    "\n",
    "# -----------------------------\n",
    "# 7. Cleanup & Save\n",
    "# -----------------------------\n",
    "plt.tight_layout(rect=[0, 0, 1, 1])\n",
    "fig.savefig('query_performance_plot.png', dpi=300, bbox_inches='tight')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f8e508a2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
