{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import os\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams.update({'font.size': 6})\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "import cmcrameri\n",
    "import torch\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "from omegaconf import OmegaConf\n",
    "\n",
    "from solo.data.classification_dataloader import prepare_data\n",
    "from solo.methods import METHODS\n",
    "from scripts.utils.get_images_and_feats import get_images_and_feats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# set up plot dir\n",
    "plot_dir = Path(\"plots/cifar/\")\n",
    "plot_dir.mkdir(parents=True, exist_ok=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "dataset = \"cifar10\"\n",
    "val_data_path = \"../datasets/cifar10/val\"\n",
    "train_data_path = \"../datasets/\"\n",
    "data_format = \"image_folder\"\n",
    "batch_size = 256\n",
    "num_workers = 4\n",
    "\n",
    "# prepare data\n",
    "train_loader, val_loader = prepare_data(\n",
    "    dataset,\n",
    "    train_data_path=train_data_path,\n",
    "    val_data_path=val_data_path,\n",
    "    data_format=data_format,\n",
    "    batch_size=batch_size,\n",
    "    num_workers=num_workers,\n",
    "    auto_augment=False,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_model(model_name, run_name):\n",
    "    folder_name = \"../trained_models/\" + model_name + \"/\"\n",
    "    # get name of the most recent model by folder creation time\n",
    "    names = sorted(os.listdir(folder_name), key=lambda x: os.path.getctime(os.path.join(folder_name, x)))\n",
    "    for n in names:\n",
    "        run = folder_name + n\n",
    "        args_file = os.path.join(run, \"args.json\")\n",
    "        args = json.load(open(args_file, \"r\"))\n",
    "        if args[\"name\"] == run_name:\n",
    "            pretrained_checkpoint_dir = run\n",
    "            name = n\n",
    "    cfg = OmegaConf.create(args)\n",
    "\n",
    "    # build paths\n",
    "    ckpt_dir = Path(pretrained_checkpoint_dir)\n",
    "    args_path = ckpt_dir / \"args.json\"\n",
    "    ckpt_path = [ckpt_dir / ckpt for ckpt in os.listdir(ckpt_dir) if ckpt.endswith(\".ckpt\")][0]\n",
    "\n",
    "    # load arguments\n",
    "    with open(args_path) as f:\n",
    "        method_args = json.load(f)\n",
    "    cfg = OmegaConf.create(method_args)\n",
    "\n",
    "    # build the model\n",
    "    model = (\n",
    "        METHODS[method_args[\"method\"]]\n",
    "        .load_from_checkpoint(ckpt_path, strict=False, cfg=cfg)\n",
    "    )\n",
    "\n",
    "    # move model to the gpu\n",
    "    device = \"cuda:0\"\n",
    "    model = model.to(device)\n",
    "\n",
    "    # get images and features\n",
    "    data, labels, z = get_images_and_feats(device, model, val_loader)\n",
    "    # clip data for imshow\n",
    "    # data = np.clip(data, 0, 1)\n",
    "\n",
    "    return data, labels, z, model, name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_name = \"gaussprob\"\n",
    "run_name = \"gaussprob_cifar10_dual_sample\"\n",
    "data, labels, z_gauss_dual_sample, model_gauss_dual_sample, name_gauss_dual_sample = load_model(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar10_single_sample\"\n",
    "_, _, z_gauss_single_sample, model_gauss_single_sample, name_gauss_single_sample = load_model(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar10_dual_knn\"\n",
    "_, _, z_gauss_dual_knn, model_gauss_dual_knn, name_gauss_dual_knn = load_model(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar10_single_knn\"\n",
    "_, _, z_gauss_single_knn, model_gauss_single_knn, name_gauss_single_knn = load_model(model_name, run_name)\n",
    "model_name = \"vicreg2\" \n",
    "run_name = \"vicreg2_cifar10_lower_entropy\"\n",
    "_, _, z_gauss_dual_logdet, model_gauss_dual_logdet, name_gauss_dual_logdet = load_model(model_name, run_name)\n",
    "model_name = \"vicreg\"\n",
    "run_name = \"vicreg-cifar10\"\n",
    "_, _, z_gauss_single_logdet, model_gauss_single_logdet, name_gauss_single_logdet = load_model(model_name, run_name)\n",
    "model_name = \"sphereprob\"\n",
    "run_name = \"sphereprob_cifar10_dual_sample\"\n",
    "_, _, z_sphere_dual_sample, model_sphere_dual_sample, name_sphere_dual_sample = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_single_sample\"\n",
    "_, _, z_sphere_single_sample, model_sphere_single_sample, name_sphere_single_sample = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_dual_knn\"\n",
    "_, _, z_sphere_dual_knn, model_sphere_dual_knn, name_sphere_dual_knn = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_single_knn\"\n",
    "_, _, z_sphere_single_knn, model_sphere_single_knn, name_sphere_single_knn = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_dual_gauss\"\n",
    "_, _, z_sphere_dual_gauss, model_sphere_dual_gauss, name_sphere_dual_gauss = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_single_gauss\"\n",
    "_, _, z_sphere_single_gauss, model_sphere_single_gauss, name_sphere_single_gauss = load_model(model_name, run_name)\n",
    "\n",
    "model_dict = {\n",
    "    r\"Plane Contr.\": (z_gauss_dual_sample, model_gauss_dual_sample),\n",
    "    r\"Plane Contr. + MI\": (z_gauss_single_sample, model_gauss_single_sample),\n",
    "    r\"Plane kNN\": (z_gauss_dual_knn, model_gauss_dual_knn),\n",
    "    r\"Plane kNN + MI\": (z_gauss_single_knn, model_gauss_single_knn),\n",
    "    r\"Plane LogDet\": (z_gauss_dual_logdet, model_gauss_dual_logdet),\n",
    "    r\"Plane LogDet + MI\": (z_gauss_single_logdet, model_gauss_single_logdet),\n",
    "    r\"Sphere Contr.\": (z_sphere_dual_sample, model_sphere_dual_sample),\n",
    "    r\"Sphere Contr. + MI\": (z_sphere_single_sample, model_sphere_single_sample),\n",
    "    r\"Sphere kNN\": (z_sphere_dual_knn, model_sphere_dual_knn),\n",
    "    r\"Sphere kNN + MI\": (z_sphere_single_knn, model_sphere_single_knn),\n",
    "    r\"Sphere LogDet\": (z_sphere_dual_gauss, model_sphere_dual_gauss),\n",
    "    r\"Sphere LogDet + MI\": (z_sphere_single_gauss, model_sphere_single_gauss),\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plot log distance distribution between encodings\n",
    "z = z_gauss_dual_sample\n",
    "distances = torch.cdist(torch.tensor(z), torch.tensor(z)).numpy().flatten()\n",
    "plt.figure(figsize=(3,2))\n",
    "plt.hist(np.log10(distances + 1e-10), bins=100, density=True, color='blue', alpha=0.7)\n",
    "plt.xlabel('Log10 Distance')\n",
    "plt.ylabel('Density')\n",
    "plt.title('Log10 Distance Distribution (Gauss Dual Sample)')\n",
    "plt.tight_layout()\n",
    "plt.savefig(plot_dir / \"cifar10_log_distance_gauss_dual_sample.png\", dpi=300)\n",
    "plt.close()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(10000, 3, 32, 32)\n",
      "(10000,)\n",
      "(10000, 2048)\n",
      "(10000, 256)\n"
     ]
    }
   ],
   "source": [
    "print(data.shape)\n",
    "print(labels.shape)\n",
    "print(z_gauss_dual_sample.shape)\n",
    "print(z_sphere_dual_sample.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 2000x400 with 10 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot some images and labels\n",
    "n = 10\n",
    "plt.figure(figsize=(20,4))\n",
    "for i in range(n):\n",
    "    j = 200\n",
    "    while labels[j] != i:\n",
    "        j += 1\n",
    "    ax = plt.subplot(2, n//2, i+1)\n",
    "    plt.imshow((data[j].transpose(1,2,0) * 0.5 + 0.5).clip(0,1))\n",
    "    plt.title(f\"{labels[j]}\")\n",
    "    plt.axis(\"off\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computing eigenvalues for Plane Contr....\n",
      "Computing eigenvalues for Plane Contr. + MI...\n",
      "Computing eigenvalues for Plane kNN...\n",
      "Computing eigenvalues for Plane kNN + MI...\n",
      "Computing eigenvalues for Plane LogDet...\n",
      "Computing eigenvalues for Plane LogDet + MI...\n",
      "Computing eigenvalues for Sphere Contr....\n",
      "Computing eigenvalues for Sphere Contr. + MI...\n",
      "Computing eigenvalues for Sphere kNN...\n",
      "Computing eigenvalues for Sphere kNN + MI...\n",
      "Computing eigenvalues for Sphere LogDet...\n",
      "Computing eigenvalues for Sphere LogDet + MI...\n"
     ]
    }
   ],
   "source": [
    "eigenvalue_dict = {}\n",
    "for name, (z, model) in model_dict.items():\n",
    "    print(f\"Computing eigenvalues for {name}...\")\n",
    "    cov = np.cov(z, rowvar=False)\n",
    "    eigenvalues, _ = np.linalg.eigh(cov)\n",
    "    eigenvalues = np.sort(eigenvalues)[::-1]\n",
    "    eigenvalue_dict[name] = eigenvalues\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x170 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "cmap = cmcrameri.cm.romaO\n",
    "plot_dict = {\n",
    "    r\"Plane Contr.\": {\"color\": cmap(0.0), \"linestyle\": \"-\"},\n",
    "    r\"Plane Contr. + MI\": {\"color\": cmap(0.15), \"linestyle\": \"-\"},\n",
    "    r\"Plane kNN\": {\"color\": cmap(0.3), \"linestyle\": \"-\"},\n",
    "    r\"Plane kNN + MI\": {\"color\": cmap(0.45), \"linestyle\": \"-\"},\n",
    "    r\"Plane LogDet\": {\"color\": cmap(0.6), \"linestyle\": \"-\"},\n",
    "    r\"Plane LogDet + MI\": {\"color\": cmap(0.75), \"linestyle\": \"-\"},\n",
    "    r\"Sphere Contr.\": {\"color\": cmap(0.0), \"linestyle\": \"--\"},\n",
    "    r\"Sphere Contr. + MI\": {\"color\": cmap(0.15), \"linestyle\": \"--\"},\n",
    "    r\"Sphere kNN\": {\"color\": cmap(0.3), \"linestyle\": \"--\"},\n",
    "    r\"Sphere kNN + MI\": {\"color\": cmap(0.45), \"linestyle\": \"--\"},\n",
    "    r\"Sphere LogDet\": {\"color\": cmap(0.6), \"linestyle\": \"--\"},\n",
    "    r\"Sphere LogDet + MI\": {\"color\": cmap(0.75), \"linestyle\": \"--\"},\n",
    "}\n",
    "\n",
    "plt.figure(figsize=(2.5,1.7))\n",
    "\n",
    "for name, eigenvalues in eigenvalue_dict.items():\n",
    "    plt_params = plot_dict[name]\n",
    "    # eigenspectrum of covariance matrix\n",
    "    plt.plot(eigenvalues[:200], label=name, color=plt_params[\"color\"], linestyle=plt_params[\"linestyle\"])\n",
    "\n",
    "plt.yscale(\"log\")\n",
    "plt.xscale(\"log\")\n",
    "plt.xlabel(\"Index\")\n",
    "plt.ylabel(\"Eigenvalue\")\n",
    "# remove top and right spines\n",
    "plt.gca().spines['top'].set_visible(False)\n",
    "plt.gca().spines['right'].set_visible(False)\n",
    "plt.legend(fontsize=6, loc='upper right', bbox_to_anchor=(1.35, 1), frameon=False)\n",
    "plt.tight_layout()\n",
    "plt.savefig(plot_dir / \"spectrum.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computing t-SNE for Plane Contr....\n",
      "Computing t-SNE for Plane Contr. + MI...\n",
      "Computing t-SNE for Plane kNN...\n",
      "Computing t-SNE for Plane kNN + MI...\n",
      "Computing t-SNE for Plane LogDet...\n",
      "Computing t-SNE for Plane LogDet + MI...\n",
      "Computing t-SNE for Sphere Contr....\n",
      "Computing t-SNE for Sphere Contr. + MI...\n",
      "Computing t-SNE for Sphere kNN...\n",
      "Computing t-SNE for Sphere kNN + MI...\n",
      "Computing t-SNE for Sphere LogDet...\n",
      "Computing t-SNE for Sphere LogDet + MI...\n"
     ]
    }
   ],
   "source": [
    "from sklearn.manifold import TSNE\n",
    "tsne_dict = {}\n",
    "\n",
    "tsne = TSNE(n_components=2, perplexity=30, max_iter=3000, random_state=42)\n",
    "n = 1000\n",
    "\n",
    "for name, (z, model) in model_dict.items():\n",
    "    print(f\"Computing t-SNE for {name}...\")\n",
    "    z_subset = z[:n]\n",
    "    z_tsne = tsne.fit_transform(z_subset)\n",
    "    tsne_dict[name] = (z_tsne, model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x200 with 12 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# t-sne visualization\n",
    "from math import ceil\n",
    "fig, ax = plt.subplots(2, ceil(len(model_dict)/2), figsize=(len(model_dict)*0.5, 2.0))\n",
    "ax = ax.flatten()\n",
    "i = 0\n",
    "for name, (z_tsne, model) in tsne_dict.items():\n",
    "    ax[i].scatter(z_tsne[:,0], z_tsne[:,1], c=labels[:n], cmap='tab10', s=1.0, linewidths=0)\n",
    "    ax[i].axis('off')\n",
    "    ax[i].set_title(name, fontsize=5)\n",
    "    i += 1\n",
    "\n",
    "# plt.colorbar(ax=ax, mappable=ax[0].collections[0], orientation='horizontal', fraction=0.03, pad=0.1, ticks=range(10))\n",
    "plt.savefig(plot_dir / \"tsne.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = \"cifar100\"\n",
    "val_data_path = \"../datasets/\"\n",
    "train_data_path = \"../datasets/\"\n",
    "data_format = \"image_folder\"\n",
    "batch_size = 256\n",
    "num_workers = 4\n",
    "\n",
    "# prepare data\n",
    "train_loader, val_loader = prepare_data(\n",
    "    dataset,\n",
    "    train_data_path=train_data_path,\n",
    "    val_data_path=val_data_path,\n",
    "    data_format=data_format,\n",
    "    batch_size=batch_size,\n",
    "    num_workers=num_workers,\n",
    "    auto_augment=False,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.21it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.16it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.01it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 11.96it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.03it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.04it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.24it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.22it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.08it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.18it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 12.02it/s]\n",
      "WARNING:root:Using scheduler_interval=step might generate issues when resuming a checkpoint.\n",
      "Collecting features: 100%|██████████| 40/40 [00:03<00:00, 11.98it/s]\n"
     ]
    }
   ],
   "source": [
    "model_name = \"gaussprob\"\n",
    "run_name = \"gaussprob_cifar100_dual_sample\"\n",
    "data, labels, z_gauss_dual_sample, model_gauss_dual_sample, name_gauss_dual_sample = load_model(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar100_single_sample\"\n",
    "_, _, z_gauss_single_sample, model_gauss_single_sample, name_gauss_single_sample = load_model(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar100_dual_knn\"\n",
    "_, _, z_gauss_dual_knn, model_gauss_dual_knn, name_gauss_dual_knn = load_model(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar100_single_knn\"\n",
    "_, _, z_gauss_single_knn, model_gauss_single_knn, name_gauss_single_knn = load_model(model_name, run_name)\n",
    "model_name = \"vicreg2\" \n",
    "run_name = \"vicreg2_cifar100_lower_entropy\"\n",
    "_, _, z_gauss_dual_logdet, model_gauss_dual_logdet, name_gauss_dual_logdet = load_model(model_name, run_name)\n",
    "model_name = \"vicreg\"\n",
    "run_name = \"vicreg-cifar100\"\n",
    "_, _, z_gauss_single_logdet, model_gauss_single_logdet, name_gauss_single_logdet = load_model(model_name, run_name)\n",
    "model_name = \"sphereprob\"\n",
    "run_name = \"sphereprob_cifar100_dual_sample\"\n",
    "_, _, z_sphere_dual_sample, model_sphere_dual_sample, name_sphere_dual_sample = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_single_sample\"\n",
    "_, _, z_sphere_single_sample, model_sphere_single_sample, name_sphere_single_sample = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_dual_knn\"\n",
    "_, _, z_sphere_dual_knn, model_sphere_dual_knn, name_sphere_dual_knn = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_single_knn\"\n",
    "_, _, z_sphere_single_knn, model_sphere_single_knn, name_sphere_single_knn = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_dual_gauss\"\n",
    "_, _, z_sphere_dual_gauss, model_sphere_dual_gauss, name_sphere_dual_gauss = load_model(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_single_gauss\"\n",
    "_, _, z_sphere_single_gauss, model_sphere_single_gauss, name_sphere_single_gauss = load_model(model_name, run_name)\n",
    "\n",
    "name_dict = {\n",
    "    r\"Plane Contr.\": name_gauss_dual_sample,\n",
    "    r\"Plane Contr. + MI\": name_gauss_single_sample,\n",
    "    r\"Plane kNN\": name_gauss_dual_knn,\n",
    "    r\"Plane kNN + MI\": name_gauss_single_knn,\n",
    "    r\"Plane LogDet\": name_gauss_dual_logdet,\n",
    "    r\"Plane LogDet + MI\": name_gauss_single_logdet,\n",
    "    r\"Sphere Contr.\": name_sphere_dual_sample,\n",
    "    r\"Sphere Contr. + MI\": name_sphere_single_sample,\n",
    "    r\"Sphere kNN\": name_sphere_dual_knn,\n",
    "    r\"Sphere kNN + MI\": name_sphere_single_knn,\n",
    "    r\"Sphere LogDet\": name_sphere_dual_gauss,\n",
    "    r\"Sphere LogDet + MI\": name_sphere_single_gauss,\n",
    "}\n",
    "\n",
    "model_dict = {\n",
    "    r\"Plane Contr.\": (z_gauss_dual_sample, model_gauss_dual_sample),\n",
    "    r\"Plane Contr. + MI\": (z_gauss_single_sample, model_gauss_single_sample),\n",
    "    r\"Plane kNN\": (z_gauss_dual_knn, model_gauss_dual_knn),\n",
    "    r\"Plane kNN + MI\": (z_gauss_single_knn, model_gauss_single_knn),\n",
    "    r\"Plane LogDet\": (z_gauss_dual_logdet, model_gauss_dual_logdet),\n",
    "    r\"Plane LogDet + MI\": (z_gauss_single_logdet, model_gauss_single_logdet),\n",
    "    r\"Sphere Contr.\": (z_sphere_dual_sample, model_sphere_dual_sample),\n",
    "    r\"Sphere Contr. + MI\": (z_sphere_single_sample, model_sphere_single_sample),\n",
    "    r\"Sphere kNN\": (z_sphere_dual_knn, model_sphere_dual_knn),\n",
    "    r\"Sphere kNN + MI\": (z_sphere_single_knn, model_sphere_single_knn),\n",
    "    r\"Sphere LogDet\": (z_sphere_dual_gauss, model_sphere_dual_gauss),\n",
    "    r\"Sphere LogDet + MI\": (z_sphere_single_gauss, model_sphere_single_gauss),\n",
    "}\n",
    "\n",
    "cmap = cmcrameri.cm.romaO\n",
    "plot_dict = {\n",
    "    r\"Plane Contr.\": {\"color\": cmap(0.0), \"linestyle\": \"-\"},\n",
    "    r\"Plane Contr. + MI\": {\"color\": cmap(0.15), \"linestyle\": \"-\"},\n",
    "    r\"Plane kNN\": {\"color\": cmap(0.3), \"linestyle\": \"-\"},\n",
    "    r\"Plane kNN + MI\": {\"color\": cmap(0.45), \"linestyle\": \"-\"},\n",
    "    r\"Plane LogDet\": {\"color\": cmap(0.6), \"linestyle\": \"-\"},\n",
    "    r\"Plane LogDet + MI\": {\"color\": cmap(0.75), \"linestyle\": \"-\"},\n",
    "    r\"Sphere Contr.\": {\"color\": cmap(0.0), \"linestyle\": \"--\"},\n",
    "    r\"Sphere Contr. + MI\": {\"color\": cmap(0.15), \"linestyle\": \"--\"},\n",
    "    r\"Sphere kNN\": {\"color\": cmap(0.3), \"linestyle\": \"--\"},\n",
    "    r\"Sphere kNN + MI\": {\"color\": cmap(0.45), \"linestyle\": \"--\"},\n",
    "    r\"Sphere LogDet\": {\"color\": cmap(0.6), \"linestyle\": \"--\"},\n",
    "    r\"Sphere LogDet + MI\": {\"color\": cmap(0.75), \"linestyle\": \"--\"},\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "cmap = cmcrameri.cm.romaO\n",
    "plot_dict = {\n",
    "    r\"Plane Contr.\": {\"color\": cmap(0.0), \"linestyle\": \"-\"},\n",
    "    r\"Plane Contr. + MI\": {\"color\": cmap(0.15), \"linestyle\": \"-\"},\n",
    "    r\"Plane kNN\": {\"color\": cmap(0.3), \"linestyle\": \"-\"},\n",
    "    r\"Plane kNN + MI\": {\"color\": cmap(0.45), \"linestyle\": \"-\"},\n",
    "    r\"Plane LogDet\": {\"color\": cmap(0.6), \"linestyle\": \"-\"},\n",
    "    r\"Plane LogDet + MI\": {\"color\": cmap(0.75), \"linestyle\": \"-\"},\n",
    "    r\"Sphere Contr.\": {\"color\": cmap(0.0), \"linestyle\": \"--\"},\n",
    "    r\"Sphere Contr. + MI\": {\"color\": cmap(0.15), \"linestyle\": \"--\"},\n",
    "    r\"Sphere kNN\": {\"color\": cmap(0.3), \"linestyle\": \"--\"},\n",
    "    r\"Sphere kNN + MI\": {\"color\": cmap(0.45), \"linestyle\": \"--\"},\n",
    "    r\"Sphere LogDet\": {\"color\": cmap(0.6), \"linestyle\": \"--\"},\n",
    "    r\"Sphere LogDet + MI\": {\"color\": cmap(0.75), \"linestyle\": \"--\"},\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computing eigenvalues for Plane Contr....\n",
      "Computing eigenvalues for Plane Contr. + MI...\n",
      "Computing eigenvalues for Plane kNN...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computing eigenvalues for Plane kNN + MI...\n",
      "Computing eigenvalues for Plane LogDet...\n",
      "Computing eigenvalues for Plane LogDet + MI...\n",
      "Computing eigenvalues for Sphere Contr....\n",
      "Computing eigenvalues for Sphere Contr. + MI...\n",
      "Computing eigenvalues for Sphere kNN...\n",
      "Computing eigenvalues for Sphere kNN + MI...\n",
      "Computing eigenvalues for Sphere LogDet...\n",
      "Computing eigenvalues for Sphere LogDet + MI...\n"
     ]
    }
   ],
   "source": [
    "eigenvalue_dict = {}\n",
    "for name, (z, model) in model_dict.items():\n",
    "    print(f\"Computing eigenvalues for {name}...\")\n",
    "    cov = np.cov(z, rowvar=False)\n",
    "    eigenvalues, _ = np.linalg.eigh(cov)\n",
    "    eigenvalues = np.sort(eigenvalues)[::-1]\n",
    "    eigenvalue_dict[name] = eigenvalues\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 250x170 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "cmap = cmcrameri.cm.romaO\n",
    "plot_dict = {\n",
    "    r\"Plane Contr.\": {\"color\": cmap(0.0), \"linestyle\": \"-\"},\n",
    "    r\"Plane Contr. + MI\": {\"color\": cmap(0.15), \"linestyle\": \"-\"},\n",
    "    r\"Plane kNN\": {\"color\": cmap(0.3), \"linestyle\": \"-\"},\n",
    "    r\"Plane kNN + MI\": {\"color\": cmap(0.45), \"linestyle\": \"-\"},\n",
    "    r\"Plane LogDet\": {\"color\": cmap(0.6), \"linestyle\": \"-\"},\n",
    "    r\"Plane LogDet + MI\": {\"color\": cmap(0.75), \"linestyle\": \"-\"},\n",
    "    r\"Sphere Contr.\": {\"color\": cmap(0.0), \"linestyle\": \"--\"},\n",
    "    r\"Sphere Contr. + MI\": {\"color\": cmap(0.15), \"linestyle\": \"--\"},\n",
    "    r\"Sphere kNN\": {\"color\": cmap(0.3), \"linestyle\": \"--\"},\n",
    "    r\"Sphere kNN + MI\": {\"color\": cmap(0.45), \"linestyle\": \"--\"},\n",
    "    r\"Sphere LogDet\": {\"color\": cmap(0.6), \"linestyle\": \"--\"},\n",
    "    r\"Sphere LogDet + MI\": {\"color\": cmap(0.75), \"linestyle\": \"--\"},\n",
    "}\n",
    "\n",
    "plt.figure(figsize=(2.5,1.7))\n",
    "\n",
    "for name, eigenvalues in eigenvalue_dict.items():\n",
    "    plt_params = plot_dict[name]\n",
    "    # eigenspectrum of covariance matrix\n",
    "    plt.plot(eigenvalues[:200], label=name, color=plt_params[\"color\"], linestyle=plt_params[\"linestyle\"])\n",
    "\n",
    "plt.yscale(\"log\")\n",
    "plt.xscale(\"log\")\n",
    "plt.xlabel(\"Index\")\n",
    "plt.ylabel(\"Eigenvalue\")\n",
    "# remove top and right spines\n",
    "plt.gca().spines['top'].set_visible(False)\n",
    "plt.gca().spines['right'].set_visible(False)\n",
    "plt.legend(fontsize=6, loc='upper right', bbox_to_anchor=(1.35, 1), frameon=False)\n",
    "plt.tight_layout()\n",
    "plt.savefig(plot_dir / \"spectrum_cifar100.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import wandb\n",
    "import pandas as pd\n",
    "\n",
    "# get wandb api key\n",
    "wandb.login()\n",
    "api = wandb.Api()\n",
    "\n",
    "\n",
    "def get_cos_sim(model_name):\n",
    "    # get the project name\n",
    "    project_name = \"<yourname>/solo-learn\"\n",
    "    run = api.run(f\"{project_name}/{model_name}\")\n",
    "    metrics = run.history(keys=[\"train_entropy_cos_sim_epoch\"])\n",
    "    cos_sim = metrics[\"train_entropy_cos_sim_epoch\"]\n",
    "    # remove nan values\n",
    "    # cos_sim = [x for x in cos_sim if not pd.isna(x)]\n",
    "    return cos_sim\n",
    "\n",
    "cos_sim_dict = {}\n",
    "for name, settings in plot_dict.items():\n",
    "    print(f\"Getting cosine similarity for {name} at {name_dict[name]}...\")\n",
    "    try:\n",
    "        cos_sim = get_cos_sim(name_dict[name])\n",
    "        cos_sim_dict[name] = cos_sim\n",
    "    except Exception as e:\n",
    "        print(f\"Could not get cosine similarity for {name}: {e}\")\n",
    "        cos_sim_dict[name] = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 150x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "plt.figure(figsize=(1.5,1.0))\n",
    "for name, settings in plot_dict.items():\n",
    "    cos_sim = cos_sim_dict[name]\n",
    "    plt.plot(cos_sim, label=name, color=settings[\"color\"], linestyle=settings[\"linestyle\"])\n",
    "\n",
    "# remove spines\n",
    "plt.gca().spines['top'].set_visible(False)\n",
    "plt.gca().spines['right'].set_visible(False)\n",
    "plt.xlabel(\"Epoch\")\n",
    "plt.ylabel(\"Grad. Cos. Sim.\")\n",
    "plt.yticks(ticks=[0, 0.5, 1.0], labels=[0, 0.5, 1.0])\n",
    "# legend outside\n",
    "plt.legend(loc='upper left', bbox_to_anchor=(1, 1), frameon=False)\n",
    "plt.savefig(plot_dir / \"grad_cos_sim_cifar.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def compute_jacobian(model, data):\n",
    "    model.eval()\n",
    "    device = next(model.parameters()).device\n",
    "    data = torch.tensor(data).to(device)\n",
    "    data.requires_grad_(True)\n",
    "    with torch.enable_grad():\n",
    "        outputs = model.backbone(data)\n",
    "        outputs = model.projector(outputs)\n",
    "    jacobians = []\n",
    "    for i in range(outputs.shape[1]):\n",
    "        grad_outputs = torch.zeros_like(outputs)\n",
    "        grad_outputs[:, i] = 1\n",
    "        grads = torch.autograd.grad(\n",
    "            outputs,\n",
    "            data,\n",
    "            grad_outputs=grad_outputs,\n",
    "            retain_graph=True,\n",
    "            create_graph=False,\n",
    "            only_inputs=True,\n",
    "        )[0]\n",
    "        jacobians.append(grads.cpu().numpy())\n",
    "    jacobian = np.stack(jacobians, axis=1)  # shape: (batch_size, output_dim, input_dim)\n",
    "    return jacobian.reshape((data.shape[0], -1, data.shape[1] * data.shape[2] * data.shape[3]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from math import ceil\n",
    "\n",
    "# compute the jacobian of the encoder network for all models\n",
    "log_det_dict = {}\n",
    "\n",
    "for name, (z, model) in model_dict.items():\n",
    "    print(f\"Computing Jacobian for {name}...\")\n",
    "    J = compute_jacobian(model, data[:10])\n",
    "    print(f\"  Jacobian shape: {J.shape}\")\n",
    "    \n",
    "    # compute log det of the jacobian's gram matrix\n",
    "    log_dets = []\n",
    "    for i in range(J.shape[0]):\n",
    "        J_i = J[i]  # shape: (output_dim, input_dim)\n",
    "        gram_matrix = J_i @ J_i.T  # shape: (output_dim, output_dim)\n",
    "        # add a small value to the diagonal for numerical stability\n",
    "        gram_matrix += 1e-6 * np.eye(gram_matrix.shape[0])\n",
    "        logdet = np.linalg.matrix_rank(gram_matrix, hermitian=True)\n",
    "        print(logdet)\n",
    "        log_dets.append(logdet)\n",
    "    log_det_dict[name] = log_dets\n",
    "\n",
    "# plot histograms of log dets for all models\n",
    "fig, ax = plt.subplots(2, ceil(len(model_dict)/2), figsize=(len(model_dict)*0.5, 2.0))\n",
    "ax = ax.flatten()\n",
    "\n",
    "for i, (name, log_dets) in enumerate(log_det_dict.items()):\n",
    "    ax[i].hist(log_dets, bins=20, color='blue', alpha=0.7)\n",
    "    ax[i].set_xlabel('Log Det', fontsize=5)\n",
    "    ax[i].set_ylabel('Freq', fontsize=5)\n",
    "    ax[i].set_title(name, fontsize=5)\n",
    "    ax[i].tick_params(labelsize=4)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(plot_dir / \"jacobian_log_det_histograms.pdf\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# cifar10 acc."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "def get_run_names(model_name, run_name):\n",
    "    folder_name = \"../trained_models/\" + model_name + \"/\"\n",
    "    # get name of the most recent model by folder creation time\n",
    "    names = sorted(os.listdir(folder_name), key=lambda x: os.path.getctime(os.path.join(folder_name, x)))\n",
    "    res = []\n",
    "    for n in names:\n",
    "        run = folder_name + n\n",
    "        args_file = os.path.join(run, \"args.json\")\n",
    "        args = json.load(open(args_file, \"r\"))\n",
    "        if args[\"name\"] == run_name:\n",
    "            res.append(n)\n",
    "    return res\n",
    "\n",
    "model_name = \"gaussprob\"\n",
    "run_name = \"gaussprob_cifar10_dual_sample\"\n",
    "names_gauss_dual_sample = get_run_names(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar10_single_sample\"\n",
    "names_gauss_single_sample = get_run_names(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar10_dual_knn\"\n",
    "names_gauss_dual_knn = get_run_names(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar10_single_knn\"\n",
    "names_gauss_single_knn = get_run_names(model_name, run_name)\n",
    "model_name = \"vicreg2\" \n",
    "run_name = \"vicreg2_cifar10_lower_entropy\"\n",
    "names_gauss_dual_logdet = get_run_names(model_name, run_name)\n",
    "model_name = \"vicreg\"\n",
    "run_name = \"vicreg-cifar10\"\n",
    "names_gauss_single_logdet = get_run_names(model_name, run_name)\n",
    "model_name = \"sphereprob\"\n",
    "run_name = \"sphereprob_cifar10_dual_sample\"\n",
    "names_sphere_dual_sample = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_single_sample\"\n",
    "names_sphere_single_sample = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_dual_knn\"\n",
    "names_sphere_dual_knn = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_single_knn\"\n",
    "names_sphere_single_knn = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_dual_gauss\"\n",
    "names_sphere_dual_gauss = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar10_single_gauss\"\n",
    "names_sphere_single_gauss = get_run_names(model_name, run_name)\n",
    "\n",
    "names_dict = {\n",
    "    r\"Plane Contr.\": names_gauss_dual_sample,\n",
    "    r\"Plane Contr. + MI\": names_gauss_single_sample,\n",
    "    r\"Plane kNN\": names_gauss_dual_knn,\n",
    "    r\"Plane kNN + MI\": names_gauss_single_knn,\n",
    "    r\"Plane LogDet\": names_gauss_dual_logdet,\n",
    "    r\"Plane LogDet + MI\": names_gauss_single_logdet,\n",
    "    r\"Sphere Contr.\": names_sphere_dual_sample,\n",
    "    r\"Sphere Contr. + MI\": names_sphere_single_sample,\n",
    "    r\"Sphere kNN\": names_sphere_dual_knn,\n",
    "    r\"Sphere kNN + MI\": names_sphere_single_knn,\n",
    "    r\"Sphere LogDet\": names_sphere_dual_gauss,\n",
    "    r\"Sphere LogDet + MI\": names_sphere_single_gauss,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import wandb\n",
    "wandb.login()\n",
    "api = wandb.Api()\n",
    "\n",
    "def get_final_val_acc(model_name):\n",
    "    # get the project name\n",
    "    project_name = \"<yourname>/solo-learn\"\n",
    "    run = api.run(f\"{project_name}/{model_name}\")\n",
    "    metrics = run.history(keys=[\"val_acc1\", \"val_acc5\"])\n",
    "    seed = run.config[\"seed\"]\n",
    "    return metrics[\"val_acc1\"].values[-1], metrics[\"val_acc5\"].values[-1], seed\n",
    "\n",
    "final_acc1_dict = {}\n",
    "final_acc5_dict = {}\n",
    "model_seed_dict = {}\n",
    "for name, run_names in names_dict.items():\n",
    "    for run_name in run_names:\n",
    "        print(f\"Getting final val acc for {name} at {run_name}...\")\n",
    "        try:\n",
    "            val_acc1, val_acc5, seed = get_final_val_acc(run_name)\n",
    "            if name in final_acc1_dict:\n",
    "                if seed in model_seed_dict[name]:\n",
    "                    print(f\"  Seed {seed} already exists for {name}, skipping...\")\n",
    "                    continue\n",
    "                model_seed_dict[name].append(seed)\n",
    "                final_acc1_dict[name].append(val_acc1)\n",
    "                final_acc5_dict[name].append(val_acc5)\n",
    "            else:\n",
    "                final_acc1_dict[name] = [val_acc1]\n",
    "                final_acc5_dict[name] = [val_acc5]\n",
    "                model_seed_dict[name] = [seed]\n",
    "        except Exception as e:\n",
    "            print(f\"Could not get final val acc for {name}: {e}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Top-1: 91.83 ± 0.01, \t Top-5: 99.73 ± 0.01, \t Plane Contr. (2 runs) Seeds: [2, 1]\n",
      "Top-1: 92.14 ± 0.03, \t Top-5: 99.78 ± 0.02, \t Plane Contr. + MI (2 runs) Seeds: [2, 1]\n",
      "Top-1: 92.01 ± 0.19, \t Top-5: 99.72 ± 0.01, \t Plane kNN (2 runs) Seeds: [2, 1]\n",
      "Top-1: 91.88 ± 0.06, \t Top-5: 99.67 ± 0.03, \t Plane kNN + MI (2 runs) Seeds: [1, 2]\n",
      "Top-1: 89.20 ± 2.87, \t Top-5: 99.59 ± 0.15, \t Plane LogDet (2 runs) Seeds: [1, 2]\n",
      "Top-1: 91.90 ± 0.00, \t Top-5: 99.72 ± 0.00, \t Plane LogDet + MI (2 runs) Seeds: [1, 2]\n",
      "Top-1: 91.11 ± 0.00, \t Top-5: 99.70 ± 0.00, \t Sphere Contr. (1 runs) Seeds: [1]\n",
      "Top-1: 91.11 ± 0.00, \t Top-5: 99.72 ± 0.00, \t Sphere Contr. + MI (1 runs) Seeds: [1]\n",
      "Top-1: 90.27 ± 0.00, \t Top-5: 99.70 ± 0.00, \t Sphere kNN (1 runs) Seeds: [1]\n",
      "Top-1: 89.76 ± 0.00, \t Top-5: 99.57 ± 0.00, \t Sphere kNN + MI (1 runs) Seeds: [1]\n",
      "Top-1: 91.20 ± 0.00, \t Top-5: 99.75 ± 0.00, \t Sphere LogDet (1 runs) Seeds: [1]\n",
      "Top-1: 91.05 ± 0.00, \t Top-5: 99.71 ± 0.00, \t Sphere LogDet + MI (1 runs) Seeds: [1]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "for name in final_acc1_dict.keys():\n",
    "    vals_acc1 = final_acc1_dict[name]\n",
    "    vals_acc5 = final_acc5_dict[name]\n",
    "    val1_mean = np.mean(vals_acc1)\n",
    "    val5_mean = np.mean(vals_acc5)\n",
    "    val1_std = np.std(vals_acc1)\n",
    "    val5_std = np.std(vals_acc5)\n",
    "    n_runs = len(vals_acc1)\n",
    "    seeds = model_seed_dict[name]\n",
    "    print(f\"Top-1: {val1_mean:.2f} ± {val1_std:.2f}, \\t Top-5: {val5_mean:.2f} ± {val5_std:.2f}, \\t {name} ({n_runs} runs) Seeds: {seeds}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# cifar100 acc."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "def get_run_names(model_name, run_name):\n",
    "    folder_name = \"../trained_models/\" + model_name + \"/\"\n",
    "    # get name of the most recent model by folder creation time\n",
    "    names = sorted(os.listdir(folder_name), key=lambda x: os.path.getctime(os.path.join(folder_name, x)))\n",
    "    res = []\n",
    "    for n in names:\n",
    "        run = folder_name + n\n",
    "        args_file = os.path.join(run, \"args.json\")\n",
    "        args = json.load(open(args_file, \"r\"))\n",
    "        if args[\"name\"] == run_name:\n",
    "            res.append(n)\n",
    "    return res\n",
    "\n",
    "model_name = \"gaussprob\"\n",
    "run_name = \"gaussprob_cifar100_dual_sample\"\n",
    "names_gauss_dual_sample = get_run_names(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar100_single_sample\"\n",
    "names_gauss_single_sample = get_run_names(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar100_dual_knn\"\n",
    "names_gauss_dual_knn = get_run_names(model_name, run_name)\n",
    "run_name = \"gaussprob_cifar100_single_knn\"\n",
    "names_gauss_single_knn = get_run_names(model_name, run_name)\n",
    "model_name = \"vicreg2\" \n",
    "run_name = \"vicreg2_cifar100_lower_entropy\"\n",
    "names_gauss_dual_logdet = get_run_names(model_name, run_name)\n",
    "model_name = \"vicreg\"\n",
    "run_name = \"vicreg-cifar100\"\n",
    "names_gauss_single_logdet = get_run_names(model_name, run_name)\n",
    "model_name = \"sphereprob\"\n",
    "run_name = \"sphereprob_cifar100_dual_sample\"\n",
    "names_sphere_dual_sample = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_single_sample\"\n",
    "names_sphere_single_sample = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_dual_knn\"\n",
    "names_sphere_dual_knn = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_single_knn\"\n",
    "names_sphere_single_knn = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_dual_gauss\"\n",
    "names_sphere_dual_gauss = get_run_names(model_name, run_name)\n",
    "run_name = \"sphereprob_cifar100_single_gauss\"\n",
    "names_sphere_single_gauss = get_run_names(model_name, run_name)\n",
    "\n",
    "names_dict = {\n",
    "    r\"Plane Contr.\": names_gauss_dual_sample,\n",
    "    r\"Plane Contr. + MI\": names_gauss_single_sample,\n",
    "    r\"Plane kNN\": names_gauss_dual_knn,\n",
    "    r\"Plane kNN + MI\": names_gauss_single_knn,\n",
    "    r\"Plane LogDet\": names_gauss_dual_logdet,\n",
    "    r\"Plane LogDet + MI\": names_gauss_single_logdet,\n",
    "    r\"Sphere Contr.\": names_sphere_dual_sample,\n",
    "    r\"Sphere Contr. + MI\": names_sphere_single_sample,\n",
    "    r\"Sphere kNN\": names_sphere_dual_knn,\n",
    "    r\"Sphere kNN + MI\": names_sphere_single_knn,\n",
    "    r\"Sphere LogDet\": names_sphere_dual_gauss,\n",
    "    r\"Sphere LogDet + MI\": names_sphere_single_gauss,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Getting final val acc for Plane Contr. at djwleeq8...\n",
      "Getting final val acc for Plane Contr. at miqllvhm...\n",
      "Getting final val acc for Plane Contr. at r4z3y96b...\n",
      "  Seed 5 already exists for Plane Contr., skipping...\n",
      "Getting final val acc for Plane Contr. at v1c53bji...\n",
      "  Seed 5 already exists for Plane Contr., skipping...\n",
      "Getting final val acc for Plane Contr. at lrwaa49b...\n",
      "Getting final val acc for Plane Contr. + MI at 6i01eji8...\n",
      "Getting final val acc for Plane Contr. + MI at n9grh228...\n",
      "  Seed 5 already exists for Plane Contr. + MI, skipping...\n",
      "Getting final val acc for Plane Contr. + MI at qlj473h6...\n",
      "  Seed 5 already exists for Plane Contr. + MI, skipping...\n",
      "Getting final val acc for Plane Contr. + MI at wx0s61jl...\n",
      "Getting final val acc for Plane Contr. + MI at lgycj0tb...\n",
      "Getting final val acc for Plane kNN at 9pppbprk...\n",
      "Getting final val acc for Plane kNN at bhx2amen...\n",
      "  Seed 5 already exists for Plane kNN, skipping...\n",
      "Getting final val acc for Plane kNN at e4ow7zdc...\n",
      "  Seed 5 already exists for Plane kNN, skipping...\n",
      "Getting final val acc for Plane kNN at wlj68fkk...\n",
      "Getting final val acc for Plane kNN at wsex0cua...\n",
      "Getting final val acc for Plane kNN + MI at 7pvdjtmq...\n",
      "Getting final val acc for Plane kNN + MI at 9ea4ncoi...\n",
      "  Seed 5 already exists for Plane kNN + MI, skipping...\n",
      "Getting final val acc for Plane kNN + MI at az0vcxf6...\n",
      "  Seed 5 already exists for Plane kNN + MI, skipping...\n",
      "Getting final val acc for Plane kNN + MI at ln0xc7dh...\n",
      "Getting final val acc for Plane kNN + MI at 8sm3tq46...\n",
      "Getting final val acc for Plane LogDet at daviwain...\n",
      "Getting final val acc for Plane LogDet at dkhftaw7...\n",
      "Getting final val acc for Plane LogDet at lig5bdk9...\n",
      "  Seed 5 already exists for Plane LogDet, skipping...\n",
      "Getting final val acc for Plane LogDet at 1vod0805...\n",
      "Getting final val acc for Plane LogDet + MI at c4hmzk0g...\n",
      "Getting final val acc for Plane LogDet + MI at ewen7jjg...\n",
      "Getting final val acc for Plane LogDet + MI at jujrh9dc...\n",
      "  Seed 5 already exists for Plane LogDet + MI, skipping...\n",
      "Getting final val acc for Plane LogDet + MI at qsy88zz0...\n",
      "  Seed 5 already exists for Plane LogDet + MI, skipping...\n",
      "Getting final val acc for Plane LogDet + MI at o1joygxe...\n",
      "Getting final val acc for Sphere Contr. at kmonjc0w...\n",
      "Getting final val acc for Sphere Contr. + MI at 9m71p7wu...\n",
      "Getting final val acc for Sphere Contr. + MI at bxvucyxq...\n",
      "  Seed 5 already exists for Sphere Contr. + MI, skipping...\n",
      "Getting final val acc for Sphere Contr. + MI at imntahnb...\n",
      "Getting final val acc for Sphere kNN at 1gjz8cky...\n",
      "Getting final val acc for Sphere kNN + MI at 8q0lgfpf...\n",
      "Getting final val acc for Sphere kNN + MI at af33lz0u...\n",
      "  Seed 5 already exists for Sphere kNN + MI, skipping...\n",
      "Getting final val acc for Sphere kNN + MI at u5p51018...\n",
      "Getting final val acc for Sphere LogDet at rzy9unoy...\n",
      "Getting final val acc for Sphere LogDet + MI at fr9fsvnb...\n",
      "Getting final val acc for Sphere LogDet + MI at r180rzka...\n",
      "Getting final val acc for Sphere LogDet + MI at wnfvcomv...\n",
      "  Seed 5 already exists for Sphere LogDet + MI, skipping...\n"
     ]
    }
   ],
   "source": [
    "import wandb\n",
    "wandb.login()\n",
    "api = wandb.Api()\n",
    "\n",
    "def get_final_val_acc(model_name):\n",
    "    # get the project name\n",
    "    project_name = \"<yourname>/solo-learn\"\n",
    "    run = api.run(f\"{project_name}/{model_name}\")\n",
    "    metrics = run.history(keys=[\"val_acc1\", \"val_acc5\"])\n",
    "    seed = run.config[\"seed\"]\n",
    "    return metrics[\"val_acc1\"].values[-1], metrics[\"val_acc5\"].values[-1], seed\n",
    "\n",
    "final_acc1_dict = {}\n",
    "final_acc5_dict = {}\n",
    "model_seed_dict = {}\n",
    "for name, run_names in names_dict.items():\n",
    "    for run_name in run_names:\n",
    "        print(f\"Getting final val acc for {name} at {run_name}...\")\n",
    "        try:\n",
    "            val_acc1, val_acc5, seed = get_final_val_acc(run_name)\n",
    "            if name in final_acc1_dict:\n",
    "                if seed in model_seed_dict[name]:\n",
    "                    print(f\"  Seed {seed} already exists for {name}, skipping...\")\n",
    "                    continue\n",
    "                model_seed_dict[name].append(seed)\n",
    "                final_acc1_dict[name].append(val_acc1)\n",
    "                final_acc5_dict[name].append(val_acc5)\n",
    "            else:\n",
    "                final_acc1_dict[name] = [val_acc1]\n",
    "                final_acc5_dict[name] = [val_acc5]\n",
    "                model_seed_dict[name] = [seed]\n",
    "        except Exception as e:\n",
    "            print(f\"Could not get final val acc for {name}: {e}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Top-1: 65.21 ± 0.29, \t Top-5: 88.96 ± 0.20, \t Plane Contr. (3 runs) Seeds: [1, 5, 2]\n",
      "Top-1: 65.29 ± 0.15, \t Top-5: 88.96 ± 0.25, \t Plane Contr. + MI (3 runs) Seeds: [5, 1, 2]\n",
      "Top-1: 65.63 ± 0.36, \t Top-5: 88.93 ± 0.06, \t Plane kNN (3 runs) Seeds: [5, 1, 2]\n",
      "Top-1: 65.85 ± 0.38, \t Top-5: 88.94 ± 0.17, \t Plane kNN + MI (3 runs) Seeds: [5, 1, 2]\n",
      "Top-1: 68.02 ± 2.24, \t Top-5: 90.44 ± 1.31, \t Plane LogDet (3 runs) Seeds: [5, 1, 2]\n",
      "Top-1: 68.62 ± 0.06, \t Top-5: 90.77 ± 0.19, \t Plane LogDet + MI (3 runs) Seeds: [1, 5, 2]\n",
      "Top-1: 65.05 ± 0.00, \t Top-5: 88.85 ± 0.00, \t Sphere Contr. (1 runs) Seeds: [1]\n",
      "Top-1: 66.05 ± 0.29, \t Top-5: 89.57 ± 0.01, \t Sphere Contr. + MI (2 runs) Seeds: [5, 1]\n",
      "Top-1: 64.24 ± 0.00, \t Top-5: 87.91 ± 0.00, \t Sphere kNN (1 runs) Seeds: [1]\n",
      "Top-1: 64.38 ± 0.03, \t Top-5: 87.81 ± 0.15, \t Sphere kNN + MI (2 runs) Seeds: [5, 1]\n",
      "Top-1: 65.52 ± 0.00, \t Top-5: 89.30 ± 0.00, \t Sphere LogDet (1 runs) Seeds: [1]\n",
      "Top-1: 65.26 ± 0.01, \t Top-5: 89.19 ± 0.08, \t Sphere LogDet + MI (2 runs) Seeds: [1, 5]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "for name in final_acc1_dict.keys():\n",
    "    vals_acc1 = final_acc1_dict[name]\n",
    "    vals_acc5 = final_acc5_dict[name]\n",
    "    val1_mean = np.mean(vals_acc1)\n",
    "    val5_mean = np.mean(vals_acc5)\n",
    "    val1_std = np.std(vals_acc1)\n",
    "    val5_std = np.std(vals_acc5)\n",
    "    n_runs = len(vals_acc1)\n",
    "    seeds = model_seed_dict[name]\n",
    "    print(f\"Top-1: {val1_mean:.2f} ± {val1_std:.2f}, \\t Top-5: {val5_mean:.2f} ± {val5_std:.2f}, \\t {name} ({n_runs} runs) Seeds: {seeds}\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "solo",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
