{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Advection Learning experiment of 5.1\n",
    "\n",
    "Creates the plot as seen in the paper (Figure 3)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import json\n",
    "import matplotlib as mpl\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "os.makedirs(\"img\", exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "MELTED_NAME_varying_difficulty = \"adv_varying_difficulty_nonlin_emulators\"\n",
    "MELTED_NAME_varying_rollout = \"adv_highest_difficulty_resnet_increasing_rollout\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "metric_data_varying_difficulty = pd.read_csv(\n",
    "    f\"../../melted/{MELTED_NAME_varying_difficulty}/metrics.csv\"\n",
    ")\n",
    "metric_data_varying_rollout = pd.read_csv(\n",
    "    f\"../../melted/{MELTED_NAME_varying_rollout}/metrics.csv\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def split_train(\n",
    "    df: pd.DataFrame,\n",
    "):\n",
    "    df[\"category\"] = df[\"train\"].apply(lambda x: x.split(\"-\")[0])\n",
    "    df[\"type\"] = df[\"category\"].apply(lambda x: \"sup\" if x in [\"one\", \"sup\"] else \"div\")\n",
    "    df[\"rollout\"] = df[\"train\"].apply(\n",
    "        lambda x: int(x.split(\";\")[1]) if x != \"one\" else 1\n",
    "    )\n",
    "\n",
    "    return df\n",
    "\n",
    "\n",
    "def read_in_kwargs(\n",
    "    df: pd.DataFrame,\n",
    "):\n",
    "    col = df[\"scenario_kwargs\"].apply(eval)\n",
    "    entries = list(col[0].keys())\n",
    "    for entry in entries:\n",
    "        df[entry] = col.apply(lambda x: x[entry])\n",
    "    return df\n",
    "\n",
    "\n",
    "def split_net(df):\n",
    "    df[\"net_type\"] = df[\"net\"].apply(lambda x: x.split(\";\")[0])\n",
    "    df[\"hidden_channels\"] = df[\"net\"].apply(\n",
    "        lambda x: int(x.split(\";\")[1])\n",
    "        if len(x.split(\";\")) == 4\n",
    "        else int(x.split(\";\")[2])\n",
    "    )\n",
    "    df[\"conv_depth\"] = df[\"net\"].apply(\n",
    "        lambda x: int(x.split(\";\")[2]) if x.split(\";\")[0].lower() == \"conv\" else 10\n",
    "    )\n",
    "\n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "metric_data_varying_difficulty = split_net(\n",
    "    read_in_kwargs(split_train(metric_data_varying_difficulty))\n",
    ")\n",
    "metric_data_varying_rollout = split_net(\n",
    "    read_in_kwargs(split_train(metric_data_varying_rollout))\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Rename some columns to make them look nicer\n",
    "metric_data_varying_difficulty = metric_data_varying_difficulty.rename(\n",
    "    columns={\n",
    "        \"net_type\": \"Arch Type\",\n",
    "        \"conv_depth\": \"Conv Depth\",\n",
    "        \"rollout\": \"Rollout\",\n",
    "        \"mean_nRMSE\": \"nRMSE\",\n",
    "        \"time_step\": \"Time Step\",\n",
    "    }\n",
    ")\n",
    "metric_data_varying_rollout = metric_data_varying_rollout.rename(\n",
    "    columns={\n",
    "        \"net_type\": \"Arch Type\",\n",
    "        \"conv_depth\": \"Conv Depth\",\n",
    "        \"rollout\": \"Rollout\",\n",
    "        \"mean_nRMSE\": \"nRMSE\",\n",
    "        \"time_step\": \"Time Step\",\n",
    "    }\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def assign_order(df: pd.DataFrame, column_name: str, order: list):\n",
    "    changing_dict = {}\n",
    "    changing_dict[column_name] = lambda data: pd.Categorical(\n",
    "        data[column_name], categories=order, ordered=True\n",
    "    )\n",
    "    df = df.assign(**changing_dict)\n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "metric_data_varying_difficulty = assign_order(\n",
    "    metric_data_varying_difficulty,\n",
    "    \"Arch Type\",\n",
    "    [\"Conv\", \"Res\", \"UNet\", \"Dil\", \"FNO\"],\n",
    ")\n",
    "metric_data_varying_rollout = assign_order(\n",
    "    metric_data_varying_rollout,\n",
    "    \"Arch Type\",\n",
    "    [\"Conv\", \"Res\", \"UNet\", \"Dil\", \"FNO\"],\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['seed', 'scenario', 'task', 'net', 'train', 'scenario_kwargs',\n",
       "       'Time Step', 'nRMSE', 'category', 'type', 'Rollout', 'advection_gamma',\n",
       "       'Arch Type', 'hidden_channels', 'Conv Depth'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "metric_data_varying_difficulty.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh8AAADVCAYAAAD3sZIqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAACP80lEQVR4nOyddXwUV9eAn9ndZOMuxBMkBEtCCN6gRQrUKG2hBlVKXai3L2/tq/ett1SAGi3UgVLcG9xdE+IJcV+93x+bLITYJtlsEpinP37NzNy5c3buyJlzj0hCCIGMjIyMjIyMjI1QtLUAMjIyMjIyMpcXsvIhIyMjIyMjY1Nk5UNGRkZGRkbGpsjKh4yMjIyMjIxNkZUPGRkZGRkZGZsiKx8yMjIyMjIyNkVWPmRkZGRkZGRsiqx8yMjIyMjIyNgUWfmQkZGRkZGRsSmy8iEjIyMjIyNjU2TlQ0ZGRkZGRsamyMqHjIyMjIyMjE2RlY9LjG+//RZ7e3sKCgos3mfBggXMnj271vqMjAxuvfVWAPbt28eqVauaJVNhYSFffvlls/aV6XikpaUxefJkunTpQnx8PDfeeCPZ2dmtcqwNGzbg4eFB3759iYyMZPTo0WzcuLFF/e3YscO8PGPGDJYtW2YNUds9ycnJxMfH11hnrd9/Yd/1PW+aIldiYiKxsbHExsbi4uJCVFQUsbGxPPLIIxb1OWHCBCoqKlrcxhKOHj3KsGHDiI2NJSoqijlz5gC1r7XLDVn5uMRYtGgR/fv3548//qi1zWAwNKmvwMBAfvzxR6BtlA+j0dis48m0HUIIrr32WiZOnMjp06fZtWsXjzzyCOfOnWu1Y1555ZXs3buXEydOMGfOHG666SYOHTrUrL4u9xdCS2nqM6a5DBkyhH379rFv3z7i4+P59ddf2bdvHx999JFFsixfvhxHR8cGj2FJG0t49NFHeemll9i3bx+HDx/m5ptvBuRrTVY+LiHy8/M5ceIEb7/9NosWLQLgv//9L9OnT2fIkCE88sgjnDhxgpEjRxITE0P//v0pKioCICUlhTFjxtC1a1fee+894PwXh8Fg4D//+Q/fffcdsbGxLF++nLKyMmbMmEH//v3p168fq1evBqCkpITbb7+d6OhoYmJi2Lx5My+88AJHjhwhNjaWV155hQ0bNjBlyhSz3FOmTGHDhg0AeHt789BDD9GnTx9OnDjBW2+9Rf/+/YmOjubdd9+14dmUaQ5r167FxcWFu+++27wuISGB3r17U1FRYb42BgwYwL59+wDTNXrPPfcwbNgwOnfuzM8//wzAzTffzLp168z9jBo1ir179zZ4/GHDhnH//ffz9ddfA3D69GnGjRtHfHw8o0aNIjk5GYARI0bw+OOPExMTQ9++fTl8+DCpqal88cUXvPnmm8TGxprlW716NYMGDaJbt24tsqp0dHx8fJg9ezZ9+vRh9OjRlJWVAaZz+dhjjxEfH8/333/P999/T58+fejduzfvvPNOg32eO3eOyZMnEx8fz+DBg83je+rUKfN9f6FC0Rjh4eE8++yz9O3bl3Xr1jFnzhz69+9P7969efzxx2u0Ky0tJTk5mZiYGKZPn06PHj24+eabEUJY3Oavv/4iMjKS/v37c/fdd9dp0cnKyiIwMBAApVJJz54967zW6jsXM2bM4IEHHiAuLo4ePXqYr8GDBw8SFxdntgDl5ORYfJ7aBULmkuGrr74STzzxhDAajSIiIkKcO3dOzJkzRwwZMkRoNBohhBD9+/cXK1euFEIIUVJSIrRarZg/f77o3r27KCkpEQUFBcLPz09oNBqRlJQk+vXrJ4QQYv78+eLJJ580H+u5554Tv/zyixBCiHPnzonu3bsLo9EonnrqKfH8888LIYQwGAyisLCwRj9CCLF+/Xpxww03mJdvuOEGsX79eiGEEIBYtmyZEEKIlStXioceekgYjUah1+vFyJEjxcGDB1vp7MlYgw8//FA89thjdW575513xKxZs4QQQmzdulVER0cLIYSYM2eOGDFihNBqteLUqVOiS5cuQgghfvnlF3H//fcLIYTIzs4W3bt3r9XnxdeSEEL8+eefYvz48UIIIcaOHSuSkpKEEEKsXbtWTJkyRQghxPDhw8VDDz0khBBixYoVYvjw4WZZPv74Y3Nf06dPF7fddpt5/1GjRjXthHQgLr5PhTD9/qVLlwohTPfm6tWrhRBC3H777eK7774TQpjO5ezZs4UQQqSlpYnOnTuLvLw8UVFRIfr27St27dpV77PklltuETt27BBCCHHixAkxYMAAIYQQEydOFL/99psQQoinn366llwXMnz4cPNzISwsTHzyySfmbXl5eUIIIYxGo5g8ebLYsmWLuV1JSYlISkoSdnZ24vDhw8JoNIrhw4eLTZs2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",
      "text/plain": [
       "<Figure size 550x200 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rc(\"text\")\n",
    "plt.rc(\"font\", family=\"sans-serif\")\n",
    "plt.rc(\"font\", size=9)\n",
    "plt.rc(\"axes\", labelsize=6)\n",
    "plt.rc(\"font\", size=9)\n",
    "plt.rc(\"legend\", fontsize=6)  # Make the legend/label fonts\n",
    "plt.rc(\"legend\", title_fontsize=7)\n",
    "plt.rc(\"xtick\", labelsize=6.5)  # a little smaller\n",
    "plt.rc(\"ytick\", labelsize=6.0)\n",
    "# Set title font size\n",
    "plt.rc(\"axes\", titlesize=8)\n",
    "\n",
    "WIDTH = 5.5\n",
    "HEIGHT = 2.0\n",
    "plt.rc(\"figure\", figsize=(WIDTH, HEIGHT))\n",
    "\n",
    "fig, ax_s = plt.subplots(1, 4)\n",
    "\n",
    "for i, advection_gamma in enumerate([0.5, 2.5, 10.5]):\n",
    "    sns.lineplot(\n",
    "        data=metric_data_varying_difficulty.query(\n",
    "            \"advection_gamma == @advection_gamma and `Time Step` <= 30\"\n",
    "        ),\n",
    "        x=\"Time Step\",\n",
    "        y=\"nRMSE\",\n",
    "        hue=\"Arch Type\",\n",
    "        style=\"Conv Depth\",\n",
    "        style_order=[10, 2, 1, 0],\n",
    "        ax=ax_s[i],\n",
    "        estimator=\"median\",\n",
    "        errorbar=None,\n",
    "        palette=[\"#377eb8\", \"#4daf4a\", \"#e41a1c\", \"#ff7f00\", \"#984ea3\"],\n",
    "        linewidth=1.5,\n",
    "    )\n",
    "    ax_s[i].set_title(f\"$\\gamma_1 = {advection_gamma:.1f}$ (a)\", pad=5)\n",
    "    ax_s[i].set_ylim(-0.001, 0.071)\n",
    "\n",
    "sns.lineplot(\n",
    "    data=metric_data_varying_rollout.query(\n",
    "        \"`Time Step` <= 30 and Rollout in [1, 3, 5]\"\n",
    "    ),\n",
    "    x=\"Time Step\",\n",
    "    y=\"nRMSE\",\n",
    "    size=\"Rollout\",\n",
    "    sizes=[1.5, 3.0, 4.5],\n",
    "    ax=ax_s[3],\n",
    "    estimator=\"median\",\n",
    "    errorbar=None,\n",
    "    # palette=\"muted\",\n",
    "    color=\"#4daf4a\",\n",
    ")\n",
    "ax_s[3].set_title(\"$\\gamma_1 = 10.5$ (b)\", pad=5)\n",
    "ax_s[3].set_ylim(-0.001, 0.071)\n",
    "\n",
    "for ax in ax_s[1:]:\n",
    "    # Remove y label\n",
    "    ax.set_ylabel(\"\")\n",
    "    # Remove label of ticks but keep ticks\n",
    "    ax.set_yticklabels([])\n",
    "\n",
    "\n",
    "# Move the legend of the first three axis jointly above them\n",
    "handles, labels = ax_s[0].get_legend_handles_labels()\n",
    "handles_2, labels_2 = ax_s[-1].get_legend_handles_labels()\n",
    "fig.tight_layout()\n",
    "fig.subplots_adjust(\n",
    "    top=0.65,\n",
    "    bottom=0.18,\n",
    "    wspace=0.1,\n",
    ")\n",
    "LEGEND_OFFSET_X = 0.43\n",
    "LEGEND_DISTANCE = 0.13\n",
    "fig.legend(\n",
    "    handles[1:6],\n",
    "    # [handles[1], handles[3], handles[5], handles[2], handles[4]],\n",
    "    labels[1:6],\n",
    "    # [labels[1], labels[3], labels[5], labels[2], labels[4]],\n",
    "    loc=\"upper right\",\n",
    "    bbox_to_anchor=(LEGEND_OFFSET_X, 1.0),\n",
    "    ncol=3,\n",
    "    title=\"Architecture\",\n",
    "    # edgecolor=\"black\",\n",
    "    frameon=False,\n",
    ")\n",
    "for handle in handles[7:11]:\n",
    "    handle.set_color(\"#377eb8\")\n",
    "fig.legend(\n",
    "    # handles[7:11],\n",
    "    [handles[10], handles[8], handles[9], handles[7]],\n",
    "    # labels[7:11],\n",
    "    [labels[10], labels[8], labels[9], labels[7]],\n",
    "    loc=\"upper center\",\n",
    "    bbox_to_anchor=(LEGEND_OFFSET_X + LEGEND_DISTANCE, 1.0),\n",
    "    ncol=2,\n",
    "    title=\"Conv Depth\",\n",
    "    # edgecolor=\"black\",\n",
    "    frameon=False,\n",
    ")\n",
    "fig.legend(\n",
    "    handles_2,\n",
    "    labels_2,\n",
    "    loc=\"upper left\",\n",
    "    bbox_to_anchor=(LEGEND_OFFSET_X + 2 * LEGEND_DISTANCE, 1.0),\n",
    "    title=\"Unrolled Training Steps\",\n",
    "    ncol=3,\n",
    "    # edgecolor=\"black\",\n",
    "    frameon=False,\n",
    "    # Align font center\n",
    "    # title_align=\"center\",\n",
    "    # alignment=\"center\",\n",
    ")\n",
    "\n",
    "\n",
    "for ax in ax_s:\n",
    "    ax.legend().remove()\n",
    "    ax.grid()\n",
    "    ax.set_xlim(-1, 26)\n",
    "    ax.set_xticks(\n",
    "        [\n",
    "            0,\n",
    "            10,\n",
    "            20,\n",
    "        ]\n",
    "    )\n",
    "    ax.set_yticks([0, 0.02, 0.04, 0.06])\n",
    "\n",
    "# fig.text(0.15, 0.675, \"(a)\", ha=\"center\")\n",
    "# fig.text(0.79, 0.775, \"(b)\", ha=\"center\")\n",
    "\n",
    "fig.savefig(\"img/adv_experiment_together.pdf\", pad_inches=0, bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "jax_gpu",
   "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.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
