{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "NOTE: Running this notebook requires running cifar10 or cifar100 training first. using the run_experiment.py file. \n",
    "Scripts to run these experiments with the config files employed in the paper can be found under /cluster_run/slurm/cifar100-cifar10-transfer. This requires a setup with apptainer and slurm. "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:13.494330Z",
     "iopub.status.busy": "2024-08-21T10:22:13.493807Z",
     "iopub.status.idle": "2024-08-21T10:22:17.327129Z",
     "shell.execute_reply": "2024-08-21T10:22:17.326407Z"
    },
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "import os\n",
    "import random\n",
    "from glob import glob\n",
    "\n",
    "import joblib\n",
    "\n",
    "# os.environ['CUDA_LAUNCH_BLOCKING'] = \"1\"\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "import torchvision\n",
    "from tqdm import tqdm\n",
    "from zennit import canonizers as zcanon\n",
    "from zennit import composites as zcomp\n",
    "from zennit import core as zcore\n",
    "\n",
    "from experiment_utils.data import dataloaders, datasets, transforms\n",
    "from experiment_utils.evaluation import evaluate\n",
    "from experiment_utils.model import models\n",
    "from lfprop.propagation import propagator_lxt as propagator\n",
    "from lfprop.rewards import rewards"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Experiment Variables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:17.330814Z",
     "iopub.status.busy": "2024-08-21T10:22:17.330624Z",
     "iopub.status.idle": "2024-08-21T10:22:17.379892Z",
     "shell.execute_reply": "2024-08-21T10:22:17.379262Z"
    },
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "dataset_name_base = \"cifar10\"  # or cifar100\n",
    "model_name = \"cifar-vgglike\"\n",
    "n_channels = 3\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "batch_size = 128\n",
    "momentum = 0.9\n",
    "reward_name = \"softmaxlossreward\"\n",
    "loss_name = \"ce-loss\"\n",
    "activation = \"relu\"\n",
    "seeds = [\"7240\", \"5110\", \"5628\"]\n",
    "norm_backward = False\n",
    "methods = [\"lfp-epsilon\", \"vanilla-gradient\"]\n",
    "\n",
    "recompute_accuracies = False\n",
    "investigated_lr = 0.1\n",
    "investigated_ep_grad = 50\n",
    "investigated_ep_lfp = 50\n",
    "\n",
    "savepath = \"<path to save results in>\"\n",
    "data_path_base = \"<path where base dataset is saved>\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### ModelWrapper Class"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:17.383514Z",
     "iopub.status.busy": "2024-08-21T10:22:17.383326Z",
     "iopub.status.idle": "2024-08-21T10:22:17.399448Z",
     "shell.execute_reply": "2024-08-21T10:22:17.398743Z"
    },
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "def get_head(model):\n",
    "    if isinstance(model, torchvision.models.VGG) or isinstance(model, torchvision.models.efficientnet.EfficientNet):\n",
    "        head = [m for m in model.classifier.modules() if not isinstance(m, torch.nn.Sequential)][-1]\n",
    "    elif isinstance(model, torchvision.models.ResNet) or isinstance(model, torchvision.models.Inception3):\n",
    "        head = model.fc\n",
    "    else:\n",
    "        head = model.classifier[-1]\n",
    "    return head\n",
    "\n",
    "\n",
    "class ModelWrapper:\n",
    "    def __init__(\n",
    "        self,\n",
    "        modelname,\n",
    "        activation,\n",
    "        n_channels,\n",
    "        n_classes,\n",
    "        savepath,\n",
    "        savename,\n",
    "        saveappendage,\n",
    "        criterion,\n",
    "        batch_size,\n",
    "        device,\n",
    "    ):\n",
    "        self.modelname = modelname\n",
    "        self.activation = activation\n",
    "        self.n_channels = n_channels\n",
    "        self.n_classes = n_classes\n",
    "        self.checkpointpath = os.path.join(savepath, f\"{savename}-{saveappendage}.pt\")\n",
    "        self.criterion = criterion\n",
    "        self.batch_size = batch_size\n",
    "        self.device = device\n",
    "\n",
    "        self.acc_log = {\"train\": [], \"base\": [], \"transfer\": []}\n",
    "        self.stored_heads = {}\n",
    "        self.best_acc = 0\n",
    "\n",
    "        # print(vars(self))\n",
    "\n",
    "    def eval(self, dataset, dataset_name, replace_last_layer=True):\n",
    "        if not hasattr(self, \"model\"):\n",
    "            self.load(dataset_name, replace_last_layer)\n",
    "        else:\n",
    "            self.load_head(dataset_name)\n",
    "\n",
    "        self.model.eval()\n",
    "\n",
    "        loader = dataloaders.get_dataloader(\n",
    "            dataset_name=dataset_name,\n",
    "            dataset=dataset,\n",
    "            batch_size=self.batch_size,\n",
    "            shuffle=False,\n",
    "        )\n",
    "\n",
    "        return_dict = evaluate.evaluate(self.model, loader, self.criterion, device)\n",
    "\n",
    "        return return_dict\n",
    "\n",
    "    def load_head(self, dataset_name):\n",
    "        in_features, out_features, head_state_dict = self.stored_heads[dataset_name]\n",
    "        models.replace_torchvision_last_layer(self.model, out_features)\n",
    "        head = get_head(self.model)\n",
    "        head.load_state_dict(head_state_dict)\n",
    "\n",
    "        self.model.to(self.device)\n",
    "\n",
    "        self.model.eval()\n",
    "\n",
    "    def load(self, dataset_name, replace_last_layer=True):\n",
    "        self.model = models.get_model(\n",
    "            self.modelname,\n",
    "            self.n_channels,\n",
    "            self.n_classes,\n",
    "            self.device,\n",
    "            replace_last_layer=replace_last_layer,\n",
    "            activation=self.activation,\n",
    "        )\n",
    "        if os.path.exists(self.checkpointpath):\n",
    "            checkpoint = torch.load(self.checkpointpath)\n",
    "            if self.model:\n",
    "                self.model.load_state_dict(checkpoint[\"model\"])\n",
    "            if \"acc_log\" in checkpoint:\n",
    "                self.acc_log = checkpoint[\"acc_log\"]\n",
    "            if \"stored_heads\" in checkpoint:\n",
    "                self.stored_heads = checkpoint[\"stored_heads\"]\n",
    "            if \"best_acc\" in checkpoint:\n",
    "                self.best_acc = checkpoint[\"best_acc\"]\n",
    "            self.global_epoch = checkpoint[\"epoch\"]\n",
    "            self.global_step = checkpoint[\"step\"]\n",
    "\n",
    "            torch.set_rng_state(checkpoint[\"random_state\"][\"torch\"])\n",
    "            torch.cuda.set_rng_state(checkpoint[\"random_state\"][\"cuda\"], device)\n",
    "            np.random.set_state(checkpoint[\"random_state\"][\"numpy\"])\n",
    "            random.setstate(checkpoint[\"random_state\"][\"random\"])\n",
    "\n",
    "            self.load_head(dataset_name)\n",
    "\n",
    "        else:\n",
    "            print(\"No checkpoint found... not loading anything.\")\n",
    "\n",
    "        self.model.eval()\n",
    "\n",
    "    def remove(self):\n",
    "        del self.model\n",
    "        if hasattr(self, \"stored_heads\"):\n",
    "            del self.stored_heads"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Paths, Dataset, Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:17.404753Z",
     "iopub.status.busy": "2024-08-21T10:22:17.404493Z",
     "iopub.status.idle": "2024-08-21T10:22:20.358961Z",
     "shell.execute_reply": "2024-08-21T10:22:20.358392Z"
    },
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "os.makedirs(data_path_base, exist_ok=True)\n",
    "\n",
    "train_dataset_base = datasets.get_dataset(\n",
    "    dataset_name_base,\n",
    "    data_path_base,\n",
    "    transforms.get_transforms(dataset_name_base, \"train\"),\n",
    "    mode=\"train\",\n",
    ")\n",
    "test_dataset_base = datasets.get_dataset(\n",
    "    dataset_name_base,\n",
    "    data_path_base,\n",
    "    transforms.get_transforms(dataset_name_base, \"test\"),\n",
    "    mode=\"test\",\n",
    ")\n",
    "\n",
    "\n",
    "propagation_composites = {\n",
    "    \"lfp-epsilon\": propagator.LFPEpsilonComposite(\n",
    "        norm_backward=norm_backward,\n",
    "    ),\n",
    "    \"vanilla-gradient\": None,\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load Checkpoints"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:20.362862Z",
     "iopub.status.busy": "2024-08-21T10:22:20.362678Z",
     "iopub.status.idle": "2024-08-21T10:22:20.382048Z",
     "shell.execute_reply": "2024-08-21T10:22:20.381517Z"
    },
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.1, vanilla-gradient, 7240\n",
      "0.1, vanilla-gradient, 5110\n",
      "0.1, lfp-epsilon, 7240\n",
      "0.1, lfp-epsilon, 5110\n",
      "0.1, vanilla-gradient, 5628\n",
      "0.1, lfp-epsilon, 5628\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "['/media/lweber/f3ed2aae-a7bf-4a55-b50d-ea8fb534f1f51/reward-backprop/resubmission-1-experiments/cifar100-cifar10-basemodels-cluster/cifar10-accuracies_basemodel-50-50.joblib']"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "transfer_wrappers = {}\n",
    "\n",
    "accuracies_basemodel = {\n",
    "    dataset_name_base: {},\n",
    "}\n",
    "\n",
    "filepath_base = os.path.join(\n",
    "    savepath, f\"{dataset_name_base}-accuracies_basemodel-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\"\n",
    ")\n",
    "\n",
    "for fulldir in glob(os.path.join(savepath, f\"{dataset_name_base}_*.yaml*\")):\n",
    "    dir = fulldir.split(\"/\")[-1]\n",
    "    runparams = dir.split(\".yaml\")[0].split(\"_\")[:-1]\n",
    "\n",
    "    lr, prop_comp, seed = float(runparams[1]), runparams[2], runparams[7]\n",
    "\n",
    "    print(f\"{lr}, {prop_comp}, {seed}\")\n",
    "\n",
    "    if lr not in transfer_wrappers.keys():\n",
    "        transfer_wrappers[lr] = {}\n",
    "        accuracies_basemodel[dataset_name_base][lr] = {}\n",
    "    if prop_comp not in transfer_wrappers[lr].keys():\n",
    "        transfer_wrappers[lr][prop_comp] = {}\n",
    "        accuracies_basemodel[dataset_name_base][lr][prop_comp] = {}\n",
    "\n",
    "    ie = investigated_ep_grad if prop_comp == \"vanilla-gradient\" else investigated_ep_lfp\n",
    "    ckpt_path = os.path.join(fulldir, \"output\", seed, \"ckpts\")\n",
    "    transfer_wrappers[lr][prop_comp][seed] = (\n",
    "        ModelWrapper(\n",
    "            modelname=model_name,\n",
    "            activation=activation,\n",
    "            n_channels=n_channels,\n",
    "            n_classes=len(test_dataset_base.classes),\n",
    "            savepath=ckpt_path,\n",
    "            savename=\"base-model\",\n",
    "            saveappendage=f\"ep-{ie}\",\n",
    "            criterion=rewards.get_reward(reward_name, device)\n",
    "            if prop_comp is not None\n",
    "            else rewards.get_reward(loss_name, device),\n",
    "            batch_size=batch_size,\n",
    "            device=device,\n",
    "        ),\n",
    "    )\n",
    "\n",
    "    if recompute_accuracies or not os.path.exists(filepath_base):\n",
    "        print(\"Evaluating Models...\")\n",
    "        # Eval base accuracy\n",
    "        # print(\"Eval base base\")\n",
    "        res = transfer_wrappers[lr][prop_comp][seed][0].eval(\n",
    "            test_dataset_base, dataset_name_base, replace_last_layer=False\n",
    "        )\n",
    "        accuracies_basemodel[dataset_name_base][lr][prop_comp][seed] = (\n",
    "            float(res[\"accuracy_p050\"]) if \"accuracy_p050\" in res.keys() else float(res[\"micro_accuracy_top1\"])\n",
    "        )\n",
    "        transfer_wrappers[lr][prop_comp][seed][0].remove()\n",
    "\n",
    "        print(f\"Accuracies Base: (Base) {accuracies_basemodel[dataset_name_base][lr][prop_comp][seed]:.2f}\")\n",
    "\n",
    "if os.path.exists(filepath_base) and not recompute_accuracies:\n",
    "    accuracies_basemodel = joblib.load(filepath_base)\n",
    "joblib.dump(accuracies_basemodel, filepath_base)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:20.385417Z",
     "iopub.status.busy": "2024-08-21T10:22:20.385240Z",
     "iopub.status.idle": "2024-08-21T10:22:20.389986Z",
     "shell.execute_reply": "2024-08-21T10:22:20.389399Z"
    },
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "# Plot Settings\n",
    "# Set font properties.\n",
    "import matplotlib.cm as cm\n",
    "import matplotlib.font_manager as font_manager\n",
    "\n",
    "font_path = plt.matplotlib.get_data_path() + \"/fonts/ttf/cmr10.ttf\"\n",
    "cmfont = font_manager.FontProperties(fname=font_path)\n",
    "plt.rcParams[\"font.family\"] = \"serif\"\n",
    "plt.rcParams[\"font.serif\"] = cmfont.get_name()\n",
    "plt.rcParams[\"mathtext.fontset\"] = \"cm\"\n",
    "\n",
    "# Set font size.\n",
    "plt.rcParams[\"font.size\"] = 15\n",
    "\n",
    "# Disable unicode minus.\n",
    "plt.rcParams[\"axes.unicode_minus\"] = False\n",
    "\n",
    "# Use mathtext for axes formatters.\n",
    "plt.rcParams[\"axes.formatter.use_mathtext\"] = True\n",
    "\n",
    "plt.rcParams[\"axes.linewidth\"] = 1.5"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot Val Accuracies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:20.393038Z",
     "iopub.status.busy": "2024-08-21T10:22:20.392817Z",
     "iopub.status.idle": "2024-08-21T10:22:20.929415Z",
     "shell.execute_reply": "2024-08-21T10:22:20.928717Z"
    },
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cifar10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_736656/1465233951.py:11: MatplotlibDeprecationWarning: The get_cmap function was deprecated in Matplotlib 3.7 and will be removed two minor releases later. Use ``matplotlib.colormaps[name]`` or ``matplotlib.colormaps.get_cmap(obj)`` instead.\n",
      "  palette = cm.get_cmap(colormap)(colors)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MAX: lfp-epsilon - 0.1 - 0.8243999481201172\n",
      "MAX: vanilla-gradient - 0.1 - 0.8402000069618225\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiwAAAE5CAYAAACzhHtcAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAA6wUlEQVR4nO3deViU5d4H8O8w7DCQioCgAgLhgLnkLmGhiQmUhKUZmZVaavmmFZWWqSVa2snqeCzULDfI7aSZuXRQcw/ccEtHjGSURRZFGXAGmHn/4DDHkUGe2WCQ7+e6uN68n/u+n99wfN75+dybSKPRaEBERERkxWyaOgAiIiKihjBhISIiIqvHhIWIiIisHhMWIiIisnpMWIiIiMjqMWEhIiIiq8eEhYiIiKweExYiIiKyekxYiIiIyOrZNnUA9amursaQIUOwcuVKdOjQQXC7GzduIDExEWq1Gt7e3jh37hzGjx+PmJgYo+oRERFR07PKhOXUqVOYNm0a9uzZg+rqasHt1Go14uLiEBISgmXLlgEALl++jLCwMKxbt06bjAitR0RERNZBZE1nCclkMkybNg3u7u64fv06duzYgezsbPj7+wtqv2bNGowZMwYymQzBwcHa8oSEBKSnp0Mmk0EkEgmu1xC1Wo2ioiIAgLOzs6A2REREBGg0GpSXlwMAPDw8YGPTwCwVjZWaNWuWBoAmOztbcJvo6GiNl5dXnfJvvvlGA0Bz5MgRg+o1pKCgQAOAP/zhD3/4wx/+mPBTUFDQ4HfufTXpNiMjA76+vnXKa8syMjIMqkdERETWwSrnsBhDoVCgsLAQUqm0zjWJRAIAyM/PF1xPCGdnZ+1/FxQUwMXFxZjQiYiIWhyFQgEvLy8Aut+n9blvEpabN28CgN6kwdXVFQBw/fp1wfXqo1QqoVQqAdT8smu5uLgwYSEiIjKCkDmg982QkFgsBgC9k3ZUKhUAoLKyUnC9+syfPx/u7u5wd3eHj4+PyXETERFRw+6bhKVNmzb1zjAuKysDUDPkI7RefaZPn47S0lKUlpYiNzfXxKiJiIhIiPtmSEgsFsPT01PvcE5tIuLv7y+4Xn0cHBzg4OCgvScRERFZ3n3zhgUAIiMjIZfL65TLZDIAQM+ePQ2qR0RERNah2SYseXl5OpNeAWD48OGQy+XIycnRKU9LS4Ofnx/69+9vUD0iIiKyDlabsFRUVABAnaQEALKzsxEQEIA+ffrolD/99NMICwtDUlKStiwzMxO7d+/G4sWLtbOQhdYjIiIi62BVW/MXFxcjISEBBQUFOHXqFNRqNSQSCbp164aIiAjMmzcPAFBUVIQ+ffpAKpVi27ZtOn0UFBQgMTERIpEInp6eOHbsGCZOnIiRI0caVe9eFAqFdil0WVkZlzUTEREJZOh3qFUlLM0NExYiIl0ajQaVlZVQq9VNHQo1AbFYDDs7O0F1Df0OvW9WCRERUdNRqVS4du0aysvLUV1d3dThUBNycHCAh4cH3NzczNovExYiIjJJeXk55HI5xGIxWrVqBScnJ4jFYs4HbGFq366Vlpbi6tWrAGDWpIUJCxERmaSoqAh2dnbw8/Pj/lQtnJOTEyQSCa5cuYKioiKzJixWu0qIiIisX1VVFRQKBVq3bs1khQDUnAvk7u4OpVJ5z6NuDMWEhYiIjFZVVQUA2h3AiQBoJ96acz4TExYiIjIZ56vQnSzx94EJCxEREVk9JixERERk9ZiwEBERkdXjsmYiIiIz2rlzJ5KSknDixAmUlZUBAPz8/BAYGIhp06YhNja2wTZisRiRkZHaycy3b9/GlStXcOHCBQA159+p1WpMmzYNp06dQklJCezs7BAZGQk7OztUV1ejpKQEIpEIo0ePxsSJE5v9xGhuzW8Cbs1PRC3d7du3tQfSOjo6NnU4VmXHjh0YNmwYevfujfT0dIPaDBgwAAcPHqxz/fjx4xg2bBhWrFiBmJgYAMD58+chlUoxdOhQ7NixQ6f+iRMnEBUVhQ4dOuC3335DmzZtTP9gAgj5e2HodyiHhIiIiCyg9ova2dnZ4Db1ncfz8MMP46OPPoJcLq/Txta27qBJjx49MG3aNJw4cQLvvPOO4DisEYeEiIjIIjRqNTT/HRJpTkSurhDZWO+/56Ojo7F8+XLB9bt06QIA2Lp1q6VCahRMWIiIyCI0ZWW4/n9vNnUYBmv19VcQmfngPlPJZDJIJBK0a9cO/v7+KCoqEty2dgdioacoWyvrTSGJiIgIQM3cltoJtyKRCF988YXgtidOnAAAJCQkCG5TUFCA2bNno3///nB3d4ezszMef/xx7Ny507DAzYgJCxERkRVTKpXYsmWLTpnQRR779+/HP/7xD4wYMQJz584V1ObMmTOIioqCvb09/vWvf+HixYvIysrCqFGjtElTU7DIkJBSqYRYLNY7AYiIiIju7cyZM4iLi4NSqcSxY8dQWFiImTNn3rNNZmYmJk6cCABQq9W4desW3NzcsGnTJgwaNEjwvQ8ePIjk5GT069dPp3zChAmGfxAzMntGcePGDYSEhKBDhw44evSoubsnIqJmQuTqilZff9XUYRhM9N+lto3h1KlTCAwMrPPGpEuXLti8eTMAoLKyEs8++2yDfQUGBuLbb79tsJ5KpYJardYps7Gxgb29PQBgxIgR2LFjB1QqFeLi4jB06FD861//QuvWrQV+Ksswe8KiVqtRVVXFg7CIyCrs2rULH82ajY/nzEZUVFRTh9OiiGxsrG7yqrX55ptv8Pnnn9+zjp2dHZ544gmz3TMqKgq///67Ttmjjz6KvXv3orq6GgsXLkRSUhJsbW1RUlJitvuayuwJS+vWrZGTk9Psd9QjouavoqICH3z4IfJy8/DBhx8iIiICTk5OTR0WkZZMJhM0H6V2qMcckpOTcevWLZ0yiUQCAPj5558RHR1tlVM6LDLp1sXFxSo/LBG1LP/85z9RUHANA1+ZiYKCa1i8eHFTh0SkdebMGVy7dq3R7xsSEoJevXrp/ISEhAAALl68WO9Gd2lpaY0ZZh0mJSwymQzFxcU6Zdu3b8eNGzdM6ZaIyGTZ2dlYsmQJOj8WD5/OvdD50Xj8a8kSZGdnN3Vo1ELcvn0bAOrMFwFqvj+fe+45+Pj46G1T+38NuY9SqTQ2VK0nnngCEydOxPbt21FcXAyFQoGzZ8/inXfeafLvdqMTlrVr16Jz584YNmyYTnlQUBDefvtt/PXXXyYHR0RkDI1Ggw9nzoSjpDVCI58BAIQOegaOrq0w86OPwCPUyJJ27tyJRx99VDtR9siRI4iKikJsbCyeeOIJdOvWDZ07d8bZs2fRvn17vW3++OMPBAUFYciQIdi1a5fe+5w8eRKDBw9GeHi49j6hoaEYPXq00bF37doVixYtwueff46AgAB06tQJ77//PkaMGIERI0YY3a85GH344WuvvYaOHTvC0dERb7/9ts61yspKTJ8+vcGJRM0dDz8ksk47d+7EK6+8goixH6B9l/8tzbxy5jD2r5yH77//nhNwzYSHH5I+ljj80OiJJmKxGB988IHea819+18iar4qKirw4cyZ8JX2gm9YX51rvmH94NO5JyfgEjVDRg8JqVSqe16/evWqsV0TERmtdqJtj6cm1NleQSQS4eHhr3ICLlEzZHTCcv36dRw4cEDvtZ9//rnOkikiIku7c6KtxMNHbx2Jhw8n4BI1Q0YPCU2fPh2PPfYYYmJi0KtXL3To0AElJSXYtWsXdu7cib1795oxTCKie9NOtHX730Tb+oQOegY5J/biw5kzsWb1am50SdQMGJ2w9OrVC+vXr8fYsWOxYcMGiEQiaDQauLm5Ye3atejbt2/DnRARmUlWVhb27tmD7jEvw9b+3pM/be0d0anfMOz99QdkZWUhODi4kaIkImOZtLtbdHQ0cnJysHXrVvz999/w8fHBU089BTduxUxEjSwoKAiPRUYi4+AvCB4Qfc+kpUp1G1mHtiFy0CAEBQU1YpREZCyTt6N1cnLCyJEjtX9uaDIuEZEliEQiTHztNewdPRrn9mxE16Ev1Fv33O6NUJQWYeJrr3E4iKiZMHrS7cWLFzFgwAAkJibqlH/33XeYPn263p39iIgsRaPRIPnbbyGxtcX5PRtxqyhXb71bhbk4v3cjXG1t8e0333ATOaJmwuiEZdGiRbh58yaOHj2qUz5p0iQkJCTc95vGEZF1ycrKwp69ezG2Y0e0tXfA8c3JdZIRjUaD41uS0dbBAWM7dsSevXuRlZXVRBETkSFMOkvoxIkT2LlzZ53yLl26oLCw0JSuiYgMEhQUhMjHHsO/8/PxVlAQci8cx9Wzf+jUuXr2CHIvHMfbgUH4KT8fgyIjOYeFqJkwOmFRq9Wws7ODvb293us3b940OigiIkOJRCJ8MncuipRKZN26hXCPtji5JRlVqpqD4apUt3FiczIe8WgL2a1bKFKp8MncuZzDQtRMGJ2wXLlyBRUVFXqvFRUVQSaTGR0UEZExAgICMOn11/G9PAdjO3ZExc0SnNuzEUDNRFvlrRt4sWMH/CDPweTXX4e/v3/TBkxEghmdsERHR+ORRx7B9u3btcM/5eXl2Lx5MyIiIhAfH2+2IImIhJoyZQq8PD2xSp6Dl/38cH7PRuSeP4rzezfiZb+OWCWXw9vLC2+88UZTh0pEBjA6YZk8eTJCQ0MRExMDb29vODo6QiKRYMSIEQgLC8OUKVPMGScRkSBOTk74OCkJBwoL8aCrBG3tHbBvxcdo6+CAIFcJDhQW4uOkJB58SNTMmDTpdvXq1UhNTUVUVBQ6deqEyMhIrFixAhs3bjRXfEREBouKikLkY49h0V+X8E5wEHycXfBOUBAWXcrCoMhIDBkypKlDpBZCpVJh2bJlGDJkCAYMGIDY2FiMGjUKn376KW7fvo28vDyMGjWq0eJ5//330adPHwQFBWHdunWNdl9zMHnjuFGjRjXqL5uIqCG1E3AHPfYYLt4qw/YBA7A4KwvFlZWcaEuN5tSpUxgxYgTatm2Lr7/+Gr169dJeO3LkCEaPHo3S0tJG3bds3rx52LRpE0aOHFnvPFRrZdIblntJSkqyVNdERA2qnYC7Iucy9hcV4vucy5xoS43m9OnTeOSRR+Dn54c9e/boJCsA0K9fP8ycORMHDx5s1LhsbGzQu3fvRr2nuZj8hqU+mzdvxgcffGCp7omIGjRlyhRsWr8eU06cgK+PDyfaNjK1RoNyZVVTh2EwZwdb2JjwFq6qqgojR46EUqnEypUr4eDgoLfeww8/jJdffhnnz583+l4tidkTlgsXLmD58uU4ceKE0X3cuHEDiYmJUKvV8Pb2xrlz5zB+/HjExMQ02PbgwYN45pln0LNnTzg7O8Pe3h62trof88svv8QDDzyAd999F7GxsQgNDYVEIkFubi727t2Ltm3bIjY21uj4icg6ODk54ZN58zDno48w6+OPOdG2kZUrqzD736ebOgyDzY5/CK6Odka3T01Nxfnz5/HUU0/B19f3nnXHjRtX54gb0s8sCUtJSQlSU1OxatUqHD16FBqNxugxYrVajbi4OISEhGDZsmUAgMuXLyMsLAzr1q1rMGk5c+YM8vPzsW3bNr3Xn376aTzwwAMAgIULF2LhwoU614cNG4b169cbFTsRWZ+oqChERUU1dRjUgmzevBkA6gwD6fPQQw+hf//+AGqGkcaNG4ecnBw8+OCD+OSTT7BlyxZs3LgRn376KZ5//nkAwOHDh/Hzzz8DACoqKnD16lW8//776NmzZ53+L126hLlz58LR0REPPPAAqqqqmu2kc6MTlqqqKmzduhWrVq3C9u3bUVlZCY1Gg4CAAIwZMwb//Oc/jeo3JSUFv//+uzZZAQA/Pz8MHz4cU6dORXR09D2TobNnz+LcuXMICgqCWCyGSCSCSCRCeXk54uLisHz5cm3djh07YujQocjNzYWvry/i4+MxdOhQo+ImIiICoN041dPTs8G6jo6OmD9/PoCa5OXQoUMYPHgwCgsLsXv3bnz22WdYunQpfv75Zzz//PNQKpWIiopCbGwsUlNTAQC7du1CREQEDh06hO7du2v7Pnr0KB5//HH88MMPiIuLA1DzUmDy5Mnm/cCNxOCEJT09HatWrcK6detQUlICjUYDFxcXeHl5Yfny5drMzdiJRKmpqfDy8kJwcLBOeUREBFJSUpCeno6+ffvW2768vBxSqbRO+dSpU/Hhhx+idevW2rKAgAAsXbrUqDiJiIj0EYvFRre1tbVFQEAA9u3bhxdeeAF2dnaQyWRwd3cHUHOAp1Qq1fkui4qKQqtWrfD999/jq6++AlCTmDz//PMICwvTJitAzaTbiRMnIjk52egYm4qghEUul2P16tVYvXo1ZDIZNBoNxGIxhgwZghdeeAHx8fFISEjQec2UkpJiVEAZGRno0KFDnfLaccCMjIx7Jix3vkGptWHDBnh7e2PgwIFGxURERIZzdrDF7PiHmjoMgzk7mDZbIjg4GJmZmcjPz9d7fdasWdi3bx/y8/O1J4q3a9cOK1asQEBAAADAwcFBezCnj4+Ptq2joyPS09NRXFyM7777DqdPn4ZEIoFCoUBpaam23pEjR3Dx4sVmO/yjj6D/Vfr27av9xffs2RMJCQkYPXo0vLy8tHXuHqZp27atwcEoFAoUFhbqfUMikUgAoN6/APW5fv06Pv/8c+zfv7/ONZVKhQULFiAvLw/29vY4d+4cJk2ahOjoaINjJyIiXTYikUmTV5urZ599Fhs3bsSRI0f0Xp8zZw4A4NChQwgPD0evXr2wZ88enTpeXl71Tn+YP38+Pv/8c3z88ceYP38+nJycsHr1ap06OTk5AID27dub+nGshqCE5fz581i/fj1+/PFHtG7dGv7+/jqvowBos0RT1J7w7OLiUueaq6srgJoExBAzZszAK6+8ovdU6dzcXMTHx2uz2AsXLqB79+5YvXo1nnnmGb39KZVKKJVKADUJFhER0Z3i4+PRuXNn/Pbbb/jrr7/QqVMnvfVq35zo+86rL1lZvnw5ZsyYgbVr12on4d7t4sWL2pGK5rY53L0I2jjOzc0N48ePx3/+8x8sXLgQZ86cwSOPPIJXX30Vv//+O4D6f7mGqB33s7GpG5ZKpQIAVFZWCu4vPz8f33//fb1LlC9duqRNVgAgJCQEERERmDJlCqqq9O8dMH/+fLi7u8Pd3V3nNR0RERFQMw/l3//+N5ydnTFmzJh6/3Fr6IgBAPzyyy8AgKeeekpbVlVVheLiYu2fk5KS0L9/fwQEBOCPP/6o00d932/WzuCdbv38/PDhhx/ijz/+wLhx47B+/Xp069YNZ8+exYULF7T1hCznulubNm30JisAUFZWBuB/Q0NCfPPNN/D09Kx3Hby+iVHt2rVDfn5+vZOGp0+fjtLSUpSWliI3N1dwLERE1HJIpVIcOnQIxcXFCA8Px759+3Su5+XlYd68eRg8eHCdtpWVlVCpVHpHLmr/kX3y5Elt2eeffw5/f3+UlJSguroaTk5OsLGxwcqVK3Ho0CFs2rRJW1elUuGzzz4DAGRlZZnjozYak2YW9e3bF3379kVlZSW2bduGGTNmoLS0FN27d0dmZqbB/YnFYnh6euod9qlNWAzZVnvz5s31JiuDBg1CXl4eTpw4AUdHR215dXU1gPozXwcHB+2uhabMBCciovtbly5dcPLkSfz444+YM2cOFAoFWrVqBVdXV7Rp0wZffPEF3N3dMXPmTAA1+7C88cYbOHToEKqqqhAcHIzw8HCsXLlS2+cnn3wCsViMd955BxEREXBxcUHPnj2xcuVKjBgxAuPGjcOMGTMA1KyuPXDgAObOnYs9e/agdevWUKvVGDNmDLZv345Vq1Zh//792pESa2eWjePs7OwQFxeHuLg4XL9+HfPmzTP6MKfIyEgcOHCgTnntunZ9G+PoU1BQgNOnT9c7HHT06FG0bt26TgZ77do1AIYlRkRERPo4OjripZdewksvvVRvnW+//RZAzT4sDSUPTk5O2jckd8vOzq5T1q1bN2zYsKFOee1LgObE7IcftmrVCgsXLqx3klFDhg8fDrlcrp3hXCstLQ1+fn7aHQGBmldq9Y0N1i6/rm8r7piYGBw9elTnukqlQkZGBkJDQ9GnTx+j4iciIiLzs9hpzdOmTTOq3dNPP42wsDCd054zMzOxe/duLF68WDu5Nzs7GwEBAfUmFgUFBQCgd3UQUDMXZdKkSbh165a2LDk5GSKRCCkpKTx+noiIyIpY7LRmY7f+tbe3R1paGhITEzF27Fh4enri2LFjSE1N1RnekUgk8PHxqXfoplOnTnB3d8eAAQP0Xu/atSvee+89vPbaa7Czs4NCoYBEIsHx48c5HERERGRlRBpzbKDSQikUCu3+MGVlZXrX0hMR3c9u376tfeN95wIGatmE/L0w9DvUYkNCRERERObChIWIiIisHhMWIiIisnpMWIiIyGScDkl3ssTfByYsRERkNFvbmsWmtYfCEgH/O/fPnDvCM2EhIiKj2drawsXFRXuODZFGo0FpaSkcHBxgZ2dntn6N3oflxIkT6NGjh07Z1KlTUV1djX79+iEhIcHk4IiIyPp5eHhALpcjOzsb7u7ucHJyglgs5gacLYxGo0FlZSVKS0tRVlZW71l+xjJ6H5bo6Gj8+uuvdcorKytx5MgRbNmyBZ9//rnJAVoz7sNCRFRDpVLh2rVrKC8v55uWFs7BwQEeHh5wc3O7Zz1Dv0ONfsNSX55jZ2eHiIgIrF692tiuiYiombG3t0f79u21/8o29gBcat7EYrFZh4HuJDhhyczMRGZmpvbPubm5WL16dZ3EpbKyEpmZmTh//rz5oiQiomZBJBLVe4YbkSkEJyyurq6oqqrC+vXrsWvXLgDA2LFj9dYNDg7G+vXrzRMhERERtXhGzWFZuHAhfv31V/zwww91rjk7O6Nt27bmiM3qcQ4LERGRcRplDsvrr7+O8+fPw8/Pz5jmRERERAbhac0m4BsWIiIi4zTaac1r167FqlWrsGnTJgDAoUOHEBYWBhcXF4wePRoKhcLYromIiIh0GJ2w7Ny5E/v370fbtm1RUVGBuLg4ODg4YN++fRg2bBhmz55txjCJiIioJTM6YfHx8cGyZcswcOBA/PTTTyguLsa3336Lnj174sUXX+TGQURERGQ2Ricsd+5gd/jwYbi6uqJPnz7aMolEYlpkRERERP9ldMJy5xkRu3btQr9+/XSul5WVGR8VERER0R2M3pq/pKQEP/zwAy5duoSLFy9izpw5AGpm/c6YMQN9+/Y1W5BERETUshm9rLmsrAyTJ0/GsWPH8Oyzz2L27NnYsmUL3n//fdy+fRtBQUH47bffzB2vVeGyZiIiIuMY+h3KfVhMwISFiIjIOI22DwsAZGVlYerUqZg1axYAQK1W46233sKFCxdM6ZaIiIhIh9EJy/79+9G1a1f89NNPOHXqVE1nNjaYO3cuvv76a5w8edJcMRIREVELZ3TCMn/+fGzduhWXL19G9+7dteXOzs746quvsGrVKnPER0RERGR8wtKpUycMHjwYgO4SZwCwtbWFjY1Jo01EREREWkZnFQ4ODtr/1jdvNy8vz9iuiYiIiHQYnbAUFxfjr7/+AqD7hkWtVmPRokVwdHQ0PToiIiIimLBx3NSpUzFgwADEx8fj0qVLmDNnDnJycrB9+3aoVCocP37cnHESERFRC2bSPiwHDhzAyy+/jEuXLmnLQkNDsXbtWnTr1s0sAVoz7sNCRERknEbfOE6j0eDw4cOQy+Xw9/dvUVvyM2EhIiIyjqHfoYKHhKqrq3Ht2jVcu3YNYrEYXbp0AVAzf2XAgAEmhExERER0b4ISFg8PD1RVVSEuLg4PPfQQ+vTpY+m4iIiIiLQEJSwlJSXYv38/wsPDLR0PERERUR2CljV37tzZ4GRlzZo1RgVEREREdDdBCUvHjh0N7vi7774zuA0RERGRPoISFltbw7drKSoqMrgNERERkT6CMpHDhw9j1qxZEIvFgjpVKBT4888/TQqMiIiIqJagfVhsbGwgEon0nhlUp8P/1hOJRKiurjZLkNaK+7AQEREZxyL7sLRu3Rqvv/664BOYy8rKsGjRIkF1iYiIiBoiKGHp27cv5syZY1DH27dvNyogIiIiorsJemWiVqsN7tjDw8PgNkRERET6CHrDIpfLDe543LhxBrcBgBs3biAxMRFqtRre3t44d+4cxo8fj5iYGEHt3333XcTGxiI0NBQSiQS5ubnYu3cv2rZti9jYWLPdh4iIiBqPoEm3YrEYBw8eRL9+/SwajFqtxqBBgxASEoLk5GQAwOXLlxEWFoZ169YJSiZEIlGdsmHDhmH9+vXayT3muA/ASbdERETGsshpza1atYJarUZ8fDy6deuG3r17W2Sb/jVr1mDMmDGQyWQIDg7WlickJCA9PR0ymUxvQnInPz8/DB06FLm5ufD19UV8fDyGDh1q9vsATFiIiIiMZZFVQtevX0dVVRUKCwtRWFgoeD8WQ6WmpsLLy0sniQCAiIgIpKSkID09HX379r1nHwEBAVi6dKnF70NERESNR9g6ZdTsdtuuXTt07doVYWFhFgkmIyMDvr6+dcpryzIyMprVfYiIiMg8DN9z30IUCgUKCwshlUrrXJNIJACA/Pz8BvtRqVRYsGAB8vLyYG9vj3PnzmHSpEmIjo42632IiIio8VhNwnLz5k0A0DuGVTvGdf369Qb7yc3NRXx8PIKCggAAFy5cQPfu3bF69Wo888wzJt9HqVRCqVQCqEl+iIiIyPIEDwlZWu28GH276apUKgBAZWVlg/1cunRJm6wAQEhICCIiIjBlyhRUVVWZfJ/58+fD3d0d7u7u8PHxaTAeIiIiMp3VJCxt2rSpd+v/srIyAP8bsrkXfROC27Vrh/z8fBw8eNDk+0yfPh2lpaUoLS1Fbm5ug/EQERGR6awmYRGLxfD09NQ7HFObSPj7+9+zj0GDBkEqleL27ds65bWHMObn55t8HwcHB7i5uWl/iIiIyPKsJmEBgMjISL276spkMgBAz54979n+6NGjqKioqHOq9LVr1wD8LxEx9T5ERETUuIxKWBQKBf766y8cO3YMR44cwdmzZ80yAXX48OGQy+XIycnRKU9LS4Ofnx/69++vLcvLy6tzz5iYGBw9ehROTk7aMpVKhYyMDISGhqJPnz4G34eIiIianuCEpby8HElJSQgLC4O7uzuCg4PRp08fhIeHo2vXrnBzc0Pnzp0xZ84co5OXp59+GmFhYUhKStKWZWZmYvfu3Vi8eLF299ns7GwEBARoE5Ba06dPx6RJk3Dr1i1tWXJyMkQiEVJSUrTthd6HiIiIrIOgrflzc3Px6KOP4urVq+jWrRt8fX0hkUjg6uoKlUqFsrIylJWVQSaT4eLFi/Dz88Pu3bvh5+dncEAFBQVITEyESCSCp6cnjh07hokTJ2LkyJHaOkVFRejTpw+kUim2bdum0/7o0aP44osvYGdnB4VCAYlEglmzZtWZlyLkPg3h1vxERETGschZQi+++CK6dOmCSZMmNbhSRy6X48svv8Tff/+NTZs2GRB688OEhYiIyDiGfocKGhLy8PDAu+++K2hZcYcOHfCPf/wDrVq1EtI1ERERUYMEJSy2toZviNu6dWuD2xARERHpIyhhOX/+PNLT0wV3euTIEZw+fdrooIiIiIjuJOjVyXvvvYfHHnsMPXv2REREBHx9feHq6goXFxftrrHXr1+HXC7HwYMHsW/fPvzyyy8WDZyIiIhaDkEJS3h4ODIyMvDmm29iwYIFUKvVdZb+ajQa2NvbY9CgQUhLS8MjjzxikYCJiIio5RG0SuhOBQUFOH78OLKzs3Hz5k3tVvft2rXDgAEDtDN+WwKuEiIiIjKORZY1k35MWIiIiIxjkWXNRERERE3JYgnLk08+aamuiYiIqIWxWMJSUFBgqa6JiIiohRG0SiglJQVVVVWCO1UoFMjMzDQ6KCIiIqI7CUpYzp8/j7lz50IkEkHoHF2eeExERETmIihh+fjjj3Hjxg0olUo8//zzDdYvLy/Hs88+a3JwRERERIDAhAUAZsyYgUmTJuHRRx8VVL9bt25GB0VERER0J8GTbr29vSEWiwV3LJVKjQqIiIiI6G7cOM4E3DiOiIjIOE2+cZxGo0FlZaW5uyUiIqIWzOwJy9WrV/Hmm29i5cqV5u6aiIiIWiizJyzt27fHkiVLcPr0aXN3TURERC2UQQnLmjVr8Oabb2Lbtm33rPf333/j4sWLJgVGREREVEtwwjJ58mSMHTsWixcvxlNPPYXly5drr+3evRtvv/02nnjiCfj6+iIwMBBubm4WCZiIiIhaHkGrhA4cOICBAweiR48eCAwMxJ9//onLly8jNzcXSUlJWLBggc4OuK1bt8bhw4cRHBxs0eCbGlcJERERGcfQ71BBCcu4ceMglUrxzjvvaMtmzpyJ/Px8rFmzBhMmTEBoaChEIhEkEgmioqLg4eFh4kexfkxYiIiIjGORhCU8PBz79u3T2TiuoqIC3t7e2Lx5MyIjI00Mu3liwkJERGQci+zD4ujoWGeXWycnJ8TGxrbYZIWIiIgaj6CExdnZWW/5gw8+WG+bDz74wLiIiIiIiO4iKGGpb9RIJBLV22bHjh3GRURERER0F0GnNe/btw9vvPEGbGx085v09HQUFRXVqV9eXo6TJ0+aJUAiIiIiQZNu705UBHUsEqG6utqooJoLTrolIiIyjqHfoYLesLi6umLDhg1wdHQUFERFRQVGjRolqC4RERFRQwQlLD169MDQoUMN6rhHjx5GBURERER0N0FjPcas+JkxY4bBbYiIiIj0EZSwREVFGdxxSEiIwW2IiIiI9DF8Nq1AEyZMsFTXRERE1MJYJGEpLCzksmYiIiIyG7MlLGq1Gtu3b8fo0aPh7++P4uJic3VNRERELZygVUL3kpmZiVWrViE1NRUFBQXQaDSClz8TERERCWFUwlJQUIC1a9di1apVOH36tHbr/v79++PVV1/Fs88+i/DwcLMGSkRERC2X4IRFqVTip59+wqpVq/Cf//wH1dXV0Gg0CAwMREJCAg4dOoRdu3Zp67/44osWCZiIiIhaHkEJy+TJk5GSkoJbt25Bo9HAw8MDI0eOxAsvvIB+/foBAOLj43XaTJs2zfzREhERUYskKGHx9vaGm5sbKioqMGfOHCQmJkIsFls6NiIiIiIAAlcJffTRR8jJycGOHTsgk8kQGRmJhQsX4sqVK5aOj4iIiMiwSbeRkZGIjIxERUUFfvrpJ7z66qtQqVQYNWoUlEqlTt3vv/8eL7/8slmDJSIiopZJpKld4mOk/Px8rF27FqmpqQgODsaECRPQq1cvBAUF4dq1a0b1eePGDSQmJkKtVsPb2xvnzp3D+PHjERMTI6j92bNnkZSUhNLSUly5cgXt27fH+++/j4iICJ167777LmJjYxEaGgqJRILc3Fzs3bsXbdu2RWxsbIP3MfRobCIiIqph6HeoyQnLnU6fPo1Vq1Zh5cqVKC4uRnV1tcF9qNVqDBo0CCEhIUhOTgYAXL58GWFhYVi3bl2DScvZs2cxdepUpKamwsPDA1VVVXjjjTewdOlSrFixAi+99JK2rkgkqtN+2LBhWL9+vfaXeC9MWIiIiIzTpAlLrcuXLyM0NBQKhcLgtmvWrMGYMWMgk8kQHBysLU9ISEB6ejpkMpneRKPW8OHDsWDBAp3DFysqKtC+fXuoVCrI5XI88MADAAA/Pz8MHToUubm58PX1RXx8PIYOHSo4ViYsRERExjH0O9QiZwn5+fmhd+/eRrVNTU2Fl5eXTrICABEREcjKykJ6evo92+/evRtDhgzRGY5ycnJCREQEysrKcOjQIW15QEAAli5dil9++QXJyckGJStERETUeCx2WvPWrVuNapeRkQFfX9865bVlGRkZ92zv7++PgoKCOm93HBwcAADl5eVGxUVERERNx6BVQkqlEleuXIFcLscjjzwCW9v6m0skEoODUSgUKCwshFQqrbe//Pz8e/Zx5MgR3Lp1C97e3jrlx44dg42NjXajOwBQqVRYsGAB8vLyYG9vj3PnzmHSpEmIjo6ut3+lUqldEWXMkBcREREZTlDC0qtXL8jlcgQEBGDYsGGQSqX3nEdirJs3bwKA3nGs2nGu69ev37MPFxeXOu23bt2KS5cu4d1330X79u215bm5uYiPj0dQUBAA4MKFC+jevTtWr16NZ555Rm//8+fPx5w5c4R/KCIiIjKZoEm3NjY2+PTTT/Huu+9aNJhr167By8sLMTEx+OWXX3SuHTp0COHh4ZgwYQKWLl0quM/y8nL06tULbdq0QVpaGuzt7bXXqqur6+zYGxUVhdOnT0Mul+t9g3T3GxYfHx8AnHRLRERkCItMuvXw8EBiYqLp0TWgTZs2sLHRH1JZWRkAw4eaJk2aBB8fH2zfvl0nWQGg93iBdu3aIT8/HwcPHtTbn4ODA9zc3LQ/REREZHmCEpbOnTvrDAHt27cPI0aMgFQqRadOndC1a1c8//zzJgcjFovh6empd9inNmHx9/cX3N9HH30ElUqFX3/9tc6+KoMGDYJUKsXt27d1ymv3jmlorgwRERE1HkFzWO5+kzBw4EAMHDgQZ86cQY8ePZCVlQU/Pz+zBBQZGYkDBw7UKZfJZACAnj17Cupn6dKlKCgowNq1a7VvbU6ePImqqir06tULR48eRevWrXH3iFjtcmhDEiMiIiKyLEFvWOqbYNulSxf0799fb7IidBv9uw0fPhxyuRw5OTk65WlpafDz80P//v21ZXl5eXpX6vz888+QyWRITk7WGWL67bfftPNSYmJicPToUTg5OWmvq1QqZGRkIDQ0FH369DEqfiIiIjI/g5Y16+Ph4aG3vLi42Kj+nn76aYSFhSEpKUm7NX9mZiZ2796NLVu2aJOn7OxsSKVSBAYG4uzZs9r2hw8fxoQJEzBkyBC88MIL2nKNRoMDBw5gypQpAIDp06dj0qRJWLFihXZeTHJyMkQiEVJSUiyyCoqIiIiMIyhhOXHiBFasWKF31UxOTg5WrVqlU3b79m2cPHnSqIDs7e2RlpaGxMREjB07Fp6enjh27BhSU1N1DiSUSCTw8fGpM3Tz5JNPori4GGvXrq3Td2BgIBwdHQEAXbt2xXvvvYfXXnsNdnZ2UCgUkEgkOH78OIeDiIiIrIzgZc31vXHQaDT1XjPm8MPmhGcJERERGcfQ71DBQ0IjR47Uvp1oSEVFBTZs2CC0ayIiIqJ7EpSwdOvWDampqQZ1XLuqh4iIiMhUglYJDR482OCOjWlDREREpI+gOSxFRUX1rgYyZ5vmhnNYiIiIjGORrfkTEhIMDuTOJcVEREREphCUsBgzH4VzWIiIiMhcBE26vXz5Mnx9feHg4CCoU6VSybN4iIiIyGwEL2vOy8szqGPuFEtERETmIihhadWqFQ4ePKhz7s69lJeXIyIiwqTAiIiIiGoJSli6du2Kzp07G9Rx165djQqIiIiI6G6CJt1++OGHBnf8wQcfGNyGiIiISB9B+7CQftyHhYiIyDgW2YclKioKnTp10v4EBgbirbfe0l6/efMmXn75ZUyZMgVZWVkmhE9ERERUl6A3LKWlpRgzZgwOHDiAt99+G+PGjYO3t3edesXFxZg5cyaio6MRGxtrkYCtCd+wEBERGccipzXb2trC3t4ex48fh7+/f7312rRpgyVLluD1119Hly5d7lmXiIiISChBQ0KLFi3C7NmzBScgc+bMwaJFi0yJi4iIiEhLUMLy559/okuXLoI79fDwQEFBgdFBEREREd1JUMJy69YtgzsuKyszuA0RERGRPoISlqKiIoM7Li4uNrgNERERkT6CEhY3NzdkZGQI7vSPP/6Am5ub0UERERER3UlQwvLMM8/g//7v/6BSqRqsq1QqMXXqVIwaNcrk4IiIiIgAgQnLSy+9hJKSEkRHR+Pq1av11rty5Qqio6Nx48YNjB071mxBEhERUcsmeB+WDRs2ICIiAp06dUJUVBT69Omj3TwuPz8f6enp2LVrF5ycnHDw4EGIxWKLBk5EREQth0FnCZ0+fRrPPvssZDIZRCKRzjWNRgOpVIr169cjLCzM7IFaI+50S0REZByL7HRb66GHHsLZs2exdu1abNmyBRcvXoRGo0FISAji4uIwevRovlkhIiIis+NpzSbgGxYiIiLjWOS0ZiIiIqKmxISFiIiIrB4TFiIiIrJ6TFiIiIjI6jFhISIiIqvHhIWIiIisHhMWIiIisnpMWIiIiMjqMWEhIiIiq8eEhYiIiKweExYiIiKyekxYiIiIyOoxYSEiIiKrx4SFiIiIrB4TFiIiIrJ6TFiIiIjI6tk2dQB3u3HjBhITE6FWq+Ht7Y1z585h/PjxiImJMWt7U+9DREREjceqEha1Wo24uDiEhIRg2bJlAIDLly8jLCwM69atazCZENre1PsQERFR4xJpNBpNUwdRa82aNRgzZgxkMhmCg4O15QkJCUhPT4dMJoNIJDK5van3qaVQKODq6goAKCsrg4uLizEfm4iIqMUx9DvUquawpKamwsvLSyeJAICIiAhkZWUhPT3dLO1NvQ8RERE1LqsaEsrIyECHDh3qlPv6+mqv9+3b1+T2pt6n1p0vpxQKRYP1iYiIqMad35tCBnusJmFRKBQoLCyEVCqtc00ikQAA8vPzTW5v6n2USiWUSiUAoLCwUFvu5eVVbxsiIiKqX3l5uXZ4qD5WMyR08+ZNANA7hlX7Ia5fv25ye1PvM3/+fLi7u8Pd3R1BQUH11iMiIiLzsZo3LGKxGABgY1M3h1KpVACAyspKk9ubep/p06fjrbfeAlCz2qi4uBj29vZ4/PHHcfz48Xrb3alnz544duzYPevcvHkTPj4+yM3NhZubm6B+7ydCfkeNrTFjMve9zNGfsX0Y2s6Q+nyWhGnJz5Ml7mNqn6a0b8rnydzPkkajQXl5OQDAw8OjwfpWk7C0adNGbxIB1MweBv43ZGNKe1Pv4+DgAAcHB+2fH3jgAQA1CZPQVUI2NjYN1q2urgZQ8yaoJa4+EvI7amyNGZO572WO/oztw9B2htTnsyRMS36eLHEfU/s0pX1TPk+WeJYaGga6k9UMCYnFYnh6euodjqlNJPz9/U1ub+p96vP6669bpG5LZY2/o8aMydz3Mkd/xvZhaDs+S+Znjb+nxorJEvcxtU9T2rfo50ljRUaPHq3p0KFDnfL58+drAGgOHjxolvam3qcxlJaWagBoSktLmzoUomaNzxKReTT1s2Q1b1gAYPjw4ZDL5cjJydEpT0tLg5+fH/r3768ty8vLq7OUWGh7Q+7TVBwcHDBr1iyd4SciMhyfJSLzaOpnyap2ulWpVHj44YcRHh6O5ORkAEBmZiYefvhhbNmyBbGxsQCA7OxsSKVSBAYG4uzZswa3F1qPiIiIrINVJSwAUFBQgMTERIhEInh6euLYsWOYOHEiRo4cqa1TVFSEPn36QCqVYtu2bQa3N6QeERERNT2rS1iIiIiI7mZVc1iIiIiI9GHCQkRERFaPCct96PLly9odeR9//HGkpaU1dUhEzVZ5eTkmTpyIffv2NXUoRFbv5s2bmDx5Mr766itMnDjRrN8/VrPTLZmHWq3GZ599hq+//hq2trZIS0tDbGwsTpw4gc6dOzd1eETNypIlS/D3339jw4YNeO6555o6HCKr984776Bfv3545ZVXUFZWhs6dO+PkyZOCtt5vCN+w3GcuXryIP/74Q3vi9ODBg9G2bVusXr26iSMjan4mT56MBQsW3PO4DiKqUV5ejtWrV+PJJ58EULPt/sMPP4ytW7eapX8mLPcZiUSCq1evIi8vT1vWtm1blJSUNGFURER0v7tw4QKAmu+cWh07dsSBAwfM0j8TlvuMj48P8vPz0bt3bwBARUUFZDIZwsPDmzgyIiK6nxUUFMDJyUmnzMXFRecf0KbgHBYLqq6uxpAhQ7By5Up06NChzvUbN24gMTERarUa3t7eOHfuHMaPH4+YmBizxfD9999DKpXi+eefN1ufRI3NGp4lovuZOZ6xkpIS2Nvb67Szt7fXHixsKiYsFnLq1ClMmzYNe/bs0R7JfSe1Wo24uDiEhIRg2bJlAGpW94SFhWHdunVm+X+0V69exYoVK/Dzzz/DxoYv06h5soZnieh+Zq5nzNXVtU7b8vJytGrVyixxMmExM5lMhmnTpsHd3b1OpnmnlJQU/P7779r/8QHAz88Pw4cPx9SpUxEdHQ2RSAQAWLZsmc6ZSXcTi8VISkqCo6OjtkypVGLq1KnYuHEjfHx8zPDJiBqXtTxLRPcrcz9j3t7euHXrlk5bhUIBLy8v8wTcJGdEtxCzZs3SANBkZ2fXuRYdHa3x8vKqU/7NN99oAGiOHDli0r3fe+89zZ9//qn988qVK03qj6gpNeWzpNFoNH5+fpo9e/aY3A+RtTLHM6ZUKjUuLi6agoICbZ1BgwZpvv76a7PEyHGCJpKRkQFfX9865bVlGRkZRve9ZMkSuLq64u+//8aOHTuwadMm3Lx50+j+iKyZJZ8lIhL+jNnb2+Opp57Cjz/+CKDmoOIzZ85g1KhRZomDQ0JNQKFQoLCwEFKptM612v0eavdRMdSFCxcwdepUVFZW6pTffao10f3Aks8SACxfvhy7du2CXC7HtGnTEBERgU8//RTOzs5G90nUnBj6jH355ZeYOnUqqqqqcObMGaSkpMDT09MssTBhaQK1bztcXFzqXKudtHT9+nWj+g4JCYFKpTI+OKJmxJLPEgCMHz8e48ePN7o9UXNn6DPm6emJlJQUi8TCIaEmIBaLAUDvyp3aZOPuNyREVBefJSLLsqZnjAlLE2jTpk29y4xr16tzK3CihvFZIrIsa3rGmLA0AbFYDE9PT72vqmv/Avj7+zdyVETND58lIsuypmeMCUsTiYyMhFwur1Muk8kAAD179mzskIiaJT5LRJZlLc8YE5YmMnz4cMjlcuTk5OiUp6Wlwc/PD/3792+iyIiaFz5LRJZlLc8YExYLqqioAFCzLOxuTz/9NMLCwpCUlKQty8zMxO7du7F48WLtzpxExGeJyNKawzMm0mg0mka5UwtRXFyMhIQEFBQU4NSpU1Cr1ZBIJOjWrRsiIiIwb948bd2CggIkJiZCJBLB09MTx44dw8SJEzFy5Mgm/ARE1oHPEpFlNbdnjAkLERERWT0OCREREZHVY8JCREREVo8JCxEREVk9JixERERk9ZiwEBERkdVjwkJERERWjwkLERERWT0mLERERGT1mLAQERGR1WPCQkTNxs6dOzFw4EBIJBKIRCKIRCL4+/tj8ODB+OWXX+rUP3nyJCIjI9GmTRuIRCI4ODhg6NChiI2NxeDBgzFgwAA899xz2LZtWxN8GiIyBLfmJ6JmZ8eOHRg2bBh69+6N9PT0BuufP38eUqkUTzzxBLZv364t12g0SElJwYsvvoiYmBhs2LABDg4OlgydiIzENyxE1Ow4OjoCAJydnQ2qLxaLdcpFIhESEhIwfPhwbN26FZ999pl5AyUis2HCQkQtXmBgIAAgIyOjiSMhovowYSGiFu/8+fMAgKioqCaOhIjqY9vUARARNZXKykosW7YMu3btwqxZszBlypSmDomI6sGEhYhaDJlMhtmzZwMA5HI5tm7dit69e0Mul8PT07NpgyOie2LCQkQtxoMPPqhNWAAgMzMTgwcPxtSpU7FmzRrY2HCUnMha8ekkovvSqVOnoFAo7lmnW7dumD59OlJTU7FixYpGioyIjMGEhYjuS998842geqGhoQDAzeOIrBwTFiK6L8lkMri4uDRYTyQSAQDOnj1r6ZCIyARMWIjovnPmzBlcu3ZNUF2JRAIAuHTpEsrLywEA165d0/43EVkHJixE1Ozcvn0bAKBWq+tck8lkeO655+Dj41Onvr4kpHfv3ggMDIRarcaRI0cAAEuWLEFRUZElQiciI/EsISJqNnbu3Il58+bh+PHjKCsrg52dHR577DHY29ujqqoKeXl5OH36NDQaDV555RVMmTIFb7/9Nk6ePImSkhIAgFQqRb9+/XQm2ebm5uKTTz7BxYsX0aNHD3h6eiIxMbGpPiYR6cGEhYiIiKweh4SIiIjI6jFhISIiIqvHhIWIiIisHhMWIiIisnpMWIiIiMjqMWEhIiIiq8eEhYiIiKweExYiIiKyekxYiIiIyOoxYSEiIiKrx4SFiIiIrB4TFiIiIrJ6TFiIiIjI6v0/2ZsOsVnOCkYAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def plot_accuracies(accuracy_res, fname, colormap=\"Set1\", dataset_readable=\"\"):\n",
    "    fig, ax = plt.subplots(1, 1, figsize=(6, 3))\n",
    "\n",
    "    lrs = sorted([lr for lr in accuracy_res.keys()])\n",
    "    methods = sorted([m for m in accuracy_res[lrs[0]].keys()])\n",
    "\n",
    "    # print(lrs)\n",
    "    # print(methods)\n",
    "\n",
    "    colors = np.linspace(0, 1, 9)\n",
    "    palette = cm.get_cmap(colormap)(colors)\n",
    "    pastel = 0.3\n",
    "    palette = (1 - pastel) * palette + pastel * np.ones((9, 4))\n",
    "\n",
    "    LABELS = {\n",
    "        \"lfp-epsilon\": r\"LFP-$\\varepsilon$\",\n",
    "        \"lfp-zplus-zminus\": r\"LFP-$z^+z^-$\",\n",
    "        \"vanilla-gradient\": r\"Grad\",\n",
    "    }\n",
    "\n",
    "    maxacclrs = []\n",
    "\n",
    "    for m, method in enumerate(methods):\n",
    "        plot_means = []\n",
    "        plot_stds = []\n",
    "        for lr in lrs:\n",
    "            ar = [accuracy_res[lr][method][seed] for seed in accuracy_res[lr][method].keys()]\n",
    "            plot_means.append(np.mean(ar))\n",
    "            plot_stds.append(np.std(ar))\n",
    "\n",
    "            # print(method, lr, np.mean(ar))\n",
    "\n",
    "        plot_means = np.array(plot_means)\n",
    "        plot_stds = np.array(plot_stds)\n",
    "\n",
    "        maxx = lrs[np.argmax(plot_means)]\n",
    "        maxy = np.max(plot_means)\n",
    "        print(f\"MAX: {method} - {maxx} - {maxy}\")\n",
    "        maxacclrs.append((method, maxx, maxy))\n",
    "\n",
    "        ax.plot(lrs, plot_means, color=palette[m], label=LABELS[method], linewidth=3)\n",
    "        ax.plot(maxx, maxy, color=palette[m], marker=\"d\", markersize=10, markeredgecolor=(0.1, 0.1, 0.1, 1))\n",
    "        ax.fill_between(lrs, plot_means + plot_stds, plot_means - plot_stds, color=palette[m], alpha=0.2)\n",
    "\n",
    "    ax.legend()\n",
    "    ax.set_xscale(\"log\")\n",
    "    # ax.set_xlim([0, 10e-2])\n",
    "    ax.set_ylabel(f\"{dataset_readable} Test Acc.\")\n",
    "    ax.set_xlabel(\"LR\")\n",
    "    ax.set_ylim([0, 1.01])\n",
    "    plt.show()\n",
    "    fig.savefig(fname)\n",
    "\n",
    "    return maxacclrs\n",
    "\n",
    "\n",
    "maxacclrs2 = {}\n",
    "for name, val in accuracies_basemodel.items():\n",
    "    print(name)\n",
    "    fname = os.path.join(\n",
    "        savepath,\n",
    "        f\"{dataset_name_base}-accuracies_transfermodel-{name}-{investigated_ep_lfp}-{investigated_ep_grad}.svg\",\n",
    "    )\n",
    "    maxacclrs2[name] = plot_accuracies(val, fname, dataset_readable=\"ImageNet\" if name == \"imagenet\" else \"CIFAR10\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Zennit Patch for Parameter Relevance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:20.932916Z",
     "iopub.status.busy": "2024-08-21T10:22:20.932713Z",
     "iopub.status.idle": "2024-08-21T10:22:20.940449Z",
     "shell.execute_reply": "2024-08-21T10:22:20.939930Z"
    }
   },
   "outputs": [],
   "source": [
    "def new_backward(self, module, grad_input, grad_output):\n",
    "    \"\"\"Backward hook to compute LRP based on the class attributes.\"\"\"\n",
    "\n",
    "    original_input = self.stored_tensors[\"input\"][0].clone()\n",
    "    param_keys = [name for name, _ in module.named_parameters(recurse=False)]\n",
    "\n",
    "    inputs = []\n",
    "    outputs = []\n",
    "    params = {k: [] for k in param_keys}\n",
    "\n",
    "    module.param_relevances = {}\n",
    "\n",
    "    for in_mod, param_mod, out_mod in zip(self.input_modifiers, self.param_modifiers, self.output_modifiers):\n",
    "        input = in_mod(original_input).requires_grad_()\n",
    "        with zcore.ParamMod.ensure(param_mod)(module) as modified, torch.autograd.enable_grad():\n",
    "            output = modified.forward(input)\n",
    "            output = out_mod(output)\n",
    "\n",
    "            for key in param_keys:\n",
    "                if getattr(modified, key) is not None:\n",
    "                    params[key].append(getattr(modified, key))\n",
    "\n",
    "        inputs.append(input)\n",
    "        outputs.append(output)\n",
    "    grad_outputs = self.gradient_mapper(grad_output[0], outputs)\n",
    "    gradients = torch.autograd.grad(\n",
    "        outputs,\n",
    "        inputs,\n",
    "        grad_outputs=grad_outputs,\n",
    "        retain_graph=True,\n",
    "        create_graph=False,  # grad_output[0].requires_grad\n",
    "    )\n",
    "    relevance = self.reducer(inputs, gradients)\n",
    "\n",
    "    for key in param_keys:\n",
    "        param_gradients = torch.autograd.grad(\n",
    "            outputs,\n",
    "            params[key],\n",
    "            grad_outputs=self.gradient_mapper(grad_output[0], outputs),\n",
    "            retain_graph=True,\n",
    "            create_graph=False,  # grad_output[0].requires_grad\n",
    "        )\n",
    "\n",
    "        param_relevance = self.reducer(params[key], param_gradients)\n",
    "        module.param_relevances[key] = param_relevance\n",
    "\n",
    "    return tuple(relevance if original.shape == relevance.shape else None for original in grad_input)\n",
    "\n",
    "\n",
    "zcore.BasicHook.backward = new_backward"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Pruning Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:20.943165Z",
     "iopub.status.busy": "2024-08-21T10:22:20.942960Z",
     "iopub.status.idle": "2024-08-21T10:22:20.948773Z",
     "shell.execute_reply": "2024-08-21T10:22:20.948218Z"
    },
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "os.environ[\"CUDA_LAUNCH_BLOCKING\"] = \"1\"\n",
    "recompute_pruning = False\n",
    "num_weights = 1000\n",
    "\n",
    "relevance_loader = dataloaders.get_dataloader(\n",
    "    dataset_name=dataset_name_base,\n",
    "    dataset=test_dataset_base,\n",
    "    batch_size=128,\n",
    "    shuffle=True,\n",
    ")\n",
    "\n",
    "\n",
    "class EpsilonComp(zcomp.LayerMapComposite):\n",
    "    def __init__(self, canonizers=None):\n",
    "        layer_map = zcomp.layer_map_base(stabilizer=1e-6) + [\n",
    "            (zcomp.Convolution, zcomp.Epsilon()),\n",
    "            (torch.nn.Linear, zcomp.Epsilon()),\n",
    "        ]\n",
    "        super().__init__(layer_map, canonizers=canonizers)\n",
    "\n",
    "\n",
    "class ZplusComp(zcomp.LayerMapComposite):\n",
    "    def __init__(self, canonizers=None):\n",
    "        layer_map = zcomp.layer_map_base(stabilizer=1e-6) + [\n",
    "            (zcomp.Convolution, zcomp.ZPlus()),\n",
    "            (torch.nn.Linear, zcomp.ZPlus()),\n",
    "        ]\n",
    "        super().__init__(layer_map, canonizers=canonizers)\n",
    "\n",
    "\n",
    "composite = EpsilonComp(canonizers=[zcanon.SequentialMergeBatchNorm()])\n",
    "# composite = ZplusComp(canonizers=[zcanon.SequentialMergeBatchNorm()])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Weight Distribution across layers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:20.952296Z",
     "iopub.status.busy": "2024-08-21T10:22:20.952013Z",
     "iopub.status.idle": "2024-08-21T10:22:22.004847Z",
     "shell.execute_reply": "2024-08-21T10:22:22.004190Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_736656/3535116526.py:71: MatplotlibDeprecationWarning: The get_cmap function was deprecated in Matplotlib 3.7 and will be removed two minor releases later. Use ``matplotlib.colormaps[name]`` or ``matplotlib.colormaps.get_cmap(obj)`` instead.\n",
      "  palette = cm.get_cmap(colormap)(colors)\n"
     ]
    },
    {
     "data": {
      "image/png": "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4Ndff0VmZiZKSkpw5coVrF27Ft9//73FeefOncP48eMxZMgQdO7cGUOGDMGBAwccipmIiIiIiIiornN4m8NWrVqhf//+AACZTGZZqVJpsTOAvQRBwMiRI9GmTRt8/vnnAIDk5GR06NABmzdvxpAhQ6qsY8mSJViyZIlF2aBBg7BlyxbT43PnzmHGjBnYtGkTQkJCoNfr8fzzzyMuLg5r1qzBlClTqh07ERERERERUV3m8AgCb29v031byxikpqZWu86NGzdi//79mDVrlqmsRYsWGDFiBGbMmGHzecpr3rw5nn76aQwZMgTPPPMMfvzxR+zcuRP+/v6mc+bNm4ePP/4YISEhAIwJjQ8++ACNGjXC9OnTkZubW+3Yq5KWloaZM2di9erVTq+biIiIiIiIqLzq9kMdThBkZWXh8uXLACxHEAiCgA8++KDCbQIrs2nTJoSFhaF169YW5bGxsbh48SKOHj1aZR0tW7bEqlWr8P3332PlypUYOHCg1Tl79uxBfHw8bt26ZSpTq9WIjY1FQUEBDh8+XO3YK1LWIC1btsQHH3yABQsWoKSkxGn1ExEREREREZlztB/q8BSDGTNm4P7778fo0aNx6dIlvPnmm7h27Rp++OEHaLVa/P7779Wu89ixY4iMjLQqj4iIMB3v0aOHoyGbREVFITExERqNxqK8bFREYWFhjZ8jLS0N77//Pj777DMUFxebyrOzs3H8+HH07t27xs9BREREREREVKam/VCHEwRdunTB119/jSeffBKXLl3Crl27AADt27fHhg0b0Lx582rVp9FokJGRgXbt2lkdCwgIAGB8sVXRarV4//33kZqaCpVKhfPnzyMhIQGDBw82nXPkyBHk5+cjPDzc4toTJ05ALpejZ8+e1YodME6zKCwsRHp6OlasWIF//etfFg2iVquRkJCA2bNnWz0vERERERERUXU5ux/qcIIAAPr06YPExET89ttvSElJQVRUlMPf8Ofl5QEA/Pz8rI6VrR+Qk5NTZT03b97E6NGjERMTAwC4cOECunTpgi+++AKPPPKI6TnKP893332HS5cu4ZVXXkGzZs0qrH/58uVYvny5VblOp7OYslCGiQEiIiIiIiJyhStXriA6Otqq3NF+aI0SBIBx/YH777/fqnzjxo0YP3683fUoFAoAsLn7gVarBWDshFfl0qVLproAoE2bNoiN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ERERUaUSExPtWk+gbOqAM6xcuRL5+fkWZQEBAQCA7du3Y/DgwVAqXTKj36UcinjcuHH4888/nR0LERERERERkd3++OMP3Lp1q9aft02bNhUeS0pKQt++fW0e2717N/r37++qsGrMoQSBSqXC4sWLKz3n3Llz6NChg0NBERERERERkbUig8HdIdjkqriKi4sBwGq+P2AcOfDYY48hIiLC5jVlt9V5Hmespffwww/jySefxNtvv43u3bvDx8cHV69exdq1a9GrV68a1+9KLhvzMGXKFBw7dsxV1RMREREREXmcvuXmvddXP/30ExYvXozff/8dAHDkyBHTtoF6vR6pqak4e/YsRFFEjx49bF7zv//9DzExMWjZsiVmz56NAQMGWD3PqVOn8PLLL+PUqVOm52nfvj06d+6MTZs2ORR7p06d8MEHH+DNN9/EsWPHoFar0b17d8ybN69+JAhefvll/Pnnn9i6dStUKhUOHz6MiRMnVni+Xq/HjRs3nBYkEREREREReY6BAwdi4MCBLr+mS5cu2L17d7WusccDDzzgknpdza4EwcaNG5GRkYH09HRERkZCrVbj+vXrGD58uGkhBnNarRZff/2104MlIiIiIiLyNGq1GklJSe4Ow25qtdrdIZCD7EoQ7N+/H5mZmYiMjAQABAUF4cEHH6w0CXD9+nXnREhEREREROTBZDIZfH193R0GeQC7EgR33XUX7rrrLtPjyMhIrFmzptJrPvroo5pFRkRERERERES1Ru7QRXI5mjVrVuk5X375pUMBEREREREREVHtq/EuBllZWdBoNBZlOp0OX3/9NZYsWVLT6omIiIiIiIioFjicIDh27BjGjRuH5ORkZ8ZDRERERERERG7gcILg5ZdfxtChQ9GxY0eoVCqLY1qtFnPnzq1xcERERERERERUOxxOEHTr1g3Lly+v8PhXX33laNVEREREREREVMscWqQQQJXbbPz888+OVk1EREREREREtczhBEHr1q1x9OjRCo8PGDDA0aqJiIiIiIiIqJY5PMWgZcuW+Oc//4mAgADce++98PHxMR3T6XQ4ceKEUwIkIiIiIiIiItdzOEEwfPhw5OXlAQA+//xzq+MymczxqIiIiIiIiAgAIIoiioqK3B2G3dRqNfuDdZTDCYLGjRvjq6++wl133WV1TKvV4qGHHqpRYERERERERAQUFRWh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ly9fRnBwsGl3gx9++AHr16/HgQMHsH//frf8+zibwwmCLVu24B//+Afi4+Nx7tw501SCtLQ0ZGVl4YcffnBWjEREREREROShfHx8MGXKFEyZMqXCc/71r38BMK6TV1VnXa1Wm0YAlHflyhWrsjZt2mDp0qW4++67LbZfLCgosCP6usXhBMF//vMf/P7774iIiMC8efOwePFi07Fff/0VGzZswN/+9jenBElEREREROSp1Gq109bHqA1qtdrdIZCDHE4Q3HXXXYiIiAAAGAwGZGRkoHHjxgCABx54oN4MsSAiIiIiInInmUzGdSyoVsgdvVCpVEKv10On0+H+++/HokWLLI47spokEREREREREblHjRYpvOuuu9CkSRPs3bsXf//731FSUoJhw4bh1KlTOHHihLNiJCIiIiIiIokwGAzuDqFK5msFkP0cThA8//zzOHr0KKKjo6FSqbBy5Uo88sgjWLVqFQDjDgdERERERERUv/zxxx/uDqFKnTt3dncIdZLDCYLw8HD8/PPPpsdDhgzBiRMnsGvXLsTExGDIkCFOCZCIiIiIiIiIXK9GUwzKa9++Pdq3b+/MKomIiIiIiEhC7r77bqfVJQgCzp8/D8DYn5TLHV4mj5zArn/9SZMmVbviyZMnV/saIiIiIiIiTyWKortDsItCoXDaj3lCQC6XO63e+sAdvw92JQh+//33alfsyDVERERERESeRqk0DuwuKSlxcyQkJTqdDkDtLrho1xSDP//8E/fffz98fHzsqrS4uBh//vlnjQIjIiIiIiLyBEqlEn5+fsjOzkZAQEC9+QacHCeKIm7fvg1vb294eXnV2vPavQbBkSNHqlWxTCardjBERERERESeKCQkBCkpKbhy5QoaNGgAtVoNhUJR7/tVBoPBNJS+uLhYcsmR2o5PFEXodDrcvn0bBQUFiIiIcOnzlWdXgmDx4sVITU3F4MGD0bNnzyrPLyoqQpcuXWoaGxERERERkUfw9fVFy5YtcevWLeTk5CAzM9PdIdUKQRCQkZEBAPDy8pLcIoXuis/b2xsREREIDAyslecrY1eCYO7cuRAEATt27MD777+PZs2a4fHHH0fDhg1tnt+gQQN07NjRmXESERERERHVayqVCs2aNTN9iywIgrtDcrmioiI8+eSTAICffvoJarXazRFZckd8CoWiVqcVmLN7ioFcLsew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eXnIzc01PS4uLkZKSopVokCn0+H06dM4e/ZstYMZNWoUOnTogEWLFpk6+KdPn8aePXuwbds205SAK1euoF27doiOjsa5c+dM1//22294+umnER8fj4kTJ5rKRVHEwYMHMX36dNPzDBgwAO+8847peZKSkrBv3z6sWLECDRs2rHbsRERERERERHWZ3QmCY8eOYd26ddixY4cpUVDRmgBeXl5Yv359tYNRqVTYvXs3Zs+ejSeeeAKhoaE4ceIENm3ahKFDh5rOCwgIQNOmTa2ef9iwYcjKysKGDRus6o6OjoaPj4/p8TfffINXX30Vw4YNQ4MGDZCVlYUtW7Zg8ODB1Y6biIiIiIiIqK6zO0HQv39/9O/fH4WFhZg6dSrOnz9vc7E+X19fdO/evdqLFJYJCwurMrkQEhKCy5cvW5VnZmba/Tx+fn746KOPqh0fERERERERUX1U7TUIfH198c9//hNTpkypcCtAIiIiIiIiIqpb5I5cFBYWhi+//LLSc6rzbT4RERERERERuZdDCQIACA4OrvT4I4884mjVRERERERERFTLHN7mEAAOHDiAo0ePQqPRWJTrdDqcOHGiRoERERERERERUe1xOEGwZMkSzJkzp8LjZVsSEhEREREREZH0OTzF4KeffsLx48dRUlICQRAsfkpKStCmTRtnxklERERERERELuTwCIL77rsPXbt2tXnMy8sLf//73x0OioiIiIiIiIhql8MjCKqaQtC6dWtHqyYiIiIiIiKiWuZwgmDy5Ml49dVXkZeXZ/P4a6+95nBQRERERERERFS77JpiMG7cOGRkZFiVZ2Rk4IMPPkCrVq3g4+NjKtfpdDh//rzzoiQiIiIiIiIil7IrQXDu3DkUFBSgZcuWFuUhISEICQmxOl+n03EXAyIiIiIiIqI6xK4EQVBQEPbs2YPQ0FC7K+7evbvDQRERERERERFR7bJrDYL58+dXKzkAAIsXL3YoICIiIiIiIiKqfXYlCPr3729Vtnr1anz//fcVXvPQQw/h4sWL2Lp1K7KyshyPkIiIiIiIiIhczuFdDL744gsolRXPUPjqq6/QuXNnLFq0CL169apwtwMiIiIiIiIicj+HEwTdunVDx44dMX/+fLz++uu4ceOGxfG5c+fi3XffxbFjx7Bs2TKsWLGixsESERERERERkWvYtUihLW3btkWbNm1QWFgI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2x4iqov43kVE5Lns6vFnZGQgODjY7kq9vLyg0WgcDoqIqo8f6Iiqxv8n0sM2ISIikg67EgS5ubnVrjgvL6/a11DdwQ90RERERERE9YvdIwgEQYBcLrerUoPBgIyMjBoFRkREREREJFX8wozqI7t6/G3atLHY5rAq33zzDdq0aeNwUERERERERERUu+xKEEyePBkzZsxASkpKledeu3YNL730Ep588skaB0dEREREREREtcOuBMHAgQPRqVMn9OjRA1u2bIHBYLA6x2AwYPPmzejZsyfuuecexMfHOz1YIiIiIiIiInINmSiKoj0n5uTkIC4uDufOnUPDhg3RpUsXhIeHAwDS0tJw6tQp5ObmomPHjti/fz8aNGjg0sClRqPRwN/fHwBQUFAAPz8/N0dERERERERE9Zmz+6F2JwjKnvDFF1/EunXrIAiCxTG5XI6nnnoKy5cvNwXoScwbJjs7mwkCIiIiIiIicimNRoOgoCAAbkgQlElOTsb27duRlJQEURTRpk0bDB8+HM2bN69RMHWZeYJg3rx5UKlUbo6IiIiIiIiI6jOtVovFixcDcE6CwK5tDstr0aIFpk+fXqMnJiIiIiIiIiLpcGgEAVnjFAMiIiIiIiKqTc6eYuDQCAKqnEql4hQDIiIiIiIicimdTufU+uza5pCIiIiIiIiI6jcmCIiIiIiIiIiICQIiIiIiIiIiYoKAiIiIiIiIiMAEARERERERERHBhQmCZcuWuapqIiIiIiIiInIymSiKYlUn5ebm4vbt22jRooXp8ZkzZyo8X6/X44knnkBKSorzIpU4jUYDf39/AM7Zf5KIiIiIiIioMs7uhyrtOalHjx64fv06Ll26hPDwcJw9exYPPvggZDKZzfNFUazwGBERERERERFJj10JgrZt20ImkyEgIAAAEBwcjPDwcKxatcpUZk6r1WLy5MnOjZSIiIiIiIiIXMauBMG2bdssHoeGhuLxxx/H0KFDK7ymf//+NYuMiIiIiIiIiGqNXWsQOCIzMxMhISGuqFqSuAYBERERERER1SZn90NdtovBI4884qqqiYiIiIiIiMjJ7JpiUJEDBw7g6NGj0Gg0FuU6nQ4nTpyoUWBEREREREREVHscThAsXboUr7zySoXHuYsBERERERERUd3h8BSDH3/8EcePH0dJSQkEQbD4KSkpQZs2bZwZJxERERERERG5kMMjCLp3746uXbvaPObl5YWnn37a4aCIiIiIiIiIqHY5nCCQyysffHDPPfc4WrVdcnNzMXv2bAiCgPDwcJw/fx7Tpk3DkCFDauV6IiIiIiIiovrE4W0Oz549i//+97+YO3cufHx8rI737NkTR44cqXGAtgiCgH79+qFNmzZYuXIlACA5ORkdOnTA5s2bq+zk1/R6W7jNIREREREREdUmZ/dDHU4QPPPMM7hy5QqOHz+Odu3aWSQJdDodfvvtN+j1+hoFV5Evv/wSkyZNQmJiIlq3bm0qnzBhAo4ePYrExMRKF0ms6fW2MEFAREREREREtcnZ/VCHFynctm0brl69ii5dusDb2xuiKFr8uNKmTZsQFhZm0bkHgNjYWFy8eBFHjx516fVERERERERE9Y3DaxA0a9YMhw8fhre3t83j3bt3dzioqhw7dgyRkZFW5REREabjPXr0cNn1RERERERERPWNwwmC9957r8LkAAAsXrzY0aorpdFokJGRgXbt2lkdCwgIAACkpaW57PqKmI+a0Gg01b6eiIiIiIiIqDrM+57OGMnvcILgoYceqvR4defw2ysvLw8AbM6tKJt7kZOT47Lrly9fjuXLl1uVm6+3EBYWVuH1RERERERERM5WWFho6tM6yuEEQWUMBgNefPFF/PHHH06vW6FQALC9zaJWqwVgXCTRVdfn5eXhxo0b9gdMREREREREVAfYlSB45JFHcP78eRw9ehT+/v7Yu3dvlSMIXCU4ONhm5x4wrtoI3Jkq4IrrAwMDTWsVmBMEAYIgICEhAS+//LLLRlBITevWrZGamoomTZogKSnJ3eEQ2CZSxDaRHraJ9LBNpIdtIk1sF+lhm0iPJ7WJKIooLCwEAISEhNS4PrsSBKdOncLNmzdRUFAAf39/BAUFwcfHBwkJCTY701qtFh9++GGNg7NFoVAgNDTU5jSAsg5+VFSUy66fOXMmZs6cWb2g67GyZItcLufWjhLBNpEeton0sE2kh20iPWwTaWK7SA/bRHo8rU1qOq3AnF0JgqNHjyIvLw/h4eEAjN/Cx8XFYenSpRVec+TIEedEaEPfvn1x8OBBq/LExEQAwL333uvS64mIiIiIiIjqG9tj7csJCgqy+Fa9WbNm+Pbbbyu9ZsOGDTUKrDIjRoxASkoKrl27ZlG+e/dutGjRAr169TKVpaamWu0qUJ3riYiIiIiIiDyBXQkCW8y3OExOTrY6XjbawBVGjRqFDh06YNGiRaay06dPY8+ePfj4449N8/+vXLmCli1bonv37g5dT0REREREROQpnLKLwVNPPYXdu3c7oyq7qFQq7N69G7Nnz8YTTzyB0NBQnDhxAps2bcLQoUNN5wUEBKBp06ZWawrYez0RERERERGRp7ArQfDYY4/h1q1bFmW9evUyfQN/8+ZN9OjRw2IBiLZt2+LTTz91YqiWwsLCsH79+krPCQkJweXLlx2+noiIiIiIiMhT2JUg+Oc//4kJEybg0KFDePLJJzF16lR07NjR4pxjx46Z7j/00EN46623nBspSdLMmTORl5eHwMBAd4dCpdgm0sM2kR62ifSwTaSHbSJNbBfpYZtID9vEcTJRFMWqTiopKcHjjz+O119/Hffcc4/V8fbt2+Pf//43mjZtitTUVLzzzjv44IMP0KpVK5cETURERERERETOZVeC4P3330dcXBx69Ohh83i/fv2wZ88e0+O0tDS89dZbLp1iQERERERERETOY9cuBidPnqwwOQAADzzwgMXj8PBwZGVl1SwyIiIiIiIiIqo1diUINBpNpccXLFhgVVZQUOBQQERERERERERU++xKEGRnZ1e74pycnGpfQ0RERERERETuYVeCwNfXFydPnrS70gMHDsDX19fhoIiIiIiIiIiodtmVIBg7diymT58OnU5X5bmFhYV48cUXMXny5BoHR0RE5IijR48iPz/f3WEQERER1Sl27WKg0+nQoUMHtGzZEuvWrUN4eLjN865evYpJkyYhKysLp06dgkqlcnrA5B7JycnYsmULjh07hrS0NOTk5ECn0yEgIABRUVHo1q0bxo4dy60ta9HevXvx008/obCwEH369MHYsWMhk8lMx7/88ktkZ2ejffv2aN++PZo2berGaD3XuXPn8M033yAtLQ1RUVEYP348IiIi3B1Wvffkk0/i119/xaZNm9C9e3d3h0M2aDQapKenW/098fPzc3doRG536NAhbNy4sdLPXY899hji4uLcHapHKC4uxk8//QRfX188+OCD8PLyMh37/PPPsWbNGmi1WgwcOBCvvvoqAgIC3BitZzh48CB8fHzQrVs3U5lOp8O//vUvbN26FTdv3kTz5s3x+OOPY8qUKe4LtC4S7XT69GkxMDBQ9PHxEUeOHCm+/fbb4qpV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",
      "text/plain": [
       "<Figure size 1200x450 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_736656/3535116526.py:71: MatplotlibDeprecationWarning: The get_cmap function was deprecated in Matplotlib 3.7 and will be removed two minor releases later. Use ``matplotlib.colormaps[name]`` or ``matplotlib.colormaps.get_cmap(obj)`` instead.\n",
      "  palette = cm.get_cmap(colormap)(colors)\n"
     ]
    },
    {
     "data": {
      "image/png": "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4Ndff0VmZiZKSkpw5coVrF27Ft9//73FeefOncP48eMxZMgQdO7cGUOGDMGBAwccipmIiIiIiIiornN4m8NWrVqhf//+AACZTGZZqVJpsTOAvQRBwMiRI9GmTRt8/vnnAIDk5GR06NABmzdvxpAhQ6qsY8mSJViyZIlF2aBBg7BlyxbT43PnzmHGjBnYtGkTQkJCoNfr8fzzzyMuLg5r1qzBlClTqh07ERERERERUV3m8AgCb29v031byxikpqZWu86NGzdi//79mDVrlqmsRYsWGDFiBGbMmGHzecpr3rw5nn76aQwZMgTPPPMMfvzxR+zcuRP+/v6mc+bNm4ePP/4YISEhAIwJjQ8++ACNGjXC9OnTkZubW+3Yq5KWloaZM2di9erVTq+biIiIiIiIqLzq9kMdThBkZWXh8uXLACxHEAiCgA8++KDCbQIrs2nTJoSFhaF169YW5bGxsbh48SKOHj1aZR0tW7bEqlWr8P3332PlypUYOHCg1Tl79uxBfHw8bt26ZSpTq9WIjY1FQUEBDh8+XO3YK1LWIC1btsQHH3yABQsWoKSkxGn1ExEREREREZlztB/q8BSDGTNm4P7778fo0aNx6dIlvPnmm7h27Rp++OEHaLVa/P7779Wu89ixY4iMjLQqj4iIMB3v0aOHoyGbREVFITExERqNxqK8bFREYWFhjZ8jLS0N77//Pj777DMUFxebyrOzs3H8+HH07t27xs9BREREREREVKam/VCHEwRdunTB119/jSeffBKXLl3Crl27AADt27fHhg0b0Lx582rVp9FokJGRgXbt2lkdCwgIAGB8sVXRarV4//33kZqaCpVKhfPnzyMhIQGDBw82nXPkyBHk5+cjPDzc4toTJ05ALpejZ8+e1YodME6zKCwsRHp6OlasWIF//etfFg2iVquRkJCA2bNnWz0vERERERERUXU5ux/qcIIAAPr06YPExET89ttvSElJQVRUlMPf8Ofl5QEA/Pz8rI6VrR+Qk5NTZT03b97E6NGjERMTAwC4cOECunTpgi+++AKPPPKI6TnKP893332HS5cu4ZVXXkGzZs0qrH/58uVYvny5VblOp7OYslCGiQEiIiIiIiJyhStXriA6Otqq3NF+aI0SBIBx/YH777/fqnzjxo0YP3683fUoFAoAsLn7gVarBWDshFfl0qVLproAoE2bNoiN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ERERUaUSExPtWk+gbOqAM6xcuRL5+fkWZQEBAQCA7du3Y/DgwVAqXTKj36UcinjcuHH4888/nR0LERERERERkd3++OMP3Lp1q9aft02bNhUeS0pKQt++fW0e2717N/r37++qsGrMoQSBSqXC4sWLKz3n3Llz6NChg0NBERERERERkbUig8HdIdjkqriKi4sBwGq+P2AcOfDYY48hIiLC5jVlt9V5Hmespffwww/jySefxNtvv43u3bvDx8cHV69exdq1a9GrV68a1+9KLhvzMGXKFBw7dsxV1RMREREREXmcvuXmvddXP/30ExYvXozff/8dAHDkyBHTtoF6vR6pqak4e/YsRFFEjx49bF7zv//9DzExMWjZsiVmz56NAQMGWD3PqVOn8PLLL+PUqVOm52nfvj06d+6MTZs2ORR7p06d8MEHH+DNN9/EsWPHoFar0b17d8ybN69+JAhefvll/Pnnn9i6dStUKhUOHz6MiRMnVni+Xq/HjRs3nBYkEREREREReY6BAwdi4MCBLr+mS5cu2L17d7WusccDDzzgknpdza4EwcaNG5GRkYH09HRERkZCrVbj+vXrGD58uGkhBnNarRZff/2104MlIiIiIiLyNGq1GklJSe4Ow25qtdrdIZCD7EoQ7N+/H5mZmYiMjAQABAUF4cEHH6w0CXD9+nXnREhEREREROTBZDIZfH193R0GeQC7EgR33XUX7rrrLtPjyMhIrFmzptJrPvroo5pFRkRERERERES1Ru7QRXI5mjVrVuk5X375pUMBEREREREREVHtq/EuBllZWdBoNBZlOp0OX3/9NZYsWVLT6omIiIiIiIioFjicIDh27BjGjRuH5ORkZ8ZDRERERERERG7gcILg5ZdfxtChQ9GxY0eoVCqLY1qtFnPnzq1xcERERERERERUOxxOEHTr1g3Lly+v8PhXX33laNVEREREREREVMscWqQQQJXbbPz888+OVk1EREREREREtczhBEHr1q1x9OjRCo8PGDDA0aqJiIiIiIiIqJY5PMWgZcuW+Oc//4mAgADce++98PHxMR3T6XQ4ceKEUwIkIiIiIiIiItdzOEEwfPhw5OXlAQA+//xzq+MymczxqIiIiIiIiAgAIIoiioqK3B2G3dRqNfuDdZTDCYLGjRvjq6++wl133WV1TKvV4qGHHqpRYERERERERAQUFRWhdevW7g7DbklJSVWuWUfS5HCCYMSIEYiPj6/w+NixYx2tmoiIiIiIiIhqmcMJgtmzZyM7OxtBQUE2jy9dutThoIiIiIiIiMjaqPlfQKnyqfrEWqbXFuPbNye5pG6tVot169Zhy5Yt0Gg0CAoKgp+fH+655x7MmDEDOTk5mDFjBjZv3uyS5y9v7ty52LNnD7Kzs7Fo0SKMGzeuVp63NjicIOjTpw8ef/xxvPXWWzaPp6SkYNKkSTh16hQmTpyIjz/+2OEgiYiIiIiICFCqfCSZIHCVM2fOYMyYMWjcuDE++ugjdOvWzXTsyJEjePzxx3H79m0IglBrMS1evBj//e9/8eijj9aptSHs4fA2h2PGjMFbb72FK1eu4OLFi1bHn3nmGQQHB+PQoUMoKirCN998U6NAiYiIiIiIyHOcPXsWffr0QYsWLbB3716L5AAA9OzZE6+//joOHTpUq3HJ5XLcd999tfqctcXhBEGjRo0wcuRIxMTEoE2bNpg8ebLpWGFhIXbt2oXZs2ejQ4cO+PTTT7Fjxw6nBExERERERET1m16vx6OPPoqSkhKsW7cO3t7eNs/r2rUrnnzyyVqOrv5yOEGQlpYGtVqNjz/+GEuWLEFSUhLWr18PALh58yZEUUS7du0AAN7e3mjYsKFTAiYiIiIiIqL6bdOmTfjrr7/w8MMPIyIiotJzp06dWktR1X8Or0Gg1WqxadMm0+O///3vmDlzJiZPnoz09HQAQIMGDUzHFQpFDcIkIiIiIiIiT7F161YAsJpWYEvHjh3Rq1cvAMZpCVOnTsW1a9dw1113YeHChdi2bRu+/vprvPvuuxg/fjwA4LfffsP27dsBGLeRvHHjBubOnYt7773Xqv6UlBR8/vnnaNKkCRo1agS9Xl/pjn51mcMJgsDAQIvH3t7epjK9Xm91viiKjj4VEREREREReZDExEQAQGhoaJXn+vj44J133gFgTBYcPnwY/fv3R0ZGBvbs2YP33nsPq1atwvbt2zF+/HiUlJRgwIABGDp0qOlL759//hmxsbE4fPgwunTpYqr7+PHjpsX5X3jhBSgUCgiCgL/97W/Of9ES4PAUg+TkZOzZswclJSXIzc3FihUroFarAQC3bt0CAGg0GgCAwWAwjSogIiIiIiIiqkxNRqArlUq0bNkSf/75JyZOnAgvLy8kJibi3//+NwCYpsMHBQWZrhkwYAAaNWqEtWvXmsoEQcCkSZMQHR2Nfv36mcrlcjmee+45h+OTModHEMyYMQP9+/dHYWEhACAyMhL9+/fHzJkzsWHDBowcORIrVqzA3LlzsXLlSossDBERERGRFJV9tpUyX19fd4dA5HKtW7fG6dOnkZaWZvP4/Pnz8euvvyItLc00Wr1JkyZYs2YNWrZsCcA4yj0mJgYA0LRpU9O1Pj4+OHr0KLKysvDvf/8bZ8+eRUBAADQaDW7fvm0678iRI0hKSsKjjz7qqpcpOQ4nCLp3747Dhw9j9erVaNCgAaZPn47AwECcP38ec+bMQWhoKAYOHIj33nsPkZGR+N///ufMuImIiIiInK5169buDqFKN27ccHcIRC43duxYfP311zhy5IjN42+++SYA4PDhw+jduze6deuGvXv3WpwTFhYGmUxm8/p33nkHS5cuxVtvvYV33nkHarUaX3zxhcU5165dM9XjKRxOEADG+R0ffvihRdk999xjuv/DDz/g7NmzaNeuXYXbUhARERERERGZGz16NNq2bYtdu3bh8uXLaNWqlc3zykYG+Pn5WR2rKDmwevVqzJs3Dxs2bDAtWlheUlISIiMjAQAlJSWOvIQ6qUYJgvIuXryIRYsWQaVSYejQoRg2bBinFhARERFRnZGUlOSUegoLC9G5c2cAwOnTpzktgKialEolvvnmG/To0QOTJk3Czz//bDMJUNEUhMp8//33AIDhw4ebyvR6PbKyskyPFy1aZJqucPbsWas6bC3MXx84NUEQExODtWvXQhRFjBw5EsOGDXNm9URERERELuWKjryvry8TBOQ0em2xu0OwyRVxtWvXDocPH8YjjzyC3r1746OPPsIDDzxgOp6amorFixejf//+Vh12nU4HrVYLURStRhKUrUtw6tQp9OnTBwCwdOlSREVFITs7GwaDAWq1GnK5HGvWrMGQIUPwyy+/4O677wYAaLVavPfeewCMX5LXJzVKEHz++ef49NNPLRZyAIDbt2+jTZs2NQqMiIiIiIiILH375iR3h1Cr7r77bpw6dQr/+c9/8Oabb0Kj0aBRo0bw9/dHcHAwli9fjgYNGuD1118HAJw9exbPP/88Dh8+DL1ej9atW6N3795Yt26dqc6FCxdCoVBg1qxZiI2NhZ+fH+69916sW7cOY8aMwdSpUzFv3jwAQGxsLNauXYvPP/8cly9fRnBwsGl3gx9++AHr16/HgQMHsH//frf8+zibwwmCLVu24B//+Afi4+Nx7tw501SCtLQ0ZGVl4YcffnBWjEREREREROShfHx8MGXKFEyZMqXCc/71r38BMK6TV1VnXa1Wm0YAlHflyhWrsjZt2mDp0qW4++67LbZfLCgosCP6usXhBMF//vMf/P7774iIiMC8efOwePFi07Fff/0VGzZswN/+9jenBElEREREROSp1Gq109bHqA1qtdrdIZCDHE4Q3HXXXYiIiAAAGAwGZGRkoHHjxgCABx54oN4MsSAiIiIiInInmUzGdSyoVsgdvVCpVEKv10On0+H+++/HokWLLI47spokEREREREREblHjRYpvOuuu9CkSRPs3bsXf//731FSUoJhw4bh1KlTOHHihLNiJCIiIiIiIokwGAzuDqFK5msFkP0cThA8//zzOHr0KKKjo6FSqbBy5Uo88sgjWLVqFQDjDgdERERERERUv/zxxx/uDqFKnTt3dncIdZLDCYLw8HD8/PPPpsdDhgzBiRMnsGvXLsTExGDIkCFOCZCIiIiIiIiIXK9GUwzKa9++Pdq3b+/MKomIiIiIiEhC7r77bqfVJQgCzp8/D8DYn5TLHV4mj5zArn/9SZMmVbviyZMnV/saIiIiIiIiTyWKortDsItCoXDaj3lCQC6XO63e+sAdvw92JQh+//33alfsyDVERERERESeRqk0DuwuKSlxcyQkJTqdDkDtLrho1xSDP//8E/fffz98fHzsqrS4uBh//vlnjQIjIiIiIiLyBEqlEn5+fsjOzkZAQEC9+QacHCeKIm7fvg1vb294eXnV2vPavQbBkSNHqlWxTCardjBERERERESeKCQkBCkpKbhy5QoaNGgAtVoNhUJR7/tVBoPBNJS+uLhYcsmR2o5PFEXodDrcvn0bBQUFiIiIcOnzlWdXgmDx4sVITU3F4MGD0bNnzyrPLyoqQpcuXWoaGxERERERkUfw9fVFy5YtcevWLeTk5CAzM9PdIdUKQRCQkZEBAPDy8pLcIoXuis/b2xsREREIDAyslecrY1eCYO7cuRAEATt27MD777+PZs2a4fHHH0fDhg1tnt+gQQN07NjRmXESERERERHVayqVCs2aNTN9iywIgrtDcrmioiI8+eSTAICffvoJarXazRFZckd8CoWiVqcVmLN7ioFcLsew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eXnIzc01PS4uLkZKSopVokCn0+H06dM4e/ZstYMZNWoUOnTogEWLFpk6+KdPn8aePXuwbds205SAK1euoF27doiOjsa5c+dM1//22294+umnER8fj4kTJ5rKRVHEwYMHMX36dNPzDBgwAO+8847peZKSkrBv3z6sWLECDRs2rHbsRERERERERHWZ3QmCY8eOYd26ddixY4cpUVDRmgBeXl5Yv359tYNRqVTYvXs3Zs+ejSeeeAKhoaE4ceIENm3ahKFDh5rOCwgIQNOmTa2ef9iwYcjKysKGDRus6o6OjoaPj4/p8TfffINXX30Vw4YNQ4MGDZCVlYUtW7Zg8ODB1Y6biIiIiIiIqK6zO0HQv39/9O/fH4WFhZg6dSrOnz9vc7E+X19fdO/evdqLFJYJCwurMrkQEhKCy5cvW5VnZmba/Tx+fn746KOPqh0fERERERERUX1U7TUIfH198c9//hNTpkypcCtAIiIiIiIiIqpb5I5cFBYWhi+//LLSc6rzbT4RERERERERuZdDCQIACA4OrvT4I4884mjVRERERERERFTLHN7mEAAOHDiAo0ePQqPRWJTrdDqcOHGiRoERERERERERUe1xOEGwZMkSzJkzp8LjZVsSEhEREREREZH0OTzF4KeffsLx48dRUlICQRAsfkpKStCmTRtnxklERERERERELuTwCIL77rsPXbt2tXnMy8sLf//73x0OioiIiIiIiIhql8MjCKqaQtC6dWtHqyYiIiIiIiKiWuZwgmDy5Ml49dVXkZeXZ/P4a6+95nBQRERERERERFS77JpiMG7cOGRkZFiVZ2Rk4IMPPkCrVq3g4+NjKtfpdDh//rzzoiQiIiIiIiIil7IrQXDu3DkUFBSgZcuWFuUhISEICQmxOl+n03EXAyIiIiIiIqI6xK4EQVBQEPbs2YPQ0FC7K+7evbvDQRERERERERFR7bJrDYL58+dXKzkAAIsXL3YoICIiIiIiIiKqfXYlCPr3729Vtnr1anz//fcVXvPQQw/h4sWL2Lp1K7KyshyPkIiIiIiIiIhczuFdDL744gsolRXPUPjqq6/QuXNnLFq0CL169apwtwMiIiIiIiIicj+HEwTdunVDx44dMX/+fLz++uu4ceOGxfG5c+fi3XffxbFjx7Bs2TKsWLGixsESERERERERkWvYtUihLW3btkWbNm1QWFgI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2x4iqov43kVE5Lns6vFnZGQgODjY7kq9vLyg0WgcDoqIqo8f6Iiqxv8n0sM2ISIikg67EgS5ubnVrjgvL6/a11DdwQ90RERERERE9YvdIwgEQYBcLrerUoPBgIyMjBoFRkREREREJFX8wozqI7t6/G3atLHY5rAq33zzDdq0aeNwUERERERERERUu+xKEEyePBkzZsxASkpKledeu3YNL730Ep588skaB0dEREREREREtcOuBMHAgQPRqVMn9OjRA1u2bIHBYLA6x2AwYPPmzejZsyfuuecexMfHOz1YIiIiIiIiInINmSiKoj0n5uTkIC4uDufOnUPDhg3RpUsXhIeHAwDS0tJw6tQp5ObmomPHjti/fz8aNGjg0sClRqPRwN/fHwBQUFAAPz8/N0dERERERERE9Zmz+6F2JwjKnvDFF1/EunXrIAiCxTG5XI6nnnoKy5cvNwXoScwbJjs7mwkCIiIiIiIicimNRoOgoCAAbkgQlElOTsb27duRlJQEURTRpk0bDB8+HM2bN69RMHWZeYJg3rx5UKlUbo6IiIiIiIiI6jOtVovFixcDcE6CwK5tDstr0aIFpk+fXqMnJiIiIiIiIiLpcGgEAVnjFAMiIiIiIiKqTc6eYuDQCAKqnEql4hQDIiIiIiIicimdTufU+uza5pCIiIiIiIiI6jcmCIiIiIiIiIiICQIiIiIiIiIiYoKAiIiIiIiIiMAEARERERERERHBhQmCZcuWuapqIiIiIiIiInIymSiKYlUn5ebm4vbt22jRooXp8ZkzZyo8X6/X44knnkBKSorzIpU4jUYDf39/AM7Zf5KIiIiIiIioMs7uhyrtOalHjx64fv06Ll26hPDwcJw9exYPPvggZDKZzfNFUazwGBERERERERFJj10JgrZt20ImkyEgIAAAEBwcjPDwcKxatcpUZk6r1WLy5MnOjZSIiIiIiIiIXMauBMG2bdssHoeGhuLxxx/H0KFDK7ymf//+NYuMiIiIiIiIiGqNXWsQOCIzMxMhISGuqFqSuAYBERERERER1SZn90NdtovBI4884qqqiYiIiIiIiMjJ7JpiUJEDBw7g6NGj0Gg0FuU6nQ4nTpyoUWBEREREREREVHscThAsXboUr7zySoXHuYsBERERERERUd3h8BSDH3/8EcePH0dJSQkEQbD4KSkpQZs2bZwZJxERERERERG5kMMjCLp3746uXbvaPObl5YWnn37a4aCIiIiIiIiIqHY5nCCQyysffHDPPfc4WrVdcnNzMXv2bAiCgPDwcJw/fx7Tpk3DkCFDauV6IiIiIiIiovrE4W0Oz549i//+97+YO3cufHx8rI737NkTR44cqXGAtgiCgH79+qFNmzZYuXIlACA5ORkdOnTA5s2bq+zk1/R6W7jNIREREREREdUmZ/dDHU4QPPPMM7hy5QqOHz+Odu3aWSQJdDodfvvtN+j1+hoFV5Evv/wSkyZNQmJiIlq3bm0qnzBhAo4ePYrExMRKF0ms6fW2MEFAREREREREtcnZ/VCHFynctm0brl69ii5dusDb2xuiKFr8uNKmTZsQFhZm0bkHgNjYWFy8eBFHjx516fVERERERERE9Y3DaxA0a9YMhw8fhre3t83j3bt3dzioqhw7dgyRkZFW5REREabjPXr0cNn1RERERERERPWNwwmC9957r8LkAAAsXrzY0aorpdFokJGRgXbt2lkdCwgIAACkpaW57PqKmI+a0Gg01b6eiIiIiIiIqDrM+57OGMnvcILgoYceqvR4defw2ysvLw8AbM6tKJt7kZOT47Lrly9fjuXLl1uVm6+3EBYWVuH1RERERERERM5WWFho6tM6yuEEQWUMBgNefPFF/PHHH06vW6FQALC9zaJWqwVgXCTRVdfn5eXhxo0b9gdMREREREREVAfYlSB45JFHcP78eRw9ehT+/v7Yu3dvlSMIXCU4ONhm5x4wrtoI3Jkq4IrrAwMDTWsVmBMEAYIgICEhAS+//LLLRlBITevWrZGamoomTZogKSnJ3eEQ2CZSxDaRHraJ9LBNpIdtIk1sF+lhm0iPJ7WJKIooLCwEAISEhNS4PrsSBKdOncLNmzdRUFAAf39/BAUFwcfHBwkJCTY701qtFh9++GGNg7NFoVAgNDTU5jSAsg5+VFSUy66fOXMmZs6cWb2g67GyZItcLufWjhLBNpEeton0sE2kh20iPWwTaWK7SA/bRHo8rU1qOq3AnF0JgqNHjyIvLw/h4eEAjN/Cx8XFYenSpRVec+TIEedEaEPfvn1x8OBBq/LExEQAwL333uvS64mIiIiIiIjqG9tj7csJCgqy+Fa9WbNm+Pbbbyu9ZsOGDTUKrDIjRoxASkoKrl27ZlG+e/dutGjRAr169TKVpaamWu0qUJ3riYiIiIiIiDyBXQkCW8y3OExOTrY6XjbawBVGjRqFDh06YNGiRaay06dPY8+ePfj4449N8/+vXLmCli1bonv37g5dT0REREREROQpnLKLwVNPPYXdu3c7oyq7qFQq7N69G7Nnz8YTTzyB0NBQnDhxAps2bcLQoUNN5wUEBKBp06ZWawrYez0RERERERGRp7ArQfDYY4/h1q1bFmW9evUyfQN/8+ZN9OjRw2IBiLZt2+LTTz91YqiWwsLCsH79+krPCQkJweXLlx2+noiIiIiIiMhT2JUg+Oc//4kJEybg0KFDePLJJzF16lR07NjR4pxjx46Z7j/00EN46623nBspSdLMmTORl5eHwMBAd4dCpdgm0sM2kR62ifSwTaSHbSJNbBfpYZtID9vEcTJRFMWqTiopKcHjjz+O119/Hffcc4/V8fbt2+Pf//43mjZtitTUVLzzzjv44IMP0KpVK5cETURERERERETOZVeC4P3330dcXBx69Ohh83i/fv2wZ88e0+O0tDS89dZbLp1iQERERERERETOY9cuBidPnqwwOQAADzzwgMXj8PBwZGVl1SwyIiIiIiIiIqo1diUINBpNpccXLFhgVVZQUOBQQERERERERERU++xKEGRnZ1e74pycnGpfQ0RERERERETuYVeCwNfXFydPnrS70gMHDsDX19fhoIiIiIiIiIiodtmVIBg7diymT58OnU5X5bmFhYV48cUXMXny5BoHR0RE5IijR48iPz/f3WEQERER1Sl27WKg0+nQoUMHtGzZEuvWrUN4eLjN865evYpJkyYhKysLp06dgkqlcnrA5B7JycnYsmULjh07hrS0NOTk5ECn0yEgIABRUVHo1q0bxo4dy60ta9HevXvx008/obCwEH369MHYsWMhk8lMx7/88ktkZ2ejffv2aN++PZo2berGaD3XuXPn8M033yAtLQ1RUVEYP348IiIi3B1Wvffkk0/i119/xaZNm9C9e3d3h0M2aDQapKenW/098fPzc3doRG536NAhbNy4sdLPXY899hji4uLcHapHKC4uxk8//QRfX188+OCD8PLyMh37/PPPsWbNGmi1WgwcOBCvvvoqAgIC3BitZzh48CB8fHzQrVs3U5lOp8O//vUvbN26FTdv3kTz5s3x+OOPY8qUKe4LtC4S7XT69GkxMDBQ9PHxEUeOHCm+/fbb4qpV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",
      "text/plain": [
       "<Figure size 1200x450 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_736656/3535116526.py:71: MatplotlibDeprecationWarning: The get_cmap function was deprecated in Matplotlib 3.7 and will be removed two minor releases later. Use ``matplotlib.colormaps[name]`` or ``matplotlib.colormaps.get_cmap(obj)`` instead.\n",
      "  palette = cm.get_cmap(colormap)(colors)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABAgAAAH8CAYAAABcop2yAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACkUElEQVR4nOzdd3xTVf8H8E9G06YT2tIWSqHQskUQEERAloBsEBFlIyjy/FSggiI+CirDAbgnPPqACg/gAkVFZMkQGbJRKatAaUsnpTPj3t8faUPSpG1mc9N83q8XryTn3nvyDadNc745QyaKoggiIiIiIiIi8mlyTwdARERERERERJ7HBAERERERERERMUFAREREREREREwQEBERERERERGYICAiIiIiIiIiMEFARERERERERGCCgIiIiIiIiIjABAERERERERERgQkCIiIiIiIiIoKEEwR6vR59+vTBlStX3HZ9eno6Hn30UYwbNw4zZ87Ek08+iT/++MPRkImIiIiIiIi8liQTBCdOnED//v2xc+dO6PV6t1x/5coVdOnSBffccw++/PJLvP322zh//jzGjh3rbPhEREREREREXkfp6QBMnT17FrNnz0ZYWBhUKpXbrhdFESNHjsTQoUMxYcIEY3leXh7q16/vUOxERERERERE3kxSIwiaN2+OLVu2YO3atejSpYvbrl+/fj2OHDmCxx9/3Kx8//792Lt3r93PS0REREREROTtJJUgqClr1qyBWq3Gbbfd5ulQiIiIiIiIiCRBUlMMaoIoiti1axfq1auH06dPY+3atSgpKcE///yD0aNHY9KkSQ7VKwgCsrKyAACBgYGQyWSuDJuIiIiIiIjIjCiKKCoqAgBERkZCLnduDIDPJQiys7NRXFwMjUaDb7/9FosXLwYAZGZmokWLFsjKysLTTz9d6fUrVqzAihUrLMp1Oh0yMjLcFjcRERERERFRZTIyMhAVFeVUHT6XICjf1SA9PR1jxowxlterVw+DBg3C888/jwkTJlT6H5ufn4/U1NQaiZWIiIiIiIiopvhcgiAiIgIAEBQUhMTERLNjDRs2RGlpKX766adKpxqEhoYiNjbWolyv1yM9PR2AIXMTFBTk4siJiIiIiIiIbiksLER0dDQAw1R3Z/lcgkCpVCIqKgr+/v4W6wT4+/sDAK5du1bp9UlJSUhKSrIoLywsRHBw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6aefxvTp09GyZUtXxklEREREREREbuTwGgR79uzB7bffjm+//RYnTpwwVCaXY/HixXj33Xdx7NgxV8VIRERERERERG7mcIJg6dKl+P7775GSkoL27dsbywMDA/H2229jzZo1roiPiIiIiIiIiGqAw4sUNm3aFH379gUAi0X9lEol5HLHcg95eXmYO3cuBEFATEwMzpw5g2nTpmHw4ME2XX/s2DF88MEH8PPzg06nw6VLlzBt2jSMHj26yutOnz6NcePGceQDERERERER+SSHEwT+/v7G+9aWMUhLS7O7TkEQMGLECLRo0QIrV64EAKSkpKBNmzZYv359tUmCkydP4oUXXsD69esRGBgIAPjiiy/w4IMPYsmSJXjuuecqfd5p06YhLy/P7phtlZ6ejtdffx2tW7fGtGnT3PY8RERERERERID9/VCHpxhkZ2fjwoULAMxHEAiCgDfffBMBAQF217l27Vrs3r0bc+bMMZY1btwYw4cPx6xZs6wmIkx99tln+OGHH/DJJ58Yy4YPHw4AePXVVyu97v3338fFixftjtcW6enpSEpKQpMmTfDmm29i4cKFKC0tdctzERERERERETnaD3V4BMGsWbNw99134/7778f58+fx0ksv4fLly/jpp5+g0Wjw559/2l3nunXrEB0djWbNmpmV9+jRA2vXrsXBgwfRpUuXSq/v0KEDgoODUbduXWNZfn4+ABhHFFSUkpKC9PR0tGzZEpcuXbI75sqUZ2o+/PBDlJSUGMtzcnJw+PBhdOvWzWXPRURERERERORsP9ThBEH79u3x1VdfYcqUKTh//jy2bdsGAGjdujW+/PJLNGrUyO46Dx06hLi4OIvy2NhY4/GqEgTjx4/H+PHjLeoEgMmTJ1u9ZvHixVixYgWGDBlid7ymRFFEUVERMjIy8O677+Kjjz4yaxC1Wo0ZM2Zg7ty5iImJceq5iIiIiIiIiFzdD3U4QQAA3bt3x9mzZ/H777/jypUriI+Pr7IDX5XCwkJkZmaiVatWFsdCQkIAGLIh9sjPz8fLL7+MUaNGYeHChRbHV69ejREjRiA4ONihmE1dvHgRCQkJFuVMDBAREREREZE7uLof6vAaBOVkMhnuvvtujBkzxiw5sHbtWrvqKZ8KEBQUZHGsvAOfm5trU12//PILZs2ahb59+yIxMRH//e9/zRZVBIDr16/j8OHD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Ek+HYEGKMdUkLr5GRERERES1id1rEAQGBuKtt97C5MmTMWnSJJcGEx0dXe3Ig8jISFy4cMGiPCIiAj///LPNz9WhQwezKRNSx2+FiYiIiIiIyJ2s7y1YjejoaHzxxRdVnpOVleVQQERERERERERU8xzexSAiIqLK4w888AB27drlaPVUAee7ExERERERkTs5nCAAgD179uDgwYMWiwFqtVocOXLEqcDIHOe7ExERERERkTs5nCB444038Oyzz1Z6vHzXASIiIiIyJ4qicdclVygqKrJ63xXUajU/1xER+QiHEwRbt27F4cOH0bZtW/j5+Zkd02q1aNeundPBEREREdVGxcXFaNasmVvqdvVnsOTkZAQGBrq0TiIikiaHEwR33nknOnToYPWYn58f/u///s/hoIiIiIiIiIioZjmcIKhuqJm7suJEREREtQkXIiYiIqlwOEEwceJEPPfcc3juuecQGhpqcfz5559H//79nQqOiIiIqLbjQsRERCQVNiUIxowZg8zMTIvyzMxMvPnmm2jatCkCAm79YdNqtThz5ozroiQiIiIiIiIit7IpQXD69GkUFBSgSZMmZuWRkZGIjIy0OF+r1XK1WyIiIiIiIiIvYlOCIDw8HDt27EBUVJTNFXfu3NnhoIiIiIiIiIioZsltOWnBggV2JQcAYMmSJQ4FREREREREREQ1z6YEQd++fS3KVq1ahR9++KHSa+69916cO3cO3333HbKzsx2PkIiIiIiIiIjczqYEgTWff/45lMrKZyhs3LgR7dq1w+LFi9G1a1fk5+c7+lRERERERERE5GYOJwg6deqEtm3bYsGCBXjhhReQmppqdnzevHl49dVXcejQISxfvhzvvvuu08ESERERERERkXvYtEihNS1btkSLFi1QVFQEAPj0009x7Ngx1KtXD1lZWbh48SLuu+8+AMDQoUPx/fffuyZiIiIiIiIiInI5h0cQ7NixA19//TUKCwuRnZ2NuXPn4u233wYApKWlQSaToWHDhsbzQ0JCnI+WiIiIiIiIiNzC4QRBo0aNMGDAAKjVatStWxezZs1CcXExACA3NxcAoFarjecrFAonQyUiIiIiIiIid3E4QVBSUmL2WBAECIIAABBF0eJ8nU7n6FMRERERERERkZs5vAaBXC7HhAkT0L17dxQXF+N///sfpk+fDgDYsmULRFFESkoKGjdujPT0dGRlZbksaCIiIiIiIiJyLYcTBAsXLsTw4cMxY8YMyGQyTJ8+Hf/88w969eqF4OBgfPvtt5g0aRJmzZqFlStXYubMma6Mm4iIiIiIfIROU1L9SR4g1biIHOVwgiAsLAy7du3CsWPHEBoaiqZNm1qck5WVhYULF2L06NHo37+/U4ESEREREZFv+valCZ4OgcgnOJwgKNe+fftKj02dOhVTp0519imIiIiIiIiIyM2cThBUZuzYsVi7dq27qiciIiIiIh8xcsHnUKoCPB2GBZ2mhKMbJKyoqMildbiiPlNqtRoymcyldTrLpgTB77//jsuXL2PMmDEAgAsXLuCLL76o9HydToctW7a4JkIiIiIiIvJpSlWAJBMEJG3t2rWTdH3JyckIDAx0aZ3OsilBMHToUOTm5uLOO+9E06ZNcf36dSxcuLDKa6SWCSEiIiIiqowoiiguLnZZfe781hGQ5jePROT9bEoQPPvsszh//jzi4+MBAOHh4WjTpg3279+PkJAQi/O1Wi3atm3r0kCJiIiIiNyluLgYzZo1c0vdrv7WEZDmN4/kW6S6g4NpXD92745wlcqD0Vgq1uvRe/duT4dRKZsSBHPnzjV73KBBA8yZM8dqcgAA/Pz8MG3aNOejIyIiIpeS4gc6KcZERERV84a1F9QKBQIVblt2r1Zy6H8rODgYkyZNMj4uKioyZjBLSkoQEBCAOXPmuCZCIiIichlv+EBH5GlcEI+IfJVT6ZRFixZh+fLl6NixI3799VcIgoB58+YhNjbWYtQBERH5Hil+MyzFmIhIWrggHpF1arUaycnJLq2zqKjIOA3n+PHjTk+dMa0vQC53Oj5f43CCYOnSpfjiiy/w1FNP4fr16wAAuVyOt956C99//z0++eQTPPbYYy4LlIioOlLs+EkxpprEb7qkR4rfjPJbUSIi7yCTydy69kVgYKBL6+dCnvZzOEGwb98+HD16FGq1Gi+99JLZsaFDh3IEARHVOHYwiKrHb0aJiIioMg4nCFq2bAm1Wg3AemamtLTU8aiIvIAUvxmWYkzk2/htNREREZH3cDhBUFBQYLwviqLZseLiYly4cMHxqIi8ADsY0sPOqPTw22oiIiIi7+FwgqBu3bp44403kJSUZBxBIAgCfvrpJyxatAgPPvigy4IkIrIFO6NERERERI5zOEHw4osvolevXli8eDH8/f3x2WefIS0tDVqtFv369cPMmTNdGSeR5PDbaiIiIiIqV1RU5NI6XFGfKbVazUX7qFoOJwjUajV+++03vPrqq/jyyy9x5coVNGnSBI888giSkpIg55YSVMvx22oiIiIiKle+tZ5U60tOTnbrDgRUOzicIAAAf39/LFiwAAsWLHBVPERERERERETkATYlCO655x789ttv7o6FiIiIiIjIK/3YvTvCVSpPh2GmWK9H7927PR0GeRGbEgQHDhzAgQMHcNddd7k7HiIiIiKfIsUtaqUYE5HUqRUKBCqcGqBN5HE2/QTrdDrMnz8fDRo0QNeuXfHAAw8gOjra3bERERER1XpcXJaIiKTCpgRBbGwsduzYAcAwmuCNN95AZmYmunfvjlGjRiE8PNytQRIRERERERGRe9mUIHj77beN9++66y7jVIO9e/di0aJFuHHjBu655x6MHDkSoaGh7omUiIiIqBbitrlERCQVNiUI7r//fqvl3bt3R/fu3SGKInbv3o25c+fi+vXrGDNmDIYOHYqgoCCXBuvLpDgXUIoxEREReRtum0tERFLh9CoaWq0WP//8M/73v//h+++/R0FBATZt2oTWrVvj1KlTroiRwPmJRERERERE5F5yW0568803zR7r9Xr8/PPPmDJlCqKiojBixAisW7cOSqUSkydPxk8//YTjx4+7JWAiIiIiIiIicj2bRhCsWbMGs2fPxo4dO7B+/Xp88803yMnJgSiKCAkJwdixYzFmzBgMGDAAfn5+7o7ZZ6jVaiQnJ7usvqKiIrRr1w4AcPz4cQQGBrqsbrVa7bK6iIiIiIiIqObZlCA4fvw46tati/z8fACGzuDo0aMxZswYDBo0CP7+/m4N0lfJZDKXduJNBQYGuq1uIiIiIiIi8j42r0FQVFSEvn37IjU1FRMmTMCUKVMQHR3tztiIiIiIiIiIqIbYlCCIjo7GyZMnERkZCQD4448/8MYbb+D69evo0aMHRo0ahfDwcLcGSkRERERERETuY1OCoEuXLsbkQPnjLl26AAD27NmDV155BTdu3ECvXr0wcuRIhISEuCdaIiIiIiIiInILm3Yx+O677yo91qNHD7z55pt499138ccffyAmJgajRo2q8hoiIiIiIiIikhab1yCwRqvVYuvWrVi/fj02b96MgoICiKKIXbt2oUGDBhgxYoSLwiQiIiIi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XXK9s89DREREREREVNvIRAeWOszIyMDkyZPx008/uTSY9evX46GHHkJKSgoaNWpkLO/Xrx+Sk5Nx8eJF49D9tLQ0hIaGmi02aOv19jwPERERERERkS9wKEEAANnZ2YiIiKj0eFZWlt1zIDQaDTp06IBu3brh448/BgAcP34cHTp0wKZNmzBkyBAAwMWLF9GqVSskJCTg9OnTdl9v63lEREREREREvsLhBEF1evXqhV27dtl9XUZGBubOnQuZTIaoqCgcOXIEjz/+OB588EHjOVlZWejcuTNatWqFLVu22H29PecRERERERER+QKnEgR79uzBwYMHUVhYaFau1Wrx1ltv4ebNm04HSERERERERETuZ/MihRUtW7YMzzzzTKXHOYefiIiIiIiIyHvIHb3w559/xuHDh1FaWgpBEMz+lZaWokWLFq6Ms1J6vR59+vTBlStX7LouLy8Pjz76KKZOnYrnn38eI0eOtJiuQEREREREROQrHB5B0LlzZ3To0MHqMT8/Pzz66KMOB2WrEydOYPbs2di5cyf0er3N1wmCgBEjRqBFixZYuXIlACAlJQVt2rTB+vXrMXjwYHeFTERERERERCRJDicI5PKqBx/ccccdjlZdrbNnz2L27NkICwuDSqWy+/q1a9di9+7dxuQAADRu3BjDhw/HrFmzMGjQIE6RICIiIiIiIp/i8BSDMWPGYOHChSgpKbF6fN68eQ4HVZ3mzZtjy5YtWLt2Lbp06WL39evWrUN0dDSaNWtmVt6jRw+cO3cOBw8edFWoRERERERERF7B4REE7777Li5evIj69eujVatWCAgIMB7TarU4fPiwSwJ0h0OHDiEuLs6iPDY21njc3sSDIAjIysoCAAQGBnIEAhEREREREbmVKIooKioCAERGRlY70r86DicINm3ahNDQULRv394YmGmQUlVYWIjMzEy0atXK4lhISAgAID09vdLrV6xYgRUrVliU63Q6ZGRkuC5QIiIiIiIiIhtlZGQgKirKqTocThA0bNgQ+/fvh7+/v9XjnTt3djgod8rPzwcABAUFWRwLDg4GAOTm5lZ5fWpqqnuCIyIiIiIiIvIQhxMEr732WqXJAQBYsmSJo1W7lUKhAGB9kUWNRgPAMEWiMqGhocapCKb0er1x5EFGRobVBAQRERERERGRqxQWFiI6OhqAYaq7sxxOENx7770A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tspFEp293homCIiIiIiIiKgmubof6vAihZs2bcKlS5fQvn17+Pv7QxRFs3/utG7dOkRHR5t17gGgR48eOHfuHA4ePOjW64mIiIiIiIhqG4fXIGjYsCH2798Pf39/q8c7d+7scFDVOXToEOLi4izKY2Njjce7dOnituuJiIiIiIiIahuHEwSvvfZapckBAFiyZImjVVepsLAQmZmZaNWqlcWxkJAQAEB6errbrq+M6aiJwsJCu68nIiIiIiIisodp39MVI/kdThDce++9VR63dw6/rfLz8wHA6tyK8rkXubm5brt+xYoVWLFihUW56XoL0dHRlV5PRERERERE5GpFRUXGPq2jHE4QVEWv12PmzJk4deqUy+tWKBQArG+zqNFoABgWSXTX9fn5+UhNTbU9YCIiIiIiIiIvYFOC4IEHHsCZM2dw8OBBBAcHY+fOndWOIHCXiIgIq517wLBqI3BrqoA7rg8NDTWuVWBKEAQIgoAZM2bg6aefdtsICqlp1qwZ0tLSUL9+fSQnJ3s6HALbRIrYJtLDNpEeton0sE2kie0iPWwT6fGlNhFFEUVFRQCAyMhIp+uzKUFw7NgxXLt2DQUFBQgODkZ4eDgCAgIwY8YMq51pjUaDt99+2+ngrFEoFIiKirI6DaC8gx8fH++265OSkpCUlGRf0LVYebJFLpdza0eJYJtID9tEetgm0sM2kR62iTSxXaSHbSI9vtYmzk4rMGVTguDgwYPIz89HTEwMAMO38D179sSyZcsqvebAgQOuidCK3r17Y+/evRblZ8+eBQB07NjRrdcTERERERER1TbWx9pXEB4ebvatesOGDfHtt99Wec2XX37pVGBVGT58OK5cuYLLly+blW/fvh2NGzdG165djWVpaWkWuwrYcz0RERERERGRL7ApQWCN6RaHKSkpFsfLRxu4w8iRI9GmTRssXrzYWHb8+HHs2LED7733nnH+/8WLF9GkSRN07tzZoeuJiIiIiIiIfIVLdjF45JFHsH37dldUZROVSoXt27dj7ty5mDRpEqKionDkyBGsW7cOQ4YMMZ4XEhKCBg0aWKwpYOv1RERERERERL7CpgTBQw89hOvXr5uVde3a1fgN/LVr19ClSxezBSBatmyJDz74wIWhmouOjsaaNWuqPCcyMhIXLlxw+HoiIiIiIiIiX2FTguCtt97CuHHjsG/fPkyZ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3bt3C5lXCdik/6mrq8P169fh5uaG4cOHix6HwCYyYpP/D+9iQERERH1Oo9HA39//kfstLCzg4uLSbdvx48f7eixFY5P+x8XFpUcTEotN5MMm/x8uEBAREVGfi46ORmBgIF5++WU4OTkBAEpKShAeHv7Qx3d0dODSpUvmHFFx2ISIiB7EuxgQERFRn5s5cyYOHToEAKiqqkJVVRUMBsMjP+4d0k59h02IiOhBvAYBERERCTFjxgwcO3bskfuDg4NRUlJixomITYiIlI1LwURERCREQkLCY/enpKSYaRK6h02IiJSNRxAQEREREREREY8gICIiIiIiIiIuEBARERERERERuEBAREREREREROACARERET2BwsJChIaGYuDAgVCpVFCpVPDw8MDkyZORn58vejwiIiIyAV6kkIiIiJ7Y559/jhkzZuDFF1/k7e6IiIh+YngEARERET0xa2trAICtra3gSYiIiMjUuEBARERERERERFwgICIiIiIiIiLAUvQARERE9NNkMBjw3nvv4fvvv4dOp4NGo4GTkxM2b96MQYMGAQDq6uowd+5cnD17FlqtFn5+fsjLy8MvfvELHD16FK+++ira29sRGBiIs2fPwtraGlqtFrt27UJ5eTkcHR1RWVkJLy8vbN26FTY2Nnj77beRmZmJuro6pKSkoLm5GefPn0dZWRk+//xzDBs2TPBvhoiISE68SCERERE9saKiIoSFhWHSpEkoKip67GMPHjyIRYsW4a9//SsiIyMBANHR0bh+/TpOnToFtfp/BzKmpaVhxYoV+OqrrzB27Fjj9q1bt8LOzg7x8fEA7i46zJkzB66urkhPTwcA6HQ6TJ48GZ6envjwww8BAJcvX4avry9CQ0Px9ttvo7KyEgsWLMCxY8cwffp0U/5KiIiIfjJ4igERERH1iaFDh2LEiBHGCxsCQExMDE6fPo3z5893e2xMTAwGDRqEzMzMbtsrKiqwcuVK49cHDhzA0aNH8dZbbxm3WVhYYOHChdi/fz8aGxsBAD4+PgAArVaL4OBgvPrqq7hy5QoXB4iIiB6DpxgQERGRSV24cAFeXl6IiIjA1atXcf78eSQnJ+PmzZtoamoCALS0tHT7Hnt7eyxcuBAfffQRduzYgYEDB6K8vBzPP/88LC3/93QlKysLlpaWxqMH7mlubsakSZNw69YtODo6GrePGjXK+Lm3t3df/LhEREQ/GVwgICIiIpPau3cvdu7cCY1Gg5iYGNTX1yMtLQ0hISEoKirCgQMHHvp9y5YtQ1paGg4cOIDly5cjIyMD69at6/aY7777Dnq9Hm+++SYsLCx+dBZXV1eT/ExERERKwFMMiIiIyKQuX74MOzs7zJs3D6Wlpfjiiy8QEhLS43EtLS2or683fu3v74+wsDDs3bsXt2/fRmtra48X+B4eHtDr9bhx40aPP0+v1+PBSyupVCoT/VREREQ/fVwgICIiIpP59ttvUV9fj1u3buH06dMIDQ3FkCFDjPs1Go3x83/+858oKCjo9v3Lly9HWVkZ4uLiEB0d3ePPj42NBQB88sknPfYlJyfj+vXrJvpJiIiIlIcLBERERPTEOjo6ANx9t/5Bly9fxiuvvAI3NzfY29vDxcUFZWVl6OrqAgDcvn0bBQUFsLS0RFNTE+rr6+Hu7t7tz5g9ezbc3d1x/vx5TJo0qcff8Zvf/AaLFy/GX/7yFzQ0NBi3FxcXo7m5GR4eHgBg/DvvzUtEREQ/jrc5JCIioh9VWFiI5ORklJaW4vbt2xgwYAB+9atfwcrKClqtFrW1tfjmm29gMBgQGxuLzMxMfPPNN9i0aRMMBgNGjx4Ng8GAP/zhD/jggw+Qk5ODuXPnIikpqce1BJKSkuDs7Izly5c/cp4PP/wQubm58PDwgJ2dHZydnREfHw9LS0vs3r0bGRkZKC8vh6WlJcaOHYvXX3/9oUckEBER0f9wgYCIiIikEhcXh507d2LgwIGiRyEiIlIUnmJAREREwhgMBmzduhVffvklAKC2thYDBw7k4gAREZEAXCAgIiIiYVpaWrB582bk5uYCuHuhwQdvbUhERETmwVMMiIiISKiUlBTcvHkT7e3tiImJwYsvvih6JCIiIkXiAgERERERERER8RQDIiIiIiIiIuICARERERERERGBCwREREREREREBC4QEBERERERERG4QEBERERERERE4AIBEREREREREYELBEREREREREQELhAQEREREREREbhAQEREREREREQA/gM3llhkhGS/xwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1200x450 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_736656/3535116526.py:71: MatplotlibDeprecationWarning: The get_cmap function was deprecated in Matplotlib 3.7 and will be removed two minor releases later. Use ``matplotlib.colormaps[name]`` or ``matplotlib.colormaps.get_cmap(obj)`` instead.\n",
      "  palette = cm.get_cmap(colormap)(colors)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABAgAAAH8CAYAAABcop2yAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACkUElEQVR4nOzdd3xTVf8H8E9G06YT2tIWSqHQskUQEERAloBsEBFlIyjy/FSggiI+CirDAbgnPPqACg/gAkVFZMkQGbJRKatAaUsnpTPj3t8faUPSpG1mc9N83q8XryTn3nvyDadNc745QyaKoggiIiIiIiIi8mlyTwdARERERERERJ7HBAERERERERERMUFAREREREREREwQEBERERERERGYICAiIiIiIiIiMEFARERERERERGCCgIiIiIiIiIjABAERERERERERgQkCIiIiIiIiIoKEEwR6vR59+vTBlStX3HZ9eno6Hn30UYwbNw4zZ87Ek08+iT/++MPRkImIiIiIiIi8liQTBCdOnED//v2xc+dO6PV6t1x/5coVdOnSBffccw++/PJLvP322zh//jzGjh3rbPhEREREREREXkfp6QBMnT17FrNnz0ZYWBhUKpXbrhdFESNHjsTQoUMxYcIEY3leXh7q16/vUOxERERERERE3kxSIwiaN2+OLVu2YO3atejSpYvbrl+/fj2OHDmCxx9/3Kx8//792Lt3r93PS0REREREROTtJJUgqClr1qyBWq3Gbbfd5ulQiIiIiIiIiCRBUlMMaoIoiti1axfq1auH06dPY+3atSgpKcE///yD0aNHY9KkSQ7VKwgCsrKyAACBgYGQyWSuDJuIiIiIiIjIjCiKKCoqAgBERkZCLnduDIDPJQiys7NRXFwMjUaDb7/9FosXLwYAZGZmokWLFsjKysLTTz9d6fUrVqzAihUrLMp1Oh0yMjLcFjcRERERERFRZTIyMhAVFeVUHT6XICjf1SA9PR1jxowxlterVw+DBg3C888/jwkTJlT6H5ufn4/U1NQaiZWIiIiIiIiopvhcgiAiIgIAEBQUhMTERLNjDRs2RGlpKX766adKpxqEhoYiNjbWolyv1yM9PR2AIXMTFBTk4siJiIiIiIiIbiksLER0dDQAw1R3Z/lcgkCpVCIqKgr+/v4W6wT4+/sDAK5du1bp9UlJSUhKSrIoLywsRHBw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6aefxvTp09GyZUtXxklEREREREREbuTwGgR79uzB7bffjm+//RYnTpwwVCaXY/HixXj33Xdx7NgxV8VIRERERERERG7mcIJg6dKl+P7775GSkoL27dsbywMDA/H2229jzZo1roiPiIiIiIiIiGqAw4sUNm3aFH379gUAi0X9lEol5HLHcg95eXmYO3cuBEFATEwMzpw5g2nTpmHw4ME2XX/s2DF88MEH8PPzg06nw6VLlzBt2jSMHj26yutOnz6NcePGceQDERERERER+SSHEwT+/v7G+9aWMUhLS7O7TkEQMGLECLRo0QIrV64EAKSkpKBNmzZYv359tUmCkydP4oUXXsD69esRGBgIAPjiiy/w4IMPYsmSJXjuuecqfd5p06YhLy/P7phtlZ6ejtdffx2tW7fGtGnT3PY8RERERERERID9/VCHpxhkZ2fjwoULAMxHEAiCgDfffBMBAQF217l27Vrs3r0bc+bMMZY1btwYw4cPx6xZs6wmIkx99tln+OGHH/DJJ58Yy4YPHw4AePXVVyu97v3338fFixftjtcW6enpSEpKQpMmTfDmm29i4cKFKC0tdctzERERERERETnaD3V4BMGsWbNw99134/7778f58+fx0ksv4fLly/jpp5+g0Wjw559/2l3nunXrEB0djWbNmpmV9+jRA2vXrsXBgwfRpUuXSq/v0KEDgoODUbduXWNZfn4+ABhHFFSUkpKC9PR0tGzZEpcuXbI75sqUZ2o+/PBDlJSUGMtzcnJw+PBhdOvWzWXPRURERERERORsP9ThBEH79u3x1VdfYcqUKTh//jy2bdsGAGjdujW+/PJLNGrUyO46Dx06hLi4OIvy2NhY4/GqEgTjx4/H+PHjLeoEgMmTJ1u9ZvHixVixYgWGDBlid7ymRFFEUVERMjIy8O677+Kjjz4yaxC1Wo0ZM2Zg7ty5iImJceq5iIiIiIiIiFzdD3U4QQAA3bt3x9mzZ/H777/jypUriI+Pr7IDX5XCwkJkZmaiVatWFsdCQkIAGLIh9sjPz8fLL7+MUaNGYeHChRbHV69ejREjRiA4ONihmE1dvHgRCQkJFuVMDBAREREREZE7uLof6vAaBOVkMhnuvvtujBkzxiw5sHbtWrvqKZ8KEBQUZHGsvAOfm5trU12//PILZs2ahb59+yIxMRH//e9/zRZVBIDr16/j8OHD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Ek+HYEGKMdUkLr5GRERERES1id1rEAQGBuKtt97C5MmTMWnSJJcGEx0dXe3Ig8jISFy4cMGiPCIiAj///LPNz9WhQwezKRNSx2+FiYiIiIiIyJ2s7y1YjejoaHzxxRdVnpOVleVQQERERERERERU8xzexSAiIqLK4w888AB27drlaPVUAee7ExERERERkTs5nCAAgD179uDgwYMWiwFqtVocOXLEqcDIHOe7ExERERERkTs5nCB444038Oyzz1Z6vHzXASIiIiIyJ4qicdclVygqKrJ63xXUajU/1xER+QiHEwRbt27F4cOH0bZtW/j5+Zkd02q1aNeundPBEREREdVGxcXFaNasmVvqdvVnsOTkZAQGBrq0TiIikiaHEwR33nknOnToYPWYn58f/u///s/hoIiIiIiIiIioZjmcIKhuqJm7suJEREREtQkXIiYiIqlwOEEwceJEPPfcc3juuecQGhpqcfz5559H//79nQqOiIiIqLbjQsRERCQVNiUIxowZg8zMTIvyzMxMvPnmm2jatCkCAm79YdNqtThz5ozroiQiIiIiIiIit7IpQXD69GkUFBSgSZMmZuWRkZGIjIy0OF+r1XK1WyIiIiIiIiIvYlOCIDw8HDt27EBUVJTNFXfu3NnhoIiIiIiIiIioZsltOWnBggV2JQcAYMmSJQ4FREREREREREQ1z6YEQd++fS3KVq1ahR9++KHSa+69916cO3cO3333HbKzsx2PkIiIiIiIiIjczqYEgTWff/45lMrKZyhs3LgR7dq1w+LFi9G1a1fk5+c7+lRERERERERE5GYOJwg6deqEtm3bYsGCBXjhhReQmppqdnzevHl49dVXcejQISxfvhzvvvuu08ESERERERERkXvYtEihNS1btkSLFi1QVFQEAPj0009x7Ngx1KtXD1lZWbh48SLuu+8+AMDQoUPx/fffuyZiIiIiIiIiInI5h0cQ7NixA19//TUKCwuRnZ2NuXPn4u233wYApKWlQSaToWHDhsbzQ0JCnI+WiIiIiIiIiNzC4QRBo0aNMGDAAKjVatStWxezZs1CcXExACA3NxcAoFarjecrFAonQyUiIiIiIiIid3E4QVBSUmL2WBAECIIAABBF0eJ8nU7n6FMRERERERERkZs5vAaBXC7HhAkT0L17dxQXF+N///sfpk+fDgDYsmULRFFESkoKGjdujPT0dGRlZbksaCIiIiIiIiJyLYcTBAsXLsTw4cMxY8YMyGQyTJ8+Hf/88w969eqF4OBgfPvtt5g0aRJmzZqFlStXYubMma6Mm4iIiIiIfIROU1L9SR4g1biIHOVwgiAsLAy7du3CsWPHEBoaiqZNm1qck5WVhYULF2L06NHo37+/U4ESEREREZFv+valCZ4OgcgnOJwgKNe+fftKj02dOhVTp0519imIiIiIiIiIyM2cThBUZuzYsVi7dq27qiciIiIiIh8xcsHnUKoCPB2GBZ2mhKMbJKyoqMildbiiPlNqtRoymcyldTrLpgTB77//jsuXL2PMmDEAgAsXLuCLL76o9HydToctW7a4JkIiIiIiIvJpSlWAJBMEJG3t2rWTdH3JyckIDAx0aZ3OsilBMHToUOTm5uLOO+9E06ZNcf36dSxcuLDKa6SWCSEiIiIiqowoiiguLnZZfe781hGQ5jePROT9bEoQPPvsszh//jzi4+MBAOHh4WjTpg3279+PkJAQi/O1Wi3atm3r0kCJiIiIiNyluLgYzZo1c0vdrv7WEZDmN4/kW6S6g4NpXD92745wlcqD0Vgq1uvRe/duT4dRKZsSBHPnzjV73KBBA8yZM8dqcgAA/Pz8MG3aNOejIyIiIpeS4gc6KcZERERV84a1F9QKBQIVblt2r1Zy6H8rODgYkyZNMj4uKioyZjBLSkoQEBCAOXPmuCZCIiIichlv+EBH5GlcEI+IfJVT6ZRFixZh+fLl6NixI3799VcIgoB58+YhNjbWYtQBERH5Hil+MyzFmIhIWrggHpF1arUaycnJLq2zqKjIOA3n+PHjTk+dMa0vQC53Oj5f43CCYOnSpfjiiy/w1FNP4fr16wAAuVyOt956C99//z0++eQTPPbYYy4LlIioOlLs+EkxpprEb7qkR4rfjPJbUSIi7yCTydy69kVgYKBL6+dCnvZzOEGwb98+HD16FGq1Gi+99JLZsaFDh3IEARHVOHYwiKrHb0aJiIioMg4nCFq2bAm1Wg3AemamtLTU8aiIvIAUvxmWYkzk2/htNREREZH3cDhBUFBQYLwviqLZseLiYly4cMHxqIi8ADsY0sPOqPTw22oiIiIi7+FwgqBu3bp44403kJSUZBxBIAgCfvrpJyxatAgPPvigy4IkIrIFO6NERERERI5zOEHw4osvolevXli8eDH8/f3x2WefIS0tDVqtFv369cPMmTNdGSeR5PDbaiIiIiIqV1RU5NI6XFGfKbVazUX7qFoOJwjUajV+++03vPrqq/jyyy9x5coVNGnSBI888giSkpIg55YSVMvx22oiIiIiKle+tZ5U60tOTnbrDgRUOzicIAAAf39/LFiwAAsWLHBVPERERERERETkATYlCO655x789ttv7o6FiIiIiIjIK/3YvTvCVSpPh2GmWK9H7927PR0GeRGbEgQHDhzAgQMHcNddd7k7HiIiIiKfIsUtaqUYE5HUqRUKBCqcGqBN5HE2/QTrdDrMnz8fDRo0QNeuXfHAAw8gOjra3bERERER1XpcXJaIiKTCpgRBbGwsduzYAcAwmuCNN95AZmYmunfvjlGjRiE8PNytQRIRERERERGRe9mUIHj77beN9++66y7jVIO9e/di0aJFuHHjBu655x6MHDkSoaGh7omUiIiIqBbitrlERCQVNiUI7r//fqvl3bt3R/fu3SGKInbv3o25c+fi+vXrGDNmDIYOHYqgoCCXBuvLpDgXUIoxEREReRtum0tERFLh9CoaWq0WP//8M/73v//h+++/R0FBATZt2oTWrVvj1KlTroiRwPmJRERERERE5F5yW0568803zR7r9Xr8/PPPmDJlCqKiojBixAisW7cOSqUSkydPxk8//YTjx4+7JWAiIiIiIiIicj2bRhCsWbMGs2fPxo4dO7B+/Xp88803yMnJgSiKCAkJwdixYzFmzBgMGDAAfn5+7o7ZZ6jVaiQnJ7usvqKiIrRr1w4AcPz4cQQGBrqsbrVa7bK6iIiIiIiIqObZlCA4fvw46tati/z8fACGzuDo0aMxZswYDBo0CP7+/m4N0lfJZDKXduJNBQYGuq1uIiIiIiIi8j42r0FQVFSEvn37IjU1FRMmTMCUKVMQHR3tztiIiIiIiIiIqIbYlCCIjo7GyZMnERkZCQD4448/8MYbb+D69evo0aMHRo0ahfDwcLcGSkRERERERETuY1OCoEuXLsbkQPnjLl26AAD27NmDV155BTdu3ECvXr0wcuRIhISEuCdaIiIiIiIiInILm3Yx+O677yo91qNHD7z55pt499138ccffyAmJgajRo2q8hoiIiIiIiIikhab1yCwRqvVYuvWrVi/fj02b96MgoICiKKIXbt2oUGDBhgxYoSLwiQiIiIi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XXK9s89DREREREREVNvIRAeWOszIyMDkyZPx008/uTSY9evX46GHHkJKSgoaNWpkLO/Xrx+Sk5Nx8eJF49D9tLQ0hIaGmi02aOv19jwPERERERERkS9wKEEAANnZ2YiIiKj0eFZWlt1zIDQaDTp06IBu3brh448/BgAcP34cHTp0wKZNmzBkyBAAwMWLF9GqVSskJCTg9OnTdl9v63lEREREREREvsLhBEF1evXqhV27dtl9XUZGBubOnQuZTIaoqCgcOXIEjz/+OB588EHjOVlZWejcuTNatWqFLVu22H29PecRERERERER+QKnEgR79uzBwYMHUVhYaFau1Wrx1ltv4ebNm04HSERERERERETuZ/MihRUtW7YMzzzzTKXHOYefiIiIiIiIyHvIHb3w559/xuHDh1FaWgpBEMz+lZaWokWLFq6Ms1J6vR59+vTBlStX7LouLy8Pjz76KKZOnYrnn38eI0eOtJiuQEREREREROQrHB5B0LlzZ3To0MHqMT8/Pzz66KMOB2WrEydOYPbs2di5cyf0er3N1wmCgBEjRqBFixZYuXIlACAlJQVt2rTB+vXrMXjwYHeFTERERERERCRJDicI5PKqBx/ccccdjlZdrbNnz2L27NkICwuDSqWy+/q1a9di9+7dxuQAADRu3BjDhw/HrFmzMGjQIE6RICIiIiIiIp/i8BSDMWPGYOHChSgpKbF6fN68eQ4HVZ3mzZtjy5YtWLt2Lbp06WL39evWrUN0dDSaNWtmVt6jRw+cO3cOBw8edFWoRERERERERF7B4REE7777Li5evIj69eujVatWCAgIMB7TarU4fPiwSwJ0h0OHDiEuLs6iPDY21njc3sSDIAjIysoCAAQGBnIEAhEREREREbmVKIooKioCAERGRlY70r86DicINm3ahNDQULRv394YmGmQUlVYWIjMzEy0atXK4lhISAgAID09vdLrV6xYgRUrVliU63Q6ZGRkuC5QIiIiIiIiIhtlZGQgKirKqTocThA0bNgQ+/fvh7+/v9XjnTt3djgod8rPzwcABAUFWRwLDg4GAOTm5lZ5fWpqqnuCIyIiIiIiIvIQhxMEr732WqXJAQBYsmSJo1W7lUKhAGB9kUWNRgPAMEWiMqGhocapCKb0er1x5EFGRobVBAQRERERERGRqxQWFiI6OhqAYaq7sxxOENx7770A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tspFEp293homCIiIiIiIiKgmubof6vAihZs2bcKlS5fQvn17+Pv7QxRFs3/utG7dOkRHR5t17gGgR48eOHfuHA4ePOjW64mIiIiIiIhqG4fXIGjYsCH2798Pf39/q8c7d+7scFDVOXToEOLi4izKY2Njjce7dOnituuJiIiIiIiIahuHEwSvvfZapckBAFiyZImjVVepsLAQmZmZaNWqlcWxkJAQAEB6errbrq+M6aiJwsJCu68nIiIiIiIisodp39MVI/kdThDce++9VR63dw6/rfLz8wHA6tyK8rkXubm5brt+xYoVWLFihUW56XoL0dHRlV5PRERERERE5GpFRUXGPq2jHE4QVEWv12PmzJk4deqUy+tWKBQArG+zqNFoABgWSXTX9fn5+UhNTbU9YCIiIiIiIiIvYFOC4IEHHsCZM2dw8OBBBAcHY+fOndWOIHCXiIgIq517wLBqI3BrqoA7rg8NDTWuVWBKEAQIgoAZM2bg6aefdtsICqlp1qwZ0tLSUL9+fSQnJ3s6HALbRIrYJtLDNpEeton0sE2kie0iPWwT6fGlNhFFEUVFRQCAyMhIp+uzKUFw7NgxXLt2DQUFBQgODkZ4eDgCAgIwY8YMq51pjUaDt99+2+ngrFEoFIiKirI6DaC8gx8fH++265OSkpCUlGRf0LVYebJFLpdza0eJYJtID9tEetgm0sM2kR62iTSxXaSHbSI9vtYmzk4rMGVTguDgwYPIz89HTEwMAMO38D179sSyZcsqvebAgQOuidCK3r17Y+/evRblZ8+eBQB07NjRrdcTERERERER1TbWx9pXEB4ebvatesOGDfHtt99Wec2XX37pVGBVGT58OK5cuYLLly+blW/fvh2NGzdG165djWVpaWkWuwrYcz0RERERERGRL7ApQWCN6RaHKSkpFsfLRxu4w8iRI9GmTRssXrzYWHb8+HHs2LED7733nnH+/8WLF9GkSRN07tzZoeuJiIiIiIiIfIVLdjF45JFHsH37dldUZROVSoXt27dj7ty5mDRpEqKionDkyBGsW7cOQ4YMMZ4XEhKCBg0aWKwpYOv1RERERERERL7CpgTBQw89hOvXr5uVde3a1fgN/LVr19ClSxezBSBatmyJDz74wIWhmouOjsaaNWuqPCcyMhIXLlxw+HoiIiIiIiIiX2FTguCtt97CuHHjsG/fPkyZ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3bt3C5lXCdik/6mrq8P169fh5uaG4cOHix6HwCYyYpP/D+9iQERERH1Oo9HA39//kfstLCzg4uLSbdvx48f7eixFY5P+x8XFpUcTEotN5MMm/x8uEBAREVGfi46ORmBgIF5++WU4OTkBAEpKShAeHv7Qx3d0dODSpUvmHFFx2ISIiB7EuxgQERFRn5s5cyYOHToEAKiqqkJVVRUMBsMjP+4d0k59h02IiOhBvAYBERERCTFjxgwcO3bskfuDg4NRUlJixomITYiIlI1LwURERCREQkLCY/enpKSYaRK6h02IiJSNRxAQEREREREREY8gICIiIiIiIiIuEBARERERERERuEBAREREREREROACARERET2BwsJChIaGYuDAgVCpVFCpVPDw8MDkyZORn58vejwiIiIyAV6kkIiIiJ7Y559/jhkzZuDFF1/k7e6IiIh+YngEARERET0xa2trAICtra3gSYiIiMjUuEBARERERERERFwgICIiIiIiIiLAUvQARERE9NNkMBjw3nvv4fvvv4dOp4NGo4GTkxM2b96MQYMGAQDq6uowd+5cnD17FlqtFn5+fsjLy8MvfvELHD16FK+++ira29sRGBiIs2fPwtraGlqtFrt27UJ5eTkcHR1RWVkJLy8vbN26FTY2Nnj77beRmZmJuro6pKSkoLm5GefPn0dZWRk+//xzDBs2TPBvhoiISE68SCERERE9saKiIoSFhWHSpEkoKip67GMPHjyIRYsW4a9//SsiIyMBANHR0bh+/TpOnToFtfp/BzKmpaVhxYoV+OqrrzB27Fjj9q1bt8LOzg7x8fEA7i46zJkzB66urkhPTwcA6HQ6TJ48GZ6envjwww8BAJcvX4avry9CQ0Px9ttvo7KyEgsWLMCxY8cwffp0U/5KiIiIfjJ4igERERH1iaFDh2LEiBHGCxsCQExMDE6fPo3z5893e2xMTAwGDRqEzMzMbtsrKiqwcuVK49cHDhzA0aNH8dZbbxm3WVhYYOHChdi/fz8aGxsBAD4+PgAArVaL4OBgvPrqq7hy5QoXB4iIiB6DpxgQERGRSV24cAFeXl6IiIjA1atXcf78eSQnJ+PmzZtoamoCALS0tHT7Hnt7eyxcuBAfffQRduzYgYEDB6K8vBzPP/88LC3/93QlKysLlpaWxqMH7mlubsakSZNw69YtODo6GrePGjXK+Lm3t3df/LhEREQ/GVwgICIiIpPau3cvdu7cCY1Gg5iYGNTX1yMtLQ0hISEoKirCgQMHHvp9y5YtQ1paGg4cOIDly5cjIyMD69at6/aY7777Dnq9Hm+++SYsLCx+dBZXV1eT/ExERERKwFMMiIiIyKQuX74MOzs7zJs3D6Wlpfjiiy8QEhLS43EtLS2or683fu3v74+wsDDs3bsXt2/fRmtra48X+B4eHtDr9bhx40aPP0+v1+PBSyupVCoT/VREREQ/fVwgICIiIpP59ttvUV9fj1u3buH06dMIDQ3FkCFDjPs1Go3x83/+858oKCjo9v3Lly9HWVkZ4uLiEB0d3ePPj42NBQB88sknPfYlJyfj+vXrJvpJiIiIlIcLBERERPTEOjo6ANx9t/5Bly9fxiuvvAI3NzfY29vDxcUFZWVl6OrqAgDcvn0bBQUFsLS0RFNTE+rr6+Hu7t7tz5g9ezbc3d1x/vx5TJo0qcff8Zvf/AaLFy/GX/7yFzQ0NBi3FxcXo7m5GR4eHgBg/DvvzUtEREQ/jrc5JCIioh9VWFiI5ORklJaW4vbt2xgwYAB+9atfwcrKClqtFrW1tfjmm29gMBgQGxuLzMxMfPPNN9i0aRMMBgNGjx4Ng8GAP/zhD/jggw+Qk5ODuXPnIikpqce1BJKSkuDs7Izly5c/cp4PP/wQubm58PDwgJ2dHZydnREfHw9LS0vs3r0bGRkZKC8vh6WlJcaOHYvXX3/9oUckEBER0f9wgYCIiIikEhcXh507d2LgwIGiRyEiIlIUnmJAREREwhgMBmzduhVffvklAKC2thYDBw7k4gAREZEAXCAgIiIiYVpaWrB582bk5uYCuHuhwQdvbUhERETmwVMMiIiISKiUlBTcvHkT7e3tiImJwYsvvih6JCIiIkXiAgERERERERER8RQDIiIiIiIiIuICARERERERERGBCwREREREREREBC4QEBERERERERG4QEBERERERERE4AIBEREREREREYELBEREREREREQELhAQEREREREREbhAQEREREREREQA/gM3llhkhGS/xwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1200x450 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import rcParams\n",
    "\n",
    "\n",
    "def gini_idx(param):\n",
    "    param = param.detach().abs()\n",
    "    sorted, indices = torch.sort(param.view(-1))\n",
    "\n",
    "    sortedidx = torch.arange(0, sorted.numel(), 1).to(param.device)\n",
    "\n",
    "    gini_numerator = 2 * (sorted * sortedidx).sum()\n",
    "    gini_denominator = sorted.numel() * sorted.sum()\n",
    "    gini_addendum = (sorted.numel() + 1) / sorted.numel()\n",
    "\n",
    "    return gini_numerator / gini_denominator - gini_addendum\n",
    "\n",
    "\n",
    "def compute_weight_distribution(layers):\n",
    "    percentiles = {}\n",
    "\n",
    "    for name, layer in layers:\n",
    "        perc = []\n",
    "        for q in [0.0, 0.25, 0.5, 0.75, 1.0]:\n",
    "            layerdata = layer.weight.data.abs().view(-1)\n",
    "            kth = torch.kthvalue(\n",
    "                layerdata, torch.arange(1, layerdata.numel() + 1)[int(q * (layerdata.numel() - 1))]\n",
    "            ).values\n",
    "            perc.append(kth.item())\n",
    "\n",
    "        percentiles[name] = perc\n",
    "\n",
    "    return percentiles\n",
    "\n",
    "\n",
    "def compute_normed_weight_distribution(layers):\n",
    "    percentiles = {}\n",
    "\n",
    "    for name, layer in layers:\n",
    "        perc = []\n",
    "        for q in [0.0, 0.25, 0.5, 0.75, 1.0]:\n",
    "            layerdata = layer.weight.data.abs().view(-1) / layer.weight.data.abs().amax()\n",
    "            kth = torch.kthvalue(\n",
    "                layerdata, torch.arange(1, layerdata.numel() + 1)[int(q * (layerdata.numel() - 1))]\n",
    "            ).values\n",
    "            perc.append(kth.item())\n",
    "\n",
    "        percentiles[name] = perc\n",
    "\n",
    "    return percentiles\n",
    "\n",
    "\n",
    "def compute_gini_idx(layers):\n",
    "    ginis = {}\n",
    "\n",
    "    for name, layer in layers:\n",
    "        layerdata = layer.weight.data.abs().view(-1)\n",
    "        ginis[name] = gini_idx(layerdata).detach().cpu().numpy()\n",
    "\n",
    "    return ginis\n",
    "\n",
    "\n",
    "def compute_normed_gini_idx(layers):\n",
    "    ginis = {}\n",
    "\n",
    "    for name, layer in layers:\n",
    "        layerdata = layer.weight.data.abs().view(-1) / layer.weight.data.abs().amax()\n",
    "        ginis[name] = gini_idx(layerdata).detach().cpu().numpy()\n",
    "\n",
    "    return ginis\n",
    "\n",
    "\n",
    "def plot_barplot(perc, fname, colormap=\"Set1\"):\n",
    "    # fig = plt.figure(figsize=(15, 3))\n",
    "    fig, axes = plt.subplots(3, 1, figsize=(12, 4.5), sharex=True, height_ratios=[0.3, 2.7, 1.5])\n",
    "    fig.subplots_adjust(hspace=0.15)\n",
    "\n",
    "    colors = np.linspace(0, 1, 9)\n",
    "    palette = cm.get_cmap(colormap)(colors)\n",
    "    pastel = 0.3\n",
    "    palette = (1 - pastel) * palette + pastel * np.ones((9, 4))\n",
    "\n",
    "    LABELS = {\n",
    "        \"lfp-epsilon\": r\"LFP-$\\varepsilon$\",\n",
    "        \"lfp-zplus-zminus\": r\"LFP-$z^+z^-$\",\n",
    "        \"vanilla-gradient\": r\"Grad\",\n",
    "    }\n",
    "\n",
    "    yoffset = 0.0\n",
    "    y_cut_1 = None\n",
    "    y_cut_2 = None\n",
    "\n",
    "    quants = perc[\"quantiles\"]\n",
    "    gini = perc[\"gini\"]\n",
    "\n",
    "    # Get ycuts\n",
    "    for m, method in enumerate(methods):\n",
    "        q_means = {}\n",
    "        lr = investigated_lr\n",
    "        for s, seedarr in enumerate(quants[method][lr]):\n",
    "            for layer, quant in seedarr.items():\n",
    "                if layer not in q_means.keys():\n",
    "                    q_means[layer] = []\n",
    "                q_means[layer].append(quant)\n",
    "\n",
    "        for layer in q_means.keys():\n",
    "            q_means[layer] = np.mean(q_means[layer], axis=0)\n",
    "\n",
    "        yvals = np.array(list(q_means.values()))\n",
    "        q_75 = yvals[:, 3]\n",
    "        q_100 = yvals[:, 4]\n",
    "\n",
    "        y_cut_1 = np.max(q_75) if y_cut_1 is None else np.max([np.max(q_75), y_cut_1])\n",
    "        y_cut_2 = np.min(q_100) if y_cut_2 is None else np.min([np.min(q_100), y_cut_2])\n",
    "\n",
    "    y_cut_1 += 0.05 * y_cut_1\n",
    "    y_cut_2 -= 0.1 * y_cut_2\n",
    "    y_cut_2 = np.max([y_cut_1, y_cut_2])\n",
    "\n",
    "    # Plot\n",
    "    for m, method in enumerate(methods):\n",
    "        q_means = {}\n",
    "        gini_means = {}\n",
    "        lr = investigated_lr\n",
    "        for s, seedarr in enumerate(quants[method][lr]):\n",
    "            for layer, quant in seedarr.items():\n",
    "                if layer not in q_means.keys():\n",
    "                    q_means[layer] = []\n",
    "                    gini_means[layer] = []\n",
    "                q_means[layer].append(quant)\n",
    "                gini_means[layer].append(gini[method][lr][s][layer])\n",
    "\n",
    "        for layer in q_means.keys():\n",
    "            q_means[layer] = np.mean(q_means[layer], axis=0)\n",
    "            gini_means[layer] = np.mean(gini_means[layer], axis=0)\n",
    "\n",
    "        xticks = np.arange(len(list(q_means.keys())))\n",
    "        yvals = np.array(list(q_means.values()))\n",
    "        yvals_gini = np.array(list(gini_means.values()))\n",
    "        q_0 = yvals[:, 0]\n",
    "        q_25 = yvals[:, 1]\n",
    "        q_50 = yvals[:, 2]\n",
    "        q_75 = yvals[:, 3]\n",
    "        q_100 = yvals[:, 4]\n",
    "\n",
    "        width = 0.4 if m == 0 else -0.4\n",
    "\n",
    "        for a, ax in enumerate([axes[0], axes[1]]):\n",
    "            if a == 1:\n",
    "                drawfilter = np.ones_like(q_75) == 1\n",
    "            else:\n",
    "                drawfilter = q_75 >= y_cut_2\n",
    "            ax.bar(\n",
    "                xticks[drawfilter],\n",
    "                (q_75 - q_25)[drawfilter] + yoffset,\n",
    "                color=palette[m],\n",
    "                bottom=q_25[drawfilter] + yoffset,\n",
    "                edgecolor=(0.1, 0.1, 0.1, 1),\n",
    "                linewidth=1.5,\n",
    "                align=\"edge\",\n",
    "                width=width,\n",
    "            )\n",
    "\n",
    "            if a == 1:\n",
    "                drawfilter = np.ones_like(q_0) == 1\n",
    "            else:\n",
    "                drawfilter = q_0 >= y_cut_2\n",
    "            ax.hlines(\n",
    "                q_0[drawfilter] + yoffset,\n",
    "                xmin=xticks[drawfilter],\n",
    "                xmax=xticks[drawfilter] + width,\n",
    "                color=(0.1, 0.1, 0.1, 1),\n",
    "                linewidth=1.5,\n",
    "            )\n",
    "\n",
    "            if a == 1:\n",
    "                drawfilter = np.ones_like(q_100) == 1\n",
    "            else:\n",
    "                drawfilter = q_100 >= y_cut_2\n",
    "            ax.hlines(\n",
    "                q_100[drawfilter] + yoffset,\n",
    "                xmin=xticks[drawfilter],\n",
    "                xmax=xticks[drawfilter] + width,\n",
    "                color=(0.1, 0.1, 0.1, 1),\n",
    "                linewidth=1.5,\n",
    "            )\n",
    "\n",
    "            if a == 1:\n",
    "                drawfilter = np.ones_like(q_50) == 1\n",
    "            else:\n",
    "                drawfilter = q_50 >= y_cut_2\n",
    "            ax.hlines(\n",
    "                q_50[drawfilter] + yoffset,\n",
    "                xmin=xticks[drawfilter],\n",
    "                xmax=xticks[drawfilter] + width,\n",
    "                color=(0.1, 0.1, 0.1, 1),\n",
    "                linewidth=1.5,\n",
    "            )\n",
    "\n",
    "            ax.vlines(\n",
    "                xticks + width / 2, ymin=q_0 + yoffset, ymax=q_25 + yoffset, color=(0.1, 0.1, 0.1, 1), linewidth=1.5\n",
    "            )\n",
    "            ax.vlines(\n",
    "                xticks + width / 2, ymin=q_75 + yoffset, ymax=q_100 + yoffset, color=(0.1, 0.1, 0.1, 1), linewidth=1.5\n",
    "            )\n",
    "\n",
    "        axes[2].plot(yvals_gini, color=palette[m], marker=\"|\", linewidth=3, markersize=15, mew=3)\n",
    "\n",
    "    linelocs = [0.25, 0.5, 0.75]\n",
    "    axes[2].hlines(linelocs, xmin=-0.6, xmax=len(xticks) - 0.4, color=(0.5, 0.5, 0.5, 1), linewidth=1.5, zorder=0)\n",
    "\n",
    "    legend_handles = []\n",
    "    for m, method in enumerate(methods):\n",
    "        legend_handles.append(\n",
    "            axes[0].bar(\n",
    "                [-10], [0.01], color=palette[m], label=LABELS[method], edgecolor=(0.1, 0.1, 0.1, 1), linewidth=1.5\n",
    "            )\n",
    "        )\n",
    "\n",
    "    axes[1].legend(handles=legend_handles)\n",
    "    axes[2].set_xlabel(\"Layer\")\n",
    "    # axes[2].set_ylabel(\"Gini Coefficient\")\n",
    "    fig.text(\n",
    "        -0.08,\n",
    "        0.6,\n",
    "        \"Weight Magnitude\",\n",
    "        va=\"center\",\n",
    "        rotation=\"vertical\",\n",
    "        fontsize=rcParams[\"axes.labelsize\"],\n",
    "        transform=axes[1].transAxes,\n",
    "    )\n",
    "    fig.text(\n",
    "        -0.08,\n",
    "        0.5,\n",
    "        \"Gini Coefficient\",\n",
    "        va=\"center\",\n",
    "        rotation=\"vertical\",\n",
    "        fontsize=rcParams[\"axes.labelsize\"],\n",
    "        transform=axes[2].transAxes,\n",
    "    )\n",
    "    axes[2].set_xticks(xticks)\n",
    "    axes[2].set_xticklabels(list(q_means.keys()), rotation=90)\n",
    "\n",
    "    axes[0].set_xlim([-0.6, len(xticks) - 0.4])\n",
    "    axes[1].set_xlim([-0.6, len(xticks) - 0.4])\n",
    "    axes[2].set_xlim([-0.6, len(xticks) - 0.4])\n",
    "\n",
    "    axes[0].tick_params(axis=\"y\", length=6, width=2)\n",
    "    axes[0].tick_params(axis=\"x\", length=0, width=0)\n",
    "    axes[1].tick_params(axis=\"y\", length=6, width=2)\n",
    "    axes[1].tick_params(axis=\"x\", length=0, width=0)\n",
    "    # axes[1].tick_params(length=6, width=2)\n",
    "    axes[2].tick_params(length=6, width=2)\n",
    "\n",
    "    axes[0].set_ylim([y_cut_2, axes[0].get_ylim()[1] + 0.1 * axes[1].get_ylim()[1]])\n",
    "    # axes[1].set_ylim([y_cut_1, y_cut_2])\n",
    "    axes[1].set_ylim([0, y_cut_1])\n",
    "    axes[2].set_ylim([0, 1])\n",
    "\n",
    "    axes[0].spines.bottom.set_visible(False)\n",
    "    # axes[0].spines.top.set_visible(False)\n",
    "    # axes[1].spines.bottom.set_visible(False)\n",
    "    # axes[1].spines.top.set_visible(False)\n",
    "    axes[1].spines.top.set_visible(False)\n",
    "    axes[1].xaxis.tick_bottom()\n",
    "\n",
    "    axes[0].set_yticks([np.round(axes[0].get_ylim()[0], decimals=2), np.round(axes[0].get_ylim()[1], decimals=2)])\n",
    "    axes[1].set_yticks(\n",
    "        [\n",
    "            np.round(axes[1].get_ylim()[0], decimals=2),\n",
    "            np.round((axes[1].get_ylim()[1] - axes[1].get_ylim()[0]) / 2, decimals=2),\n",
    "            np.round(axes[1].get_ylim()[1], decimals=2),\n",
    "        ]\n",
    "    )\n",
    "    # axes[1].set_yticks([0])\n",
    "    axes[2].set_yticks([0, 0.5, 1.0])\n",
    "\n",
    "    d = 0.5  # proportion of vertical to horizontal extent of the slanted line\n",
    "    kwargs = dict(marker=[(-1, -d), (1, d)], markersize=12, linestyle=\"none\", color=\"k\", mec=\"k\", mew=2, clip_on=False)\n",
    "    axes[0].plot([0, 1], [0, 0], transform=axes[0].transAxes, **kwargs)\n",
    "    # axes[1].plot([0, 1], [0, 0], transform=axes[1].transAxes, **kwargs)\n",
    "    # axes[1].plot([0, 1], [1, 1], transform=axes[1].transAxes, **kwargs)\n",
    "    axes[1].plot([0, 1], [1, 1], transform=axes[1].transAxes, **kwargs)\n",
    "\n",
    "    plt.show()\n",
    "    fn = fname.split(\".svg\")[0]\n",
    "    fig.savefig(f\"{fn}-{method}.svg\")\n",
    "\n",
    "\n",
    "p_rel_file = os.path.join(savepath, f\"{dataset_name_base}-w_dist-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\")\n",
    "if not os.path.exists(p_rel_file) or recompute_pruning:\n",
    "    p_rel = {\"quantiles\": {}, \"gini\": {}}\n",
    "    lr = investigated_lr\n",
    "    for name in transfer_wrappers[lr].keys():\n",
    "        if name not in p_rel[\"quantiles\"].keys():\n",
    "            p_rel[\"quantiles\"][name] = {}\n",
    "            p_rel[\"gini\"][name] = {}\n",
    "        if lr not in p_rel[\"quantiles\"][name].keys():\n",
    "            p_rel[\"quantiles\"][name][lr] = []\n",
    "            p_rel[\"gini\"][name][lr] = []\n",
    "\n",
    "        for seed in seeds:\n",
    "            transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "            layers = [\n",
    "                (n, m) for n, m in transfer_wrappers[lr][name][seed][0].model.named_modules() if hasattr(m, \"weight\")\n",
    "            ]\n",
    "            parameter_rel = compute_weight_distribution(layers)\n",
    "            gini = compute_gini_idx(layers)\n",
    "            transfer_wrappers[lr][name][seed][0].remove()\n",
    "            p_rel[\"quantiles\"][name][lr].append(parameter_rel)\n",
    "            p_rel[\"gini\"][name][lr].append(gini)\n",
    "    joblib.dump(p_rel, p_rel_file)\n",
    "else:\n",
    "    p_rel = joblib.load(p_rel_file)\n",
    "\n",
    "fname = os.path.join(savepath, f\"{dataset_name_base}-w_dist-{investigated_ep_lfp}-{investigated_ep_grad}.svg\")\n",
    "plot_barplot(p_rel, fname)\n",
    "\n",
    "p_rel_file = os.path.join(\n",
    "    savepath, f\"{dataset_name_base}-w_dist_canonized-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\"\n",
    ")\n",
    "if not os.path.exists(p_rel_file) or recompute_pruning:\n",
    "    p_rel = {\"quantiles\": {}, \"gini\": {}}\n",
    "    lr = investigated_lr\n",
    "    for name in transfer_wrappers[lr].keys():\n",
    "        if name not in p_rel[\"quantiles\"].keys():\n",
    "            p_rel[\"quantiles\"][name] = {}\n",
    "            p_rel[\"gini\"][name] = {}\n",
    "        if lr not in p_rel[\"quantiles\"][name].keys():\n",
    "            p_rel[\"quantiles\"][name][lr] = []\n",
    "            p_rel[\"gini\"][name][lr] = []\n",
    "\n",
    "        for seed in seeds:\n",
    "            transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "            canon = zcanon.SequentialMergeBatchNorm()\n",
    "            handles = canon.apply(transfer_wrappers[lr][name][seed][0].model)\n",
    "            layers = [\n",
    "                (n, m)\n",
    "                for n, m in transfer_wrappers[lr][name][seed][0].model.named_modules()\n",
    "                if hasattr(m, \"weight\") and not isinstance(m, torch.nn.BatchNorm2d)\n",
    "            ]\n",
    "            parameter_rel = compute_weight_distribution(layers)\n",
    "            gini = compute_gini_idx(layers)\n",
    "            for handle in handles:\n",
    "                handle.remove()\n",
    "            transfer_wrappers[lr][name][seed][0].remove()\n",
    "            p_rel[\"quantiles\"][name][lr].append(parameter_rel)\n",
    "            p_rel[\"gini\"][name][lr].append(gini)\n",
    "    joblib.dump(p_rel, p_rel_file)\n",
    "else:\n",
    "    p_rel = joblib.load(p_rel_file)\n",
    "\n",
    "fname = os.path.join(savepath, f\"{dataset_name_base}-w_dist_canonized-{investigated_ep_lfp}-{investigated_ep_grad}.svg\")\n",
    "plot_barplot(p_rel, fname)\n",
    "\n",
    "p_rel_file = os.path.join(\n",
    "    savepath, f\"{dataset_name_base}-w_dist_normed-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\"\n",
    ")\n",
    "if not os.path.exists(p_rel_file) or recompute_pruning:\n",
    "    p_rel = {\"quantiles\": {}, \"gini\": {}}\n",
    "    lr = investigated_lr\n",
    "    for name in transfer_wrappers[lr].keys():\n",
    "        if name not in p_rel[\"quantiles\"].keys():\n",
    "            p_rel[\"quantiles\"][name] = {}\n",
    "            p_rel[\"gini\"][name] = {}\n",
    "        if lr not in p_rel[\"quantiles\"][name].keys():\n",
    "            p_rel[\"quantiles\"][name][lr] = []\n",
    "            p_rel[\"gini\"][name][lr] = []\n",
    "\n",
    "        for seed in seeds:\n",
    "            transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "            layers = [\n",
    "                (n, m) for n, m in transfer_wrappers[lr][name][seed][0].model.named_modules() if hasattr(m, \"weight\")\n",
    "            ]\n",
    "            parameter_rel = compute_normed_weight_distribution(layers)\n",
    "            gini = compute_normed_gini_idx(layers)\n",
    "            transfer_wrappers[lr][name][seed][0].remove()\n",
    "            p_rel[\"quantiles\"][name][lr].append(parameter_rel)\n",
    "            p_rel[\"gini\"][name][lr].append(gini)\n",
    "    joblib.dump(p_rel, p_rel_file)\n",
    "else:\n",
    "    p_rel = joblib.load(p_rel_file)\n",
    "\n",
    "fname = os.path.join(savepath, f\"{dataset_name_base}-w_dist_normed-{investigated_ep_lfp}-{investigated_ep_grad}.svg\")\n",
    "plot_barplot(p_rel, fname)\n",
    "\n",
    "p_rel_file = os.path.join(\n",
    "    savepath, f\"{dataset_name_base}-w_dist_normed_canonized-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\"\n",
    ")\n",
    "if not os.path.exists(p_rel_file) or recompute_pruning:\n",
    "    p_rel = {\"quantiles\": {}, \"gini\": {}}\n",
    "    lr = investigated_lr\n",
    "    for name in transfer_wrappers[lr].keys():\n",
    "        if name not in p_rel[\"quantiles\"].keys():\n",
    "            p_rel[\"quantiles\"][name] = {}\n",
    "            p_rel[\"gini\"][name] = {}\n",
    "        if lr not in p_rel[\"quantiles\"][name].keys():\n",
    "            p_rel[\"quantiles\"][name][lr] = []\n",
    "            p_rel[\"gini\"][name][lr] = []\n",
    "\n",
    "        for seed in seeds:\n",
    "            transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "            canon = zcanon.SequentialMergeBatchNorm()\n",
    "            handles = canon.apply(transfer_wrappers[lr][name][seed][0].model)\n",
    "            layers = [\n",
    "                (n, m)\n",
    "                for n, m in transfer_wrappers[lr][name][seed][0].model.named_modules()\n",
    "                if hasattr(m, \"weight\") and not isinstance(m, torch.nn.BatchNorm2d)\n",
    "            ]\n",
    "            parameter_rel = compute_normed_weight_distribution(layers)\n",
    "            gini = compute_normed_gini_idx(layers)\n",
    "            for handle in handles:\n",
    "                handle.remove()\n",
    "            transfer_wrappers[lr][name][seed][0].remove()\n",
    "            p_rel[\"quantiles\"][name][lr].append(parameter_rel)\n",
    "            p_rel[\"gini\"][name][lr].append(gini)\n",
    "    joblib.dump(p_rel, p_rel_file)\n",
    "else:\n",
    "    p_rel = joblib.load(p_rel_file)\n",
    "\n",
    "fname = os.path.join(\n",
    "    savepath, f\"{dataset_name_base}-w_dist_normed_canonized-{investigated_ep_lfp}-{investigated_ep_grad}.svg\"\n",
    ")\n",
    "plot_barplot(p_rel, fname)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Weight Pruning"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:22.008858Z",
     "iopub.status.busy": "2024-08-21T10:22:22.008686Z",
     "iopub.status.idle": "2024-08-21T10:22:22.032013Z",
     "shell.execute_reply": "2024-08-21T10:22:22.030997Z"
    },
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "def compute_aggregated_relevances(trainer, layers, composite, loader, device, num_classes):\n",
    "    for samples, labels in loader:\n",
    "        samples = samples.to(device)\n",
    "        labels = labels.to(device)\n",
    "\n",
    "        eye = torch.eye(num_classes, device=device)\n",
    "        one_hot = eye[labels]\n",
    "\n",
    "        with composite.context(trainer.model) as modified:\n",
    "            inputs = samples.detach().requires_grad_(True)\n",
    "\n",
    "            outputs = modified(inputs)\n",
    "\n",
    "            # Compute Relevance\n",
    "            torch.autograd.grad((outputs,), (inputs,), grad_outputs=(one_hot,), retain_graph=False)[0]\n",
    "\n",
    "        for layer in layers:\n",
    "            if not hasattr(layer, \"aggregated_param_relevances\"):\n",
    "                layer.aggregated_param_relevances = {k: 0 for k, _ in layer.param_relevances.items()}\n",
    "            for key, val in layer.param_relevances.items():\n",
    "                layer.aggregated_param_relevances[key] += val\n",
    "\n",
    "\n",
    "def get_prunemask(trainer, layers, p=0.05, criterion=\"min\", pruning_criterion=\"relevance\", structured=False):\n",
    "    if not hasattr(layers[0], \"aggregated_param_relevances\") and pruning_criterion == \"relevance\":\n",
    "        compute_aggregated_relevances(\n",
    "            trainer, layers, composite, relevance_loader, device, len(test_dataset_base.classes)\n",
    "        )\n",
    "\n",
    "    if structured:\n",
    "        crit_tensor = torch.cat(\n",
    "            [\n",
    "                layer.weight.data.abs().sum(dim=(1, 2, 3)).view(-1)\n",
    "                if pruning_criterion == \"weight\"\n",
    "                else layer.aggregated_param_relevances[\"weight\"].abs().sum(dim=(1, 2, 3)).view(-1)\n",
    "                for layer in layers\n",
    "            ]\n",
    "        )\n",
    "    else:\n",
    "        crit_tensor = torch.cat(\n",
    "            [\n",
    "                layer.weight.data.view(-1)\n",
    "                if pruning_criterion == \"weight\"\n",
    "                else layer.aggregated_param_relevances[\"weight\"].view(-1)\n",
    "                for layer in layers\n",
    "            ]\n",
    "        )\n",
    "\n",
    "    prune_mask = torch.ones_like(crit_tensor)\n",
    "    toprune = int(crit_tensor.numel() * p)\n",
    "\n",
    "    if criterion == \"min\":\n",
    "        topk = torch.topk(torch.abs(crit_tensor), k=toprune, largest=False)\n",
    "    else:\n",
    "        topk = torch.topk(torch.abs(crit_tensor), k=toprune, largest=True)\n",
    "\n",
    "    prune_mask[topk.indices] = 0\n",
    "\n",
    "    return prune_mask\n",
    "\n",
    "\n",
    "def get_prunemask_local(trainer, layers, p=0.05, criterion=\"min\", pruning_criterion=\"relevance\", structured=False):\n",
    "    if not hasattr(layers[0], \"aggregated_param_relevances\") and pruning_criterion == \"relevance\":\n",
    "        compute_aggregated_relevances(\n",
    "            trainer, layers, composite, relevance_loader, device, len(test_dataset_base.classes)\n",
    "        )\n",
    "\n",
    "    if structured:\n",
    "        crit_tensor = [\n",
    "            layer.weight.data.abs().sum(dim=(1, 2, 3)).view(-1)\n",
    "            if pruning_criterion == \"weight\"\n",
    "            else layer.aggregated_param_relevances[\"weight\"].abs().sum(dim=(1, 2, 3)).view(-1)\n",
    "            for layer in layers\n",
    "        ]\n",
    "    else:\n",
    "        crit_tensor = [\n",
    "            layer.weight.data.view(-1)\n",
    "            if pruning_criterion == \"weight\"\n",
    "            else layer.aggregated_param_relevances[\"weight\"].view(-1)\n",
    "            for layer in layers\n",
    "        ]\n",
    "\n",
    "    prune_mask = [torch.ones_like(c) for c in crit_tensor]\n",
    "\n",
    "    for l, layer in enumerate(layers):\n",
    "        toprune = int(crit_tensor[l].numel() * p)\n",
    "\n",
    "        if criterion == \"min\":\n",
    "            topk = torch.topk(torch.abs(crit_tensor[l]), k=toprune, largest=False)\n",
    "        else:\n",
    "            topk = torch.topk(torch.abs(crit_tensor[l]), k=toprune, largest=True)\n",
    "\n",
    "        prune_mask[l][topk.indices] = 0\n",
    "\n",
    "    return torch.cat(prune_mask)\n",
    "\n",
    "\n",
    "def get_prune_acc(trainer, layers, p=0.05, pruning_criterion=\"weight\", structured=False, mask_function=get_prunemask):\n",
    "    prune_rates = np.clip(np.arange(p, 1 + p, p), 0, 1)\n",
    "\n",
    "    res = trainer.eval(test_dataset_base, dataset_name_base)\n",
    "    prune_accs = [float(res[\"accuracy_p050\"]) if \"accuracy_p050\" in res.keys() else float(res[\"micro_accuracy_top1\"])]\n",
    "    print(\"Pruning...\")\n",
    "    with tqdm(total=len(prune_rates)) as pbar:\n",
    "        for rate in prune_rates:\n",
    "            prune_mask = mask_function(\n",
    "                trainer, layers, p=rate, criterion=\"min\", pruning_criterion=pruning_criterion, structured=structured\n",
    "            )\n",
    "            pointer = 0\n",
    "            for layer in layers:\n",
    "                if structured:\n",
    "                    numel = layer.weight.data.shape[0]\n",
    "                    layer.weight.data *= prune_mask[pointer : pointer + numel][:, None, None, None]\n",
    "                else:\n",
    "                    numel = layer.weight.data.numel()\n",
    "                    layer.weight.data *= prune_mask[pointer : pointer + numel].view_as(layer.weight.data)\n",
    "\n",
    "                pointer += numel\n",
    "            res = trainer.eval(test_dataset_base, dataset_name_base)\n",
    "            prune_accs.append(\n",
    "                float(res[\"accuracy_p050\"]) if \"accuracy_p050\" in res.keys() else float(res[\"micro_accuracy_top1\"])\n",
    "            )\n",
    "            pbar.update(1)\n",
    "\n",
    "    return prune_accs\n",
    "\n",
    "\n",
    "def plot_pruning_acc(p_accs, fname, colormap=\"Set1\", pruning_criterion=\"weight\"):\n",
    "    fig, ax = plt.subplots(1, 1, figsize=(3, 3))\n",
    "\n",
    "    colors = np.linspace(0, 1, 9)\n",
    "    palette = cm.get_cmap(colormap)(colors)\n",
    "    pastel = 0.3\n",
    "    palette = (1 - pastel) * palette + pastel * np.ones((9, 4))\n",
    "\n",
    "    LABELS = {\n",
    "        \"lfp-epsilon\": r\"LFP-$\\varepsilon$\",\n",
    "        \"lfp-zplus-zminus\": r\"LFP-$z^+z^-$\",\n",
    "        \"vanilla-gradient\": r\"Grad\",\n",
    "    }\n",
    "\n",
    "    for m, method in enumerate(methods):\n",
    "        accs = p_accs[method][investigated_lr]\n",
    "        plot_means = np.mean(accs, axis=0)\n",
    "        plot_stds = np.std(accs, axis=0)\n",
    "\n",
    "        # ax.plot(1-np.arange(0, 0.92, 0.9/20), plot_means, color=palette[m], label=LABELS[method], linewidth=3, alpha=1)\n",
    "        # ax.fill_between(1-np.arange(0, 0.92, 0.9/20), plot_means+plot_stds, plot_means-plot_stds, color=palette[m], alpha=0.2)\n",
    "        ax.plot(np.arange(0, 1 + 0.05, 0.05), plot_means, color=palette[m], label=LABELS[method], linewidth=3, alpha=1)\n",
    "        ax.fill_between(\n",
    "            np.arange(0, 1 + 0.05, 0.05), plot_means + plot_stds, plot_means - plot_stds, color=palette[m], alpha=0.2\n",
    "        )\n",
    "\n",
    "    ax.legend()\n",
    "    ax.set_ylim([0, 1])\n",
    "    # plt.gca().invert_xaxis()\n",
    "    # ax.set_xscale('log')\n",
    "\n",
    "    linelocs = [0.2, 0.4, 0.6, 0.8]\n",
    "    ax.hlines(linelocs, xmin=-0.05, xmax=1.5, color=(0.5, 0.5, 0.5, 1), linewidth=1.5, zorder=0)\n",
    "\n",
    "    # ax.set_xticks([0.1, 1.0])\n",
    "    # ax.xaxis.set_major_formatter(ticker.ScalarFormatter())\n",
    "    # ax.set_xticklabels([100, 0])\n",
    "    ax.set_xlim([0, 1])\n",
    "    ax.set_xticks([0.0, 0.2, 0.4, 0.6, 0.8, 1.0])\n",
    "    ax.set_xticklabels([0, 20, 40, 60, 80, 100])\n",
    "    ax.set_yticks([0.0, 0.2, 0.4, 0.6, 0.8, 1.0])\n",
    "    ax.set_yticklabels([0, 20, 40, 60, 80, 100])\n",
    "    ax.set_ylabel(\"Accuracy [%]\")\n",
    "    if pruning_criterion == \"weight\":\n",
    "        ax.set_xlabel(\"Smallest Weights Pruned [%]\")\n",
    "    else:\n",
    "        ax.set_xlabel(\"Smallest Relevances Pruned [%]\")\n",
    "    ax.tick_params(length=6, width=2)\n",
    "    plt.show()\n",
    "    fig.savefig(fname)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:22.035121Z",
     "iopub.status.busy": "2024-08-21T10:22:22.034495Z",
     "iopub.status.idle": "2024-08-21T10:22:22.232730Z",
     "shell.execute_reply": "2024-08-21T10:22:22.232152Z"
    },
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dict_keys(['vanilla-gradient', 'lfp-epsilon'])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_371758/787198864.py:103: MatplotlibDeprecationWarning: The get_cmap function was deprecated in Matplotlib 3.7 and will be removed two minor releases later. Use ``matplotlib.colormaps[name]`` or ``matplotlib.colormaps.get_cmap(obj)`` instead.\n",
      "  palette = cm.get_cmap(colormap)(colors)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_acc_file = os.path.join(\n",
    "    savepath,\n",
    "    f\"{dataset_name_base}-p_accs_weight_unstructured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\",\n",
    ")\n",
    "if not os.path.exists(p_acc_file) or recompute_pruning:\n",
    "    p_accs = {}\n",
    "    lr = investigated_lr\n",
    "    for name in transfer_wrappers[lr].keys():\n",
    "        print(name, lr)\n",
    "        if name not in p_accs.keys():\n",
    "            p_accs[name] = {}\n",
    "        if lr not in p_accs[name].keys():\n",
    "            p_accs[name][lr] = []\n",
    "\n",
    "        for seed in seeds:\n",
    "            transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "            canon = zcanon.SequentialMergeBatchNorm()\n",
    "            handles = canon.apply(transfer_wrappers[lr][name][seed][0].model)\n",
    "            layers = [\n",
    "                module\n",
    "                for module in transfer_wrappers[lr][name][seed][0].model.modules()\n",
    "                if hasattr(module, \"weight\") and isinstance(module, torch.nn.Conv2d)\n",
    "            ]\n",
    "            prune_acc = get_prune_acc(\n",
    "                transfer_wrappers[lr][name][seed][0],\n",
    "                layers,\n",
    "                p=0.05,\n",
    "                pruning_criterion=\"weight\",\n",
    "                structured=False,\n",
    "                mask_function=get_prunemask,\n",
    "            )\n",
    "            for handle in handles:\n",
    "                handle.remove()\n",
    "            transfer_wrappers[lr][name][seed][0].remove()\n",
    "            p_accs[name][lr].append(prune_acc)\n",
    "    joblib.dump(p_accs, p_acc_file)\n",
    "else:\n",
    "    p_accs = joblib.load(p_acc_file)\n",
    "\n",
    "print(p_accs.keys())\n",
    "\n",
    "fname = os.path.join(\n",
    "    savepath,\n",
    "    f\"{dataset_name_base}-pruning_accuracies_weight_unstructured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.svg\",\n",
    ")\n",
    "plot_pruning_acc(p_accs, fname, pruning_criterion=\"weight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:22.236256Z",
     "iopub.status.busy": "2024-08-21T10:22:22.236088Z",
     "iopub.status.idle": "2024-08-21T10:22:22.239318Z",
     "shell.execute_reply": "2024-08-21T10:22:22.238711Z"
    }
   },
   "outputs": [],
   "source": [
    "# p_acc_file = os.path.join(savepath, f\"{dataset_name_base}-p_accs_weight_structured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\")\n",
    "# if not os.path.exists(p_acc_file) or recompute_pruning:\n",
    "#     p_accs = {}\n",
    "#     lr = investigated_lr\n",
    "#     for name in transfer_wrappers[lr].keys():\n",
    "#         print(name, lr)\n",
    "#         if name not in p_accs.keys():\n",
    "#             p_accs[name] = {}\n",
    "#         if lr not in p_accs[name].keys():\n",
    "#             p_accs[name][lr] = []\n",
    "\n",
    "#         for seed in seeds:\n",
    "#             transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "#             canon = zcanon.SequentialMergeBatchNorm()\n",
    "#             handles = canon.apply(transfer_wrappers[lr][name][seed][0].model)\n",
    "#             layers = [module for module in transfer_wrappers[lr][name][seed][0].model.modules() if hasattr(module, \"weight\") and isinstance(module, torch.nn.Conv2d)]\n",
    "#             prune_acc = get_prune_acc(transfer_wrappers[lr][name][seed][0], layers, p=0.05, pruning_criterion=\"weight\", structured=True, mask_function=get_prunemask)\n",
    "#             for handle in handles:\n",
    "#                 handle.remove()\n",
    "#             transfer_wrappers[lr][name][seed][0].remove()\n",
    "#             p_accs[name][lr].append(prune_acc)\n",
    "#     joblib.dump(p_accs, p_acc_file)\n",
    "# else:\n",
    "#     p_accs = joblib.load(p_acc_file)\n",
    "\n",
    "# print(p_accs.keys())\n",
    "\n",
    "\n",
    "# fname = os.path.join(savepath, f\"{dataset_name_base}-pruning_accuracies_weight_structured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.svg\")\n",
    "# plot_pruning_acc(p_accs, fname, pruning_criterion=\"weight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:22.243348Z",
     "iopub.status.busy": "2024-08-21T10:22:22.243012Z",
     "iopub.status.idle": "2024-08-21T10:22:22.384984Z",
     "shell.execute_reply": "2024-08-21T10:22:22.384352Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dict_keys(['vanilla-gradient', 'lfp-epsilon'])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_371758/787198864.py:103: MatplotlibDeprecationWarning: The get_cmap function was deprecated in Matplotlib 3.7 and will be removed two minor releases later. Use ``matplotlib.colormaps[name]`` or ``matplotlib.colormaps.get_cmap(obj)`` instead.\n",
      "  palette = cm.get_cmap(colormap)(colors)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_acc_file = os.path.join(\n",
    "    savepath,\n",
    "    f\"{dataset_name_base}-p_accs_weight_local_unstructured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\",\n",
    ")\n",
    "if not os.path.exists(p_acc_file) or recompute_pruning:\n",
    "    p_accs = {}\n",
    "    lr = investigated_lr\n",
    "    for name in transfer_wrappers[lr].keys():\n",
    "        print(name, lr)\n",
    "        if name not in p_accs.keys():\n",
    "            p_accs[name] = {}\n",
    "        if lr not in p_accs[name].keys():\n",
    "            p_accs[name][lr] = []\n",
    "\n",
    "        for seed in seeds:\n",
    "            transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "            canon = zcanon.SequentialMergeBatchNorm()\n",
    "            handles = canon.apply(transfer_wrappers[lr][name][seed][0].model)\n",
    "            layers = [\n",
    "                module\n",
    "                for module in transfer_wrappers[lr][name][seed][0].model.modules()\n",
    "                if hasattr(module, \"weight\") and isinstance(module, torch.nn.Conv2d)\n",
    "            ]\n",
    "            prune_acc = get_prune_acc(\n",
    "                transfer_wrappers[lr][name][seed][0],\n",
    "                layers,\n",
    "                p=0.05,\n",
    "                pruning_criterion=\"weight\",\n",
    "                structured=False,\n",
    "                mask_function=get_prunemask_local,\n",
    "            )\n",
    "            for handle in handles:\n",
    "                handle.remove()\n",
    "            transfer_wrappers[lr][name][seed][0].remove()\n",
    "            p_accs[name][lr].append(prune_acc)\n",
    "    joblib.dump(p_accs, p_acc_file)\n",
    "else:\n",
    "    p_accs = joblib.load(p_acc_file)\n",
    "\n",
    "print(p_accs.keys())\n",
    "\n",
    "fname = os.path.join(\n",
    "    savepath,\n",
    "    f\"{dataset_name_base}-pruning_accuracies_weight_local_unstructured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.svg\",\n",
    ")\n",
    "plot_pruning_acc(p_accs, fname, pruning_criterion=\"weight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:22.388499Z",
     "iopub.status.busy": "2024-08-21T10:22:22.388330Z",
     "iopub.status.idle": "2024-08-21T10:22:22.391361Z",
     "shell.execute_reply": "2024-08-21T10:22:22.390883Z"
    }
   },
   "outputs": [],
   "source": [
    "# p_acc_file = os.path.join(savepath, f\"{dataset_name_base}-p_accs_weight_local_structured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\")\n",
    "# if not os.path.exists(p_acc_file) or recompute_pruning:\n",
    "#     p_accs = {}\n",
    "#     lr = investigated_lr\n",
    "#     for name in transfer_wrappers[lr].keys():\n",
    "#         print(name, lr)\n",
    "#         if name not in p_accs.keys():\n",
    "#             p_accs[name] = {}\n",
    "#         if lr not in p_accs[name].keys():\n",
    "#             p_accs[name][lr] = []\n",
    "\n",
    "#         for seed in seeds:\n",
    "#             transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "#             canon = zcanon.SequentialMergeBatchNorm()\n",
    "#             handles = canon.apply(transfer_wrappers[lr][name][seed][0].model)\n",
    "#             layers = [module for module in transfer_wrappers[lr][name][seed][0].model.modules() if hasattr(module, \"weight\") and isinstance(module, torch.nn.Conv2d)]\n",
    "#             prune_acc = get_prune_acc(transfer_wrappers[lr][name][seed][0], layers, p=0.05, pruning_criterion=\"weight\", structured=True, mask_function=get_prunemask_local)\n",
    "#             for handle in handles:\n",
    "#                 handle.remove()\n",
    "#             transfer_wrappers[lr][name][seed][0].remove()\n",
    "#             p_accs[name][lr].append(prune_acc)\n",
    "#     joblib.dump(p_accs, p_acc_file)\n",
    "# else:\n",
    "#     p_accs = joblib.load(p_acc_file)\n",
    "\n",
    "# print(p_accs.keys())\n",
    "\n",
    "# fname = os.path.join(savepath, f\"{dataset_name_base}-pruning_accuracies_weight_local_structured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.svg\")\n",
    "# plot_pruning_acc(p_accs, fname, pruning_criterion=\"weight\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:22.395422Z",
     "iopub.status.busy": "2024-08-21T10:22:22.395089Z",
     "iopub.status.idle": "2024-08-21T10:22:22.536788Z",
     "shell.execute_reply": "2024-08-21T10:22:22.536215Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dict_keys(['vanilla-gradient', 'lfp-epsilon'])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_371758/787198864.py:103: MatplotlibDeprecationWarning: The get_cmap function was deprecated in Matplotlib 3.7 and will be removed two minor releases later. Use ``matplotlib.colormaps[name]`` or ``matplotlib.colormaps.get_cmap(obj)`` instead.\n",
      "  palette = cm.get_cmap(colormap)(colors)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_acc_file = os.path.join(\n",
    "    savepath,\n",
    "    f\"{dataset_name_base}-p_accs_relevance_unstructured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\",\n",
    ")\n",
    "if not os.path.exists(p_acc_file) or recompute_pruning:\n",
    "    p_accs = {}\n",
    "    lr = investigated_lr\n",
    "    for name in transfer_wrappers[lr].keys():\n",
    "        print(name, lr)\n",
    "        if name not in p_accs.keys():\n",
    "            p_accs[name] = {}\n",
    "        if lr not in p_accs[name].keys():\n",
    "            p_accs[name][lr] = []\n",
    "\n",
    "        for seed in seeds:\n",
    "            transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "            canon = zcanon.SequentialMergeBatchNorm()\n",
    "            handles = canon.apply(transfer_wrappers[lr][name][seed][0].model)\n",
    "            layers = [\n",
    "                module\n",
    "                for module in transfer_wrappers[lr][name][seed][0].model.modules()\n",
    "                if hasattr(module, \"weight\") and isinstance(module, torch.nn.Conv2d)\n",
    "            ]\n",
    "            prune_acc = get_prune_acc(\n",
    "                transfer_wrappers[lr][name][seed][0],\n",
    "                layers,\n",
    "                p=0.05,\n",
    "                pruning_criterion=\"relevance\",\n",
    "                structured=False,\n",
    "                mask_function=get_prunemask,\n",
    "            )\n",
    "            for handle in handles:\n",
    "                handle.remove()\n",
    "            transfer_wrappers[lr][name][seed][0].remove()\n",
    "            p_accs[name][lr].append(prune_acc)\n",
    "    joblib.dump(p_accs, p_acc_file)\n",
    "else:\n",
    "    p_accs = joblib.load(p_acc_file)\n",
    "\n",
    "print(p_accs.keys())\n",
    "\n",
    "fname = os.path.join(\n",
    "    savepath,\n",
    "    f\"{dataset_name_base}-pruning_accuracies_relevance_unstructured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.svg\",\n",
    ")\n",
    "plot_pruning_acc(p_accs, fname, pruning_criterion=\"relevance\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-21T10:22:22.540318Z",
     "iopub.status.busy": "2024-08-21T10:22:22.540154Z",
     "iopub.status.idle": "2024-08-21T10:22:22.543231Z",
     "shell.execute_reply": "2024-08-21T10:22:22.542748Z"
    }
   },
   "outputs": [],
   "source": [
    "# p_acc_file = os.path.join(savepath, f\"{dataset_name_base}-p_accs_relevance_structured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.joblib\")\n",
    "# if not os.path.exists(p_acc_file) or recompute_pruning:\n",
    "#     p_accs = {}\n",
    "#     lr = investigated_lr\n",
    "#     for name in transfer_wrappers[lr].keys():\n",
    "#         print(name, lr)\n",
    "#         if name not in p_accs.keys():\n",
    "#             p_accs[name] = {}\n",
    "#         if lr not in p_accs[name].keys():\n",
    "#             p_accs[name][lr] = []\n",
    "\n",
    "#         for seed in seeds:\n",
    "#             transfer_wrappers[lr][name][seed][0].load(dataset_name_base, replace_last_layer=True)\n",
    "#             canon = zcanon.SequentialMergeBatchNorm()\n",
    "#             handles = canon.apply(transfer_wrappers[lr][name][seed][0].model)\n",
    "#             layers = [module for module in transfer_wrappers[lr][name][seed][0].model.modules() if hasattr(module, \"weight\") and isinstance(module, torch.nn.Conv2d)]\n",
    "#             prune_acc = get_prune_acc(transfer_wrappers[lr][name][seed][0], layers, p=0.05, pruning_criterion=\"relevance\", structured=True, mask_function=get_prunemask)\n",
    "#             for handle in handles:\n",
    "#                 handle.remove()\n",
    "#             transfer_wrappers[lr][name][seed][0].remove()\n",
    "#             p_accs[name][lr].append(prune_acc)\n",
    "#     joblib.dump(p_accs, p_acc_file)\n",
    "# else:\n",
    "#     p_accs = joblib.load(p_acc_file)\n",
    "\n",
    "# print(p_accs.keys())\n",
    "\n",
    "# fname = os.path.join(savepath, f\"{dataset_name_base}-pruning_accuracies_relevance_structured_canonized-{investigated_lr}-{investigated_ep_lfp}-{investigated_ep_grad}.svg\")\n",
    "# plot_pruning_acc(p_accs, fname, pruning_criterion=\"relevance\")\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "lfp-KukTaqIE-py3.11",
   "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
