{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import glob\n",
    "import re\n",
    "from tqdm import tqdm\n",
    "import multiprocessing as mp\n",
    "import plotly.express as px\n",
    "import plotly.graph_objects as go\n",
    "import pandas as pd\n",
    "import os\n",
    "import sys"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "ROOT = \"../rot_vqvae\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 74/74 [00:41<00:00,  1.77it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "74"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "logs = list(Path(ROOT).rglob(\"logged.pt\"))\n",
    "logs = [path for path in logs if \"bak\" not in str(path)]\n",
    "\n",
    "def load(path):\n",
    "    return {\n",
    "        \"path\": str(path),\n",
    "        \"logs\": torch.load(path, map_location=\"cpu\"),\n",
    "        \"arch\": re.search(r\"arch=([^_]+)\", path.parent.name).group(1),\n",
    "        \"f\": re.search(r\"f=([^_]+)\", path.parent.name).group(1) if \"f=\" in path.parent.name else 16,\n",
    "        \"dataset\": re.search(r\"dataset=([^_]+)\", path.parent.name).group(1),\n",
    "    }\n",
    "\n",
    "# logs = [load(path) for path in tqdm(logs)]\n",
    "with mp.Pool(8) as p:\n",
    "    logs = list(tqdm(p.imap(load, logs), total=len(logs)))\n",
    "len(logs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def parse_log(log):\n",
    "    try:\n",
    "        arch, dataset = log['arch'], log['dataset']\n",
    "        path = log['path']\n",
    "        vq = \"rot_vqvae\" if log[\"path\"].startswith(\"rot_vqvae\") else \"vqvae\" # this is a bug. should use contains(\"rot_vqvae\")\n",
    "        import re\n",
    "        codebook_size = int(re.search(r\"(\\d+)x(\\d+)d\", log['path']).group(1))\n",
    "        f = log['f']\n",
    "        log = log['logs']\n",
    "        all_logs = []\n",
    "        for args, kwargs, global_step in log:\n",
    "            log_dict = args[0]\n",
    "            log_dict['global_step'] = global_step\n",
    "            all_logs.append(log_dict)\n",
    "        df = pd.DataFrame(all_logs)\n",
    "        # merge on global_step\n",
    "        merged = df.groupby(\"global_step\").first().reset_index()\n",
    "        # drop the rows with nan val_loss\n",
    "        nonan = merged[~merged.val_loss.isna()]\n",
    "        # drop the rows with nan codebook_eff_dim\n",
    "        nonan = nonan[~nonan.codebook_eff_dim.isna()]\n",
    "        # find the row with the lowest val_loss\n",
    "        row = nonan.loc[nonan.val_loss.idxmin()]\n",
    "        row = row.to_dict()\n",
    "        row['path'] = path\n",
    "        row['arch'] = arch + f\"(f={f})\"\n",
    "        row['dataset'] = dataset\n",
    "        row['vq'] = vq\n",
    "        row['codebook_size'] = codebook_size\n",
    "        row2 = nonan.loc[nonan.global_step.idxmax()]\n",
    "        # merge the two rows. naming row2 as last_...\n",
    "        for key, value in row2.items():\n",
    "            row[f\"last_{key}\"] = value\n",
    "        return row\n",
    "    except Exception as e:\n",
    "        print(f\"Error parsing log: {e}\")\n",
    "        return {}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/74 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 16%|█▌        | 12/74 [00:06<00:34,  1.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 20%|██        | 15/74 [00:09<00:37,  1.57it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 27%|██▋       | 20/74 [00:11<00:28,  1.87it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n",
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 39%|███▉      | 29/74 [00:14<00:18,  2.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 49%|████▊     | 36/74 [00:16<00:13,  2.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 59%|█████▉    | 44/74 [00:16<00:07,  4.21it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n",
      "\n",
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 62%|██████▏   | 46/74 [00:16<00:06,  4.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 72%|███████▏  | 53/74 [00:17<00:03,  5.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n",
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n",
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 84%|████████▍ | 62/74 [00:20<00:02,  4.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n",
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n",
      "Error parsing log: 'DataFrame' object has no attribute 'val_loss'\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 74/74 [00:22<00:00,  3.24it/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "58"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "with mp.Pool(64) as p:\n",
    "    parsed_logs = list(tqdm(p.imap(parse_log, logs), total=len(logs)))\n",
    "df = pd.DataFrame(parsed_logs)\n",
    "df = df.dropna(subset=['codebook_eff_dim', 'val_loss'])\n",
    "len(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# to disk\n",
    "torch.save(df, \"df.pt\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "---\n",
    "Done Preprocessing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import glob\n",
    "import re\n",
    "from tqdm import tqdm\n",
    "import multiprocessing as mp\n",
    "import plotly.express as px\n",
    "import plotly.graph_objects as go\n",
    "import pandas as pd\n",
    "import os\n",
    "import sys\n",
    "\n",
    "df = torch.load(\"df.pt\")\n",
    "abl_df = torch.load(\"../../bak_ablation/tests/df.pt\")\n",
    "df = pd.concat([df, abl_df], ignore_index=True).reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "metadata": {},
   "outputs": [],
   "source": [
    "# filter out PerformanceWarning and UserWarning of pandas\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\", category=UserWarning)\n",
    "from pandas.errors import PerformanceWarning\n",
    "warnings.filterwarnings(\"ignore\", category=PerformanceWarning)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 139,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "304"
      ]
     },
     "execution_count": 139,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# if not max_global_step > 10000, we drop it\n",
    "# df_ = df[df.last_global_step > 10000]\n",
    "\n",
    "# for cifar10 and celeba, we calculate the largest last_global_step, and filterout those less than 0.9 of the max\n",
    "max_global_step = df.groupby(['dataset', 'arch', 'vq'])['last_global_step'].max().reset_index()\n",
    "max_global_step = max_global_step.rename(columns={'last_global_step': 'max_global_step'})\n",
    "df_ = df.merge(max_global_step, on=['dataset', 'arch', 'vq'])\n",
    "df_ = df_[df_.last_global_step > 0.95 * df_.max_global_step].reset_index(drop=True)\n",
    "df_ = df_[df_['dataset'] != 'imagenet']  # filter out imagenet for now\n",
    "df_ = df_[df_['arch'].str.contains(\"f=16\")] # filter out f != 16 for now\n",
    "len(df_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'../rot_vqvae/vqvae_cosine_thr0.008_cw2.0_512x32d_dec0.95_gpu=0_dataset=cifar10_arch=enhancing_dim_per_quantizer=8_num_quantizers=4_split_vq=True/logged.pt'"
      ]
     },
     "execution_count": 140,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_['path'].iloc[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 141,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_num_quantizers(path):\n",
    "    return int(re.search(r\"num_quantizers=(\\d+)\", path).group(1)) if \"num_quantizers=\" in path else 1\n",
    "\n",
    "def get_dim_per_quantizer(path):\n",
    "    return int(re.search(r\"dim_per_quantizer=(\\d+)\", path).group(1)) if \"dim_per_quantizer=\" in path else get_codebook_dim(path)\n",
    "\n",
    "def get_codebook_dim(path):\n",
    "    return int(re.search(r\"(\\d+)x(\\d+)d\", path).group(2))\n",
    "\n",
    "def get_split_vq(path):\n",
    "    return \"split_vq=True\" in path\n",
    "\n",
    "def get_f(path):\n",
    "    return int(re.search(r\"f=(\\d+)\", path).group(1)) if \"f=\" in path else 16\n",
    "\n",
    "def get_cw(path):\n",
    "    return float(re.search(r\"cw([\\d\\.]+)\", path).group(1)) if \"cw\" in path else None\n",
    "\n",
    "def get_thr(path):\n",
    "    return float(re.search(r\"thr([\\d\\.]+)\", path).group(1)) if \"thr\" in path else None\n",
    "\n",
    "def get_dec(path):\n",
    "    return float(re.search(r\"dec([\\d\\.]+)\", path).group(1)) if \"dec\" in path else None\n",
    "\n",
    "def get_rotation_trick(path):\n",
    "    if path.startswith(\"../rot_vqvae/rot_vqvae\"):\n",
    "        return \"Enabled\"\n",
    "    else:\n",
    "        assert path.startswith(\"../rot_vqvae/vqvae\")\n",
    "        return \"Disabled\"\n",
    "    \n",
    "def get_group(row):\n",
    "    if row['num_quantizers'] == 1:\n",
    "        return \"VQVAE\"\n",
    "    if row['split_vq']:\n",
    "        return f\"DCVQ-{row['dim_per_quantizer']}d\"\n",
    "    else:\n",
    "        return f\"RQ-{row['dim_per_quantizer']}d\"\n",
    "\n",
    "df_[\"codebook_dim\"] = df_[\"path\"].apply(get_codebook_dim)\n",
    "df_[\"codebook_size\"] = df_[\"codebook_size\"].astype(int)\n",
    "df_[\"f\"] = df_[\"path\"].apply(get_f)\n",
    "df_[\"cw\"] = df_[\"path\"].apply(get_cw)\n",
    "df_[\"thr\"] = df_[\"path\"].apply(get_thr)\n",
    "df_[\"dec\"] = df_[\"path\"].apply(get_dec)\n",
    "df_[\"Rotation Trick\"] = df_[\"path\"].apply(get_rotation_trick)\n",
    "\n",
    "df_[\"num_quantizers\"] = df_[\"path\"].apply(get_num_quantizers)\n",
    "df_[\"dim_per_quantizer\"] = df_[\"path\"].apply(get_dim_per_quantizer)\n",
    "df_[\"split_vq\"] = df_[\"path\"].apply(get_split_vq)\n",
    "df_[\"group\"] = df_.apply(get_group, axis=1)\n",
    "df_ = df_[~df_[\"group\"].str.contains(\"RQ\")] # filter out RQ for now\n",
    "df_ = df_[df_[\"codebook_size\"] == 512]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "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>arch</th>\n",
       "      <th>dataset</th>\n",
       "      <th>val_loss</th>\n",
       "      <th>global_step</th>\n",
       "      <th>codebook_eff_dim</th>\n",
       "      <th>last_global_step</th>\n",
       "      <th>last_val_loss</th>\n",
       "      <th>last_codebook_eff_dim</th>\n",
       "      <th>codebook_dim</th>\n",
       "      <th>codebook_size</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.252243</td>\n",
       "      <td>9604.0</td>\n",
       "      <td>22.0</td>\n",
       "      <td>19404.0</td>\n",
       "      <td>0.268596</td>\n",
       "      <td>22.0</td>\n",
       "      <td>32</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.111633</td>\n",
       "      <td>19404.0</td>\n",
       "      <td>80.0</td>\n",
       "      <td>19404.0</td>\n",
       "      <td>0.111633</td>\n",
       "      <td>80.0</td>\n",
       "      <td>128</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.172750</td>\n",
       "      <td>13132.0</td>\n",
       "      <td>41.0</td>\n",
       "      <td>19404.0</td>\n",
       "      <td>0.181648</td>\n",
       "      <td>41.0</td>\n",
       "      <td>64</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.209346</td>\n",
       "      <td>18620.0</td>\n",
       "      <td>73.0</td>\n",
       "      <td>19404.0</td>\n",
       "      <td>0.210414</td>\n",
       "      <td>73.0</td>\n",
       "      <td>256</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.296274</td>\n",
       "      <td>18032.0</td>\n",
       "      <td>49.0</td>\n",
       "      <td>19404.0</td>\n",
       "      <td>0.296781</td>\n",
       "      <td>49.0</td>\n",
       "      <td>128</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>286</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>celeba</td>\n",
       "      <td>0.040007</td>\n",
       "      <td>14421.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>62073.0</td>\n",
       "      <td>0.045002</td>\n",
       "      <td>3.0</td>\n",
       "      <td>6</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>289</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>celeba</td>\n",
       "      <td>0.032749</td>\n",
       "      <td>25707.0</td>\n",
       "      <td>6.0</td>\n",
       "      <td>62073.0</td>\n",
       "      <td>0.036032</td>\n",
       "      <td>6.0</td>\n",
       "      <td>32</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>294</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>celeba</td>\n",
       "      <td>0.031831</td>\n",
       "      <td>28215.0</td>\n",
       "      <td>5.0</td>\n",
       "      <td>62073.0</td>\n",
       "      <td>0.033701</td>\n",
       "      <td>5.0</td>\n",
       "      <td>8</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>301</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>celeba</td>\n",
       "      <td>0.033892</td>\n",
       "      <td>21318.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>62073.0</td>\n",
       "      <td>0.037218</td>\n",
       "      <td>4.0</td>\n",
       "      <td>6</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>303</th>\n",
       "      <td>enhancing(f=16)</td>\n",
       "      <td>celeba</td>\n",
       "      <td>0.032674</td>\n",
       "      <td>49533.0</td>\n",
       "      <td>7.0</td>\n",
       "      <td>62073.0</td>\n",
       "      <td>0.032906</td>\n",
       "      <td>7.0</td>\n",
       "      <td>8</td>\n",
       "      <td>512</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>94 rows × 10 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                arch  dataset  val_loss  global_step  codebook_eff_dim  \\\n",
       "0    enhancing(f=16)  cifar10  0.252243       9604.0              22.0   \n",
       "1    enhancing(f=16)  cifar10  0.111633      19404.0              80.0   \n",
       "2    enhancing(f=16)  cifar10  0.172750      13132.0              41.0   \n",
       "7    enhancing(f=16)  cifar10  0.209346      18620.0              73.0   \n",
       "8    enhancing(f=16)  cifar10  0.296274      18032.0              49.0   \n",
       "..               ...      ...       ...          ...               ...   \n",
       "286  enhancing(f=16)   celeba  0.040007      14421.0               3.0   \n",
       "289  enhancing(f=16)   celeba  0.032749      25707.0               6.0   \n",
       "294  enhancing(f=16)   celeba  0.031831      28215.0               5.0   \n",
       "301  enhancing(f=16)   celeba  0.033892      21318.0               4.0   \n",
       "303  enhancing(f=16)   celeba  0.032674      49533.0               7.0   \n",
       "\n",
       "     last_global_step  last_val_loss  last_codebook_eff_dim  codebook_dim  \\\n",
       "0             19404.0       0.268596                   22.0            32   \n",
       "1             19404.0       0.111633                   80.0           128   \n",
       "2             19404.0       0.181648                   41.0            64   \n",
       "7             19404.0       0.210414                   73.0           256   \n",
       "8             19404.0       0.296781                   49.0           128   \n",
       "..                ...            ...                    ...           ...   \n",
       "286           62073.0       0.045002                    3.0             6   \n",
       "289           62073.0       0.036032                    6.0            32   \n",
       "294           62073.0       0.033701                    5.0             8   \n",
       "301           62073.0       0.037218                    4.0             6   \n",
       "303           62073.0       0.032906                    7.0             8   \n",
       "\n",
       "     codebook_size  \n",
       "0              512  \n",
       "1              512  \n",
       "2              512  \n",
       "7              512  \n",
       "8              512  \n",
       "..             ...  \n",
       "286            512  \n",
       "289            512  \n",
       "294            512  \n",
       "301            512  \n",
       "303            512  \n",
       "\n",
       "[94 rows x 10 columns]"
      ]
     },
     "execution_count": 142,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_[['arch', 'dataset', 'val_loss', 'global_step', 'codebook_eff_dim', 'last_global_step', 'last_val_loss', 'last_codebook_eff_dim', 'codebook_dim', 'codebook_size']]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array(['enhancing(f=16)', 'taming(f=16)'], dtype=object), 94)"
      ]
     },
     "execution_count": 144,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_[\"arch\"].unique(), len(df_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 145,
   "metadata": {},
   "outputs": [],
   "source": [
    "# rename taming -> CNN, enhancing -> ViT, cifar10 -> CIFAR10, celeba -> CelebA\n",
    "df_['Architecture'] = df_['arch'].apply(\n",
    "    lambda x: x.replace(\"taming\", \"CNN\").replace(\"enhancing\", \"ViT\")\n",
    ")\n",
    "df_['dataset'] = df_['dataset'].replace({\n",
    "    'cifar10': 'CIFAR10',\n",
    "    'celeba': 'CelebA'\n",
    "})\n",
    "df_[\"Dataset\"] = df_[\"dataset\"]\n",
    "\n",
    "df_ = df_.rename(columns={\n",
    "    'codebook_eff_dim': 'Effective Dim',\n",
    "    'val_loss': 'Val Loss',\n",
    "    'f': 'Scale Factor ($f$)',\n",
    "    'codebook_size': 'Codebook Size',\n",
    "    'codebook_dim': 'Background Dim',\n",
    "    \"cw\": \"Commitment Loss Weight\",\n",
    "    \"thr\": \"Code Restart Threshold\",\n",
    "    \"dec\": \"EMA Decay\",\n",
    "    \"split_vq\": \"DCVQ\",\n",
    "})"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Demos"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 146,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "sns.set_context(\"paper\", font_scale=1.2)\n",
    "sns.set_style(\"whitegrid\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 450x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "\n",
    "def draw_simplified(df, x_col, x_log=False, y_log=False, figsize=(4.5, 4)):\n",
    "    df = df.copy()\n",
    "    # Plot\n",
    "    plt.figure(figsize=figsize)\n",
    "    # sort by architecture\n",
    "    df = df.sort_values(by=['Architecture', 'Dataset'])\n",
    "    sns.scatterplot(data=df, x=x_col, y='Val Loss', hue='Dataset', style='Architecture', legend=True, alpha=0.5, s=50, edgecolor='black')\n",
    "    # sns.lineplot(data=df, x=x_col, y='Val Loss', hue='Dataset', style='Architecture', legend=False, estimator='mean')\n",
    "    plt.title(f'Validation Loss vs {x_col}')\n",
    "    plt.xlabel(x_col)\n",
    "    plt.ylabel('Validation Loss')\n",
    "    plt.grid(True)\n",
    "    if x_log:\n",
    "        plt.xscale('log')\n",
    "    if y_log:\n",
    "        plt.yscale('log')\n",
    "    plt.tight_layout()\n",
    "    plt.grid(True)\n",
    "    plt.ylim(0, 1)\n",
    "    plt.xlim(0, max(df[x_col]) * 1.1)\n",
    "    # plt.legend(frameon=False)\n",
    "    plt.legend(fontsize=8)\n",
    "\n",
    "\n",
    "# Visualize both key relationships\n",
    "draw_simplified(df_, 'Effective Dim', y_log=True)\n",
    "# save fig\n",
    "# plt.savefig(\"large_scale_effective_dim_vs_val_loss.pdf\", dpi=300, bbox_inches='tight', format='pdf')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 239,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from matplotlib.colors import LogNorm\n",
    "# matplotlib.colormaps[name]\n",
    "from matplotlib import colormaps\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.rcParams['axes.labelsize'] = 12  # Default size for x and y labels\n",
    "\n",
    "# from scipy.stats import norm\n",
    "# def gaussian_band(x, y, x_grid, bandwidth=1.0):\n",
    "#     band_upper = []\n",
    "#     band_lower = []\n",
    "#     mean_vals = []\n",
    "\n",
    "#     for xg in x_grid:\n",
    "#         weights = norm.pdf(x - xg, scale=bandwidth)\n",
    "#         if np.sum(weights) > 0:\n",
    "#             avg = np.sum(weights * y) / np.sum(weights)\n",
    "#             var = np.sum(weights * (y - avg)**2) / np.sum(weights)\n",
    "#             std = np.sqrt(var)\n",
    "#         else:\n",
    "#             avg = np.nan\n",
    "#             std = 0\n",
    "#         mean_vals.append(avg)\n",
    "#         band_upper.append(avg + std)\n",
    "#         band_lower.append(avg - std)\n",
    "\n",
    "#     return np.array(mean_vals), np.array(band_lower), np.array(band_upper)\n",
    "\n",
    "\n",
    "\n",
    "def draw_grid(df, x_col=\"Effective Dim\", y_col=\"Val Loss\", x_log=False, y_log=False,\n",
    "                size_key=\"Codebook Size\", symbol_key=\"Background Dim\", hue_key=\"Weight of Rank Regularization\", alpha=0.9,\n",
    "                figsize=(18, 8), min_size=10, max_size=100, log_size=True, title=None, discrete_color=False, corr_df=None, no_legend=False, legend_ncol=20, ylim=None, \n",
    "                share_x=False, share_y=False, add_diag_line=False, cmap=\"viridis\"):\n",
    "              \n",
    "    datasets = [\"CelebA\", \"CIFAR10\"]\n",
    "    vars = [\"\"] # dummy\n",
    "    archs = [\"CNN\", \"ViT\"]\n",
    "\n",
    "\n",
    "    fig, axs = plt.subplots(nrows=2, ncols=2, figsize=figsize, sharex=share_x, sharey=share_y)\n",
    "    axs = axs.reshape(2, 2)\n",
    "\n",
    "    # Make sure that each value is treated as a categorical variable\n",
    "    # To achieve this, we convert it to string\n",
    "    # and then sort it to maintain the order\n",
    "    df = df.copy()\n",
    "    if size_key is not None:\n",
    "        # df[size_key] = df[size_key].astype(float)\n",
    "        sorted_size_keys = sorted(df[size_key].unique())\n",
    "        sorted_size_keys = [str(x) for x in sorted_size_keys]\n",
    "        df[size_key] = df[size_key].astype(str)\n",
    "        sizes = {\n",
    "            x: (np.log2(float(x)) if log_size else float(x))\n",
    "              for x in sorted_size_keys\n",
    "        }\n",
    "        # scale such that the smallest size is 10 and the largest is 100\n",
    "        sizes = {x: min_size + (max_size - min_size) * (sizes[x] - min(sizes.values())) / (max(sizes.values()) - min(sizes.values())) for x in sizes}\n",
    "\n",
    "    if symbol_key is not None:\n",
    "        # Also make sure that the symbol_key is treated as a categorical variable\n",
    "        # df[symbol_key] = df[symbol_key].astype(float)\n",
    "        sorted_symbol_keys = sorted(df[symbol_key].unique())\n",
    "        sorted_symbol_keys = [str(x) for x in sorted_symbol_keys]\n",
    "        df[symbol_key] = df[symbol_key].astype(str)\n",
    "    \n",
    "\n",
    "    if hue_key is not None and not discrete_color:\n",
    "        hue_norm = LogNorm(vmin=df[hue_key].min(), vmax=df[hue_key].max() + 0.03) # avoid bright yellow\n",
    "        if not callable(cmap):\n",
    "            cmap = colormaps[cmap]\n",
    "    elif hue_key is not None and discrete_color:\n",
    "        # df[hue_key] = df[hue_key].astype(float)\n",
    "        if hue_key == \"Rotation Trick\":\n",
    "            sorted_hue_keys = [\"Disabled\", \"Enabled\"]\n",
    "        else:\n",
    "            sorted_hue_keys = sorted(df[hue_key].unique())\n",
    "        sorted_hue_keys = [str(x) for x in sorted_hue_keys]\n",
    "        df[hue_key] = df[hue_key].astype(str)\n",
    "        if not callable(cmap):\n",
    "            cmap = colormaps[cmap]\n",
    "        palette = {\n",
    "            x: cmap(i / (len(sorted_hue_keys) - 1))\n",
    "            for i, x in enumerate(sorted_hue_keys)\n",
    "        }\n",
    "\n",
    "    for i, dataset in enumerate(datasets):\n",
    "        for j, var in enumerate(vars):\n",
    "            for k, arch in enumerate(archs):\n",
    "                ax = axs[i, j*2 + k]\n",
    "                cond = (\n",
    "                    (df[\"Dataset\"] == dataset) &\n",
    "                    (df[\"Architecture\"].str.contains(arch)) &\n",
    "                    (df[\"Architecture\"].str.contains(var)) & \n",
    "                    (~df[\"path\"].str.contains(\"euclidean\")) # exclude euclidean\n",
    "                )\n",
    "                subset = df[cond].copy()\n",
    "                if subset.empty:\n",
    "                    print(f\"Empty subset for {dataset}, {arch}, f={16}\")\n",
    "                    ax.set_visible(False)\n",
    "                    continue\n",
    "\n",
    "\n",
    "                kwargs = {}\n",
    "                if size_key is not None:\n",
    "                    kwargs.update(dict(\n",
    "                        size=size_key,\n",
    "                        sizes=sizes,\n",
    "                        size_order=sorted_size_keys,\n",
    "                    ))\n",
    "                else:\n",
    "                    kwargs.update(dict(\n",
    "                        s=min_size,\n",
    "                    ))\n",
    "                if symbol_key is not None:\n",
    "                    kwargs.update(dict(\n",
    "                        style=symbol_key,\n",
    "                        style_order=sorted_symbol_keys,\n",
    "                    ))\n",
    "                if hue_key is not None and not discrete_color:\n",
    "                    kwargs.update(dict(\n",
    "                        hue=hue_key,\n",
    "                        hue_norm=hue_norm, \n",
    "                        palette=cmap,\n",
    "                    ))\n",
    "                elif hue_key is not None and discrete_color:\n",
    "                    kwargs.update(dict(\n",
    "                        hue=hue_key,\n",
    "                        palette=palette,\n",
    "                        hue_order=sorted_hue_keys\n",
    "                    ))\n",
    "\n",
    "                sns.scatterplot(\n",
    "                    data=subset,\n",
    "                    x=x_col,\n",
    "                    y=y_col,\n",
    "                    **kwargs,\n",
    "                    ax=ax,\n",
    "                    legend=(ax == axs[0, 0]),\n",
    "                    alpha=alpha,\n",
    "                    # edgecolor=\"none\",\n",
    "                )\n",
    "                # add lineplot\n",
    "                sns.lineplot(\n",
    "                    data=subset,\n",
    "                    x=x_col,\n",
    "                    y=y_col,\n",
    "                    **{k:v for k, v in kwargs.items() if k not in ['s', 'size', 'sizes', 'size_order', 'style', 'style_order']},\n",
    "                    ax=ax,\n",
    "                    legend=False,\n",
    "                    alpha=alpha,\n",
    "                    # edgecolor=\"none\",\n",
    "                    linewidth=1.5,\n",
    "                )\n",
    "                # annotate each point if it contains DCVQ using num_quantizers\n",
    "                if corr_df is None and False:\n",
    "                    texts = []\n",
    "                    for idx, row in subset.iterrows():\n",
    "                        if row[\"dim_per_quantizer\"] == 8:\n",
    "                            offset = -2\n",
    "                        elif row[\"dim_per_quantizer\"] == 32:\n",
    "                            offset = 2\n",
    "                        if True:\n",
    "                            offset = 0\n",
    "                        if True:\n",
    "                            # scale = 1.5\n",
    "                            scale = 1.1\n",
    "\n",
    "                        if row[\"num_quantizers\"] > 1:\n",
    "                            text = ax.annotate(\n",
    "                                f\"{row['num_quantizers']}x{row['dim_per_quantizer']}d\",\n",
    "                                (row[x_col] + offset, row[y_col] * scale),\n",
    "                                fontsize=10,\n",
    "                                ha='center',\n",
    "                                va='center',\n",
    "                                alpha=0.7,\n",
    "                                color=palette.get(row[hue_key], 'black') if hue_key else 'black',\n",
    "                            )\n",
    "                            texts.append(text)\n",
    "                else:\n",
    "                    texts = None\n",
    "\n",
    "                if corr_df is not None:\n",
    "                    try:\n",
    "                        group_corr = corr_df.loc[(dataset, f, arch)]\n",
    "                        group_corr = group_corr.reset_index()\n",
    "                        texts = []\n",
    "                        for bg_dim, corr_val in group_corr.iloc:\n",
    "                            if not pd.isna(corr_val):\n",
    "                                text = ax.text(\n",
    "                                    float(bg_dim),              # x position (Background Dim)\n",
    "                                    ax.get_ylim()[1],          # y position (top of y-axis)\n",
    "                                    fr\"$r$={corr_val:.2f}\",         # formatted correlation\n",
    "                                    ha=\"center\", va=\"top\",\n",
    "                                    fontsize=8, color=\"gray\", rotation=90,\n",
    "                                )\n",
    "                            else:\n",
    "                                text = ax.text(\n",
    "                                    float(bg_dim),              # x position (Background Dim)\n",
    "                                    ax.get_ylim()[1],          # y position (top of y-axis)\n",
    "                                    r\"$r$=NA\",                     # formatted correlation\n",
    "                                    ha=\"center\", va=\"top\",\n",
    "                                    fontsize=8, color=\"gray\", rotation=90,\n",
    "                                )\n",
    "                            texts.append(text)\n",
    "                    except KeyError:\n",
    "                        pass  # No correlation data for this plot\n",
    "\n",
    "                # if True: # debug\n",
    "                #     # annotate each point wiht Architecture\n",
    "                #     for idx, row in subset.iterrows():\n",
    "                #         ax.annotate(\n",
    "                #             row[\"Architecture\"],\n",
    "                #             (row[x_col], row[y_col]),\n",
    "                #             fontsize=8,\n",
    "                #             ha='center',\n",
    "                #             va='center',\n",
    "                #             alpha=0.7,\n",
    "                #             color='black',\n",
    "                #         )\n",
    "\n",
    "                # # groupby hue_key and plot the mean\n",
    "                # for hue_val, group in subset.groupby(hue_key):\n",
    "                #     # sns.regplot(\n",
    "                #     #     data=group,\n",
    "                #     #     x=x_col,\n",
    "                #     #     y=y_col,\n",
    "                #     #     lowess=True,\n",
    "                #     #     scatter=False,\n",
    "                #     #     ax=ax,\n",
    "                #     #     color=cmap(hue_norm(hue_val)),\n",
    "                #     # )\n",
    "                #     from statsmodels.nonparametric.smoothers_lowess import lowess\n",
    "                #     smoothed = lowess(endog=group[y_col], exog=group[x_col], frac=0.5)\n",
    "                #     ax.plot(\n",
    "                #         smoothed[:, 0],\n",
    "                #         smoothed[:, 1],\n",
    "                #         label=hue_val,\n",
    "                #         color=cmap(hue_norm(hue_val)),\n",
    "                #         alpha=0.1,\n",
    "                #     )\n",
    "\n",
    "                # for hue_val, group in subset.groupby(hue_key):\n",
    "                #     x = group[x_col].values\n",
    "                #     y = group[y_col].values\n",
    "\n",
    "                #     # Define a common x grid to smooth over\n",
    "                #     x_grid = np.linspace(np.min(x), np.max(x), 100)\n",
    "\n",
    "                #     # Apply Gaussian smoothing\n",
    "                #     mean_y, lower_y, upper_y = gaussian_band(x, y, x_grid, bandwidth=3.0)\n",
    "                #     ax.plot(x_grid, mean_y, color=cmap(hue_norm(hue_val)), alpha=0.6)\n",
    "                #     ax.fill_between(x_grid, lower_y, upper_y, color=cmap(hue_norm(hue_val)), alpha=0.2)\n",
    "\n",
    "                ax.set_title(f\"{dataset}, {arch}, f={16}\", fontweight='bold', fontsize=12)\n",
    "                if x_log:\n",
    "                    ax.set_xscale(\"log\")\n",
    "                if corr_df is not None:\n",
    "                    # treat x as categorical\n",
    "                    ax.set_xticks(sorted(subset[x_col].unique()))\n",
    "                    ax.set_xticklabels(sorted(subset[x_col].unique()), rotation=45)\n",
    "                    \n",
    "                if y_log:\n",
    "                    ax.set_yscale(\"log\")\n",
    "                xlim = ax.get_xlim()\n",
    "                ax.set_xlim(0, xlim[1]) \n",
    "                if ylim is not None:\n",
    "                    ax.set_ylim(ylim[0], ylim[1])\n",
    "                ax.grid(True)\n",
    "\n",
    "                if texts is not None:\n",
    "                    # Adjust the text positions to avoid overlap\n",
    "                    from adjustText import adjust_text\n",
    "                    # adjust_text(texts, arrowprops=dict(arrowstyle=\"-\", color='gray', lw=0.5), ax=ax)\n",
    "                    adjust_text(texts, ax=ax,\n",
    "                    expand_text=(1.2, 1.2), # Optional: spacing between texts and points\n",
    "                    expand_points=(1.1, 1.1),\n",
    "                    )\n",
    "    if add_diag_line and share_x and share_y:\n",
    "        xlim = max(ax.get_xlim()[1] for ax in axs.flatten())\n",
    "        ylim = max(ax.get_ylim()[1] for ax in axs.flatten())\n",
    "        xy_lim = [0, min(xlim, ylim)]\n",
    "        for ax in axs.flatten():\n",
    "            ax.plot(xy_lim, xy_lim, color='gray', linestyle='--', linewidth=0.5)\n",
    "            # annotate the line\n",
    "            # Add rotated annotation\n",
    "            ax.annotate(\n",
    "                \"Upper bound\",\n",
    "                xy=(xy_lim[1], xy_lim[1]),\n",
    "                xytext=(xy_lim[1] * 0.9*0.9, xy_lim[1] * 0.8*0.9),\n",
    "                fontsize=12,\n",
    "                rotation=67,\n",
    "                rotation_mode='anchor',\n",
    "                ha='center',\n",
    "                va='bottom',\n",
    "            )\n",
    "\n",
    "    if not no_legend:\n",
    "        handles, labels = axs[0, 0].get_legend_handles_labels()\n",
    "        single_legend_type = (None if sum(i is not None for i in (hue_key, symbol_key, size_key)) != 1 else (hue_key or symbol_key or size_key))\n",
    "        if single_legend_type is not None:\n",
    "            bbox_to_anchor = (0.5, -0.1)\n",
    "        else:\n",
    "            bbox_to_anchor = (0.5, -0.05)\n",
    "        fig.legend(\n",
    "            handles=handles,\n",
    "            labels=labels,\n",
    "            loc=\"lower center\",\n",
    "            bbox_to_anchor=bbox_to_anchor,  # Adjust vertical spacing as needed\n",
    "            ncol=legend_ncol,\n",
    "            title=single_legend_type,\n",
    "            fontsize=11,\n",
    "        )\n",
    "\n",
    "    if axs[0, 0].legend_ is not None:\n",
    "        axs[0, 0].legend_.remove()  # Remove legend from the first subplot\n",
    "\n",
    "    # # After plotting all subplots (inside your loop or afterward), add this:\n",
    "    # # Share x within columns\n",
    "    # for col in range(4):\n",
    "    #     base_ax = axs[0, col]\n",
    "    #     axs[1, col].get_shared_x_axes().join(axs[1, col], base_ax)\n",
    "    # # Share y within same dataset and f\n",
    "    # for i, dataset in enumerate(datasets):\n",
    "    #     for j, f in enumerate(fs):\n",
    "    #         base_ax = axs[i, j*2]\n",
    "    #         axs[i, j*2 + 1].get_shared_y_axes().join(axs[i, j*2 + 1], base_ax)\n",
    "\n",
    "    # make suptitle closer to the plots\n",
    "    if corr_df is not None:\n",
    "        avg_corr = corr_df[\"Correlation\"].dropna().mean()\n",
    "        full_title = f\"{title}\\nAverage correlation: r = {avg_corr:.2f}\"\n",
    "    else:\n",
    "        full_title = title\n",
    "\n",
    "    fig.suptitle(full_title, fontsize=16, fontweight='bold', y=0.92)\n",
    "    fig.subplots_adjust(top=0.9)\n",
    "    fig.tight_layout(rect=[0, 0, 1, 0.96])\n",
    "    return axs\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Finals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 242,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxEAAAJwCAYAAAD2uOwtAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdeXwU5f3A8c/slU2yue+EQDgkgBABpYgcKl5IRRGrqHhrFRUVf7b1bK1YRK1aRRS0WCqKVK14g6j1BFFEDrkEgQTIHXInm73n98ewQ5YkkA25+b5fr30lczyzz06y88x3nktRVVVFCCGEEEIIIZrJ0NEZEEIIIYQQQnQtEkQIIYQQQgghgiJBhBBCCCGEECIoEkQIIYQQQgghgiJBhBBCCCGEECIoEkQIIYQQQgghgiJBhBBCCCGEECIoEkQIIYQQQgghgiJBhBBCCCGEECIopo7OgOgebrnlFr766it9+Y477mDGjBlN7v/tt99y00036csJCQl89dVXmEwt+5fMzc3lrLPO0pd/85vf8Nprr+nLzz//PPPmzdOX58yZw5QpU5p9/Pvuu493331XX168eDEjR45sUV5batmyZdx///368owZM7jjjjvaNQ8tdfj560p5Px5lZmY2e98XXniBs88+O2Dd3r17efHFF1m7di0lJSW43W4AIiIiWLdunb7f8uXLWbp0KTt37qSqqgqfzwfANddcw4MPPtgKn6TtXH311axdu1Zf/t///kePHj06MEdHd/j3EMBkMmE2m7HZbCQmJtKnTx/GjBnD+eefT0hISKPH6crXovb2ww8/cM011+jLF198MY8//ngH5kiI1iM1EaJVXHzxxQHLH3744RH3f//99wOWJ02a1OIAoqu77777yMzM1F8//PBDR2dJiBYrLS3lsssu47333iM/P18PIA733//+l7vvvpu1a9dSUVGhBxAdrf53cfz48R2dnTbn8Xioq6ujpKSErVu38uGHH3Lvvfcybtw43nvvvY7OnhCiEzs+79pEqxs/fjzR0dFUVFQAkJOTw8aNGxk6dGiDfWtra/n8888D1h0ehLS2vn37ct555+nLaWlpbfp+bSEtLS3gM/Tt27cDcyOOJ+PGjSM0NLTRbYmJiQHLn376qX4dAIiKimL48OFYLJaAY7z11lsB6fr3709GRgaKojBw4MDWy3wbGTFiBDEx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uOyyy3jnnXfYuHEjBQUFOJ1OQkNDSU1NZcCAAZx66qmN/k1mzJjB+eefz1tvvcXatWvZv38/dXV1REREkJqayogRIwJqIUCb10JRFN5++22ys7OPuePylClTmDt3bkDNwQUXXBDQ3Opwf/jDH/SBAdatW0dubi51dXWEhISQnJxM//799UEnjpXBYMBisRAREUFCQgJ9+vRhzJgxTJw4sUFTy87i6quv5owzzuDNN9/k+++/Z9++fdTU1GCxWEhISKBfv36MGDGCc845p8FgBS3VVt/HY7nGCdHRFLWzDHEjhBBCCCGE6BK6xuNIIYQQQgghRKchQYQQQgghhBAiKBJECCGEEEIIIYIiQYQQQgghhBAiKBJECCGEEEIIIYIiQYQQQgghhBAiKBJECCGEEEIIIYIiQYQQQgghhBAiKBJECCGEEEIIIYIiQYQQQgghhBAiKBJECCGEEEIIIYIiQYQQQgghhBAiKBJECCGEEEIIIYIiQYQQQgghhBAiKBJEiE4vMzOTzMxMxo8f36HHEEeXk5PD9OnTGTVqlH7OP//8847OlhDiOCPlhuaHH37QP8d9993X5u9XU1PDrFmzOPPMMxk4cCCZmZnMnj27zd9XdAxTR2dAdB92u5233nqLzz77jF27dmG320lISOCEE05g4sSJnH/++Vgslo7OZlCKioo444wz8Pl8AERERPDdd9+16ucoLCxk8eLFrFq1itzcXHw+HykpKWRlZTF58mRGjRoFwPPPP8+8efP0dC+//DKnn366vnzffffx7rvvAvDXv/6VK664osF6RVH48MMPOeGEE/R0V199NWvXrgXgn//8J+PGjWvR5/B6vcyYMYNff/21RekbU1FRwSuvvMKGDRvYvHkzDocDgIsvvpjHH3+80TSqqvL+++/z9ttvs2PHDlwuF3FxcWRlZXH77bfTv3//VsufEOLYSLnRPHa7ndNOO426ujoAPv/8c9LT0xvsN3XqVDZu3AjA3//+d5KSkhrsM378ePLy8pr1vosXL2bkyJHNzueTTz7Jm2++2ez9m+Nf//oXa9euZcOGDVRUVACQlpbGF1980WSan376iUWLFrF+/XqqqqqIjo7mhBNOYNq0aZx99tmtmr/jmQQRolXs2rWL6dOns3///oD1eXl55OXl8dVXX9G/f38GDhzYQTlsmRUrVugFAUB1dTXffPNNq12EVq5cyX333Yfdbg9Yv2fPHvbs2cP//vc/1q1b12ja+fPnBwQRzaGqKgsWLODpp59ucZ6bkpubqwcQGRkZ/OUvfyEkJIR+/fq1+JgFBQW8/PLLzd7f6/Vyzz33sGLFioD1+fn55OfnM378eAkihOgkpNxovrCwMMaPH8/HH3+sv8fNN98csE9BQQGbNm0CwGq1ctZZZ+Hz+ViyZAkA8fHxLX7/5vrqq68AMJvNPPnkkyQmJjYayATjxRdfpLq6utn7L168mMceewxVVfV1JSUllJSUkJqaKkFEK5IgQhyziooKfv/735Ofnw9AYmIiN954I5mZmdTW1rJ27VqWLVvWwblsmY8++qjBuo8//rhVLkIbNmzgnnvuwe12A5CVlcW0adNITk6muLiYr776itWrVx8x/Zo1a/SaiuZasWIFd9xxBxkZGceS/QaKi4v134cOHcro0aOP+Zhms5kRI0YwbNgwSktLeeedd464/yuvvKIHEL179+a6666jZ8+eVFZW8vPPP5OYmHjMeRJCHDspN4I3ceLEIwYRn3zyiX7jfPrppxMeHg7AKaecErDfc889h9Pp1JdnzpxJSUkJAA899FBA0JaZmRlUHv3lQEJCAhMnTgwqbVMGDhxI3759SUlJ4ZlnnjnivuvXr2fOnDmoqkpUVBTXXXcdgwcPxu12s2vXLv2ciNYhQYQ4Zv/617/0giAiIoL//ve/AU8ezj77bG655RaMRqO+zu128/rrr/Phhx+yZ88eAE444QSuuuoqLrrooma9b0uPkZuby+zZs/n++++xWCxMnDiRP/7xj4SFhQXst2/fPjZv3gzA8OHDKSgooKCggC+//BK73d5g/2A98cQTegAxbNgwXnvtNcxms779wgsvZPfu3Uc8xvz584MOIrxeLy+99BJz5swJPtNNqN8kCuC9997jvffeA+B///sfiYmJ/Pzzz806VmZmJhEREQD069eP119/HYClS5ceMYhwOp288sorgPbEbenSpcTExOjbzz///KA+kxCi7Ui5Ebxx48YRGRlJVVUV27ZtY+/evfTq1Uvf/sknn+i/X3DBBYDWJ+Kaa64BDjUDHTJkSMBx6zez6t+/f4OgozkOb26bn5+vByBz5sxhypQpbN68OSB4aUpqaiqpqan68muvvQbA7t27jxpELFiwQK8FevHFFwM+y1lnndX8DySaRYIIccyWL1+u/37dddc1WnUZFxen/+52u/n973/PmjVrAvb5+eef+dOf/sTOnTv54x//eMT3bOkxamtrmTZtGoWFhYDWzvSNN95g//79LFy4MGBf/xMf0G5Ac3NzefXVV6mrq+OLL77QL9ItUVBQwIYNG/Tl//u//wsIIPz69u3baPrBgwezZcsWfvjhBzZs2MCwYcOa9b7+dB9++CEzZswgLS2tZR8gSMXFxUybNq1Z+wbbBtdv/fr1envZzMxMZs2axQ8//IDdbicrK4u77rqLk08+OejjCiFan5QbwbNYLJxzzjn6w5QVK1Ywffp0QLtp9zdlstlsQTd1bQ933XVXs/pizJgxgzvuuCPo4zudTr777jtAq9n68ssv+dOf/kRJSQkZGRlcd911XHLJJUEfVzRNRmcSx6S2tjagPWtzbtIWL16sX8SHDh3KCy+8wNy5c+nduzcACxcu1C+GrX2MiooK4uLieOGFF/jzn/9MaGgoAN9++22DTlr+wkBRFM477zzOO++8Btta6pdfftF/NxqNzQ4C/EaNGsXQoUMB7WlLc02ePJmUlBTcbjf//Oc/g3rPI3nooYd46KGH9OVx48axZMkSlixZ0m5NiOrX2qxevZrly5dTWlpKXV0dP/zwA9deey3ff/99u+RFCNE0KTda7re//a3+e/2+XytXrtSbMp111lmEhIQc83sF45JLLtH7XoDWnMlfBrRXQLN37169dr+4uJiFCxeSl5eHy+Vi586dPPDAA8yfP79d8nK8kCBCHJOampqA5ebcMH7wwQf679dddx3R0dHExcUxadKkRvdp7WP84x//4Oyzz+aqq67i2muv1dfXH4p0586deifhoUOHkpSUxPDhw/XP9+2331JVVXXUz9qU+p3EYmJiGq2FOBr/E6hvvvmGLVu2NCuNyWTipptuAuCdd96hqKgo6PdtTGZmZkCH5bi4OE455RROOeUULBYLPXr0YMeOHc16taQWAmjw97jgggt4+eWX9Sd/bre7yRGdhBDtR8qNljv11FP1GppffvmF7OxsIDCgqB9otJfU1NSApkMWi0UvA/z5/eKLL5pVBrSkFgIalgEDBw5kwYIFzJw5U1/3wgsvUFpa2qLji4akOZM4JjabLWC5uLi4ySY4fjk5Ofrv9b/c9R2tL0BLjxEdHR3QhjQrK0v/vf6TsfpPjPxPkvxPll577TXcbjeffvopv/vd746Yz6b42/wDlJeX43a7gw4kzjzzTAYNGsS2bduYP39+wDGP5NJLL2XBggWUlJTofQjamsvlalGfiGDUb9drNpt59NFHCQsL45RTTmHlypW43W62b99OeXl5QF8JIUT7knKjZeUGaDXXEyZM0J/6r1ixgsmTJ+vX1+jo6FYZ1KIttLRPRHMdPoTuH//4R0aPHs2ZZ57J119/zYYNG3C73axbty6ghki0nAQR4piEh4eTnp6uX0jXr18fdEffxvjHwm7rYyiK0uj6+u11H3/88UafYC9fvrzFhcGAAQP0371eL5s2bWpRZ7bp06dz55138r///Y9BgwY1K01ISAg33HADTzzxBG+99Va79Itojz4R9Qud6OhovQNjeHg40dHR+ugjNTU1EkQI0YGk3Gh5EAFaTUP9IMJqtepNmc477zxMps55a9fWfSIODzzqL6empur9EA+vCRMtJ82ZxDGrP4zbv//970abyJSWluqdXusPLfr55583Wp3573//+4jv2dJjVFRUsHfvXn25fvtX/8Q9P//8M/v27Tvi+wN8//33La4WTUlJCegH8fTTT+ttOes72pO1c889l379+qGqKlu3bm32+19++eXExMRQV1fHrl27mp/xTmzo0KF64V5RUaHfDNjtdv1/z2w2k5CQ0FFZFEIcJOVGyw0fPly/Qd65cyeLFy/Wt3VEU6bOIj4+np49e+rLBQUF+u/+kcBAK39F6+ic4aroUm644QY+/PBD8vPzqaqq4rLLLuOGG26gf//+AeN9v/baa0RHRzNp0iS9Y/H06dO56aab9LkR9uzZwxdffMH111/PlClTmnzPYznGPffcw6233qrPFO3nH/6t/hjfEydObNDp7/PPP2fNmjV4vV4++eQT/Ql7/Zmhm/M0/d577+Xqq6/G7Xazfv16pk2bxpVXXklycjIlJSV8+eWXrF69mh9++KHJYyiKwi233HLUUUkOFxYWxrXXXsuzzz7b5D71h+zzD9HXUv4+EcGqq6vj66+/BmD79u36+ry8PH04wyFDhpCWlkZqaipjxozh22+/xe128+c//5kLL7yQ999/Xw/Qxo4di9VqbfHnEEK0Dik3WlZugHbdP//88/XmqP6b5cTEREaMGHHU9M3V2PCwx+JIM0wfyddff01dXV3AXER1dXV6GZCWlqYPW3vppZfqk6k+9dRT3HnnnezYsUOvhYiPj5dR+lqRBBHimEVHR/PPf/5Tn3m0sLCQxx57rMn9r7nmGlatWsWaNWvYtWsX9913X9Dv2dJjREREkJeXx2233RawfvTo0YwfPx6fzxfQQe3WW29tMMNxcnKyPsLHxx9/3OxmOocbNmwYTz/9tD5j9aZNmxqMDNKcvgG//e1vmTdvXsCTsua46qqreOWVV4KaCbS9lZaWctdddzVYv3btWn1eivoBzsMPP8wVV1xBSUkJH374IR9++KGeJj4+ngcffLB9Mi6EOCIpN1pWbvhdcMEFDfq0TZgwAYOh+zUweeSRRxo0gyorK9PLhvoBznXXXcdXX33FTz/9xNatW7nlllv0NGazmVmzZrX7yFXdWff7bxMdol+/fnzwwQfcf//9nHzyyURHR2M2m0lJSWHMmDE88cQTesc5i8XCwoULeeihh8jKyiI8PJyQkBB69OjBGWecwezZsznnnHOO+H4tPUZkZCRLlixh7NixhIWFER0dzeWXX87zzz+Poij8+OOP+tOOHj16NCgIQCs4/Beh9evX60+B/BPc+PPXHOeddx4rVqzgxhtvpH///oSFhWG1WunVqxcXXHABc+fOPeoxjEZjg5lLmyMiIoKrr766ye0t+TwdLT09nbfffptLLrmEhIQETCYTiYmJXHrppSxbtowePXp0dBaFEAdJudHy6+ygQYP0oWn9WrspU1csAywWC//617+YMWMGGRkZmM1moqKiOPPMM1myZIlMONfKFNXfG0cIcUwmTZrEzp07GT58OG+88UaTne+6iunTp/Pll1+Snp7Oxx9/LE9vhBCilXXmcmPRokU8/vjjmEwm3n//ffr169fRWRKdjNRECNEKysvL+fXXXzEajTz88MOdqiBoCZ/Px08//QTAgw8+KAGEEEK0ss5ebvibjF5zzTUSQIhGSRAhRCv46aefUFWVyy+/PGD41q5qx44dVFVVccYZZ3DmmWd2dHaEEKLb6czlhv9BUkJCArfffntHZ0d0UtKcSQghhBBCCBEUqYkQQgghhBBCBEWCCCGEEEIIIURQJIgQQgghhBBCBEUmm2sBj8dDZWUlISEh3XJiFyFE9+fz+XA6nURFRWEydf6iYPv27Tz66KNs2bKF+Ph4brjhBq666qqjpsvNzeWRRx7hxx9/xGazcdlllzFjxowG1+5t27bx9NNPs379egwGA5mZmTzxxBOkp6c3O49SNgghurpgyobOX3J0QpWVleTk5HR0NoQQ4phlZGQQFxfX0dk4orKyMq6//nqysrJ46aWX2Lp1K4899hg2m43Jkyc3mc7lcnHjjTcSFRXF3LlzKSwsZM6cORiNxoARZ7Zs2cJVV13FhAkTeP755/F4PGzYsAGXyxVUPqVsEEJ0F80pGySIaAH/mPk9e/YkPDy8g3PTvXm9Xnbu3En//v0xGo0dnZ1uT853++noc11XV0dOTk6XmANk6dKlKIrCc889R2hoKKNGjSI3N5f58+cfMYhYvnw5eXl5LF68mKSkJEC70Z8/fz433XST/tn/+te/cu655/L444/rac8444yg8yllQ8t19PehK5Nz13Jy7hoKpmyQIKIF/NXUVquVsLCwDs5N9+b1egEICwvrNF9wj8eDwWDols0VOuP57q46y7nuCv/Hq1at4vTTTyc0NFRfN2HCBJYuXcr+/fubbHK0atUqhg0bpgcQ/nRPPfUU69evZ9SoUfz6669s3ryZhx566JjzebSywefz4fP5ukTzsfbWWb4PXZGcu5aTc9e05pQNnb/0EKKTqKqqIjs7m+3bt7N9+3YKCwtxOBwdnS0hur2cnBz69OkTsM6/vGfPniOm6927d8C69PR0LBYL2dnZAPz8888AVFRUcMEFFzBo0CAmTJjAJ5980mr5dzgcFBYW6teO7OxsqqqqWu34QgjREeRxiBDNUFpayt69e/H5fPq63NxcysvL6d27N1artQNzJ0T3VlVVRURERMC6qKgofduR0kVGRjZYHxkZqac7cOAAAPfeey8333wzgwYN4r333mPmzJm88847nHjiiUHn1+fz6U84nU4n2dnZ2O12fbvD4aCsrIxevXoRExMT9PG7I//58v8UzSfnruXk3DUUzLmQIEKIo3C5XOTl5QUEEH61tbWUlZWRmpraATkTQhwr//f60ksv5cYbbwTg1FNPZdu2bSxatIinnnoq6GPu2rULQG8esX///kb3Ky8vJy0tLSDAON5t3ry5o7PQZcm5azk5dy0jQYQQR1FbW4vL5cLn8+FwOHA6nVitVr19dmlpKQkJCZjN5g7OqRDdU2RkJNXV1QHr/DUJjdU0HCmdP60/nf/nyJEj9e2KojBixAg2bNjQovz269cPm82Gx+Nhx44dJCcnA1qH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dCJ4mzdv7ugsHFfkfLef7nau26JsEEII0fm0KIj45ZdfuOaaa3A4HPTu3ZudO3fSr18/qqqqKCoqomfPniQnJ7d2XluNqqrcf//9uFwuHnjggRYfp1+/fthstlbMmTic1+tl8+bNDBkyRO/PItqOnO/209Hn2m63s3PnzlY9ZlcvG4QQQjRfi4KIp59+mrCwMN577z2sViunnXYaDzzwAKNGjWLFihX89a9/5amnngr6uJGRkVRXVwes89ckNFbTcKR0/rSNpXvqqaf45ptveO2111pcCwFgMBjkRqudGI1GOdftSM53++moc90W79lWZYMQQojOp0WTza1fv56pU6eSmpqqz8OgqioA559/PpMmTeLJJ58M+rgZGRlkZ2cHrNuzZw9wqG9EU+n8+/nl5ubicrno3bt3wPo333yTV155hSeffJKsrKyg8yiEEKJxbVU2CCGE6HxaFET4fD7i4+MBrRbAaDRSUVGhb8/MzGTr1q1BH3fMmDF8/fXXOBwOfd3KlSvJyMg4YufnMWPGsGHDBoqLiwPS2Ww2hg8frq/75ptvmDVrFvfccw/nnXde0PkTQgjRtLYqG4QQQnQ+LQoievToQW5urnYAg4EePXqwZs0affv69esbdJBujiuuuAKfz8fMmTNZs2YNr7zyCm+++Sa33nprwH6DBg1i3rx5+vLEiRNJS0vjjjvu4Ntvv+Xtt99m3rx53HDDDYSEhACwe/duZs6cyUknncSIESPYuHGj/iorK2vJaRBCCFFPW5UNQgghOp8W9YkYM2YMn3zyCXfffTeg3fw//vjj7N+/H1VVWbt2Lddff33Qx42NjWXRokXMmjWLm2++mfj4eO67774GE815vV69ihzAYrGwcOFCHnnkEWbMmIHNZuO6664LCD42bdpEbW0tP/30E1OnTg043pw5c5gyZUrQ+RVCCHFIW5UNQgghOp9mBxGVlZX6cKvTp0/nt7/9LW63G7PZzLXXXovdbufTTz/FYDBw2223ccstt7QoQwMHDmTp0qVH3GfHjh0N1qWnp7Nw4cIm00yZMkUCBSGEaGXtVTYIIYToXJodRIwePZrTTz+dSZMmMX78eAYPHqxvUxSF2267jdtuu61NMimEEKJzkrJBCCGOT80OIs477zy++OILvvjiC8LDwznnnHO48MILOfXUU1EUpS3zKIQQopOSskEIIY5P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41q3bu323tUwxMXFuW0PCwsDII8lJiJqLGwf3LF9IG9hEEFUC1EUMXjwYNxzzz217k9KSvLZtYcPHw6DwYB169ahd+/eWLduHVQqFcaMGeNWPkEQ8O6779Y6e4fRaLysMpw5cwZlZWV1js2trq7ZQ+raLnFWaSIKYGwf2D6QjEEEUS3atm0Li8WCQYMGXfK4LVu2oKSkxGtPm4xGI6666iqsX78ef/vb37B27VpcccUVaNWqldt1JUlCYmJijW56b/jqq68AAEOGDPH6uYmIAhnbB7YPJOMUr0S1GDt2LHbt2oXNmzfX2Gc2m+FwOADI4zolScL8+fNrHFf9iYrRaPSom3bcuHE4e/YsPv30Uxw6dAhjx4512z969Gio1WrMnz+/xpMbSZJQXFxc72tdaOvWrXjrrbeQmJiIa6+9tsHnISIKRmwf2D6QjD0RFBR++uknHD9+vMb23r17o02bNh6f7+6778amTZtw33334YYbbkDXrl1RWVmJjIwMbNiwAd999x2io6MxYMAAXHfddViyZAlOnDiBoUOHQhRF7Ny5E/3798dtt90GAOjatSu2bt2KDz74AC1btkRiYqKSYFabYcOGITQ0FHPmzIFarcbVV1/ttr9t27Z45JFHMHfuXOTm5mLUqFEIDQ1FTk4Ovv32W9x00024++67L1lP1/fN6XSioKAA27ZtU1YkXbBgAVcfJaKAx/aB7QP5BoMICgqvv/56rdtffPHFBjUSBoMBS5YswcKFC7F+/Xp8+eWXMJlMSEpKwoMPPqgkgbmukZqais8++wwvv/wywsLC0K1bN/Tq1Us5ZtasWfjHP/6B1157DVarFTfccMNFG4mQkBCMGDECq1atwqBBg2pNYJs2bRqSkpKwaNEivPnmmwDkZLXBgwdjxIgR9aqn6/um1WoRGRmJlJQUPPXUU5g4caLbzBlERIGK7QPbB/INQWIWCxEREREReYA5EURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEGEURERERE5BEG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EQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRHjh48CAmT56M9PR0jBgxAkuXLvV3kepl7dq1mDZtGoYMGYI+ffrg1ltvxY4dO9yOsVqt+Ne//oX+/fujd+/eePzxx1FSUuKfAnvo8OHDSEtLw5VXXum2vbi4GI8//jh69+6N/v3747nnnoPVavVTKS/ObrfjrbfewsiRI9GtWzeMGDECCxcudDsmUOrzxRdfYMKECejZsydGjBiBl19+GZWVlW7HNNW67N27F0888QT+9Kc/ITU1Ff/9739rHFPfsi9evBgjRoxAeno6Jk+ejEOHDjVGFchPArV98FR92pPU1NQar1mzZvmpxN6zcuXKWuu2bds25Zimem/zhttvv73W+qempuLs2bMAgudnz7agfgJuxWp/KSoqwtSpU5Geno6FCxdi//79eOGFF2AymWqslt3ULF68GO3atcM//vEPGI1GrFy5EnfeeSc+++wzdO7cGQDw7LPPYvPmzfj73/8OvV6P//znP3jkkUewaNEi/xa+Hl544QVERkbW2P7QQw/h7NmzePnll1FVVYUXXngBVqsVL7zwQuMX8hKeeOIJ/P7775g5cybatm2LnJwcFBYWuh0TCPX55ptvMGvWLNxzzz0YMmQIjh8/jldffRXl5eV47rnnlOOaal1+//137NmzB3369EFxcXGtx9Sn7J9//jleeuklPProo+jWrRsWLVqEu+66C2vWrEFUVFRjVYcaSSC3D56qT3sCANOnT8eIESOU99HR0f4ork989NFHUKvVyvuOHTsqXzfVe5s3PPvssygvL3fb9txzz8HhcKBly5bKtmD42bMtqCeJ6mX+/PnSgAEDJIvFomx79tlnpdGjR/uxVPVTVFTk9t7pdErjxo2TnnnmGUmSJCknJ0fq3LmztHbtWuWYPXv2SCkpKdLOnTsbtaye2rhxozR8+HDplVdekYYOHaps3759u5SSkiLt2bNH2bZmzRqpc+fO0qlTp/xR1Dp9//33UteuXaWjR4/WeUyg1Ofhhx+WbrnlFrdtr7/+utSvXz/lfVOui9PpVL4ePny49Oqrr7rtr2/ZR44cKf3zn/9U3ldUVEj9+/eXFixY4MPSk78EcvvgqUu1J5IkSSkpKdInn3zS2EXzuc8//1xKSUmR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uX3w1KXakxUrVmD//v0YOHAgIiMjsXPnTrz77rsYM2ZMwI+Jf+ihh9C9e3ekpqbCZrPhs88+w+7du7FgwQIATfve5k1r165Fnz59lHu6SzD97NkW1I8g1TWOgmo4ePAgnnvuOezbtw8xMTG46667cPvtt/u7WJc0YsQIZShJdQkJCdi0aRMA+T/JnDlzsHbtWtjtdowYMQLPPPNMwKyo+MYbb+DTTz/FTz/9pGwrKirCv//9b3z//ffQarW45ppr8OSTT9bryVljO378OJ5//nn8/vvv0Ov1GDt2LJ588km3eecDoT5OpxNLlizBJ598gtzcXLRo0QIjRozAww8/7DZ7TVOty7Zt23DHHXfU2F79/0p9y7548WJ88MEHKCgoQLdu3fDss8/WGOpFwSNQ2wdPXao92bp1K+bNm4djx47BYrGgVatWmDBhAh544IEa04gHmldffRUbNmzAmTNnAMhP1++//34MGzZMOaap3tu8JS8vD8OGDcPf//533HrrrW77gulnz7agfhhEEBERERGRR5gTQUREREREHmEQQUREREREHmEQQUREREREHmEQQUREREREHmEQQUREREREHmEQQUREREREHmEQQUREREREHmEQQUREREREHmEQQc1GRUUFnn76aQwePBipqamYPXs2AKCgoAAPPfQQ+vfvj9TUVCxatKjRyrRy5UqkpqYiJyen0a7ZUG+88QZSU1P9XQwiIq9j+3B52D40Txp/F4DocqxcuRJ/+9vf6ty/YsUK9OzZEwCwcOFCfPHFF5gxYwbatGmDDh06AABefPFFbN68GTNnzkRMTAy6devm9XK+/fbb6NixI0aNGuX1czfEhd83nU6HiIgIpKamYtiwYZg4cSJMJpMfS0hEdHnYPjQM2weqL0GSJMnfhSBqKNfN7qGHHkJiYmKN/UOHDkV0dDQA4KabboJarcby5cvdjhk8eDAGDhyIV155xWfl7NWrF66++mq89NJLbtudTiccDgd0Oh0EQfDZ9S904ffN4XCgoKAAv/32G37++WfEx8fjrbfeQufOnZXPOBwOOJ1OhISENFo5iYgaiu1Dw7B9oPpiTwQFhSuvvBLdu3e/6DGFhYXo2LFjrdvDw8N9VbSLUqvVUKvVfrk2UPP7Nn36dGzduhX33XcfZsyYgbVr10Kv1wMANBoNNBreMogosLB9aBi2D3QpzImgoLdt2zZlXOkPP/yA1NRUpKamKuNNJUnCsmXLlO0uZrMZs2fPxrBhw9CtWzf86U9/wjvvvANRFN3OL4oiPvzwQ0yYMAHdu3fHgAEDcPfdd2Pv3r0AgNTUVFgsFnzxxRfKNWbNmgWg5pjX6dOnY+TIkbXWY9KkSZg4caLbtq+++goTJ05Eeno6+vXrh0cffRSnT5++rO/XwIEDMWPGDOTm5uLrr79Wttc25jU1NRXPPfcc1q1bh3HjxiE9PR2TJk3C4cOHAQAff/wx/vSnP6F79+64/fbbA2JsLxE1H2wfPMP2gapj2EhBoby8HEVFRW7bBEFAVFQUOnTogJdffhkvvvgi4uLiMHXqVABAWloaXn75ZTzxxBMYPHgwrrvuOuWzlZWVuO2225CXl4ebb74ZrVu3xq5du/Dqq68iPz8fTz/9tHLs008/jZUrV+LKK6/EX/7yFzidTuzYsQN79uxB9+7d8fLLL+OZZ55Beno6brrpJgBA27Zta63H2LFj8eSTT+KPP/5Aenq6sj03Nxe7d+/GE088oWxbsGAB5s2bh7Fjx+Ivf/kLioqKsHTpUtx666348ssvL+vp2XXXXYdXX30VW7ZsUcpclx07dmDTpk2YPHkyAOCdd97Bfffdh3vuuQcfffQRJk+ejNLSUvzvf//DU089hcWLFze4XEREnmL7wPaBfEQiCmCff/65lJKSUuurW7dubscOHz5cmjZtWo1zpKSkSP/617/ctr355ptSz549pczMTLftr7zyitSlSxfp1KlTkiRJ0tatW6WUlBTp+eefr3FeURSVr3v27Ck9+eSTdZY/OztbkiRJKisrk7p16ya99NJLbse9++67UmpqqpSbmytJkiTl5ORIXbp0kRYsWOB23OHDh6W0tLQa2+u67h9//FHnMX369JGuv/565f3rr78upaSkuB3j+j67yi9JkvTxxx9LKSkp0uDBg6WysjJl+9y5c93qSkTkS2wf2D6Qb7EngoLCP/7xD7Rv395tm0rV8NF669evR58+fRAeHu72BGvQoEF45513sH37dlx77bX45ptvIAgCZs6cWeMcDUmEM5lMuPLKK7Fu3To88cQTyjnWrl2Lnj17Ij4+HgCwceNGiKKIsWPHupUvJiYG7dq1w7Zt23Dfffd5fP3qjEYjKioqLnncwIED3ZIWe/ToAQAYPXq02wweridn2dnZtSY5EhH5AtsHGdsH8jYGERQU0tPTL5k454kTJ07g8OHDGDhwYK37XTfmkydPomXLloiMjPTatceNG4dvv/0Wu3btQu/evXHy5Ens378fTz31lHJMVlYWJEnC6NGjaz2HNxLcLBYLWrRoccnjWrdu7fbe1TDExcW5bQ8LCwMgjyUmImosbB/csX0gb2EQQVQLURQxePBg3HPPPbXuT0pK8tm1hw8fDoPBgHXr1qF3795Yt24dVCoVxowZ41Y+QRDw7rvv1jp7h9FovKwynDlzBmVlZXWOza2urtlD6toucVZpIgpgbB/YPpCMQQRRLdq2bQuLxYJBgwZd8rgtW7agpKTEa0+bjEYjrrrqKqxfvx5/+9vfsHbtWlxxxRVo1aqV23UlSUJiYmKNbnpv+OqrrwAAQ4YM8fq5iYgCGdsHtg8k4xSvRLUYO3Ysdu3ahc2bN9fYZzab4XA4AMjjOiVJwvz582scV/2JitFo9Kibdty4cTh79iw+/fRTHDp0CGPHjnXbP3r0aKjVasyfP7/GkxtJklBcXFzva11o69ateOutt5CYmIhrr722wechIgpGbB/YPpCMPREUFH766SccP368xvbevXujTZs2Hp/v7rvvxqZNm3DffffhhhtuQNeuXVFZWYmMjAxs2LAB3333HaKjozFgwABcd911WLJkCU6cOIGhQ4dCFEXs3LkT/fv3x2233QYA6Nq1K7Zu3YoPPvgALVu2RGJiopJgVpthw4YhNDQUc+bMgVqtxtVXX+22v23btnjkkUcwd+5c5ObmYtSoUQgNDUVOTg6+/fZb3HTTTbj77rsvWU/X983pdKKgoADbtm1TViRdsGABVx8looDH9oHtA/kGgwgKCq+//nqt21988cUGNRIGgwFLlizBwoULsX79enz55ZcwmUxISkrCgw8+qCSBua6RmpqKzz77DC+//DLCwsLQrVs39OrVSzlm1qxZ+Mc//oHXXnsNVqsVN9xww0UbiZCQEIwYMQKrVq3CoEGDak1gmzZtGpKSkrBo0SK8+eabAORktcGDB2PEiBH1qqfr+6bVahEZGYmUlBQ89dRTmDhxotvMGUREgYrtA9sH8g1BYhYLERERERF5gDkRRERERETkEQYRRERERETkEQYRRERERETkEQYRgg4vdwAAGC1JREFURERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEQYRRERERETkEY2/C0DUFIiiCEmS/F0MIiIKAIIgQKXic1hq3hhEULNWXFyM/Px8OJ1OfxeFiIgCiFqtRmxsLKKiovxdFCK/YBBBzVZxcTHOnj2LhIQE6PV6CILg7yIREVEAkCQJVqsVubm5AMBAgpolBhHUbOXn5yMhIQEmk8nfRSEiogBjMpmQkJCAU6dOMYigZokD+qhZEkURTqcTer3e30UhIqIApdfr4XQ6IYqiv4tC1OgYRFCz5Eqi5hAmIiJqKFcbwok5qDliEEFERERERB5hEEFERERERB5hEEFEFCBWrlyJ1NRUpKamIjMzs8b+3377Tdn/yy+/eHTuRYsW4Ztvvqmx/Y033kBqaiocDkeDy10ft99+O26//XafXoOIiLyHQQQRUYAJDQ3FV199VWP7F198gdDQ0Aadc/HixbUGEURERLVhEEFEFGBGjx6Nr7/+2i2Z02q1YsOGDbj66qv9WDIiImouGEQQEQWY6667DqdOncLOnTuVbRs3boQkSRg9enSN43/77TdMmTIFvXr1Qs+ePXH33XcjIyND2T9ixAjk5uZi1apVynCoWbNmuZ0jJycH06ZNQ69evTB8+HDMnz+/xrSWx48fxwMPPIArrrgC6enpuOmmm/DTTz/VKM+aNWswZswYdOvWDddccw02btx4ud8SIiJqZAwiiIgCTHx8PPr27es2pOnLL7/EqFGjYDQa3Y794YcfcOedd8JoNOI///kPXnnlFVRUVODWW2/F6dOnAQDz589HbGwshgwZghUrVmDFihWYMWOG23lmzpyJAQMG4M0338TIkSPxxhtv4IsvvlD25+XlYfLkyTh06BD+/ve/47XXXkNYWBimT5+OH3/8UTnul19+weOPP46kpCTMnz8fd999N2bPnl1rjgcRETVdXLGaiCgAXXfddZgzZw6eeeYZlJaWYuvWrXj33XdrHDd79mz07dsXCxYsULYNGDAAI0eOxPvvv4+nn34aaWlp0Ol0iIqKQs+ePWu93tSpU/HnP/8ZADBo0CBs27YNa9asUbYtWrQIZrMZK1asQLt27QAAw4YNw7hx4/Daa69h2LBhAIDXX38dycnJeOutt6BSyc+xkpOTMWnSJLRv395r3x8iIvIt9kQQEQWgMWPGwGazYdOmTVi1ahViYmIwcOBAt2OysrJw8uRJTJgwAQ6HQ3np9Xr06tULO3bsqPf1rrrqKrf3nTp1wqlTp5T327dvR48ePZQAAgDUajXGjx+PgwcPory8HE6nE/v27cPVV1+tBBAA0LNnTyQkJHj4HSAiIn9iTwQRUQAymUwYNWoUvvrqK+Tm5mLChAluf5gDQGFhIQDg6aefxtNPP13jHPHx8fW+XkREhNt7nU4Hm82mvC8tLUWXLl1qfC4mJgaSJKG0tBRWqxV2ux0xMTG1HkdERIGDQQQRUYC67rrrMH36dIiiiFdffbXG/sjISADA448/XqOXAgC0Wq3XyhIREYGCgoIa2wsKCiAIAiIiImAwGKDVaus8jr0RRESBg0EEEVGAGjx4MMaOHYuwsDB06tSpxv7k5GQkJCTgyJEjmDZt2kXPpdVqUVVV1eCy9O3bF4sXL0ZOTg4SExMBAE6nE2vXrkVaWhpMJhMAoFu3btiwYQMefPBBpedkz549yM3NZRBBRBRAGEQQEQUotVpdaw+EiyAIePbZZzFjxgzY7XaMHTsWUVFRKCgowK5duxAfH4+pU6cCADp27IgdO3bg+++/R0xMDKKiopRgoD7uvPNOfPHFF7jrrrvw4IMPwmQy4aOPPkJWVhYWLlyoHPfQQw/hrrvuwowZM3DzzTejqKgIb7zxBmJjYxv+jSAiokbHxGoioiA2bNgwLF26FJWVlXjmmWdw991345VXXkFBQYHbTEyPPfYY2rdvj0ceeQR/+ctfMH/+fI+u06pVK3z00Ufo2LEj/vnPf+Khhx5CaWkpFi5ciCuvvFI5btCgQXjllVeQmZmJmTNn4r333sNTTz3FmZmIiAKMIFVf8pSomXA6ncjIyEBKSgrUarW/i0NERAGIbQk1Z+yJICIiIiIijzCIICIiIiIijzCIICIiIiIijzCIICIiIiIijzCIICIiIiIijzCIICIiIiIijzCIICIiIiIijzCIICIiIiIijzCIICIiIiIijzCIIAoCb7zxBlJTU5GamorOnTujT58+mDBhAp577jkcO3asxvE2mw2LFi3CxIkT0atXL6Snp2PChAl44403YDabsWHDBqSmpmLHjh21Xq+kpATdunXDvHnzlG1WqxVvvfUWxo0bh+7du6N///64//778ccff9S7HnPmzME111yDXr16oXfv3vjzn/+MNWvWuB1z/PhxPPfccxg3bhx69OiBESNG4Nlnn0VRUdElz282m5GamoqVK1fWu0wkC5bfscrKSsydOxcjR45Ejx49cPXVV+Ptt9+Gw+G45Gevu+46zJo1q97XIuC+++7D6NGj69y/ZMkSpKam4uTJkwCAY8eO4fHHH8fgwYPRrVs3jBo1Ci+//DLMZrPymYb87hQVFaFr167o1asXrFZrjc+sXLlS+f2+8PWPf/yjodUnCmoafxeAiLxDr9fjww8/BABUVFQgIyMDK1aswCeffILZs2fjuuuuAwBUVVXhnnvuwe7du3HrrbfikUcegU6nw8GDB7FkyRKUlZXh8ccfh8lkwpo1a3DFFVfUuNaGDRtgt9sxYcIEAIDFYsGdd96JI0eO4J577sEVV1yBkpISLF26FJMnT8Z///tf/OlPf7pkHSoqKnDjjTciOTkZgiBgw4YNeOyxxyCKonKtX375BTt27MCkSZPQuXNnnDp1Cq+//jp+++03fPXVV9DpdN76ltIFguF37LnnnsM333yDxx57DB06dMDu3bvx+uuvo7KyEo8++qgXv1sEAOPHj8fjjz+OP/74A+np6TX2r1mzBj179kTbtm2xfft2TJs2DW3btsUTTzyB1q1b49ChQ1iwYAF++OEHLF26FNHR0bjqqqs8+t0BgLVr18LhcMDhcGDTpk0YN25creX93//+h7CwMLdtLVq0uMzvAlGQkoiaIYfDIR04cEByOBz+LopXvP7661LPnj1rbLdardIdd9whde3aVTp58qQkSZI0Z84cqXPnztLPP/9c6/G//PKLJEmSNGvWLGnAgAGS3W6vcdxtt90m3XDDDcr7F154QUpJSZG2bt3qdpzD4ZDuuOMOqU+fPlJBQUGD6jZp0iRp6tSpyvuioiJJFEW3Y3bu3CmlpKRI69evv+i5SktLpZSUFOnzzz9vUFmas2D4HXM6nVKPHj2k119/3W37E088IY0cOfKin5UkSbr22mulJ5988pLH0XkWi0Xq2bOnNHv27Br7srOzpZSUFGnx4sVSZWWlNGTIEGncuHFSRUWF23FHjx6VunXrJj366KPKNk9+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",
      "text/plain": [
       "<Figure size 800x600 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_[\"Method\"] = df_[\"group\"]\n",
    "draw_grid(df_, \"Effective Dim\", y_col=\"Val Loss\", size_key=None, symbol_key=None, hue_key=\"Method\",\n",
    "          alpha=0.5, figsize=(8, 6), min_size=40, title=\"Validation Loss vs. Effective Dimension\", cmap=\"Set1\", discrete_color=True)\n",
    "# plt.savefig(f\"dcvq_val_loss_vs_eff_dim.pdf\", format=\"pdf\", bbox_inches=\"tight\", dpi=300)\n",
    "plt.savefig(f\"dcvq_val_loss_vs_eff_dim.svg\", format=\"svg\", bbox_inches=\"tight\", dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rotation_trick",
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
