{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d98765e1",
   "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": "116617c2",
   "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": "0d465bf9",
   "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": "6a45fdd7",
   "metadata": {},
   "source": [
    "## Loading data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "755588f7",
   "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",
    "HR_PLOT = ['Contrastive + Structure (Baseline)', 'Contrastive + Behavior', 'Contrastive + Structure + Behavior']\n",
    "\n",
    "HYPERREP_PATH = Path('{YOUR_WORKING_PATH}/results/hyperrepresentations/tune')\n",
    "\n",
    "EXPERIMENT_PATH = Path.cwd() / 'results' "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e0f27f84",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3f09a64e37a6496daba04d4321956128",
       "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": "407a49eb",
   "metadata": {},
   "outputs": [],
   "source": [
    "idx_dict = {\n",
    "    '00011': 'Contrastive + Structure (Baseline)',\n",
    "    '00000': 'Behavior',\n",
    "    '00006': 'Contrastive + Behavior',\n",
    "    '00002': 'Structure + Behavior',\n",
    "    '00008': 'Contrastive + Structure + Behavior'\n",
    "}\n",
    "\n",
    "df_hr['Hyper-representation'] = df_hr['Trial ID'].str.slice(start=-5).map(idx_dict)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2bc649bf",
   "metadata": {},
   "source": [
    "### Loading model zoos metadata"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "6b9502ec",
   "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>Activation function</th>\n",
       "      <th>Initialisation</th>\n",
       "      <th>Learning rate</th>\n",
       "      <th>Weight decay</th>\n",
       "      <th>Seed</th>\n",
       "      <th>Epoch</th>\n",
       "      <th>Test accuracy</th>\n",
       "      <th>Generalisation gap</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>7597300394</td>\n",
       "      <td>relu</td>\n",
       "      <td>kaiming_uniform</td>\n",
       "      <td>0.00075</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>0.071758</td>\n",
       "      <td>-0.001563</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>7597300394</td>\n",
       "      <td>relu</td>\n",
       "      <td>kaiming_uniform</td>\n",
       "      <td>0.00075</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>6</td>\n",
       "      <td>1</td>\n",
       "      <td>0.775200</td>\n",
       "      <td>-0.182034</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>7597300394</td>\n",
       "      <td>relu</td>\n",
       "      <td>kaiming_uniform</td>\n",
       "      <td>0.00075</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>6</td>\n",
       "      <td>2</td>\n",
       "      <td>0.829479</td>\n",
       "      <td>-0.016614</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>7597300394</td>\n",
       "      <td>relu</td>\n",
       "      <td>kaiming_uniform</td>\n",
       "      <td>0.00075</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>6</td>\n",
       "      <td>3</td>\n",
       "      <td>0.846381</td>\n",
       "      <td>-0.003682</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>SVHN</td>\n",
       "      <td>7597300394</td>\n",
       "      <td>relu</td>\n",
       "      <td>kaiming_uniform</td>\n",
       "      <td>0.00075</td>\n",
       "      <td>0.0005</td>\n",
       "      <td>6</td>\n",
       "      <td>4</td>\n",
       "      <td>0.848033</td>\n",
       "      <td>0.010410</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  Model zoo    Trial ID Activation function   Initialisation  Learning rate  \\\n",
       "0      SVHN  7597300394                relu  kaiming_uniform        0.00075   \n",
       "1      SVHN  7597300394                relu  kaiming_uniform        0.00075   \n",
       "2      SVHN  7597300394                relu  kaiming_uniform        0.00075   \n",
       "3      SVHN  7597300394                relu  kaiming_uniform        0.00075   \n",
       "4      SVHN  7597300394                relu  kaiming_uniform        0.00075   \n",
       "\n",
       "   Weight decay  Seed  Epoch  Test accuracy  Generalisation gap  \n",
       "0        0.0005     6      0       0.071758           -0.001563  \n",
       "1        0.0005     6      1       0.775200           -0.182034  \n",
       "2        0.0005     6      2       0.829479           -0.016614  \n",
       "3        0.0005     6      3       0.846381           -0.003682  \n",
       "4        0.0005     6      4       0.848033            0.010410  "
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "DF_ZOO_PATH = EXPERIMENT_PATH / 'zoo_analysis' / 'df_zoo.csv'\n",
    "\n",
    "df_zoo = pd.read_csv(DF_ZOO_PATH, index_col=0)\n",
    "df_zoo.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c04ee8e1",
   "metadata": {},
   "source": [
    "### Loading reconstruction accuracies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "7c4c8f5d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "7ebd36b1ff224a18aa6c2fb6e0311632",
       "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 index</th>\n",
       "      <th>Hyper-representation model</th>\n",
       "      <th>Original accuracy</th>\n",
       "      <th>Reconstruction accuracy</th>\n",
       "      <th>Model zoo</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0</td>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>0.743623</td>\n",
       "      <td>0.195874</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>0.828596</td>\n",
       "      <td>0.195913</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>0.856215</td>\n",
       "      <td>0.295444</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>0.873848</td>\n",
       "      <td>0.429779</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>4</td>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>0.887792</td>\n",
       "      <td>0.581400</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   Model index          Hyper-representation model  Original accuracy  \\\n",
       "0            0  Contrastive + Structure (Baseline)           0.743623   \n",
       "1            1  Contrastive + Structure (Baseline)           0.828596   \n",
       "2            2  Contrastive + Structure (Baseline)           0.856215   \n",
       "3            3  Contrastive + Structure (Baseline)           0.873848   \n",
       "4            4  Contrastive + Structure (Baseline)           0.887792   \n",
       "\n",
       "   Reconstruction accuracy Model zoo  \n",
       "0                 0.195874      SVHN  \n",
       "1                 0.195913      SVHN  \n",
       "2                 0.295444      SVHN  \n",
       "3                 0.429779      SVHN  \n",
       "4                 0.581400      SVHN  "
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "zoo_acc = list()\n",
    "\n",
    "for ds in tqdm(DATASETS, desc='Loading data', unit='dataset'):\n",
    "    df_zoo_acc_path = EXPERIMENT_PATH / f'hr_analysis_{ds}' / 'df_zoo_acc.csv'\n",
    "    df_zoo_acc = pd.read_csv(df_zoo_acc_path, index_col=0)\n",
    "    \n",
    "    df_zoo_acc['Model zoo'] = DATASET_LABELS[ds]\n",
    "    \n",
    "    zoo_acc.append(df_zoo_acc)\n",
    "    \n",
    "zoo_acc = pd.concat(zoo_acc)\n",
    "zoo_acc.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0386b2bf",
   "metadata": {},
   "source": [
    "### Loading generation accuracies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "173cd2d9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "6b2b0dc3bb0046e290506853eac14718",
       "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>Hyper-representation model</th>\n",
       "      <th>Origin</th>\n",
       "      <th>Accuracy</th>\n",
       "      <th>Model zoo</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>Generated</td>\n",
       "      <td>0.369084</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>Generated</td>\n",
       "      <td>0.159381</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>Generated</td>\n",
       "      <td>0.221996</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>Generated</td>\n",
       "      <td>0.288222</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Contrastive + Structure (Baseline)</td>\n",
       "      <td>Generated</td>\n",
       "      <td>0.195874</td>\n",
       "      <td>SVHN</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "           Hyper-representation model     Origin  Accuracy Model zoo\n",
       "0  Contrastive + Structure (Baseline)  Generated  0.369084      SVHN\n",
       "1  Contrastive + Structure (Baseline)  Generated  0.159381      SVHN\n",
       "2  Contrastive + Structure (Baseline)  Generated  0.221996      SVHN\n",
       "3  Contrastive + Structure (Baseline)  Generated  0.288222      SVHN\n",
       "4  Contrastive + Structure (Baseline)  Generated  0.195874      SVHN"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gen_acc = list()\n",
    "\n",
    "for ds in tqdm(DATASETS, desc='Loading data', unit='dataset'):\n",
    "    df_gen_acc_path = EXPERIMENT_PATH / f'hr_analysis_{ds}' / 'df_generative.csv'\n",
    "    df_gen_acc = pd.read_csv(df_gen_acc_path, index_col=0)\n",
    "    \n",
    "    df_gen_acc['Model zoo'] = DATASET_LABELS[ds]\n",
    "    \n",
    "    gen_acc.append(df_gen_acc)\n",
    "    \n",
    "gen_acc = pd.concat(gen_acc)\n",
    "gen_acc.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3f4f05c2",
   "metadata": {},
   "source": [
    "### Loading generation diversity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "33fb24b8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ef9835ef32b042ce9c979101a32de969",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading data:   0%|          | 0/3 [00:00<?, ?dataset/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "gen_diversity = dict()\n",
    "\n",
    "for ds in tqdm(DATASETS, desc='Loading data', unit='dataset'):\n",
    "    gen_diversity_path = EXPERIMENT_PATH / f'hr_analysis_{ds}' / 'gen_diversity.json'\n",
    "    with open(gen_diversity_path, 'r') as ifh:\n",
    "        gen_diversity[ds] = json.load(ifh)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "98b0e5bf",
   "metadata": {},
   "source": [
    "## Analysing data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9d157bbf",
   "metadata": {},
   "source": [
    "### Plotting figures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "59919522",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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hQ4dOhATE8O8efNISkpiyZIlLq+ffo6YmJhqTVms1WoJCwtzGUgVHN0fwDEzmxBCiMqVX5fLFw8Pj3o5bqtWrSgoKMBqtbqsz87ORq/XV/nQ2GQyOR9KlH/uKO/WPGfOHGesefjhhwGky5moE0kSCVENdrud7du3V1h/5MgRANq3bw9Ax44d6dChA7/++iubN29m9OjR9VqOsWPH0qZNG5YtW4anp2e9HlsIIc5Ht9xyC+np6axcudJlvcVicT6Zrak1a9bg6enJRx99xPLly53LtGnTSE5O5sCBA5Xu17dvXyZOnMg777xDfHx8rc59uvHjx7Njxw5yc3MBx1h5GzZsICYmhtatW9f5+EIIcb4pTxaVj+umqirbtm2r9v69e/dGVVU2bdrkXGc2m/nrr7/o06ePcxzTbdu2VXigcPrnDlVVWbt2LX379nWJM8uXL6dXr16sX7++QiJKiOqS7mZCVMPatWudg8ZddNFFhIWFsWvXLpYsWcLw4cOdXccURWHUqFG8//77AFWOM1RbOp2OmTNn8vTTT8t4EkIIUQ+GDRvGpZdeyuOPP05CQgIDBw4kOTmZzz//nM6dO3PPPffU6HgWi4X169czbNgwBgwY4PKal5cXn376KWvWrKFbt26V7n/fffexevVqnnzySd555506XeunTZvGF198wezZs5k5cyYbNmxg7969LFq0qNbHFEKI88Hhw4crPJDt06cPPXr0AODll19m3Lhx/PTTT+zdu7fax7388st5//33eeihh7j77rsJDAzk008/JScnh1dffRWAvXv3MmPGDAYMGMCECRNo164dhw4d4s0336Rr166MHj3aOdX9rbfeSv/+/V3OMXHiRJ599ll27NhRIQ4JUR3SkkiIahgzZgxLly7FarXy5ptvctddd/HTTz8xa9YsFi1ahEbzz7/S6NGjUVWVXr16ERISUu9lmTJlCr6+vrWaZUEIIYQrRVFYuHAhjzzyCDt27ODee+/lww8/pGvXrtx99901Pt62bdvIz8+vtCVp165dad26tbOLQGXatGnDjTfeyO+//84vv/xS4/OfrkOHDrz//vtotVrmzp3L3r17WbhwoYxrJ4QQ57Bw4UKmT5/uspSWljJ48GBmzZrFmjVreOKJJ/Dz8+OZZ56p9nENBgOffPIJF110EW+88QZz587FbDbz8ccfO8dA6tGjB1988QUBAQF88MEH3HHHHXz22WdcfvnlLF26FA8PD2ccqWyCnPL4I13ORG0pqnzSFEIIIYQQQgghhDjvSUsiIYQQQgghhBBCCCFJIiGEEEIIIYQQQgghSSIhhBBCCCGEEEIIgSSJhBD1TKbbdCW/DyHE+Uiufa7k9yGEOF/J9c9VS/h9SJJINKmCggI+/fRTMjIymroooh6kpaUxYcIEjh071tRFqbb09HQ+++wzCgoK6v3YP//8M9OnT8disdT7sYVwJxIL3IvEAlcSC4SoPokH7kXigauWEg8kSSSa1Pfff8+jjz7KBx980NRFEXWkqioPPfQQQUFBdOjQoamLU6nExEQefvhhDh065Fz3wQcfsGDBAn744Yd6P9+AAQOIj49nyZIl9X5sIdyJxAL3IbGgIokFQlSfxAP3IfGgopYSD3RNXQDh+Af64osv+Oqrr9i/fz9BQUH07duX2bNn07Zt2wY5X2ZmJn5+fhgMhno/flUKCwuxWq34+/s7140dO5bMzEwuvfTSRitHTWzatInXX3+dAwcO4OnpSefOnbn++uu56KKLnNuYzWby8vIICQlp1LLZbDYyMjIICwtr1PNW5bfffuP3339nxYoVaDSO/POXX37JvHnzANDpdAQFBdGlSxeuueYaxowZ0+hlTE5O5osvvnD5e5s6dSoeHh4NUp7AwEDuuOMOXnzxRaZMmUJ4eHi9n0O4D4kFEgtqQ2JBzUksEM2dxAOJB7Uh8aDmJB5UTloSNQPz589nwYIF9OrVi5deeolZs2axd+9e1q1b1yDn++qrrxg6dCjp6ekNcvyq9OvXjw8//NBlXXBwMLNnz6Z9+/aNWpbq2Lx5MzfffDM6nY758+czb948goODueuuuzh+/Lhzu5tuuol777230cv3+uuvuwSkpvbKK69wwQUXEBsbW+G1Bx98kKVLl/LII4/g6enJnXfeyVdffdUEpayoffv2zJ49m+Dg4AY5/tSpUzGZTLzxxhsNcnzhPiQWSCyoDYkF9UNigWhOJB5IPKgNiQf1Q+KBtCRqcn/++ScrVqzgscce45prrnGuv+KKK9BqtU1YMrFixQq0Wi1LlizBaDQCMHHiRObMmdNgF42W6ujRoxw4cIDHHnus0te7dOnCgAEDABgzZgzDhw9n5cqVXHHFFY1Yyqbh6enJiBEj+Pnnn1mwYAE6nVx2RUUSC5oviQXVJ7GgahILRHVJPGi+JB5Un8SDqrWEeCAtiZrYkiVLCA0NZcqUKS7rdTodiqI4fy4sLGTBggWMHTuW/v37c+2117J161aXff7++2+io6NJSkrikUceYejQoVx00UWsWLHCuU3//v2dTfxGjx5NdHQ0CQkJALz66qtMmjSJAwcOMGPGDHr37k1hYSE5OTk89NBDjB07ltjYWIYOHcrDDz/sMpiX1Wrl1VdfZfTo0fTq1YtJkybx+uuvU1JSwtNPP010dDQAr732GtHR0bz88ssAnDx5kujoaL788kvAkVkdN24cqqo6j62qKuPGjeO6665zrktMTOS2225j4MCBjBs3jpdeeqnaA4CNGjWKV1999ZzblZWVoaoqJSUlLuvLg8Dq1auJjo5m8+bNbN68mejoaJdgPmrUKN59910+/PBDRo0axX333ef8PZf/Psp9+eWXREdHc/LkSZf1q1ev5uqrr6ZPnz6MGTOGV155hbS0NKKjo3nttdcAiI6OpmvXrpjNZgCuvfZarr32WpfjzJ07l1GjRlX4PVRWPoC9e/dy3XXX0a9fPyZNmsT777/v8p6cac2aNQBccMEFVW5TTlEU9Hq9y+91z5493HHHHQwbNoyePXsyZswY3n77bZdzZmZmMnfuXIYOHUq/fv24+uqr+eGHH1y2qWm54Z//m7///tu5bu7cucyaNYudO3dy/fXX07dvX6ZNm8bRo0dd9rVarbz88suMGzeOCy64gFmzZnHixIkK5xg4cCC5ubns3LnznL8fcX6SWCCxACQWSCwQQuKBxAMHiQcSD5qSJIma2MGDB+nRo8dZ+/9arVamT5/O6tWrueWWW3j++ecxGo1ce+21Ln+85W666Sb0ej3z588nKiqKBQsWOC/2b7/9NrNmzQIcTQCXL19O69atnfumpaXxyCOPMHnyZN544w28vb3x8/MjPDycW2+9lddee42bbrqJVatWsWjRIud+b731Fq+99hojRoxg8eLFXH311axdu5bs7Gyuu+46li9fDsC//vUvli9fzv/93/9VWteLL76YhIQElxHwjx07RkJCAhMmTAAgNzeXq666ipKSEp577jlmzpzJxx9/zJNPPlnl71BVVaxWK1arFVVVsdvtzp+rMn78eKxWK1deeSUfffQRRUVFLq/369eP5cuX061bN7p168by5csrlGHVqlWs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f//+6nXXXafu3LnT5TiVjcR+5gwB5V599VV14MCB6oABA9TnnntOVdWqR8QvKipSH374YXXgwIHqyJEj1f/+979qcXGxOmvWLPXjjz9WVVVVt27dqt56663q8OHD1djYWPXyyy9Xv/76a5fjbN++Xb344ovVmJgYderUqWpaWlqV5UtNTVWjo6PV6OhoNS0trUKZTpw4od5xxx3q4MGD1QsuuEC98cYb1S1btlTn111t6enp6mOPPaZeccUVaq9evdThw4ers2fPVg8fPlxhu5kzZ6oxMTHq2LFj1T///FNVVccMAXPmzKlwXLvdrr744ovO3+fTTz+t7tq1q9JZJb799lvn+ceNG6e++uqranFxsaqqjpH+58+fr/bt21cdNGiQ+v7776uqqqp5eXnqnXfeqfbu3VudPHmy+tlnn6nvvvtupTMYVFY+VVXVvXv3qtdff706YMAAdejQoepdd92l7t+//6y/ryVLlqg9e/Z0mUXizBkM+vXrp15yySXqq6++qhYUFDi3O3HihHrDDTc4y/zNN9+oR48eVS+99FL10KFDqs1mU1euXKlec8016oABA9R+/fqpN954Y4X/gXOV2263q/fff7/au3dv50wdVc1gcObvq7L/D7PZrC5atEidMGGC2qtXL/Xyyy9X3333XZdZFH777Tc1KipK3bx581l/f0JILJBYILFAYoEQqirxQOKBxAOJB01LUVVVbepElRCi5SstLWXixIkMGzaMxx9/vKmL0yxYrVauuuoqWrduXasne0II0dJILKhIYoEQ4nwk8aCilhIPZEwiIUS9MBqNPPvss6xYscLZF/h89+2335KUlMSCBQuauihCCNEoJBZUJLFACHE+knhQUUuJB9KSSAhRr/bt20e3bt1QFKWpi9LkLBYLx48fJyoqqqmLIoQQjUpiwT8kFgghzmcSD/7RUuKBJImEEEIIIYQQQgghRPPsbrZu3TpGjx7NqFGjqtxm7dq1TJkyhb59+3LNNdewe/fuRiyhEEKIxiDxQAghhMQCIYRoPM0qSZSUlMTtt9/OPffcg7e3d5Xb7dy5kzvvvJORI0fy+eef06VLF6677jpSUlIasbRCCCEaisQDIYQQEguEEKLxNaskUWlpKSaTiZ9++okxY8ZUud1HH31Eu3btuOuuu+jcuTMPP/wwACtWrGisogohhGhAEg+EEEJI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Q5VFCCFECyCxQAghBEg8EEIId1SngavPxmazNdShhRBCtBASC4QQQoDEAyGEaClq1JKoMmlpacTFxVFYWOhcZ7PZWLt2LSkpKXz55Zd1PYUQQohmTmKBEEIIkHgghBAtXZ2SROvXr+c///kPpaWlKIqCqqrO1/z9/XnyySfrXEAhhBDNm8QCIYQQIPFACCHcQZ26my1atIghQ4bw/fffo6oqb7zxBmvWrOG1117D09OTtm3b1lc5hRBCNFMSC4QQQoDEAyGEcAd1ShIdO3aMyZMn07FjRxRFwc/Pj9atWzNmzBiuu+46nn766foqpxBCiGZKYoEQQgiQeCCEEO6gTkkik8mEXq9Ho9HQqlUrDhw44HwtMDCQffv21bmAQgghmjeJBUIIIUDigRBCuIM6jUnUuXNn4uPjAbjgggtYvHgxiqKg0WhYunSpNCkVQojzgMQCIYQQIPFACCHcQZ2SRNdccw2BgYEA/Pvf/2bnzp08/vjjAHh6evK///2v7iUUQgjRrEksEEIIARIPhBDCHdQpSTRx4kTn961bt+brr79m586dFBUV0adPH4KCgupcQCGEEM2bxAIhhBAg8UAIIdxBnZJEZzKZTAwaNKg+DymEEKKFkVgghBACJB4IIURLVOck0dGjR/nggw84ePAgGRkZtGrVitjYWGbOnEl4eHh9lFEIIUQzJ7FACCEESDwQQoiWrk6zm23atInLLruMFStWkJOTQ0hICBkZGSxdupSJEyeyf//++iqnEEKIZkpigRBCCJB4IIQQ7qBOLYlefPFFevbsySuvvEJYWJhz/fHjx5k9ezbPPPMMH374YZ0LKYQQovmSWCCEEAIkHgghhDuoU0uixMREbrnlFpcgABAZGcldd91Vq6cFK1asYPLkyfTv358bb7yRhISEs26/detW7rvvPiwWS43PJYQQou4kFgghhACJB0II4Q7qlCTq3bs3x44dq/S1/Px8OnfuXKPjrVq1ivnz5zN9+nQ+/vhjPDw8mD59OiUlJZVur6oqixYtwmq1otfra1x+IYQQdSexQAghBEg8EEIId1Cj7mYFBQUUFBQ4f77llluYN28ePXv2pH379s71ubm5vP322yxcuLBGhVm2bBlDhgxh2rRpACxYsIARI0bw448/MmXKlArb//XXX2zZsoXvvvuuRucRQghRexILhBBCgMQDIYRwRzVK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EomIiIiIiIiISMMxTNM0G7oQIiIiIiIiIiLSsNSSSERERERERERElCQSEREREREREREliUREREREREREBCWJREREREREREQEJYlERERERERERAQliapk4cKFjB8/nqFDhzJt2jR2795d6bJr167l8ssvZ/DgwUyYMIGvvvqq/gpaA1Wt45o1a5g2bRonnHACI0eO5NFHH6W4uLieS+s/f75DgF9++YXbb78du91eTyWsOX/qmJ+fzz333MNpp53GiSeeyF133UVjf9BhVevncrl4/vnnGTVqFMnJyVxwwQUsXry4nktbPcuXL2fUqFGceeaZlS6zbNkyJkyYwODBg7n88stZt25dPZZQFA9KKR40TooFbooFUpcUC0opFjReigduigfVYMoxffrpp2ZiYqL59ttvm1u2bDFvvPFGc/jw4WZBQUG5Zffu3WsmJyebs2bNMrdt22bOmzfP7NOnj7l27doGKHnVVbWOBw8eNE8++WTz+eefN3///XfznXfeMfv372/OmTOngUpeNf58h6Zpmi6Xy5wyZYr55z//uZ5LWn3+1NHhcJgXX3yxOWXKFHPt2rXmr7/+an733XcNUOqq86d+r7zyijlw4EDz/fffNzdt2mQ++uijZq9evczVq1c3QMmrZu/eveaNN95oDhgwwDz//PPNM844o8Ll1qxZY/bu3dt86qmnzK1bt5ozZ840BwwYYKamptZziZsnxYNSigeNk2JBKcUCqSuKBaUUCxovxYNSigf+U5LoOCZNmmROmzbN+z41NdXs1auX+d5775Vb9vHHHzcHDhxoFhcXm6bpPqCcddZZ5h133FFv5a0Of+p49D/ezTffbI4dO7bOy1gT/tTPNE1z5cqVZmJiovn777/XVxFrzJ86fvrpp2ZycrKZmZlZn0WsEX/qd9NNN5nTp0/3vi8pKTEHDBhgvvHGG/VS1urYtm2bedttt5mpqanmk08+WWkguP32282zzz7b+76oqMgcMGCAOW/evPoqarOmeOBL8aDxUSwopVggdUWxwJdiQeOkeFBK8cB/6m52DKZpsn79egYNGuSd1rZtW9q1a8fatWvLLb9u3Tr69+9PcHAwAIZhMHjw4AqXbSz8rWNYWJjP+6ysLOLi4uq8nNXlb/1M02TevHmcd9559OzZsz6LWm3+1vGzzz5jwIABfPrpp4wbN47Ro0fz2muvNdompf7Wb8iQIaxatYqNGzcCsHr1akzT5PTTT6+3Mvure/fuPP7447Rt2/aYy61bt47Bgwd734eEhNC/f/9GfYwJFIoHigeNnWKBL8UCqQuKBYoFTYHigS/FA//ZarR2gMvKysJutxMVFeUzPTo6moMHD5ZbPj09na5du5ZbNi0trU7LWRP+1rGsjRs3snr1ah5++OG6LGKN+Fu/FStWsHbtWh566CEA7rrrLgAeeeSRui9sNflbx3379rFjxw6io6OZNWsWe/bs4d5776Vz586cccYZ9VXsKvO3fldddRWpqalcdNFFDBgwgJ07d7JgwQI6duxYX0WuM+np6RV+DsfrRy81p3igeNDY44FigS/FAqkLigWKBY09FoDiwdEUD/ynlkRSLVlZWfzf//0fp556KhdccEFDF6dWmKbJk08+ybhx4+jevXtDF6fO5OTk0LVrVx5//HFOOOEEJkyYwLBhw/j8888bumi1YuXKlSxfvpzZs2dz4YUX0rJlS2699VY2b97c0EUTCUiKB02TYoGI1CbFgqZL8UCOpiTRMcTExBAUFEROTo7P9OzsbFq3bl1u+fj4eLKzs8stm5CQUJfFrBF/6wju0e+vv/56YmNjefLJJ7FYGu+fkT/1S01NZf369Xz66acMGjSIQYMG8dFHH/HRRx8xduzY+iy2X/z9DuPi4oiJicFms/lMy8zMrPOyVoc/9SspKeHWW29lxIgRTJgwgT/96U98+umnWCwW5syZU5/FrhPx8fF+/a9K7VE8UDxo7PFAsaCUYoHUFcUCxYLGHgtA8aAsxYPqUXezYzAMg6SkJNasWeOdduDAAVJTU0lOTgbA6XRitVoBSE5O5vXXX6ekpITg4GBM02TNmjUMHDiwIYpfJf7Wsbi4mOnTp2MYBs8991y5fsiNjT/1a926dbmM+d/+9jcSEhK8TUsbI3+/w759+/LZZ5/hcrm8QXzXrl2cdNJJ9V/4KvCnfoWFheTn59O5c2fvssHBwXTs2JH09PR6L3ttOPoYU/ZzKC4uZsOGDVx11VUNVLrmQ/FA8aCxxwPFAsUCxYK6p1igWNDYYwEoHoDiQU3jQeNN8zYSU6dOZeXKlbzzzjts3bqVBx98kFatWjF27FgWLlzI0KFDWbFiBQCXXnopLpeL2bNns337dp5++mn27NnDlClTGrgWx1bVOjocDm6//Xb27t3Lww8/TGFhIenp6aSnp+N0Ohu6GpWqav2CgoLo3Lmzzys0NJTIyEg6dOjQ0NU4Jn/+Ti+77DKysrJ4/PHH2bFjBy+99BLbtm3j8ssvb+BaVK6q9YuKiuKkk04iJSWFlStXsmfPHt59912+/fZbzjvvvIauht+eeuopTjjhBLZs2QLAlClT2L17N8888wzbt2/noYcewjRNJk6c2MAlbR4UDxQPGns8UCxQLJC6p1igWNDYYwEoHige1CweqCXRcZxzzjnk5eUxf/585syZQ1JSEikpKYSHhxMaGkpERIT3iQXt27dn/vz5PPLII1xyySV07dqVZ555xpvRbKyqWscDBw7wxRdfAJRrYrlmzRrCw8MbovjH5c932FT5U8eePXvy4osvMm/ePFJSUujWrRuvvvqqT4a9sfGnfvPmzWPevHncc889ZGZm0rFjR+6+++5Gf0JWkbCwMCIiIggKCgJg4MCBPP300zzzzDO8/PLLJCYmMn/+fNq1a9fAJW0eFA8UDxo7xQLFAql7igWKBU2B4oHiQU0YZmN9tp2IiIiIiIiIiNQbdTcTEREREREREREliUREREREREREREkiERERERERERFBSSIREREREREREUFJIhERERERERERQUkiERERERERERFBSSIREREREREREUFJIhERERERERERQUkiEREREREREREBbA1dAJGquOKKK/jpp58qnX/vvfdy5ZVX1sq+HA4Hhw4dIiEhoVa2JyIitUfxQEREFAtE6o5hmqbZ0IUQOZ4tW7aQl5cHwKJFi3j//ff517/+Rbt27QDo1q0bsbGxtbKvu+66i59++olly5bVyvZERKT2KB6IiIhigUjdUUsiaRISExO9v3///fcA9OvXj+7duzdUkUREpAEoHoiIiGKBSN3RmEQSUEzT5LXXXmPcuHEMHTqUK664gt9++81nmZUrVzJp0iQGDRrE6aefzq233sqOHTvYtGkTiYmJfPDBB+zbt4/ExEROO+20Svf13Xffcc011zBixAiSkpIYO3Ys77//frnl0tLS+POf/8zw4cM56aSTuOmmm9i2bVuV5r///vskJiayd+9e7/I//vgjiYmJ/Pjjj95pTz31FOPGjWPz5s1MmTKFgQMHkp+fT1ZWFvfccw+jR48mOTmZESNGcO+993rvvHg4nU6ef/55xo0bx8CBAzn//PP58MMP2bp1K4mJibz66qs+y2/YsIHExEQ+/PDD438pIiINQPFA8UBERLFAsUD8p5ZEElCee+45nn/+eW677Ta6dOnCokWLuPzyy1m8eDEdO3Zk9+7dXH/99fTq1YuHHnoIgCVLlvDtt98yYcIEUlJSeP7559m0aRPz5s0jPDy80n3FxMQwbNgwLrnkEoKCgli6dCl33303PXv2JCkpCYC8vDwmTJhASEgId955J2FhYXz66afk5+dXab4/0tLSuO+++5g4cSK33HILkZGRuFwu2rZty/XXX09CQgLbt2/n6aefJiwsjPvuu8+77j//+U8WLFjAjTfeyMCBA/ntt9/YuXMnF154Id27d2fZsmVcffXV3uW/+uorgoKCOOOMM/wup4hIfVA8UDwQEVEsUCwQ/ylJJAEjPz+fl19+mcmTJ3sPWiNGjODMM89k/vz53HfffWzatAm73c6ECRMYO3YsgPcnwNChQ2nVqhUhISEMHTr0mPvr27cvffv2BcDlcnHKKafw/vvv88svv3gDwfz580lPT+f999+nX79+AIwePdq7jePN90dubi7Dhw/nsssu806zWCzMmDEDcN9JOeWUU1i3bp3PnYY9e/bwzjvvMHnyZP7yl78AcPrpp3vnjxkzhhdeeIGcnByioqIA+Prrrzn55JO970VEGhPFA8UDERHFAsUCqR51N5OAsWXLFg4fPky/fv1wOBw4HA4Mw6B///5s2rQJcB/oY2JieOqpp5g3bx47duyo9v4yMzP55z//yZlnnkn//v0ZNGgQgE+mf/Xq1bRu3dp7kD/a8eb765JLLvF5b5omixYt4qKLLmLw4MH069ePxYsXc/jwYe8yv/76K06ns9LM/5gxY3A6naxYsQJw13vdunWcffbZtVJmEZHapnigeCAioligWCDVoySRBIwDBw4AcPvtt9OvXz/va9myZaSlpQHQqlUrPvjgA84991zeeustzj33XC6//HK/A4Jpmtxyyy288847TJo0iddee4333nuv3HKpqanExcVVup3jzfdXx44dfd4vXLiQe+65h3bt2jF37lwWLlzIyJEjfZbZv38/QKXlSExMpHPnzixfvhyAb775BovFwqhRo2qt3CIitUnxQPFARESxQLFAqkfdzSRgxMfHA/B///d/nHjiiT7zgoODvb+3bduW+++/n7vvvpulS5dy//33c/vtt/PBBx9UeV979+5l9erVTJs2jeuvv/6YZSo7sJy/82vqv//9L/Hx8cybNw+bzf3vHhMTU64MANnZ2RVuwzAMzjnnHN5++23sdjtff/01J554Yq09VlREpLYpHpSneCAizY1iQXmKBVIVakkkAaNnz56EhITwxx9/kJSU5PMq+5hMl8sFuIPDueeey7Bhw9i2bZt3utVqpaioCNM0K92Xp9mo1Wr1TvM0W3U6nd5pSUlJpKamsn379gq3c7z5ISEhAGRkZHinrVq1qvIPoZJyWizuf3W73c7WrVt9yti/f3/A/WSHyowZM4bc3Fx++eUXvv32WzUnFZFGTfGg8nIqHohIc6FYUHk5FQvkWNSSSAJGTEwM06ZN4/nnnycqKooTTzyRjIwMPvzwQ2644QZOPvlkUlJSWLBgAZMmTaJDhw6sX7+eFStWcNppp3kPlj179uS9997jzTffBOCkk06iZ8+ePvvq3r07bdq04cMPP6RTp044nU7+85//kJCQwMqVK7n22muJjIzkmmuuYeHChcyYMYPp06cTFBTE4sWLmTx5MkOHDj3u/D59+mAYBi+88AKTJk3iu+++4/vvv6/yZzJ8+HBeeeUVZs+ezbBhw/jggw/IycnhwIEDrFu3juTkZHr27Mn48eP5z3/+Q0REBH369GH9+vXk5+dz5513Au6B+Dp06MDcuXPJy8ur9gB6IiL1QfGgPMUDEWluFAvKUyyQqlCSSALKX/7yF+Li4li4cCFvvPEGHTp0YNSoUd4nCpx77rns3LmTBQsWsHv3bmJiYrj00ku59dZbvdu49NJLWbVqFY899hhRUVHExsaWCwTBwcE8++yzPPjggzz88MN0796dBx54gNDQUGbOnOm98xAXF8eiRYuYPXs2Dz74IBaLhSFDhhAdHV2l+d26deO+++7j+eefZ/369QwfPpwXXnihyo+XnD59Orm5uXz88ccsW7aMsWPHMnfuXG677TY2bNhAcnIyALNnz6Z9+/a8//77pKWl0a1bN6688kpM08QwDAzDYMyYMbzyyisMGzaMVq1a1eBbEhGpe4oHvhQPRKQ5UizwpVggVWGYx2o3JyJyxNatW7ngggv4xz/+wYQJExq6OCIi0kAUD0RERLEgcClJJCLHlZuby0033URGRgb//e9/CQ0NbegiiYhIA1A8EBERxYLApoGrReSYXnnlFUaOHEl6ejpPPfWUgoCISDOleCAiIooFgU8tiUTkmL777jsKCgoYMWIEYWFhDV0cERFpIIoHIiKiWBD4lCQSERERERERERF1NxMRERERERERESWJREREREREREQEJYlERERERERERAQliUREREREREREBCWJREREREREREQEJYlERERERERERAQliUREREREREREBCWJREREREREREQEJYlERERERERERAQliUREREREREREBCWJREREREREREQEJYlERERERERERAQliUREREREREREBCWJREREREREREQEJYlERERERERERAQliUREREREREREBCWJREREREREREQEJYlEqqy4uJhnn32WMWPGMGDAAM477zzuvvtuDhw4wJ133knv3r3Jysoqt97LL79MYmIiu3btAiAxMZHbbrut3HJ33XUXiYmJFBcXl5s2ffp0n2X37t1LYmIi77//fu1WUkSkGTJNk4ULF/KnP/2JQYMGcdZZZ3HHHXewZ88e7/H23//+t3d5z7SjX8nJybhcLp/tnnnmmSQmJjJ//vxy+33//fd91h8xYgRTp05l+fLlfpV/+/btXHrppSQmJrJ3716feb/99hvTpk1j6NChTJw4kY8++sjPT0dEpPk4+rjseZ133nn1Wg6Xy0VKSgrjx49nwIABjBkzhltvvZXt27eXW7ZsTNq8ebPPvIrqUvZ19PIiALaGLoBIU/Hggw/ywQcfcOWVV3LCCSdw4MABUlJSuOOOO5g8eTIffvgh3333HePGjfNZb8WKFXTv3p0uXbpUe99ffvklu3btqtE2RESkYjNnzmTRokVcddVVXHfddWRkZPDaa6+xfPlyzjzzzErXGzduHJdffrn3fXBwMBZL6f23LVu2sG/fPmJjY1m2bBlTp06tcDt33HEHycnJZGRk8N///pcbb7yRxx57rFw8OZrD4eDVV1/lySef9Nmvx86dO7nqqqvo06cPDz/8MN988w133HEHwcHBnHPOOcf7WEREmq077riDAQMGeN+3aNGiXvf//PPPM2/ePC655BL+/Oc/k52dzaJFi7j55pv5+OOPCQ4O9i67dOlSwsLCME2TpUuX0rt3b++8lJQU7+///Oc/SU1N5dlnn/VO69atW/1USJoUJYlEqqCoqIgPP/yQcePGcdddd3mnX3LJJRQUFBAUFERwcDArVqzwOak/fPgw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c++99wKoy5nUiJJEIlXgcrlYvXp1uenbtm0DoHPnzgB069aNLl268MUXX/DTTz8xatSoWi3H6NGj6dChA/Pnzyc8PLxWty0i0hxdd911HDx4kEWLFvlMt9vt3juz/lq6dCnh4eG8+eabpKSkeF+TJk0iNTWVzZs3V7je4MGDGTt2LC+//DK7du2q1r7LGjNmDGvWrCE7Oxtwj5X3zTffkJSURPv27Wu8fRGR5saTLPKM62aaJqtWrary+gMHDsQ0Tb777jvvtJKSEn744QcGDRrkHcd01apV5W4olL3uME2TZcuWMXjwYJ84k5KSwoABA/j666/LJaJEqkrdzUSqYNmyZd5B404//XTatGnD2rVreeGFFzjttNO8XccMw+DMM8/k1VdfBah0nKHqstlsTJ06lYceekjjSYiI1IJTTz2V888/n7///e/s3r2bE044gdTUVN5991169OjBbbfd5tf27HY7X3/9NaeeeirDhg3zmRcREcGCBQtYunQpffr0qXD922+/nS+//JJ//OMfvPzyyzU61k+aNIn33nuPGTNmMHXqVL755hs2bNjAvHnzqr1NEZHmYOvWreVuyA4aNIh+/foBMHfuXM4++2w+/fRTNmzYUOXtXnjhhbz66qvcc8893HrrrcTGxrJgwQKysrJ46qmnANiwYQNTpkxh2LBhnHPOOXTq1Inff/+d559/nt69ezNq1Cjvo+6vv/56hg4d6rOPsWPH8vDDD7NmzZpycUikKtSSSKQKzjrrLF577TUcDgfPP/8806dP59NPP+WGG25g3rx5WCyl/0qjRo3CNE0GDBhAfHx8rZdlwoQJtGzZslpPWRAREV+GYTBnzhzuu+8+1qxZw1//+lfeeOMNevfuza233ur39latWkVubm6FLUl79+5N+/btvV0EKtKhQwemTZvGt99+y+eff+73/svq0qULr776KlarlbvuuosNGzYwZ84cjWsnInIcc+bMYfLkyT6voqIiTjnlFG644QaWLl3Kgw8+SFRUFLNnz67ydoODg3n77bc5/fTTee6557jrrrsoKSnhrbfe8o6B1K9fP9577z1iYmJ4/fXXufnmm3nnnXe48MILee211wgJCfHGkYoekOOJP+pyJtVlmLrSFBERERERERFp9tSSSERERERERERElCQSEREREREREREliUREREREREREBCWJpAHk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Yg4fPtycNGmSd9oPP/xg9urVy5w7d6532qZNm8xevXqZn3zySbnt7dmzx2c/Tz75pNmrVy/z8ccfr7QsLpfLtNvt5q233mqOGzfOO/366683+/TpY+bm5la6bq9evcwnn3zSZ9qePXvMXr16mYsWLTJN0zT37t1r9urVy3zxxRe9y7z00ktm7969zfT0dNM0TfOpp54y+/fvb2ZmZnqXefPNN82+ffuaBw8erHDfns+motex6vrmm2+aAwcONHv16mUOHjzYvP/++73l8JgyZYo5ZcqUcuufccYZZq9evcydO3f6TPd8zmUd/Z24XC5z1KhR5vjx402Xy1Vh+SraTmXlufPOO80zzjijSuW76667zOHDh5vFxcXeaY8++qg5bNgws6SkpMKyeMp/9OvofZbl+e6Pft1+++0++/7xxx/L/f1v3brV7NWrl/nZZ5/51PuUU04xDxw44J128803m+ecc06F+6/sb/npp582e/Xq5fO3NHbsWPP666/3vj/68/T8fb355ps+27/44ovN008/3XQ6nT51Pv30002Hw1HpZyPNj+KB4oGH4oHigTRfigWKBR6KBYoFjYVaEjVSq1atwjAMhg8f7p0WFBTEySefzPr168tlTE8++WTv756Ma1FRUZX3d8kll/i8N02TRYsWcdFFFzF48GD69evH4sWLfbLno0ePxul0cs011/DBBx+Qn5/vVx092rdvz8CBA1m2bJl32vLlyxk6dKi3KeeqVavo0KEDLVq08GakBwwYgMPhYNu2bRVut1+/frz33nu89957xMfHc+mll3rfV8YwDCZPnsyKFSv45z//SUJCAm+//Tbjx49n//79VarPsGHD6NKlS9U/gCMOHjzInj17OOOMM3yaFte2isq3atUqevfujcVi8X6+AwcOJCcnhwMHDlS4nZEjR/p8nrfccgvvvfcezz777HHLcOGFF/Lee+/x9ttv88ADD/DDDz9w0003eZvIrlq1CoA+ffp4y9OlSxdatGjBpk2bfLbVrVs3EhISvO9btGhBcXGx931V/pY9d6W++uorwN18edu2bd7pFfGU8dRTT/VOMwyDU089lf3795cbCPLiiy/WuAJSLYoHigd1RfFA8UCaDsUCxYK6oligWHA0DVxdz1q0aEF0dHSl/1weBw4coEWLFuUe+xcTE4PdbicrK6tWB0s7+tGaCxcuZObMmZx11ln85S9/ITY2lmeeeYatW7d6l7nkkkto1aoVb775Jvfccw8zZ87kT3/6E3fccQc2m39/Wueeey6PPPIImZmZGIbB6tWrue+++7zz9+/fz86dO+nXr1+5ddPS0ircZmRkJElJSYC7X2vr1q29748nMjKSiRMnMmHCBBYtWsR9993Hyy+/zMyZM4+7bocOHaq0j6N5Ak1sbGy11q+qisq3f/9+du/eXennW9GjV2NjY33K2qFDhyp/vvHx8d5lBw8eTLt27bj++ut57733+NOf/uT9LE477bQKy+OPqvwtd+/encTERJYuXcrEiRNZtmwZQUFBx2z66fkfjomJ8ZnueZ+WlubzONLq/l1I4FI8qJjigeKB4oE0J4oFFVMsUCxQLGg4ShI1gF69erFhwwbsdnu5A71HQkICeXl5OBwOn4NqZmYmQUFB5f74att///tf4uPjmTdvnnf/Fe1z5MiRjBw5krS0NF555RXmz59Phw4dfAaVq4pzzjmHhx9+mK+++gqr1eodnM4jPj4el8vFY489Vm7duvwHs1gsTJw4kX//+98+/aLrQnx8PAA5OTl1up/K9t22bVvuuuuucvO6du1a5/v3BAXPnZ/WrVsD8Nprr3nvfnn4+7df1b/lsWPHegdXXL58OaeccgotW7asdLueOxTZ2dm0aNHCOz0zMxPAJwiIVEbxoDzFA8UDUDyQ5kWxoDzFAsUCUCxoKOpu1gCuu+46Dh48yKJFi3ym2+12bzO3gQMHYpom3333nXd+SUkJP/zwA4MGDfK7aZpn+ao2M/U0D7VYLN6ybd261acpq8vl8v6ekJDAjBkzAHyaeFqt1nJPA6hImzZtGDx4MMuWLWP58uUMGzbMe2AE94Fi3759tGrViqSkJJ9XVQ4My5Yt85bvWDZs2FCuvGlpaeTk5NCpUye/6+XheXRjeno64G7m6GmS6NGmTRtatWrFypUrK92O53s8et/BwcHebYN79P+NGzdWuXxJSUls376drl27lvt8jz4QV2TLli3egfOqw5O579y5s7c84D6oHl0efwN/Vf6WwX0yUlxczGeffcbPP/98zOak4P4fBfjmm2+800zTZMWKFXTo0MEbzESORfGgPMUDxQNQPJDmRbGgPMUCxQJQLGgoaknUAE499VTOP/98/v73v7N7925OOOEEUlNTeffdd+nRowePPfYYF154Ia+++ir33HMPt956K7GxsSxYsICsrKwqPa7xaD169ADgP//5DyeddBIRERHHbC43fPhwXnnlFWbPns2wYcP44IMPvH1Q161bR58+fbjyyivp0KGDt5/sJ598Avg2A+zRowdLly4lOTmZP/74g+uuu67SfZ577rk8/vjjWK1W/vrXv/rMu+aaa3jvvfe4/vrruemmmwgPD+fXX39l+/btzJs3z/tPXhMFBQXcdNNNhISEMHHiRBITE8nMzOTll18mLCyMq6++2qdeCxYs4MMPP+TgwYNcfPHFx2zi62mqOXfuXM4++2w+/fRTNmzY4LOM1Wrl1ltv5b777uPee+/l7LPPZv/+/Xz33Xf8+9//JiQkhJ49ewLw/PPP06FDB7p27crQoUPp378/3377La+99hqtW7fmzTffLHegO5bp06ezdOlSbrzxRq666ioMw+D777/H4XDwwAMP+PEpVs3+/fv55ZdfKCkpYceOHbz00kvEx8czZswYwP03NGTIEB588EGys7Pp3LkzO3bs8D55oOxJwvEc7285OTkZgC5dutC3b18ee+wxDMM47lMGTjnlFE4++WT+/e9/43Q66dSpE4sXL2bDhg088cQTddp3XAKH4kHFFA8UDxQPpDlRLKiYYoFigWJBw1CSqAEYhsGcOXMYOHAgH3/8MQsWLCAhIYEBAwYwffp0wJ39ffvtt5kzZw7PPfcceXl59O3bl7feeosBAwb4vc9+/foxY8YM3njjDb788ksmTJhwzD/06dOnk5uby8cff8yyZcsYO3Ysc+fO5bbbbmPDhg0kJyfzt7/9jRdffJFHH32U7OxsunXrxpw5czjrrLO82/n73//Ovffeyx133EHv3r258MILK93nmDFjmD17NuAe+K6suLg4Fi1axCOPPMJDDz2E0+mkX79+3HTTTbUSBADCw8NZtGgRzz77LEuWLOHZZ58lKiqKAQMGMG/ePJ8B3W644Qa2bdvGrFmzaNOmDcnJyccMBKeccgo33HAD77zzDj/88ANnnXUWs2fPZuLEiT7LTZw4kdDQUF599VU++eQTEhISGD9+vPfOzKhRo7jssst48803CQkJ4frrr2fo0KFcc8013qDYsWNHpkyZQn5+Pm+++WaV6t6zZ0/effdd/vWvf3HPPfcQEhLCwIEDueWWW/z/IKvgf//7H//73/8IDQ2l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j70FpespeIiIAGXHJGrYcoiIiNSEWhKVUpJIRJq1ooxDFOw/eNzlirNKu5ipIZGIiJuebiYiIoHAkyTSwNU17G42evRoHnvsMdavX19b5RERaZTKJoZ69mzTcAVphBQLRJqv0mOjTqpF8UBEmq7S7mYNXJBGoEYtibp3786bb77Jyy+/TNu2bRkzZgxjxoxh4MCBtVQ8EZHGoeyoG927JzRkURodxQKRZsB+EIrSyk8vKQLAwA5FO49aR8fK5kbxQESaKqdT3c08apQkev755ykpKeGHH37g66+/5osvvuDVV1+ldevWnH322Zx99tkMGzZMH7SINHmeJFGP1iENWo7GSLFApBkw7eAqKj/ZVQKAgav8fNNeHyWTRkTxQESaqtLu0zo+1fjpZsHBwZx22mnMnDmTL7/8ksWLF3P11VezevVqpk6dyujRo3n//fdro6wiIg3HMzhrw5ai0VIsEGmeNHC1HE3xQESaIk93M41JVAtJorJ2797NN998w1dffcWWLVuwWq0MGDCAe+65h7lz59bmrkRE6pW3u5nixnEpFog0IxqTSI5B8UBEmgp1NytVo+5mLpeL1atXs2zZMpYvX86uXbuw2WyMGDGChx56iDPPPJOWLVty9tlnc9ttt3HBBRfQrVu32iq7iEi9KR2TSIHjaIoFIs2XEuhSluKBiDRVGri6VI2SRCeddBJ5eXneZqW33HILI0eOJDIy0me5MWPG0KNHD1asWKFAICJNk7pUVEqxQKT5Kh3DoYELIo2C4oGINFUul1oSedQoSXTKKacwZswYTj/9dMLDw4+57Pz582nZsmVNdici0mDM4y/SbCkWiDRfGpNIylI8EJGmypMk0phENRyT6LLLLmPkyJEVBoEPP/yQ22+/3fs+JiYGq9Vak92JiDSY0u5mcjTFApHmS8dGKUvxQESaKrUkKlWjJNG0adPYtGlThfNCQkL4+uuva7J5EZHGQ3fLK6VYINKMKUskZSgeiEhTVTomkQKa393NioqKWL9+PeDuh75p0yacTqfPMoWFhXz00UeEhobWTilFRBqYroN8KRaICJTtbqajY3OleCAigaC0JVFpbGuu/E4SFRYWcsUVV2AYBoZh8M9//rPcMqZpYrPZuP/++2ulkCIiDU1PefalWCAioAS6KB6ISGDwtCSyWAxvwqi58jtJFBMTw+uvv45pmkyd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gkjHiTk8A+zlx447Hg7+HlYmLx9p/Knq9VS/w4uLsxMXd2x3Lq2K7tan+rHyVK/fwao7FsDJd25gdR5uYP+jMOwRXWw91Y+VcBLW0eqM6DfwyVY/R4Tf7WM9Vh7t3OBIqmpokRMdD6r/DL0Kffnll8d9m/fdd98J23ZNcKrXD079Oqp+J7/ToY5VSbGgck71Oqp+J79TvY6nev2qg+JB5E71+sGpX0fV7+R3outYI25empSUhN1uJy8vr8z03Nxc6tatW275OnXqkJubW27ZevXqnchiiojICaZ4ICIiigUiItWnRiSJDMOgTZs2LFu2LDwtMzOTnTt3hgebCxzUD7Ft27b88ssveL2h0flN02TZsmUamE5E5CSneCAiIooFIiLVp0YkiQBuvvlmFi9ezNtvv8369esZP348ycnJ9O3blzlz5tCxY0e+/fZbAAYMGEAwGGTChAls3LiRqVOnsm3bNgYPHlzNtRARkWOleCAiIooFIiLVo8YkiXr37s348eN54403GDhwIEVFRcyaNYvo6GhcLhcxMTE4HKFBq1JSUpg5cyZr1qzh2muvZeHChbz44ou6WiAicgpQPBAREcUCEZHqUaMGrr7uuuu47rrryk2/4ooruOKKK8pMa9++PbNnz66qoomISBVSPBAREcUCEZGqV2NaEomIiIiIiIiISPUxTNM0q7sQIiIiIiIiIiJSvdSSSERERERERERElCQSEREREREREREliUREREREREREBCWJREREREREREQEJYlERERERERERAQliUREREREREREBCWJKmTOnDlcccUVdOzYkaFDh7J169bDLrtixQoGDRpEhw4d6N+/P19//XXVFfQYVLSOy5YtY+jQoZx77rlcfPHFPPPMM3g8nioubeQi+QwBfvrpJ0aOHInP56uiEh67SOpYUFDA2LFjufDCC+ncuTMPPfQQpmlWYWkjV9H6BYNBpk2bRs+ePWnbti1XXXUVH3/8cRWXtnIWLlxIz5496dGjx2GX+eqrr+jfvz8dOnRg0KBBrFy5sgpLKIoHByge1EyKBSGKBXIiKRYcoFhQcykehCgeVIIpR7RgwQIzPT3dfOutt8y1a9eaI0aMMLt27WoWFRWVW3b79u1m27Ztzccee8zcsGGDOWnSJLNly5bmihUrqqHkFVfROmZlZZldunQxp02bZq5bt858++23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9PSgeKB4UNMpFigWyImnWKBYcDJQPFA8OBaGWVPvbSciIiIiIiIiIlVG3c1ERERERERERERJIhERERERERERUZJIRERERERERERQkkhERERERERERFCSSEREREREREREUJJIRERERERERERQkkhERERERERERFCSSEREREREREREAFt1F0CkIm666SaWLFly2PkPP/wwQ4YMOS778vv97N27l3r16h2X7YmIyPGjeCAiIooFIieOYZqmWd2FEDmatWvXkp+fD8C7777LvHnz+Nvf/kbDhg0BaNq0KbVq1Tou+3rooYdYsmQJX3311XHZnoiIHD+KByIiolggcuKoJZGcFNLT08N/f//99wC0atWKtLS06iqSiIhUA8UDERFRLBA5cTQmkZxSTNPktdde4/LLL6djx47cdNNN/PLLL2WWWbx4MQMHDiQjI4OLLrqI++67j02bNrF69WrS09N577332LFjB+np6Vx44YWH3dd3333HsGHD6NatG23atKFv377Mmzev3HK7d+/mnnvuoWvXrpx33nnccccdbNiwoULz582bR3p6Otu3bw8v/8MPP5Cens4PP/wQnjZlyhQuv/xy1qxZw+DBg2nfvj0FBQXk5OQwduxYLr30Utq2bUu3bt14+OGHw1deSgUCAaZNm8bll19O+/btufLKK5k/fz7r168nPT2dV199tczyv/76K+np6cyfP//oH4qISDVQPFA8EBFRLFAskMipJZGcUl566SWmTZvG/fffz5lnnsm7777LoEGD+Pjjj2nUqBFbt25l+PDhtGjRgieffBKATz75hEWLFtG/f39mzZrFtGnTWL16NZMmTSI6Ovqw+0pKSqJTp05ce+212O12vvzyS8aMGUPz5s1p06YNAPn5+fTv3x+n08mDDz5IVFQUCxYsoKCgoELzI7F7924eeeQRrrvuOv7yl78QGxtLMBikQYMGDB8+nHr16rFx40amTp1KVFQUjzzySHjdJ554gtmzZzNixAjat2/PL7/8wubNm+nXrx9paWl89dVX3HrrreHlv/76a+x2O927d4+4nCIiVUHxQPFARESxQLFAIqckkZwyCgoKmD59OjfeeGP4oNWtWzd69OjBzJkzeeSRR1i9ejU+n4/+/fvTt29fgPAzQMeOHUlOTsbpdNKxY8cj7u/ss8/m7LPPBiAYDHL++eczb948fvrp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NjUaFRGRmq00VpXGLhERqR5KEomInOLUbF9ERGo6xSoRkZpBSSIREZEqkJubyy+//FLdxRCJSGFhIW63u7qLISc5j8dDQUFBdRdDREQqQEkiEZHTkBkMnjb7XbNmDd26dWPOnDkVWt7r9XLZZZcxduzY41qON954g3vuuee4brOyTNM8rfYrlffpp5/Srl276i4GAMFg9Xx/qmu/p5Lly5dzzjnnsH379uouioiIHIUGqhAROQ0ZFgsb3/0I9569VbZPV3Jt0vpfVun1c3Nzef7551myZAm7d++mWbNmXH311QwaNOiI3RSio6Np1KgRtWrVqtB+LBYLjRo1omHDhpUua01nGAZm/o/gz6+6ndriMOI6VWrVKVOmMHXqVAAcDgf169fnoosuYsSIESfNnfsmT57Mpk2beOGFF074vrKysrjlllt44okn6NChwwnfX1WxWAz++9815OUVVdk+ExKiufDCsyq9vtvt5qWXXuKrr75i27ZtpKSk0LVrV0aMGFHhY1J1uuKKK7jjjjvo27dvdRdFRESqiJJEIiKnKfeevRTtyqruYlRITk4O/fr1IyUlhXHjxlGvXj2WLl3KM888wy+//MKECRMOu27jxo156623DjkvGAySk5NDVlYW3333HU2bNqVHjx5MmzbtRFWl5vDnQyC3uksRkW+++YZAIMCmTZt44oknWL58Oe+88w4WS81vGL1z50727q2apKzX62Xjxo34fL4q2V9VyssrYt++k6PbktvtZsCAAfj9fkaPHk1aWho7duzg/fffZ8eOHSdFkmjdunXqbigicpqp+b+qRETktDd16lS8Xi8zZszgvPPOo0mTJvTv358nn3ySd999l2XLlgHQo0cP5s+fz5gxY+jYsSOLFy9m+/btpKen88MPP4S398UXX3D11VeTkZHB+eefz+jRo9m0aRPFxcXh7UyZMiW8/JQpUxg6dChffPEF/fv3p0OHDtxzzz0UFR1o0TBnzhxuu+02unTpQufOnfnrX//K/v37q+gdOj0kJyeTkpLCBRdcwJ133smqVav4/fffAfj++++59tprycjI4Morr+Tjjz8us+7+/fsZM2YM3bp149xzz+XOO+9k27ZtAAQCAV5++WX69u1LRkYGAwcO5H//+1+Z9W+66SZeeuklpk2bxqWXXkrnzp3DrZsg1JVuxowZ9OzZk3bt2nHFFVfw2muv4ff7SU9P57333mPJkiWkp6czbtw4gPB3c+XKlQwZMoSMjAyKioqYN28e6enp5fb/0EMPlZn2xRdfcM0119C+fXt69erFrFmzmDJlCj179gRgyJAhpKenh5NTfr+fiRMn0qNHDzp37swdd9wRfg9KLV26lOuuu44OHTowZMgQNmzYUJmPSoAXX3yR7du3M3PmTLp3707jxo3p0qULTz/9NG3atAGguLiYxx9/nG7dutGtWzdGjx5dJpk4b948evXqxdKlS7nhhhvIyMjg1ltvJTs7u8y+PvroI6688koyMjIYMGAA33//fZn56enpfPvtt9x5551kZGSwefNm1q9fz8iRI+nbty/t2rXjmmuu4ccffwzvt/Q7OGbMmPD3FELf9ZkzZ9K7d2/OOecchgwZwurVq8vsb+PGjdx000106NCB6667jp9//vn4vrkiInLCKEkkIiI13qeffkqfPn2IiooqM71nz57ExMSwcOHC8LTJkyfTuHFj5s2bR8eOHctta9WqVdx999306dOHn376ienTp7N9+3Z69+7NZZcdvjvcihUrePPNN3nooYf4+9//zmeffcbs2bPD85s2bcrAgQOZNWsWTz31FN9///3p0SKpmlitViB0kr127VqGDx/O4MGDef/99xkyZAijRo3ip59+AkIntbfffjvLly/nhRde4N///jdt2rQhLi4OCH1nXn75Ze69917mzp1LRkYGt9xyS7mBxl977TV27drFpEmTGDx4MFOmTAkv89lnn/Hss88yYMAA3n//fUaNGkVOTg5Wq5VFixbRp08fMjIyWLRoEaNGjSqz3QcffJAhQ4bw4YcfEh0dXaH6f/fdd/zlL3+hR48evPfee4wZM4a4uDiGDh0aHn9rypQpLFq0KNxiZeLEiSxcuJAXXniBWbNm4XA4GD58eLjFUWZmJrfccguNGzfmnXfe4eabby6XbJOK+/jjj+nduzd16tQ57DJjxoxhy5YtzJgxg5dffpnMzExGjRpVZvyuHTt28MwzzzBixAhefvllVq1aVebY8s033/Doo49y3333MX/+fC655BL+/Oc/l0sAPv744/To0YP333+f1NRU6tSpQ9euXXn22Wd58803adiwIffeey/BYJC+ffuyaNEiAMaOHcuiRYs4++yzAXjrrbd45ZVXGDduHHPnzqVFixbceuut4aR4UVERQ4YMwWKx8O9//5u//vWvfPLJJ8ftfRURkRNL3c1ERKRGKygoIDs7mzPOOKPcPIvFQkpKCps3bw5Ps1qt3H777YftgvTzzz8TDAa58sorsdvtXHDBBdSpU4e5c+dy4YUXHrYcNpuNqVOnEhsbC8BZZ51VppXFOeecE/67adOmnH/++eWursuxM02Tbdu28corr3DmmWfSrFkzHnvsMTp16kS/fv2AUBfDBQsWMH/+fDp27MiPP/7I0qVLmT59ejhx2KxZMyCUZHr11VcZNmwYvXr1AmD06NF8/vnnvPLKKzz//PPhfbdq1Ypx48ZhGAaNGjVi6tSpbNiwgdatW4dbdrRt25YzzzyTM888k4suugiAOnXq4HK5sNvth0wYZGRkcMkll0T0PkybNo327dtz1113AdCkSZPwvNKkUEJCQnh/xcXFvPnmmzzxxBO0bdsWgEceeYRu3bqxcuVKzjnnHN566y0sFgv/93//R2xsLM2aNSM3N/e4D+J+OigsLGT79u0MHDgwPO3uu+8OJ17at2/P+PHjWbBgAW+99Va41c7IkSO5/vrrycrKol69egD4fD4mT54cft25c+cyx57p06dz2WWX0aNHDwCGDx/OvHnz+M9//sMdd9wRXq5Ro0Zce+214deJiYlcc8014dcDBw7k888/Jzs7m3r16uFyuQCIi4sr872dPn06gwYN4rzzzgPgoYceYu7cuXz99ddceeWVfPTRR+zZs4fZs2fTqFEjIJRouvnmm4/1bRURkSqgJJGIiNRokd4Rq1evXkcco6ZTp05YrVbmz5/PsGHDWLRoEb///ns4QXA4MTEx4QQRhE6cggfdrW3lypX84x//YO3ateTm5uLxeMokjuTYdezYkUAggNfrpWfPnjz88MPY7XbWrl3LmjVryMjICC/r8Xjo3LkzEBpXBaB169bltrl161Y8Hk+4lQSEko9nnXUW69evL7Ns3bp1w4Okl7ZCKv0O9OvXj59++olhw4bRoUMHbrjhBi655BIcDsdR69W7d+9I3oZwnS6//PIKL79t2zbcbjdjx47lscceAw78b+3YsYNzzjmHjRs30rhx4zLf8yMNCi+HV/q9sNvt4WmPP/44hYWFjBo1CrfbHU703HrrreFjVul627dvDyeFgDJ/x8XFlenKum7dOpYuXcp//vOf8LTi4mJ27NhRpkx//J7l5+fzj3/8g2+++YasrCy8Xi/AEceyKigoYMeOHUydOpV//vOfh9zfhg0biI2NDSeIQN8jEZGTiZJEIiJSo8XFxZGcnFzuhAdCJ1Q7duyge/fu4WlOp/OI22vVqhUTJkzgwQcfDN9pqlevXmWuuEdq9+7d3HLLLbRr144HHniAFi1aMHHiRPLy8iq9TSnv3XffJTs7m9tuu43zzjuPlJQUIDTWTpcuXcLJj1KlLSH8fj9AxANcR3JiGxsbywsvvMC2bduYPXs2TzzxBC+88AJz5swhISHhiOse7Tt7KIFAIKLylb4Hjz76aDh5Vqp27drhZXQyf3zExcWRlJTErl27wtOSk5NJTk7G5XLh9/vDn8nkyZM588wzy6x/cFLoaPx+P/369WP48OFlph+c7IPy37OxY8eyZMkS7rnnHtq1a8emTZsYPXr0EfcVCASAUGulq666qsy80u95pN9NERGpWZQkEhGRGq979+4sWLCAkSNHlhmz5csvv6SwsDDczaKiXn31Vf7yl78waNAg4uLiwsmEylq+fDmFhYXcf//94a48Tqcz4lZQcmSpqamkpaUxfPhw/v73v3PBBRfQpEkT0tLSWLZsGQ0bNizTcqNUWloaAGvWrCmXIGncuDF2u501a9Zw6aWXAqHk45o1a2jfvn3EZWzUqBGjR4+mZ8+eDBo0iB9//DHclezglmdHUprMKi4uJioqikAgQG5ubjgpVlqntWvXHnE7B+8vNTUVq9XKtm3bGDBgwCGXP/PMM1myZAlutzv8P1HaukQi161bNz755BNGjRp1yO9l06ZNAdi1a1e4a2JlpKWlsWHDBho3bhxRcmbRokX069ePG2+8EYDc3FygfOvNg79HCQkJJCcns2XLFlJTUw+53dTUVPLz88nMzKR+/fqAvkciIicTDVwtIiI13v33349hGPz5z39myZIlbNmyhffee49HHnmEAQMGRHQyHwwG2bx5M3v27MHn81FYWFjhk/fDady4MRC6w9n69et58803+eabb9iyZUu4NZHL5SI/P58tW7Yc074ERowYQUpKCg899BB+v59bb72VXbt2MW7cODZt2sTy5cvDAwIDnH/++bRs2ZIJEyawYsUK1q9fz0svvUROTg7R0dEMHjyY119/nS+++IJNmzbx3HPPsXPnTv785z9XuEzvvPMOzz//PL/88gtr1qzh/fffx2KxhBMBDRo0YN26daxcuZKFCxceMYFY2qrk7bffZv369Tz88MNkZWWVWWbYsGEsWbKEGTNmsHXrVr7++mvmz58PhMZAstvtfPnll6xatYr169cTExPDoEGDeOONN/jwww/ZunUrCxYsYNy4ceGyXHvttRQVFTFhwgQ2btzIRx99xEsvvVTh90DKuv/++ykoKODOO+/k559/Ztu2bXz55ZfhO/KlpaXRvXt3Jk+ezNdff82WLVuYO3cuEydOjGg/w4YNY/ny5UyaNIktW7bwww8/hAdOP5LGjRuzaNEili1bxvfffx8ef2vVqlXhZRo0aMB///tfVq9eHb672bBhw/j4449588032bp1K9988w0PPvggHo8HgMsuu4zo6GjGjx/Phg0bWLhwIU8//XREdRIRkeqjlkQiIqcpV3Ltk2Z/tWvX5oMPPuC5557j4YcfZs+ePaSlpXHvvfcyaNCgiLZlsVgYO3YskydP5u233w6VzeVi0KBBPPDAAxF3SQJo2bIlY8eOZfr06Xz22WdceOGFfPjhh9xzzz389ttvdOnShT59+rBw4UIGDRrE/PnzI+pOckLY4k7a/TkcDp588kkGDRrEjBkzuP3225kxYwYvvPAC/fv3p3bt2lx88cXEx8cDocHMp0+fzlNPPcUdd9xBIBCgY8eO5Ofnk5SUxKhRo4iNjeVvf/sbWVlZnHXWWbz++uvlbkN/JK1atWLhwoXMnz+fvLw80tLSmDp1ajhJNHjwYH766ScGDx5MamoqLVu2POy22rVrx9ChQ5k6dSpvvfUWgwcPxuFwlGmN8ac//YnnnnuOl19+mcmTJ9OwYcNwixCn08mjjz7KxIkTw2NvNW/enAcffJDY2FgmTZrE3r17adq0KTfddBOmaWIYBs2aNWPq1Km88MILLFiwgC5dujBmzBjuvffeynxMJ0RCQsXu/lYT9peSksIHH3zAs88+y8iRI9m3bx8NGjSgU6dO3HDDDQA899xz/O1vf2PcuHHk5+eTnp5ertvY0fTq1YvnnnuOf/3rX7z66qs0aNCAPn36HHU8rKeffppHH32UW2+9laZNmzJu3Di+/PJL/ve//9G3b18g1D1x/Pjx3HDDDVx55ZW0bduWW265BYvFwqxZs/jb3/5G48aN6d+/f7gVU61atZgxYwZPPPEE119/Pe3atePRRx/VwNUiIicJw1RbeBGRU5Lb7Wbz5s00adKkXHcqMxjEqEQy5FhV134P9vvvv5OYmBhOIBQVFfH555/zwAMPMH36dC644IJqLV9VKE0KnC77lVNDMGhisVT996e69nu6OVLMEhGRqqOWRCIip6HqStRUd4II4OGHHyYuLo7bbruNlJQU9u3bF+6WUTqA76muuhI1ShDJsaiuRI0SRCIicjpRkkhERE4r48aN45lnnuHOO+9k//79xMXFkZaWxuTJk8vcBl1ERERE5HSjJJGIiJxW0tLSePnll6u7GCIiIiIiNU71t/sXEREREREREZFqpySRiIiIiIiIiIgoSSQicqrTTSxFRKSmU6wSEakZlCQSETlF2e12IHSLdxERkZqsNFaVxi4REakeGrhaROQUZbVaSUxMJCsrC4Do6GjdglxERGoU0zQpKioiKyuLxMRErFZrdRdJROS0Zphq2ykicsoyTZPMzExyc3OruygiIiKHlZiYSP369XUxQ0SkmilJJCJyGggEAvh8vuouhoiISDl2u10tiEREaggliURERERERERERANXi4iIiIiIiIiIkkQiIiIiIiIiIoKSRCIiIiIiIiIigpJEIiIiIiIiIiKCkkQiIiIiIiIiIoKSRCIiIiIiIiIigpJEIiIiIiIiIiIC/H9dVrwCWfp9WQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1400x600 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "_, axs = plt.subplots(2, 3, figsize=(14, 6))\n",
    "\n",
    "for d, ds in enumerate(DATASETS):\n",
    "    ds_label = DATASET_LABELS[ds]\n",
    "    df_zoo_acc = zoo_acc[zoo_acc['Model zoo'] == ds_label]\n",
    "    df_generative = gen_acc[gen_acc['Model zoo'] == ds_label]\n",
    "\n",
    "    label = 'Contrastive + Structure (Baseline)'\n",
    "    sns.histplot(df_zoo_acc[df_zoo_acc['Hyper-representation model'] == label], x='Original accuracy', stat='probability', binwidth=0.05, binrange=(0., 1.), kde=True, color=COLOURS[0], alpha=0.5, label='Original', ax=axs[0][d])\n",
    "    sns.histplot(df_zoo_acc[df_zoo_acc['Hyper-representation model'] == label], x='Reconstruction accuracy', stat='probability', binwidth=0.05, binrange=(0., 1.), kde=True, color=COLOURS[1], alpha=0.5, label='Reconstructed', ax=axs[0][d])\n",
    "    sns.histplot(\n",
    "        df_generative[(df_generative['Hyper-representation model'] == label) & (df_generative['Origin'] == 'Generated')],\n",
    "        x='Accuracy',\n",
    "        stat='probability',\n",
    "        binwidth=0.05,\n",
    "        binrange=(0., 1.),\n",
    "        kde=True,\n",
    "        color=COLOURS[2],\n",
    "        alpha=0.5,\n",
    "        label='Generated',\n",
    "        ax=axs[0][d]\n",
    "    )\n",
    "    axs[0][d].set(title=f\"{ds_label}\\n{label}\", xlabel='Test accuracy', ylabel='Probability', ylim=(0, 1))\n",
    "    \n",
    "    label = 'Contrastive + Structure + Behavior'\n",
    "    sns.histplot(df_zoo_acc[df_zoo_acc['Hyper-representation model'] == label], x='Original accuracy', stat='probability', binwidth=0.05, binrange=(0., 1.), kde=True, color=COLOURS[0], alpha=0.5, label='Original', ax=axs[1][d])\n",
    "    sns.histplot(df_zoo_acc[df_zoo_acc['Hyper-representation model'] == label], x='Reconstruction accuracy', stat='probability', binwidth=0.05, binrange=(0., 1.), kde=True, color=COLOURS[1], alpha=0.5, label='Reconstructed', ax=axs[1][d])\n",
    "    sns.histplot(\n",
    "        df_generative[(df_generative['Hyper-representation model'] == label) & (df_generative['Origin'] == 'Generated')],\n",
    "        x='Accuracy',\n",
    "        stat='probability',\n",
    "        binwidth=0.05,\n",
    "        binrange=(0., 1.),\n",
    "        kde=True,\n",
    "        color=COLOURS[2],\n",
    "        alpha=0.5,\n",
    "        label='Generated',\n",
    "        ax=axs[1][d]\n",
    "    )\n",
    "    axs[1][d].set(title=f\"{ds_label}\\n{label}\", xlabel='Test accuracy', ylabel='Probability', ylim=(0, 1))\n",
    "    \n",
    "plt.legend(loc=(-1.50, -0.50), ncols=3)\n",
    "plt.subplots_adjust(hspace=0.6, wspace=0.25)\n",
    "plt.savefig('figures/generative_dstk.png', dpi=300, bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "15dd738e",
   "metadata": {},
   "source": [
    "### Analysing generated models' diversity\n",
    "\n",
    "#### Structure"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "56709da1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llll}\n",
      "Model zoo & SVHN & CIFAR-10 & EuroSAT \\\\\n",
      "Losses &  &  &  \\\\\n",
      "Model zoo & 23.3 (±4) & 22.9 (±4) & 23.0 (±5) \\\\\n",
      "Contrastive + Structure (Baseline) & 13.4 (±3) & 14.9 (±4) & 16.8 (±5) \\\\\n",
      "Behavior & 1.6 (±0) & 3.5 (±1) & 6.3 (±1) \\\\\n",
      "Contrastive + Behavior & 1.7 (±0) & 1.5 (±0) & 3.0 (±1) \\\\\n",
      "Structure + Behavior & 1.6 (±0) & 1.5 (±0) & 2.8 (±1) \\\\\n",
      "Contrastive + Structure + Behavior & 1.5 (±0) & 1.3 (±0) & 2.1 (±1) \\\\\n",
      "\\end{tabular}\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style type=\"text/css\">\n",
       "</style>\n",
       "<table id=\"T_d5246\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th class=\"index_name level0\" >Model zoo</th>\n",
       "      <th id=\"T_d5246_level0_col0\" class=\"col_heading level0 col0\" >SVHN</th>\n",
       "      <th id=\"T_d5246_level0_col1\" class=\"col_heading level0 col1\" >CIFAR-10</th>\n",
       "      <th id=\"T_d5246_level0_col2\" class=\"col_heading level0 col2\" >EuroSAT</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th class=\"index_name level0\" >Losses</th>\n",
       "      <th class=\"blank col0\" >&nbsp;</th>\n",
       "      <th class=\"blank col1\" >&nbsp;</th>\n",
       "      <th class=\"blank col2\" >&nbsp;</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th id=\"T_d5246_level0_row0\" class=\"row_heading level0 row0\" >Model zoo</th>\n",
       "      <td id=\"T_d5246_row0_col0\" class=\"data row0 col0\" >23.3 (±4)</td>\n",
       "      <td id=\"T_d5246_row0_col1\" class=\"data row0 col1\" >22.9 (±4)</td>\n",
       "      <td id=\"T_d5246_row0_col2\" class=\"data row0 col2\" >23.0 (±5)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_d5246_level0_row1\" class=\"row_heading level0 row1\" >Contrastive + Structure (Baseline)</th>\n",
       "      <td id=\"T_d5246_row1_col0\" class=\"data row1 col0\" >13.4 (±3)</td>\n",
       "      <td id=\"T_d5246_row1_col1\" class=\"data row1 col1\" >14.9 (±4)</td>\n",
       "      <td id=\"T_d5246_row1_col2\" class=\"data row1 col2\" >16.8 (±5)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_d5246_level0_row2\" class=\"row_heading level0 row2\" >Behavior</th>\n",
       "      <td id=\"T_d5246_row2_col0\" class=\"data row2 col0\" >1.6 (±0)</td>\n",
       "      <td id=\"T_d5246_row2_col1\" class=\"data row2 col1\" >3.5 (±1)</td>\n",
       "      <td id=\"T_d5246_row2_col2\" class=\"data row2 col2\" >6.3 (±1)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_d5246_level0_row3\" class=\"row_heading level0 row3\" >Contrastive + Behavior</th>\n",
       "      <td id=\"T_d5246_row3_col0\" class=\"data row3 col0\" >1.7 (±0)</td>\n",
       "      <td id=\"T_d5246_row3_col1\" class=\"data row3 col1\" >1.5 (±0)</td>\n",
       "      <td id=\"T_d5246_row3_col2\" class=\"data row3 col2\" >3.0 (±1)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_d5246_level0_row4\" class=\"row_heading level0 row4\" >Structure + Behavior</th>\n",
       "      <td id=\"T_d5246_row4_col0\" class=\"data row4 col0\" >1.6 (±0)</td>\n",
       "      <td id=\"T_d5246_row4_col1\" class=\"data row4 col1\" >1.5 (±0)</td>\n",
       "      <td id=\"T_d5246_row4_col2\" class=\"data row4 col2\" >2.8 (±1)</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_d5246_level0_row5\" class=\"row_heading level0 row5\" >Contrastive + Structure + Behavior</th>\n",
       "      <td id=\"T_d5246_row5_col0\" class=\"data row5 col0\" >1.5 (±0)</td>\n",
       "      <td id=\"T_d5246_row5_col1\" class=\"data row5 col1\" >1.3 (±0)</td>\n",
       "      <td id=\"T_d5246_row5_col2\" class=\"data row5 col2\" >2.1 (±1)</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n"
      ],
      "text/plain": [
       "<pandas.io.formats.style.Styler at 0x7f7c51875cc0>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_div_str = pd.DataFrame(columns=['Losses', 'Model zoo', 'Average', 'Standard deviation'])\n",
    "\n",
    "for ds, data in gen_diversity.items():\n",
    "    for hr, dist in data.items():\n",
    "        df_div_str.loc[len(df_div_str)] = (hr, DATASET_LABELS[ds], np.mean(dist['l2_structure']), np.std(dist['l2_structure']))\n",
    "        \n",
    "df_div_str['print'] = df_div_str['Average'].map(lambda x: f\"{x:.1f}\") + df_div_str['Standard deviation'].map(lambda x: f\" (±{x:.0f})\")\n",
    "df_div_str = df_div_str.pivot(index='Losses', columns='Model zoo', values='print')\n",
    "df_div_str = df_div_str.loc[['Model zoo'] + HR_ORDER, DS_ORDER]\n",
    "df_div_str = df_div_str.style.format(precision=3)\n",
    "print(df_div_str.to_latex())\n",
    "df_div_str"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a6d703bc",
   "metadata": {},
   "source": [
    "#### Behavior"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dd4f759b",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_div_str = pd.DataFrame(columns=['Losses', 'Model zoo', 'Average', 'Standard deviation'])\n",
    "\n",
    "for ds, data in gen_diversity.items():\n",
    "    for hr, dist in data.items():\n",
    "        df_div_str.loc[len(df_div_str)] = (hr, DATASET_LABELS[ds], np.mean(dist['l2_behaviour']), np.std(dist['l2_behaviour']))\n",
    "        \n",
    "df_div_str['print'] = df_div_str['Average'].map(lambda x: f\"{x:.1f}\") + df_div_str['Standard deviation'].map(lambda x: f\" (±{x:.0f})\")\n",
    "df_div_str = df_div_str.pivot(index='Losses', columns='Model zoo', values='print')\n",
    "df_div_str = df_div_str.loc[['Model zoo'] + HR_ORDER, DS_ORDER]\n",
    "df_div_str = df_div_str.style.format(precision=3)\n",
    "print(df_div_str.to_latex())\n",
    "df_div_str"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "78b340f3",
   "metadata": {},
   "source": [
    "### Examining the maximum performance of models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "d566b250",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\\begin{tabular}{llrrrrr}\n",
      " &  & Zoo accuracy & Reconstruction accuracy & $\\Delta_{Acc}$ Reconstruction & Generation accuracy & $\\Delta_{Acc}$ Generation \\\\\n",
      "Model zoo & Hyper-representation model &  &  &  &  &  \\\\\n",
      "\\multirow[c]{2}{*}{SVHN} & Contrastive + Structure (Baseline) & 91.0% & 74.5% & -16.5% & 61.3% & -29.7% \\\\\n",
      " & Contrastive + Structure + Behavior & 91.0% & 90.4% & -0.6% & 90.4% & -0.6% \\\\\n",
      "\\multirow[c]{2}{*}{CIFAR-10} & Contrastive + Structure (Baseline) & 70.1% & 51.2% & -18.9% & 46.0% & -24.1% \\\\\n",
      " & Contrastive + Structure + Behavior & 70.1% & 69.5% & -0.6% & 69.5% & -0.6% \\\\\n",
      "\\multirow[c]{2}{*}{EuroSAT} & Contrastive + Structure (Baseline) & 88.5% & 68.6% & -19.9% & 56.5% & -32.0% \\\\\n",
      " & Contrastive + Structure + Behavior & 88.5% & 87.7% & -0.8% & 87.5% & -1.0% \\\\\n",
      "\\end{tabular}\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style type=\"text/css\">\n",
       "</style>\n",
       "<table id=\"T_b716f\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th class=\"blank\" >&nbsp;</th>\n",
       "      <th class=\"blank level0\" >&nbsp;</th>\n",
       "      <th id=\"T_b716f_level0_col0\" class=\"col_heading level0 col0\" >Zoo accuracy</th>\n",
       "      <th id=\"T_b716f_level0_col1\" class=\"col_heading level0 col1\" >Reconstruction accuracy</th>\n",
       "      <th id=\"T_b716f_level0_col2\" class=\"col_heading level0 col2\" >$\\Delta_{Acc}$ Reconstruction</th>\n",
       "      <th id=\"T_b716f_level0_col3\" class=\"col_heading level0 col3\" >Generation accuracy</th>\n",
       "      <th id=\"T_b716f_level0_col4\" class=\"col_heading level0 col4\" >$\\Delta_{Acc}$ Generation</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th class=\"index_name level0\" >Model zoo</th>\n",
       "      <th class=\"index_name level1\" >Hyper-representation model</th>\n",
       "      <th class=\"blank col0\" >&nbsp;</th>\n",
       "      <th class=\"blank col1\" >&nbsp;</th>\n",
       "      <th class=\"blank col2\" >&nbsp;</th>\n",
       "      <th class=\"blank col3\" >&nbsp;</th>\n",
       "      <th class=\"blank col4\" >&nbsp;</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th id=\"T_b716f_level0_row0\" class=\"row_heading level0 row0\" rowspan=\"2\">SVHN</th>\n",
       "      <th id=\"T_b716f_level1_row0\" class=\"row_heading level1 row0\" >Contrastive + Structure (Baseline)</th>\n",
       "      <td id=\"T_b716f_row0_col0\" class=\"data row0 col0\" >91.0%</td>\n",
       "      <td id=\"T_b716f_row0_col1\" class=\"data row0 col1\" >74.5%</td>\n",
       "      <td id=\"T_b716f_row0_col2\" class=\"data row0 col2\" >-16.5%</td>\n",
       "      <td id=\"T_b716f_row0_col3\" class=\"data row0 col3\" >61.3%</td>\n",
       "      <td id=\"T_b716f_row0_col4\" class=\"data row0 col4\" >-29.7%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_b716f_level1_row1\" class=\"row_heading level1 row1\" >Contrastive + Structure + Behavior</th>\n",
       "      <td id=\"T_b716f_row1_col0\" class=\"data row1 col0\" >91.0%</td>\n",
       "      <td id=\"T_b716f_row1_col1\" class=\"data row1 col1\" >90.4%</td>\n",
       "      <td id=\"T_b716f_row1_col2\" class=\"data row1 col2\" >-0.6%</td>\n",
       "      <td id=\"T_b716f_row1_col3\" class=\"data row1 col3\" >90.4%</td>\n",
       "      <td id=\"T_b716f_row1_col4\" class=\"data row1 col4\" >-0.6%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_b716f_level0_row2\" class=\"row_heading level0 row2\" rowspan=\"2\">CIFAR-10</th>\n",
       "      <th id=\"T_b716f_level1_row2\" class=\"row_heading level1 row2\" >Contrastive + Structure (Baseline)</th>\n",
       "      <td id=\"T_b716f_row2_col0\" class=\"data row2 col0\" >70.1%</td>\n",
       "      <td id=\"T_b716f_row2_col1\" class=\"data row2 col1\" >51.2%</td>\n",
       "      <td id=\"T_b716f_row2_col2\" class=\"data row2 col2\" >-18.9%</td>\n",
       "      <td id=\"T_b716f_row2_col3\" class=\"data row2 col3\" >46.0%</td>\n",
       "      <td id=\"T_b716f_row2_col4\" class=\"data row2 col4\" >-24.1%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_b716f_level1_row3\" class=\"row_heading level1 row3\" >Contrastive + Structure + Behavior</th>\n",
       "      <td id=\"T_b716f_row3_col0\" class=\"data row3 col0\" >70.1%</td>\n",
       "      <td id=\"T_b716f_row3_col1\" class=\"data row3 col1\" >69.5%</td>\n",
       "      <td id=\"T_b716f_row3_col2\" class=\"data row3 col2\" >-0.6%</td>\n",
       "      <td id=\"T_b716f_row3_col3\" class=\"data row3 col3\" >69.5%</td>\n",
       "      <td id=\"T_b716f_row3_col4\" class=\"data row3 col4\" >-0.6%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_b716f_level0_row4\" class=\"row_heading level0 row4\" rowspan=\"2\">EuroSAT</th>\n",
       "      <th id=\"T_b716f_level1_row4\" class=\"row_heading level1 row4\" >Contrastive + Structure (Baseline)</th>\n",
       "      <td id=\"T_b716f_row4_col0\" class=\"data row4 col0\" >88.5%</td>\n",
       "      <td id=\"T_b716f_row4_col1\" class=\"data row4 col1\" >68.6%</td>\n",
       "      <td id=\"T_b716f_row4_col2\" class=\"data row4 col2\" >-19.9%</td>\n",
       "      <td id=\"T_b716f_row4_col3\" class=\"data row4 col3\" >56.5%</td>\n",
       "      <td id=\"T_b716f_row4_col4\" class=\"data row4 col4\" >-32.0%</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th id=\"T_b716f_level1_row5\" class=\"row_heading level1 row5\" >Contrastive + Structure + Behavior</th>\n",
       "      <td id=\"T_b716f_row5_col0\" class=\"data row5 col0\" >88.5%</td>\n",
       "      <td id=\"T_b716f_row5_col1\" class=\"data row5 col1\" >87.7%</td>\n",
       "      <td id=\"T_b716f_row5_col2\" class=\"data row5 col2\" >-0.8%</td>\n",
       "      <td id=\"T_b716f_row5_col3\" class=\"data row5 col3\" >87.5%</td>\n",
       "      <td id=\"T_b716f_row5_col4\" class=\"data row5 col4\" >-1.0%</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n"
      ],
      "text/plain": [
       "<pandas.io.formats.style.Styler at 0x7f7c75e409d0>"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "max_acc = zoo_acc.groupby(['Model zoo', 'Hyper-representation model'])[['Original accuracy', 'Reconstruction accuracy']].max()\n",
    "\n",
    "# Adding max performance data for the entire zoo\n",
    "max_acc['Zoo accuracy'] = max_acc.index.get_level_values('Model zoo').map(df_zoo.groupby(['Model zoo'])['Test accuracy'].max().to_dict())\n",
    "\n",
    "# This data corresponds to the test split of the model zoo only\n",
    "max_acc['Test split accuracy'] = max_acc['Original accuracy']\n",
    "max_acc = max_acc.drop('Original accuracy', axis=1)\n",
    "\n",
    "# Adding max performance data for generated models\n",
    "max_acc['Generation accuracy'] = gen_acc.groupby(['Model zoo', 'Hyper-representation model'])['Accuracy'].max()\n",
    "\n",
    "# Computing max performance difference between reconstructed / generated models and the entire zoo\n",
    "max_acc['$\\Delta_{Acc}$ Reconstruction'] = max_acc['Reconstruction accuracy'] - max_acc['Zoo accuracy']\n",
    "max_acc['$\\Delta_{Acc}$ Generation'] = max_acc['Generation accuracy'] - max_acc['Zoo accuracy']\n",
    "\n",
    "# Re-ordering lines\n",
    "new_index = pd.MultiIndex.from_product([DS_ORDER, ['Contrastive + Structure (Baseline)', 'Contrastive + Structure + Behavior']], names=['Model zoo', 'Hyper-representation model'])\n",
    "max_acc = max_acc.reindex(new_index).loc[:, ['Zoo accuracy', 'Reconstruction accuracy', '$\\Delta_{Acc}$ Reconstruction', 'Generation accuracy', '$\\Delta_{Acc}$ Generation']]\n",
    "\n",
    "# Print\n",
    "max_acc = max_acc.style.format('{:.1%}')\n",
    "print(max_acc.to_latex())\n",
    "max_acc"
   ]
  }
 ],
 "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
}
