{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Pull data command:\n",
    "# python download_data.py --project=discrete-mbrl-soft-vqvae-best --history_vars n_step goal_state_distrib_kl_div goal_delayed_state_distrib_kl_div goal_uniform_distrib_kl_div explore_right_state_distrib_kl_div explore_right_delayed_state_distrib_kl_div explore_right_uniform_distrib_kl_div --params codebook_size filter_size eval_policy env_name ae_model_type latent_dim final_latent_dim e2e_loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from collections import Counter\n",
    "import os\n",
    "import sys\n",
    "sys.path.append(os.path.abspath('../../..'))\n",
    "from plotting_utils import *\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import scipy.stats as st\n",
    "import seaborn as sns\n",
    "\n",
    "%matplotlib inline\n",
    "set_matplotlib_style()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "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>step</th>\n",
       "      <th>n_step</th>\n",
       "      <th>explore_right_state_distrib_kl_div</th>\n",
       "      <th>explore_right_delayed_state_distrib_kl_div</th>\n",
       "      <th>explore_right_uniform_distrib_kl_div</th>\n",
       "      <th>ae_model_type</th>\n",
       "      <th>codebook_size</th>\n",
       "      <th>env_name</th>\n",
       "      <th>filter_size</th>\n",
       "      <th>final_latent_dim</th>\n",
       "      <th>latent_dim</th>\n",
       "      <th>experiment_key</th>\n",
       "      <th>goal_state_distrib_kl_div</th>\n",
       "      <th>goal_delayed_state_distrib_kl_div</th>\n",
       "      <th>goal_uniform_distrib_kl_div</th>\n",
       "      <th>Model Type</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>1.437187</td>\n",
       "      <td>-1.257582e-08</td>\n",
       "      <td>4.125888</td>\n",
       "      <td>vqvae</td>\n",
       "      <td>64</td>\n",
       "      <td>minigrid-crossing-stochastic</td>\n",
       "      <td>6</td>\n",
       "      <td>2304</td>\n",
       "      <td>None</td>\n",
       "      <td>bcac7b257c464f9abf6a456a98374cb9</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>One-Hot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2</td>\n",
       "      <td>2</td>\n",
       "      <td>1.092798</td>\n",
       "      <td>1.487571e+01</td>\n",
       "      <td>3.252357</td>\n",
       "      <td>vqvae</td>\n",
       "      <td>64</td>\n",
       "      <td>minigrid-crossing-stochastic</td>\n",
       "      <td>6</td>\n",
       "      <td>2304</td>\n",
       "      <td>None</td>\n",
       "      <td>bcac7b257c464f9abf6a456a98374cb9</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>One-Hot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3</td>\n",
       "      <td>3</td>\n",
       "      <td>1.362391</td>\n",
       "      <td>1.245456e+01</td>\n",
       "      <td>2.838870</td>\n",
       "      <td>vqvae</td>\n",
       "      <td>64</td>\n",
       "      <td>minigrid-crossing-stochastic</td>\n",
       "      <td>6</td>\n",
       "      <td>2304</td>\n",
       "      <td>None</td>\n",
       "      <td>bcac7b257c464f9abf6a456a98374cb9</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>One-Hot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>4</td>\n",
       "      <td>4</td>\n",
       "      <td>1.419378</td>\n",
       "      <td>8.472774e+00</td>\n",
       "      <td>2.556366</td>\n",
       "      <td>vqvae</td>\n",
       "      <td>64</td>\n",
       "      <td>minigrid-crossing-stochastic</td>\n",
       "      <td>6</td>\n",
       "      <td>2304</td>\n",
       "      <td>None</td>\n",
       "      <td>bcac7b257c464f9abf6a456a98374cb9</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>One-Hot</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>5</td>\n",
       "      <td>5</td>\n",
       "      <td>2.850567</td>\n",
       "      <td>7.351248e+00</td>\n",
       "      <td>2.272615</td>\n",
       "      <td>vqvae</td>\n",
       "      <td>64</td>\n",
       "      <td>minigrid-crossing-stochastic</td>\n",
       "      <td>6</td>\n",
       "      <td>2304</td>\n",
       "      <td>None</td>\n",
       "      <td>bcac7b257c464f9abf6a456a98374cb9</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>One-Hot</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   step  n_step  explore_right_state_distrib_kl_div  \\\n",
       "0     1       1                            1.437187   \n",
       "1     2       2                            1.092798   \n",
       "2     3       3                            1.362391   \n",
       "3     4       4                            1.419378   \n",
       "4     5       5                            2.850567   \n",
       "\n",
       "   explore_right_delayed_state_distrib_kl_div  \\\n",
       "0                               -1.257582e-08   \n",
       "1                                1.487571e+01   \n",
       "2                                1.245456e+01   \n",
       "3                                8.472774e+00   \n",
       "4                                7.351248e+00   \n",
       "\n",
       "   explore_right_uniform_distrib_kl_div ae_model_type  codebook_size  \\\n",
       "0                              4.125888         vqvae             64   \n",
       "1                              3.252357         vqvae             64   \n",
       "2                              2.838870         vqvae             64   \n",
       "3                              2.556366         vqvae             64   \n",
       "4                              2.272615         vqvae             64   \n",
       "\n",
       "                       env_name  filter_size  final_latent_dim latent_dim  \\\n",
       "0  minigrid-crossing-stochastic            6              2304       None   \n",
       "1  minigrid-crossing-stochastic            6              2304       None   \n",
       "2  minigrid-crossing-stochastic            6              2304       None   \n",
       "3  minigrid-crossing-stochastic            6              2304       None   \n",
       "4  minigrid-crossing-stochastic            6              2304       None   \n",
       "\n",
       "                     experiment_key  goal_state_distrib_kl_div  \\\n",
       "0  bcac7b257c464f9abf6a456a98374cb9                        NaN   \n",
       "1  bcac7b257c464f9abf6a456a98374cb9                        NaN   \n",
       "2  bcac7b257c464f9abf6a456a98374cb9                        NaN   \n",
       "3  bcac7b257c464f9abf6a456a98374cb9                        NaN   \n",
       "4  bcac7b257c464f9abf6a456a98374cb9                        NaN   \n",
       "\n",
       "   goal_delayed_state_distrib_kl_div  goal_uniform_distrib_kl_div Model Type  \n",
       "0                                NaN                          NaN    One-Hot  \n",
       "1                                NaN                          NaN    One-Hot  \n",
       "2                                NaN                          NaN    One-Hot  \n",
       "3                                NaN                          NaN    One-Hot  \n",
       "4                                NaN                          NaN    One-Hot  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_path = 'data/discrete-mbrl-soft-vqvae-best_data.csv'\n",
    "df = pd.read_csv(data_path, index_col=0)\n",
    "df['Model Type'] = df['ae_model_type']\n",
    "\n",
    "model_type_map = {\n",
    "  'soft_vqvae': 'Quantized',\n",
    "  'vqvae': 'One-Hot',\n",
    "}\n",
    "df['Model Type'] = df['Model Type'].apply(lambda x: model_type_map[x])\n",
    "\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "kl_div_columns = [col for col in df.columns if 'kl_div' in col]\n",
    "# Drop the rows where all of the columns are NaN\n",
    "df = df.dropna(subset=kl_div_columns, how='all')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Work out the policy types and simplify the KL divergence columns\n",
    "\n",
    "def infer_policy_type(row):\n",
    "  for key, val in row.items():\n",
    "    if 'kl_div' in key and val is not None and not np.isnan(val):\n",
    "      return key[:key.find('state')-1]\n",
    "    \n",
    "\n",
    "df['policy_type'] = df.apply(infer_policy_type, axis=1)\n",
    "df['state_distrib_kl_div'] = df.apply(\n",
    "  lambda row: row[row['policy_type'] + '_state_distrib_kl_div'],\n",
    "  axis=1)\n",
    "df['uniform_distrib_kl_div'] = df.apply(\n",
    "  lambda row: row[row['policy_type'] + '_uniform_distrib_kl_div'],\n",
    "  axis=1)\n",
    "# df['delayed_state_distrib_kl_div'] = df.apply(\n",
    "#   lambda row: row[row['policy_type'] + '_delayed_state_distrib_kl_div'],\n",
    "#   axis=1)\n",
    "\n",
    "df.drop(columns=kl_div_columns, inplace=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "64\n"
     ]
    },
    {
     "data": {
      "image/png": "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U/0liIODg8NQZm8ty2wrbjs4ODgMa7JSlkqpzyul/LvvF5Gr+18kBwcHh6FHtg6em4BblVL/AO4Wkd17gwwImUyG7du3k0w6Jf36E7/fz5gxY/B4PIMtioPDkCUrZSkik+weyJcBLymltmC1U71fROpyKN8ubN++nby8PMaPH4/dMdRhLxERGhsb2b59OxMmTBhscRwchixZr1mKyMsicilWO9VfA+djtUodMJLJJCUlJY6i7EeUUpSUlDjWuoNDD/TFwTMZmIPVj6S2f8XpGUdR9j/Oe+rg0DPZOnhKlFLXKaWWAW9gdQn8HFbz+GGFUoqLL76447Gu65SVlbFgwYJuzvok48eP7zEWtKvnHHbYYcydO5fKykrKysqYO3cuc+fOZfPmzb0a38HBYWDJ1sFTDXwA3Ak8JCKtuRMpt4RCIVasWEEikSAQCPDCCy8wevToARv/7bethn+LFi1i6dKl3HbbbQM2toODQ9/Jdhp+kIgcLiJ3DmdF2c7pp5/OU09Z8fQPPfQQF154YcexpqYmzjnnHGbPns3hhx/O8uXLAWhsbOTUU09l5syZXHHFFXSuMP+3v/2NQw89lLlz5/KlL30JwzCylsU0TaZMmUJ9fX3H48mTJ1NfX89ll13GVVddxfz585k6dSpPPvkkAIZh8M1vfpNDDjmE2bNn86c//Wmv3xMHB4fuyUpZisjKnp81fPjsZz/L3//+d5LJJMuXL+ewww7rOLZw4UIOOuggli9fzk9/+lMuueQSAG6++WaOPvpoPv74Y84991y2brXi8VetWsU//vEPlixZwrJly3C5XDzwwANZy6JpGhdffHHHOS+++CJz5syhrKwMgM2bN/POO+/w1FNPcdVVV5FMJrn77rspKCjg3Xff5d133+Uvf/kLmzZt6q+3x8HBoQv2OA1XSjWJSLG9nQG6bNYjIt4cyZYzZs+ezebNm3nooYc4/fTTdzn2+uuv869//QuAE088kcbGRiKRCK+++iqPPvooAGeccQZFRUUALF68mPfee49DDjkEgEQiQXl5ea/kufzyyzn77LP52te+xj333MMXvvCFjmOf/vSn0TSNKVOmMHHiRFavXs3zzz/P8uXL+ec//wlAa2sr69atc0J/HBxySHdrlmd12j4514IMNGeddRY33HADr7zyCo2NjX2+johw6aWX8rOf/azP1xg7diwVFRW89NJLvPPOO7tYprt7qpVSiAi33norp512Wp/HdHDY3xDDwIjH+OCUOaMPeWtTVW/P3+M0XERe77T93z3d+ir4YHP55ZezcOFCZs3atV/9Mccc06GsXnnlFUpLS8nPz+fYY4/lwQcfBOCZZ56hubkZgJNOOol//vOf1NVZsflNTU1s2bKl1/JcccUVXHzxxVxwwQW4XK6O/Y888gimabJhwwY2btzItGnTOO2007jjjjvIZDIArF27llgs1vs3wcFhH0ZMEyPWRqq2iujKD2l953WiH70PMLcv1+vRG66UcgOXAicBJUAjsBgreyeT7UBKqQXAj7BqySngZhF5tC9C9wdjxozhuuuu+8T+m266icsvv5zZs2cTDAa57777AGst88ILL2TmzJkceeSRVFZWAjBjxgx+/OMfc+qpp2KaJh6Ph9tvv51x48b1Sp6zzjqLL3zhC7tMwQEqKys59NBDiUQi3Hnnnfj9fq644go2b97MwQcfjIhQVlbGv//97769EQ4O+wgighmPocei6E31ZFqaQUxQGi6/H3dhUftMTe/L9bvtG66U8gKvAAcB7wHbgTHAPKxQouNFJN3jIJaETcAxIrJCKTUbWAIUiIjZ1Tnz58+XpUuX7rJv1apVTJ8+PYuXNfxYunQp119/Pa+99lrHvssuu4wFCxZw/vnn53z8ffm9ddj30SOtJLasx2hrA6XQ/H40nx+lfXLyvPKysz51yFubnuvtGD1ZltcAecAsEVnfvlMpNRn4F3AtVupjNphAgb1dCNTsSVHub/z85z/njjvu6JUX3cHBAYxEnOS2zWQaatECITzFJTkbqydleR7wtc6KEkBE1iulvg78kCyUpYiIUurTwONKqRiWAj69h9P2G77zne/wne985xP7Fy1aNPDCODgMA8x0ilTNdlJV21BeD+6i0pyn7fakLA8AXtvDsdeAadkMYq973gicLSJLlFJHAQ8rpWaISLTT864ErgQ61gQdHBwc2hFdJ11fS3LrJgSsdcguptq5oKdRPHtak7T3Z5suORcYJSJL7HOXADFgl0UyEfmziMwXkfntQdkODg4OIkK6sY62Ze+Q2LweVyiMp6BwwBQl9KzsepIkW0m3A2OUUtNEZI1SajpQAWzI8nwHB4f9CNF1zFQSM5lAj7WhNzWix6K48/LxhPMGRaaelGVYKdWdt9vVzbEO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",
      "text/plain": [
       "<Figure size 360x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "60\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "min_runs = 30\n",
    "for keys, group in df.groupby(['env_name', 'policy_type']):\n",
    "    n_runs = len(group['experiment_key'].unique())\n",
    "    min_runs = min(min_runs, n_runs)\n",
    "\n",
    "for keys, group in df.groupby(['env_name', 'policy_type']):\n",
    "    # Count the number of runs (number of times n_step == 30) for each ae_model_type\n",
    "    print(len(group['experiment_key'].unique()))\n",
    "\n",
    "    baseline_row_sets = []\n",
    "    for baseline_type in ['uniform']:\n",
    "        with warnings.catch_warnings():\n",
    "            warnings.simplefilter('ignore')\n",
    "            if keys[1] == 'random' and baseline_type == 'delayed_state':\n",
    "                continue\n",
    "            baseline_rows = group[group['ae_model_type'] == 'vqvae']\n",
    "            baseline_rows['state_distrib_kl_div'] = baseline_rows[f'{baseline_type}_distrib_kl_div']\n",
    "            baseline_title = baseline_type.replace('_', ' ').title()\n",
    "            baseline_rows['Model Type'] = f'{baseline_title}'\n",
    "            baseline_rows['experiment_key'] = baseline_rows['experiment_key'] \\\n",
    "                + f'_{baseline_type}_baseline'\n",
    "            baseline_rows = baseline_rows[\n",
    "                baseline_rows['experiment_key'] == baseline_rows['experiment_key'].iloc[0]\n",
    "            ]\n",
    "            if baseline_type == 'delayed_state':\n",
    "                # Drop n_step = 1\n",
    "                baseline_rows = baseline_rows.drop(\n",
    "                    baseline_rows[baseline_rows['n_step'] == 1].index)\n",
    "            baseline_row_sets.append(baseline_rows)\n",
    "\n",
    "    max_base_y = np.percentile(group['state_distrib_kl_div'], 93)\n",
    "\n",
    "    for baseline_rows in baseline_row_sets:\n",
    "        group = pd.concat([group, baseline_rows])\n",
    "\n",
    "    # Reindex group\n",
    "    group = group.reset_index(drop=True)\n",
    "\n",
    "    # Set up the figure and axis\n",
    "    fig, ax = plt.subplots()\n",
    "\n",
    "    # Create a list of unique Model Types\n",
    "    model_types = group['Model Type'].unique()\n",
    "    color_palette = get_color_palette(group['Model Type'].unique())\n",
    "    \n",
    "    sns.lineplot(\n",
    "        data=group, x='n_step', y='state_distrib_kl_div', hue='Model Type',\n",
    "        palette=color_palette, errorbar='ci', estimator=np.mean)\n",
    "\n",
    "    plt.title(f'{standardize_env_name(keys[0])}')\n",
    "    set_fig_labels('Rollout Steps', 'State Distribution KL Div.')\n",
    "\n",
    "    plt.xlim(1, 30)\n",
    "    plt.ylim(0, 1.1 * max_base_y)\n",
    "\n",
    "    yticks = plt.gca().get_yticks()\n",
    "    plt.gca().set_yticks(yticks[::2])\n",
    "\n",
    "    save_fig_versions(f'{standardize_env_name(keys[0])}_quantized')\n",
    "    plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ml2",
   "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.9.12"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "d1fe9e103656f2266082d3c8033b60b2c460ce6c85d6ed8c56af72efc68894ec"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
