{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "321d78aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import warnings\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torchvision\n",
    "\n",
    "from pathlib import Path\n",
    "from tqdm.notebook import tqdm\n",
    "from copy import deepcopy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "21c7d01c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "{YOUR_WORKING_PATH}/zoo_utils.py:6: TqdmExperimentalWarning: Using `tqdm.autonotebook.tqdm` in notebook mode. Use `tqdm.tqdm` instead to force console mode (e.g. in jupyter console)\n",
      "  from tqdm.autonotebook import tqdm\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import re\n",
    "\n",
    "from utils import test_model, compare_models_prediction, generate_z_samples\n",
    "from zoo_utils import load_hyperrep_edx\n",
    "\n",
    "from shrp.models.def_net import CNN, CNN3\n",
    "from shrp.models.def_AE_trainable import get_transformations\n",
    "from shrp.datasets.dataset_auxiliaries import tokens_to_recipe, tokens_to_checkpoint\n",
    "from shrp.models.def_loss import DistillationLoss, ReconDistillationLoss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "892c085f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "sns.set_theme(context='notebook', style='whitegrid',\n",
    "              rc={\n",
    "                  'axes.spines.right': False,\n",
    "                  'axes.spines.top': False,\n",
    "                  'xtick.bottom': True,\n",
    "                  'ytick.left': True,\n",
    "                  'font.family': 'Fira Sans'\n",
    "              })\n",
    "\n",
    "COLOURS = [\n",
    "    '#960018',  # Carmine Red\n",
    "    '#FED85D',  # Mustard Gold\n",
    "    '#434384',  # Marian Blue\n",
    "    '#54B674',  # Emerald Green\n",
    "    '#D183C9',  # French Mauve\n",
    "    '#318CE7',  # French Blue\n",
    "    '#D08000'   # Fulvous Orange\n",
    "]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5ae4fe26",
   "metadata": {},
   "source": [
    "## Loading data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "93332954",
   "metadata": {},
   "outputs": [],
   "source": [
    "DATASETS = ['svhn', 'cifar10', 'eurosat']\n",
    "DATASET_LABELS = {\n",
    "    'svhn': 'SVHN',\n",
    "    'cifar10': 'CIFAR-10',\n",
    "    'eurosat': 'EuroSAT'\n",
    "}\n",
    "\n",
    "DS_ORDER = ['SVHN', 'CIFAR-10', 'EuroSAT']\n",
    "HR_ORDER = ['Contrastive + Structure (Baseline)', 'Behavior', 'Contrastive + Behavior', 'Structure + Behavior', 'Contrastive + Structure + Behavior']\n",
    "\n",
    "HYPERREP_PATH = Path('{YOUR_WORKING_PATH}/results/hyperrepresentations/tune')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d1273705",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "fbb1b9807305480d876780662f62ed0c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading data:   0%|          | 0/3 [00:00<?, ?dataset/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "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>Model zoo</th>\n",
       "      <th>Trial ID</th>\n",
       "      <th>Learning rate</th>\n",
       "      <th>Latent dimension</th>\n",
       "      <th>Behaviour loss</th>\n",
       "      <th>Query set</th>\n",
       "      <th>Query dataset</th>\n",
       "      <th># of queries</th>\n",
       "      <th>Gamma</th>\n",
       "      <th>Beta</th>\n",
       "      <th>...</th>\n",
       "      <th>Train loss (recon)</th>\n",
       "      <th>Train loss (structure)</th>\n",
       "      <th>Train loss (behaviour)</th>\n",
       "      <th>Test loss</th>\n",
       "      <th>Test loss (contrast)</th>\n",
       "      <th>Test loss (recon)</th>\n",
       "      <th>Test loss (structure)</th>\n",
       "      <th>Test loss (behaviour)</th>\n",
       "      <th>Dstk: Test accuracy</th>\n",
       "      <th>Dstk: GGap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>50f57_00020</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>cross_entropy</td>\n",
       "      <td>data</td>\n",
       "      <td>SVHN</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>1.344194</td>\n",
       "      <td>0.930796</td>\n",
       "      <td>1.390127</td>\n",
       "      <td>1.059503</td>\n",
       "      <td>1.045855</td>\n",
       "      <td>1.060222</td>\n",
       "      <td>0.791913</td>\n",
       "      <td>1.090034</td>\n",
       "      <td>0.559680</td>\n",
       "      <td>0.283559</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>50f57_00020</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>cross_entropy</td>\n",
       "      <td>data</td>\n",
       "      <td>SVHN</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.275532</td>\n",
       "      <td>0.770928</td>\n",
       "      <td>0.220488</td>\n",
       "      <td>0.257198</td>\n",
       "      <td>0.887651</td>\n",
       "      <td>0.224016</td>\n",
       "      <td>0.591360</td>\n",
       "      <td>0.183200</td>\n",
       "      <td>0.554503</td>\n",
       "      <td>0.276677</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>50f57_00020</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>cross_entropy</td>\n",
       "      <td>data</td>\n",
       "      <td>SVHN</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.266038</td>\n",
       "      <td>0.677502</td>\n",
       "      <td>0.220320</td>\n",
       "      <td>0.247892</td>\n",
       "      <td>0.708432</td>\n",
       "      <td>0.223653</td>\n",
       "      <td>0.544859</td>\n",
       "      <td>0.187963</td>\n",
       "      <td>0.550643</td>\n",
       "      <td>0.276275</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>50f57_00020</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>cross_entropy</td>\n",
       "      <td>data</td>\n",
       "      <td>SVHN</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.264123</td>\n",
       "      <td>0.664841</td>\n",
       "      <td>0.219599</td>\n",
       "      <td>0.239949</td>\n",
       "      <td>0.652948</td>\n",
       "      <td>0.218212</td>\n",
       "      <td>0.527920</td>\n",
       "      <td>0.183800</td>\n",
       "      <td>0.551713</td>\n",
       "      <td>0.279411</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>50f57_00020</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>cross_entropy</td>\n",
       "      <td>data</td>\n",
       "      <td>SVHN</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.261248</td>\n",
       "      <td>0.628665</td>\n",
       "      <td>0.220424</td>\n",
       "      <td>0.242219</td>\n",
       "      <td>0.741064</td>\n",
       "      <td>0.215964</td>\n",
       "      <td>0.495595</td>\n",
       "      <td>0.184894</td>\n",
       "      <td>0.538348</td>\n",
       "      <td>0.282729</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 23 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "  Model zoo     Trial ID  Learning rate  Latent dimension Behaviour loss  \\\n",
       "0      SVHN  50f57_00020        0.00001                64  cross_entropy   \n",
       "1      SVHN  50f57_00020        0.00001                64  cross_entropy   \n",
       "2      SVHN  50f57_00020        0.00001                64  cross_entropy   \n",
       "3      SVHN  50f57_00020        0.00001                64  cross_entropy   \n",
       "4      SVHN  50f57_00020        0.00001                64  cross_entropy   \n",
       "\n",
       "  Query set Query dataset  # of queries  Gamma  Beta  ...  Train loss (recon)  \\\n",
       "0      data          SVHN           256   0.05   0.1  ...            1.344194   \n",
       "1      data          SVHN           256   0.05   0.1  ...            0.275532   \n",
       "2      data          SVHN           256   0.05   0.1  ...            0.266038   \n",
       "3      data          SVHN           256   0.05   0.1  ...            0.264123   \n",
       "4      data          SVHN           256   0.05   0.1  ...            0.261248   \n",
       "\n",
       "   Train loss (structure)  Train loss (behaviour)  Test loss  \\\n",
       "0                0.930796                1.390127   1.059503   \n",
       "1                0.770928                0.220488   0.257198   \n",
       "2                0.677502                0.220320   0.247892   \n",
       "3                0.664841                0.219599   0.239949   \n",
       "4                0.628665                0.220424   0.242219   \n",
       "\n",
       "   Test loss (contrast)  Test loss (recon)  Test loss (structure)  \\\n",
       "0              1.045855           1.060222               0.791913   \n",
       "1              0.887651           0.224016               0.591360   \n",
       "2              0.708432           0.223653               0.544859   \n",
       "3              0.652948           0.218212               0.527920   \n",
       "4              0.741064           0.215964               0.495595   \n",
       "\n",
       "   Test loss (behaviour)  Dstk: Test accuracy  Dstk: GGap  \n",
       "0               1.090034             0.559680    0.283559  \n",
       "1               0.183200             0.554503    0.276677  \n",
       "2               0.187963             0.550643    0.276275  \n",
       "3               0.183800             0.551713    0.279411  \n",
       "4               0.184894             0.538348    0.282729  \n",
       "\n",
       "[5 rows x 23 columns]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "MAX_EPOCH = 100\n",
    "\n",
    "df_hr = pd.DataFrame(columns=[\n",
    "    'Model zoo',\n",
    "    'Trial ID',\n",
    "    'Learning rate',\n",
    "    'Latent dimension',\n",
    "    'Behaviour loss',\n",
    "    'Query set',\n",
    "    'Query dataset',\n",
    "    '# of queries',\n",
    "    'Gamma',\n",
    "    'Beta',\n",
    "    'Epoch',\n",
    "    'Train loss',\n",
    "    'Train loss (contrast)', \n",
    "    'Train loss (recon)',\n",
    "    'Train loss (structure)', \n",
    "    'Train loss (behaviour)',\n",
    "    'Test loss',\n",
    "    'Test loss (contrast)', \n",
    "    'Test loss (recon)',\n",
    "    'Test loss (structure)', \n",
    "    'Test loss (behaviour)',\n",
    "    'Dstk: Test accuracy',\n",
    "    'Dstk: GGap'\n",
    "])\n",
    "\n",
    "for ds in tqdm(DATASETS, desc='Loading data', unit='dataset'):\n",
    "    hr_path = HYPERREP_PATH / f\"{ds}_train_hyperrep\"\n",
    "    for path in os.listdir(hr_path):\n",
    "        if not re.match('AE_trainable', path):\n",
    "            continue\n",
    "        path = hr_path / path\n",
    "\n",
    "        with open(path / 'params.json') as ifh_config, open(path / 'result.json') as ifh_result:\n",
    "            config = json.load(ifh_config)\n",
    "            result = pd.read_json(ifh_result, lines=True, dtype={'trial_id': str})\n",
    "\n",
    "        for edx in range(len(result)):\n",
    "            df_hr.loc[len(df_hr)] = (\n",
    "                DATASET_LABELS[ds],\n",
    "                result.loc[edx]['trial_id'],\n",
    "                config['optim::lr'],\n",
    "                config['ae:lat_dim'],\n",
    "                config['training::loss_distillation'],\n",
    "                config['training::queryset_distillation'],\n",
    "                config['training::queryset_dump'],\n",
    "                config['training::n_queries_distillation'],\n",
    "                config['training::gamma'],\n",
    "                config['training::beta'],\n",
    "                result.loc[edx]['training_iteration'],\n",
    "                result.loc[edx]['loss/loss_train'],\n",
    "                result.loc[edx]['loss/loss_contrast_train'],\n",
    "                result.loc[edx]['loss/loss_recon_train'],\n",
    "                result.loc[edx]['loss/loss_structure_train'],\n",
    "                result.loc[edx]['loss/loss_behaviour_train'],\n",
    "                result.loc[edx]['loss/loss_test'],\n",
    "                result.loc[edx]['loss/loss_contrast_test'],\n",
    "                result.loc[edx]['loss/loss_recon_test'],\n",
    "                result.loc[edx]['loss/loss_structure_test'],\n",
    "                result.loc[edx]['loss/loss_behaviour_test'],\n",
    "                result.loc[edx]['dstk/test_acc_test'],\n",
    "                result.loc[edx]['dstk/ggap_test']\n",
    "            )\n",
    "\n",
    "df_hr['Query dataset'] = df_hr['Query dataset'].map({\n",
    "    '{YOUR_WORKING_PATH}/results/data/svhn_train_zoo_relu/dataset.pt': 'SVHN',\n",
    "    '{YOUR_WORKING_PATH}/results/data/cifar10_train_zoo_relu/dataset.pt': 'CIFAR-10',\n",
    "    '{YOUR_WORKING_PATH}/results/data/eurosat_train_zoo_relu/dataset.pt': 'EuroSAT',\n",
    "    '{YOUR_WORKING_PATH}/results/data/tinyimagenet_32/dataset.pt': 'TinyImagenet-32'\n",
    "})\n",
    "df_hr.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "2cdbc7ef",
   "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>Model zoo</th>\n",
       "      <th>Trial ID</th>\n",
       "      <th>Learning rate</th>\n",
       "      <th>Latent dimension</th>\n",
       "      <th>Behaviour loss</th>\n",
       "      <th>Query set</th>\n",
       "      <th>Query dataset</th>\n",
       "      <th># of queries</th>\n",
       "      <th>Gamma</th>\n",
       "      <th>Beta</th>\n",
       "      <th>...</th>\n",
       "      <th>Train loss (recon)</th>\n",
       "      <th>Train loss (structure)</th>\n",
       "      <th>Train loss (behaviour)</th>\n",
       "      <th>Test loss</th>\n",
       "      <th>Test loss (contrast)</th>\n",
       "      <th>Test loss (recon)</th>\n",
       "      <th>Test loss (structure)</th>\n",
       "      <th>Test loss (behaviour)</th>\n",
       "      <th>Dstk: Test accuracy</th>\n",
       "      <th>Dstk: GGap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>100</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>50f57_00020</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>cross_entropy</td>\n",
       "      <td>data</td>\n",
       "      <td>SVHN</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.219501</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.185790</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>403</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>50f57_00032</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>distillation</td>\n",
       "      <td>data</td>\n",
       "      <td>SVHN</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.071529</td>\n",
       "      <td>0.621905</td>\n",
       "      <td>0.010376</td>\n",
       "      <td>0.071910</td>\n",
       "      <td>0.285326</td>\n",
       "      <td>0.060677</td>\n",
       "      <td>0.510241</td>\n",
       "      <td>0.010726</td>\n",
       "      <td>0.871641</td>\n",
       "      <td>0.363464</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1312</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>50f57_00008</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>l2</td>\n",
       "      <td>data</td>\n",
       "      <td>SVHN</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.096635</td>\n",
       "      <td>0.619713</td>\n",
       "      <td>0.038515</td>\n",
       "      <td>0.095468</td>\n",
       "      <td>0.293242</td>\n",
       "      <td>0.085059</td>\n",
       "      <td>0.516894</td>\n",
       "      <td>0.037078</td>\n",
       "      <td>0.885545</td>\n",
       "      <td>0.368292</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4039</th>\n",
       "      <td>CIFAR-10</td>\n",
       "      <td>0d5ff_00032</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>distillation</td>\n",
       "      <td>data</td>\n",
       "      <td>CIFAR-10</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.079704</td>\n",
       "      <td>0.721238</td>\n",
       "      <td>0.008423</td>\n",
       "      <td>0.074469</td>\n",
       "      <td>0.270508</td>\n",
       "      <td>0.064151</td>\n",
       "      <td>0.566380</td>\n",
       "      <td>0.008348</td>\n",
       "      <td>0.923251</td>\n",
       "      <td>0.767691</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4948</th>\n",
       "      <td>CIFAR-10</td>\n",
       "      <td>0d5ff_00020</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>cross_entropy</td>\n",
       "      <td>data</td>\n",
       "      <td>CIFAR-10</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.662900</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.861416</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5958</th>\n",
       "      <td>CIFAR-10</td>\n",
       "      <td>0d5ff_00008</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>l2</td>\n",
       "      <td>data</td>\n",
       "      <td>CIFAR-10</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.137927</td>\n",
       "      <td>0.643100</td>\n",
       "      <td>0.081796</td>\n",
       "      <td>0.133346</td>\n",
       "      <td>0.290942</td>\n",
       "      <td>0.125051</td>\n",
       "      <td>0.517291</td>\n",
       "      <td>0.081469</td>\n",
       "      <td>0.946772</td>\n",
       "      <td>0.785136</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9392</th>\n",
       "      <td>EuroSAT</td>\n",
       "      <td>d28cf_00008</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>l2</td>\n",
       "      <td>data</td>\n",
       "      <td>EuroSAT</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>0.149865</td>\n",
       "      <td>0.887436</td>\n",
       "      <td>0.067913</td>\n",
       "      <td>0.174474</td>\n",
       "      <td>0.284862</td>\n",
       "      <td>0.168664</td>\n",
       "      <td>1.076722</td>\n",
       "      <td>0.067769</td>\n",
       "      <td>0.969290</td>\n",
       "      <td>0.528638</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9695</th>\n",
       "      <td>EuroSAT</td>\n",
       "      <td>d28cf_00020</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>cross_entropy</td>\n",
       "      <td>data</td>\n",
       "      <td>EuroSAT</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.072064</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>3.181914</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10200</th>\n",
       "      <td>EuroSAT</td>\n",
       "      <td>d28cf_00032</td>\n",
       "      <td>0.00001</td>\n",
       "      <td>64</td>\n",
       "      <td>distillation</td>\n",
       "      <td>data</td>\n",
       "      <td>EuroSAT</td>\n",
       "      <td>256</td>\n",
       "      <td>0.05</td>\n",
       "      <td>0.1</td>\n",
       "      <td>...</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>6.127028</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>6.141829</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>9 rows × 23 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      Model zoo     Trial ID  Learning rate  Latent dimension Behaviour loss  \\\n",
       "100        SVHN  50f57_00020        0.00001                64  cross_entropy   \n",
       "403        SVHN  50f57_00032        0.00001                64   distillation   \n",
       "1312       SVHN  50f57_00008        0.00001                64             l2   \n",
       "4039   CIFAR-10  0d5ff_00032        0.00001                64   distillation   \n",
       "4948   CIFAR-10  0d5ff_00020        0.00001                64  cross_entropy   \n",
       "5958   CIFAR-10  0d5ff_00008        0.00001                64             l2   \n",
       "9392    EuroSAT  d28cf_00008        0.00001                64             l2   \n",
       "9695    EuroSAT  d28cf_00020        0.00001                64  cross_entropy   \n",
       "10200   EuroSAT  d28cf_00032        0.00001                64   distillation   \n",
       "\n",
       "      Query set Query dataset  # of queries  Gamma  Beta  ...  \\\n",
       "100        data          SVHN           256   0.05   0.1  ...   \n",
       "403        data          SVHN           256   0.05   0.1  ...   \n",
       "1312       data          SVHN           256   0.05   0.1  ...   \n",
       "4039       data      CIFAR-10           256   0.05   0.1  ...   \n",
       "4948       data      CIFAR-10           256   0.05   0.1  ...   \n",
       "5958       data      CIFAR-10           256   0.05   0.1  ...   \n",
       "9392       data       EuroSAT           256   0.05   0.1  ...   \n",
       "9695       data       EuroSAT           256   0.05   0.1  ...   \n",
       "10200      data       EuroSAT           256   0.05   0.1  ...   \n",
       "\n",
       "       Train loss (recon)  Train loss (structure)  Train loss (behaviour)  \\\n",
       "100                   NaN                     NaN                0.219501   \n",
       "403              0.071529                0.621905                0.010376   \n",
       "1312             0.096635                0.619713                0.038515   \n",
       "4039             0.079704                0.721238                0.008423   \n",
       "4948                  NaN                     NaN                0.662900   \n",
       "5958             0.137927                0.643100                0.081796   \n",
       "9392             0.149865                0.887436                0.067913   \n",
       "9695                  NaN                     NaN                3.072064   \n",
       "10200                 NaN                     NaN                6.127028   \n",
       "\n",
       "       Test loss  Test loss (contrast)  Test loss (recon)  \\\n",
       "100          NaN                   NaN                NaN   \n",
       "403     0.071910              0.285326           0.060677   \n",
       "1312    0.095468              0.293242           0.085059   \n",
       "4039    0.074469              0.270508           0.064151   \n",
       "4948         NaN                   NaN                NaN   \n",
       "5958    0.133346              0.290942           0.125051   \n",
       "9392    0.174474              0.284862           0.168664   \n",
       "9695         NaN                   NaN                NaN   \n",
       "10200        NaN                   NaN                NaN   \n",
       "\n",
       "       Test loss (structure)  Test loss (behaviour)  Dstk: Test accuracy  \\\n",
       "100                      NaN               0.185790                  NaN   \n",
       "403                 0.510241               0.010726             0.871641   \n",
       "1312                0.516894               0.037078             0.885545   \n",
       "4039                0.566380               0.008348             0.923251   \n",
       "4948                     NaN               0.861416                  NaN   \n",
       "5958                0.517291               0.081469             0.946772   \n",
       "9392                1.076722               0.067769             0.969290   \n",
       "9695                     NaN               3.181914                  NaN   \n",
       "10200                    NaN               6.141829                  NaN   \n",
       "\n",
       "       Dstk: GGap  \n",
       "100           NaN  \n",
       "403      0.363464  \n",
       "1312     0.368292  \n",
       "4039     0.767691  \n",
       "4948          NaN  \n",
       "5958     0.785136  \n",
       "9392     0.528638  \n",
       "9695          NaN  \n",
       "10200         NaN  \n",
       "\n",
       "[9 rows x 23 columns]"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_hr[(df_hr['Epoch'] == 100) & (df_hr['Beta'] == 0.1) & (df_hr['Gamma'] == 0.05) & (df_hr['Learning rate'] == 1e-5)] "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1122e2ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "idx_dict = {\n",
    "    '00008': 'MSE',\n",
    "    '00020': 'Cross-entropy',\n",
    "    '00032': 'Distillation',\n",
    "}\n",
    "\n",
    "df_hr['Hyper-representation'] = df_hr['Trial ID'].str.slice(start=-5).map(idx_dict)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c171626b",
   "metadata": {},
   "source": [
    "## Analysing data\n",
    "\n",
    "### Other behavior losses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "ce7d0b75",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABIoAAAFsCAYAAACjNFLNAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACUK0lEQVR4nOzdd5xU1fnH8c+dPtsLSwdBFLAAUqwYURAxKlFjLxHFgiWamGKN5qexpBljiykmisaKPYktAirWWBAQEQHpy7K9zuzU+/vjzsyyNLfM7uzMft+v175g7ty5c87M7jxzn3vOcwzTNE1ERERERERERKTXs6W6ASIiIiIiIiIi0jMoUSQiIiIiIiIiIoASRSIiIiIiIiIiEqNEkYiIiIiIiIiIAEoUiYiIiIiIiIhIjBJFIiIiIiIiIiICKFEkIiIiIiIiIiIxShSJiIiIiIiIiAigRJGIiIiIiIiIiMQoUSQiIiIiIiIiIoASRSJtFggE+NOf/sSMGTMYN24cxx9/PNdffz1lZWVce+21jB49mpqamh0e99BDDzFq1CjWrVsHwKhRo7j66qt32O+6665j1KhRBAKBHbb98Ic/bLXvpk2bGDVqFM8//3xyOyki0kuZpsm8efM4++yzGT9+PEcffTTXXHMNGzduTHzm/v73v0/sH9+2/c/YsWOJRqOtjjt16lRGjRrF3Llzd3je559/vtXjDz/8cGbNmsXChQvb1f41a9Zw+umnM2rUKDZt2tTqvi+++ILZs2czadIkTjvtNF5++eV2vjoiIr3H9p/L8Z/jjz++W9sRjUZ5/PHHmTlzJuPGjWPGjBn8+Mc/Zs2aNTvsu21M+uqrr1rdt7O+bPuz/f4iAI5UN0AkXdx666288MILnHfeeRx00EGUlZXx+OOPc80113DOOefw4osv8t5773HCCSe0etyiRYsYMWIEw4YN6/Bzv/nmm6xbt65TxxARkV276aabeO655zj//PO5+OKLqays5JFHHmHhwoVMnTp1l4874YQTOOussxK3XS4XNlvLdbiVK1eyefNmioqKWLBgAbNmzdrpca655hrGjh1LZWUlL730Epdeeil33XXXDjFle+FwmIcffph777231fPGrV27lvPPP5999tmHO++8k3feeYdrrrkGl8vFscce+20vi4hIr3XNNdcwbty4xO3c3Nxuff4///nP3HPPPZx66qlcddVV1NbW8txzz3H55Zfzr3/9C5fLldh3/vz5eL1eTNNk/vz5jB49OnHf448/nvj/bbfdRmlpKX/6058S2/bcc8/u6ZCkFSWKRNqgubmZF198kRNOOIHrrrsusf3UU0/F5/PhdDpxuVwsWrSo1Zf6pqYmPv30U84///wOP/eECRP48ssvefjhh7nllls60w0REdmJDz74gHnz5vF///d/rZI+J598Mna7nc2bN+/ysQMGDGDSpEm7vH/+/Pnk5ORw3nnncd9991FXV0d+fv4O++29994ceOCBAEyfPp3vfve7PPTQQ9+aKHr88cf54x//yJw5c+jXrx8333xzq/ufeuopmpubuffeeyksLGTatGksX76cv/3tb0oUiYjsxt57773bz/eu9vTTTzNp0iRuv/32xLZTTjmFmpqaVkkigAULFnDQQQclEkVXXHFF4r5t+5Cbm4vT6UxpvyQ9aOqZSBuEw2HC4TA+n6/VdpfLRUFBAdnZ2Rx22GEsWrSo1ZSDjz76iFAotNur0d/G7XZz8skn88ILL1BdXd3h44iIyM795S9/oW/fvpxyyimttjscDgzD6NSx58+fz6GHHsqRRx5JJBLhnXfe+dbHOBwORowYwdq1a79131NOOYXnnnuOq666CqfTucP9b7zxBuPHj6ewsBAAm83GEUccwRdffLHbBJiIiOzcfffdx6hRo1pti09X23bq73XXXcecOXP44IMPOOWUUzjiiCMwTROAxsZGbr75ZqZPn86kSZP4wQ9+wCeffNLqmM3Nzfj9/lbnFjabjeLi4lb71dXV8fHHH3P44YczefJkli9fTllZWbK7Lb2MEkUibZCTk8Phhx/Of//7X+bMmcOHH36Y+KCPmzZtGlVVVaxYsSKxbdGiRRQVFbUatgrWnON48in+s20Q2JbP5+P8888nGAy2GjoqIiLJsXLlSvbbb78drtB2VllZGcuXL2fy5MmMGjWK4uJiFixY8K2PM02TTZs20adPn2/dNycnp9UUg21FIhHKysoYPHhwq+1DhgwBYMuWLW3ohYiIdNSaNWv49a9/zfnnn8/dd9+NYRiEw2HOOecc3nzzTS6++GJ+85vf4PF4+MEPfsBHH32UeOyMGTNYvnx5Yt9IJLLT53j77beJRCJMnjyZww8/HKDdde5EtqdEkUgb/e53v2PGjBm89dZbzJo1i+OPP55nnnkmkeA56qijMAwjcbXYNE0WLVrEUUcdhd1ub3Ws1157jf3226/Vz0svvbTT5/X5fAwbNoxp06bx+OOP4/f7u7ajIiK9SENDA9XV1fTv379Dj98+8b9t0j+eFDr88MOx2WwcdthhvPPOOwSDwZ0eJxQKUV5ezh//+EdWrVrVahpcIBBo9bOzY2yvtraWaDRKTk5Oq+15eXkAVFRUdKjPIiK9wfaf79tfJG6LjRs3cu655zJz5kwmTpwIwMsvv8xXX33FHXfcwemnn860adP405/+RHFxMX/84x8Tj73++us588wz+fzzz7niiiuYPn06f/vb33b4/F+wYAEDBw5kzz33ZMSIEfTr14/58+d3qu8iShSJtFFRURH33nsvr732GhdccAFbtmzhpptu4uc//zmmaVJSUsK4ceNYtGgRAOvXr2fjxo07nXY2efJknn322VY/Rx555E6fNz7d7YILLqCmpoYXXnih01MhREQkOf7+97+3Svq/++67ifvmz5/PsGHDEiN4Dj/8cBobG/n44493OM6cOXPYf//9+c53vsNTTz3Fddddx4UXXpi4f+zYsa1+tr1vV74tViiWiIjs2pw5c1p9vm/YsKHdx/B6vRx33HGttn366acYhsHkyZMT25xOJ4ceeijLli1LjBzyer3ccsstLFy4kCuvvBKfz8fvf/97LrjgAkKhEADBYJB33nmHww8/HMMwEsf98MMPaWxs7ETvpbdTMWuRdho+fDjXXXcdl112Gddeey3//ve/ueCCC9h///2ZNm0af/zjH6mvr+edd97B7Xa3CgJx+fn5jBkzptW2eP2IXZk4cSJjx47lkUceUQFSEZEkyc3NpaCgoMP1HE466STOPffcxO346pSNjY189NFHnHTSSTQ1NQFwwAEHANbV3+1jw4033sj48eO59dZbqaqq4swzz2yVyHn22Wdb7Z+dnf2tbcvPz8dms+1wslBfXw/QpqltIiK9VfxzOa4jI0+Liop2+LwuKytLFJXeVmFhIaFQiJqamlafz/379+eHP/whF154IXfccQfPPPMMCxYsYMaMGXz00Uc0NTUxceLERKyZOHEizz//PO+99x4zZsxod5tFQCOKRDosPz+f008/HYBvvvkGsOoURSIR3n//fRYtWsRhhx2G1+tNyvMZhsHs2bNZv359q/nLIiLSOSNHjmT58uWJK7TtUVJSwpgxYxI/8eWTFy1aRCgUYt68eUyYMIEJEyYkvrAvWLBghykMw4YNY8yYMVx//fVs3ryZv/zlL63u3/Y5xowZ06bljO12O/37929VXBWsqRBgrdgmIiI7F/9cjv+43e6kHLdfv340NDQQDodbba+ursbpdO7y4rHX601cmIife8SnOF977bWJWHPjjTcCaPqZdIoSRSJtEI1G+eyzz3bYvnr1agD22GMPAPbcc0+GDRvGf//7X/73v/8xbdq0pLZj+vTpDB48mLlz55KVlZXUY4uI9FYXX3wx5eXlPPfcc622h0KhxBXa9po/fz5ZWVn885//5PHHH0/8nHnmmZSWlvLVV1/t9HETJkzguOOO46GHHmLdunUdeu5tzZgxg8WLF1NbWwtY9fPeeecdxowZw6BBgzp9fBGR3iaeMIrXeTNNk08//bTNjz/ggAMwTZP33nsvsS0YDPLhhx8yfvz4RG3TTz/9dIeLCtuee5imyYIFC5gwYUKrOPP4448zbtw43n777R2SUSJtpalnIm2wYMGCRBG5KVOm0L9/f5YsWcJf/vIXjjjiiMQ0MsMwmDp1Kg8//DDALusOdZTD4WDWrFncfvvtqi0hIpIk3/nOd/je977HLbfcwvr16znooIMoLS3lmWeeYa+99uLqq69u1/FCoRBvv/023/nOdzjwwANb3Zednc1TTz3F/Pnz2WeffXb6+J/+9Ke8+eab/OpXv+Khhx7q1Of9mWeeybPPPsuVV17JrFmzeOedd1i+fDn33HNPh48pItIbrFq1aocLs+PHj2e//fYD4O677+aYY47h1VdfZfny5W0+7kknncTDDz/MDTfcwI9//GOKiop46qmnqKmp4b777gNg+fLlnHvuuRx44IEce+yxDB06lK+//po///nPjB49mmnTprF8+XLKysq45JJLmDRpUqvnOO6447jzzjtZvHjxDnFIpC00okikDY4++mgeeeQRwuEwf/7zn/nhD3/Iq6++ypw5c7jnnnuw2Vr+lKZNm4ZpmowbN46SkpKkt+WUU04hLy+vQysviIjIjgzD4Le//S2/+MUvWLx4MT/5yU947LHHGD16ND/+8Y/bfbxPP/2U+vr6nY4qHT16NIMGDUpMF9iZwYMHM3v2bN59913eeOONdj//toYNG8bDDz+M3W7nuuuuY/ny5fz2t79VrTsRkW/x29/+lnPOOafVT3NzM4cddhhz5sxh/vz53HrrreTn53PHHXe0+bgul4snn3ySKVOm8OCDD3LdddcRDAZ54oknEjWR9ttvP5599lkKCwt59NFHufzyy3n66ac56aSTeOSRR3C73Yk4srOFc+LxR9PPpKMMU2ebIiIiIiIiIiKCRhSJiIiIiIiIiEiMEkUiIiIiIiIiIgIoUSQiIiIiIiIiIjE9KlH07LPPcsYZZzB+/HiOO+44nn322V3uu2TJEs466ywmTJjAKaecwltvvdV9DRURkS6leCAiIooFIiKp0WMSRe+++y533XUX5513Hk899RRTpkzhxhtv5O23395h382bN3PeeecxcuRI5s2bx5QpU7j88stZunRpClouIiLJpHggIiKKBSIiqdOjVj3z+/14vV4ATNPkoIMO4oQTTuCXv/xlq/3uvvtuHn30UT766CNcLhemaXLMMccwYcIEfvOb36Si6SIikkSKByIiolggIpIajlQ3YFvxQAAQDAZpamqiuLh4h/2WLl3K/vvvj8vlAsAwDCZMmMCSJUt2e/xp06bt8r5LL72UsWPHMmrUqA62XkREkkXxQEREFAtERFKjRyWKtvXUU09hs9k4/vjjd7ivoqKC4cOHt9pWUFDA1q1bO/x8+fn5NDY28umnn3b4GCIiPc3EiRNT3YROUzwQEem8dI8HigUiIp3X1ljQIxNFS5cu5Y9//CNXXXXVDh/6nTF//vxd3rds2TJM02SvvfZq1zH9fj/r1q1j2LBhra56ZJJM76P6l/4yvY+Z3r/dUTzoOdS/9Jfpfcz0/kHv6OPOKBb0LJneR/Uv/WV6H7ujfz0uUbR69Wouvvhizj77bC6++OKd7lNSUkJtbW2rbbW1tfTr169Tz20YBllZWR16rNfr7fBj00Wm91H9S3+Z3sdM79/2FA96JvUv/WV6HzO9f9A7+hinWNBzZXof1b/0l+l97Mr+9ZhVzwA2bdrE7NmzOf744/nZz36GYRiJ+yKRSOL/Y8eO5YsvviAYDAJWcbvFixczduzYbm+ziIgkn+KBiIgoFoiIpEaPSRRVVlYye/Zs9t13X+bMmUNlZSUVFRVUV1czb948Jk2axKJFiwA4/fTTiUaj3HHHHaxZs4b777+fjRs3cu6556a4FyIi0lmKByIiolggIpI6PWbq2TvvvMP69etZv349CxcuTGwfM2YMs2bNIjs7O7GSwaBBg5g7dy6//vWvOfXUUxk+fDgPPPCArhqIiGQAxQMREVEsEBFJnR6TKPr+97/P97///V3eP3PmzFa3DzjgAJ566qmubpaIiHQzxQMREVEsEBFJnR4z9UxERERERERERFJLiSIREREREREREQGUKBIRERERERERkRglikREREREREREBFCiSEREREREREREYpQoEhERERERERERQIkiERERERERERGJUaJIREREREREREQAJYpERERERERERCRGiSIREREREREREQGUKBIRERERERERkRglikREREREREREBFCiSEREREREREREYpQoEhERERERERERQIkiERERERERERGJUaJIREREREREREQAJYpERERERERERCRGiSIREREREREREQGUKBIRERERERERkRglikREREREREREBFCiSEREREREREREYpQoEhERERERERERQIkiERERERERERGJUaJIREREREREREQAJYpERERERERERCRGiSIREREREREREQGUKBIRERERERERkRglikREREREREREBFCiSEREREREREREYpQoEhERERERERERQIkiERERERERERGJUaJIREREREREREQAJYpERERERERERCRGiSIREREREREREQGUKBIRERERERERkRglikREREREREREBFCiSEREREREREREYpQoEhERERERERERQIkiERERERERERGJUaJIREREREREREQAJYpERERERERERCRGiSIREREREREREQGUKBIRERERERERkRglikREREREREREBFCiSEREREREREREYpQoEhERERERERERoIcnihYuXMi0adOYOnXqTu//wQ9+wKhRo1r9XH755d3cShER6UqKBSIiAooHIiLdxZHqBuzM5s2bue222/jggw/YY489aGho2OW+3/3ud7nxxhsTtz0eT3c0UUREuphigYiIgOKBiEh365Ejipqbm/F6vbz66qscffTRu93X4/FQUlKS+MnNze2mVoqISFdSLBAREVA8EBHpbj1yRNGIESP4wx/+0KZ9Fy9ezFlnncXmzZuZPHky1113Hfn5+Tvdd9q0abs8zrXXXkv//v3x+Xztaqvf72/1bybK9D6qf+kv0/vYmf5lZWUluzndpqtiASgedIT6l/4yvY+Z3j9QPGgLnRt0vUzv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RBQLREQyS4cTRWPHjuXRRx/l7rvv5pVXXiEUCuFwOBgzZgy/+93vmDhxYjLb2XNp1TMR6cUUC0RERLFARCSzdDhRBDBhwgQee+wxotEo1dXVFBYWYrfbk9W2tGAaGlEkIr2bYoGIiCgWiIhkjg7XKGp1EJuNPn36JIJBfX09CxcuTMah00C8RpESRSLSu/XuWCAiIqBYICKSCZKSKNreokWLuPbaa7vi0D2PRhSJiOxUr4oFIiKyU4oFIiLpp81Tz37+85/z73//u80HHjNmTIcalHZUo0hEehHFAhERUSwQEclsbU4UnXTSSeyxxx5t2jcvL48TTjihw41KL7GXUCOKRKQXUCwQERHFAhGRzNbmRNHkyZOZPHlyV7YlLbUUs9aIIhHJfIoFIiKiWCAiktm6pEZRrxKbemagEUUiIiIiIiIikt6UKOqseI0ijSgSERERERERkTSnRFGnadUzEREREREREckMShR1VmLVMyWKRERERERERCS9dShR9PHHH/Paa699637V1dWsXLmSaDTakadJC6amnolIL6VYICIiigUiIpmnzauebeu1117j66+/5qCDDuJf//oXZWVlHHHEERx66KGJfZ577jl++ctfEolEGD58OA8//DD9+vVLWsN7ipf+vYaPFg3hth/Wk53qxoiIdCPFAhERUSwQEck8HRpRdMwxx1BTU8Nll13GnXfeycMPP8zs2bN55JFHAPD7/dx+++1897vf5b777gPgr3/9a9Ia3ZPMf2s9y9ZksWKtPdVNERHpVooFIiKiWCAiknk6lCgaOHAgq1evZu+99+aDDz7ggw8+4LTTTuOee+4hFAqxdu1afD4fP/rRjzj66KO55JJLWLRoUbLb3iPY7dZLGAxpGK2I9C6KBSIiolggIpJ5OpQoKikpAeCKK66gsLCQwsJCrr76avx+P5s2bcLv92MYBoMHDwZg6NChlJeXJ6/VPYjTac3eCylRJCK9jGKBiIgoFoiIZJ4OJYo8Hg/9+vVj69atiW1bt27FMAzy8vLYunUrDkdL+aNQKITT6ex8a3sgp9OachYOm5immeLWiIh0H8UCERFRLBARyTwdKmYNcOSRR3L11Vfzgx/8AIAnnniC/Px8Zs6cSTgcZty4cYl9P/74Y/r379/51vZAiRFFYQOI0ImXVEQk7SgWiIiIYoGISGbpcFbjJz/5CWvX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eWvWrOHiiy/mwAMPZMqUKfzzn/9M3JfufaytreXGG2/ksMMOY/z48VxwwQUsX748cf/atWu54IILmDRpEjNnzuS5555LYWvbbuHChUybNo2pU6cmtlVWVvLDH/6Qgw8+mBkzZvDXv/4V0zRbPS7d389MoliQnjI5HigWKBZIaigepJ9MjgWgeKB40EGmdNirr75qjho1ynzyySfNlStXmpdeeqk5efJk0+fzpbpp7bZo0SLzkEMOMf/973+bX331lfnrX//aHDlypPnWW2+Zpmmal1xyiTl9+nTz888/N999913zoIMOMn/1q1+luNXtV1tba06cONH85z//2Wr74sWLzdGjR5v33XefuWrVKvOmm24yx40bZ5aWlqaopR2zYcOGxHvz9ddfm++++6751VdfmaaZGX2cM2eOecIJJ5hvvfWWuXjxYvOiiy4yDzzwQNPn85lNTU3moYceal5++eXmypUrzccff9wcNWqU+frrr6e62bu0adMm89JLLzXHjRtnfu973zOPOuoo0zRNMxKJmCeccIJ5xhlnmF9++aX5yiuvmGPGjDEffvjhxGMz4f3MFIoF6RcLTDOz44FigWJBOr2fmUTxIP3iQSbHAtNUPFA86Pj7qURRJ5x55pnm7NmzE7dLS0vNkSNHms8++2wKW9Vx2waxaDRqTpo0yfy///s/c+3atebIkSPNf/3rX4n7H3jgAfOAAw4wGxoaUtHUDrv77rvNKVOmmIFAoNX2n/70p+YxxxyTuN3c3GyOGzfOvOeee7q7iZ1yyy23mKeeeqoZjUZ3uC8T+jhx4kTz0UcfTdz+9NNPzZEjR5orV640n3nmGXPkyJFmWVlZ4v5Zs2aZ55xzTiqa2iarV682r776arO0tNS89957E8HgvffeM0eOHGl+9tlniX1vuOEG86ijjjIjkYhpmpnxfmYKxYL0iwWmmdnxQLFAsSCd3s9MoniQfvEgk2OBaSoeKB50/P3U1LMOMk2TZcuWMX78+MS2AQMGMHDgQJYsWZLClnWc1+tN/D8YDNLU1ERxcXFiyNq2fZ0wYQI+n4/Vq1d3ezs7qrq6mrlz53LZZZfhcrla3bd06VImTJiQuO12u9l///3T7r18/fXXOeyww7jttts46qij+P73v8/7778PZEYfJ06cyOuvv87WrVsBeO+99xgxYgR77bUXS5YsYdCgQfTr1y+x/4QJE1iyZMkOwzJ7ihEjRvCHP/yBAQMGtNq+ZMkSbDYbY8eOTWybMGECmzdvpqqqCsiM9zMTKBakXyyAzI8HigWKBen0fmYKxYP0iweZHgtA8UDxoOPvpxJFHVRTU0MoFCI/P7/V9oKCAsrLy1PUquR56qmnsNlsHH/88VRUVAC06mtBQQFA4o8yHfzjH/+gsLCQk08+GYCpU6fy/PPPA1BRUZH272VzczOVlZU8+eST5OTkcM899zBhwgSuuOIKysvLM6KPv/3tbwmHw0ydOpUzzjiDV155JfG7WlFRkfi9jCsoKCAYDFJbW5uS9nZURUUFeXl52O32xLbt/+Yy4f3MBIoFBUB6xQLI7HigWKBYkG7vZ6ZQPCgA0iseZHIsAMUDxYPOvZ9KFMkOli5dyh//+Eeuuuoqhg8fnurmJEVVVRX//Oc/d3rFIFPU19cDcMopp3D11VczduxYrrnmGkKhUOLKQbqbN28e1dXV/OUvf+Gggw6ivLycn/70p4m+i0jyZGIsgMyPB4oFIpJsmRgPMj0WgOKBdI4j1Q1IV4WFhTidTurq6lptr62tZcyYMSlqVeetXr2aiy++mLPPPpuLL74YgJKSEgDq6urIyckBSGRhtx3K15O98847+P1+brvtNu644w4AfD4fN998M59//jklJSU7fS/79u2biuZ2SGFhIQDFxcWJbS6Xi7y8PKqqqtK+j0uXLuV3v/sdf/jDHzj88MM5/PDDOeOMM5g+fTpPPPEEJSUlrFq1qtVjamtrcblcO1xN6OlKSkqor68nEokkrhxs/zeX7u9nplAsqAXSJxZA5scDxQLFgnR6PzOJ4kEtkD7xINNjASgeKB507v3UiKIOMgyDMWPGsHjx4sS2srIySktLW80dTCebNm1i9uzZHH/88fzsZz/DMAyARH8+//zzxL6LFy/G6/Wy1157paKp7TZ9+nTeeOMNXn75ZV588UVefPFFAK666iquuuoqxo4d2+q9DAQCLF++PK3eS6fTyciRI1mxYkViW21tLTU1NQwfPjzt+xgfVjl06NDEtoEDB+LxeKipqWHcuHFs3ry51ZDnxYsXM3bs2MTvcroYN24c0WiUZcuWJbYtXryYQYMGJYJ9ur+fmUKxIL1iAWR+PFAsUCxIp/czkygepFc8yPRYAIoHigedez+VKOqEWbNm8f777/P000+zatUqbr31Vvr06cNxxx2X6qa1W2VlJbNnz2bfffdlzpw5VFZWUlFRQXV1NcOGDePII4/k3nvvZenSpbz//vs88sgjnHrqqYmrCD1dTk4Oe+yxR6sfgD59+tCnTx/OPfdc1q9fzwMPPMCaNWu4/fbbMU2T0047LcUtb5/zzjuP119/nZdeeok1a9Zwyy23MGzYMA4//PC07+PEiRMpKiriD3/4A19++SXffPMNt99+O4FAgBkzZnD88cdTXFzMr371K1atWsWTTz7JBx98wHnnnZfqprfbIYccwsiRI/n1r3/NV199xWuvvcbLL7/MD37wA2w262M73d/PTKJYkD6xAHpHPFAsUCxIl/cz0ygepE886A2xABQPFA868X52aK00SXjmmWfM448/3pwwYYI5a9Ysc+3ataluUoc899xz5siRI3f4OeWUU0zTNM3GxkbzmmuuMQ877DBzypQp5u23324Gg8EUt7pzRo4caT733HOJ22+++aZ58sknmwcccIB5xhlnmJ9//nkKW9cx0WjUfPjhh83jjjvOnDBhgjlnzhxz8+bNifvTvY9ff/21eemll5oHH3ywOX78ePPMM880Fy1alLj/m2++Mc877zxzwoQJ5vHHH28+88wzKWxt+2y7BKZpmmZFRYV52WWXmQceeKA5ffp088EHH9xhadN0fz8ziWJBesu0eKBYoFggqaN4kL4yLRaYpuKB4kHH30/DNHvo2nAiIiIiIiIiItKtNPVMREREREREREQAJYpERERERERERCRGiSIREREREREREQGUKBIRERERERERkRglikREREREREREBFCiSEREREREREREYpQoEhERERERERERQIkikbTy6aef8swzz6S6GSIikmKKByIiAooH0jUcqW6ASE/2/PPPc/311++wfa+99uI///lPt7dn3rx5/O9//+P000/v9ucWEenNFA9ERAQUD6R3UKJIpA2uueYaxo0bl7idm5ubwtaIiEiqKB6IiAgoHkhmU6JIpA323ntvJk2alOpmiIhIiikeiIgIKB5IZlONIpFOeP755xk/fjybNm1izpw5TJo0iRNPPJF//etfO+y7dOlSzj//fA466CCmTp3K9ddfT21t7Q77vfnmm5xxxhmMHz+eo48+mj/+8Y/4/f5W+3zxxRfMmjWLCRMmcPbZZ/PNN990VRdFRKQNFA9ERAQU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",
      "text/plain": [
       "<Figure size 1400x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "_, axs = plt.subplots(1, 3, figsize=(14, 3))\n",
    "\n",
    "for d, ds in enumerate(DATASETS):\n",
    "    ds_label = DATASET_LABELS[ds]\n",
    "    \n",
    "    df_hr_plot = df_hr[df_hr['Model zoo'] == ds_label]\n",
    "    \n",
    "    for i, (idx, label) in enumerate(idx_dict.items()):\n",
    "        sns.lineplot(df_hr_plot[df_hr_plot['Hyper-representation'] == label], x='Epoch', y='Train loss', color=COLOURS[i], label=label, ax=axs[d])\n",
    "    \n",
    "    axs[d].set(title=f\"{ds_label}\", ylabel='Training loss', ylim=(0., 2.))\n",
    "    axs[d].get_legend().remove()\n",
    "\n",
    "plt.legend(loc=(-1.40, -0.40), ncols=3)\n",
    "plt.subplots_adjust(hspace=0.6, wspace=0.25)\n",
    "plt.savefig('figures/train_loss_different_functions.png', dpi=300, bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
