{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "8d8162e9-f891-4e74-a169-1fd39e6cd604",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/hpc/iwb3/iwb3021h/.local/lib/python3.12/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "from torchsummary import summary\n",
    "import functools\n",
    "import ast\n",
    "import torch\n",
    "import random\n",
    "import numpy as np\n",
    "import icecream as ic\n",
    "import time\n",
    "from IPython.display import clear_output\n",
    "import matplotlib.pyplot as plt\n",
    "sys.path.append(\"../../\")\n",
    "sys.path.append(\"../\")\n",
    "####### Dataset ############\n",
    "from data_processor import DataProcessor\n",
    "######## Search space #########\n",
    "from search_space.RegNet import RegNet\n",
    "from search_space.utils import create_widths_plot, scatter_results, get_generation_dfs\n",
    "######## Training ###############\n",
    "from trainer import Trainer, TrainerDistillation\n",
    "from utils.train_cfg import get_cfg, show_cfg\n",
    "###################################################\n",
    "random_seed = 1\n",
    "random.seed(random_seed)\n",
    "# Set seed for NumPy\n",
    "np.random.seed(random_seed)\n",
    "# Set seed for PyTorch\n",
    "torch.manual_seed(random_seed)\n",
    "torch.cuda.manual_seed_all(random_seed)\n",
    "# Additional steps if using CuDNN (optional, for GPU acceleration)\n",
    "torch.backends.cudnn.deterministic = True\n",
    "torch.backends.cudnn.benchmark = False\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "import os\n",
    "from datetime import datetime\n",
    "import itertools\n",
    "import pandas as pd\n",
    "import json\n",
    "from io import StringIO\n",
    "from coolname import generate_slug\n",
    "from sklearn.metrics import accuracy_score\n",
    "import torch.multiprocessing as mp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "50069289-0f40-4994-bf26-08bd16165b90",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def load_dataset_metadata(dataset_path):\n",
    "    with open(os.path.join(dataset_path, 'metadata'), \"r\") as f:\n",
    "        metadata = json.load(f)\n",
    "    return metadata\n",
    "# load dataset from file\n",
    "def load_datasets(data_path, truncate):\n",
    "    data_path = '../../datasets/'+data_path\n",
    "    train_x = np.load(os.path.join(data_path,'train_x.npy'))\n",
    "    train_y = np.load(os.path.join(data_path,'train_y.npy'))\n",
    "    valid_x = np.load(os.path.join(data_path,'valid_x.npy'))\n",
    "    valid_y = np.load(os.path.join(data_path,'valid_y.npy'))\n",
    "    test_x = np.load(os.path.join(data_path,'test_x.npy'))\n",
    "    metadata = load_dataset_metadata(data_path)\n",
    "\n",
    "    if truncate:\n",
    "        train_x = train_x[:64]\n",
    "        train_y = train_y[:64]\n",
    "        valid_x = valid_x[:64]\n",
    "        valid_y = valid_y[:64]\n",
    "        test_x = test_x[:64]\n",
    "\n",
    "    return (train_x, train_y), \\\n",
    "           (valid_x, valid_y), \\\n",
    "           (test_x), metadata\n",
    "\n",
    "def validation(model, val_loader):\n",
    "    model.eval()\n",
    "    correct = 0\n",
    "    total = 0\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for images, labels in val_loader:\n",
    "            images, labels = images.to(device), labels.to(device)\n",
    "            outputs = model(images)\n",
    "            _, predicted = torch.max(outputs, 1)\n",
    "            total += labels.size(0)\n",
    "            correct += (predicted == labels).sum().item()\n",
    "\n",
    "    # 4. Calculate Accuracy\n",
    "    accuracy = correct / total\n",
    "    print('Accuracy on the test set: {:.2f}%'.format(accuracy * 100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ea16d92d-5b0a-41dd-ac77-9dffb6792bc9",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/apps/jupyterhub/jh3.1.1-py3.11/envs/pytorch-2.2.0/lib/python3.12/site-packages/torchvision/transforms/v2/_deprecated.py:41: UserWarning: The transform `ToTensor()` is deprecated and will be removed in a future release. Instead, please use `v2.Compose([v2.ToImage(), v2.ToDtype(torch.float32, scale=True)])`.\n",
      "  warnings.warn(\n",
      "ic| self.x.shape: torch.Size([45000, 3, 64, 64])\n",
      "ic| self.x.shape: torch.Size([15000, 3, 64, 64])\n",
      "ic| self.x.shape: torch.Size([10000, 3, 64, 64])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "{'num_classes': 4,\n",
       " 'input_shape': [49260, 3, 64, 64],\n",
       " 'codename': 'Caitie',\n",
       " 'benchmark': 47.008,\n",
       " 'select_augment': False,\n",
       " 'train_config_path': 'anki_lab_submission/configs/train/augmentations_adam.yaml'}"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Dataset=\"CIFARTile\"\n",
    "(train_x, train_y), (valid_x, valid_y), (test_x), metadata = load_datasets(Dataset, truncate=False)\n",
    "test_y = np.load(os.path.join('../../datasets/'+Dataset,'test_y.npy'))\n",
    "metadata[\"select_augment\"]=False\n",
    "data_processor = DataProcessor(train_x[:], train_y[:], valid_x, valid_y, test_x, metadata)\n",
    "train_loader, valid_loader, test_loader = data_processor.process()\n",
    "\n",
    "\n",
    "metadata"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "81a75f8a-ccb2-43e0-b9f6-822cb451c5c9",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "current_transforms=train_loader.dataset.transform.transforms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a8192f51-d715-4ac8-bb5c-1ad7ff898e61",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "from torchvision.transforms import v2\n",
    "class RandomPixelChange:\n",
    "    def __init__(self, change_prob=0.1):\n",
    "        self.change_prob = change_prob\n",
    "    \n",
    "    def __call__(self, img):\n",
    "        # Convert image to numpy array\n",
    "        img_array = np.array(img).astype(np.float32)\n",
    "        \n",
    "        # Normalize the array to [0, 1]\n",
    "        img_array = (img_array - img_array.min()) / (img_array.max() - img_array.min())#\n",
    "        \n",
    "        unique_values=np.unique(img_array)\n",
    "        \n",
    "        # Generate a random mask with the same shape as img_array\n",
    "        mask = np.random.rand(*img_array.shape) < self.change_prob\n",
    "        \n",
    "        # Apply the mask to randomly change the pixels to any of the unique values\n",
    "        random_values = np.random.choice(unique_values, size=img_array.shape)\n",
    "        img_array[mask] = random_values[mask]\n",
    "        \n",
    "        return img_array.transpose(1, 2, 0)\n",
    "\n",
    "C,H,W=metadata['input_shape'][1:4]\n",
    "PH,PW=int(H/8),int(W/8)\n",
    "poss_augs= [               [],\n",
    "                [RandomPixelChange(0.01), v2.ToTensor()],\n",
    "                [RandomPixelChange(0.05), v2.ToTensor()],\n",
    "                [RandomPixelChange(0.01), v2.ToTensor(), v2.RandomHorizontalFlip(),v2.RandomVerticalFlip()],\n",
    "                [RandomPixelChange(0.01), v2.ToTensor(), v2.RandomCrop((H,W), padding=(PH,PW))],\n",
    "                [v2.RandomHorizontalFlip(),v2.RandomVerticalFlip()],\n",
    "                [v2.RandomErasing(p=0.2, scale=(0.05, 0.2), ratio=(0.3, 3.3))],\n",
    "                [v2.RandomErasing(p=0.2, scale=(0.02, 0.2), ratio=(0.3, 3.3)), v2.RandomCrop((H,W), padding=(PH,PW))],\n",
    "                [v2.RandomCrop((H,W), padding=(PH,PW))],\n",
    "                [v2.RandomErasing(p=0.2, scale=(0.02, 0.2), ratio=(0.3, 3.3)),v2.RandomCrop((H,W), padding=(PH,PW)),v2.RandomHorizontalFlip()]\n",
    "           ]\n",
    "\n",
    "poss_augs=   [             [],  # No augmentation\n",
    "\n",
    "                [RandomPixelChange(0.02), v2.ToTensor()],\n",
    "                [RandomPixelChange(0.05), v2.ToTensor()],\n",
    "                [RandomPixelChange(0.01), v2.ToTensor(), v2.RandomHorizontalFlip(),v2.RandomVerticalFlip()],\n",
    "                [RandomPixelChange(0.01), v2.ToTensor(), v2.RandomCrop((H,W), padding=(PH,PW))],\n",
    "\n",
    "                [v2.RandomHorizontalFlip(), v2.RandomVerticalFlip()],\n",
    "                [ v2.RandomCrop((H,W), padding=(PH,PW)),\n",
    "                v2.RandomHorizontalFlip()],\n",
    "                [v2.RandomGrayscale(p=0.2),v2.RandomErasing(p=0.1, scale=(0.02, 0.33), ratio=(0.3, 3.3))],\n",
    "                [ v2.RandomCrop((H,W), padding=(PH,PW)),\n",
    "                v2.RandomHorizontalFlip(), v2.RandomGrayscale(p=0.1),v2.RandomErasing(p=0.1, scale=(0.02, 0.33), ratio=(0.3, 3.3))]\n",
    "                               ]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "47ba2d22-4405-47fb-a0da-1ec0df7c2a17",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "train_loader.shuffle=False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "58450024-da7d-4f95-92e9-f0e1455832d2",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "aug=7\n",
    "train_loader.dataset.transform=v2.Compose(poss_augs[aug]+[current_transforms[-1]])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b69171e0-5980-40cf-8ed8-4c13c98848ae",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[RandomGrayscale(p=0.2),\n",
       " RandomErasing(p=0.1, scale=(0.02, 0.33), ratio=(0.3, 3.3), value=[0.0], inplace=False),\n",
       " Normalize(mean=tensor([-0.2695, -0.2762, -0.2390]), std=tensor([1.1456, 1.1417, 1.0874]))]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_loader.dataset.transform.transforms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "45545083-9d74-4231-b633-11d8f4720113",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "#os.mkdir(\"zcost_proxies/results/augs\")               \n",
    "#df_syn.to_csv(f\"zcost_proxies/results/augs/gutenberg_t{aug}.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "cfbe8a74-54aa-4dd0-83a9-1976cffe21d6",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "rg=RegNet(metadata,\n",
    "                    W0=[16, 120, 8],\n",
    "                    WA=[16, 64, 8],\n",
    "                    WM=[2.05,2.9,0.05],\n",
    "                    D=[8,22,1], \n",
    "                    G=[8,8,8], \n",
    "                    base_config=f\"../configs/search_space/config.yaml\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "78d6137c-42aa-4c71-8cdd-c7137ed7a7b4",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "current_time=datetime.now().strftime(\"%d_%m_%Y_%H_%M\")\n",
    "#folder=f\"/home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/stages_pool\"\n",
    "folder=f\"/home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train\"\n",
    "\n",
    "dataset=metadata[\"codename\"]\n",
    "#models, chromosomes=rg.load_generation(folder+\"/\"+dataset)\n",
    "#models, chromosomes=rg.create_random_generation(save_folder=test_folder,gen=None, size=1, config_updates=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "a648ac41-7c38-431a-b533-97b699cc784c",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import json\n",
    "with open(f'/home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/augmentations_test/{dataset}/augmentation_results.json', 'r') as file:\n",
    "    data = json.load(file)\n",
    "    \n",
    "val_scores_df=pd.DataFrame(data).T.sort_values(by=\"val_acc\").reset_index().rename(columns={\"index\":\"aug\"})\n",
    "val_scores_df.aug=val_scores_df.aug.astype(int)\n",
    "\n",
    "aug_dfs=[]\n",
    "for aug in [0,2,3,4,5,6,7,8]:\n",
    "    df=pd.read_csv(f\"zcost_proxies/results/augs/{dataset}_t{aug}.csv\",index_col=0)[[\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"]].median().reset_index().set_index(\"index\").T\n",
    "    df[\"aug\"]=aug\n",
    "    aug_dfs.append(df)\n",
    "aug_dfs=pd.concat(aug_dfs)\n",
    "\n",
    "aug_merged=pd.merge(aug_dfs,val_scores_df[[\"aug\",\"val_acc\",\"train_acc\"]],on=\"aug\" ).sort_values(by=\"val_acc\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "baea7dbc-ab64-4b10-81a3-5a8c0a7c88a4",
   "metadata": {
    "tags": []
   },
   "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>aug</th>\n",
       "      <th>val_acc</th>\n",
       "      <th>train_acc</th>\n",
       "      <th>epoch_time</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>26.500000</td>\n",
       "      <td>41.457443</td>\n",
       "      <td>30.256330</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>4</td>\n",
       "      <td>26.966667</td>\n",
       "      <td>50.643250</td>\n",
       "      <td>34.261710</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2</td>\n",
       "      <td>29.106667</td>\n",
       "      <td>44.718216</td>\n",
       "      <td>30.842927</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3</td>\n",
       "      <td>30.126667</td>\n",
       "      <td>44.037125</td>\n",
       "      <td>32.754755</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0</td>\n",
       "      <td>46.806667</td>\n",
       "      <td>59.666576</td>\n",
       "      <td>9.626233</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>7</td>\n",
       "      <td>48.426666</td>\n",
       "      <td>61.433849</td>\n",
       "      <td>12.399353</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>5</td>\n",
       "      <td>58.466667</td>\n",
       "      <td>73.896011</td>\n",
       "      <td>12.167558</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>8</td>\n",
       "      <td>68.386665</td>\n",
       "      <td>70.136665</td>\n",
       "      <td>17.430750</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>6</td>\n",
       "      <td>69.053337</td>\n",
       "      <td>75.442932</td>\n",
       "      <td>15.319733</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   aug    val_acc  train_acc  epoch_time\n",
       "0    1  26.500000  41.457443   30.256330\n",
       "1    4  26.966667  50.643250   34.261710\n",
       "2    2  29.106667  44.718216   30.842927\n",
       "3    3  30.126667  44.037125   32.754755\n",
       "4    0  46.806667  59.666576    9.626233\n",
       "5    7  48.426666  61.433849   12.399353\n",
       "6    5  58.466667  73.896011   12.167558\n",
       "7    8  68.386665  70.136665   17.430750\n",
       "8    6  69.053337  75.442932   15.319733"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "val_scores_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "a4887666-ee5e-4fd5-be50-cbed363c3014",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "fisher\n",
      "0.14285714285714288\n",
      "grad_norm\n",
      "0.4285714285714286\n",
      "jacob_cov\n",
      "0.0\n",
      "plain\n",
      "0.19047619047619052\n",
      "snip\n",
      "0.261904761904762\n",
      "synflow\n",
      "0.3233590907165799\n"
     ]
    }
   ],
   "source": [
    "for metric in [\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"]:\n",
    "    print(metric)\n",
    "    corr, _=spearmanr(aug_merged[metric],aug_merged[\"val_acc\"])\n",
    "    print(corr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "540d8a74-5b4b-4a38-824c-30a075b18d7b",
   "metadata": {
    "tags": []
   },
   "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>fisher</th>\n",
       "      <th>grad_norm</th>\n",
       "      <th>jacob_cov</th>\n",
       "      <th>plain</th>\n",
       "      <th>snip</th>\n",
       "      <th>synflow</th>\n",
       "      <th>aug</th>\n",
       "      <th>val_acc</th>\n",
       "      <th>train_acc</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.035559</td>\n",
       "      <td>20.254367</td>\n",
       "      <td>-129.006691</td>\n",
       "      <td>0.052259</td>\n",
       "      <td>80.543282</td>\n",
       "      <td>3.953281e+39</td>\n",
       "      <td>4</td>\n",
       "      <td>26.966667</td>\n",
       "      <td>50.643250</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.027626</td>\n",
       "      <td>19.811438</td>\n",
       "      <td>-128.941599</td>\n",
       "      <td>0.060183</td>\n",
       "      <td>72.616066</td>\n",
       "      <td>4.209597e+39</td>\n",
       "      <td>2</td>\n",
       "      <td>29.106667</td>\n",
       "      <td>44.718216</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.096594</td>\n",
       "      <td>33.491844</td>\n",
       "      <td>-128.995591</td>\n",
       "      <td>0.083029</td>\n",
       "      <td>155.533325</td>\n",
       "      <td>7.703862e+41</td>\n",
       "      <td>3</td>\n",
       "      <td>30.126667</td>\n",
       "      <td>44.037125</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.058657</td>\n",
       "      <td>33.105900</td>\n",
       "      <td>-129.009727</td>\n",
       "      <td>0.054275</td>\n",
       "      <td>159.422134</td>\n",
       "      <td>7.577779e+41</td>\n",
       "      <td>0</td>\n",
       "      <td>46.806667</td>\n",
       "      <td>59.666576</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>0.024783</td>\n",
       "      <td>20.433469</td>\n",
       "      <td>-128.994126</td>\n",
       "      <td>0.063075</td>\n",
       "      <td>83.771671</td>\n",
       "      <td>4.221342e+39</td>\n",
       "      <td>7</td>\n",
       "      <td>48.426666</td>\n",
       "      <td>61.433849</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.024656</td>\n",
       "      <td>19.721895</td>\n",
       "      <td>-128.978208</td>\n",
       "      <td>0.066911</td>\n",
       "      <td>79.816074</td>\n",
       "      <td>3.953281e+39</td>\n",
       "      <td>5</td>\n",
       "      <td>58.466667</td>\n",
       "      <td>73.896011</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>0.060178</td>\n",
       "      <td>33.147995</td>\n",
       "      <td>-129.002461</td>\n",
       "      <td>0.050118</td>\n",
       "      <td>152.232651</td>\n",
       "      <td>7.340520e+41</td>\n",
       "      <td>8</td>\n",
       "      <td>68.386665</td>\n",
       "      <td>70.136665</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.060679</td>\n",
       "      <td>33.594887</td>\n",
       "      <td>-128.997395</td>\n",
       "      <td>0.069126</td>\n",
       "      <td>153.365326</td>\n",
       "      <td>7.628238e+41</td>\n",
       "      <td>6</td>\n",
       "      <td>69.053337</td>\n",
       "      <td>75.442932</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     fisher  grad_norm   jacob_cov     plain        snip       synflow  aug  \\\n",
       "3  0.035559  20.254367 -129.006691  0.052259   80.543282  3.953281e+39    4   \n",
       "1  0.027626  19.811438 -128.941599  0.060183   72.616066  4.209597e+39    2   \n",
       "2  0.096594  33.491844 -128.995591  0.083029  155.533325  7.703862e+41    3   \n",
       "0  0.058657  33.105900 -129.009727  0.054275  159.422134  7.577779e+41    0   \n",
       "6  0.024783  20.433469 -128.994126  0.063075   83.771671  4.221342e+39    7   \n",
       "4  0.024656  19.721895 -128.978208  0.066911   79.816074  3.953281e+39    5   \n",
       "7  0.060178  33.147995 -129.002461  0.050118  152.232651  7.340520e+41    8   \n",
       "5  0.060679  33.594887 -128.997395  0.069126  153.365326  7.628238e+41    6   \n",
       "\n",
       "     val_acc  train_acc  \n",
       "3  26.966667  50.643250  \n",
       "1  29.106667  44.718216  \n",
       "2  30.126667  44.037125  \n",
       "0  46.806667  59.666576  \n",
       "6  48.426666  61.433849  \n",
       "4  58.466667  73.896011  \n",
       "7  68.386665  70.136665  \n",
       "5  69.053337  75.442932  "
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "aug_merged"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "19acfa11-4530-48b8-83e5-42a703d868ca",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import json\n",
    "import os\n",
    "\n",
    "import kaleido\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import plotly.graph_objects as go\n",
    "######## Search space #########\n",
    "import sys\n",
    "sys.path.append(\"../\")\n",
    "from search_space.RegNet import RegNet\n",
    "from search_space.utils import create_widths_plot, scatter_results\n",
    "# Initialize an empty list to store dictionaries\n",
    "def results_to_df(path, name):\n",
    "    data = []\n",
    "    # Open the text file\n",
    "    with open(path, 'r') as file:\n",
    "        lines = file.readlines()\n",
    "        # Initialize an empty dictionary to store data for each block\n",
    "        block_data = {}\n",
    "        for line in lines:\n",
    "            # If the line contains dashes, it indicates the end of a block\n",
    "            if '-------------------------' in line:\n",
    "                # If block_data is not empty, add it to the list of data dictionaries\n",
    "                if block_data:\n",
    "                    data.append(block_data)\n",
    "                    # Reset block_data for the next block\n",
    "                    block_data = {}\n",
    "            elif 'best_acc' in line:\n",
    "                continue\n",
    "            else:\n",
    "                # Split the line by ':'\n",
    "                #print(line)\n",
    "                key, value = line.strip().split(': ')\n",
    "                # Store the key-value pair in the block_data dictionary\n",
    "                block_data[key] = value\n",
    "\n",
    "    # Create a DataFrame from the list of dictionaries\n",
    "    df = pd.DataFrame(data)\n",
    "\n",
    "    # Convert columns to appropriate data types if needed\n",
    "    df['epoch'] = df['epoch'].astype(int)\n",
    "    df['lr'] = df['lr'].astype(float)\n",
    "    df['train_acc'] = df['train_acc'].astype(float)\n",
    "    df['train_loss'] = df['train_loss'].astype(float)\n",
    "    df['test_acc'] = df['test_acc'].astype(float)\n",
    "    df['test_acc_top5'] = df['test_acc_top5'].astype(float)\n",
    "    df['test_loss'] = df['test_loss'].astype(float)\n",
    "    df['epoch_time'] = df['epoch_time'].astype(float)\n",
    "    df=df.assign(name=name)\n",
    "    \n",
    "    return df\n",
    "\n",
    "metadata_dict={}\n",
    "metadata_dict[\"Caitie\"]={'num_classes': 4,\n",
    "                         'input_shape': [49260, 3, 64, 64],\n",
    "                         'codename': 'Caitie',\n",
    "                         'benchmark': 47.008,\n",
    "                         }\n",
    "metadata_dict[\"Adaline\"]={'num_classes': 20,\n",
    "                         'input_shape': [50000, 3, 28, 28],\n",
    "                         'codename': 'Adaline',\n",
    "                         'benchmark': 89.85}\n",
    "metadata_dict[\"Chester\"]={'input_shape': [49998, 12, 8, 8],\n",
    "                         'codename': 'Chester',\n",
    "                         'benchmark': 57.826,\n",
    "                         'num_classes': 3}\n",
    "metadata_dict[\"Gutenberg\"]={'input_shape': [45000, 1, 27, 18],\n",
    "                         'codename': 'Gutenberg',\n",
    "                         'benchmark': 40.98,\n",
    "                         'num_classes': 6}\n",
    "metadata_dict[\"LaMelo\"]={'num_classes': 10,\n",
    "                         'codename': 'LaMelo',\n",
    "                         'input_shape': [50000, 1, 24, 24],\n",
    "                         'benchmark': 85.2}\n",
    "metadata_dict[\"Mateo\"]={'num_classes': 10,\n",
    "                         'input_shape': [50000, 3, 28, 28],\n",
    "                         'codename': 'Mateo',\n",
    "                         'benchmark': 90.87}\n",
    "metadata_dict[\"Sadie\"]={'input_shape': [50000, 3, 64, 64],\n",
    "                         'codename': 'Sadie',\n",
    "                         'benchmark': 80.33,\n",
    "                         'num_classes': 10}\n",
    "metadata_dict[\"Sokoto\"]={'input_shape': [50000, 1, 9, 9],\n",
    "                         'codename': 'Sokoto',\n",
    "                         'benchmark': 0.0,\n",
    "                         'num_classes': 9}\n",
    "def get_predictor_data_from_folder(base_folder,studies):\n",
    "\n",
    "    \n",
    "    train_data=[]\n",
    "    for study_name in studies: \n",
    "        \n",
    "\n",
    "        metadata=metadata_dict[study_name]\n",
    "        rg=RegNet(metadata,\n",
    "                        W0=[16, 120, 8],\n",
    "                        WA=[16, 64, 8],\n",
    "                        WM=[2.05,2.9,0.05],\n",
    "                        D=[8,22,1], \n",
    "                        G=[8,8,8], \n",
    "                        base_config=f\"../configs/search_space/config.yaml\")\n",
    "        data=[]\n",
    "        study_folder=f\"{base_folder}/{study_name}\"\n",
    "        subjects= os.listdir(study_folder)\n",
    "\n",
    "        subjects=[subject for subject in subjects if os.path.isdir(f\"{study_folder}/{subject}\")]\n",
    "        print(subjects)\n",
    "        for name in subjects:\n",
    "            try:\n",
    "                test_acc=results_to_df(f\"{study_folder}/{name}/worklog.txt\", f\"{name}\")[[\"epoch\",\"test_acc\",\"name\"]]\n",
    "                #test_acc=test_acc.rename(columns={\"test_acc\":\"acc\",\"test_loss\":\"test_acc\"})\n",
    "                #print(test_acc.columns)\n",
    "                if len(test_acc)>49:\n",
    "                    test_acc_piv = test_acc[[\"epoch\",\"test_acc\",\"name\"]].pivot(index='name', columns='epoch', values='test_acc').add_prefix(\"epoch_\").reset_index()\n",
    "                    test_acc_piv[\"best_acc\"]=test_acc[\"test_acc\"].max()\n",
    "                    \n",
    "                    model, info=rg.load_model(config_file=f\"{study_folder}/{name}/config.yaml\")\n",
    "                    test_acc_piv[\"gen\"]=1\n",
    "                    test_acc_piv[\"num_stages\"]=info[\"num_stages\"]\n",
    "                    test_acc_piv[\"params\"]=info[\"params\"]\n",
    "                    test_acc_piv[\"WA\"]=info[\"WA\"]\n",
    "                    test_acc_piv[\"W0\"]=info[\"W0\"]\n",
    "                    test_acc_piv[\"WM\"]=info[\"WM\"]\n",
    "                    test_acc_piv[\"DEPTH\"]=info[\"DEPTH\"]\n",
    "                    test_acc_piv[\"num_classes\"]=metadata[\"num_classes\"]\n",
    "                    test_acc_piv[\"num_channels\"]=metadata[\"input_shape\"][1]\n",
    "                    test_acc_piv[\"benchmark\"]=metadata[\"benchmark\"]\n",
    "                    \n",
    "                    #print(info)\n",
    "                    data.append(test_acc_piv)\n",
    "            except:\n",
    "                    pass\n",
    "\n",
    "        data=pd.concat(data)\n",
    "        train_data.append(data)\n",
    "    train_data=pd.concat(train_data)\n",
    "    return train_data\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "38e53f07-9f61-431c-9f00-bf3883712365",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['masked_earthworm', 'daffy_mongrel', 'wandering_tody', 'uber_bat', 'vivacious_eel', 'lush_chimpanzee', 'ultra_vulture', 'olive_hoatzin', 'antique_taipan', 'tremendous_pony', 'independent_chowchow', 'micro_pug', 'cerulean_galago', 'capable_mussel', 'fuzzy_magpie', 'magic_pheasant', 'charming_dachshund', 'invisible_stork', 'sapphire_seagull', 'axiomatic_vole', 'snobbish_curassow', 'vengeful_otter', 'ochre_grebe', 'imposing_walrus', 'lurking_chowchow', 'holistic_marten', 'spectral_flamingo', 'ruddy_rhino', 'aboriginal_okapi', 'slick_penguin', 'imperial_oyster', 'cherry_rook', 'adept_sponge', 'adaptable_weasel', 'loyal_macaque', 'amber_jackdaw', 'polar_harrier', 'giga_seal', 'calculating_coyote', 'gabby_kangaroo', 'manipulative_cormorant', 'steady_kakapo', 'obedient_curassow', 'cooperative_tench', 'prudent_caribou', 'radiant_raptor', 'impressive_agouti', 'placid_peacock', 'rose_mackerel', 'glittering_wildcat', 'inventive_horse', 'devious_cicada', 'delicate_lemur', 'certain_mastodon', 'abiding_turaco', 'mature_locust', 'elegant_aardwark', 'fiery_heron', 'didactic_turkey', 'heavenly_moose', 'lyrical_skylark', 'helpful_horse', 'impressive_binturong', 'emerald_earthworm', 'jumping_nuthatch', 'just_salmon', 'deft_alpaca', 'innocent_barnacle', 'adept_orangutan', 'incredible_cat', 'capable_carp', 'apricot_jerboa', 'flying_tody', 'large_mustang', 'certain_porpoise', 'gleaming_spoonbill', 'bold_mouse', 'idealistic_crayfish', 'diamond_tench', 'cocky_gerbil', 'esoteric_husky', 'carrot_chameleon', 'gentle_kakapo', 'ingenious_puffin', 'imposing_wildcat', 'fanatic_chicken', 'busy_lemur', 'benign_jackrabbit', 'honest_chamois', 'adept_weasel', 'bizarre_grouse', 'abstract_spoonbill', 'fancy_kestrel', 'axiomatic_wallaby', 'fearless_manatee', 'competent_bee', 'dancing_angelfish', 'daffodil_mackerel', 'jovial_mammoth', 'fluorescent_mussel', 'asparagus_mammoth', 'astute_ape', 'happy_hedgehog', 'expert_tody', 'beige_panther', 'dashing_sidewinder', 'divergent_mole', 'delicate_swift', 'honest_sloth', 'able_griffin', 'azure_asp', 'logical_pudu', 'dazzling_polecat', 'acrid_echidna', 'cherry_mastiff', 'dramatic_impala', 'gigantic_chihuahua', 'hilarious_dragon', 'able_fennec']\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/masked_earthworm/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/daffy_mongrel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/wandering_tody/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/uber_bat/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/vivacious_eel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/lush_chimpanzee/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/ultra_vulture/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/olive_hoatzin/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/antique_taipan/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/tremendous_pony/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/independent_chowchow/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/micro_pug/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/cerulean_galago/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/capable_mussel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/fuzzy_magpie/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/magic_pheasant/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/charming_dachshund/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/invisible_stork/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/sapphire_seagull/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/axiomatic_vole/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/snobbish_curassow/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/vengeful_otter/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/ochre_grebe/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/imposing_walrus/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/lurking_chowchow/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/holistic_marten/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/spectral_flamingo/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/ruddy_rhino/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/aboriginal_okapi/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/slick_penguin/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/imperial_oyster/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/cherry_rook/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/adept_sponge/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/adaptable_weasel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/loyal_macaque/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/amber_jackdaw/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/polar_harrier/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/giga_seal/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/calculating_coyote/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/manipulative_cormorant/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/steady_kakapo/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/obedient_curassow/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/cooperative_tench/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/prudent_caribou/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/radiant_raptor/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/impressive_agouti/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/placid_peacock/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/rose_mackerel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/glittering_wildcat/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/inventive_horse/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/devious_cicada/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/delicate_lemur/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/certain_mastodon/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/abiding_turaco/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/mature_locust/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/elegant_aardwark/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/fiery_heron/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/didactic_turkey/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/heavenly_moose/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/lyrical_skylark/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/helpful_horse/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/impressive_binturong/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/emerald_earthworm/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/jumping_nuthatch/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/just_salmon/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/deft_alpaca/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/innocent_barnacle/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/adept_orangutan/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/incredible_cat/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/capable_carp/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/apricot_jerboa/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/flying_tody/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/large_mustang/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/certain_porpoise/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/gleaming_spoonbill/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/bold_mouse/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/idealistic_crayfish/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/diamond_tench/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/cocky_gerbil/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/esoteric_husky/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/carrot_chameleon/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/gentle_kakapo/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/ingenious_puffin/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/imposing_wildcat/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/fanatic_chicken/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/busy_lemur/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/benign_jackrabbit/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/honest_chamois/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/adept_weasel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/bizarre_grouse/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/abstract_spoonbill/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/fancy_kestrel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/fearless_manatee/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/competent_bee/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/dancing_angelfish/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/daffodil_mackerel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/jovial_mammoth/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/fluorescent_mussel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/asparagus_mammoth/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/astute_ape/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/happy_hedgehog/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/expert_tody/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/beige_panther/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/dashing_sidewinder/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/divergent_mole/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/delicate_swift/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/honest_sloth/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/able_griffin/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/azure_asp/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/logical_pudu/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/dazzling_polecat/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/acrid_echidna/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/cherry_mastiff/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/dramatic_impala/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/gigantic_chihuahua/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/hilarious_dragon/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/able_fennec/config.yaml\n"
     ]
    }
   ],
   "source": [
    "train_data=get_predictor_data_from_folder(base_folder=folder,\n",
    "                                          studies=[dataset])\n",
    "#test_data=get_predictor_data_from_folder(base_folder=\"/home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train\",\n",
    "#                                         studies=test_studies)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "aa16e232-440d-467f-832c-b9e9d8310a34",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "test_names=train_data.name.unique()[:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "3d9dcfd2-dd80-4d2e-ae3d-675cf756182a",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "118"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(valid_loader)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "3c9d0a0f-2dbd-4568-b3cb-175b72319748",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch.nn as nn\n",
    "import types\n",
    "import copy\n",
    "import torch.nn.functional as F\n",
    "from zcost_proxies.predictive import find_measures"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "5a37646f-abbd-4b50-9221-599c29f90959",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'num_classes': 4,\n",
       " 'input_shape': [49260, 3, 64, 64],\n",
       " 'codename': 'Caitie',\n",
       " 'benchmark': 47.008,\n",
       " 'select_augment': False,\n",
       " 'train_config_path': 'anki_lab_submission/configs/train/augmentations_adam.yaml'}"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "metadata"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "054c94fe-7513-45b0-b04b-cb0b64c95e23",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "train_loader_iter = iter(train_loader)\n",
    "\n",
    "# Number of batches to extract\n",
    "num_batches =1\n",
    "\n",
    "# Initialize lists to hold the inputs and targets from the first 5 batches\n",
    "inputs_list = []\n",
    "targets_list = []\n",
    "\n",
    "for _ in range(num_batches):\n",
    "    inputs, targets = next(train_loader_iter)  # Get the next batch\n",
    "    inputs_list.append(inputs)\n",
    "    targets_list.append(targets)\n",
    "\n",
    "# Concatenate the inputs and targets across the batches\n",
    "inputs = torch.cat(inputs_list)\n",
    "targets = torch.cat(targets_list)\n",
    "\n",
    "# Create a new TensorDataset from the selected data\n",
    "new_dataset = TensorDataset(inputs, targets)\n",
    "\n",
    "# Create a new DataLoader from this new dataset\n",
    "new_valid_loader = DataLoader(new_dataset, batch_size=train_loader.batch_size, shuffle=True)\n",
    "#train_loader.batch_size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7826bdc4-daa7-4691-a8b0-913cb0c5d501",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "6222d74b-47c2-4dea-adff-6138a58a1299",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Number of batches to extract\n",
    "num_batches =5\n",
    "\n",
    "# Initialize lists to hold the inputs and targets from the first 5 batches\n",
    "inputs_list = []\n",
    "targets_list = []\n",
    "\n",
    "for _ in range(num_batches):\n",
    "    inputs, targets = next(train_loader_iter)  # Get the next batch\n",
    "    inputs_list.append(inputs)\n",
    "    targets_list.append(targets)\n",
    "\n",
    "# Concatenate the inputs and targets across the batches\n",
    "inputs = torch.cat(inputs_list)\n",
    "targets = torch.cat(targets_list)\n",
    "\n",
    "# Create a new TensorDataset from the selected data\n",
    "new_dataset = TensorDataset(inputs, targets)\n",
    "\n",
    "# Create a new DataLoader from this new dataset\n",
    "new_valid_loader_grasp = DataLoader(new_dataset, batch_size=train_loader.batch_size, shuffle=True)\n",
    "#train_loader.batch_size\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "0a4a98d4-26e7-4b50-b9f8-67b076d1790c",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "del train_loader\n",
    "del valid_loader"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "33e80ea9-e89f-40a8-b65d-6510609ecdeb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def load_stages_pool(pool_folders):\n",
    "    df_results_list=[]\n",
    "    for pool_folder in pool_folders:\n",
    "        df_results=pd.read_csv(f\"{pool_folder}/df_blocks_pool.csv\", index_col=0)\n",
    "        df_results=df_results[df_results.dataset!=metadata[\"codename\"]]\n",
    "        df_results[\"dataset\"]=pool_folder+df_results[\"dataset\"]\n",
    "        df_results_list.append(df_results)\n",
    "    df_results=pd.concat(df_results_list)\n",
    "    #df_results.to_csv(\"initial_pool.csv\")\n",
    "    return df_results\n",
    "\n",
    "def transfer_weights(model,model_name,total_pool_individuals,rg):\n",
    "        n_access={}\n",
    "\n",
    "        print(\"Model Name: \",model_name)\n",
    "        print(\"#######################\")\n",
    "        pool_models={}\n",
    "        pool_chroms={}\n",
    "        for stage, info in total_pool_individuals[model_name].items():\n",
    "            name, transfer_dataset=info\n",
    "\n",
    "            weights_file=f\"{transfer_dataset}/{name}/student_best\"\n",
    "            config_file=f\"{transfer_dataset}/{name}/config.yaml\"\n",
    "            if os.path.exists(weights_file):\n",
    "                pool_models[stage],pool_chroms[stage]=rg.load_model(config_file=config_file, weights_file=weights_file)\n",
    "            else:\n",
    "                ic(f\"Weights file does not exits {weights_file}\")\n",
    "                pool_chroms[stage]=None\n",
    "        chrom=chromosomes[model_name]\n",
    "        n_access[model_name]=0\n",
    "        for stage in range(1,chrom[\"num_stages\"]+1):\n",
    "            if pool_chroms[stage] is not None:\n",
    "                max_block=min(chrom[\"ds\"][stage-1], pool_chroms[stage][\"ds\"][stage-1])\n",
    "                print(\"###### MAX BLOCK #####: \",max_block)\n",
    "                for block in range(1,max_block+1):\n",
    "                    print(\"Block: \", block)\n",
    "                    model_part = eval(f\"model.s{stage}.b{block}\")\n",
    "                    orig_part = eval(f\"pool_models[stage].s{stage}.b{block}.state_dict()\")\n",
    "\n",
    "                    for key in model_part.state_dict().keys():\n",
    "\n",
    "                        tensor = orig_part[key]\n",
    "                        tensor_shape = tensor.shape\n",
    "\n",
    "                        tensor_student_shape=model_part.state_dict()[key].shape\n",
    "                        if tensor_shape==tensor_student_shape:\n",
    "                            #print(key)\n",
    "                            #print(tensor_shape)\n",
    "                            n_access[model_name]=n_access[model_name]+1\n",
    "\n",
    "\n",
    "                            keys = key.split('.')\n",
    "\n",
    "                            # Access the specific layer that contains the weight attribute\n",
    "                            param = functools.reduce(getattr, keys[:-1], model_part)\n",
    "                            #print(param.requires_grad)\n",
    "                            #param.weight.requires_grad=False\n",
    "                            # Use setattr to update the .data attribute of the weight tensor\n",
    "                            getattr(param, keys[-1]).data = tensor.clone()\n",
    "            else:\n",
    "                ic(f\"Stage {stage} is None\")\n",
    "        print(n_access)    \n",
    "        rg=RegNet(metadata,\n",
    "                        W0=[16, 120, 8],\n",
    "                        WA=[16, 64, 8],\n",
    "                        WM=[2.05,2.9,0.05],\n",
    "                        D=[8,22,1], \n",
    "                        G=[8,8,8], \n",
    "                        base_config=f\"../configs/search_space/config.yaml\")\n",
    "        return model\n",
    "\n",
    "preloaded=False\n",
    "if preloaded:\n",
    "    pool_stages_df=load_stages_pool(\n",
    "            #pool_folders= [\"/home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/\"]\n",
    "            pool_folders= [\"/home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/stages_pool/\"])\n",
    "            #]) if self.pretrained_pool else pd.DataFrame()\n",
    "        \n",
    "\n",
    "    df_models=pd.DataFrame(chromosomes).T[[\"ws\",\"ds\",\"num_stages\", \"DEPTH\"]]\n",
    "    total_pool_individuals={}\n",
    "\n",
    "    for model_name in list(chromosomes.keys()):\n",
    "        df_current_model=df_models.loc[model_name]\n",
    "\n",
    "        filtered_dfs=[]\n",
    "        df_results_aux=pool_stages_df.drop(columns=[\"ws\",\"ds\"])\n",
    "        df_results_aux[\"diff_stages\"]=abs(df_results_aux[\"num_stages\"]-df_current_model[\"num_stages\"])\n",
    "        df_results_aux[\"diff_depth\"]=abs(df_results_aux[\"DEPTH\"]-df_current_model[\"DEPTH\"])\n",
    "\n",
    "        for stage in range(1, df_current_model[\"num_stages\"]+1):\n",
    "            df_results_aux[f\"diff_ws{stage}\"]=abs(df_results_aux[f\"ws{stage}\"]-df_current_model[\"ws\"][stage-1])\n",
    "            df_results_aux[f\"diff_d{stage}\"]=abs(df_results_aux[f\"ds{stage}\"]-df_current_model[\"ds\"][stage-1])\n",
    "\n",
    "        for stage in range(1, df_current_model[\"num_stages\"]+1):\n",
    "            if stage==1:\n",
    "                df_results_aux=df_results_aux.sort_values([\"diff_ws1\",\"diff_d1\",\"diff_stages\",\"diff_ws2\",\"diff_depth\"])\n",
    "            else:\n",
    "                df_results_aux=df_results_aux.sort_values([f\"diff_ws{stage}\",f\"diff_d{stage}\",f\"diff_ws{stage-1}\",\"diff_stages\", \"diff_depth\"])\n",
    "\n",
    "            if stage==1:\n",
    "                first_row_values = df_results_aux[[\"diff_stages\", f\"diff_ws{stage}\", f\"diff_d{stage}\"]].iloc[0]\n",
    "                # Filter the DataFrame based on these values\n",
    "                filtered_df = df_results_aux[\n",
    "                    (df_results_aux[\"diff_stages\"] == first_row_values[\"diff_stages\"]) &\n",
    "                    (df_results_aux[f\"diff_ws{stage}\"] == first_row_values[f\"diff_ws{stage}\"]) &\n",
    "                    (df_results_aux[f\"diff_d{stage}\"] == first_row_values[f\"diff_d{stage}\"])\n",
    "                ]\n",
    "            else:\n",
    "                first_row_values = df_results_aux[[\"diff_stages\",f\"diff_ws{stage-1}\", f\"diff_ws{stage}\", f\"diff_d{stage}\"]].iloc[0]\n",
    "                # Filter the DataFrame based on these values\n",
    "                filtered_df = df_results_aux[\n",
    "                    (df_results_aux[\"diff_stages\"] == first_row_values[\"diff_stages\"]) &\n",
    "                    (df_results_aux[f\"diff_ws{stage-1}\"] == first_row_values[f\"diff_ws{stage-1}\"]) &\n",
    "                    (df_results_aux[f\"diff_ws{stage}\"] == first_row_values[f\"diff_ws{stage}\"]) &\n",
    "                    (df_results_aux[f\"diff_d{stage}\"] == first_row_values[f\"diff_d{stage}\"])\n",
    "                ]\n",
    "            filtered_dfs.append(filtered_df)\n",
    "\n",
    "        pool_individuals={}\n",
    "        items=[]\n",
    "        for idx, stage_df in enumerate(filtered_dfs):\n",
    "            items.append(dict(zip(stage_df.index.tolist(),stage_df.dataset.tolist())))\n",
    "        for idx, item in enumerate(items):\n",
    "            for i in range(0,len(items)):\n",
    "                if i !=idx:\n",
    "                    common_items = item.items() & items[i].items()\n",
    "                    #print(common_items)\n",
    "                    if common_items:\n",
    "                        pool_individuals[idx+1]=next(iter(common_items))\n",
    "                        break\n",
    "            if idx+1 not in pool_individuals:\n",
    "                 pool_individuals[idx+1]=next(iter(item.items()))\n",
    "        total_pool_individuals[model_name]=pool_individuals  \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "a00fb5af-f652-4018-b367-357ded104509",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#del models\n",
    "import gc\n",
    "gc.collect()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "ad0bf75f-9471-458f-847d-6e16c5a2727e",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/invisible_stork/config.yaml\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/apps/jupyterhub/jh3.1.1-py3.11/envs/pytorch-2.2.0/lib/python3.12/site-packages/torch/nn/modules/module.py:1352: UserWarning: Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
      "  warnings.warn(\"Using a non-full backward hook when the forward contains multiple autograd Nodes \"\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/flying_tody/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/honest_sloth/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/happy_hedgehog/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/daffodil_mackerel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/antique_taipan/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/adept_sponge/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/magic_pheasant/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/emerald_earthworm/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/fiery_heron/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/lyrical_skylark/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/ingenious_puffin/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/rose_mackerel/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/asparagus_mammoth/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/spectral_flamingo/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/cerulean_galago/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/impressive_binturong/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/uber_bat/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/cherry_mastiff/config.yaml\n",
      "Loading model: /home/woody/iwb3/iwb3021h/NAS_COMPETITION_RESULTS/classifier_train/Caitie/divergent_mole/config.yaml\n"
     ]
    }
   ],
   "source": [
    "import gc\n",
    "individuals=os.listdir(folder+\"/\"+dataset)\n",
    "individuals=[ind for ind in individuals if os.path.isdir(os.path.join(folder+\"/\"+dataset, ind)) and \".ipynb\" not in ind]\n",
    "#individuals = random.sample(individuals, 20)\n",
    "individuals=['invisible_stork',\n",
    " 'flying_tody',\n",
    " 'honest_sloth',\n",
    " 'happy_hedgehog',\n",
    " 'daffodil_mackerel',\n",
    " 'antique_taipan',\n",
    " 'adept_sponge',\n",
    " 'magic_pheasant',\n",
    " 'emerald_earthworm',\n",
    " 'fiery_heron',\n",
    " 'lyrical_skylark',\n",
    " 'ingenious_puffin',\n",
    " 'rose_mackerel',\n",
    " 'asparagus_mammoth',\n",
    " 'spectral_flamingo',\n",
    " 'cerulean_galago',\n",
    " 'impressive_binturong',\n",
    " 'uber_bat',\n",
    " 'cherry_mastiff',\n",
    " 'divergent_mole']\n",
    "syn_scores={}\n",
    "measures=[\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"]\n",
    "for individual in individuals:\n",
    "                gc.collect\n",
    "                ind_config=f\"{folder}/{dataset}/{individual}/config.yaml\"\n",
    "                \n",
    "                model_aux, _=rg.load_model(config_file=ind_config)\n",
    "                if preloaded:\n",
    "                    model_aux=transfer_weights(model_aux,individual,total_pool_individuals,rg)\n",
    "                syn_scores[individual]=find_measures(model_aux.to(\"cuda\"), new_valid_loader, (\"random\",len(new_valid_loader),metadata[\"num_classes\"]), \"cuda\", F.cross_entropy, measures )\n",
    "                \n",
    "                syn_scores[individual][\"grasp\"]=find_measures(model_aux.to(\"cuda\"), new_valid_loader_grasp, (\"grasp\",len(new_valid_loader_grasp),metadata[\"num_classes\"]), \"cuda\", F.cross_entropy, [\"grasp\"] )[\"grasp\"]\n",
    "                del model_aux\n",
    "                gc.collect\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "7d0309ef-91da-4991-b08a-d98a9a85a80f",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_syn=pd.DataFrame(syn_scores).T.reset_index().rename(columns={\"index\":\"name\"})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "c1ce790b-3331-4c52-a409-9e3937efed21",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sorted_df=train_data[train_data.name.isin(test_names)].sort_values(by=\"best_acc\",ascending=False)[[\"name\",\"best_acc\"]]\n",
    "df_syn=pd.merge(df_syn, sorted_df[[\"name\",\"best_acc\"]], on=\"name\")\n",
    "df_syn=df_syn.sort_values(by=\"best_acc\",ascending=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "6e3e61d8-2b6d-4229-b30d-85504615d787",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "for metric in [\"grasp\",\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"]:\n",
    "    if metric==\"jacob_cov\":\n",
    "        df_syn[f\"rank_{metric}\"]=df_syn[metric].rank(ascending=False).astype(int)\n",
    "    else:\n",
    "        df_syn[f\"rank_{metric}\"]=df_syn[metric].rank().astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "561b4829-d462-4aca-9ac0-5a187092918c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0      8\n",
       "13    10\n",
       "1      9\n",
       "5      1\n",
       "17     6\n",
       "11     4\n",
       "18     3\n",
       "12     7\n",
       "10     4\n",
       "16     2\n",
       "dtype: int64"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_syn.head(10)[[\"rank_jacob_cov\",\"rank_snip\",\"rank_grad_norm\"]].sum(axis=1).rank(ascending=True).astype(int)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "fe43441c-8364-454e-b251-8c6265937108",
   "metadata": {
    "tags": []
   },
   "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>name</th>\n",
       "      <th>fisher</th>\n",
       "      <th>grad_norm</th>\n",
       "      <th>jacob_cov</th>\n",
       "      <th>plain</th>\n",
       "      <th>snip</th>\n",
       "      <th>synflow</th>\n",
       "      <th>grasp</th>\n",
       "      <th>best_acc</th>\n",
       "      <th>rank_grasp</th>\n",
       "      <th>rank_fisher</th>\n",
       "      <th>rank_grad_norm</th>\n",
       "      <th>rank_jacob_cov</th>\n",
       "      <th>rank_plain</th>\n",
       "      <th>rank_snip</th>\n",
       "      <th>rank_synflow</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>invisible_stork</td>\n",
       "      <td>0.339233</td>\n",
       "      <td>84.290810</td>\n",
       "      <td>-128.997664</td>\n",
       "      <td>0.485008</td>\n",
       "      <td>471.623199</td>\n",
       "      <td>7.658091e+53</td>\n",
       "      <td>452.466675</td>\n",
       "      <td>90.55</td>\n",
       "      <td>17</td>\n",
       "      <td>17</td>\n",
       "      <td>18</td>\n",
       "      <td>11</td>\n",
       "      <td>20</td>\n",
       "      <td>18</td>\n",
       "      <td>15</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>asparagus_mammoth</td>\n",
       "      <td>4.807892</td>\n",
       "      <td>236.178848</td>\n",
       "      <td>-129.032097</td>\n",
       "      <td>-0.341567</td>\n",
       "      <td>1393.496948</td>\n",
       "      <td>7.809049e+64</td>\n",
       "      <td>15839.566406</td>\n",
       "      <td>88.02</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "      <td>15</td>\n",
       "      <td>1</td>\n",
       "      <td>20</td>\n",
       "      <td>20</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>flying_tody</td>\n",
       "      <td>0.374094</td>\n",
       "      <td>74.006508</td>\n",
       "      <td>-129.038862</td>\n",
       "      <td>0.219872</td>\n",
       "      <td>461.849274</td>\n",
       "      <td>7.738844e+44</td>\n",
       "      <td>-31.790359</td>\n",
       "      <td>87.58</td>\n",
       "      <td>5</td>\n",
       "      <td>18</td>\n",
       "      <td>17</td>\n",
       "      <td>17</td>\n",
       "      <td>17</td>\n",
       "      <td>17</td>\n",
       "      <td>13</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>antique_taipan</td>\n",
       "      <td>0.010136</td>\n",
       "      <td>10.139218</td>\n",
       "      <td>-128.965507</td>\n",
       "      <td>-0.000652</td>\n",
       "      <td>54.411110</td>\n",
       "      <td>1.008409e+27</td>\n",
       "      <td>-11.496610</td>\n",
       "      <td>86.85</td>\n",
       "      <td>11</td>\n",
       "      <td>3</td>\n",
       "      <td>2</td>\n",
       "      <td>7</td>\n",
       "      <td>2</td>\n",
       "      <td>7</td>\n",
       "      <td>4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>uber_bat</td>\n",
       "      <td>0.054573</td>\n",
       "      <td>25.989874</td>\n",
       "      <td>-129.037391</td>\n",
       "      <td>0.036742</td>\n",
       "      <td>152.927353</td>\n",
       "      <td>2.622048e+41</td>\n",
       "      <td>23.206848</td>\n",
       "      <td>86.51</td>\n",
       "      <td>14</td>\n",
       "      <td>14</td>\n",
       "      <td>12</td>\n",
       "      <td>16</td>\n",
       "      <td>8</td>\n",
       "      <td>15</td>\n",
       "      <td>12</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>ingenious_puffin</td>\n",
       "      <td>0.027172</td>\n",
       "      <td>27.886860</td>\n",
       "      <td>-128.882305</td>\n",
       "      <td>0.192485</td>\n",
       "      <td>91.771538</td>\n",
       "      <td>2.301706e+59</td>\n",
       "      <td>-33.630600</td>\n",
       "      <td>86.19</td>\n",
       "      <td>3</td>\n",
       "      <td>11</td>\n",
       "      <td>13</td>\n",
       "      <td>2</td>\n",
       "      <td>16</td>\n",
       "      <td>12</td>\n",
       "      <td>18</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>cherry_mastiff</td>\n",
       "      <td>0.019817</td>\n",
       "      <td>19.738598</td>\n",
       "      <td>-128.940606</td>\n",
       "      <td>0.112149</td>\n",
       "      <td>83.040024</td>\n",
       "      <td>2.789768e+33</td>\n",
       "      <td>-25.957006</td>\n",
       "      <td>85.60</td>\n",
       "      <td>7</td>\n",
       "      <td>9</td>\n",
       "      <td>10</td>\n",
       "      <td>5</td>\n",
       "      <td>13</td>\n",
       "      <td>10</td>\n",
       "      <td>8</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>rose_mackerel</td>\n",
       "      <td>0.281642</td>\n",
       "      <td>72.945198</td>\n",
       "      <td>-129.014253</td>\n",
       "      <td>0.060319</td>\n",
       "      <td>339.011383</td>\n",
       "      <td>2.533506e+57</td>\n",
       "      <td>850.405762</td>\n",
       "      <td>85.51</td>\n",
       "      <td>18</td>\n",
       "      <td>16</td>\n",
       "      <td>16</td>\n",
       "      <td>13</td>\n",
       "      <td>10</td>\n",
       "      <td>16</td>\n",
       "      <td>17</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>lyrical_skylark</td>\n",
       "      <td>0.011243</td>\n",
       "      <td>13.250108</td>\n",
       "      <td>-129.025070</td>\n",
       "      <td>0.057316</td>\n",
       "      <td>54.345139</td>\n",
       "      <td>7.102761e+31</td>\n",
       "      <td>-2.796352</td>\n",
       "      <td>85.42</td>\n",
       "      <td>12</td>\n",
       "      <td>6</td>\n",
       "      <td>7</td>\n",
       "      <td>14</td>\n",
       "      <td>9</td>\n",
       "      <td>6</td>\n",
       "      <td>7</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>impressive_binturong</td>\n",
       "      <td>0.012378</td>\n",
       "      <td>13.206054</td>\n",
       "      <td>-128.944454</td>\n",
       "      <td>0.026935</td>\n",
       "      <td>58.651211</td>\n",
       "      <td>2.892519e+29</td>\n",
       "      <td>-17.254631</td>\n",
       "      <td>84.69</td>\n",
       "      <td>9</td>\n",
       "      <td>7</td>\n",
       "      <td>6</td>\n",
       "      <td>6</td>\n",
       "      <td>7</td>\n",
       "      <td>8</td>\n",
       "      <td>5</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                    name    fisher   grad_norm   jacob_cov     plain  \\\n",
       "0        invisible_stork  0.339233   84.290810 -128.997664  0.485008   \n",
       "13     asparagus_mammoth  4.807892  236.178848 -129.032097 -0.341567   \n",
       "1            flying_tody  0.374094   74.006508 -129.038862  0.219872   \n",
       "5         antique_taipan  0.010136   10.139218 -128.965507 -0.000652   \n",
       "17              uber_bat  0.054573   25.989874 -129.037391  0.036742   \n",
       "11      ingenious_puffin  0.027172   27.886860 -128.882305  0.192485   \n",
       "18        cherry_mastiff  0.019817   19.738598 -128.940606  0.112149   \n",
       "12         rose_mackerel  0.281642   72.945198 -129.014253  0.060319   \n",
       "10       lyrical_skylark  0.011243   13.250108 -129.025070  0.057316   \n",
       "16  impressive_binturong  0.012378   13.206054 -128.944454  0.026935   \n",
       "\n",
       "           snip       synflow         grasp  best_acc  rank_grasp  \\\n",
       "0    471.623199  7.658091e+53    452.466675     90.55          17   \n",
       "13  1393.496948  7.809049e+64  15839.566406     88.02          20   \n",
       "1    461.849274  7.738844e+44    -31.790359     87.58           5   \n",
       "5     54.411110  1.008409e+27    -11.496610     86.85          11   \n",
       "17   152.927353  2.622048e+41     23.206848     86.51          14   \n",
       "11    91.771538  2.301706e+59    -33.630600     86.19           3   \n",
       "18    83.040024  2.789768e+33    -25.957006     85.60           7   \n",
       "12   339.011383  2.533506e+57    850.405762     85.51          18   \n",
       "10    54.345139  7.102761e+31     -2.796352     85.42          12   \n",
       "16    58.651211  2.892519e+29    -17.254631     84.69           9   \n",
       "\n",
       "    rank_fisher  rank_grad_norm  rank_jacob_cov  rank_plain  rank_snip  \\\n",
       "0            17              18              11          20         18   \n",
       "13           20              20              15           1         20   \n",
       "1            18              17              17          17         17   \n",
       "5             3               2               7           2          7   \n",
       "17           14              12              16           8         15   \n",
       "11           11              13               2          16         12   \n",
       "18            9              10               5          13         10   \n",
       "12           16              16              13          10         16   \n",
       "10            6               7              14           9          6   \n",
       "16            7               6               6           7          8   \n",
       "\n",
       "    rank_synflow  \n",
       "0             15  \n",
       "13            20  \n",
       "1             13  \n",
       "5              4  \n",
       "17            12  \n",
       "11            18  \n",
       "18             8  \n",
       "12            17  \n",
       "10             7  \n",
       "16             5  "
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_syn.head(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "8056a184-453b-400a-b4e4-350ca734a0a2",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "from scipy.stats import spearmanr\n",
    "dict_spearman={}\n",
    "dict_pearson={}\n",
    "for metric in [\"grasp\",\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"]:\n",
    "#for metric in [\"snip\"]:\n",
    "        spearman_corr, _ = spearmanr(df_syn['best_acc'],df_syn[f\"{metric}\"])\n",
    "        pearson_corr= df_syn['best_acc'].corr(df_syn[metric])\n",
    "        \n",
    "        dict_spearman[metric]=spearman_corr\n",
    "        dict_pearson[metric]=pearson_corr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "367a30eb-919a-4df7-8241-6844bb51b3fc",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "corr_df=pd.DataFrame([dict_spearman])\n",
    "corr_df[\"dataset\"]=dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "0d1cedc9-bdea-4607-842b-fc015f542563",
   "metadata": {
    "tags": []
   },
   "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>grasp</th>\n",
       "      <th>fisher</th>\n",
       "      <th>grad_norm</th>\n",
       "      <th>jacob_cov</th>\n",
       "      <th>plain</th>\n",
       "      <th>snip</th>\n",
       "      <th>synflow</th>\n",
       "      <th>dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.269173</td>\n",
       "      <td>0.362406</td>\n",
       "      <td>0.347368</td>\n",
       "      <td>-0.067669</td>\n",
       "      <td>-0.052632</td>\n",
       "      <td>0.482707</td>\n",
       "      <td>0.245113</td>\n",
       "      <td>Caitie</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      grasp    fisher  grad_norm  jacob_cov     plain      snip   synflow  \\\n",
       "0  0.269173  0.362406   0.347368  -0.067669 -0.052632  0.482707  0.245113   \n",
       "\n",
       "  dataset  \n",
       "0  Caitie  "
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corr_df #aug6"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "323a3d19-3531-4990-aa79-50a7cac77588",
   "metadata": {
    "tags": []
   },
   "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>grasp</th>\n",
       "      <th>fisher</th>\n",
       "      <th>grad_norm</th>\n",
       "      <th>jacob_cov</th>\n",
       "      <th>plain</th>\n",
       "      <th>snip</th>\n",
       "      <th>synflow</th>\n",
       "      <th>dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.269173</td>\n",
       "      <td>0.362406</td>\n",
       "      <td>0.347368</td>\n",
       "      <td>-0.067669</td>\n",
       "      <td>-0.052632</td>\n",
       "      <td>0.482707</td>\n",
       "      <td>0.245113</td>\n",
       "      <td>Caitie</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      grasp    fisher  grad_norm  jacob_cov     plain      snip   synflow  \\\n",
       "0  0.269173  0.362406   0.347368  -0.067669 -0.052632  0.482707  0.245113   \n",
       "\n",
       "  dataset  \n",
       "0  Caitie  "
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corr_df #aug9"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "9fe041bd-7f67-4fbe-b2db-31bf8bc02e49",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df_syn.to_csv(f\"zcost_proxies/results/augs/{dataset}_t{aug}.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "f5917952-0dd9-422c-8375-d0d6073de5c6",
   "metadata": {
    "tags": []
   },
   "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>grasp</th>\n",
       "      <th>fisher</th>\n",
       "      <th>grad_norm</th>\n",
       "      <th>jacob_cov</th>\n",
       "      <th>plain</th>\n",
       "      <th>snip</th>\n",
       "      <th>synflow</th>\n",
       "      <th>dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-0.413534</td>\n",
       "      <td>0.369925</td>\n",
       "      <td>0.44812</td>\n",
       "      <td>0.085714</td>\n",
       "      <td>0.009023</td>\n",
       "      <td>0.478195</td>\n",
       "      <td>0.245113</td>\n",
       "      <td>Caitie</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      grasp    fisher  grad_norm  jacob_cov     plain      snip   synflow  \\\n",
       "0 -0.413534  0.369925    0.44812   0.085714  0.009023  0.478195  0.245113   \n",
       "\n",
       "  dataset  \n",
       "0  Caitie  "
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corr_df #aug5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "3f370e7f-ccd2-4fad-9ac7-ef5513530378",
   "metadata": {
    "tags": []
   },
   "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>grasp</th>\n",
       "      <th>fisher</th>\n",
       "      <th>grad_norm</th>\n",
       "      <th>jacob_cov</th>\n",
       "      <th>plain</th>\n",
       "      <th>snip</th>\n",
       "      <th>synflow</th>\n",
       "      <th>dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.085487</td>\n",
       "      <td>-0.5661</td>\n",
       "      <td>-0.542704</td>\n",
       "      <td>0.359396</td>\n",
       "      <td>0.082358</td>\n",
       "      <td>-0.522087</td>\n",
       "      <td>-0.37394</td>\n",
       "      <td>Gutenberg</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      grasp  fisher  grad_norm  jacob_cov     plain      snip  synflow  \\\n",
       "0  0.085487 -0.5661  -0.542704   0.359396  0.082358 -0.522087 -0.37394   \n",
       "\n",
       "     dataset  \n",
       "0  Gutenberg  "
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corr_df #aug0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "d6f9a1b7-2282-40dd-81b7-709020795bf3",
   "metadata": {
    "tags": []
   },
   "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>grasp</th>\n",
       "      <th>fisher</th>\n",
       "      <th>grad_norm</th>\n",
       "      <th>jacob_cov</th>\n",
       "      <th>plain</th>\n",
       "      <th>snip</th>\n",
       "      <th>synflow</th>\n",
       "      <th>dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>-0.099231</td>\n",
       "      <td>-0.561821</td>\n",
       "      <td>-0.546281</td>\n",
       "      <td>0.228095</td>\n",
       "      <td>0.053812</td>\n",
       "      <td>-0.518833</td>\n",
       "      <td>-0.374568</td>\n",
       "      <td>Gutenberg</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      grasp    fisher  grad_norm  jacob_cov     plain      snip   synflow  \\\n",
       "0 -0.099231 -0.561821  -0.546281   0.228095  0.053812 -0.518833 -0.374568   \n",
       "\n",
       "     dataset  \n",
       "0  Gutenberg  "
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corr_df # Aug 1-best"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "aa236949-f9b0-46a0-869c-2c5c73ef0798",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "corr_dfs=[]\n",
    "for dataset in [\"Sadie\",\"Chester\",\"Caitie\",\"Adaline\",\"Mateo\",\"LaMelo\",\"Gutenberg\"]:\n",
    "    corr_dfs.append(pd.read_csv(f\"zcost_proxies/results/corr_{dataset}.csv\", index_col=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "6d822d6b-271c-42d5-8cda-413bc4dd789e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "corr_dfs=pd.concat(corr_dfs).set_index(\"dataset\").T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "878088d5-69b3-4980-a229-513afc9f4b51",
   "metadata": {
    "tags": []
   },
   "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>dataset</th>\n",
       "      <th>Sadie</th>\n",
       "      <th>Chester</th>\n",
       "      <th>Caitie</th>\n",
       "      <th>Adaline</th>\n",
       "      <th>Mateo</th>\n",
       "      <th>LaMelo</th>\n",
       "      <th>Gutenberg</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>grasp</th>\n",
       "      <td>-0.015370</td>\n",
       "      <td>-0.031674</td>\n",
       "      <td>-0.056426</td>\n",
       "      <td>0.017826</td>\n",
       "      <td>0.075161</td>\n",
       "      <td>0.096642</td>\n",
       "      <td>0.085339</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>fisher</th>\n",
       "      <td>-0.299095</td>\n",
       "      <td>-0.396435</td>\n",
       "      <td>0.244160</td>\n",
       "      <td>-0.320120</td>\n",
       "      <td>-0.257678</td>\n",
       "      <td>-0.394138</td>\n",
       "      <td>-0.430577</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>grad_norm</th>\n",
       "      <td>-0.311202</td>\n",
       "      <td>-0.387656</td>\n",
       "      <td>0.272185</td>\n",
       "      <td>-0.298897</td>\n",
       "      <td>-0.231163</td>\n",
       "      <td>-0.365825</td>\n",
       "      <td>-0.402824</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>jacob_cov</th>\n",
       "      <td>0.705298</td>\n",
       "      <td>-0.034257</td>\n",
       "      <td>0.301509</td>\n",
       "      <td>0.698369</td>\n",
       "      <td>0.718633</td>\n",
       "      <td>0.390085</td>\n",
       "      <td>0.488031</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>plain</th>\n",
       "      <td>0.047703</td>\n",
       "      <td>0.071265</td>\n",
       "      <td>0.198465</td>\n",
       "      <td>0.157651</td>\n",
       "      <td>-0.026278</td>\n",
       "      <td>0.018055</td>\n",
       "      <td>0.119690</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>snip</th>\n",
       "      <td>-0.254757</td>\n",
       "      <td>-0.375072</td>\n",
       "      <td>0.338454</td>\n",
       "      <td>-0.268118</td>\n",
       "      <td>-0.198280</td>\n",
       "      <td>-0.330324</td>\n",
       "      <td>-0.363375</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>synflow</th>\n",
       "      <td>-0.208974</td>\n",
       "      <td>-0.328032</td>\n",
       "      <td>0.302363</td>\n",
       "      <td>-0.020706</td>\n",
       "      <td>0.022250</td>\n",
       "      <td>-0.078566</td>\n",
       "      <td>-0.301963</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "dataset       Sadie   Chester    Caitie   Adaline     Mateo    LaMelo  \\\n",
       "grasp     -0.015370 -0.031674 -0.056426  0.017826  0.075161  0.096642   \n",
       "fisher    -0.299095 -0.396435  0.244160 -0.320120 -0.257678 -0.394138   \n",
       "grad_norm -0.311202 -0.387656  0.272185 -0.298897 -0.231163 -0.365825   \n",
       "jacob_cov  0.705298 -0.034257  0.301509  0.698369  0.718633  0.390085   \n",
       "plain      0.047703  0.071265  0.198465  0.157651 -0.026278  0.018055   \n",
       "snip      -0.254757 -0.375072  0.338454 -0.268118 -0.198280 -0.330324   \n",
       "synflow   -0.208974 -0.328032  0.302363 -0.020706  0.022250 -0.078566   \n",
       "\n",
       "dataset    Gutenberg  \n",
       "grasp       0.085339  \n",
       "fisher     -0.430577  \n",
       "grad_norm  -0.402824  \n",
       "jacob_cov   0.488031  \n",
       "plain       0.119690  \n",
       "snip       -0.363375  \n",
       "synflow    -0.301963  "
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corr_dfs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c0f6b296-6f34-4e24-ac00-c58e2af026da",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b4b2c4ae-4a99-4a67-9bd9-dd148687ac7d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "https://plot.ly"
       },
       "data": [
        {
         "insidetextanchor": "middle",
         "marker": {
          "color": "#4E79A7"
         },
         "name": "Sadie",
         "showlegend": false,
         "text": [
          -0.0153703684446437,
          -0.2990953988890124,
          -0.3112019638946393,
          0.7052977590778057,
          0.0477034800221714,
          -0.2547573632434051,
          -0.208973767597126
         ],
         "textposition": "inside",
         "texttemplate": "%{text:.2f}",
         "type": "bar",
         "width": 0.6,
         "x": [
          "grasp",
          "fisher",
          "grad_norm",
          "jacob_cov",
          "plain",
          "snip",
          "synflow"
         ],
         "xaxis": "x",
         "y": [
          -0.0153703684446437,
          -0.2990953988890124,
          -0.3112019638946393,
          0.7052977590778057,
          0.0477034800221714,
          -0.2547573632434051,
          -0.208973767597126
         ],
         "yaxis": "y"
        },
        {
         "insidetextanchor": "middle",
         "marker": {
          "color": "#F28E2B"
         },
         "name": "Chester",
         "showlegend": false,
         "text": [
          -0.0316735482175316,
          -0.3964350332267981,
          -0.3876563105106574,
          -0.0342571596498135,
          0.0712646153404433,
          -0.3750716225663163,
          -0.3280318369995272
         ],
         "textposition": "inside",
         "texttemplate": "%{text:.2f}",
         "type": "bar",
         "width": 0.6,
         "x": [
          "grasp",
          "fisher",
          "grad_norm",
          "jacob_cov",
          "plain",
          "snip",
          "synflow"
         ],
         "xaxis": "x2",
         "y": [
          -0.0316735482175316,
          -0.3964350332267981,
          -0.3876563105106574,
          -0.0342571596498135,
          0.0712646153404433,
          -0.3750716225663163,
          -0.3280318369995272
         ],
         "yaxis": "y2"
        },
        {
         "insidetextanchor": "middle",
         "marker": {
          "color": "#76B7B2"
         },
         "name": "Caitie",
         "showlegend": false,
         "text": [
          -0.0564261180211917,
          0.2441600164405775,
          0.2721851023142161,
          0.3015089116795598,
          0.1984654556929499,
          0.3384541773251736,
          0.3023633350293659
         ],
         "textposition": "inside",
         "texttemplate": "%{text:.2f}",
         "type": "bar",
         "width": 0.6,
         "x": [
          "grasp",
          "fisher",
          "grad_norm",
          "jacob_cov",
          "plain",
          "snip",
          "synflow"
         ],
         "xaxis": "x3",
         "y": [
          -0.0564261180211917,
          0.2441600164405775,
          0.2721851023142161,
          0.3015089116795598,
          0.1984654556929499,
          0.3384541773251736,
          0.3023633350293659
         ],
         "yaxis": "y3"
        },
        {
         "insidetextanchor": "middle",
         "marker": {
          "color": "#59A14F"
         },
         "name": "Adaline",
         "showlegend": false,
         "text": [
          0.0178258605268478,
          -0.3201197861544484,
          -0.2988968326852331,
          0.6983689222739364,
          0.1576511529595525,
          -0.2681178291504966,
          -0.0207060903153823
         ],
         "textposition": "inside",
         "texttemplate": "%{text:.2f}",
         "type": "bar",
         "width": 0.6,
         "x": [
          "grasp",
          "fisher",
          "grad_norm",
          "jacob_cov",
          "plain",
          "snip",
          "synflow"
         ],
         "xaxis": "x4",
         "y": [
          0.0178258605268478,
          -0.3201197861544484,
          -0.2988968326852331,
          0.6983689222739364,
          0.1576511529595525,
          -0.2681178291504966,
          -0.0207060903153823
         ],
         "yaxis": "y4"
        },
        {
         "insidetextanchor": "middle",
         "marker": {
          "color": "#E15759"
         },
         "name": "Mateo",
         "showlegend": false,
         "text": [
          0.075160658196889,
          -0.2576778098327018,
          -0.2311633882953341,
          0.7186328514518887,
          -0.026278274757467,
          -0.1982799491941771,
          0.022249888512104
         ],
         "textposition": "inside",
         "texttemplate": "%{text:.2f}",
         "type": "bar",
         "width": 0.6,
         "x": [
          "grasp",
          "fisher",
          "grad_norm",
          "jacob_cov",
          "plain",
          "snip",
          "synflow"
         ],
         "xaxis": "x5",
         "y": [
          0.075160658196889,
          -0.2576778098327018,
          -0.2311633882953341,
          0.7186328514518887,
          -0.026278274757467,
          -0.1982799491941771,
          0.022249888512104
         ],
         "yaxis": "y5"
        },
        {
         "insidetextanchor": "middle",
         "marker": {
          "color": "#FF9DA7"
         },
         "name": "LaMelo",
         "showlegend": false,
         "text": [
          0.0966418949406922,
          -0.3941380756832373,
          -0.3658251154815964,
          0.3900854294726013,
          0.0180545909589514,
          -0.3303236568600614,
          -0.0785664677544368
         ],
         "textposition": "inside",
         "texttemplate": "%{text:.2f}",
         "type": "bar",
         "width": 0.6,
         "x": [
          "grasp",
          "fisher",
          "grad_norm",
          "jacob_cov",
          "plain",
          "snip",
          "synflow"
         ],
         "xaxis": "x6",
         "y": [
          0.0966418949406922,
          -0.3941380756832373,
          -0.3658251154815964,
          0.3900854294726013,
          0.0180545909589514,
          -0.3303236568600614,
          -0.0785664677544368
         ],
         "yaxis": "y6"
        },
        {
         "insidetextanchor": "middle",
         "marker": {
          "color": "#9C755F"
         },
         "name": "Gutenberg",
         "showlegend": false,
         "text": [
          0.0853390469627543,
          -0.4305768495706101,
          -0.4028239104388179,
          0.4880308508137911,
          0.1196897588908262,
          -0.3633752882494835,
          -0.3019625344274433
         ],
         "textposition": "inside",
         "texttemplate": "%{text:.2f}",
         "type": "bar",
         "width": 0.6,
         "x": [
          "grasp",
          "fisher",
          "grad_norm",
          "jacob_cov",
          "plain",
          "snip",
          "synflow"
         ],
         "xaxis": "x7",
         "y": [
          0.0853390469627543,
          -0.4305768495706101,
          -0.4028239104388179,
          0.4880308508137911,
          0.1196897588908262,
          -0.3633752882494835,
          -0.3019625344274433
         ],
         "yaxis": "y7"
        }
       ],
       "layout": {
        "annotations": [
         {
          "font": {
           "size": 16
          },
          "showarrow": false,
          "text": "Sadie",
          "x": 0.225,
          "xanchor": "center",
          "xref": "paper",
          "y": 1,
          "yanchor": "bottom",
          "yref": "paper"
         },
         {
          "font": {
           "size": 16
          },
          "showarrow": false,
          "text": "Chester",
          "x": 0.775,
          "xanchor": "center",
          "xref": "paper",
          "y": 1,
          "yanchor": "bottom",
          "yref": "paper"
         },
         {
          "font": {
           "size": 16
          },
          "showarrow": false,
          "text": "Caitie",
          "x": 0.225,
          "xanchor": "center",
          "xref": "paper",
          "y": 0.7124999999999999,
          "yanchor": "bottom",
          "yref": "paper"
         },
         {
          "font": {
           "size": 16
          },
          "showarrow": false,
          "text": "Adaline",
          "x": 0.775,
          "xanchor": "center",
          "xref": "paper",
          "y": 0.7124999999999999,
          "yanchor": "bottom",
          "yref": "paper"
         },
         {
          "font": {
           "size": 16
          },
          "showarrow": false,
          "text": "Mateo",
          "x": 0.225,
          "xanchor": "center",
          "xref": "paper",
          "y": 0.425,
          "yanchor": "bottom",
          "yref": "paper"
         },
         {
          "font": {
           "size": 16
          },
          "showarrow": false,
          "text": "LaMelo",
          "x": 0.775,
          "xanchor": "center",
          "xref": "paper",
          "y": 0.425,
          "yanchor": "bottom",
          "yref": "paper"
         },
         {
          "font": {
           "size": 16
          },
          "showarrow": false,
          "text": "Gutenberg",
          "x": 0.225,
          "xanchor": "center",
          "xref": "paper",
          "y": 0.1375,
          "yanchor": "bottom",
          "yref": "paper"
         }
        ],
        "font": {
         "size": 12
        },
        "height": 1200,
        "margin": {
         "b": 40,
         "l": 60,
         "r": 60,
         "t": 100
        },
        "paper_bgcolor": "white",
        "plot_bgcolor": "rgba(0, 0, 0, 0)",
        "template": {
         "data": {
          "bar": [
           {
            "error_x": {
             "color": "#2a3f5f"
            },
            "error_y": {
             "color": "#2a3f5f"
            },
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "bar"
           }
          ],
          "barpolar": [
           {
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "barpolar"
           }
          ],
          "carpet": [
           {
            "aaxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "baxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "type": "carpet"
           }
          ],
          "choropleth": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "choropleth"
           }
          ],
          "contour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "contour"
           }
          ],
          "contourcarpet": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "contourcarpet"
           }
          ],
          "heatmap": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmap"
           }
          ],
          "heatmapgl": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmapgl"
           }
          ],
          "histogram": [
           {
            "marker": {
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "histogram"
           }
          ],
          "histogram2d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2d"
           }
          ],
          "histogram2dcontour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2dcontour"
           }
          ],
          "mesh3d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "mesh3d"
           }
          ],
          "parcoords": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "parcoords"
           }
          ],
          "pie": [
           {
            "automargin": true,
            "type": "pie"
           }
          ],
          "scatter": [
           {
            "fillpattern": {
             "fillmode": "overlay",
             "size": 10,
             "solidity": 0.2
            },
            "type": "scatter"
           }
          ],
          "scatter3d": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatter3d"
           }
          ],
          "scattercarpet": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattercarpet"
           }
          ],
          "scattergeo": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergeo"
           }
          ],
          "scattergl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergl"
           }
          ],
          "scattermapbox": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattermapbox"
           }
          ],
          "scatterpolar": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolar"
           }
          ],
          "scatterpolargl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolargl"
           }
          ],
          "scatterternary": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterternary"
           }
          ],
          "surface": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "surface"
           }
          ],
          "table": [
           {
            "cells": {
             "fill": {
              "color": "#EBF0F8"
             },
             "line": {
              "color": "white"
             }
            },
            "header": {
             "fill": {
              "color": "#C8D4E3"
             },
             "line": {
              "color": "white"
             }
            },
            "type": "table"
           }
          ]
         },
         "layout": {
          "annotationdefaults": {
           "arrowcolor": "#2a3f5f",
           "arrowhead": 0,
           "arrowwidth": 1
          },
          "autotypenumbers": "strict",
          "coloraxis": {
           "colorbar": {
            "outlinewidth": 0,
            "ticks": ""
           }
          },
          "colorscale": {
           "diverging": [
            [
             0,
             "#8e0152"
            ],
            [
             0.1,
             "#c51b7d"
            ],
            [
             0.2,
             "#de77ae"
            ],
            [
             0.3,
             "#f1b6da"
            ],
            [
             0.4,
             "#fde0ef"
            ],
            [
             0.5,
             "#f7f7f7"
            ],
            [
             0.6,
             "#e6f5d0"
            ],
            [
             0.7,
             "#b8e186"
            ],
            [
             0.8,
             "#7fbc41"
            ],
            [
             0.9,
             "#4d9221"
            ],
            [
             1,
             "#276419"
            ]
           ],
           "sequential": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ],
           "sequentialminus": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ]
          },
          "colorway": [
           "#636efa",
           "#EF553B",
           "#00cc96",
           "#ab63fa",
           "#FFA15A",
           "#19d3f3",
           "#FF6692",
           "#B6E880",
           "#FF97FF",
           "#FECB52"
          ],
          "font": {
           "color": "#2a3f5f"
          },
          "geo": {
           "bgcolor": "white",
           "lakecolor": "white",
           "landcolor": "#E5ECF6",
           "showlakes": true,
           "showland": true,
           "subunitcolor": "white"
          },
          "hoverlabel": {
           "align": "left"
          },
          "hovermode": "closest",
          "mapbox": {
           "style": "light"
          },
          "paper_bgcolor": "white",
          "plot_bgcolor": "#E5ECF6",
          "polar": {
           "angularaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "radialaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "scene": {
           "xaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "yaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "zaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           }
          },
          "shapedefaults": {
           "line": {
            "color": "#2a3f5f"
           }
          },
          "ternary": {
           "aaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "baxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "caxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "title": {
           "x": 0.05
          },
          "xaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          },
          "yaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          }
         }
        },
        "title": {
         "font": {
          "size": 22
         },
         "text": "<b>Spearmann Correlation of Each Zero-Cost Metric</b>",
         "x": 0.5
        },
        "width": 800,
        "xaxis": {
         "anchor": "y",
         "autorange": true,
         "domain": [
          0,
          0.45
         ],
         "range": [
          -0.5,
          6.5
         ],
         "tickangle": -45,
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Metrics</b>"
         },
         "type": "category"
        },
        "xaxis2": {
         "anchor": "y2",
         "autorange": true,
         "domain": [
          0.55,
          1
         ],
         "range": [
          -0.5,
          6.5
         ],
         "tickangle": -45,
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Metrics</b>"
         },
         "type": "category"
        },
        "xaxis3": {
         "anchor": "y3",
         "autorange": true,
         "domain": [
          0,
          0.45
         ],
         "range": [
          -0.5,
          6.5
         ],
         "tickangle": -45,
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Metrics</b>"
         },
         "type": "category"
        },
        "xaxis4": {
         "anchor": "y4",
         "autorange": true,
         "domain": [
          0.55,
          1
         ],
         "range": [
          -0.5,
          6.5
         ],
         "tickangle": -45,
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Metrics</b>"
         },
         "type": "category"
        },
        "xaxis5": {
         "anchor": "y5",
         "autorange": true,
         "domain": [
          0,
          0.45
         ],
         "range": [
          -0.5,
          6.5
         ],
         "tickangle": -45,
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Metrics</b>"
         },
         "type": "category"
        },
        "xaxis6": {
         "anchor": "y6",
         "autorange": true,
         "domain": [
          0.55,
          1
         ],
         "range": [
          -0.5,
          6.5
         ],
         "tickangle": -45,
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Metrics</b>"
         },
         "type": "category"
        },
        "xaxis7": {
         "anchor": "y7",
         "autorange": true,
         "domain": [
          0,
          0.45
         ],
         "range": [
          -0.5,
          6.5
         ],
         "tickangle": -45,
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Metrics</b>"
         },
         "type": "category"
        },
        "xaxis8": {
         "anchor": "y8",
         "domain": [
          0.55,
          1
         ],
         "tickangle": -45,
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Metrics</b>"
         }
        },
        "yaxis": {
         "anchor": "x",
         "domain": [
          0.8625,
          1
         ],
         "range": [
          -0.5,
          0.8
         ],
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Correlation</b>"
         },
         "type": "linear"
        },
        "yaxis2": {
         "anchor": "x2",
         "domain": [
          0.8625,
          1
         ],
         "range": [
          -0.5,
          0.8
         ],
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Correlation</b>"
         },
         "type": "linear"
        },
        "yaxis3": {
         "anchor": "x3",
         "domain": [
          0.575,
          0.7124999999999999
         ],
         "range": [
          -0.5,
          0.8
         ],
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Correlation</b>"
         },
         "type": "linear"
        },
        "yaxis4": {
         "anchor": "x4",
         "domain": [
          0.575,
          0.7124999999999999
         ],
         "range": [
          -0.5,
          0.8
         ],
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Correlation</b>"
         },
         "type": "linear"
        },
        "yaxis5": {
         "anchor": "x5",
         "domain": [
          0.2875,
          0.425
         ],
         "range": [
          -0.5,
          0.8
         ],
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Correlation</b>"
         },
         "type": "linear"
        },
        "yaxis6": {
         "anchor": "x6",
         "domain": [
          0.2875,
          0.425
         ],
         "range": [
          -0.5,
          0.8
         ],
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Correlation</b>"
         },
         "type": "linear"
        },
        "yaxis7": {
         "anchor": "x7",
         "domain": [
          0,
          0.1375
         ],
         "range": [
          -0.5,
          0.8
         ],
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Correlation</b>"
         },
         "type": "linear"
        },
        "yaxis8": {
         "anchor": "x8",
         "domain": [
          0,
          0.1375
         ],
         "tickfont": {
          "size": 10
         },
         "title": {
          "text": "<b>Correlation</b>"
         }
        }
       }
      },
      "image/png": "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",
      "text/html": [
       "<div>                            <div id=\"968aece1-4c6c-455f-a010-670e03ff33a9\" class=\"plotly-graph-div\" style=\"height:1200px; width:800px;\"></div>            <script type=\"text/javascript\">                require([\"plotly\"], function(Plotly) {                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"968aece1-4c6c-455f-a010-670e03ff33a9\")) {                    Plotly.newPlot(                        \"968aece1-4c6c-455f-a010-670e03ff33a9\",                        [{\"insidetextanchor\":\"middle\",\"marker\":{\"color\":\"#4E79A7\"},\"name\":\"Sadie\",\"showlegend\":false,\"text\":[-0.0153703684446437,-0.2990953988890124,-0.3112019638946393,0.7052977590778057,0.0477034800221714,-0.2547573632434051,-0.208973767597126],\"textposition\":\"inside\",\"texttemplate\":\"%{text:.2f}\",\"width\":0.6,\"x\":[\"grasp\",\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"],\"y\":[-0.0153703684446437,-0.2990953988890124,-0.3112019638946393,0.7052977590778057,0.0477034800221714,-0.2547573632434051,-0.208973767597126],\"type\":\"bar\",\"xaxis\":\"x\",\"yaxis\":\"y\"},{\"insidetextanchor\":\"middle\",\"marker\":{\"color\":\"#F28E2B\"},\"name\":\"Chester\",\"showlegend\":false,\"text\":[-0.0316735482175316,-0.3964350332267981,-0.3876563105106574,-0.0342571596498135,0.0712646153404433,-0.3750716225663163,-0.3280318369995272],\"textposition\":\"inside\",\"texttemplate\":\"%{text:.2f}\",\"width\":0.6,\"x\":[\"grasp\",\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"],\"y\":[-0.0316735482175316,-0.3964350332267981,-0.3876563105106574,-0.0342571596498135,0.0712646153404433,-0.3750716225663163,-0.3280318369995272],\"type\":\"bar\",\"xaxis\":\"x2\",\"yaxis\":\"y2\"},{\"insidetextanchor\":\"middle\",\"marker\":{\"color\":\"#76B7B2\"},\"name\":\"Caitie\",\"showlegend\":false,\"text\":[-0.0564261180211917,0.2441600164405775,0.2721851023142161,0.3015089116795598,0.1984654556929499,0.3384541773251736,0.3023633350293659],\"textposition\":\"inside\",\"texttemplate\":\"%{text:.2f}\",\"width\":0.6,\"x\":[\"grasp\",\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"],\"y\":[-0.0564261180211917,0.2441600164405775,0.2721851023142161,0.3015089116795598,0.1984654556929499,0.3384541773251736,0.3023633350293659],\"type\":\"bar\",\"xaxis\":\"x3\",\"yaxis\":\"y3\"},{\"insidetextanchor\":\"middle\",\"marker\":{\"color\":\"#59A14F\"},\"name\":\"Adaline\",\"showlegend\":false,\"text\":[0.0178258605268478,-0.3201197861544484,-0.2988968326852331,0.6983689222739364,0.1576511529595525,-0.2681178291504966,-0.0207060903153823],\"textposition\":\"inside\",\"texttemplate\":\"%{text:.2f}\",\"width\":0.6,\"x\":[\"grasp\",\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"],\"y\":[0.0178258605268478,-0.3201197861544484,-0.2988968326852331,0.6983689222739364,0.1576511529595525,-0.2681178291504966,-0.0207060903153823],\"type\":\"bar\",\"xaxis\":\"x4\",\"yaxis\":\"y4\"},{\"insidetextanchor\":\"middle\",\"marker\":{\"color\":\"#E15759\"},\"name\":\"Mateo\",\"showlegend\":false,\"text\":[0.075160658196889,-0.2576778098327018,-0.2311633882953341,0.7186328514518887,-0.026278274757467,-0.1982799491941771,0.022249888512104],\"textposition\":\"inside\",\"texttemplate\":\"%{text:.2f}\",\"width\":0.6,\"x\":[\"grasp\",\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"],\"y\":[0.075160658196889,-0.2576778098327018,-0.2311633882953341,0.7186328514518887,-0.026278274757467,-0.1982799491941771,0.022249888512104],\"type\":\"bar\",\"xaxis\":\"x5\",\"yaxis\":\"y5\"},{\"insidetextanchor\":\"middle\",\"marker\":{\"color\":\"#FF9DA7\"},\"name\":\"LaMelo\",\"showlegend\":false,\"text\":[0.0966418949406922,-0.3941380756832373,-0.3658251154815964,0.3900854294726013,0.0180545909589514,-0.3303236568600614,-0.0785664677544368],\"textposition\":\"inside\",\"texttemplate\":\"%{text:.2f}\",\"width\":0.6,\"x\":[\"grasp\",\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"],\"y\":[0.0966418949406922,-0.3941380756832373,-0.3658251154815964,0.3900854294726013,0.0180545909589514,-0.3303236568600614,-0.0785664677544368],\"type\":\"bar\",\"xaxis\":\"x6\",\"yaxis\":\"y6\"},{\"insidetextanchor\":\"middle\",\"marker\":{\"color\":\"#9C755F\"},\"name\":\"Gutenberg\",\"showlegend\":false,\"text\":[0.0853390469627543,-0.4305768495706101,-0.4028239104388179,0.4880308508137911,0.1196897588908262,-0.3633752882494835,-0.3019625344274433],\"textposition\":\"inside\",\"texttemplate\":\"%{text:.2f}\",\"width\":0.6,\"x\":[\"grasp\",\"fisher\",\"grad_norm\",\"jacob_cov\",\"plain\",\"snip\",\"synflow\"],\"y\":[0.0853390469627543,-0.4305768495706101,-0.4028239104388179,0.4880308508137911,0.1196897588908262,-0.3633752882494835,-0.3019625344274433],\"type\":\"bar\",\"xaxis\":\"x7\",\"yaxis\":\"y7\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"bar\":[{\"error_x\":{\"color\":\"#2a3f5f\"},\"error_y\":{\"color\":\"#2a3f5f\"},\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"bar\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"carpet\":[{\"aaxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"baxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"type\":\"carpet\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"sequentialminus\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"diverging\":[[0,\"#8e0152\"],[0.1,\"#c51b7d\"],[0.2,\"#de77ae\"],[0.3,\"#f1b6da\"],[0.4,\"#fde0ef\"],[0.5,\"#f7f7f7\"],[0.6,\"#e6f5d0\"],[0.7,\"#b8e186\"],[0.8,\"#7fbc41\"],[0.9,\"#4d9221\"],[1,\"#276419\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,0.45],\"title\":{\"text\":\"\\u003cb\\u003eMetrics\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10},\"tickangle\":-45},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.8625,1.0],\"range\":[-0.5,0.8],\"title\":{\"text\":\"\\u003cb\\u003eCorrelation\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10}},\"xaxis2\":{\"anchor\":\"y2\",\"domain\":[0.55,1.0],\"title\":{\"text\":\"\\u003cb\\u003eMetrics\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10},\"tickangle\":-45},\"yaxis2\":{\"anchor\":\"x2\",\"domain\":[0.8625,1.0],\"range\":[-0.5,0.8],\"title\":{\"text\":\"\\u003cb\\u003eCorrelation\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10}},\"xaxis3\":{\"anchor\":\"y3\",\"domain\":[0.0,0.45],\"title\":{\"text\":\"\\u003cb\\u003eMetrics\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10},\"tickangle\":-45},\"yaxis3\":{\"anchor\":\"x3\",\"domain\":[0.575,0.7124999999999999],\"range\":[-0.5,0.8],\"title\":{\"text\":\"\\u003cb\\u003eCorrelation\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10}},\"xaxis4\":{\"anchor\":\"y4\",\"domain\":[0.55,1.0],\"title\":{\"text\":\"\\u003cb\\u003eMetrics\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10},\"tickangle\":-45},\"yaxis4\":{\"anchor\":\"x4\",\"domain\":[0.575,0.7124999999999999],\"range\":[-0.5,0.8],\"title\":{\"text\":\"\\u003cb\\u003eCorrelation\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10}},\"xaxis5\":{\"anchor\":\"y5\",\"domain\":[0.0,0.45],\"title\":{\"text\":\"\\u003cb\\u003eMetrics\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10},\"tickangle\":-45},\"yaxis5\":{\"anchor\":\"x5\",\"domain\":[0.2875,0.425],\"range\":[-0.5,0.8],\"title\":{\"text\":\"\\u003cb\\u003eCorrelation\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10}},\"xaxis6\":{\"anchor\":\"y6\",\"domain\":[0.55,1.0],\"title\":{\"text\":\"\\u003cb\\u003eMetrics\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10},\"tickangle\":-45},\"yaxis6\":{\"anchor\":\"x6\",\"domain\":[0.2875,0.425],\"range\":[-0.5,0.8],\"title\":{\"text\":\"\\u003cb\\u003eCorrelation\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10}},\"xaxis7\":{\"anchor\":\"y7\",\"domain\":[0.0,0.45],\"title\":{\"text\":\"\\u003cb\\u003eMetrics\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10},\"tickangle\":-45},\"yaxis7\":{\"anchor\":\"x7\",\"domain\":[0.0,0.1375],\"range\":[-0.5,0.8],\"title\":{\"text\":\"\\u003cb\\u003eCorrelation\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10}},\"xaxis8\":{\"anchor\":\"y8\",\"domain\":[0.55,1.0],\"title\":{\"text\":\"\\u003cb\\u003eMetrics\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10},\"tickangle\":-45},\"yaxis8\":{\"anchor\":\"x8\",\"domain\":[0.0,0.1375],\"title\":{\"text\":\"\\u003cb\\u003eCorrelation\\u003c\\u002fb\\u003e\"},\"tickfont\":{\"size\":10}},\"annotations\":[{\"font\":{\"size\":16},\"showarrow\":false,\"text\":\"Sadie\",\"x\":0.225,\"xanchor\":\"center\",\"xref\":\"paper\",\"y\":1.0,\"yanchor\":\"bottom\",\"yref\":\"paper\"},{\"font\":{\"size\":16},\"showarrow\":false,\"text\":\"Chester\",\"x\":0.775,\"xanchor\":\"center\",\"xref\":\"paper\",\"y\":1.0,\"yanchor\":\"bottom\",\"yref\":\"paper\"},{\"font\":{\"size\":16},\"showarrow\":false,\"text\":\"Caitie\",\"x\":0.225,\"xanchor\":\"center\",\"xref\":\"paper\",\"y\":0.7124999999999999,\"yanchor\":\"bottom\",\"yref\":\"paper\"},{\"font\":{\"size\":16},\"showarrow\":false,\"text\":\"Adaline\",\"x\":0.775,\"xanchor\":\"center\",\"xref\":\"paper\",\"y\":0.7124999999999999,\"yanchor\":\"bottom\",\"yref\":\"paper\"},{\"font\":{\"size\":16},\"showarrow\":false,\"text\":\"Mateo\",\"x\":0.225,\"xanchor\":\"center\",\"xref\":\"paper\",\"y\":0.425,\"yanchor\":\"bottom\",\"yref\":\"paper\"},{\"font\":{\"size\":16},\"showarrow\":false,\"text\":\"LaMelo\",\"x\":0.775,\"xanchor\":\"center\",\"xref\":\"paper\",\"y\":0.425,\"yanchor\":\"bottom\",\"yref\":\"paper\"},{\"font\":{\"size\":16},\"showarrow\":false,\"text\":\"Gutenberg\",\"x\":0.225,\"xanchor\":\"center\",\"xref\":\"paper\",\"y\":0.1375,\"yanchor\":\"bottom\",\"yref\":\"paper\"}],\"title\":{\"font\":{\"size\":22},\"text\":\"\\u003cb\\u003eSpearmann Correlation of Each Zero-Cost Metric\\u003c\\u002fb\\u003e\",\"x\":0.5},\"font\":{\"size\":12},\"margin\":{\"t\":100,\"b\":40,\"l\":60,\"r\":60},\"height\":1200,\"width\":800,\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"rgba(0,0,0,0)\"},                        {\"responsive\": true}                    ).then(function(){\n",
       "                            \n",
       "var gd = document.getElementById('968aece1-4c6c-455f-a010-670e03ff33a9');\n",
       "var x = new MutationObserver(function (mutations, observer) {{\n",
       "        var display = window.getComputedStyle(gd).display;\n",
       "        if (!display || display === 'none') {{\n",
       "            console.log([gd, 'removed!']);\n",
       "            Plotly.purge(gd);\n",
       "            observer.disconnect();\n",
       "        }}\n",
       "}});\n",
       "\n",
       "// Listen for the removal of the full notebook cells\n",
       "var notebookContainer = gd.closest('#notebook-container');\n",
       "if (notebookContainer) {{\n",
       "    x.observe(notebookContainer, {childList: true});\n",
       "}}\n",
       "\n",
       "// Listen for the clearing of the current output cell\n",
       "var outputEl = gd.closest('.output');\n",
       "if (outputEl) {{\n",
       "    x.observe(outputEl, {childList: true});\n",
       "}}\n",
       "\n",
       "                        })                };                });            </script>        </div>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import plotly.subplots as sp\n",
    "import plotly.graph_objects as go\n",
    "\n",
    "# Create subplots with a 4x2 grid\n",
    "fig = sp.make_subplots(\n",
    "    rows=4, cols=2, \n",
    "    subplot_titles=corr_dfs.columns,\n",
    "    horizontal_spacing=0.10,  # Add spacing between subplots\n",
    "    vertical_spacing=0.15\n",
    ")\n",
    "\n",
    "# Defining a refined color palette for the bars\n",
    "colors = ['#4E79A7', '#F28E2B', '#76B7B2', '#59A14F', '#E15759', '#FF9DA7', '#9C755F', '#EDC948']\n",
    "\n",
    "# Adding traces for each column and displaying the scores inside each bar\n",
    "for i, column in enumerate(corr_dfs.columns):\n",
    "    row = i // 2 + 1  # Adjust row based on 4 rows and 2 columns layout\n",
    "    col = i % 2 + 1   # Adjust column based on 2 columns\n",
    "    fig.add_trace(\n",
    "        go.Bar(\n",
    "            x=corr_dfs.index, \n",
    "            y=corr_dfs[column], \n",
    "            name=column, \n",
    "            marker_color=colors[i % len(colors)],  # Cycle through colors\n",
    "            showlegend=False,  # Hide individual legends\n",
    "            text=corr_dfs[column],  # Display the score values\n",
    "            textposition='inside',  # Position the text inside the bars\n",
    "            texttemplate='%{text:.2f}',  # Format the text to 2 decimal places\n",
    "            insidetextanchor='middle',  # Center the text within the bars\n",
    "            width=0.6  # Adjust bar width to avoid clutter\n",
    "        ),\n",
    "        row=row, col=col\n",
    "    )\n",
    "\n",
    "# Fix the y-axis range between -0.5 and 0.8 for all subplots\n",
    "for i, column in enumerate(corr_dfs.columns):\n",
    "    row = i // 2 + 1  # Adjust row\n",
    "    col = i % 2 + 1   # Adjust column\n",
    "    fig.update_yaxes(range=[-0.5, 0.8], row=row, col=col)\n",
    "\n",
    "# Update layout with professional design elements\n",
    "fig.update_layout(\n",
    "    height=1200,  # Increase height for better visualization\n",
    "    width=800,  # Adjust width for 2-column layout\n",
    "    title_text=\"<b>Spearmann Correlation of Each Zero-Cost Metric</b>\",  # Make title bold\n",
    "    title_font_size=22,  # Increase title font size\n",
    "    title_x=0.5,  # Center the title\n",
    "    font=dict(size=12),  # Adjust font size for axis labels and tick marks\n",
    "    margin=dict(t=100, b=40, l=60, r=60),  # Adjust margins for balanced spacing\n",
    "    paper_bgcolor='white',  # Set a clean white background\n",
    "    plot_bgcolor='rgba(0,0,0,0)',  # Transparent plot background\n",
    ")\n",
    "\n",
    "# Customize the axis titles and tick labels for better readability\n",
    "fig.update_xaxes(title_text=\"<b>Metrics</b>\", tickangle=-45, tickfont=dict(size=10))\n",
    "fig.update_yaxes(title_text=\"<b>Correlation</b>\", tickfont=dict(size=10))\n",
    "\n",
    "# Show plot\n",
    "fig.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "76e7159e-b55c-4ad2-9ad8-f85a87014bf0",
   "metadata": {
    "tags": []
   },
   "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>grasp</th>\n",
       "      <th>fisher</th>\n",
       "      <th>grad_norm</th>\n",
       "      <th>jacob_cov</th>\n",
       "      <th>plain</th>\n",
       "      <th>snip</th>\n",
       "      <th>synflow</th>\n",
       "      <th>dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.027921</td>\n",
       "      <td>-0.389183</td>\n",
       "      <td>-0.363203</td>\n",
       "      <td>0.315912</td>\n",
       "      <td>-0.215401</td>\n",
       "      <td>-0.327441</td>\n",
       "      <td>-0.078879</td>\n",
       "      <td>LaMelo</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      grasp    fisher  grad_norm  jacob_cov     plain      snip   synflow  \\\n",
       "0  0.027921 -0.389183  -0.363203   0.315912 -0.215401 -0.327441 -0.078879   \n",
       "\n",
       "  dataset  \n",
       "0  LaMelo  "
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corr_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "05108b9f-7552-477b-bdc5-fd5c5b2db672",
   "metadata": {
    "tags": []
   },
   "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>grasp</th>\n",
       "      <th>fisher</th>\n",
       "      <th>grad_norm</th>\n",
       "      <th>jacob_cov</th>\n",
       "      <th>plain</th>\n",
       "      <th>snip</th>\n",
       "      <th>synflow</th>\n",
       "      <th>dataset</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.009081</td>\n",
       "      <td>-0.394204</td>\n",
       "      <td>-0.364255</td>\n",
       "      <td>0.25582</td>\n",
       "      <td>-0.10449</td>\n",
       "      <td>-0.324191</td>\n",
       "      <td>-0.078566</td>\n",
       "      <td>LaMelo</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      grasp    fisher  grad_norm  jacob_cov    plain      snip   synflow  \\\n",
       "0  0.009081 -0.394204  -0.364255    0.25582 -0.10449 -0.324191 -0.078566   \n",
       "\n",
       "  dataset  \n",
       "0  LaMelo  "
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "corr_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "cd71d2c8-5088-46d0-9c30-177a61af6eea",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig.write_image(\"regressors/zcost_corr.svg\",format=\"SVG\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "6a4cda45-dc80-48f0-a797-fe5718014013",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "fig.write_image(\"regressors/zcost_corr.png\",format=\"PNG\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "49414ea9-26ce-49ae-9799-0967d71c2a9d",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:pytorch-2.2.0]",
   "language": "python",
   "name": "conda-env-pytorch-2.2.0-py"
  },
  "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.12.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
