{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Data Analysis of Similarity on Inverted Images with Varying Dataset Size and Robustness"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-02T08:25:02.797857Z",
     "start_time": "2024-10-02T08:25:02.779719Z"
    }
   },
   "source": [
    "palette = {\"inverted\": \"C0\", \"standard\": \"C1\"}\n",
    "palette = {\"inverted\": \"magenta\", \"standard\": \"cyan\"}\n",
    "palette = {\"inverted\": \"plum\", \"standard\": \"darkturquoise\"}\n",
    "\n",
    "color_kwargs=dict(hue=\"input\", palette=palette, legend=False)"
   ],
   "outputs": [],
   "execution_count": 1
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-02T09:40:32.097771Z",
     "start_time": "2024-10-02T09:40:31.407299Z"
    }
   },
   "source": [
    "results_base_dir = \"/root/univ-data/results\"\n",
    "\n",
    "results = {\n",
    "    \"imagenet100\": {\n",
    "        \"standard\":{\n",
    "            \"dis\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet100/standard/dis_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet100/standard/dis_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet100/standard/dis_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet100/standard/dis_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet100/standard/dis_eps3_0.csv\",\n",
    "            },\n",
    "            \"jsd\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet100/standard/jsd_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet100/standard/jsd_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet100/standard/jsd_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet100/standard/jsd_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet100/standard/jsd_eps3_0.csv\",\n",
    "            }\n",
    "        },\n",
    "        \"inverted\": {\n",
    "            \"dis\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet100/dis_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet100/dis_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet100/dis_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet100/dis_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet100/dis_eps3_0.csv\",\n",
    "            },\n",
    "            \"jsd\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet100/jsd_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet100/jsd_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet100/jsd_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet100/jsd_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet100/jsd_eps3_0.csv\",\n",
    "            },\n",
    "            \"cka\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet100/cka_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet100/cka_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet100/cka_eps05_100.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet100/cka_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet100/cka_eps3_0.csv\",\n",
    "            },\n",
    "            \"2ndcos\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet100/cos_sim_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet100/cos_sim_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet100/cos_sim_mean_eps05_100.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet100/cos_sim_mean_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet100/cos_sim_mean_eps3_0.csv\",\n",
    "            },\n",
    "            \"jaccard\": {\n",
    "                # \"eps0\":f\"{results_base_dir}/imagenet100/jac_mean_eps0_100.csv\",\n",
    "                # \"eps025\":f\"{results_base_dir}/imagenet100/jac_mean_eps025_100.csv\",\n",
    "                # \"eps05\":f\"{results_base_dir}/imagenet100/jac_mean_eps05_100.csv\",\n",
    "                # \"eps1\":f\"{results_base_dir}/imagenet100/jac_mean_eps1_100.csv\",\n",
    "                # \"eps3\":f\"{results_base_dir}/imagenet100/jac_mean_eps3_100.csv\",\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet100/jac_mean_eps0_10.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet100/jac_mean_eps025_10.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet100/jac_mean_eps05_10.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet100/jac_mean_eps1_10.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet100/jac_mean_eps3_10.csv\",\n",
    "            },\n",
    "            \"proc\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet100/proc_norm_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet100/proc_norm_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet100/proc_norm_mean_eps05_100.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet100/proc_norm_mean_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet100/proc_norm_mean_eps3_0.csv\",\n",
    "            },\n",
    "        }\n",
    "    },\n",
    "    \"imagenet1k\": {\n",
    "        \"inverted\": {\n",
    "            \"dis\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet1k/dis_eps0_1.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet1k/dis_eps025_1.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet1k/dis_eps05_1.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet1k/dis_eps1_1.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet1k/dis_eps3_1.csv\",\n",
    "            },\n",
    "            \"jsd\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet1k/jsd_eps0_1.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet1k/jsd_eps025_1.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet1k/jsd_eps05_1.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet1k/jsd_eps1_1.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet1k/jsd_eps3_1.csv\",\n",
    "            },\n",
    "            \"cka\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet1k/cka_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet1k/cka_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet1k/cka_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet1k/cka_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet1k/cka_eps3_0.csv\",\n",
    "            },\n",
    "            \"2ndcos\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet1k/cos_sim_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet1k/cos_sim_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet1k/cos_sim_mean_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet1k/cos_sim_mean_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet1k/cos_sim_mean_eps3_0.csv\",\n",
    "            },\n",
    "            \"jaccard\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet1k/jac_mean_eps0_10.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet1k/jac_mean_eps025_10.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet1k/jac_mean_eps05_10.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet1k/jac_mean_eps1_10.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet1k/jac_mean_eps3_10.csv\",\n",
    "            },\n",
    "            \"proc\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet1k/proc_norm_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet1k/proc_norm_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet1k/proc_norm_mean_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet1k/proc_norm_mean_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet1k/proc_norm_mean_eps3_0.csv\",\n",
    "            },\n",
    "        },\n",
    "        \"standard\": {\n",
    "            \"dis\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet1k/standard/dis_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet1k/standard/dis_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet1k/standard/dis_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet1k/standard/dis_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet1k/standard/dis_eps3_0.csv\",\n",
    "            },\n",
    "            \"jsd\": {\n",
    "                \"eps0\":f\"{results_base_dir}/imagenet1k/standard/jsd_eps0_1.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/imagenet1k/standard/jsd_eps025_1.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/imagenet1k/standard/jsd_eps05_1.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/imagenet1k/standard/jsd_eps1_1.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/imagenet1k/standard/jsd_eps3_1.csv\",\n",
    "            }\n",
    "        }\n",
    "    },\n",
    "    \"cifar10\": {\n",
    "        \"inverted\": {\n",
    "            \"dis\": {\n",
    "                \"eps0\": f\"{results_base_dir}/cifar10/dis_eps0_0.csv\",\n",
    "                \"eps025\": f\"{results_base_dir}/cifar10/dis_eps025_0.csv\",\n",
    "                \"eps05\": f\"{results_base_dir}/cifar10/dis_eps05_0.csv\",\n",
    "                \"eps1\": f\"{results_base_dir}/cifar10/dis_eps1_0.csv\",\n",
    "            },\n",
    "            \"jsd\": {\n",
    "                \"eps0\":f\"{results_base_dir}/cifar10/jsd_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/cifar10/standard/jsd_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/cifar10/standard/jsd_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/cifar10/jsd_eps1_0.csv\",\n",
    "            },\n",
    "            \"cka\": {\n",
    "                \"eps0\":f\"{results_base_dir}/cifar10/cka_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/cifar10/cka_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/cifar10/cka_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/cifar10/cka_eps1_0.csv\",\n",
    "            },\n",
    "            \"2ndcos\": {\n",
    "                \"eps0\":f\"{results_base_dir}/cifar10/cos_sim_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/cifar10/cos_sim_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/cifar10/cos_sim_mean_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/cifar10/cos_sim_mean_eps1_0.csv\",\n",
    "            },\n",
    "            \"jaccard\": {\n",
    "                \"eps0\":f\"{results_base_dir}/cifar10/jac_mean_eps0_10.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/cifar10/jac_mean_eps025_10.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/cifar10/jac_mean_eps05_10.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/cifar10/jac_mean_eps1_10.csv\",\n",
    "            },\n",
    "            \"proc\": {\n",
    "                \"eps0\":f\"{results_base_dir}/cifar10/proc_norm_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/cifar10/proc_norm_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/cifar10/proc_norm_mean_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/cifar10/proc_norm_mean_eps1_0.csv\",\n",
    "            },\n",
    "        },\n",
    "        \"standard\": {\n",
    "            \"dis\": {\n",
    "                \"eps0\": f\"{results_base_dir}/cifar10/standard/dis_eps0_0.csv\",\n",
    "                \"eps025\": f\"{results_base_dir}/cifar10/standard/dis_eps025_0.csv\",\n",
    "                \"eps05\": f\"{results_base_dir}/cifar10/standard/dis_eps05_0.csv\",\n",
    "                \"eps1\": f\"{results_base_dir}/cifar10/standard/dis_eps1_0.csv\",\n",
    "            }\n",
    "            ,\n",
    "            \"jsd\": {\n",
    "                \"eps0\":f\"{results_base_dir}/cifar10/standard/jsd_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/cifar10/standard/jsd_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/cifar10/standard/jsd_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/cifar10/standard/jsd_eps1_0.csv\",\n",
    "            }\n",
    "        }\n",
    "    },\n",
    "    \"sat6_imagenet1k\": {\n",
    "        \"inverted\": {\n",
    "            \"dis\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/imagenet/dis_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/imagenet/dis_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/imagenet/dis_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/imagenet/dis_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/sat6/imagenet/dis_eps3_0.csv\",\n",
    "            },\n",
    "            \"jsd\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/imagenet/jsd_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/imagenet/jsd_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/imagenet/jsd_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/imagenet/jsd_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/sat6/imagenet/jsd_eps3_0.csv\",\n",
    "            },\n",
    "            \"cka\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/imagenet/cka_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/imagenet/cka_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/imagenet/cka_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/imagenet/cka_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/sat6/imagenet/cka_eps3_0.csv\",\n",
    "            },\n",
    "            \"2ndcos\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/imagenet/cos_sim_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/imagenet/cos_sim_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/imagenet/cos_sim_mean_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/imagenet/cos_sim_mean_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/sat6/imagenet/cos_sim_mean_eps3_0.csv\",\n",
    "            },\n",
    "            \"jaccard\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/imagenet/jac_mean_eps0_10.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/imagenet/jac_mean_eps025_10.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/imagenet/jac_mean_eps05_10.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/imagenet/jac_mean_eps1_10.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/sat6/imagenet/jac_mean_eps3_10.csv\",\n",
    "            },\n",
    "            \"proc\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/imagenet/proc_norm_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/imagenet/proc_norm_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/imagenet/proc_norm_mean_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/imagenet/proc_norm_mean_eps1_0.csv\",\n",
    "                \"eps3\":f\"{results_base_dir}/sat6/imagenet/proc_norm_mean_eps3_0.csv\",\n",
    "            },\n",
    "        },\n",
    "    },\n",
    "    \"sat6_cifar10\": {\n",
    "        \"inverted\": {\n",
    "            \"dis\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/cifar10/dis_eps0_0.csv\",\n",
    "                #\"eps025\":f\"{results_base_dir}/sat6/cifar10/dis_eps025_0.csv\",\n",
    "                #\"eps05\":f\"{results_base_dir}/sat6/cifar10/dis_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/cifar10/dis_eps1_0.csv\",\n",
    "            },\n",
    "            \"jsd\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/cifar10/jsd_eps0_0.csv\",\n",
    "                #\"eps025\":f\"{results_base_dir}/sat6/cifar10/jsd_eps025_0.csv\",\n",
    "                #\"eps05\":f\"{results_base_dir}/sat6/cifar10/jsd_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/cifar10/jsd_eps1_0.csv\",\n",
    "            },\n",
    "            \"cka\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/cifar10/cka_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/cifar10/cka_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/cifar10/cka_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/cifar10/cka_eps1_0.csv\",\n",
    "            },\n",
    "            \"2ndcos\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/cifar10/cos_sim_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/cifar10/cos_sim_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/cifar10/cos_sim_mean_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/cifar10/cos_sim_mean_eps1_0.csv\",\n",
    "            },\n",
    "            \"jaccard\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/cifar10/jac_mean_eps0_10.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/cifar10/jac_mean_eps025_10.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/cifar10/jac_mean_eps05_10.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/cifar10/jac_mean_eps1_10.csv\",\n",
    "            },\n",
    "            \"proc\": {\n",
    "                \"eps0\":f\"{results_base_dir}/sat6/cifar10/proc_norm_mean_eps0_0.csv\",\n",
    "                \"eps025\":f\"{results_base_dir}/sat6/cifar10/proc_norm_mean_eps025_0.csv\",\n",
    "                \"eps05\":f\"{results_base_dir}/sat6/cifar10/proc_norm_mean_eps05_0.csv\",\n",
    "                \"eps1\":f\"{results_base_dir}/sat6/cifar10/proc_norm_mean_eps1_0.csv\",\n",
    "            },\n",
    "        },\n",
    "    },\n",
    "}\n",
    "\n",
    "\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "sns.set_theme(\"paper\", style=\"darkgrid\", font_scale=1.5)\n",
    "\n",
    "def eps_to_float(eps: str) -> float:\n",
    "    if eps == \"eps0\":\n",
    "        return 0.0\n",
    "    elif eps == \"eps025\":\n",
    "        return 0.25\n",
    "    elif eps == \"eps05\":\n",
    "        return 0.5\n",
    "    elif eps == \"eps1\":\n",
    "        return 1.0\n",
    "    elif eps == \"eps3\":\n",
    "        return 3.0\n",
    "    else:\n",
    "        raise ValueError(f\"Eps level not recognized: {eps}\")\n",
    "\n",
    "dfs = []\n",
    "for dataset, dataset_results in results.items():\n",
    "    for input_type, input_type_results in dataset_results.items():\n",
    "        for measure, path_dict in input_type_results.items():\n",
    "            for eps, csv_path in path_dict.items():\n",
    "                try:\n",
    "                    df = pd.read_csv(csv_path, index_col=0)\n",
    "                except FileNotFoundError as e:\n",
    "                    print(e)\n",
    "                    continue\n",
    "\n",
    "                # Mask out comparisons between identical models, so we can drop them easier later\n",
    "                for index_val in df.index:\n",
    "                    # df.loc[index_val, index_val] = 1.0\n",
    "                    df.loc[index_val, index_val] = np.NaN\n",
    "\n",
    "                # Give name to index\n",
    "                df = df.rename_axis(\"model1\")\n",
    "\n",
    "                # Bring data to long format (many rows) and remove self comparisons\n",
    "                df = df.reset_index().melt(id_vars=\"model1\", var_name=\"model2\", value_name=\"score\")\n",
    "                df = df.dropna(axis=0)\n",
    "\n",
    "                df[\"measure\"] = measure\n",
    "                df[\"eps\"] = eps_to_float(eps)\n",
    "                df[\"dataset\"] = dataset\n",
    "                df[\"input\"] = input_type\n",
    "\n",
    "                if measure == \"proc\":\n",
    "                    df.loc[:, \"score\"] = (2 - df.loc[:, \"score\"]) / 2\n",
    "\n",
    "                if measure == \"dis\":\n",
    "                    df.loc[:, \"score\"] = 1 - df.loc[:, \"score\"]\n",
    "\n",
    "                if measure == \"jsd\":\n",
    "                    df.loc[:, \"score\"] = (np.log(2) - df.loc[:, \"score\"]) / np.log(2)\n",
    "\n",
    "                dfs.append(df)\n",
    "\n",
    "data = pd.concat(dfs, axis=0)\n",
    "\n",
    "# Exclude tiny_vit_5m results on ImageNet100, because we mistakingly used checkpoints for IN1k\n",
    "data = data.loc[~(((data.model1 == \"tiny_vit_5m\") | (data.model2 == \"tiny_vit5m\")) & (data.dataset==\"imagenet100\"))]\n",
    "\n",
    "data.head()"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "            model1           model2   score measure  eps      dataset  \\\n",
       "1  wide_resnet50_2         resnet50  0.9695     dis  0.0  imagenet100   \n",
       "2      densenet161         resnet50  0.9599     dis  0.0  imagenet100   \n",
       "3         vgg16_bn         resnet50  0.9446     dis  0.0  imagenet100   \n",
       "4         resnet50  wide_resnet50_2  0.9695     dis  0.0  imagenet100   \n",
       "6      densenet161  wide_resnet50_2  0.9635     dis  0.0  imagenet100   \n",
       "\n",
       "      input  \n",
       "1  standard  \n",
       "2  standard  \n",
       "3  standard  \n",
       "4  standard  \n",
       "6  standard  "
      ],
      "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>model1</th>\n",
       "      <th>model2</th>\n",
       "      <th>score</th>\n",
       "      <th>measure</th>\n",
       "      <th>eps</th>\n",
       "      <th>dataset</th>\n",
       "      <th>input</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>wide_resnet50_2</td>\n",
       "      <td>resnet50</td>\n",
       "      <td>0.9695</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>densenet161</td>\n",
       "      <td>resnet50</td>\n",
       "      <td>0.9599</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>vgg16_bn</td>\n",
       "      <td>resnet50</td>\n",
       "      <td>0.9446</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>resnet50</td>\n",
       "      <td>wide_resnet50_2</td>\n",
       "      <td>0.9695</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>densenet161</td>\n",
       "      <td>wide_resnet50_2</td>\n",
       "      <td>0.9635</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 10
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "# sns.catplot(data=data, x=\"eps\", y=\"score\", hue=\"dataset\", kind=\"box\", row=\"measure\")\n",
    "sns.catplot(data=data, x=\"eps\", y=\"score\", hue=\"dataset\", kind=\"strip\", row=\"measure\", col=\"input\", alpha=0.4)"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "# sns.catplot(data=data, x=\"dataset\", y=\"score\", hue=\"eps\", kind=\"box\", row=\"measure\")"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "# sns.displot(data=data, x=\"score\", hue=\"dataset\", col=\"eps\", row=\"measure\", bins=20)\n"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## procrustes clusters"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "from sklearn.cluster import KMeans\n",
    "\n",
    "scores_df = data.loc[(data.dataset == \"imagenet1k\") & (data.eps==3.0) & (data.measure == \"proc\"), :].copy()\n",
    "\n",
    "scores = scores_df[\"score\"].values.reshape(-1, 1)\n",
    "kmeans = KMeans(n_clusters=4, random_state=567, n_init=\"auto\").fit(scores)\n",
    "\n",
    "\n",
    "scores_df[\"cluster\"] = kmeans.labels_\n"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "sns.catplot(data=scores_df, x=\"eps\", y=\"score\", hue=\"cluster\", palette=\"pastel\")"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "from IPython.display import display\n",
    "\n",
    "for cluster in sorted(scores_df.cluster.unique()):\n",
    "    print(cluster)\n",
    "    display(scores_df[scores_df.cluster == cluster])"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "data[(data.dataset==\"imagenet1k\") & (data.eps ==3) & (data.model1 == \"vgg16_bn\") & (data.model2 == \"tiny_vit_5m\")]\n",
    "data[(data.dataset==\"imagenet1k\") & (data.eps ==3) & (data.model1 == \"vgg16_bn\") & (data.model2 == \"tiny_vit_5m\")]"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Repsim Boxplots"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### One Panel Per Metric Per Dataset"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "# sns.set_theme(\n",
    "#         style=\"whitegrid\",\n",
    "#         palette=\"colorblind\",\n",
    "#     )\n",
    "n_panels = 3\n",
    "fig, axes = plt.subplots(1, n_panels, figsize=(n_panels*3*1.61, 3))\n",
    "ax_idx = 0\n",
    "\n",
    "models = [\"resnet18\", \"resnet50\", \"wide_resnet50_2\", \"wide_resnet50_4\", \"densenet161\", 'vgg16_bn', 'tiny_vit_5m', \"resnext50_32x4d\"]\n",
    "models = set(data.model1.unique()) | set(data.model2.unique())\n",
    "dataset = \"sat6_imagenet1k\"\n",
    "# dataset = \"imagenet1k\"\n",
    "input_type = \"inverted\"\n",
    "\n",
    "\n",
    "    # plotdata = data.loc[(data.measure == \"cka\") & (data.dataset.isin([\"cifar10\", \"imagenet1k\"])) & (data.input == input_type) & data.model1.isin(models) & data.model2.isin(models)]\n",
    "plotdata = data.loc[(data.measure == \"cka\") & (data.dataset == dataset) & (data.input == input_type) & data.model1.isin(models) & data.model2.isin(models)]\n",
    "ax = axes[ax_idx]\n",
    "sns.boxplot(plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"CKA\")\n",
    "ax.set_ylabel(\"Similarity\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "ax_idx += 1\n",
    "\n",
    "plotdata = data.loc[(data.measure == \"proc\") & (data.dataset == dataset) & (data.input == input_type)& data.model1.isin(models) & data.model2.isin(models)]\n",
    "ax = axes[ax_idx]\n",
    "sns.boxplot(plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"ProcrustesSim\")\n",
    "ax.set_ylabel(\"Similarity\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "ax_idx += 1\n",
    "\n",
    "plotdata = data.loc[(data.measure == \"jaccard\") & (data.dataset == dataset) & (data.input == input_type)& data.model1.isin(models) & data.model2.isin(models)]\n",
    "ax = axes[ax_idx]\n",
    "sns.boxplot(plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"Jaccard\")\n",
    "ax.set_ylabel(\"Similarity\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "ax_idx += 1\n",
    "\n",
    "# sns.reset_orig()\n",
    "fig.suptitle(dataset, y=1.05)\n",
    "fig.savefig(f\"./figs/repsim_inverted_{dataset}.pdf\", bbox_inches=\"tight\")\n",
    "fig"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### One Panel Per Metric"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-02T09:41:16.119762Z",
     "start_time": "2024-10-02T09:41:15.191428Z"
    }
   },
   "source": [
    "n_panels = 3\n",
    "\n",
    "models = [\"resnet18\", \"resnet50\", \"wide_resnet50_2\", \"wide_resnet50_4\", \"densenet161\", \"vgg16\", \"resnext50_32x4d\", \"vgg16_bn\", \"tiny_vit_5m\"]\n",
    "models = set(data.model1.unique()) | set(data.model2.unique())\n",
    "\n",
    "datasets = [\"sat6_cifar10\", \"sat6_imagenet1k\"]\n",
    "input_type = \"inverted\"\n",
    "\n",
    "fig, axes = plt.subplots(1, n_panels, figsize=(n_panels*3*1.61, 3))\n",
    "ax_idx = 0\n",
    "\n",
    "\n",
    "# plotdata = data.loc[(data.measure == \"cka\") & (data.dataset.isin([\"cifar10\", \"imagenet1k\"])) & (data.input == input_type) & data.model1.isin(models) & data.model2.isin(models)]\n",
    "plotdata = data.loc[(data.measure == \"cka\") & (data.dataset.isin(datasets)) & (data.input == input_type) & data.model1.isin(models) & data.model2.isin(models)]\n",
    "ax = axes[ax_idx]\n",
    "sns.boxplot(plotdata, x=\"dataset\", y=\"score\", ax=ax, hue=\"eps\", legend=False)\n",
    "ax.set_title(\"CKA\")\n",
    "ax.set_ylabel(\"Similarity\")\n",
    "ax.set_xlabel(r\"Training Dataset\")\n",
    "ax.set_xticklabels([\"ImageNet1k\", \"CIFAR-10\"])\n",
    "ax_idx += 1\n",
    "\n",
    "plotdata = data.loc[(data.measure == \"proc\") & (data.dataset.isin(datasets)) & (data.input == input_type)& data.model1.isin(models) & data.model2.isin(models)]\n",
    "ax = axes[ax_idx]\n",
    "sns.boxplot(plotdata, x=\"dataset\", y=\"score\", ax=ax, hue=\"eps\", legend=False)\n",
    "ax.set_title(\"ProcrustesSim\")\n",
    "ax.set_ylabel(\"\")\n",
    "ax.set_xlabel(r\"Training Dataset\")\n",
    "ax.set_xticklabels([\"ImageNet1k\", \"CIFAR-10\"])\n",
    "ax_idx += 1\n",
    "\n",
    "plotdata = data.loc[(data.measure == \"jaccard\") & (data.dataset.isin(datasets)) & (data.input == input_type)& data.model1.isin(models) & data.model2.isin(models)]\n",
    "ax = axes[ax_idx]\n",
    "sns.boxplot(plotdata, x=\"dataset\", y=\"score\", ax=ax, hue=\"eps\", legend=True)\n",
    "ax.set_title(\"Jaccard\")\n",
    "ax.set_ylabel(\"\")\n",
    "ax.set_xlabel(r\"Training Dataset\")\n",
    "ax.set_xticklabels([\"ImageNet1k\", \"CIFAR-10\"])\n",
    "sns.move_legend(ax, \"center\", bbox_to_anchor=(1.2,0.5))\n",
    "\n",
    "ax_idx += 1\n",
    "\n",
    "fig.savefig(f\"./figs/repsim_sat6_inverted_in1k_and_cifar10.pdf\", bbox_inches=\"tight\")"
   ],
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_241546/1374791797.py:20: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"ImageNet1k\", \"CIFAR-10\"])\n",
      "/tmp/ipykernel_241546/1374791797.py:29: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"ImageNet1k\", \"CIFAR-10\"])\n",
      "/tmp/ipykernel_241546/1374791797.py:38: UserWarning: FixedFormatter should only be used together with FixedLocator\n",
      "  ax.set_xticklabels([\"ImageNet1k\", \"CIFAR-10\"])\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 1449x300 with 3 Axes>"
      ],
      "image/png": "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offjjz/im2++Ubm+V69e8Pf3x5UrV7Bt2zaV8/n5+aioqND62vriuHfvHt59910d7qz2eaampgYffPCBUgL19u3b+OKLL3Tqk4haLi4hJzKRF198EQ8ePMCmTZswefJk+Pv7o1evXrCzs8Pdu3fx+++/48aNG+jVq1eD/QgEArz77ruwtrbG559/jueeew6fffYZDh06hOrqaowdO1Zp98C/mzJlCs6ePYuvv/4aQ4YM0fdtEhE1e//+978xbdo0rF69Gj/99BN69eqF7OxsJCYmwsLCAu+9957SBjJTpkzB77//joMHD2LkyJEYMWIE2rVrh7y8PPz666+YNGkSFi5cqPH4zz//PJYuXYpp06YhJCQEVlZWOH36NKqqquDn54c//vhDcW15eTmeeeYZdOzYET179oSnpycqKirw888/488//8Tw4cPRpUsXxfWPPfYY0tPTMXfuXAQEBMDS0hJ+fn4YPnw4nJycsH79eoSHh+Ppp5/GY489hq5du0IgECAnJwepqamQyWSKD+F++uknrFmzBv369UOnTp3g7OyMnJwcpKSkwMLCAs8//7xi3B9//BHvvPMOvLy80L9/f3h4eKCyshI3b97EqVOnUFVVhenTp+t1cyMioubomWeewf79+/Hyyy8jODgYEokE//nPf/Djjz8iNDQUhw8fVmmzZs0azJgxAx9++CGOHj2KwYMHQy6X48aNG/jpp59w5MgReHt7a3Vt79690b9/fyQlJSEsLAz9+/fHvXv3cPLkSfj4+EAikWh9b3PmzMGxY8dw9OhRTJgwAY8//jiKiopw5MgRBAQE4Pjx403++RFRy8EEJpEJRUREIDQ0FF999RVOnz6N/fv3o7KyEmKxGH5+fpg7d67anXLV+de//gUbGxt8/PHHeO655xRLHSdPntxgu5CQEKxcuRLHjx/HvXv36i2kTUTUWrVv3x779u3D5s2bcfLkSZw5cwZ2dnYYOnQoXnzxRZUkm0AgwOrVq/H4449j7969OHLkCCorK+Hq6ooBAwZg+PDhWo0/efJkyOVyfPbZZ4iPj4ejoyNGjBiBxYsX46WXXlK61sbGBq+++ipOnz6N1NRUHDt2DHZ2dujQoQPeeecdTJo0Sen6+fPno7CwECdOnMC5c+dQXV2NCRMmKGJ87LHH8O233+LTTz/FqVOn8Pvvv0MkEkEikeDRRx9F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bV9QUIB169YpHbt06RIuXboEAJgwYYJSAtPT0xN79uxBTEwM9uzZg9LSUnTq1Anvvvsupk6dqt+boxbJVugMoUBk0DGq5VVMlBJRi6RzApNahpEjQ7B+/VpERb2O5cuj4enppaiB6ejoiKCgYFOHSEREpJX7BQUQCASIiorUuq22baytrLFvfwKTmEQmEhISgpCQkAavGTx4MK5evapy3NvbW+3xhrRv3x4ffvihVm2I6ggFIrSxsDTsIAZeok5EZCpMYLZytrZ2iInZhMWLwzF2bDBcXSXIy8uFo6MjYmI2cQMfIiJqdorLSmvrcI+aDM92utW704T0fh62HP4GMpmMCUwiIiIiIgPSOIHp5+cHgUCg9QACgQCXL1/Wuh0ZT9++/khISEZy8lFkZWXCy8sbQUHBTF4SEZlYxu3bBh9DmpNr8DFMxbOdBD5uTCwSERERETV3GicwBw4caMg4yMRsbe242zgRkZlZtnqtqUMgMiuZmbfVbhbUGAcHh0brdBIRERGR+dI4gVm3Qx8REREZx/LIV+DT3rBJl59++x1bdsUadAwifcjPz8f48aGoqdG+wJtQKERS0knuek5ERESoqKhAVVWVqcNQIhKJYGVlZeowzBprYBIREZkpn/bt0aNbV4OOYYxl6i0ddzs3DicnJxw4cETtDMyMjOuIiorEihWr4ePTWeW8g4MDk5dERESEiooKhAQPx73790wdihLnds5IPHq8yUnMEydSEBv7Of78878QiUTo29cf8+dHoEuXxt9TJCR8ixUr3lF7zs+vBz777MsmxdZUTGASERERbmZlGbT/7Dt3DNq/KchKahNpxtjt3NLSCvHx37X6JGZjy8B9fDqjR49HjBQNERERNTdVVVW4d/8edr/3PmytrU0dDgCgtLwc0/71OqqqqpqUwPz22wN477130aVLV4SHv4TKykrExe3BCy/Mxtatn6Jr124a9TNz5hx06uSjdMzRUaxzXPqicQJz48aNEAgEePbZZyEWi7Fx40aN2gkEAoSHh+scIBERERnevzdtNnUIzU5peTkAwFboDKFAZLBxquVVKK28x93OiYiISMndu3ewYUMMbt26iY4dOyEiYhFcXFxNHVazYGttDTsbG1OHoTeFhYVYt+5DSCRu2Lr1U9jZ2QMARowIwrRpkxETswabNm3VqK9Bgx7FgAEBhgxXJ1on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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 11
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Repsim Heatmaps"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {},
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "df = data.copy()\n",
    "# Add back self-comparisons\n",
    "self_comps = []\n",
    "for dataset in df.dataset.unique():\n",
    "    for measure in df.measure.unique():\n",
    "        for eps in df.eps.unique():\n",
    "            for input_type in df.input.unique():\n",
    "                selection = df.loc[(df.dataset == dataset) & (df.measure == measure) & (df.eps == eps) & (df.input == input_type)]\n",
    "                for model in set(selection.model1.unique()) | set(selection.model2.unique()):\n",
    "                    self_comps.append((model, model, 1.0, measure, eps, dataset, input_type))\n",
    "self_comps = pd.DataFrame.from_records(self_comps, columns=df.columns)\n",
    "df = pd.concat((df, self_comps))\n",
    "print(df.tail())\n",
    "\n",
    "measures = [\"cka\", \"proc\", \"jaccard\"]\n",
    "models = [\"resnet18\", \"resnet50\", \"wide_resnet50_2\", \"wide_resnet50_4\", \"tiny_vit_5m\", \"vgg16_bn\"]\n",
    "# measures = [\"cka\", \"2ndcos\", \"proc\", \"jaccard\"]\n",
    "n_measures = len(measures)\n",
    "fig, axes = plt.subplots(n_measures, 5, figsize=(5*3, n_measures*3))\n",
    "for row_idx, measure in enumerate(measures):\n",
    "    for col_idx, eps in enumerate(sorted(df.eps.unique())):\n",
    "        ax = axes[row_idx, col_idx]\n",
    "        plotdf = df.loc[\n",
    "            (df.dataset == \"imagenet1k\") & (df.measure == measure) & (df.eps == eps) & (df.input == \"inverted\") &\n",
    "              (df.model1.isin(models)) &\n",
    "              (df.model2.isin(models))\n",
    "        ]\n",
    "        plotdf = plotdf.pivot(index=\"model1\", columns=\"model2\", values=\"score\")\n",
    "        sns.heatmap(\n",
    "            plotdf,\n",
    "            ax=ax,\n",
    "            vmin=0,\n",
    "            vmax=1,\n",
    "            annot=True,\n",
    "            fmt=\".1f\",\n",
    "            linewidths=0.5,\n",
    "            cbar=False,\n",
    "            # xticklabels=[\"\"] * len(plotdf.columns),\n",
    "            # yticklabels=[\"\"] * len(plotdf.columns),\n",
    "        )\n",
    "        if col_idx == 0:\n",
    "            ax.set_ylabel(measure)\n",
    "        else:\n",
    "            ax.set_ylabel(\"\")\n",
    "        if row_idx == 0:\n",
    "            ax.set_title(f\"{eps=}\")\n",
    "        ax.set_xlabel(\"\")\n",
    "\n",
    "# for measure in df.measure.unique():\n",
    "#     plotdf = df.loc[\n",
    "#         (df.dataset == \"imagenet1k\") & (df.measure == measure) & (df.eps == 3.0) & (df.input == \"inverted\")\n",
    "#     ]\n",
    "#     plotdf = plotdf.pivot(index=\"model1\", columns=\"model2\", values=\"score\")\n",
    "#     sns.heatmap(plotdf, ax=ax, vmin=0, vmax=1, annot=True, fmt=\".2f\", linewidths=0.5)\n",
    "#     ax.set_title(measure)\n",
    "\n",
    "fig.savefig(\"../figs/repsim_inverted.pdf\", bbox_inches=\"tight\")"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Agreement plot mit min/max"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-02T08:26:14.593992Z",
     "start_time": "2024-10-02T08:26:14.517842Z"
    }
   },
   "source": [
    "evals = pd.read_csv(\"/root/univ-data/eval_results.csv\", index_col=0)\n",
    "evals.loc[:, \"dataset\"] = evals[\"dataset\"].map({\"imagenet\": \"imagenet1k\", \"imagenet100\": \"imagenet100\", \"cifar10\": \"cifar10\"})\n",
    "\n",
    "# Exclude tiny_vit_5m results on ImageNet100, because we mistakingly used checkpoints for IN1k\n",
    "evals = evals.loc[~((evals.model == \"tiny_vit_5m\") & (evals.dataset==\"imagenet100\"))]\n",
    "\n",
    "evals.head()"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "         model      dataset        acc      loss  trained_eps  attack_lr  \\\n",
       "0  densenet161  imagenet100  83.299995  0.641170         0.00       0.00   \n",
       "1  densenet161  imagenet100  57.480000  2.102689         0.00       0.16   \n",
       "0  densenet161  imagenet100  83.239998  0.589786         0.25       0.00   \n",
       "1  densenet161  imagenet100  78.320000  0.769355         0.25       0.16   \n",
       "0  densenet161  imagenet100  82.159996  0.610331         0.50       0.00   \n",
       "\n",
       "   attack_eps                   timestamp  \n",
       "0        0.00  2024-09-27 12:42:17.010629  \n",
       "1        0.25  2024-09-27 12:42:17.010629  \n",
       "0        0.00  2024-09-27 12:43:26.219966  \n",
       "1        0.25  2024-09-27 12:43:26.219966  \n",
       "0        0.00  2024-09-27 12:44:35.519516  "
      ],
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>model</th>\n",
       "      <th>dataset</th>\n",
       "      <th>acc</th>\n",
       "      <th>loss</th>\n",
       "      <th>trained_eps</th>\n",
       "      <th>attack_lr</th>\n",
       "      <th>attack_eps</th>\n",
       "      <th>timestamp</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>densenet161</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>83.299995</td>\n",
       "      <td>0.641170</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>2024-09-27 12:42:17.010629</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>densenet161</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>57.480000</td>\n",
       "      <td>2.102689</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.16</td>\n",
       "      <td>0.25</td>\n",
       "      <td>2024-09-27 12:42:17.010629</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>densenet161</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>83.239998</td>\n",
       "      <td>0.589786</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>2024-09-27 12:43:26.219966</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>densenet161</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>78.320000</td>\n",
       "      <td>0.769355</td>\n",
       "      <td>0.25</td>\n",
       "      <td>0.16</td>\n",
       "      <td>0.25</td>\n",
       "      <td>2024-09-27 12:43:26.219966</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>densenet161</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>82.159996</td>\n",
       "      <td>0.610331</td>\n",
       "      <td>0.50</td>\n",
       "      <td>0.00</td>\n",
       "      <td>0.00</td>\n",
       "      <td>2024-09-27 12:44:35.519516</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 3
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-02T08:26:16.075181Z",
     "start_time": "2024-10-02T08:26:16.026888Z"
    }
   },
   "cell_type": "code",
   "source": [
    "evals = pd.read_csv(\"/root/univ-data/eval_results.csv\", index_col=0)\n",
    "print(evals[(evals.dataset == \"imagenet\") & (evals.model == \"wide_resnet50_4\")][[\"model\", \"acc\", \"trained_eps\"]])"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "             model        acc  trained_eps\n",
      "0  wide_resnet50_4  77.909996         0.00\n",
      "1  wide_resnet50_4  32.742001         0.00\n",
      "0  wide_resnet50_4  77.099998         0.25\n",
      "1  wide_resnet50_4  72.823997         0.25\n",
      "0  wide_resnet50_4  76.519997         0.50\n",
      "1  wide_resnet50_4  68.995995         0.50\n",
      "0  wide_resnet50_4  75.509995         1.00\n",
      "1  wide_resnet50_4  62.783997         1.00\n",
      "0  wide_resnet50_4  69.669998         3.00\n",
      "1  wide_resnet50_4  45.174000         3.00\n"
     ]
    }
   ],
   "execution_count": 4
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Add column with accuracy difference to correlate with similarity metrics"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-02T08:26:32.412217Z",
     "start_time": "2024-10-02T08:26:19.246575Z"
    }
   },
   "source": [
    "data2 = data.copy().reset_index(drop=True)\n",
    "data2[\"acc_diff\"] = np.nan\n",
    "for index, row in data.reset_index(drop=True).iterrows():\n",
    "\n",
    "    # dataset == \"imagenet\" if row[\"dataset\"] == \"imagenet1k\" else row[\"dataset\"]\n",
    "    dataset = row[\"dataset\"]\n",
    "\n",
    "    acc1 = evals.loc[(evals.model == row[\"model1\"]) & (evals.dataset == dataset) & (evals.attack_eps == row[\"eps\"]) & (evals.trained_eps == row[\"eps\"]), \"acc\"]\n",
    "    acc2 = evals.loc[(evals.model == row[\"model2\"]) & (evals.dataset == dataset) & (evals.attack_eps == row[\"eps\"]) & (evals.trained_eps == row[\"eps\"]), \"acc\"]\n",
    "\n",
    "    if len(acc1) == 1 and len(acc2) == 1:\n",
    "        data2.loc[index, \"acc_diff\"] = abs(acc1.item() - acc2.item())\n",
    "\n",
    "data2.head()"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "            model1           model2   score measure  eps      dataset  \\\n",
       "0  wide_resnet50_2         resnet50  0.9695     dis  0.0  imagenet100   \n",
       "1      densenet161         resnet50  0.9599     dis  0.0  imagenet100   \n",
       "2         vgg16_bn         resnet50  0.9446     dis  0.0  imagenet100   \n",
       "3         resnet50  wide_resnet50_2  0.9695     dis  0.0  imagenet100   \n",
       "4      densenet161  wide_resnet50_2  0.9635     dis  0.0  imagenet100   \n",
       "\n",
       "      input  acc_diff  \n",
       "0  standard  1.500000  \n",
       "1  standard  4.299995  \n",
       "2  standard  3.519997  \n",
       "3  standard  1.500000  \n",
       "4  standard  2.799995  "
      ],
      "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>model1</th>\n",
       "      <th>model2</th>\n",
       "      <th>score</th>\n",
       "      <th>measure</th>\n",
       "      <th>eps</th>\n",
       "      <th>dataset</th>\n",
       "      <th>input</th>\n",
       "      <th>acc_diff</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>wide_resnet50_2</td>\n",
       "      <td>resnet50</td>\n",
       "      <td>0.9695</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "      <td>1.500000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>densenet161</td>\n",
       "      <td>resnet50</td>\n",
       "      <td>0.9599</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "      <td>4.299995</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>vgg16_bn</td>\n",
       "      <td>resnet50</td>\n",
       "      <td>0.9446</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "      <td>3.519997</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>resnet50</td>\n",
       "      <td>wide_resnet50_2</td>\n",
       "      <td>0.9695</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "      <td>1.500000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>densenet161</td>\n",
       "      <td>wide_resnet50_2</td>\n",
       "      <td>0.9635</td>\n",
       "      <td>dis</td>\n",
       "      <td>0.0</td>\n",
       "      <td>imagenet100</td>\n",
       "      <td>standard</td>\n",
       "      <td>2.799995</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "execution_count": 5
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "# sns.lmplot(data2[data2.measure == \"dis\"], x=\"acc_diff\", y=\"score\", row=\"dataset\", col=\"eps\")"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Agreement\n",
    "#### Standard"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-02T08:43:44.518657Z",
     "start_time": "2024-10-02T08:43:42.040686Z"
    }
   },
   "source": [
    "def disagreement_lower_bound(x, num_classes: int=1000):\n",
    "    \"\"\"Fort et al 2020. Deep Ensembles: A Loss Landscape Perspective. Apx D2\"\"\"\n",
    "    a = x[\"acc1\"]/100\n",
    "    a_star = x[\"acc2\"]/100\n",
    "\n",
    "    if np.isnan(a) or np.isnan(a_star):\n",
    "        return np.nan\n",
    "\n",
    "    if a > a_star:\n",
    "        a_star, a = a, a_star\n",
    "\n",
    "    return (num_classes - 1) * (a_star - a) / (num_classes * a_star - 1)\n",
    "\n",
    "\n",
    "def disagreement_upper_bound(x, num_classes: int=1000):\n",
    "    \"\"\"Fort et al 2020. Deep Ensembles: A Loss Landscape Perspective. Apx D1\"\"\"\n",
    "    a = x[\"acc1\"]/100\n",
    "    a_star = x[\"acc2\"]/100\n",
    "\n",
    "    if np.isnan(a) or np.isnan(a_star):\n",
    "        return np.nan\n",
    "\n",
    "    if a > a_star:\n",
    "        a_star, a = a, a_star\n",
    "\n",
    "    return (1 - a_star) * a + (1 - a) * a_star + (1 - a_star) * (1 - a) * (num_classes - 2) / (num_classes - 1)\n",
    "\n",
    "\n",
    "def combine_agreement_with_acc(data: pd.DataFrame, evals: pd.DataFrame, dataset: str, num_classes: int = 1000, input_type=\"standard\", combine_with_regular_acc: bool=True):\n",
    "    agreement_data = data.loc[(data.dataset == dataset) & (data.measure == \"dis\") & (data.input == input_type), :].copy()\n",
    "    if combine_with_regular_acc:\n",
    "        evals_subset = evals.loc[(evals.dataset == dataset) & (evals.attack_eps==0), :]\n",
    "    else:\n",
    "        evals_subset = evals.loc[(evals.dataset == dataset) & (evals.attack_eps==evals.trained_eps), :]\n",
    "\n",
    "\n",
    "    evals_subset = evals_subset.drop_duplicates([\"model\", \"dataset\", \"acc\", \"trained_eps\", \"attack_lr\", \"attack_eps\"], keep=\"last\")\n",
    "    print(len(agreement_data), len(evals_subset))\n",
    "\n",
    "    # Add accuracy information to each comparison\n",
    "    merged = pd.merge(\n",
    "        agreement_data,\n",
    "        evals_subset.rename(columns={\"model\": \"model1\", \"trained_eps\": \"eps\"}),\n",
    "        \"left\",\n",
    "        on=[\"model1\", \"eps\"],\n",
    "        suffixes=(None, \"_y\"),\n",
    "    )\n",
    "    merged = merged.drop([\"loss\", \"attack_lr\", \"attack_eps\", \"timestamp\", \"dataset_y\"], axis=\"columns\")\n",
    "    merged = merged.rename(columns={\"acc\": \"acc1\"})\n",
    "\n",
    "    merged = pd.merge(\n",
    "        merged,\n",
    "        evals_subset.rename(columns={\"model\": \"model2\", \"trained_eps\": \"eps\"}),\n",
    "        \"left\",\n",
    "        on=[\"model2\", \"eps\"],\n",
    "        suffixes=(None, \"_y\"),\n",
    "    )\n",
    "    merged = merged.drop([\"loss\", \"attack_lr\", \"attack_eps\", \"timestamp\", \"dataset_y\"], axis=\"columns\")\n",
    "    merged = merged.rename(columns={\"acc\": \"acc2\"})\n",
    "\n",
    "    # Add bounds\n",
    "    merged[\"ub\"] = 1 - merged.apply(disagreement_lower_bound, axis=1, num_classes=num_classes)\n",
    "    merged[\"lb\"] = 1 - merged.apply(disagreement_upper_bound, axis=1, num_classes=num_classes)\n",
    "    return merged\n",
    "\n",
    "\n",
    "\n",
    "n_panels = 2\n",
    "fig, axes = plt.subplots(1, n_panels, figsize=(n_panels*3*1.61, 3))\n",
    "\n",
    "fontsize=24\n",
    "# fontweight=\"normal\"\n",
    "fontweight=\"bold\"\n",
    "\n",
    "ax_idx = 0\n",
    "ax = axes[ax_idx]\n",
    "plotdata = combine_agreement_with_acc(data2, evals, \"imagenet1k\")\n",
    "sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"ImageNet1k\")\n",
    "ax.set_ylabel(\"Agreement\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "#bounds = plotdata.groupby([\"eps\"])[[\"ub\", \"lb\"]].mean()\n",
    "#ax.plot([0, 1, 2, 3, 4], bounds[\"lb\"], color=\"gray\", linestyle=\"--\")\n",
    "#ax.plot([0, 1, 2, 3, 4], bounds[\"ub\"], color=\"gray\", linestyle=\"-.\")\n",
    "#ax.text(3.8, 0.93, \"Upper Bound\", color=\"gray\", ha=\"center\")\n",
    "#ax.text(3.8, 0.47, \"Lower Bound\", color=\"gray\", ha=\"center\")\n",
    "ax.text(x=-0.15, y=1.03, s=\"A\", va=\"bottom\", color=\"black\", transform=ax.transAxes, fontdict={\n",
    "                        'fontsize': fontsize,\n",
    "                        'fontweight': fontweight\n",
    "                    })\n",
    "ax_idx += 1\n",
    "\n",
    "# ax = axes[ax_idx]\n",
    "# plotdata = combine_agreement_with_acc(data2, evals, \"imagenet100\", num_classes=100)\n",
    "# sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "# ax.set_title(\"ImageNet100\")\n",
    "# ax.set_ylabel(\"Agreement\")\n",
    "# ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "# bounds = plotdata.groupby([\"eps\"])[[\"ub\", \"lb\"]].mean()\n",
    "# ax.plot([0, 1, 2, 3, 4], bounds[\"lb\"], color=\"gray\", linestyle=\"--\")\n",
    "# ax.plot([0, 1, 2, 3, 4], bounds[\"ub\"], color=\"gray\", linestyle=\"-.\")\n",
    "# ax_idx += 1\n",
    "\n",
    "ax = axes[ax_idx]\n",
    "plotdata = combine_agreement_with_acc(data2, evals, \"cifar10\", num_classes=10)\n",
    "sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"CIFAR10\")\n",
    "ax.set_ylabel(\"Agreement\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "#bounds = plotdata.groupby([\"eps\"])[[\"ub\", \"lb\"]].mean()\n",
    "#ax.plot([0, 1, 2, 3], bounds[\"lb\"], color=\"gray\", linestyle=\"--\")\n",
    "#ax.plot([0, 1, 2, 3], bounds[\"ub\"], color=\"gray\", linestyle=\"-.\")\n",
    "#ax.text(3.0, 0.91, \"Upper Bound\", color=\"gray\", ha=\"center\")\n",
    "#ax.text(3.0, 0.57, \"Lower Bound\", color=\"gray\", ha=\"center\")\n",
    "#ax.text(x=-0.15, y=1.03, s=\"A\", va=\"bottom\", color=\"black\", transform=ax.transAxes, fontdict={\n",
    " #                       'fontsize': fontsize,\n",
    "  #                      'fontweight': fontweight\n",
    "   #                 })\n",
    "\n",
    "\n",
    "fig.savefig(\"./figs/agreement_regular.pdf\", bbox_inches=\"tight\")"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "202 0\n",
      "168 20\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 966x300 with 2 Axes>"
      ],
      "image/png": "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liq3t7eHn58fZsyYUa/zERERERGR4dLLogkAhg4diqFDhyrcp3fv3rh165bcbc2aNcOcOXMwZ84chX106NABX3zxhaphEhERERGRgdO7Z5qIiIiIiIj0CYsmIiIiIiIiBVg0ERERERERKcCiiYiIiIiISAEWTURERERERAqwaCIiIiIiIlKARRMREREREZECLJqIiIiIiIgUYNFERERERESkAIsmIiIiIiIiBUx0HQAREWlHdnYWSkqK671/RsY9qV+VYWFhCScnZ6WPIyIi3VM2XzxPnfzxLH3KJQKRSCTSdRCGLC+vBJWV1boOg4iauMLCAsyYMQkikXY+j4yMjLBzZxSsrW000p+JiRHs7Cw00pchYY4hIk3Tdr5QRNO5RJ765hcWTQ2MCY2I9IW63xwqQ9PfDrJoko85hogagjbzhSLauNNU3/zC6XlERE2EvkxxICIi/cZ8IYsLQRARERERESnAoomIiIiIiEgBFk1EREREREQKsGgiIiIiIiJSgEUTERERERGRAiyaiIiIiIiIFGDRREREREREpADf09TAjI1ZlxIRqYufpfJxXIiI1FPfz1GBSCQSNXAsREREREREjRa/oiIiIiIiIlKARRMREREREZECLJqIiIiIiIgUYNFERERERESkAIsmIiIiIiIiBVg0ERERERERKcCiiYiIiIiISAEWTURERERERAqwaCIiIiIiIlKARRMREREREZECLJqIiIiIiIgUMNF1AKSakydPYteuXbh9+zaEQiF69uyJBQsWwN3dvV7Hl5aWYuvWrTh27BgePnwIR0dH+Pv7IywsDObm5g0cverUue7Tp08jKSkJaWlpyMzMRLNmzdC2bVsEBQVhzJgxMDGR/nFYunQpEhMT5fY1bdo0LFmyRCPX1BDUGaeEhAQsW7ZM7rbOnTsjISFB0+E2qC+//BLXr1/H9evX8d///hdGRka4fv260v001p+ZZ+Xm5mL9+vW4du0asrOz8eTJEzg4OODll1/GjBkz0Llz53r1YwhjQeppqjlIE5jHtIe5ULOaej5l0dQIxcXFYeXKlXB3d8eiRYtQVlaG6OhohISEICYmBh4eHgqPr6qqwqxZs5CSkoLRo0fjlVdewc2bNxEZGYnLly9j9+7dMDLSv5uQ6l73qlWrYG5uDj8/P3To0AFFRUU4evQoVqxYgZMnT2LHjh0QCAQy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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 9
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Inverted"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "n_panels = 2\n",
    "fig, axes = plt.subplots(1, n_panels, figsize=(n_panels*3*1.61, 3))\n",
    "\n",
    "fontsize=24\n",
    "# fontweight=\"normal\"\n",
    "fontweight=\"bold\"\n",
    "\n",
    "ax_idx = 0\n",
    "ax = axes[ax_idx]\n",
    "plotdata = combine_agreement_with_acc(data2, evals, \"imagenet1k\", input_type=\"inverted\", combine_with_regular_acc=False)\n",
    "sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"ImageNet1k\")\n",
    "ax.set_ylabel(\"Agreement\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "ax.text(x=-0.15, y=1.03, s=\"A\", va=\"bottom\", color=\"black\", transform=ax.transAxes, fontdict={\n",
    "                        'fontsize': fontsize,\n",
    "                        'fontweight': fontweight\n",
    "                    })\n",
    "ax_idx += 1\n",
    "\n",
    "# ax = axes[ax_idx]\n",
    "# plotdata = combine_agreement_with_acc(data2, evals, \"imagenet100\", num_classes=100, input_type=\"inverted\", combine_with_regular_acc=False)\n",
    "# sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, hue=\"input\", palette=palette, legend=False)\n",
    "# ax.set_title(\"ImageNet100\")\n",
    "# ax.set_ylabel(\"Agreement\")\n",
    "# ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "# ax_idx += 1\n",
    "\n",
    "ax = axes[ax_idx]\n",
    "plotdata = combine_agreement_with_acc(data2, evals, \"cifar10\", num_classes=10, input_type=\"inverted\", combine_with_regular_acc=False)\n",
    "sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"CIFAR10\")\n",
    "ax.set_ylabel(\"Agreement\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "\n",
    "fig.savefig(\"../figs/agreement_inverted.pdf\", bbox_inches=\"tight\")\n"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### JSD\n",
    "\n",
    "#### Standard"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "n_panels = 2\n",
    "fig, axes = plt.subplots(1, n_panels, figsize=(n_panels*3*1.61, 3))\n",
    "\n",
    "ax_idx = 0\n",
    "ax = axes[ax_idx]\n",
    "plotdata = data2.loc[(data2.dataset == \"imagenet1k\") & (data2.measure == \"jsd\") & (data2.input == \"standard\")]\n",
    "sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"ImageNet1k\")\n",
    "ax.set_ylabel(\"JSDSim\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "ax.text(x=-0.15, y=1.03, s=\"B\", va=\"bottom\", color=\"black\", transform=ax.transAxes, fontdict={\n",
    "                        'fontsize': fontsize,\n",
    "                        'fontweight': fontweight\n",
    "                    })\n",
    "\n",
    "ax_idx += 1\n",
    "\n",
    "ax = axes[ax_idx]\n",
    "plotdata = data2.loc[(data2.dataset == \"cifar10\") & (data2.measure == \"jsd\") & (data2.input == \"standard\")]\n",
    "sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"CIFAR10\")\n",
    "ax.set_ylabel(\"\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "ax_idx += 1\n",
    "\n",
    "# plotdata = data2.loc[(data2.dataset == \"imagenet100\") & (data2.measure == \"jsd\") & (data2.input == \"standard\")]\n",
    "# sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax)\n",
    "# ax.set_title(\"ImageNet100\")\n",
    "# ax.set_ylabel(\"\")\n",
    "# ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "# ax_idx += 1\n",
    "\n",
    "fig.savefig(\"../figs/jsd_regular.pdf\", bbox_inches=\"tight\")\n"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Inverted"
   ]
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [
    "n_panels = 2\n",
    "fig, axes = plt.subplots(1, n_panels, figsize=(n_panels*3*1.61, 3))\n",
    "\n",
    "ax_idx = 0\n",
    "ax = axes[ax_idx]\n",
    "plotdata = data2.loc[(data2.dataset == \"imagenet1k\") & (data2.measure == \"jsd\") & (data2.input == \"inverted\")]\n",
    "sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"ImageNet1k\")\n",
    "ax.set_ylabel(\"JSDSim\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "ax.text(x=-0.15, y=1.03, s=\"B\", va=\"bottom\", color=\"black\", transform=ax.transAxes, fontdict={\n",
    "                        'fontsize': fontsize,\n",
    "                        'fontweight': fontweight\n",
    "                    })\n",
    "\n",
    "ax_idx += 1\n",
    "\n",
    "ax = axes[ax_idx]\n",
    "plotdata = data2.loc[(data2.dataset == \"cifar10\") & (data2.measure == \"jsd\") & (data2.input == \"inverted\")]\n",
    "sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax, **color_kwargs)\n",
    "ax.set_title(\"CIFAR10\")\n",
    "ax.set_ylabel(\"\")\n",
    "ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "ax_idx += 1\n",
    "\n",
    "# plotdata = data2.loc[(data2.dataset == \"imagenet100\") & (data2.measure == \"jsd\") & (data2.input == \"inverted\")]\n",
    "# sns.boxplot(data=plotdata, x=\"eps\", y=\"score\", ax=ax)\n",
    "# ax.set_title(\"ImageNet100\")\n",
    "# ax.set_ylabel(\"\")\n",
    "# ax.set_xlabel(r\"Robustness $\\epsilon$\")\n",
    "# ax_idx += 1\n",
    "\n",
    "fig.savefig(\"../figs/jsd_inverted.pdf\", bbox_inches=\"tight\")\n"
   ],
   "outputs": [],
   "execution_count": null
  },
  {
   "cell_type": "code",
   "metadata": {},
   "source": [],
   "outputs": [],
   "execution_count": null
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "robust-transfer",
   "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
