{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Matplotlib is building the font cache; this may take a moment.\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "L_s = np.loadtxt(\"./Comparison_SW_Sinkhorn_d3\").reshape(1,5,20)\n",
    "L_w = np.loadtxt(\"./Comparison_SW_W_d3\").reshape(1,5,20)\n",
    "\n",
    "# print(np.loadtxt(\"./Comparison_SW_Sinkhorn_d3\").shape)\n",
    "\n",
    "L_hsw = np.zeros((1, 2, 5, 20))\n",
    "for k, proj in enumerate([200]):\n",
    "    L_hsw[0, k] = np.loadtxt(\"./Comparison_HSW_projs_\"+str(proj)+\"_d3\")\n",
    "#     L_hsw[0, k] = np.loadtxt(\"./Colab_20trys/Comparison_HSW_projs_\"+str(proj))\n",
    "\n",
    "L_hhsw = np.zeros((1, 2, 5, 20))\n",
    "for k, proj in enumerate([200]):\n",
    "    L_hhsw[0, k] = np.loadtxt(\"./Comparison_HHSWp_projs_\"+str(proj)+\"_d3\")\n",
    "#     L_hhsw[0, k] = np.loadtxt(\"./Colab_20trys/Comparison_HHSWp_projs_\"+str(proj))\n",
    "\n",
    "    \n",
    "L_swp = np.zeros((1, 2, 5, 20))\n",
    "for k, proj in enumerate([200]):\n",
    "    L_swp[0, k] = np.loadtxt(\"./Comparison_SWp_projs_\"+str(proj)+\"_d3\")\n",
    "    \n",
    "L_swl = np.zeros((1, 2, 5, 20))\n",
    "for k, proj in enumerate([200]):\n",
    "    L_swl[0, k] = np.loadtxt(\"./Comparison_SWl_projs_\"+str(proj)+\"_d3\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/clement/anaconda3/lib/python3.7/site-packages/numpy/core/_methods.py:229: RuntimeWarning: invalid value encountered in subtract\n",
      "  x = asanyarray(arr - arrmean)\n",
      "/home/clement/anaconda3/lib/python3.7/site-packages/numpy/core/_methods.py:229: RuntimeWarning: invalid value encountered in subtract\n",
      "  x = asanyarray(arr - arrmean)\n"
     ]
    },
    {
     "data": {
      "image/png": "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365duw5ec801ju6wrh33Gd5+uGh0E06cOCGvqqqSh5dBD3Pw4EGl2+0Wxo8f744lDSDd7OfMmTPwrrvuspaUlPxSU1OTt3r16sLRo0d7AMBoNDbxSvfTTz+p9uzZowsEAuRwOCLnzOuvv556xx13VIeXwz5Xjhw5ogitItumT432IooiVq5cedxqtebl5eUVlJaWKu68886scPxTTz2VumnTpoRdu3YdLC4u/hkAbrvttr6xxvd0ysvLxaKiItWjjz5aZTabA4IgoH///g1PPvlklVqtZmEf3eH0V1xxxaC5c+f2mjFjRn+tVjsqMzNz2EcffZTQWvl//etfzSkpKSO+++67yFLn+/btUw8bNmywVqsdNXLkyEv27dsXWcbc6XQKv/nNbzLDvrynTZvW/+jRoxFHSVdcccWg+++/P3PatGn9dTrdqBdeeCHllltuybrpppv63n777X30ev2lycnJI1577TVLc1s4EvyJqZuwc+dOrSiKGD16dBPHP7m5uWqz2ezPzs5u+PDDDxPaSgMA77zzTvLEiRPtc+fOjawXNWnSJM+kSZPCohFx9QoAS5cuTbvnnnuqVq5cmWS1WkWDwRDcsWOHZs+ePbqPPvrovJcI//777zUajSY4cuRIb9up28eyZctOh7+np6f7H3744cq5c+dGbvoffvhh0hNPPFEWdk/7xhtvnBo2bNiww4cPKwYNGuRrK76j7W2Jbz84mFlz2nVB3L0mZug8V98zOGanT6mpqYHs7GzvAw88kPXb3/626sorr3SPGjXK25IzozBr1641//3vfz/21VdfFb700kvJ8+bNy5o9e/bPer0+GJ3uD3/4Q/qnn35q+u677w5Fuw9etWqVZcOGDYW9evVqmDNnTt9HHnkk8/vvvz8KAA899FBmfn6++ocffjhoNpsDc+fOzZw1a1b2gQMHCsI+OD755BPL6tWrj23evLnQ7XYL9913X+9vvvnG9P777xeuWrXq5EcffZTw29/+tt/s2bMdAwcO5D5TmsFbGt2E3bt3a/v06ePV6XRN2vx5eXma4cOHu2NNA0i+Mnbt2mV48cUXk/fu3atCM8KuXgGpFbB169aExYsXV+h0ukDY7ekrr7ySOnv27JqOWO589+7d2iFDhnjO5hXtrrvu6h3t0rP5Z8mSJamx7Gvr1q36gQMH1gGA1WoVy8rKFGPHjo0c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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6,2))\n",
    "\n",
    "# plt.rcParams.update({\n",
    "#     \"text.usetex\": True,\n",
    "#     \"font.family\": \"serif\",\n",
    "#     \"font.serif\": \"cm\"\n",
    "# })\n",
    "\n",
    "ds = [3]\n",
    "samples = [int(1e2),int(1e3),int(1e4),int(1e5/2),int(1e5)]\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    for l, n_projs in enumerate([200]):\n",
    "        m = np.mean(L_hsw[i, l], axis=-1)\n",
    "        s = np.std(L_hsw[i, l], axis=-1)\n",
    "        \n",
    "        plt.loglog(samples, m, label=r\"$GHSW_2$,\" + r\" $L=$\"+str(n_projs))\n",
    "        plt.fill_between(samples, m-s, m+s,alpha=0.5)\n",
    "        \n",
    "        m = np.mean(L_hhsw[i, l], axis=-1)\n",
    "        s = np.std(L_hhsw[i, l], axis=-1)\n",
    "        \n",
    "        plt.loglog(samples, m, label=r\"$HHSW_2$,\" + r\" $L=$\"+str(n_projs))\n",
    "        plt.fill_between(samples, m-s, m+s,alpha=0.5)\n",
    "        \n",
    "        m = np.mean(L_swp[i, l], axis=-1)\n",
    "        s = np.std(L_swp[i, l], axis=-1)\n",
    "        \n",
    "        plt.loglog(samples, m, label=r\"$SW_2$,\" + r\" $L=$\"+str(n_projs))\n",
    "        plt.fill_between(samples, m-s, m+s,alpha=0.5)\n",
    "        \n",
    "#         m = np.mean(L_swl[i, l], axis=-1)\n",
    "#         s = np.std(L_swl[i, l], axis=-1)\n",
    "        \n",
    "#         plt.loglog(samples, m, label=r\"$SWl_2$,\" + r\" $L=$\"+str(n_projs))\n",
    "#         plt.fill_between(samples, m-s, m+s,alpha=0.5)\n",
    "        \n",
    "\n",
    "    m_w = np.mean(L_w[i], axis=-1)\n",
    "    s_w = np.std(L_w[i], axis=-1)\n",
    "\n",
    "    plt.loglog(samples, m_w, label=r\"Wasserstein\")\n",
    "    plt.fill_between(samples, m_w-s_w, m_w+s_w, alpha=0.5)\n",
    "\n",
    "\n",
    "    m_s = np.mean(L_s[i], axis=-1)\n",
    "    s_s = np.std(L_s[i], axis=-1)\n",
    "\n",
    "    plt.loglog(samples, m_s, label=r\"Sinkhorn\")\n",
    "    plt.fill_between(samples, m_s-s_s, m_s+s_s, alpha=0.5)\n",
    "\n",
    "plt.xlabel(r\"Number of samples in each distribution\", fontsize=13)\n",
    "plt.ylabel(r\"Seconds\", fontsize=13)\n",
    "#     plt.yscale(\"log\")\n",
    "    # plt.xscale(\"log\")\n",
    "    \n",
    "plt.legend(fontsize=13, bbox_to_anchor=(0,1.02,1,0.2), loc=\"lower left\", ncol=2)\n",
    "# plt.title(\"Computational Time\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.yticks([10,1,0.1,0.01,0.001])\n",
    "\n",
    "plt.savefig(\"./Comparison_Time_HHSW.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.font_manager"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/clement/anaconda3/lib/python3.7/site-packages/numpy/core/_methods.py:229: RuntimeWarning: invalid value encountered in subtract\n",
      "  x = asanyarray(arr - arrmean)\n",
      "/home/clement/anaconda3/lib/python3.7/site-packages/numpy/core/_methods.py:229: RuntimeWarning: invalid value encountered in subtract\n",
      "  x = asanyarray(arr - arrmean)\n",
      "findfont: Font family ['serif'] not found. Falling back to DejaVu Sans.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6,2))\n",
    "\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": \"cm\"\n",
    "})\n",
    "\n",
    "ds = [3]\n",
    "samples = [int(1e2),int(1e3),int(1e4),int(1e5/2),int(1e5)]\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    for l, n_projs in enumerate([200]):\n",
    "        m = np.mean(L_hsw[i, l], axis=-1)\n",
    "        s = np.std(L_hsw[i, l], axis=-1)\n",
    "        \n",
    "        plt.loglog(samples, m, label=r\"$GHSW_2$,\" + r\" $L=$\"+str(n_projs))\n",
    "        plt.fill_between(samples, m-s, m+s,alpha=0.5)\n",
    "        \n",
    "        m = np.mean(L_hhsw[i, l], axis=-1)\n",
    "        s = np.std(L_hhsw[i, l], axis=-1)\n",
    "        \n",
    "        plt.loglog(samples, m, label=r\"$HHSW_2$,\" + r\" $L=$\"+str(n_projs))\n",
    "        plt.fill_between(samples, m-s, m+s,alpha=0.5)\n",
    "        \n",
    "        m = np.mean(L_swp[i, l], axis=-1)\n",
    "        s = np.std(L_swp[i, l], axis=-1)\n",
    "        \n",
    "        plt.loglog(samples, m, label=r\"$SW_2$,\" + r\" $L=$\"+str(n_projs))\n",
    "        plt.fill_between(samples, m-s, m+s,alpha=0.5)\n",
    "        \n",
    "#         m = np.mean(L_swl[i, l], axis=-1)\n",
    "#         s = np.std(L_swl[i, l], axis=-1)\n",
    "        \n",
    "#         plt.loglog(samples, m, label=r\"$SWl_2$,\" + r\" $L=$\"+str(n_projs))\n",
    "#         plt.fill_between(samples, m-s, m+s,alpha=0.5)\n",
    "        \n",
    "\n",
    "    m_w = np.mean(L_w[i], axis=-1)\n",
    "    s_w = np.std(L_w[i], axis=-1)\n",
    "\n",
    "    plt.loglog(samples, m_w, label=r\"Wasserstein\")\n",
    "    plt.fill_between(samples, m_w-s_w, m_w+s_w, alpha=0.5)\n",
    "\n",
    "\n",
    "    m_s = np.mean(L_s[i], axis=-1)\n",
    "    s_s = np.std(L_s[i], axis=-1)\n",
    "\n",
    "    plt.loglog(samples, m_s, label=r\"Sinkhorn\")\n",
    "    plt.fill_between(samples, m_s-s_s, m_s+s_s, alpha=0.5)\n",
    "\n",
    "plt.xlabel(r\"Number of samples in each distribution\", fontsize=13)\n",
    "plt.ylabel(r\"Seconds\", fontsize=13)\n",
    "#     plt.yscale(\"log\")\n",
    "    # plt.xscale(\"log\")\n",
    "    \n",
    "plt.legend(fontsize=13, bbox_to_anchor=(0,1.02,1,0.2), loc=\"lower left\", ncol=2)\n",
    "# plt.title(\"Computational Time\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.yticks([10,1,0.1,0.01,0.001])\n",
    "\n",
    "plt.savefig(\"./Comparison_Time_LateX.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.7.9"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": true,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
