{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b3960d83-1962-4f28-bdbc-4ebf6caf3927",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "import shared"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c884650f-c98d-4f14-a132-241d9e2e5d2a",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams.update({\n",
    "    'text.latex.preamble': r'\\usepackage{amsfonts}\\usepackage{bm}'\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9f7abf69-007a-4f3d-a9dd-afa38e5f18cc",
   "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>digit</th>\n",
       "      <th>arl</th>\n",
       "      <th>edd</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>1000</td>\n",
       "      <td>88.84</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>10000</td>\n",
       "      <td>108.17</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>100000</td>\n",
       "      <td>128.89</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2</td>\n",
       "      <td>1000</td>\n",
       "      <td>263.39</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2</td>\n",
       "      <td>10000</td>\n",
       "      <td>336.52</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   digit     arl     edd\n",
       "0      1    1000   88.84\n",
       "0      1   10000  108.17\n",
       "0      1  100000  128.89\n",
       "0      2    1000  263.39\n",
       "0      2   10000  336.52"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.read_csv(f\"../results/edd_distribution_free-mmdew.csv\", index_col=0)\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "9e67e43b-98e5-49dc-9c86-83ed2a1c7fbe",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = df.rename(columns={\"arl\" : \"logARL\", \"edd\" : \"EDD\"})\n",
    "df[\"algorithm\"] = \"Online RFF MMD\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "261e5bc2-9ff5-46e9-9fca-d2a10a09389e",
   "metadata": {},
   "outputs": [],
   "source": [
    "df[\"logARL\"] = np.log10(df[\"logARL\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "eff3dae9-6142-4ffb-ad6b-470a48fbbf46",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = df.dropna()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "902103aa-c8e9-456f-a772-a3d57bb7806d",
   "metadata": {},
   "outputs": [],
   "source": [
    "sns_conf = shared.get_sns_conf([\"Online RFF MMD\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7e53e0d7-2bf2-4491-bc74-4de9f87b758a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x300 with 9 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, (row1,row2,row3) = plt.subplots(3,3, sharex=True, sharey=True, figsize=(8,3),constrained_layout=True)\n",
    "\n",
    "for digit, ax in zip([1,2,3],row1):\n",
    "    sns.lineplot(data=df[df[\"digit\"] == digit], x=\"logARL\", y=\"EDD\", hue=\"algorithm\",ax=ax,style=\"algorithm\",**sns_conf)\n",
    "for digit, ax in zip([4,5,6],row2):\n",
    "    sns.lineplot(data=df[df[\"digit\"] == digit], x=\"logARL\", y=\"EDD\", hue=\"algorithm\",ax=ax,style=\"algorithm\",**sns_conf)\n",
    "for digit, ax in zip([7,8,9],row3):\n",
    "    sns.lineplot(data=df[df[\"digit\"] == digit], x=\"logARL\", y=\"EDD\", hue=\"algorithm\",ax=ax,style=\"algorithm\",**sns_conf)\n",
    "    ax.set_xlabel(\"$\\\\log_{10}$ ARL\")\n",
    "\n",
    "\n",
    "Line, Label = row1[0].get_legend_handles_labels()\n",
    "\n",
    "for row in [row1,row2,row3]:\n",
    "    for ax in row:\n",
    "        ax.get_legend().remove()\n",
    "\n",
    "fig.legend(Line, Label, loc=\"upper center\", bbox_to_anchor=(0.527, 1.11), ncol=1)\n",
    "plt.savefig(\"../../article/figures/edd_mnist1-9_distribution_free.pdf\", bbox_inches=None)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ba023c75-f2e1-461f-8de5-f1bc7aafe872",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
