{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4b9a1f35-93fb-474b-a1bf-767429e3cf50",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.insert(0, \"../\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "754c17ff-f149-4b17-a474-89938324c16b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "from src.config.utils import make_inference_csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a98f8f86-4509-4573-b6c6-f7d114e89569",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "dae067974729407fbb7c5ed9f1f622e2",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model index is:  0\n",
      "model index is:  1\n",
      "model index is:  2\n",
      "model index is:  3\n",
      "model index is:  4\n",
      "model index is:  5\n",
      "model index is:  6\n",
      "model index is:  7\n",
      "model index is:  8\n",
      "model index is:  9\n",
      "model index is:  10\n",
      "model index is:  11\n",
      "model index is:  12\n",
      "model index is:  13\n",
      "model index is:  14\n",
      "model index is:  15\n",
      "model index is:  16\n",
      "model index is:  17\n",
      "model index is:  18\n",
      "model index is:  19\n"
     ]
    }
   ],
   "source": [
    "make_inference_csv(\n",
    "    dataset_name='mnist',\n",
    "    path_to_saved_models=\"../out/FedAvg/Noneall_params_stopgrad_logp_mnist_100_natpn.pt\",\n",
    "    path_to_centralized_model=\"../out/FedAvg/centralized_all_params_stopgrad_logp_mnist_1_natpn.pt\",\n",
    "    device=\"cpu\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "053e2ccf-2226-4305-9aaa-22d96835ba6d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "92aec255-fd75-4d5a-8b10-5b931e3fd600",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d09c3c029c384592a909d38fac60475f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model index is:  0\n",
      "model index is:  1\n",
      "model index is:  2\n",
      "model index is:  3\n",
      "model index is:  4\n",
      "model index is:  5\n",
      "model index is:  6\n",
      "model index is:  7\n",
      "model index is:  8\n",
      "model index is:  9\n",
      "model index is:  10\n",
      "model index is:  11\n",
      "model index is:  12\n",
      "model index is:  13\n",
      "model index is:  14\n",
      "model index is:  15\n",
      "model index is:  16\n",
      "model index is:  17\n",
      "model index is:  18\n",
      "model index is:  19\n"
     ]
    }
   ],
   "source": [
    "make_inference_csv(\n",
    "    dataset_name='cifar10',\n",
    "    path_to_saved_models=\"../out/FedAvg/Noneall_params_stopgrad_logp_cifar10_100_natpn.pt\",\n",
    "    path_to_centralized_model=\"../out/FedAvg/centralized_all_params_stopgrad_logp_cifar10_1_natpn.pt\",\n",
    "    device=\"cpu\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "488928a1-9bbb-4eb5-a3f9-fd1f82a92b2a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "29db8a43-d826-45bf-ab6b-1a773509ba51",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using downloaded and verified file: ../data/svhn/raw/train_32x32.mat\n",
      "Using downloaded and verified file: ../data/svhn/raw/test_32x32.mat\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "36ddfe84b31c4e4eadc688439b93002e",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model index is:  0\n",
      "model index is:  1\n",
      "model index is:  2\n",
      "model index is:  3\n",
      "model index is:  4\n",
      "model index is:  5\n",
      "model index is:  6\n",
      "model index is:  7\n",
      "model index is:  8\n",
      "model index is:  9\n",
      "model index is:  10\n",
      "model index is:  11\n",
      "model index is:  12\n",
      "model index is:  13\n",
      "model index is:  14\n",
      "model index is:  15\n",
      "model index is:  16\n",
      "model index is:  17\n",
      "model index is:  18\n",
      "model index is:  19\n"
     ]
    }
   ],
   "source": [
    "make_inference_csv(\n",
    "    dataset_name='svhn',\n",
    "    path_to_saved_models=\"../out/FedAvg/Noneall_params_stopgrad_logp_svhn_100_natpn.pt\",\n",
    "    path_to_centralized_model=\"../out/FedAvg/centralized_all_params_stopgrad_logp_svhn_1_natpn.pt\",\n",
    "    device=\"cpu\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0314cd33-81dc-46da-85a8-a5c9aa386782",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a78c09c5-8b04-42c2-b4ae-e04ff78bd4f0",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "50dff53095b945d0a68bd7894315652f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model index is:  0\n",
      "model index is:  1\n",
      "model index is:  2\n",
      "model index is:  3\n",
      "model index is:  4\n",
      "model index is:  5\n",
      "model index is:  6\n",
      "model index is:  7\n",
      "model index is:  8\n",
      "model index is:  9\n",
      "model index is:  10\n",
      "model index is:  11\n",
      "model index is:  12\n",
      "model index is:  13\n",
      "model index is:  14\n",
      "model index is:  15\n",
      "model index is:  16\n",
      "model index is:  17\n",
      "model index is:  18\n",
      "model index is:  19\n"
     ]
    }
   ],
   "source": [
    "make_inference_csv(\n",
    "    dataset_name='fmnist',\n",
    "    path_to_saved_models=\"../out/FedAvg/Noneall_params_stopgrad_logp_fmnist_100_natpn.pt\",\n",
    "    path_to_centralized_model=\"../out/FedAvg/centralized_all_params_stopgrad_logp_fmnist_1_natpn.pt\",\n",
    "    device=\"cpu\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6508d4d9-1d18-463e-a9dd-de67a22572e8",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b4ba58cceed340498889cfab56ddc3de",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model index is:  0\n",
      "model index is:  1\n",
      "model index is:  2\n",
      "model index is:  3\n",
      "model index is:  4\n",
      "model index is:  5\n",
      "model index is:  6\n",
      "model index is:  7\n",
      "model index is:  8\n",
      "model index is:  9\n",
      "model index is:  10\n",
      "model index is:  11\n",
      "model index is:  12\n",
      "model index is:  13\n",
      "model index is:  14\n",
      "model index is:  15\n",
      "model index is:  16\n",
      "model index is:  17\n",
      "model index is:  18\n",
      "model index is:  19\n"
     ]
    }
   ],
   "source": [
    "make_inference_csv(\n",
    "    dataset_name='medmnistS',\n",
    "    path_to_saved_models=\"../out/FedAvg/Noneall_params_stopgrad_logp_medmnistS_100_natpn.pt\",\n",
    "    path_to_centralized_model=\"../out/FedAvg/centralized_all_params_stopgrad_logp_medmnistS_1_natpn.pt\",\n",
    "    device=\"cpu\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "98dbb690-013e-4292-8d9b-7287645a84f6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "65f5e63ddd6e4a87915d419ebc78652c",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model index is:  0\n",
      "model index is:  1\n",
      "model index is:  2\n",
      "model index is:  3\n",
      "model index is:  4\n",
      "model index is:  5\n",
      "model index is:  6\n",
      "model index is:  7\n",
      "model index is:  8\n",
      "model index is:  9\n",
      "model index is:  10\n",
      "model index is:  11\n",
      "model index is:  12\n",
      "model index is:  13\n",
      "model index is:  14\n",
      "model index is:  15\n",
      "model index is:  16\n",
      "model index is:  17\n",
      "model index is:  18\n",
      "model index is:  19\n"
     ]
    }
   ],
   "source": [
    "make_inference_csv(\n",
    "    dataset_name='medmnistA',\n",
    "    path_to_saved_models=\"../out/FedAvg/Noneall_params_stopgrad_logp_medmnistA_100_natpn.pt\",\n",
    "    path_to_centralized_model=\"../out/FedAvg/centralized_all_params_stopgrad_logp_medmnistA_1_natpn.pt\",\n",
    "    device=\"cpu\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6ef6c747-7145-4d35-b17a-cff95639ef6a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "8133c95e6652474c8fe71afe6acf70fd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model index is:  0\n",
      "model index is:  1\n",
      "model index is:  2\n",
      "model index is:  3\n",
      "model index is:  4\n",
      "model index is:  5\n",
      "model index is:  6\n",
      "model index is:  7\n",
      "model index is:  8\n",
      "model index is:  9\n",
      "model index is:  10\n",
      "model index is:  11\n",
      "model index is:  12\n",
      "model index is:  13\n",
      "model index is:  14\n",
      "model index is:  15\n",
      "model index is:  16\n",
      "model index is:  17\n",
      "model index is:  18\n",
      "model index is:  19\n"
     ]
    }
   ],
   "source": [
    "make_inference_csv(\n",
    "    dataset_name='medmnistC',\n",
    "    path_to_saved_models=\"../out/FedAvg/Noneall_params_stopgrad_logp_medmnistC_100_natpn.pt\",\n",
    "    path_to_centralized_model=\"../out/FedAvg/centralized_all_params_stopgrad_logp_medmnistC_1_natpn.pt\",\n",
    "    device=\"cpu\",\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f0e38929-86b7-419e-b2d3-d1eeedf5bd15",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5600ca50-0694-4e9c-aedb-9c05f92ef3d9",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "63ec551f-b65c-4bd7-ad6f-6e649e057d4b",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv('mnist.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "2af3e639-8496-49cd-9790-fce7208a771f",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset_name</th>\n",
       "      <th>model_id</th>\n",
       "      <th>dataset_id</th>\n",
       "      <th>class_intersect_len</th>\n",
       "      <th>centralized_model_acc</th>\n",
       "      <th>local_model_acc</th>\n",
       "      <th>global_model_acc</th>\n",
       "      <th>switch_model_acc_mi</th>\n",
       "      <th>switch_model_acc_rmi</th>\n",
       "      <th>switch_model_acc_epkl</th>\n",
       "      <th>switch_model_acc_entropy</th>\n",
       "      <th>switch_model_acc_logprob</th>\n",
       "      <th>switch_model_acc_catentropy</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>0.976452</td>\n",
       "      <td>0.996860</td>\n",
       "      <td>0.979592</td>\n",
       "      <td>0.995290</td>\n",
       "      <td>0.995290</td>\n",
       "      <td>0.995290</td>\n",
       "      <td>0.987441</td>\n",
       "      <td>0.987441</td>\n",
       "      <td>0.996860</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.991549</td>\n",
       "      <td>0.343662</td>\n",
       "      <td>0.967606</td>\n",
       "      <td>0.490141</td>\n",
       "      <td>0.490141</td>\n",
       "      <td>0.490141</td>\n",
       "      <td>0.412676</td>\n",
       "      <td>0.915493</td>\n",
       "      <td>0.343662</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0.980243</td>\n",
       "      <td>0.284195</td>\n",
       "      <td>0.983283</td>\n",
       "      <td>0.440729</td>\n",
       "      <td>0.440729</td>\n",
       "      <td>0.440729</td>\n",
       "      <td>0.548632</td>\n",
       "      <td>0.972644</td>\n",
       "      <td>0.284195</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>0.968504</td>\n",
       "      <td>0.719685</td>\n",
       "      <td>0.976378</td>\n",
       "      <td>0.785827</td>\n",
       "      <td>0.785827</td>\n",
       "      <td>0.785827</td>\n",
       "      <td>0.968504</td>\n",
       "      <td>0.981102</td>\n",
       "      <td>0.719685</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "      <td>0.992519</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.993766</td>\n",
       "      <td>0.245636</td>\n",
       "      <td>0.245636</td>\n",
       "      <td>0.245636</td>\n",
       "      <td>0.952618</td>\n",
       "      <td>0.982544</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>0.986861</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.963504</td>\n",
       "      <td>0.232117</td>\n",
       "      <td>0.232117</td>\n",
       "      <td>0.232117</td>\n",
       "      <td>0.217518</td>\n",
       "      <td>0.894891</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>0.990923</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.983359</td>\n",
       "      <td>0.228442</td>\n",
       "      <td>0.228442</td>\n",
       "      <td>0.228442</td>\n",
       "      <td>0.809380</td>\n",
       "      <td>0.968230</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>0.984720</td>\n",
       "      <td>0.283531</td>\n",
       "      <td>0.955857</td>\n",
       "      <td>0.465195</td>\n",
       "      <td>0.465195</td>\n",
       "      <td>0.465195</td>\n",
       "      <td>0.561969</td>\n",
       "      <td>0.911715</td>\n",
       "      <td>0.283531</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>0.985134</td>\n",
       "      <td>0.220020</td>\n",
       "      <td>0.986125</td>\n",
       "      <td>0.415263</td>\n",
       "      <td>0.415263</td>\n",
       "      <td>0.415263</td>\n",
       "      <td>0.676908</td>\n",
       "      <td>0.967294</td>\n",
       "      <td>0.220020</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>0.980870</td>\n",
       "      <td>0.709565</td>\n",
       "      <td>0.989565</td>\n",
       "      <td>0.773913</td>\n",
       "      <td>0.773913</td>\n",
       "      <td>0.773913</td>\n",
       "      <td>0.973913</td>\n",
       "      <td>0.993043</td>\n",
       "      <td>0.709565</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>0</td>\n",
       "      <td>0.990814</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.979003</td>\n",
       "      <td>0.246719</td>\n",
       "      <td>0.246719</td>\n",
       "      <td>0.246719</td>\n",
       "      <td>0.181102</td>\n",
       "      <td>0.925197</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>0</td>\n",
       "      <td>0.986376</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.989101</td>\n",
       "      <td>0.264305</td>\n",
       "      <td>0.264305</td>\n",
       "      <td>0.264305</td>\n",
       "      <td>0.844687</td>\n",
       "      <td>0.970027</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>0.986095</td>\n",
       "      <td>0.271147</td>\n",
       "      <td>0.974508</td>\n",
       "      <td>0.438007</td>\n",
       "      <td>0.438007</td>\n",
       "      <td>0.438007</td>\n",
       "      <td>0.943221</td>\n",
       "      <td>0.968714</td>\n",
       "      <td>0.271147</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>13</td>\n",
       "      <td>0</td>\n",
       "      <td>0.990415</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.968051</td>\n",
       "      <td>0.236422</td>\n",
       "      <td>0.236422</td>\n",
       "      <td>0.236422</td>\n",
       "      <td>0.629393</td>\n",
       "      <td>0.923323</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>14</td>\n",
       "      <td>1</td>\n",
       "      <td>0.985294</td>\n",
       "      <td>0.329412</td>\n",
       "      <td>0.969118</td>\n",
       "      <td>0.466176</td>\n",
       "      <td>0.466176</td>\n",
       "      <td>0.466176</td>\n",
       "      <td>0.508824</td>\n",
       "      <td>0.905882</td>\n",
       "      <td>0.329412</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>15</td>\n",
       "      <td>1</td>\n",
       "      <td>0.990979</td>\n",
       "      <td>0.284794</td>\n",
       "      <td>0.974227</td>\n",
       "      <td>0.487113</td>\n",
       "      <td>0.487113</td>\n",
       "      <td>0.487113</td>\n",
       "      <td>0.442010</td>\n",
       "      <td>0.944588</td>\n",
       "      <td>0.284794</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>16</td>\n",
       "      <td>2</td>\n",
       "      <td>0.992515</td>\n",
       "      <td>0.585329</td>\n",
       "      <td>0.980539</td>\n",
       "      <td>0.685629</td>\n",
       "      <td>0.685629</td>\n",
       "      <td>0.685629</td>\n",
       "      <td>0.985030</td>\n",
       "      <td>0.985030</td>\n",
       "      <td>0.585329</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>17</td>\n",
       "      <td>1</td>\n",
       "      <td>0.989426</td>\n",
       "      <td>0.246224</td>\n",
       "      <td>0.980363</td>\n",
       "      <td>0.459215</td>\n",
       "      <td>0.459215</td>\n",
       "      <td>0.459215</td>\n",
       "      <td>0.830816</td>\n",
       "      <td>0.959215</td>\n",
       "      <td>0.246224</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>18</td>\n",
       "      <td>2</td>\n",
       "      <td>0.977431</td>\n",
       "      <td>0.993056</td>\n",
       "      <td>0.979167</td>\n",
       "      <td>0.986111</td>\n",
       "      <td>0.986111</td>\n",
       "      <td>0.986111</td>\n",
       "      <td>0.987847</td>\n",
       "      <td>0.987847</td>\n",
       "      <td>0.993056</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>mnist</td>\n",
       "      <td>0</td>\n",
       "      <td>19</td>\n",
       "      <td>0</td>\n",
       "      <td>0.987106</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.959885</td>\n",
       "      <td>0.273639</td>\n",
       "      <td>0.273639</td>\n",
       "      <td>0.273639</td>\n",
       "      <td>0.656160</td>\n",
       "      <td>0.914040</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dataset_name  model_id  dataset_id  class_intersect_len   \n",
       "0         mnist         0           0                    3  \\\n",
       "1         mnist         0           1                    1   \n",
       "2         mnist         0           2                    1   \n",
       "3         mnist         0           3                    1   \n",
       "4         mnist         0           4                    0   \n",
       "5         mnist         0           5                    0   \n",
       "6         mnist         0           6                    0   \n",
       "7         mnist         0           7                    1   \n",
       "8         mnist         0           8                    1   \n",
       "9         mnist         0           9                    2   \n",
       "10        mnist         0          10                    0   \n",
       "11        mnist         0          11                    0   \n",
       "12        mnist         0          12                    1   \n",
       "13        mnist         0          13                    0   \n",
       "14        mnist         0          14                    1   \n",
       "15        mnist         0          15                    1   \n",
       "16        mnist         0          16                    2   \n",
       "17        mnist         0          17                    1   \n",
       "18        mnist         0          18                    2   \n",
       "19        mnist         0          19                    0   \n",
       "\n",
       "    centralized_model_acc  local_model_acc  global_model_acc   \n",
       "0                0.976452         0.996860          0.979592  \\\n",
       "1                0.991549         0.343662          0.967606   \n",
       "2                0.980243         0.284195          0.983283   \n",
       "3                0.968504         0.719685          0.976378   \n",
       "4                0.992519         0.000000          0.993766   \n",
       "5                0.986861         0.000000          0.963504   \n",
       "6                0.990923         0.000000          0.983359   \n",
       "7                0.984720         0.283531          0.955857   \n",
       "8                0.985134         0.220020          0.986125   \n",
       "9                0.980870         0.709565          0.989565   \n",
       "10               0.990814         0.000000          0.979003   \n",
       "11               0.986376         0.000000          0.989101   \n",
       "12               0.986095         0.271147          0.974508   \n",
       "13               0.990415         0.000000          0.968051   \n",
       "14               0.985294         0.329412          0.969118   \n",
       "15               0.990979         0.284794          0.974227   \n",
       "16               0.992515         0.585329          0.980539   \n",
       "17               0.989426         0.246224          0.980363   \n",
       "18               0.977431         0.993056          0.979167   \n",
       "19               0.987106         0.000000          0.959885   \n",
       "\n",
       "    switch_model_acc_mi  switch_model_acc_rmi  switch_model_acc_epkl   \n",
       "0              0.995290              0.995290               0.995290  \\\n",
       "1              0.490141              0.490141               0.490141   \n",
       "2              0.440729              0.440729               0.440729   \n",
       "3              0.785827              0.785827               0.785827   \n",
       "4              0.245636              0.245636               0.245636   \n",
       "5              0.232117              0.232117               0.232117   \n",
       "6              0.228442              0.228442               0.228442   \n",
       "7              0.465195              0.465195               0.465195   \n",
       "8              0.415263              0.415263               0.415263   \n",
       "9              0.773913              0.773913               0.773913   \n",
       "10             0.246719              0.246719               0.246719   \n",
       "11             0.264305              0.264305               0.264305   \n",
       "12             0.438007              0.438007               0.438007   \n",
       "13             0.236422              0.236422               0.236422   \n",
       "14             0.466176              0.466176               0.466176   \n",
       "15             0.487113              0.487113               0.487113   \n",
       "16             0.685629              0.685629               0.685629   \n",
       "17             0.459215              0.459215               0.459215   \n",
       "18             0.986111              0.986111               0.986111   \n",
       "19             0.273639              0.273639               0.273639   \n",
       "\n",
       "    switch_model_acc_entropy  switch_model_acc_logprob   \n",
       "0                   0.987441                  0.987441  \\\n",
       "1                   0.412676                  0.915493   \n",
       "2                   0.548632                  0.972644   \n",
       "3                   0.968504                  0.981102   \n",
       "4                   0.952618                  0.982544   \n",
       "5                   0.217518                  0.894891   \n",
       "6                   0.809380                  0.968230   \n",
       "7                   0.561969                  0.911715   \n",
       "8                   0.676908                  0.967294   \n",
       "9                   0.973913                  0.993043   \n",
       "10                  0.181102                  0.925197   \n",
       "11                  0.844687                  0.970027   \n",
       "12                  0.943221                  0.968714   \n",
       "13                  0.629393                  0.923323   \n",
       "14                  0.508824                  0.905882   \n",
       "15                  0.442010                  0.944588   \n",
       "16                  0.985030                  0.985030   \n",
       "17                  0.830816                  0.959215   \n",
       "18                  0.987847                  0.987847   \n",
       "19                  0.656160                  0.914040   \n",
       "\n",
       "    switch_model_acc_catentropy  \n",
       "0                      0.996860  \n",
       "1                      0.343662  \n",
       "2                      0.284195  \n",
       "3                      0.719685  \n",
       "4                      0.000000  \n",
       "5                      0.000000  \n",
       "6                      0.000000  \n",
       "7                      0.283531  \n",
       "8                      0.220020  \n",
       "9                      0.709565  \n",
       "10                     0.000000  \n",
       "11                     0.000000  \n",
       "12                     0.271147  \n",
       "13                     0.000000  \n",
       "14                     0.329412  \n",
       "15                     0.284794  \n",
       "16                     0.585329  \n",
       "17                     0.246224  \n",
       "18                     0.993056  \n",
       "19                     0.000000  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "159011b8-16b8-4bb3-bb48-9041e5fcae91",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv('cifar10.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1506ce2a-dfaf-4080-b7c0-f2a2126084d3",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset_name</th>\n",
       "      <th>model_id</th>\n",
       "      <th>dataset_id</th>\n",
       "      <th>class_intersect_len</th>\n",
       "      <th>centralized_model_acc</th>\n",
       "      <th>local_model_acc</th>\n",
       "      <th>global_model_acc</th>\n",
       "      <th>switch_model_acc_mi</th>\n",
       "      <th>switch_model_acc_rmi</th>\n",
       "      <th>switch_model_acc_epkl</th>\n",
       "      <th>switch_model_acc_entropy</th>\n",
       "      <th>switch_model_acc_logprob</th>\n",
       "      <th>switch_model_acc_catentropy</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>0.434545</td>\n",
       "      <td>0.818182</td>\n",
       "      <td>0.080000</td>\n",
       "      <td>0.625455</td>\n",
       "      <td>0.625455</td>\n",
       "      <td>0.625455</td>\n",
       "      <td>0.810909</td>\n",
       "      <td>0.796364</td>\n",
       "      <td>0.772727</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.223333</td>\n",
       "      <td>0.255000</td>\n",
       "      <td>0.130000</td>\n",
       "      <td>0.220000</td>\n",
       "      <td>0.220000</td>\n",
       "      <td>0.220000</td>\n",
       "      <td>0.251667</td>\n",
       "      <td>0.240000</td>\n",
       "      <td>0.253333</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0.476667</td>\n",
       "      <td>0.188333</td>\n",
       "      <td>0.215000</td>\n",
       "      <td>0.193333</td>\n",
       "      <td>0.193333</td>\n",
       "      <td>0.193333</td>\n",
       "      <td>0.188333</td>\n",
       "      <td>0.210000</td>\n",
       "      <td>0.190000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>0.472727</td>\n",
       "      <td>0.596364</td>\n",
       "      <td>0.292727</td>\n",
       "      <td>0.501818</td>\n",
       "      <td>0.501818</td>\n",
       "      <td>0.501818</td>\n",
       "      <td>0.601818</td>\n",
       "      <td>0.605455</td>\n",
       "      <td>0.507273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "      <td>0.455714</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.368571</td>\n",
       "      <td>0.095714</td>\n",
       "      <td>0.095714</td>\n",
       "      <td>0.095714</td>\n",
       "      <td>0.004286</td>\n",
       "      <td>0.027143</td>\n",
       "      <td>0.002857</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>0.298951</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.087413</td>\n",
       "      <td>0.020979</td>\n",
       "      <td>0.020979</td>\n",
       "      <td>0.020979</td>\n",
       "      <td>0.013986</td>\n",
       "      <td>0.003497</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>0.540000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.523636</td>\n",
       "      <td>0.116364</td>\n",
       "      <td>0.116364</td>\n",
       "      <td>0.116364</td>\n",
       "      <td>0.009091</td>\n",
       "      <td>0.030909</td>\n",
       "      <td>0.047273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>0.539554</td>\n",
       "      <td>0.206897</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.158215</td>\n",
       "      <td>0.158215</td>\n",
       "      <td>0.158215</td>\n",
       "      <td>0.206897</td>\n",
       "      <td>0.206897</td>\n",
       "      <td>0.206897</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>0.451111</td>\n",
       "      <td>0.166667</td>\n",
       "      <td>0.037778</td>\n",
       "      <td>0.134444</td>\n",
       "      <td>0.134444</td>\n",
       "      <td>0.134444</td>\n",
       "      <td>0.162222</td>\n",
       "      <td>0.154444</td>\n",
       "      <td>0.165556</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>0.512000</td>\n",
       "      <td>0.550000</td>\n",
       "      <td>0.296000</td>\n",
       "      <td>0.488000</td>\n",
       "      <td>0.488000</td>\n",
       "      <td>0.488000</td>\n",
       "      <td>0.556000</td>\n",
       "      <td>0.564000</td>\n",
       "      <td>0.512000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>0</td>\n",
       "      <td>0.404762</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.038690</td>\n",
       "      <td>0.014881</td>\n",
       "      <td>0.014881</td>\n",
       "      <td>0.014881</td>\n",
       "      <td>0.004464</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>0</td>\n",
       "      <td>0.465035</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.526224</td>\n",
       "      <td>0.146853</td>\n",
       "      <td>0.146853</td>\n",
       "      <td>0.146853</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.012238</td>\n",
       "      <td>0.073427</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>0.485333</td>\n",
       "      <td>0.216000</td>\n",
       "      <td>0.188000</td>\n",
       "      <td>0.198667</td>\n",
       "      <td>0.198667</td>\n",
       "      <td>0.198667</td>\n",
       "      <td>0.216000</td>\n",
       "      <td>0.229333</td>\n",
       "      <td>0.184000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>13</td>\n",
       "      <td>0</td>\n",
       "      <td>0.661818</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.247273</td>\n",
       "      <td>0.067273</td>\n",
       "      <td>0.067273</td>\n",
       "      <td>0.067273</td>\n",
       "      <td>0.009091</td>\n",
       "      <td>0.016364</td>\n",
       "      <td>0.001818</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>14</td>\n",
       "      <td>1</td>\n",
       "      <td>0.291958</td>\n",
       "      <td>0.290210</td>\n",
       "      <td>0.103147</td>\n",
       "      <td>0.239510</td>\n",
       "      <td>0.239510</td>\n",
       "      <td>0.239510</td>\n",
       "      <td>0.279720</td>\n",
       "      <td>0.277972</td>\n",
       "      <td>0.283217</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>15</td>\n",
       "      <td>1</td>\n",
       "      <td>0.502857</td>\n",
       "      <td>0.242857</td>\n",
       "      <td>0.044286</td>\n",
       "      <td>0.190000</td>\n",
       "      <td>0.190000</td>\n",
       "      <td>0.190000</td>\n",
       "      <td>0.231429</td>\n",
       "      <td>0.215714</td>\n",
       "      <td>0.238571</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>16</td>\n",
       "      <td>2</td>\n",
       "      <td>0.449091</td>\n",
       "      <td>0.505455</td>\n",
       "      <td>0.298182</td>\n",
       "      <td>0.436364</td>\n",
       "      <td>0.436364</td>\n",
       "      <td>0.436364</td>\n",
       "      <td>0.494545</td>\n",
       "      <td>0.489091</td>\n",
       "      <td>0.529091</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>17</td>\n",
       "      <td>1</td>\n",
       "      <td>0.632727</td>\n",
       "      <td>0.160000</td>\n",
       "      <td>0.267273</td>\n",
       "      <td>0.194545</td>\n",
       "      <td>0.194545</td>\n",
       "      <td>0.194545</td>\n",
       "      <td>0.167273</td>\n",
       "      <td>0.174545</td>\n",
       "      <td>0.178182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>18</td>\n",
       "      <td>2</td>\n",
       "      <td>0.616000</td>\n",
       "      <td>0.772000</td>\n",
       "      <td>0.010000</td>\n",
       "      <td>0.586000</td>\n",
       "      <td>0.586000</td>\n",
       "      <td>0.586000</td>\n",
       "      <td>0.774000</td>\n",
       "      <td>0.762000</td>\n",
       "      <td>0.728000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>cifar10</td>\n",
       "      <td>0</td>\n",
       "      <td>19</td>\n",
       "      <td>0</td>\n",
       "      <td>0.578671</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.276224</td>\n",
       "      <td>0.062937</td>\n",
       "      <td>0.062937</td>\n",
       "      <td>0.062937</td>\n",
       "      <td>0.003497</td>\n",
       "      <td>0.006993</td>\n",
       "      <td>0.038462</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dataset_name  model_id  dataset_id  class_intersect_len   \n",
       "0       cifar10         0           0                    3  \\\n",
       "1       cifar10         0           1                    1   \n",
       "2       cifar10         0           2                    1   \n",
       "3       cifar10         0           3                    1   \n",
       "4       cifar10         0           4                    0   \n",
       "5       cifar10         0           5                    0   \n",
       "6       cifar10         0           6                    0   \n",
       "7       cifar10         0           7                    1   \n",
       "8       cifar10         0           8                    1   \n",
       "9       cifar10         0           9                    2   \n",
       "10      cifar10         0          10                    0   \n",
       "11      cifar10         0          11                    0   \n",
       "12      cifar10         0          12                    1   \n",
       "13      cifar10         0          13                    0   \n",
       "14      cifar10         0          14                    1   \n",
       "15      cifar10         0          15                    1   \n",
       "16      cifar10         0          16                    2   \n",
       "17      cifar10         0          17                    1   \n",
       "18      cifar10         0          18                    2   \n",
       "19      cifar10         0          19                    0   \n",
       "\n",
       "    centralized_model_acc  local_model_acc  global_model_acc   \n",
       "0                0.434545         0.818182          0.080000  \\\n",
       "1                0.223333         0.255000          0.130000   \n",
       "2                0.476667         0.188333          0.215000   \n",
       "3                0.472727         0.596364          0.292727   \n",
       "4                0.455714         0.000000          0.368571   \n",
       "5                0.298951         0.000000          0.087413   \n",
       "6                0.540000         0.000000          0.523636   \n",
       "7                0.539554         0.206897          0.000000   \n",
       "8                0.451111         0.166667          0.037778   \n",
       "9                0.512000         0.550000          0.296000   \n",
       "10               0.404762         0.000000          0.038690   \n",
       "11               0.465035         0.000000          0.526224   \n",
       "12               0.485333         0.216000          0.188000   \n",
       "13               0.661818         0.000000          0.247273   \n",
       "14               0.291958         0.290210          0.103147   \n",
       "15               0.502857         0.242857          0.044286   \n",
       "16               0.449091         0.505455          0.298182   \n",
       "17               0.632727         0.160000          0.267273   \n",
       "18               0.616000         0.772000          0.010000   \n",
       "19               0.578671         0.000000          0.276224   \n",
       "\n",
       "    switch_model_acc_mi  switch_model_acc_rmi  switch_model_acc_epkl   \n",
       "0              0.625455              0.625455               0.625455  \\\n",
       "1              0.220000              0.220000               0.220000   \n",
       "2              0.193333              0.193333               0.193333   \n",
       "3              0.501818              0.501818               0.501818   \n",
       "4              0.095714              0.095714               0.095714   \n",
       "5              0.020979              0.020979               0.020979   \n",
       "6              0.116364              0.116364               0.116364   \n",
       "7              0.158215              0.158215               0.158215   \n",
       "8              0.134444              0.134444               0.134444   \n",
       "9              0.488000              0.488000               0.488000   \n",
       "10             0.014881              0.014881               0.014881   \n",
       "11             0.146853              0.146853               0.146853   \n",
       "12             0.198667              0.198667               0.198667   \n",
       "13             0.067273              0.067273               0.067273   \n",
       "14             0.239510              0.239510               0.239510   \n",
       "15             0.190000              0.190000               0.190000   \n",
       "16             0.436364              0.436364               0.436364   \n",
       "17             0.194545              0.194545               0.194545   \n",
       "18             0.586000              0.586000               0.586000   \n",
       "19             0.062937              0.062937               0.062937   \n",
       "\n",
       "    switch_model_acc_entropy  switch_model_acc_logprob   \n",
       "0                   0.810909                  0.796364  \\\n",
       "1                   0.251667                  0.240000   \n",
       "2                   0.188333                  0.210000   \n",
       "3                   0.601818                  0.605455   \n",
       "4                   0.004286                  0.027143   \n",
       "5                   0.013986                  0.003497   \n",
       "6                   0.009091                  0.030909   \n",
       "7                   0.206897                  0.206897   \n",
       "8                   0.162222                  0.154444   \n",
       "9                   0.556000                  0.564000   \n",
       "10                  0.004464                  0.000000   \n",
       "11                  0.000000                  0.012238   \n",
       "12                  0.216000                  0.229333   \n",
       "13                  0.009091                  0.016364   \n",
       "14                  0.279720                  0.277972   \n",
       "15                  0.231429                  0.215714   \n",
       "16                  0.494545                  0.489091   \n",
       "17                  0.167273                  0.174545   \n",
       "18                  0.774000                  0.762000   \n",
       "19                  0.003497                  0.006993   \n",
       "\n",
       "    switch_model_acc_catentropy  \n",
       "0                      0.772727  \n",
       "1                      0.253333  \n",
       "2                      0.190000  \n",
       "3                      0.507273  \n",
       "4                      0.002857  \n",
       "5                      0.000000  \n",
       "6                      0.047273  \n",
       "7                      0.206897  \n",
       "8                      0.165556  \n",
       "9                      0.512000  \n",
       "10                     0.000000  \n",
       "11                     0.073427  \n",
       "12                     0.184000  \n",
       "13                     0.001818  \n",
       "14                     0.283217  \n",
       "15                     0.238571  \n",
       "16                     0.529091  \n",
       "17                     0.178182  \n",
       "18                     0.728000  \n",
       "19                     0.038462  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1378c18-46f7-44c6-a9ac-acb84aa87cbc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "1a293bca-b8bb-4a2c-b7c5-e0cd954129a8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "df = pd.read_csv('svhn.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "70aed6bd-f16d-492a-8653-621e121097c4",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset_name</th>\n",
       "      <th>model_id</th>\n",
       "      <th>dataset_id</th>\n",
       "      <th>class_intersect_len</th>\n",
       "      <th>centralized_model_acc</th>\n",
       "      <th>local_model_acc</th>\n",
       "      <th>global_model_acc</th>\n",
       "      <th>switch_model_acc_mi</th>\n",
       "      <th>switch_model_acc_rmi</th>\n",
       "      <th>switch_model_acc_epkl</th>\n",
       "      <th>switch_model_acc_entropy</th>\n",
       "      <th>switch_model_acc_logprob</th>\n",
       "      <th>switch_model_acc_catentropy</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>0.930493</td>\n",
       "      <td>0.821749</td>\n",
       "      <td>0.032511</td>\n",
       "      <td>0.548206</td>\n",
       "      <td>0.548206</td>\n",
       "      <td>0.548206</td>\n",
       "      <td>0.802691</td>\n",
       "      <td>0.795964</td>\n",
       "      <td>0.772422</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>1</td>\n",
       "      <td>0.939200</td>\n",
       "      <td>0.370400</td>\n",
       "      <td>0.000800</td>\n",
       "      <td>0.218400</td>\n",
       "      <td>0.218400</td>\n",
       "      <td>0.218400</td>\n",
       "      <td>0.370400</td>\n",
       "      <td>0.360000</td>\n",
       "      <td>0.341600</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>1</td>\n",
       "      <td>0.934879</td>\n",
       "      <td>0.131347</td>\n",
       "      <td>0.175497</td>\n",
       "      <td>0.164459</td>\n",
       "      <td>0.164459</td>\n",
       "      <td>0.164459</td>\n",
       "      <td>0.132450</td>\n",
       "      <td>0.135762</td>\n",
       "      <td>0.142384</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>1</td>\n",
       "      <td>0.935532</td>\n",
       "      <td>0.496252</td>\n",
       "      <td>0.202399</td>\n",
       "      <td>0.451274</td>\n",
       "      <td>0.451274</td>\n",
       "      <td>0.451274</td>\n",
       "      <td>0.446777</td>\n",
       "      <td>0.451274</td>\n",
       "      <td>0.515742</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>0</td>\n",
       "      <td>0.959788</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.274074</td>\n",
       "      <td>0.114286</td>\n",
       "      <td>0.114286</td>\n",
       "      <td>0.114286</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.002116</td>\n",
       "      <td>0.044444</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>0</td>\n",
       "      <td>0.937500</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.003074</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.003074</td>\n",
       "      <td>0.001025</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>6</td>\n",
       "      <td>0</td>\n",
       "      <td>0.924887</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.719457</td>\n",
       "      <td>0.201810</td>\n",
       "      <td>0.201810</td>\n",
       "      <td>0.201810</td>\n",
       "      <td>0.012670</td>\n",
       "      <td>0.084163</td>\n",
       "      <td>0.015385</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>7</td>\n",
       "      <td>1</td>\n",
       "      <td>0.929936</td>\n",
       "      <td>0.170382</td>\n",
       "      <td>0.038217</td>\n",
       "      <td>0.125796</td>\n",
       "      <td>0.125796</td>\n",
       "      <td>0.125796</td>\n",
       "      <td>0.173567</td>\n",
       "      <td>0.173567</td>\n",
       "      <td>0.171975</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>8</td>\n",
       "      <td>1</td>\n",
       "      <td>0.946467</td>\n",
       "      <td>0.336188</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.201999</td>\n",
       "      <td>0.201999</td>\n",
       "      <td>0.201999</td>\n",
       "      <td>0.336188</td>\n",
       "      <td>0.321199</td>\n",
       "      <td>0.302641</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>9</td>\n",
       "      <td>2</td>\n",
       "      <td>0.932412</td>\n",
       "      <td>0.450077</td>\n",
       "      <td>0.235023</td>\n",
       "      <td>0.423963</td>\n",
       "      <td>0.423963</td>\n",
       "      <td>0.423963</td>\n",
       "      <td>0.413210</td>\n",
       "      <td>0.436252</td>\n",
       "      <td>0.480799</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>10</td>\n",
       "      <td>0</td>\n",
       "      <td>0.938679</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>11</td>\n",
       "      <td>0</td>\n",
       "      <td>0.919703</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.762483</td>\n",
       "      <td>0.210526</td>\n",
       "      <td>0.210526</td>\n",
       "      <td>0.210526</td>\n",
       "      <td>0.005398</td>\n",
       "      <td>0.121457</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>12</td>\n",
       "      <td>1</td>\n",
       "      <td>0.946903</td>\n",
       "      <td>0.179204</td>\n",
       "      <td>0.150442</td>\n",
       "      <td>0.189159</td>\n",
       "      <td>0.189159</td>\n",
       "      <td>0.189159</td>\n",
       "      <td>0.159292</td>\n",
       "      <td>0.174779</td>\n",
       "      <td>0.198009</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>13</td>\n",
       "      <td>0</td>\n",
       "      <td>0.919656</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.433286</td>\n",
       "      <td>0.133429</td>\n",
       "      <td>0.133429</td>\n",
       "      <td>0.133429</td>\n",
       "      <td>0.032999</td>\n",
       "      <td>0.014347</td>\n",
       "      <td>0.028694</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>14</td>\n",
       "      <td>1</td>\n",
       "      <td>0.942096</td>\n",
       "      <td>0.396140</td>\n",
       "      <td>0.000919</td>\n",
       "      <td>0.239890</td>\n",
       "      <td>0.239890</td>\n",
       "      <td>0.239890</td>\n",
       "      <td>0.396140</td>\n",
       "      <td>0.373162</td>\n",
       "      <td>0.364890</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>15</td>\n",
       "      <td>1</td>\n",
       "      <td>0.924448</td>\n",
       "      <td>0.383701</td>\n",
       "      <td>0.081494</td>\n",
       "      <td>0.247878</td>\n",
       "      <td>0.247878</td>\n",
       "      <td>0.247878</td>\n",
       "      <td>0.390492</td>\n",
       "      <td>0.365874</td>\n",
       "      <td>0.348896</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>16</td>\n",
       "      <td>2</td>\n",
       "      <td>0.911854</td>\n",
       "      <td>0.433131</td>\n",
       "      <td>0.441489</td>\n",
       "      <td>0.387538</td>\n",
       "      <td>0.387538</td>\n",
       "      <td>0.387538</td>\n",
       "      <td>0.434650</td>\n",
       "      <td>0.495441</td>\n",
       "      <td>0.402736</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>17</td>\n",
       "      <td>1</td>\n",
       "      <td>0.917939</td>\n",
       "      <td>0.114504</td>\n",
       "      <td>0.656489</td>\n",
       "      <td>0.256679</td>\n",
       "      <td>0.256679</td>\n",
       "      <td>0.256679</td>\n",
       "      <td>0.125954</td>\n",
       "      <td>0.190840</td>\n",
       "      <td>0.114504</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>18</td>\n",
       "      <td>2</td>\n",
       "      <td>0.902357</td>\n",
       "      <td>0.681818</td>\n",
       "      <td>0.097643</td>\n",
       "      <td>0.523569</td>\n",
       "      <td>0.523569</td>\n",
       "      <td>0.523569</td>\n",
       "      <td>0.664983</td>\n",
       "      <td>0.661616</td>\n",
       "      <td>0.680135</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>svhn</td>\n",
       "      <td>0</td>\n",
       "      <td>19</td>\n",
       "      <td>0</td>\n",
       "      <td>0.915191</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.616962</td>\n",
       "      <td>0.142591</td>\n",
       "      <td>0.142591</td>\n",
       "      <td>0.142591</td>\n",
       "      <td>0.012116</td>\n",
       "      <td>0.093197</td>\n",
       "      <td>0.000932</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   dataset_name  model_id  dataset_id  class_intersect_len   \n",
       "0          svhn         0           0                    3  \\\n",
       "1          svhn         0           1                    1   \n",
       "2          svhn         0           2                    1   \n",
       "3          svhn         0           3                    1   \n",
       "4          svhn         0           4                    0   \n",
       "5          svhn         0           5                    0   \n",
       "6          svhn         0           6                    0   \n",
       "7          svhn         0           7                    1   \n",
       "8          svhn         0           8                    1   \n",
       "9          svhn         0           9                    2   \n",
       "10         svhn         0          10                    0   \n",
       "11         svhn         0          11                    0   \n",
       "12         svhn         0          12                    1   \n",
       "13         svhn         0          13                    0   \n",
       "14         svhn         0          14                    1   \n",
       "15         svhn         0          15                    1   \n",
       "16         svhn         0          16                    2   \n",
       "17         svhn         0          17                    1   \n",
       "18         svhn         0          18                    2   \n",
       "19         svhn         0          19                    0   \n",
       "\n",
       "    centralized_model_acc  local_model_acc  global_model_acc   \n",
       "0                0.930493         0.821749          0.032511  \\\n",
       "1                0.939200         0.370400          0.000800   \n",
       "2                0.934879         0.131347          0.175497   \n",
       "3                0.935532         0.496252          0.202399   \n",
       "4                0.959788         0.000000          0.274074   \n",
       "5                0.937500         0.000000          0.003074   \n",
       "6                0.924887         0.000000          0.719457   \n",
       "7                0.929936         0.170382          0.038217   \n",
       "8                0.946467         0.336188          0.000000   \n",
       "9                0.932412         0.450077          0.235023   \n",
       "10               0.938679         0.000000          0.000000   \n",
       "11               0.919703         0.000000          0.762483   \n",
       "12               0.946903         0.179204          0.150442   \n",
       "13               0.919656         0.000000          0.433286   \n",
       "14               0.942096         0.396140          0.000919   \n",
       "15               0.924448         0.383701          0.081494   \n",
       "16               0.911854         0.433131          0.441489   \n",
       "17               0.917939         0.114504          0.656489   \n",
       "18               0.902357         0.681818          0.097643   \n",
       "19               0.915191         0.000000          0.616962   \n",
       "\n",
       "    switch_model_acc_mi  switch_model_acc_rmi  switch_model_acc_epkl   \n",
       "0              0.548206              0.548206               0.548206  \\\n",
       "1              0.218400              0.218400               0.218400   \n",
       "2              0.164459              0.164459               0.164459   \n",
       "3              0.451274              0.451274               0.451274   \n",
       "4              0.114286              0.114286               0.114286   \n",
       "5              0.000000              0.000000               0.000000   \n",
       "6              0.201810              0.201810               0.201810   \n",
       "7              0.125796              0.125796               0.125796   \n",
       "8              0.201999              0.201999               0.201999   \n",
       "9              0.423963              0.423963               0.423963   \n",
       "10             0.000000              0.000000               0.000000   \n",
       "11             0.210526              0.210526               0.210526   \n",
       "12             0.189159              0.189159               0.189159   \n",
       "13             0.133429              0.133429               0.133429   \n",
       "14             0.239890              0.239890               0.239890   \n",
       "15             0.247878              0.247878               0.247878   \n",
       "16             0.387538              0.387538               0.387538   \n",
       "17             0.256679              0.256679               0.256679   \n",
       "18             0.523569              0.523569               0.523569   \n",
       "19             0.142591              0.142591               0.142591   \n",
       "\n",
       "    switch_model_acc_entropy  switch_model_acc_logprob   \n",
       "0                   0.802691                  0.795964  \\\n",
       "1                   0.370400                  0.360000   \n",
       "2                   0.132450                  0.135762   \n",
       "3                   0.446777                  0.451274   \n",
       "4                   0.000000                  0.002116   \n",
       "5                   0.000000                  0.003074   \n",
       "6                   0.012670                  0.084163   \n",
       "7                   0.173567                  0.173567   \n",
       "8                   0.336188                  0.321199   \n",
       "9                   0.413210                  0.436252   \n",
       "10                  0.000000                  0.000000   \n",
       "11                  0.005398                  0.121457   \n",
       "12                  0.159292                  0.174779   \n",
       "13                  0.032999                  0.014347   \n",
       "14                  0.396140                  0.373162   \n",
       "15                  0.390492                  0.365874   \n",
       "16                  0.434650                  0.495441   \n",
       "17                  0.125954                  0.190840   \n",
       "18                  0.664983                  0.661616   \n",
       "19                  0.012116                  0.093197   \n",
       "\n",
       "    switch_model_acc_catentropy  \n",
       "0                      0.772422  \n",
       "1                      0.341600  \n",
       "2                      0.142384  \n",
       "3                      0.515742  \n",
       "4                      0.044444  \n",
       "5                      0.001025  \n",
       "6                      0.015385  \n",
       "7                      0.171975  \n",
       "8                      0.302641  \n",
       "9                      0.480799  \n",
       "10                     0.000000  \n",
       "11                     0.000000  \n",
       "12                     0.198009  \n",
       "13                     0.028694  \n",
       "14                     0.364890  \n",
       "15                     0.348896  \n",
       "16                     0.402736  \n",
       "17                     0.114504  \n",
       "18                     0.680135  \n",
       "19                     0.000932  "
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6dce8b19-da59-4573-b2e8-8caa229375d2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4988a10c-6160-4a94-aa93-f8f278580957",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "184a9ae4-5b9f-443f-835f-5f868cb4cd7f",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.insert(0, \"../\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "52b29eb3-0ca4-4bc4-bf32-ef116e0ea618",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "from tqdm.auto import tqdm\n",
    "from src.config.models import NatPnModel, LeNet5, ResNet18\n",
    "from data.utils.datasets import DATASETS\n",
    "from data.utils.constants import MEAN, STD\n",
    "from torch.utils.data import DataLoader, Subset\n",
    "from torchvision.transforms import Compose, Normalize\n",
    "from src.config.utils import evaluate, evaluate_only_classifier, validate_accuracy_per_client, evaluate_switch\n",
    "from src.config.nat_pn.loss import BayesianLoss\n",
    "from src.config.uncertainty_metrics import (\n",
    "    load_dataset,\n",
    "    load_dataloaders,\n",
    "    choose_threshold,\n",
    "    load_model,\n",
    "    expected_entropy,\n",
    ")\n",
    "from torch.nn import CrossEntropyLoss\n",
    "from typing import Optional\n",
    "from collections import OrderedDict\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import math\n",
    "from copy import deepcopy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d57de5c-1c35-470c-a6a3-15f5d23dedca",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6ce45769-5683-48be-b864-ed35e47c14f4",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "dataset_name = 'cifar10'\n",
    "\n",
    "# path = f\"../out/FedAvg/Noneall_params_stopgrad_logp_{dataset_name}_100_natpn.pt\"\n",
    "path = f\"../out/FedAvg/Noneall_params_{dataset_name}_100_natpn.pt\"\n",
    "\n",
    "backbone = 'res18' if dataset_name in ['cifar10', 'svhn'] else 'lenet5'\n",
    "batch_size = 4000 if dataset_name in ['cifar10', 'svhn'] else 20000\n",
    "\n",
    "\n",
    "device = \"cuda:0\"\n",
    "stopgrad = True\n",
    "\n",
    "\n",
    "all_params_dict = torch.load(path, map_location=device)\n",
    "data_indices, trainset, testset = load_dataset(dataset_name=dataset_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "6dfe9b30-7bc6-472d-8885-858a4c348ee6",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "criterion = BayesianLoss(entropy_weight=0.0, log_prob_weight=0.01, embeddings_weight=1.0,\n",
    "                           reduction='sum')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "77cd4ce5-b4d0-4a34-a46b-f5d688f2e56e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# validate_accuracy_per_client(\n",
    "#     dataset_name=dataset_name,\n",
    "#     backbone=backbone,\n",
    "#     stopgrad=stopgrad,\n",
    "#     criterion=criterion,\n",
    "#     all_params_dict=all_params_dict,\n",
    "#     device=device,\n",
    "#     validate_only_classifier=False,\n",
    "# )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f641cd8b-4112-4d03-9916-3feb90df7c2a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "02c4098a-1ab4-465e-88ed-24856e62697e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "train_indices = [i for i in range(len(trainset.dataset)) if i % 10 != 0]\n",
    "test_indices = [i for i in range(len(trainset.dataset)) if i % 10 == 0]\n",
    "\n",
    "\n",
    "trainloader, _, _ = load_dataloaders(\n",
    "    client_id=0, data_indices=[\n",
    "        {\n",
    "            \"train\": train_indices,\n",
    "            \"test\": test_indices,\n",
    "        }\n",
    "    ], trainset=trainset, testset=testset, batch_size=batch_size,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "02a2dd49-0333-4d3a-b24f-9be00ea7a562",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "quantiles = {\n",
    "    'mnist': 1 - 0.3,\n",
    "    'fmnist': 1 - 0.4,\n",
    "    'medmnistA': 1 - 0.4,\n",
    "    'medmnistC': 1 - 0.4,\n",
    "    'medmnistS': 1 - 0.4,\n",
    "    'cifar10': 1 - 0.4,\n",
    "    'svhn': 1 - 0.4,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d6961300-3a8c-4fb4-b11e-c675ce31d5cd",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "!\n"
     ]
    }
   ],
   "source": [
    "global_model = load_model(\n",
    "    dataset_name=dataset_name,\n",
    "    backbone=backbone,\n",
    "    stopgrad=stopgrad,\n",
    "    index='global',\n",
    "    all_params_dict=all_params_dict,\n",
    ")\n",
    "global_model.eval()\n",
    "global_model.to(device)\n",
    "print('!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "8652c3a4-b78c-479f-9d02-8a20378f3338",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4000"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "batch_size"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f80a7fcf-4ec0-4f20-839e-2c3209a35931",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "57e551d274b6448384d7aa020a3ada3f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/20 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "all_models_accuracy_per_class_local = []\n",
    "all_models_accuracy_per_class_global = []\n",
    "all_models_accuracy_per_class_switch = []\n",
    "\n",
    "ind_classes = []\n",
    "with torch.no_grad():\n",
    "    for model_index in tqdm(range(len(all_params_dict) - 1)):\n",
    "\n",
    "        current_model = load_model(\n",
    "            dataset_name=dataset_name,\n",
    "            backbone=backbone,\n",
    "            stopgrad=stopgrad,\n",
    "            index=model_index,\n",
    "            all_params_dict=all_params_dict,\n",
    "        )\n",
    "        current_model.eval()\n",
    "        current_model.to(device)\n",
    "        \n",
    "        data_indices, trainset, testset = load_dataset(dataset_name=dataset_name)\n",
    "        \n",
    "        _, _, calloader = load_dataloaders(\n",
    "            client_id=model_index, data_indices=data_indices, trainset=trainset, testset=testset, batch_size=batch_size,\n",
    "        )\n",
    "        \n",
    "        threshold_dict, _ = choose_threshold(model=current_model, calloader=calloader,\n",
    "                                          device=device, alpha=quantiles[dataset_name])\n",
    "\n",
    "        # for batch in trainloader:\n",
    "            # x, y = batch[0].to(device), batch[1].to(device)\n",
    "            # y_pred, log_prob_processed, local_embeddings = current_model.train_forward(x=x)\n",
    "        _, _, _, _, local_predictions, global_predictions, switch_predictions, true_labels, _, _ = evaluate_switch(\n",
    "            dataloader=trainloader,\n",
    "            local_model=current_model,\n",
    "            global_model=global_model,\n",
    "            threshold=threshold_dict['log_prob'], \n",
    "            uncertainty_measure='log_prob',\n",
    "            device=device,\n",
    "            return_predictions=True\n",
    "        )\n",
    "\n",
    "        true_labels = torch.hstack(true_labels).numpy()\n",
    "        local_predictions = torch.hstack(local_predictions).numpy()\n",
    "        global_predictions = torch.hstack(global_predictions).numpy()\n",
    "        switch_predictions = torch.hstack(switch_predictions).numpy()\n",
    "\n",
    "        \n",
    "        acc_per_class_local = []\n",
    "        acc_per_class_global = []\n",
    "        acc_per_class_switch = []\n",
    "        n_classes = current_model.classifier.linear[-1].out_features\n",
    "        for l in range(n_classes):\n",
    "            indices = true_labels == l\n",
    "            acc_per_class_local.append( (true_labels[indices] == local_predictions[indices]).sum() / len(true_labels[indices]))\n",
    "            acc_per_class_global.append( (true_labels[indices] == global_predictions[indices]).sum() / len(true_labels[indices]))\n",
    "            acc_per_class_switch.append( (true_labels[indices] == switch_predictions[indices]).sum() / len(true_labels[indices]))\n",
    "        all_models_accuracy_per_class_local.append(acc_per_class_local)\n",
    "        all_models_accuracy_per_class_global.append(acc_per_class_global)\n",
    "        all_models_accuracy_per_class_switch.append(acc_per_class_switch)\n",
    "        ind_classes.append(current_model.labels.cpu().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "8fe24841-cd44-4f67-a765-eb896352922f",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "local_model_accuracies = np.vstack(all_models_accuracy_per_class_local)\n",
    "global_model_accuracies = np.vstack(all_models_accuracy_per_class_global)\n",
    "switch_model_accuracies = np.vstack(all_models_accuracy_per_class_switch)\n",
    "ind_classes = np.vstack([np.bincount(el.tolist(), minlength=n_classes) for el in ind_classes])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "75290fcd-14fa-44ed-a7cc-3cfa8a3c7ac3",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "c3a439a5-d5f3-4937-aa75-36fa2b27d164",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([1, 2, 5, 6, 7, 8, 9]),\n",
       " array([ 675, 1642,   87,  217,   94, 2287,  396]))"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.unique(global_predictions[true_labels == 0], return_counts=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1c0eda1c-41d9-4f62-8b86-bb25dbeb61cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "9773f21b-5228-4c23-8243-e13a3f5cd231",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "def pretty_matplotlib_config(fontsize=15):\n",
    "    matplotlib.rcParams['pdf.fonttype'] = 42\n",
    "    matplotlib.rcParams['ps.fonttype'] = 42\n",
    "    matplotlib.rcParams['text.usetex'] = True\n",
    "    matplotlib.rcParams.update({'font.size': fontsize})\n",
    "    \n",
    "pretty_matplotlib_config(40)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "23144dd3-8f61-48c2-a270-5c14b4b21a54",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "221b41db-62bc-4348-9fa0-9c55a6132304",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 3500x2000 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(ncols=3, figsize=(35, 20),) # You can adjust the size\n",
    "\n",
    "title_name = {\n",
    "    \"mnist\": \"MNIST\",\n",
    "    \"fmnist\": \"FashionMNIST\",\n",
    "    \"cifar10\": \"CIFAR10\",\n",
    "    \"svhn\": \"SVHN\",\n",
    "    \"medmnistA\": \"MedMNIST-A\",\n",
    "    \"medmnistS\": \"MedMNIST-S\",\n",
    "    \"medmnistC\": \"MedMNIST-C\",\n",
    "}\n",
    "\n",
    "fig.suptitle(title_name[dataset_name])\n",
    "\n",
    "\n",
    "f = sns.heatmap(global_model_accuracies, annot=False, fmt=\".2f\", linewidths=.5, ax=ax[0], cmap='viridis', vmin=0, vmax=1)\n",
    "f.set_title('Global model')\n",
    "f.axis('off')\n",
    "f.set_xlabel('Dataset')\n",
    "f.set_ylabel('Model')\n",
    "f.set_aspect('equal')\n",
    "\n",
    "f = sns.heatmap(local_model_accuracies, annot=False, fmt=\".2f\", linewidths=.5, ax=ax[1], cmap='viridis', vmin=0, vmax=1, )\n",
    "f.set_title('Local model')\n",
    "f.axis('off')\n",
    "f.set_xlabel('Dataset')\n",
    "f.set_ylabel('Model')\n",
    "f.set_aspect('equal')\n",
    "\n",
    "f = sns.heatmap(\n",
    "    # (switch_model_accuracies - local_model_accuracies) * 100 / (local_model_accuracies + 1e-5),\n",
    "                switch_model_accuracies,\n",
    "                annot=False, fmt=\".2f\", linewidths=.5, ax=ax[2], cmap='viridis',\n",
    "                vmin=0,\n",
    "                vmax=1\n",
    "               )\n",
    "f.set_title('Switching model')\n",
    "f.axis('off')\n",
    "f.set_xlabel('Dataset')\n",
    "f.set_ylabel('Model')\n",
    "f.set_aspect('equal')\n",
    "\n",
    "plt.tight_layout()\n",
    "# plt.savefig(f'{title_name[dataset_name]}_models_matrices.pdf', format='pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "97cffbc8-8b2a-4c95-b6d4-9b0be04cde86",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "77d506df-13a6-4e80-8c6d-906723e5fb39",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
