{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 19,
   "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": 20,
   "id": "71f13dfe",
   "metadata": {},
   "outputs": [],
   "source": [
    "algorithms = [\"Multi-HNSW-64\", \"C-Multi-HNSW-64\", \"Multi-HNSW-128\", \"C-Multi-HNSW-128\", \"Multi-HNSW-256\", \"C-Multi-HNSW-256\"]\n",
    "datasets = [\"CLERC-768\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "fed41e3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "my_sorted_recall_list = [0.263]\n",
    "my_sorted_qps_list = [63]\n",
    "df_temp = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'Memory (GB)': my_sorted_qps_list,\n",
    "    'Algorithm': 'Multi-HNSW-64',\n",
    "    'Dataset':  datasets[0]\n",
    "})\n",
    "\n",
    "my_sorted_recall_list = [0.239]\n",
    "my_sorted_qps_list = [34]\n",
    "df_temp3 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'Memory (GB)': my_sorted_qps_list,\n",
    "    'Algorithm': 'C-Multi-HNSW-64',\n",
    "    'Dataset': datasets[0]\n",
    "})\n",
    "\n",
    "df_combined = pd.concat([df_temp, df_temp3], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ce1ecb55",
   "metadata": {},
   "outputs": [],
   "source": [
    "my_sorted_recall_list = [0.27]\n",
    "my_sorted_qps_list = [71]\n",
    "df_temp = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'Memory (GB)': my_sorted_qps_list,\n",
    "    'Algorithm': 'Multi-HNSW-128',\n",
    "    'Dataset':  datasets[0]\n",
    "})\n",
    "\n",
    "my_sorted_recall_list = [0.226]\n",
    "my_sorted_qps_list = [45]\n",
    "df_temp3 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'Memory (GB)': my_sorted_qps_list,\n",
    "    'Algorithm': 'C-Multi-HNSW-128',\n",
    "    'Dataset': datasets[0]\n",
    "})\n",
    "\n",
    "df_combined_128 = pd.concat([df_temp, df_temp3], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "95105760",
   "metadata": {},
   "outputs": [],
   "source": [
    "my_sorted_recall_list = [0.273]\n",
    "my_sorted_qps_list = [89]\n",
    "df_temp = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'Memory (GB)': my_sorted_qps_list,\n",
    "    'Algorithm': 'Multi-HNSW-256',\n",
    "    'Dataset':  datasets[0]\n",
    "})\n",
    "\n",
    "my_sorted_recall_list = [0.247]\n",
    "my_sorted_qps_list = [66]\n",
    "df_temp3 = pd.DataFrame({\n",
    "    'Recall': my_sorted_recall_list,\n",
    "    'Memory (GB)': my_sorted_qps_list,\n",
    "    'Algorithm': 'C-Multi-HNSW-256',\n",
    "    'Dataset': datasets[0]\n",
    "})\n",
    "\n",
    "df_combined_256 = pd.concat([df_temp, df_temp3], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "c2da17d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.concat([df_combined, df_combined_128, df_combined_256], ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "eca83e83",
   "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>Memory (GB)</th>\n",
       "      <th>Algorithm</th>\n",
       "      <th>Dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.263</td>\n",
       "      <td>63</td>\n",
       "      <td>Multi-HNSW-64</td>\n",
       "      <td>CLERC-768</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.239</td>\n",
       "      <td>34</td>\n",
       "      <td>C-Multi-HNSW-64</td>\n",
       "      <td>CLERC-768</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.270</td>\n",
       "      <td>71</td>\n",
       "      <td>Multi-HNSW-128</td>\n",
       "      <td>CLERC-768</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.226</td>\n",
       "      <td>45</td>\n",
       "      <td>C-Multi-HNSW-128</td>\n",
       "      <td>CLERC-768</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.273</td>\n",
       "      <td>89</td>\n",
       "      <td>Multi-HNSW-256</td>\n",
       "      <td>CLERC-768</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.247</td>\n",
       "      <td>66</td>\n",
       "      <td>C-Multi-HNSW-256</td>\n",
       "      <td>CLERC-768</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Recall  Memory (GB)         Algorithm    Dataset\n",
       "0   0.263           63     Multi-HNSW-64  CLERC-768\n",
       "1   0.239           34   C-Multi-HNSW-64  CLERC-768\n",
       "2   0.270           71    Multi-HNSW-128  CLERC-768\n",
       "3   0.226           45  C-Multi-HNSW-128  CLERC-768\n",
       "4   0.273           89    Multi-HNSW-256  CLERC-768\n",
       "5   0.247           66  C-Multi-HNSW-256  CLERC-768"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "36fc5360",
   "metadata": {},
   "outputs": [],
   "source": [
    "# df.to_csv(\"/home/ali/hnswlib/evaluation/results_connectivity.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "30757bbc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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kZZimCciIiIi0lIM80REREREWophnoiIiIhISzHMExERERFpKYZ5IiIiIiItxTBPRERERKSlGOaJiIiIiLQUwzwRERERkZZimCciIiIi0lIM80REREREWophnoiIiIhISzHMExERERFpKYZ5IiIiIiItxTBPRERERKSlGOaJiIiIiLQUwzwRERERkZZimCciIiIi0lIM80REREREWophnoiIiIhISzHMExERERFpKYZ5IiIiIiItxTBPRERERKSlGOaJiIiIiLQUwzwRERERkZZimCciIiIi0lIM80REREREWophnoiIiIhISzHMExERERFpKYZ5IiIiIiItxTBPRERERKSlGOaJiIiIiLQUwzwRERERkZZimCciIiIi0lIM80REREREWophnoiIiIhISzHMExERERFpKYZ5IiIiIiItxTBPRERERKSlGOaJiIiIiLQUwzwRERERkZbSq+8OlCaVSrFjxw5ERETg7t27kEql0NfXR9OmTeHo6AgvLy90795ddExRURFCQ0MRFhaGxMRE5Ofnw9raGv369YOPjw+aNm1aT2dDRERERFR7JHK5XF7fnVDIysrC5MmTcffu3XLb6OjoYM2aNRgzZgwAID8/H3PmzMHZs2fLbG9ubo6tW7eia9euavdDKpXCyckJMTExMDExqdpJEBGRxuHvdSJ6VWlUmU1ISIgoyLu6umLBggV45513oKdX8iVCcXEx1q9fL7RZt26dEOR1dXUxefJkzJ07FzY2NgCAjIwMLFiwADk5OXV4JkREREREtU+jymzu378vLDdq1Ajbt2+Hrq4uAEAmk2Hv3r0AgPT0dABAZmYmgoODhWNmzpyJRYsWAQBGjRqFESNGQC6XIyUlBWFhYfD09KyrUyEiIiIiqnUaNTLfvn17YTk7OxtnzpxBQUEB7t27hytXrgj7+vbtCwA4d+4c8vPzhe1DhgwRltu1a4cOHToI6xEREbXZdSIiIiKiOqdRI/OTJ0/GoUOHEBsbi+LiYnz44Yei/bq6uhg6dChWrFgBAIiLixPtb9mypcp6fHx8mW2JiIiIiLSdRo3MGxoaIiAgAJMmTSpzv52dHUaOHAkzMzMAwPPnz0X7S9/UZGxsLCyXbktEREREpO00KsxLpVLMnDkToaGhAIBu3brB19cX48ePh56eHuLj4zF37lxs27atzONLT8yjvC6RSGqv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X19f2NnZIScnB8nJyfjzzz/x4MEDob2+vj66deuGCxcuACj581CE+aSkJDx79kxoK5fLcenSJQwePBgAEBUVJexr3rw5WrRoUel56Ovro2fPnnBwcEDz5s2xdu3aSo+RSCRwd3fHkCFDYGtri7t372LTpk1IT0+HXC7HqlWrMGrUKBgaGgIAQkJChCBvbGyMZcuWoUWLFjh8+DB27dol9P369evo2rVrpe+vDoZ5IiKi19CEyZPxw5o1kACwrOA5MakFBUgyaojxkybVXecABAQECEEeAL799luMHDlS1GbcuHFISkoSglRVmJiYQCqVIjAwEP/5z38AALt370ZOTg50dHRgaGiInJwcleOWLl0qlMaULjFRLvsICAiAm5tbue+v3BYoGaW3t7cX1hVlH2Vtq2vJycnYvXu3UBJTHkXpDVDyZzN16lTR/unTp0MqlYq2ubi4iMK8gmLZyMgIlpaWuH//PmJiYoQwr9zWyclJrfNo3749du7cKZxTZWG+WbNm2LdvHzp37ixs6927N5o2bSr8uWdnZyM+Ph7dunUDUPKBUMHd3R2T/v//m27duglhHgAKCwvV6rM6qnQDLBEREb0a9PT0MGfpUuzMelFhu50vXmDusmXQ06vb8T/lG0V79eqlEuQV2rZtW62HVirKhw8ePIiMjAwUFxdjx44dAICBAweicePG1ej1q0fxPKEff/wR+fn5FbZVrncPDw/Hnj178PDhw3LbAOJvHq5evYqCggIAQExMDACgR48ewoeissJ+6deoSc2bNxcFeYW2bduK1o2MjITlPn36CMtnz55FaGgoIiMjRR8c7O3t4eDgUGP9ZJgnIiJ6TU2YPBlX9PSQ+v8BqrTUggJc0der81H5nJwcJCUlCeu9e/eu8ffw9PSErq4u8vLysHv3bpw+fVooAVHUdNcmPz8/LF++XFi3srJCcHCw8FOT9fGDBg0SzYpjb28v+lagIgsXLgRQclOnYlS7PP379xeWnz17hs8++wwDBw5Er169MHfuXISFhamMSDs6OgrlOwUFBbh69SoACPdJODk5CWH95s2byMnJQXp6Ou7evSu8houLi1rnUlOUb8Rt27Yt7OzshPVBgwZh2bJlMDMzQ3Z2NpYvX47p06dj165d0NfXx/vvv4+goKBKS5aqgmU2RERErylhdH7lSvhaWKrs3/niBeb+84s6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+HhERkaiqKgIISEhomNNTU3h5+cnmtmGiIiIiOhVoDFhvroMDQ2xdetWhIaGIiwsDAkJCSgoKIC1tTX69esHHx+fcp8gS0RERESkzbQizFf29FY9PT14enrC09OzjnpERERERFT/tPoGWCIiIiKi1xnDPBERERGRlmKYJyIiIiLSUgzzRERERERaimGeiIiIiEhLMcwTEREREWkphnkiIiIiIi3FME9EREREpKUY5omIiIiItBTDPBERERGRlmKYJyIiIiLSUgzzRERERERaimGeiIiIiEhLMcwTEREREWkphnkiIiIiIi3FME9EREREpKUY5omIiIiItBTDPBERERGRlmKYJyIiIiLSUgzzRERERERaimGeiIiIiEhLMcwTEREREWkphnkiIiIiIi3FME9EREREpKUY5omIiIiItBTDPBERERGRlmKYJyIiIiLSUgzzRERERERaSq++O0CkrpEefSB9/kTt9iaNmyE84lwt9oiIiIiofjHMk9aQPn+CM166arfvH6x+8CciIiLSRiyzISIiIiLSUgzzRERERERaimGeiIiIiEhLMcwTEREREWkphnkiIiIiIi3FME9EREREpKUY5omIiIiItBTDPBERERGRlmKYJyIiIiLSUgzzRERERERaSq++O0CkLpPGzdA/+EmV2hMRERG9yhjmSWuER5yr7y4QERERaRSW2RARERERaSmGeSIiIiIiLcUwT0RERESkpRjmiYiIiIi0FMM8EREREZGWYpgnIiIiItJSDPNERERERFqKYZ6IiIiISEsxzBMRERERaSmGeSIiIiIiLcUwT0RERESkpfTquwOaSC6XAwCkUmk994SIiGqC4ve5VCqFsbExJBJJPfeIiKhmSOSK5EqCx48fo3///vXdDSIiqgUxMTEwMTGp724QEdUIhvkyFBcX4+nTpxy9ISJ6RcjlcmRnZ8PY2BgmJib83U5ErwyGeSIiIiIiLcUbYImIiIiItBTDPBERERGRlmKYJyIiIiLSUgzzRERERERaimGeiIiIiEhLMcwTEREREWkphnkiIiIiIi3FME9EREREpKX06rsDr7qkpCRs2bIFf/31l/BU2TfeeAOTJk3CiBEj1H6dv//+G6dOnUJUVBT+/vtvpKamIjc3F02aNEGPHj0wZcoUvPnmmyrHHT58GCdOnMDt27eRmpoKqVQKAwMDWFtbw8nJCd7e3ujUqVNNnvJLq+9rVtovv/yCNWvWiLbFxcVV+bxqS31fr6VLl2Lfvn0VvvaCBQswZ86cKp9bbanva6aQlZWFwMBARERE4N69e8jNzUXjxo3Rpk0buLm5Yd68eTVxui+tPq/X3r17sWzZMrVePyAgAG5ublU6NyIibccnwNaiM2fOwNfXF/n5+WXuHzduHFavXq3WY8X/+c9/IiQkpMI2S5YsgY+Pj2jbrFmzcPr06XKP0dfXx7p16zB48OBK+1AXNOGaKUtKSsLYsWORl5cn2q4pYV4Trpe2hXlNuGYAcPXqVXz44YdITU0t8zhdXV3cvHmz0j7Utvq+XlUJ84GBgXB1dVWrLRHRq4Ij87XkyZMnWLJkifAPYPv27TFixAjcuXMH4eHhAIB9+/aha9eu8PLyUvt127RpA3d3d1hYWODmzZs4ceIEFJ/Hvv/+ewwePBjt2rUT2hsaGsLV1RX29vZo0qQJioqKcOnSJZw/fx4AIJPJ8N1332lEmNeUa6ZQXFyMZcuWqQR5TaFp1wsA3n33XbRq1Uplu5OTU1VPr1ZoyjV7/PgxZs6ciYyMDACAhYUFBg8eDGtra+Tn5+PRo0e4detWDZ119WnC9eratSs++eSTMl9nz549uHPnDgDA3NwcXbt2rfa5EhFpK4b5WhIQEICsrCwAgLGxMYKDg2Fubg4AkEgkOHjwIADgp59+wrvvvgtdXd0KX69jx474+eef0b9/f9H2H374AX5+fgBKwue5c+dEoUGxr7QPPvgA586dAwCkpKRU/QRrgaZcM4VffvkFsbGx0NPTQ9++fXHq1KmXPcUapWnXCwBGjBih0WUOmnLN1q1bJwR5Nzc3bNmyBQ0aNKiJU6xRmnC9OnTogA4dOqi8Vnp6uuj3m6enJxo2bFi9EyUi0mK8AbaWRERECMuurq7CP4AAMHToUGH5yZMnuHHjRqWv5+3trfIPIACVEXWZTFbh60ilUvz555+4ffu2sK19+/aVvn9d0KRrdufOHSEo+Pj4oEuXLpW+X13TpOulsHTpUnTr1g3du3fHsGHDsHLlSjx8+LDS964rmnDN8vPzhVFtAOjTpw/mzJmDXr16oUePHhg/fjyCgoJQXFys1jnVJk24XuUJDg4WvjEwMDCAt7d3pccQEb2KGOZrQUFBAZKSkoT1li1bivaXXn+Z+mvl9wFQ7tfMHh4esLe3h5OTE/7xj38gLS0NAGBqaorPP/+82u9fUzTpmhUVFeGzzz5Dfn4+OnXqpDG13so06Xope/jwIfLz85GXl4ekpCQEBgbi7bffxqVLl6r9/jVFU67Z9evXUVBQIKz/97//xdmzZ5Geno7c3FzcuHEDX331FXx9fes10GvK9SpLfn4+duzYIayPHTsWlpaW1X5/IiJtxjBfCzIzM6F8X7GJiYlov7GxsWj9+fPn1Xqf1NRUfPPNN8K6i4sLXFxc1D7e1tYW27Zt04h6Zk26Zv7+/rh8+TL09fWxZs0a6OvrV+u9apMmXS+gpF555MiRmD17NmbNmiX6JiMrKwuLFy8WBdj6oCnX7NmzZyrH9O7dG/PmzUO3bt2EbSdOnEBoaGi1+lATNOV6lWXfvn1IT08HUFLuM3369Gq9NxHRq4BhvhaUniCosvXquH//Pry8vPDgwQMAQNu2bcutjweA2bNn46OPPsKMGTOEoJWcnAxPT0/8/vvvL92fl6Up1+zOnTvYsGEDgJJr1rlz55d+39qgKdcLAObMmYNz587hv//9LxYtWoTFixdjz549GD16tNDm0aNHwk3X9UVTrlnpEpIuXbpg27Zt8PX1RXBwMKysrIR9Bw4ceOk+VZemXK+y+rV9+3ZhfcCAAbCzs3vpvhARaSuG+Vpgbm4umqYtOztbtF8qlaq0r4orV67gnXfewd9//w0AsLe3R2BgICwsLMo9ZvLkyZg5cyY++eQT7N27FxMmTABQEiy+/PLLMkcL65KmXLNVq1ahoKAAXbp0wezZs6v0HnVJU64XALRq1Qp6euJ76SUSCaZOnSralpiYWKU+1DRNuWampqaidVdXV6FfBgYG6NGjh7Dv/v37VepDTdKU61VaRESEqCxnxowZVXpfIqJXDcN8LTAwMECbNm2EdcWok0Lpf6Dt7e3Vfu3jx4/jvffeE75i7t27t8ponjoGDRokLOfl5eHKlStVOr6maco1U8z5fePGDXTp0gX29vawt7fHxo0bVd6/Kn2oaZpyvSpSeuRWR6d+f91oyjUra2YWZcoBuj5nuNGU61XaL7/8Iix37dq1SqWFRESvIob5WjJw4EBh+cKFC6J60sOHDwvLTZs2hYODAwBgw4YNQkj08PBQec1ff/0V8+fPF+Y9nzhxIrZs2YJGjRqV2Ye///4bV69eLXPfmTNnROvqPPCltmnCNdMmmnC9kpKS8MMPPwjTFyrI5XIEBQWJtlUWYuuCJlwzGxsbdOzYUViPjo4WlgsKCnD58mVhXdGH+qIJ10vZtWvXRNfrgw8+qPpJERG9YjjPfC2ZNm0aQkJCkJ2djZycHHh7e2PEiBFITEzE0aNHhXYzZ86sdG5mANi2bRvWrl0rrLdu3Rrt2rXDr7/+KmrXoUMH9OvXD0BJWcPcuXNhb28PV1dXWFlZQSqVIjo6GrGxscIxxsbGGjG6pQnXrHfv3mjdurXKayUmJgoPpwHE0/LVF024Xnl5efDz88OWLVvg7u4Oe3t7FBQU4OzZs6KpCtu2bYs333zzZU/5pWnCNQOADz/8EIsWLQJQMrvNjBkz4OjoiD/++ANPnz4FUPIBuyoPYqoNmnK9lI9XsLW11Yj/D4mI6hvDfC2xtrbGt99+iwULFqCgoACJiYlYv369qM3bb7+t9tzI8fHxovV79+7h66+/Vmk3btw4lX8E4+Liyp02rmHDhvjmm29U6njrgyZcs08//bTM19qwYYOo1KZ0v+qDJlwvhZycHBw7dgzHjh1Tad+sWTNs2rRJI2YF0pRrNmLECFy7dk0Ip2fPnsXZs2eF/RKJBB9//DGcnZ3VPrfaoCnXCyh5uJ3y369p06ap9QGCiOhVxzBfizw8PPD7779j69atiIyMRGpqKoyMjNC5c2dMnjwZI0eOrNX379q1K+bOnYuYmBjcv38fz58/h0wmg4mJCdq2bQs3Nzd4enrC2tq6VvtRFfV9zbRNfV+v9u3b4+eff8bp06cRGxuL1NRUPH/+HIaGhmjXrh0GDhwIb29vjfiwqFDf10zh008/hZubG4KDg3Ht2jVkZWXB3NwcPXv2xLRp0+o9yCtoyvUKCAhAYWEhAMDMzAwTJ06sk/clItJ0EnlNzC9GRERERER1jjfAEhERERFpKYZ5IiIiIiItxTBPRERERKSlGOaJiIiIiLQUwzwRERERkZZimCciIiIi0lIM80REREREWophnoiIiIhISzHMExERERFpKYZ5IqoxGzZsgL29Pezt7bF06VJh+969e4XtU6dOrcceEhERvVr06rsDRPQ/e/fuxbJly1S2GxgYwMrKCt27d8f06dPRvXv3eugdERERaRqOzBNpgYKCAqSkpODQoUOYMmUKzp8/X99dIiIiIg3AkXkiDRYcHIzi4mIkJCTg22+/RU5ODgoLC+Hv74/evXvXd/eIiIionjHME2kwZ2dnAICrqyvu3LmD4OBgAEBKSoqoXUZGBrZv346IiAg8ePAARUVFaNmyJYYNG4YPPvgAxsbGovZyuRz79+9HWFgYbt26haysLDRq1Ajt27fHlClTMHz4cADA2bNnsXv3bsTFxSE9PR1SqRQNGjRA69atMWjQIHzwwQcwMjKqgytBREREZWGYJ9ISxcXFwrK1tbWwfO/ePbz33nt4/PixqH1iYiI2btyIY8eOITAwEObm5gBKSnbmzp2LP/74Q9Q+PT0dUVFRaNGihRDm//rrLxw+fFjUrrCwEDdv3sTNmzdx5swZ7Ny5E3p6/FVCRERUH/gvMJEGu3jxolBmExYWBgCQSCSiGWE+/vhjIci7ubnhvffeg46ODn755RdERUUhPj4eq1atwtdffw0A2LRpkxDkJRIJJkyYAA8PDxQXF+Py5cuQyWTCa7u4uKBZs2Zo3rw5jI2NoaOjg/T0dGzduhXXr1/H1atXceLECQwbNqyuLgkREREpYZgn0mBeXl6i9TZt2uDTTz+Fh4cHACA+Ph5XrlwBAOjr68PHxweGhoYAAG9vb0RFRQEADh06hC+//BJGRkYIDQ0VXs/b2xvLly8X1t966y3R+7m6uuLWrVvYvHkz/v77b2RnZ4u+IQCAy5cvM8wTERHVE4Z5Ii2SkpKCu3fvCmE+MTFR2CeTyTBjxowyj5PJZPj777/RvHlzpKWlCdtLh3dlcrkcM2fORHR0dIV9yszMrMopEBERUQ3i1JREGiwuLg5//fWXMEIvk8nwzTff4Ny5c1V+rezsbMjlctE2iURSbvvY2FghyOvq6sLX1xfbt29HcHAwxowZI7Qr/ZpERERUdzgyT6ThGjdujOXLl+Py5cu4ceMGAGDt2rUICwuDnZ2d0M7Q0BBnz55Fo0aNVF5DKpXCxMQEcrkcFhYWwuj8sWPH4OrqKmorl8shkUjw6NEjYVunTp0wb948Yd3Pz69Gz5GIiIiqh2GeSAvo6OhgwYIF8PHxAVAyYn/ixAm89dZb6Nq1K65du4a8vDxMmzYNU6dOhbW1NZ4/f47k5GScOnUK+vr6CAgIgEQiwcSJE/HTTz8BKJnHvqCgAAMGDEBxcTGuXbuG3NxcfPbZZ2jZsqXw/vHx8QgKCkKrVq0QHh4u1OITERFR/WKYJ9IS/fv3F4I7APzwww9466238O2332LatGl4/Pgxbty4gaVLl6ocqzz6Pm/ePNy4cQNnz55FcXExQkJCEBISIuwfN24cAKBr165wdnbGxYsXIZPJ8NVXXwEoKblRbCciIqL6xZp5Ii2iXOpy8+ZNREREoE2bNti/fz/mzp2LN954A0ZGRjAwMICNjQ1cXFywaNEirFixQjjOwMAAW7ZswerVq9GrVy+Ym5tDT08PjRs3houLC/r16wegpJ5+06ZNmDRpEqysrNCwYUM4OjrC398fb775Zl2fOhEREZVBIufda0REREREWokj80REREREWophnoiIiIhISzHMExERERFpKYZ5IiIiIiItxTBPRERERKSlGOaJiIiIiLQUwzwRERERkZZimCciIiIi0lIM80REREREWophnoiIiIhISzHMExERERFpKYZ5IiIiIiItxTBPRERERKSlGOaJiIiIiLQUwzwRERERkZZimCciIiIi0lIM80REREREWophnoiIiIhISzHMExERERFpKYZ5IiIiIiItxTBPRERERKSlGOaJiIiIiLTU/7V39zFdVQ8cxz8gz8oPeW4JhkMjY8NAB5LWDKjNWStdkVSgjGXaDJeWjQ3X5vgjs7IZpKVmrUiLhJQw5wA3GyZoT5YwUFAi0D/koUhAvl/w9wfj7nt5UAKfvuP92tjuvefcwzl8//l8D+eeS5gHAAAA7BRhHgAAALBThHkAAADAThHmAQAAADtFmAcAAADsFGEeAAAAsFOEeQAAAMBOEeYBAAAAO0WYBwAAAOwUYR4AAACwU4R5AAAAwE4R5gEAAAA7RZgHAAAA7BRhHgAAALBThHkAAADAThHmAQAAADtFmAcAAADsFGEeAAAAsFOEeQAAAMBOEeYBAAAAO0WYBwAAAOwUYR4AAACwU4R5AAAAwE4R5jGu1NXVKTw8XGFhYdqyZcuo27FarYqLi1NYWJheeOGFG9hDAACAkXO63R0AbqW3335bVqtV7u7uWrZs2ajbcXJyUlpamjZu3KgTJ06ouLhYCQkJ/6kNi8WioqIiHTp0SJWVlWptbZWHh4cCAwMVGRmpRYsWKTo6WpJUXl6ulJQU496SkhIFBQUN23ZycrIqKiqu+fszMjK0fPlySVJ+fr4yMjIG1XFxcZG/v79mzZql5cuXa9asWWMey/WMpO/S0H+DhoYG7d69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",
      "text/plain": [
       "<Figure size 500x600 with 1 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",
    "# Example placeholders — replace with your actual data\n",
    "# algorithms = ['Algo1', 'Algo2', 'Algo3']\n",
    "# datasets = ['sift1m']\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\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\n",
    "# -----------------------------\n",
    "n_datasets = len(datasets)\n",
    "fig, axes = plt.subplots(nrows=1, ncols=n_datasets, figsize=(4.5 * n_datasets, 6))\n",
    "axes = axes.flatten() if n_datasets > 1 else [axes]\n",
    "\n",
    "# -----------------------------\n",
    "# 5. Plot Each Dataset\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",
    "        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['Memory (GB)'],\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",
    "        mem_min, mem_max = df_subset['Memory (GB)'].min(), df_subset['Memory (GB)'].max()\n",
    "\n",
    "        x_margin = 0.02 * (recall_max - recall_min if recall_max > recall_min else 0.1)\n",
    "        y_margin = 0.05 * (mem_max - mem_min if mem_max > mem_min else 1)\n",
    "\n",
    "        ax.set_xlim(recall_min - x_margin, recall_max + x_margin)\n",
    "        ax.set_ylim(mem_min - y_margin, mem_max + y_margin)\n",
    "\n",
    "    ax.set_xlabel('Recall', fontsize=13, fontweight='bold')\n",
    "    ax.set_ylabel('Memory (GB)', fontsize=13, 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=13,\n",
    "        fontweight='bold'\n",
    "    )\n",
    "\n",
    "# -----------------------------\n",
    "# 6. Legend (Closer and cleaner)\n",
    "# -----------------------------\n",
    "handles, labels = axes[0].get_legend_handles_labels()\n",
    "\n",
    "if n_datasets == 1:\n",
    "    # Vertical legend extremely close to the plot\n",
    "    fig.legend(\n",
    "        handles, labels,\n",
    "        loc='center left',\n",
    "        bbox_to_anchor=(0.995, 0.5),  # << closer to the plot edge\n",
    "        fontsize=13,\n",
    "        frameon=False\n",
    "    )\n",
    "    fig.set_size_inches(5.0, 6)          # narrower width\n",
    "    plt.tight_layout(rect=[0, 0, 0.965, 1])  # expand usable width\n",
    "else:\n",
    "    # Horizontal legend for multiple subplots\n",
    "    fig.legend(\n",
    "        handles, labels,\n",
    "        loc='upper center',\n",
    "        bbox_to_anchor=(0.5, 1.08),\n",
    "        ncol=len(algorithms),\n",
    "        fontsize=13,\n",
    "        frameon=False\n",
    "    )\n",
    "    plt.tight_layout(rect=[0, 0, 1, 1])\n",
    "\n",
    "# -----------------------------\n",
    "# 7. Save & Show\n",
    "# -----------------------------\n",
    "fig.savefig('query_performance_plot_single_row.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
}
