{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "plt.style.use('seaborn-whitegrid')\n",
    "plt.rcParams['pdf.fonttype'] = 42\n",
    "plt.rcParams['ps.fonttype'] = 42\n",
    "\n",
    "import numpy as np\n",
    "import re"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "poincare_glove_hnsw_single_M12_txt = '''1\t0.325186\t6.35162 us\t90.551 dcs\t7.18945 hps\n",
    "2\t0.51841\t8.96329 us\t118.237 dcs\t9.10878 hps\n",
    "3\t0.629707\t10.8559 us\t136.952 dcs\t10.501 hps\n",
    "4\t0.701353\t12.1458 us\t152.162 dcs\t11.674 hps\n",
    "5\t0.752963\t14.5191 us\t165.8 dcs\t12.766 hps\n",
    "6\t0.788419\t15.2937 us\t177.905 dcs\t13.7707 hps\n",
    "7\t0.816637\t17.057 us\t189.484 dcs\t14.7482 hps\n",
    "8\t0.838141\t17.8714 us\t200.599 dcs\t15.7018 hps\n",
    "9\t0.857338\t19.5108 us\t211.542 dcs\t16.6466 hps\n",
    "10\t0.871709\t20.5052 us\t222.019 dcs\t17.5686 hps\n",
    "20\t0.940732\t31.4499 us\t321.889 dcs\t26.8945 hps\n",
    "30\t0.965488\t41.9803 us\t415.749 dcs\t36.4228 hps\n",
    "40\t0.976398\t51.0752 us\t505.098 dcs\t46.092 hps\n",
    "50\t0.983006\t60.69 us\t590.909 dcs\t55.8489 hps\n",
    "60\t0.988042\t70.1376 us\t673.419 dcs\t65.6568 hps\n",
    "70\t0.98972\t78.6389 us\t753.262 dcs\t75.529 hps\n",
    "80\t0.991608\t87.6088 us\t830.12 dcs\t85.4075 hps\n",
    "90\t0.992447\t96.564 us\t904.14 dcs\t95.294 hps\n",
    "100\t0.993916\t104.766 us\t976.349 dcs\t105.231 hps\n",
    "140\t0.996538\t138.188 us\t1244.99 dcs\t144.979 hps\n",
    "180\t0.997587\t169.838 us\t1487.62 dcs\t184.807 hps\n",
    "220\t0.998007\t199.445 us\t1709.82 dcs\t224.687 hps\n",
    "260\t0.998426\t228.212 us\t1915.09 dcs\t264.574 hps\n",
    "300\t0.998741\t256.442 us\t2106.42 dcs\t304.475 hps\n",
    "340\t0.998951\t283.286 us\t2286.19 dcs\t344.388 hps\n",
    "380\t0.998951\t308.223 us\t2455.95 dcs\t384.329 hps\n",
    "420\t0.999266\t334.326 us\t2617.13 dcs\t424.238 hps\n",
    "460\t0.999266\t358.634 us\t2770.48 dcs\t464.163 hps\n",
    "500\t0.999266\t382.769 us\t2916.79 dcs\t504.094 hps\n",
    "'''\n",
    "\n",
    "poincare_glove_hnsw_single_M10_txt = '''1\t0.281758\t5.25386 us\t76.4441 dcs\t6.79241 hps\n",
    "2\t0.477919\t7.46816 us\t101.928 dcs\t8.80804 hps\n",
    "3\t0.587958\t9.13784 us\t118.602 dcs\t10.2225 hps\n",
    "4\t0.661911\t10.6234 us\t132.623 dcs\t11.447 hps\n",
    "5\t0.718976\t12.0946 us\t145.438 dcs\t12.6068 hps\n",
    "6\t0.758733\t13.3903 us\t156.662 dcs\t13.6545 hps\n",
    "7\t0.791671\t14.5763 us\t167.106 dcs\t14.6493 hps\n",
    "8\t0.812336\t15.7073 us\t177.015 dcs\t15.6026 hps\n",
    "9\t0.831952\t16.7758 us\t186.825 dcs\t16.565 hps\n",
    "10\t0.848736\t17.8375 us\t196.476 dcs\t17.525 hps\n",
    "20\t0.926151\t27.2959 us\t285.153 dcs\t26.8441 hps\n",
    "30\t0.956362\t36.0097 us\t368.191 dcs\t36.3101 hps\n",
    "40\t0.96916\t44.4325 us\t448.106 dcs\t45.9423 hps\n",
    "50\t0.977866\t52.7066 us\t525.27 dcs\t55.6838 hps\n",
    "60\t0.983531\t60.8794 us\t599.846 dcs\t65.474 hps\n",
    "70\t0.986258\t68.6791 us\t672.148 dcs\t75.3218 hps\n",
    "80\t0.988356\t76.5761 us\t742.214 dcs\t85.1896 hps\n",
    "90\t0.989825\t84.283 us\t809.88 dcs\t95.0869 hps\n",
    "100\t0.991293\t91.9283 us\t875.925 dcs\t104.995 hps\n",
    "140\t0.994965\t121.782 us\t1123.57 dcs\t144.718 hps\n",
    "180\t0.996433\t150.314 us\t1349.37 dcs\t184.547 hps\n",
    "220\t0.996958\t177.778 us\t1557.44 dcs\t224.4 hps\n",
    "260\t0.997797\t204.485 us\t1751.25 dcs\t264.289 hps\n",
    "300\t0.998322\t229.827 us\t1933.04 dcs\t304.195 hps\n",
    "340\t0.998531\t254.77 us\t2104.52 dcs\t344.101 hps\n",
    "380\t0.998531\t278.786 us\t2267.48 dcs\t384.04 hps\n",
    "420\t0.998846\t302.34 us\t2422.57 dcs\t423.959 hps\n",
    "460\t0.998951\t325.19 us\t2570.76 dcs\t463.87 hps\n",
    "500\t0.998951\t347.717 us\t2712.81 dcs\t503.808 hps\n",
    "'''\n",
    "\n",
    "poincare_glove_hnsw_single_M14_txt = '''1\t0.354977\t6.85493 us\t100.592 dcs\t7.20434 hps\n",
    "2\t0.54883\t9.25323 us\t129.544 dcs\t9.03042 hps\n",
    "3\t0.65331\t11.0137 us\t148.552 dcs\t10.3297 hps\n",
    "4\t0.724221\t12.6715 us\t164.672 dcs\t11.4727 hps\n",
    "5\t0.77153\t14.2172 us\t179.274 dcs\t12.5435 hps\n",
    "6\t0.805413\t15.5924 us\t192.377 dcs\t13.5352 hps\n",
    "7\t0.834784\t16.9319 us\t204.983 dcs\t14.5049 hps\n",
    "8\t0.853561\t18.2491 us\t217.065 dcs\t15.452 hps\n",
    "9\t0.871499\t19.5365 us\t228.839 dcs\t16.3859 hps\n",
    "10\t0.885031\t20.8085 us\t240.378 dcs\t17.3167 hps\n",
    "20\t0.949019\t36.5911 us\t348.931 dcs\t26.6073 hps\n",
    "30\t0.970943\t42.1804 us\t451.261 dcs\t36.1586 hps\n",
    "40\t0.980069\t51.9846 us\t548.741 dcs\t45.866 hps\n",
    "50\t0.985104\t61.464 us\t641.583 dcs\t55.6405 hps\n",
    "60\t0.989195\t70.7888 us\t730.472 dcs\t65.4784 hps\n",
    "70\t0.990979\t79.6089 us\t816.355 dcs\t75.3659 hps\n",
    "80\t0.992552\t88.5447 us\t898.677 dcs\t85.2562 hps\n",
    "90\t0.993706\t97.1924 us\t977.922 dcs\t95.1639 hps\n",
    "100\t0.994335\t105.785 us\t1054.55 dcs\t105.091 hps\n",
    "140\t0.997168\t143.556 us\t1339.05 dcs\t144.856 hps\n",
    "180\t0.998007\t172.237 us\t1594.1 dcs\t184.71 hps\n",
    "220\t0.998322\t199.22 us\t1825.85 dcs\t224.593 hps\n",
    "260\t0.998636\t231.865 us\t2038.83 dcs\t264.482 hps\n",
    "300\t0.998951\t276.077 us\t2236.46 dcs\t304.394 hps\n",
    "340\t0.999161\t280.004 us\t2421.19 dcs\t344.319 hps\n",
    "380\t0.999266\t304.82 us\t2594.41 dcs\t384.274 hps\n",
    "420\t0.999266\t329.611 us\t2757.91 dcs\t424.217 hps\n",
    "460\t0.999266\t352.346 us\t2912.92 dcs\t464.163 hps\n",
    "500\t0.999266\t377.092 us\t3059.81 dcs\t504.119 hps\n",
    "'''\n",
    "\n",
    "glove_hnsw_single_M10_txt = '''1\t0.210951\t2.75296 us\t72.1453 dcs\t5.30368 hps\n",
    "2\t0.396832\t4.17571 us\t106.466 dcs\t7.58575 hps\n",
    "3\t0.510752\t5.23162 us\t131.16 dcs\t9.27714 hps\n",
    "4\t0.589846\t6.3127 us\t151.102 dcs\t10.6838 hps\n",
    "5\t0.646701\t7.36148 us\t168.434 dcs\t11.9374 hps\n",
    "6\t0.68929\t8.29393 us\t183.827 dcs\t13.0721 hps\n",
    "7\t0.721074\t9.1798 us\t198.232 dcs\t14.155 hps\n",
    "8\t0.748243\t10.1572 us\t212.278 dcs\t15.2279 hps\n",
    "9\t0.770167\t11.0046 us\t225.534 dcs\t16.2525 hps\n",
    "10\t0.790727\t11.8787 us\t238.604 dcs\t17.2761 hps\n",
    "20\t0.887758\t19.5217 us\t355.403 dcs\t26.8863 hps\n",
    "30\t0.929193\t26.2622 us\t462.215 dcs\t36.3451 hps\n",
    "40\t0.951851\t32.7713 us\t565.267 dcs\t45.9654 hps\n",
    "50\t0.965383\t38.9974 us\t663.827 dcs\t55.609 hps\n",
    "60\t0.973461\t45.2278 us\t759.91 dcs\t65.345 hps\n",
    "70\t0.97881\t53.8316 us\t853.728 dcs\t75.1929 hps\n",
    "80\t0.983006\t66.3074 us\t944.349 dcs\t85.0111 hps\n",
    "90\t0.986678\t63.2374 us\t1032.45 dcs\t94.8522 hps\n",
    "100\t0.989195\t70.1578 us\t1118.37 dcs\t104.738 hps\n",
    "140\t0.994755\t107.928 us\t1443.44 dcs\t144.48 hps\n",
    "180\t0.996643\t115.907 us\t1741.26 dcs\t184.267 hps\n",
    "220\t0.997482\t142.665 us\t2017.74 dcs\t224.173 hps\n",
    "260\t0.997902\t160.946 us\t2275.12 dcs\t264.078 hps\n",
    "300\t0.998217\t194.735 us\t2517.05 dcs\t304.033 hps\n",
    "340\t0.998322\t203.562 us\t2744.77 dcs\t343.949 hps\n",
    "380\t0.998531\t224.308 us\t2960.49 dcs\t383.892 hps\n",
    "420\t0.998741\t252.282 us\t3164.31 dcs\t423.888 hps\n",
    "460\t0.998741\t267.237 us\t3358.54 dcs\t463.902 hps\n",
    "500\t0.998741\t293.639 us\t3543.2 dcs\t503.877 hps\n",
    "'''\n",
    "\n",
    "glove_hnsw_single_M12_txt = '''1\t0.2484\t3.06189 us\t85.6232 dcs\t5.36673 hps\n",
    "2\t0.437428\t4.74342 us\t124.111 dcs\t7.5246 hps\n",
    "3\t0.549984\t6.25071 us\t151.571 dcs\t9.11172 hps\n",
    "4\t0.625407\t7.73828 us\t173.821 dcs\t10.4371 hps\n",
    "5\t0.677331\t8.57673 us\t193.309 dcs\t11.6232 hps\n",
    "6\t0.718137\t9.5417 us\t211.038 dcs\t12.7336 hps\n",
    "7\t0.748453\t10.9083 us\t227.698 dcs\t13.7927 hps\n",
    "8\t0.772999\t11.8741 us\t243.542 dcs\t14.813 hps\n",
    "9\t0.795028\t12.4199 us\t258.752 dcs\t15.8034 hps\n",
    "10\t0.811917\t13.7966 us\t273.802 dcs\t16.7949 hps\n",
    "20\t0.905172\t22.8185 us\t410.648 dcs\t26.3196 hps\n",
    "30\t0.942935\t30.9249 us\t536.536 dcs\t35.7842 hps\n",
    "40\t0.961817\t38.4222 us\t657.363 dcs\t45.3909 hps\n",
    "50\t0.974719\t45.807 us\t773.815 dcs\t55.102 hps\n",
    "60\t0.980489\t53.1961 us\t886.657 dcs\t64.9048 hps\n",
    "70\t0.985209\t60.0968 us\t995.402 dcs\t74.7293 hps\n",
    "80\t0.988461\t67.2281 us\t1101 dcs\t84.5906 hps\n",
    "90\t0.98972\t73.9391 us\t1203 dcs\t94.4487 hps\n",
    "100\t0.992762\t81.0436 us\t1302.73 dcs\t104.384 hps\n",
    "140\t0.996643\t108.526 us\t1675.27 dcs\t144.09 hps\n",
    "180\t0.998112\t135.304 us\t2013.96 dcs\t183.925 hps\n",
    "220\t0.998636\t160.566 us\t2325.39 dcs\t223.853 hps\n",
    "260\t0.998741\t186.856 us\t2613.4 dcs\t263.786 hps\n",
    "300\t0.998951\t210.004 us\t2882.31 dcs\t303.72 hps\n",
    "340\t0.999056\t234.123 us\t3132.76 dcs\t343.637 hps\n",
    "380\t0.999056\t257.646 us\t3368.82 dcs\t383.606 hps\n",
    "420\t0.999161\t279.79 us\t3590.45 dcs\t423.567 hps\n",
    "460\t0.999161\t302.263 us\t3800.17 dcs\t463.583 hps\n",
    "500\t0.999266\t324.009 us\t3998.45 dcs\t503.54 hps\n",
    "'''\n",
    "\n",
    "glove_hnsw_single_M14_txt = '''1\t0.284171\t3.47288 us\t101.08 dcs\t5.42736 hps\n",
    "2\t0.473198\t5.21221 us\t142.318 dcs\t7.43145 hps\n",
    "3\t0.579566\t6.64188 us\t171.91 dcs\t8.92122 hps\n",
    "4\t0.650267\t7.94912 us\t196.246 dcs\t10.1833 hps\n",
    "5\t0.700724\t9.14686 us\t217.505 dcs\t11.3186 hps\n",
    "6\t0.74048\t10.3106 us\t237.612 dcs\t12.414 hps\n",
    "7\t0.770796\t11.3793 us\t255.922 dcs\t13.4296 hps\n",
    "8\t0.796811\t12.4188 us\t273.933 dcs\t14.4431 hps\n",
    "9\t0.814749\t13.4828 us\t290.915 dcs\t15.4118 hps\n",
    "10\t0.833001\t14.5228 us\t308.318 dcs\t16.4087 hps\n",
    "20\t0.920172\t24.1269 us\t463.318 dcs\t25.8338 hps\n",
    "30\t0.951432\t32.8264 us\t607.439 dcs\t35.3119 hps\n",
    "40\t0.96937\t44.1518 us\t745.294 dcs\t44.9427 hps\n",
    "50\t0.980594\t63.5437 us\t877.986 dcs\t54.7038 hps\n",
    "60\t0.985839\t59.2289 us\t1005.63 dcs\t64.5105 hps\n",
    "70\t0.990244\t64.2434 us\t1128.5 dcs\t74.3466 hps\n",
    "80\t0.992238\t71.9107 us\t1247.34 dcs\t84.2253 hps\n",
    "90\t0.994021\t79.4312 us\t1362.33 dcs\t94.1307 hps\n",
    "100\t0.995384\t86.8654 us\t1473.68 dcs\t104.045 hps\n",
    "140\t0.998112\t115.768 us\t1888.85 dcs\t143.802 hps\n",
    "180\t0.998636\t143.565 us\t2263.22 dcs\t183.656 hps\n",
    "220\t0.998846\t170.466 us\t2604.32 dcs\t223.529 hps\n",
    "260\t0.998951\t196.722 us\t2917.94 dcs\t263.44 hps\n",
    "300\t0.999056\t221.635 us\t3208.66 dcs\t303.379 hps\n",
    "340\t0.999161\t253.881 us\t3478.36 dcs\t343.325 hps\n",
    "380\t0.999161\t320.85 us\t3730.42 dcs\t383.245 hps\n",
    "420\t0.999266\t296.956 us\t3965.98 dcs\t423.222 hps\n",
    "460\t0.999266\t315.858 us\t4187.23 dcs\t463.221 hps\n",
    "500\t0.999266\t338.186 us\t4395.46 dcs\t503.166 hps\n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "splitted_poincare_glove = re.findall(r\"[0-9.]+\", poincare_glove_hnsw_single_M12_txt)\n",
    "poincare_glove_M12_recall = np.array(list(map(float, splitted_poincare_glove[1::5])))\n",
    "poincare_glove_M12_ms = np.array(list(map(float, splitted_poincare_glove[2::5])))\n",
    "poincare_glove_M12_dcs = np.array(list(map(float, splitted_poincare_glove[3::5])))\n",
    "poincare_glove_M12_hops = np.array(list(map(float, splitted_poincare_glove[4::5])))\n",
    "\n",
    "splitted_glove = re.findall(r\"[0-9.]+\", glove_hnsw_single_M12_txt)\n",
    "glove_M12_recall = np.array(list(map(float, splitted_glove[1::5])))\n",
    "glove_M12_ms = np.array(list(map(float, splitted_glove[2::5])))\n",
    "glove_M12_dcs = np.array(list(map(float, splitted_glove[3::5])))\n",
    "glove_M12_hops = np.array(list(map(float, splitted_glove[4::5])))\n",
    "\n",
    "splitted_poincare_glove = re.findall(r\"[0-9.]+\", poincare_glove_hnsw_single_M14_txt)\n",
    "poincare_glove_M14_recall = np.array(list(map(float, splitted_poincare_glove[1::5])))\n",
    "poincare_glove_M14_ms = np.array(list(map(float, splitted_poincare_glove[2::5])))\n",
    "poincare_glove_M14_dcs = np.array(list(map(float, splitted_poincare_glove[3::5])))\n",
    "poincare_glove_M14_hops = np.array(list(map(float, splitted_poincare_glove[4::5])))\n",
    "\n",
    "splitted_glove = re.findall(r\"[0-9.]+\", glove_hnsw_single_M14_txt)\n",
    "glove_M14_recall = np.array(list(map(float, splitted_glove[1::5])))\n",
    "glove_M14_ms = np.array(list(map(float, splitted_glove[2::5])))\n",
    "glove_M14_dcs = np.array(list(map(float, splitted_glove[3::5])))\n",
    "glove_M14_hops = np.array(list(map(float, splitted_glove[4::5])))\n",
    "\n",
    "splitted_poincare_glove = re.findall(r\"[0-9.]+\", poincare_glove_hnsw_single_M10_txt)\n",
    "poincare_glove_M10_recall = np.array(list(map(float, splitted_poincare_glove[1::5])))\n",
    "poincare_glove_M10_ms = np.array(list(map(float, splitted_poincare_glove[2::5])))\n",
    "poincare_glove_M10_dcs = np.array(list(map(float, splitted_poincare_glove[3::5])))\n",
    "poincare_glove_M10_hops = np.array(list(map(float, splitted_poincare_glove[4::5])))\n",
    "\n",
    "splitted_glove = re.findall(r\"[0-9.]+\", glove_hnsw_single_M10_txt)\n",
    "glove_M10_recall = np.array(list(map(float, splitted_glove[1::5])))\n",
    "glove_M10_ms = np.array(list(map(float, splitted_glove[2::5])))\n",
    "glove_M10_dcs = np.array(list(map(float, splitted_glove[3::5])))\n",
    "glove_M10_hops = np.array(list(map(float, splitted_glove[4::5])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(9, 6))\n",
    "\n",
    "# Baseline\n",
    "plt.plot(poincare_glove_M10_dcs, poincare_glove_M10_recall, 'g--', label='Poincaré GloVe')\n",
    "plt.plot(glove_M10_dcs, glove_M10_recall, 'b--', label='GloVe')\n",
    "\n",
    "plt.xticks( fontsize=11)\n",
    "plt.xlim([100, 1500])\n",
    "plt.ylim([0.5, 1.01])\n",
    "\n",
    "plt.xlabel('DCS', fontsize=14)\n",
    "plt.ylabel('Recall@1', fontsize=14)\n",
    "plt.legend(loc=4, fontsize=15)\n",
    "\n",
    "pp = PdfPages(\"./glove.pdf\")\n",
    "pp.savefig(bbox_inches='tight')\n",
    "pp.close()"
   ]
  }
 ],
 "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.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
