{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"0\"\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.backends.cudnn as cudnn\n",
    "import torchvision\n",
    "import torchvision.transforms as transforms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from imagenet_ipc import ImageFolderIPC\n",
    "def get_trainset(path, ipc):\n",
    "    transform_train = transforms.Compose(\n",
    "        [\n",
    "            transforms.RandomCrop(32, padding=4),\n",
    "            transforms.RandomHorizontalFlip(),\n",
    "            transforms.ToTensor(),\n",
    "            transforms.Normalize((0.4914, 0.4822, 0.4465), (0.2023, 0.1994, 0.2010)),\n",
    "        ]\n",
    "    )\n",
    "    trainset = ImageFolderIPC(root=path, transform=transform_train, ipc=ipc)\n",
    "    return trainset\n",
    "\n",
    "def get_loader(trainset):\n",
    "    trainloader = torch.utils.data.DataLoader(trainset, batch_size=100, shuffle=False, num_workers=2)\n",
    "    return trainloader\n",
    "\n",
    "def load_model(ckpt_path):\n",
    "    CLASS_NUM = 100\n",
    "    device = 'cuda'\n",
    "    ckpt = torch.load(ckpt_path, weights_only=False)\n",
    "    model = torchvision.models.get_model(\"resnet18\", num_classes=CLASS_NUM)\n",
    "    model.conv1 = nn.Conv2d(3, 64, kernel_size=(3, 3), stride=(1, 1), padding=(1, 1), bias=False)\n",
    "    model.maxpool = nn.Identity()\n",
    "    net = model.to(device)\n",
    "    cudnn.benchmark = True\n",
    "    net.load_state_dict({k[len(\"module.\"):]:ckpt[\"state_dict\"][k] for k in ckpt[\"state_dict\"]})\n",
    "    net.eval()\n",
    "    return net\n",
    "\n",
    "def get_model(ir, ipc, t, suffix, stage='save_post_cifar100', stage_name_fn=None):\n",
    "    if stage_name_fn is None:\n",
    "        ckpt_root = f\"./{stage}/{suffix}/rand{t}\"\n",
    "        ckpt_path = os.path.join(ckpt_root, f\"{ir}_{ipc}\", \"ckpt.pth\")\n",
    "    else:\n",
    "        ckpt_root = f\"./{stage}/{suffix}/rand{t}\"\n",
    "        ckpt_path = os.path.join(ckpt_root, stage_name_fn(suffix, ir, ipc))\n",
    "    net = load_model(ckpt_path)\n",
    "    return net"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_data_path(suffix, rand, number):\n",
    "    return f\"./syn_data/{suffix}_10ipc/rand{rand}/SPEC_NUMBER{number}_IPC10\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def bar(ax, logits, labels, class_id, err=False, suffix_title=\"\"):\n",
    "    class_logits = logits[labels == class_id]\n",
    "    mean = class_logits.mean(axis=0)\n",
    "    std = class_logits.std(axis=0)\n",
    "    if err:\n",
    "        ax.bar(range(len(mean)), mean, yerr=std)\n",
    "    else:\n",
    "        ax.bar(range(len(mean)), mean)\n",
    "    ax.set_title(f\"{suffix_title}: class {class_id}\")\n",
    "    ax.set_xlabel(\"class\")\n",
    "    ax.set_ylabel(\"logit\")\n",
    "\n",
    "# paint the distribution by 20 classes\n",
    "def bin5(logits):\n",
    "    def sub_acc(a, b):\n",
    "        return np.sum(logits[:, a:b], axis=1)\n",
    "    new_logits = np.zeros((logits.shape[0], 5))\n",
    "    for i in range(5):\n",
    "        new_logits[:, i] = sub_acc(i*20, (i+1)*20)/20\n",
    "    return new_logits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tqdm import tqdm\n",
    "def get_info(spec_number, suffix_data, suffix_model, model_stage, model_stage_name_fn, model_ir, random_list, verbose=True):\n",
    "    trainloader_list = []\n",
    "\n",
    "    for rand in random_list:\n",
    "        data_path = get_data_path(suffix_data, rand, spec_number)\n",
    "        trainset = get_trainset(data_path, ipc=10)\n",
    "        trainloader = get_loader(trainset)\n",
    "        trainloader_list.append(trainloader)\n",
    "    \n",
    "    model_list = []\n",
    "    for rand in random_list:\n",
    "        model = get_model(ir=model_ir, ipc=10, t=rand, suffix=suffix_model, stage=model_stage, stage_name_fn=model_stage_name_fn) \n",
    "        model_list.append(model)\n",
    "\n",
    "    logits = []\n",
    "    labels = []\n",
    "    softmaxs = []\n",
    "    \n",
    "    for trainloader in trainloader_list:\n",
    "        for i, (inputs, targets) in tqdm(enumerate(trainloader), total=len(trainloader), disable=not verbose):\n",
    "            inputs, targets = inputs.cuda(), targets.cuda()\n",
    "            _logit = []\n",
    "            for model in model_list:\n",
    "                outputs = model(inputs)\n",
    "                _logit.append(outputs)\n",
    "            _logit = torch.mean(torch.stack(_logit), dim=0)\n",
    "            logits.append(_logit.cpu().detach().numpy())\n",
    "            labels.append(targets.cpu().detach().numpy())\n",
    "            softmaxs.append(torch.nn.functional.softmax(_logit, dim=1).cpu().detach().numpy())\n",
    "    logits = np.concatenate(logits, axis=0)\n",
    "    labels = np.concatenate(labels, axis=0)\n",
    "    softmaxs = np.concatenate(softmaxs, axis=0)\n",
    "    return logits, labels, softmaxs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
    "random_list = [0, 1, 2, 3, 4, 5]\n",
    "save_root = \"./cache/final_evaluation\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/13 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 13/13 [00:09<00:00,  1.41it/s]\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "softmax_dict = {}\n",
    "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
    "for i, spec_number in tqdm(enumerate(spec_number_list), total=len(spec_number_list)):\n",
    "    softmax_dict[spec_number] = {}\n",
    "    for j, model_ir in enumerate(spec_number_list):\n",
    "        suffix_data = \"imb_size10000_extream_lt_specific\"\n",
    "        suffix_model = \"imb_size10000_extream_lt_specific\"\n",
    "        model_stage = 'save'\n",
    "        model_stage_name_fn = lambda _suffix, _ir, _ipc: f\"E200_lr0.1_{_suffix}_{_ir}_10000/ckpt.pth\"\n",
    "        # spec_number = 1\n",
    "        path = f\"./cache/logits/{suffix_data}_{suffix_model}_{model_ir}_{spec_number}.pkl\"\n",
    "        # read path\n",
    "        with open(path, 'rb') as f:\n",
    "            tmp = pickle.load(f)\n",
    "            logits, labels, softmaxs = tmp[\"logits\"], tmp[\"labels\"], tmp[\"softmaxs\"]\n",
    "        softmax_dict[spec_number][model_ir] = (softmaxs, labels)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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EELUHQmxQohadeutt3Lp0iWbIPjll19azpf322+/cfbsWcttg8HAkiVLaNasGWFhYZbjixYt4vHHH+ehhx7is88+q7QsYOjQofz+++9Wqxbk5eWxdOlS7rzzTjSayue3BgcH8/jjj7Nq1SpLfys6duwYe/bsqfQxVCoVWq3W6tjPP/982U0GvL29ueeee3jqqac4f/683dn2ERERPP3009XeuKEmauM9tPe67Nmzx+5KAABLly6lqKjIcjsvL48VK1bQs2dP1Gp1jZ8bYOlHZUulderUiW7duvHWW2/xzTff8PDDD18X6+oK0djJ6gRCiFo1YsQIPvzwQ0aOHMnJkyeJi4tj48aNvPHGGwwcOJDbbrvNqr2/vz+33HILL730kmVm+6FDh6yWaPrvf//LY489RocOHXjyySf5448/rB4jPj7eEkwmTpzIV199xe233860adPQarW8+eabFBUVMXXq1Cv2/9133+X48eM8/PDDrFq1iqFDhxIUFERWVharV69m4cKFLF68uNJltu644w4WLVpE69atadeuHTt27GDmzJlWgRxg0KBBlnVcAwICOHXqFHPmzCEyMpIWLVqQk5PDzTffzD/+8Q9at26Nh4cH27dvZ+XKldx1111VeStqrDbewzvuuIPXXnuNV155haSkJA4fPsy0adOIjo62u+yZWq2mT58+TJgwAaPRyFtvvUVubi6vvvrqVT+/Zs2a4eLiwjfffENMTAzu7u6EhIRYrTwwduxY7r//flQqFWPGjLnqawohroH6nlkmhLi+VFydQFEUJTs7Wxk9erTSpEkTRaPRKJGRkcqUKVOUoqIiq3aA8tRTTynz5s1TmjVrpjg6OiqtW7dWvvnmG5trAJV+lZ+driiKcvToUWXIkCGKp6en4urqqtx6663Kjh07qvyc9Hq98sUXXyi33HKL4uvrq2g0GiUgIEAZMGCA8p///EcxGAyKothfneDChQvKY489pgQGBiqurq5Kjx49lA0bNihJSUlKUlKSpd2sWbOUbt26Kf7+/oqTk5MSERGhPPbYY8rJkycVRVGUoqIiZfTo0Uq7du0UT09PxcXFRWnVqpXyyiuvKPn5+Zftv3nW/vbt2y/bzt57Z3at38Pi4mJl4sSJSmhoqOLs7Kx07NhRWb58uc1qAubX9K233lJeffVVJSwsTHFyclLi4+OVVatW2X2e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165dSU5OrnG/aqJaI7FOTk506tSJ1atXM3ToUMvx1atXM3jwYLv3SUxMZMWKFVbHfv31VxISEqr8W0lNrgug1WrRamV2tLhxZRdml+2UlbaZS7pLlnNWk7LCexHtKZOyLArOl6th3W36MzfVtp1KDUGx1jWsgbGgcarzLosrUxSFQp2d1R7qgIujukY/X0uXLqV9+/Y88cQTjBo1qtr3f+WVV5gzZw4RERE8+uijDBs2DE9PT9577z1cXV257777ePnlly2TpvPy8hg5ciTvv/8+ALNmzWLgwIEcOXIEDw8PjEYjQ4YMISIigm3btpGXl8ezzz5rdc2CggJuvvlmevbsyfr169FoNEyfPp3+/fuzZ88enJxsfz569+5NcnIyzz77LIqisGHDBnx8fNi4cSMDBw5k7dq1BAcH06pVK5v7bt++ncDAQBYuXEj//v2tlms6duwYy5cv56effuLChQvcd999vPnmm7z++uuVvmYFBQW88847fPXVVzg4OPDQQw8xceJEvvnmGwDee+89Zs2axfz584mPj+fzzz/nzjvvZP/+/bRo0cLyOJMnT2bWrFksXLgQrVbLunXr+P333wkLC2P9+vVs2rSJxx57jC1bttCrVy+2bdvGkiVLGD16NH369CE8PBwADw8PFi1aREhICHv37mXUqFF4eHgwadKkqv41sFJUVESnTp2YPHkynp6e/PzzzwwfPpymTZvStWtXS7svvviCxx57jG3btvHnn3/yxBNPEBkZafl7+Mgjj3Dy5EkWL15MSEgIy5Yto3///uzdu9fqdahN1S4nmDBhAsOHDychIYHExEQ++eQTUlJSLOu+TpkyhdTUVL788kvAtBLB3LlzmTBhAqNGjWLLli0sWLDAKvWXlJRw4MABy/epqans3r0bd3d3mjdvXqXrCiFM/0kfPH/QsuFAxUlZvs6+pp2ywkw7ZXk4edRjbxuIohxT3Wr5LVovnrLTUAUBray3Zw1uC44udd5lUTOFOgOxL6+ql2sfmNYPV6fqV/D5+vqiVqvx8PCoUbnAxIkT6devHwBjx45l2LBh/Pbbb3Tv3h2Axx57jEWLFlna33LLLVb3nz9/Pj4+Pqxbt4477riDX3/9lWPHjpGcnGzpz+uvv06fPn0s91m8eDEODg589tlnluC+cOFCvL29SU5OtpnsDaYQu2DBAoxGI3v37kWt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",
      "text/plain": [
       "<Figure size 800x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "def compute_top20(spec_or_ir_list, fixed_value, mode, softmax_dict):\n",
    "    \"\"\"\n",
    "    Compute the top-20 class probability for different modes.\n",
    "    \n",
    "    Args:\n",
    "        spec_or_ir_list (list): List of spec_number or model_ir values to iterate over.\n",
    "        fixed_value (int): Fixed value for spec_number or model_ir.\n",
    "        mode (str): Mode of operation ('lt_normal', 'normal_lt', 'lt_lt').\n",
    "        softmax_dict (dict): Dictionary containing softmax and label data.\n",
    "        \n",
    "    Returns:\n",
    "        list: Computed top-20 class probabilities.\n",
    "    \"\"\"\n",
    "    top20 = []\n",
    "    for value in spec_or_ir_list:\n",
    "        if mode == \"lt_normal\":\n",
    "            softmaxs, labels = softmax_dict[value][fixed_value]\n",
    "        elif mode == \"normal_lt\":\n",
    "            softmaxs, labels = softmax_dict[fixed_value][value]\n",
    "        elif mode == \"lt_lt\":\n",
    "            softmaxs, labels = softmax_dict[value][value]\n",
    "        else:\n",
    "            raise ValueError(\"Invalid mode specified.\")\n",
    "        \n",
    "        new_labels = labels // 20\n",
    "        softmaxs_bin = bin5(softmaxs)\n",
    "        mean = np.mean(softmaxs_bin[new_labels == 0], axis=0)\n",
    "        std = np.std(softmaxs_bin[new_labels == 0], axis=0)\n",
    "        top20.append(mean[0])\n",
    "    return top20\n",
    "\n",
    "# Define spec_number_list and model_ir\n",
    "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
    "\n",
    "plt.figure(figsize=(8, 2))\n",
    "\n",
    "# Plot for \"lt image with normal label\"\n",
    "top20_lt_normal = compute_top20(spec_number_list, 100, \"lt_normal\", softmax_dict)\n",
    "plt.plot(spec_number_list, top20_lt_normal, label=\"lt image with normal label\")\n",
    "\n",
    "# Plot for \"normal image with lt label\"\n",
    "top20_normal_lt = compute_top20(spec_number_list, 100, \"normal_lt\", softmax_dict)\n",
    "plt.plot(spec_number_list, top20_normal_lt, label=\"normal image with lt label\")\n",
    "\n",
    "# Plot for \"lt image with lt label\"\n",
    "top20_lt_lt = compute_top20(spec_number_list, None, \"lt_lt\", softmax_dict)\n",
    "plt.plot(spec_number_list, top20_lt_lt, label=\"lt image with lt label\")\n",
    "\n",
    "# Finalize plot\n",
    "plt.title(\"Top20 Class Probability\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
      "top20_lt_normal_probability = [np.float64(0.011344784241435783), np.float64(0.016183589861112912), np.float64(0.016239648069022224), np.float64(0.01583764810006999), np.float64(0.017403921824048405), np.float64(0.01671606460040818), np.float64(0.01804786221629391), np.float64(0.01828043563617809), np.float64(0.02051260178060537), np.float64(0.020056214722488742), np.float64(0.0192419716263456), np.float64(0.018893782539733884), np.float64(0.020234249884004903)]\n",
      "top20_normal_lt_probability = [np.float64(0.002183218383978393), np.float64(0.004120775532042639), np.float64(0.004057900456126455), np.float64(0.004219308127534792), np.float64(0.0039786676743096905), np.float64(0.003636938404654627), np.float64(0.0037326745128146805), np.float64(0.004676485491550661), np.float64(0.005601457484847612), np.float64(0.009066341657375493), np.float64(0.012081375486606183), np.float64(0.01548314361220816), np.float64(0.020234249884004903)]\n",
      "top20_lt_lt_probability = [np.float64(0.0030461776628050888), np.float64(0.004207843946205685), np.float64(0.004398195257521625), np.float64(0.004774633761621771), np.float64(0.004587654129042806), np.float64(0.004274686312209529), np.float64(0.004581009146750148), np.float64(0.005610722630663077), np.float64(0.007571094876147981), np.float64(0.011910419702055931), np.float64(0.014094428199516966), np.float64(0.01727334661633774), np.float64(0.020234249884004903)]\n"
     ]
    }
   ],
   "source": [
    "print(f\"spec_number_list = {spec_number_list}\")\n",
    "print(f\"top20_lt_normal_probability = {top20_lt_normal}\")\n",
    "print(f\"top20_normal_lt_probability = {top20_normal_lt}\")\n",
    "print(f\"top20_lt_lt_probability = {top20_lt_lt}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "def compute_top20_acc(spec_or_ir_list, fixed_value, mode, softmax_dict):\n",
    "    \"\"\"\n",
    "    Compute the top-20 class probability for different modes.\n",
    "    \n",
    "    Args:\n",
    "        spec_or_ir_list (list): List of spec_number or model_ir values to iterate over.\n",
    "        fixed_value (int): Fixed value for spec_number or model_ir.\n",
    "        mode (str): Mode of operation ('lt_normal', 'normal_lt', 'lt_lt').\n",
    "        softmax_dict (dict): Dictionary containing softmax and label data.\n",
    "        \n",
    "    Returns:\n",
    "        list: Computed top-20 class probabilities.\n",
    "    \"\"\"\n",
    "    top20 = []\n",
    "    for value in spec_or_ir_list:\n",
    "        if mode == \"lt_normal\":\n",
    "            softmaxs, labels = softmax_dict[value][fixed_value]\n",
    "        elif mode == \"normal_lt\":\n",
    "            softmaxs, labels = softmax_dict[fixed_value][value]\n",
    "        elif mode == \"lt_lt\":\n",
    "            softmaxs, labels = softmax_dict[value][value]\n",
    "        else:\n",
    "            raise ValueError(\"Invalid mode specified.\")\n",
    "        \n",
    "        # new_labels = labels // 20\n",
    "        # softmaxs_bin = bin5(softmaxs)\n",
    "        # mean = np.mean(softmaxs_bin[new_labels == 0], axis=0)\n",
    "        # top20.append(mean[0])\n",
    "        predicted_class = np.argmax(softmaxs, axis=1)\n",
    "        correct = (predicted_class == labels)\n",
    "        correct = correct[labels < 20]\n",
    "        top20.append(np.mean(correct))\n",
    "\n",
    "    return top20\n",
    "\n",
    "# Define spec_number_list and model_ir\n",
    "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
    "\n",
    "plt.figure(figsize=(8, 2))\n",
    "\n",
    "# Plot for \"lt image with normal label\"\n",
    "top20_lt_normal = compute_top20_acc(spec_number_list, 100, \"lt_normal\", softmax_dict)\n",
    "plt.plot(spec_number_list, top20_lt_normal, label=\"lt image with normal label\")\n",
    "\n",
    "# Plot for \"normal image with lt label\"\n",
    "top20_normal_lt = compute_top20_acc(spec_number_list, 100, \"normal_lt\", softmax_dict)\n",
    "plt.plot(spec_number_list, top20_normal_lt, label=\"normal image with lt label\")\n",
    "\n",
    "# Plot for \"lt image with lt label\"\n",
    "top20_lt_lt = compute_top20_acc(spec_number_list, None, \"lt_lt\", softmax_dict)\n",
    "plt.plot(spec_number_list, top20_lt_lt, label=\"lt image with lt label\")\n",
    "\n",
    "# Finalize plot\n",
    "plt.title(\"Top20 Class Accuracy\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
      "top20_lt_normal_acc = [np.float64(0.005714285714285714), np.float64(0.35214285714285715), np.float64(0.38142857142857145), np.float64(0.3942857142857143), np.float64(0.44785714285714284), np.float64(0.4057142857142857), np.float64(0.4735714285714286), np.float64(0.4907142857142857), np.float64(0.6021428571428571), np.float64(0.6128571428571429), np.float64(0.5957142857142858), np.float64(0.5735714285714286), np.float64(0.6492857142857142)]\n",
      "top20_normal_lt_acc = [np.float64(0.0), np.float64(0.0), np.float64(0.0), np.float64(0.0), np.float64(0.0), np.float64(0.0), np.float64(0.0014285714285714286), np.float64(0.007857142857142858), np.float64(0.04428571428571428), np.float64(0.24142857142857144), np.float64(0.35928571428571426), np.float64(0.4907142857142857), np.float64(0.6492857142857142)]\n",
      "top20_lt_lt_acc = [np.float64(0.0), np.float64(0.0), np.float64(0.0), np.float64(0.0), np.float64(0.0035714285714285713), np.float64(0.0007142857142857143), np.float64(0.02214285714285714), np.float64(0.06642857142857143), np.float64(0.16714285714285715), np.float64(0.4057142857142857), np.float64(0.4514285714285714), np.float64(0.5585714285714286), np.float64(0.6492857142857142)]\n"
     ]
    }
   ],
   "source": [
    "# simple version\n",
    "print(f\"spec_number_list = {spec_number_list}\")\n",
    "print(f\"top20_lt_normal_acc = {top20_lt_normal}\")\n",
    "print(f\"top20_normal_lt_acc = {top20_normal_lt}\")\n",
    "print(f\"top20_lt_lt_acc = {top20_lt_lt}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def softmax_entropy(logits):\n",
    "    \"\"\"\n",
    "    计算 softmax 输出的信息熵\n",
    "    :param logits: 原始 logits 值 (未归一化)\n",
    "    :return: 信息熵\n",
    "    \"\"\"\n",
    "    # 计算 softmax 输出\n",
    "    exp_logits = np.exp(logits - np.max(logits))  # 防止数值溢出\n",
    "    softmax_probs = exp_logits / np.sum(exp_logits)\n",
    "    \n",
    "    # 计算信息熵\n",
    "    entropy = -np.sum(softmax_probs * np.log(softmax_probs + 1e-9))  # 加上小值防止 log(0)\n",
    "    return entropy\n",
    "\n",
    "def get_info_cifar100(dataloader, suffix_model, model_stage, model_stage_name_fn, model_ir, random_list, verbose=True):\n",
    "    model_list = []\n",
    "    for rand in random_list:\n",
    "        model = get_model(ir=model_ir, ipc=10, t=rand, suffix=suffix_model, stage=model_stage, stage_name_fn=model_stage_name_fn) \n",
    "        model_list.append(model)\n",
    "\n",
    "    logits = []\n",
    "    labels = []\n",
    "    softmaxs = []\n",
    "    \n",
    "    for i, (inputs, targets) in tqdm(enumerate(dataloader), total=len(dataloader), disable=not verbose):\n",
    "        inputs, targets = inputs.cuda(), targets.cuda()\n",
    "        _logit = []\n",
    "        for model in model_list:\n",
    "            outputs = model(inputs)\n",
    "            _logit.append(outputs)\n",
    "        _logit = torch.mean(torch.stack(_logit), dim=0)\n",
    "        logits.append(_logit.cpu().detach().numpy())\n",
    "        labels.append(targets.cpu().detach().numpy())\n",
    "        softmaxs.append(torch.nn.functional.softmax(_logit, dim=1).cpu().detach().numpy())\n",
    "    logits = np.concatenate(logits, axis=0)\n",
    "    labels = np.concatenate(labels, axis=0)\n",
    "    softmaxs = np.concatenate(softmaxs, axis=0)\n",
    "    return logits, labels, softmaxs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "distill_entropy_dict = {}\n",
    "\n",
    "random_list = [0, 1, 2, 3, 4, 5]\n",
    "# random_list = [0, 1, 2]\n",
    "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
    "\n",
    "for i, spec_number in enumerate(spec_number_list):\n",
    "    for j, model_ir in enumerate(spec_number_list):\n",
    "        path = f\"cache/distilled/entropy_{spec_number}_{model_ir}.pkl\"\n",
    "        with open(path, 'rb') as f:\n",
    "            tmp = pickle.load(f)\n",
    "        distill_entropy_dict[(spec_number, model_ir)] = tmp[\"mean_entropy\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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AwIC2LZtG8888wz/+Mc/uP/+++nRowc7d+5k4MCBjBo1ipSUFABsNhv16tXjhx9+4MCBA7z66qu89NJL/PDDD459zp49m0WLFjFv3jw2b95MUlJSnnsKp0+fzrx58/jss8/Yv38/zz33HA8//DARERH51jMsLIz9+/dz8eJFACIiIggICHCUt1gsbNmyhdDQ0DzbvvDCCzzwwAPccccdnDt3jnPnztGjRw/H+pdffpkXXniB3bt307x5c0aMGIHFYinS97dt2zYA1q5dy7lz51i2bFmRtktLS6Nz586sXLmSffv28eSTTzJq1Ci2bt3qVG7BggUYDAa2bt3Khx9+yPvvv8/XX3/tWP/II4+wefNmlixZwp49e7j//vu54447OHLkSJHqUSpUOUtMTFSASkxMLJfj/brnrGow9SfVZn4b1WZ+G5WQmlAuxxVCiJouNTVVHThwQKWmpl5fmH5Vqde8KuaVfrXIdQ8NDVW9evVyWta1a1c1depUpZRSq1evVnq9Xp06dcqxfv/+/QpQ27ZtU0op9dprrymj0aji4+Od9gOo6dOnOz7/8ccfClDffPONY9nixYuVq6troXVs3bq1+uijjxyfGzRooN5///0Cy48ZM0YNHTq0wHO0WCzKw8NDjRo1yrHs3LlzClB//PFHgft9+umn1d///nfH56CgIPXuu+867bd+/fqOY1+9elW5urqqLVu2OO3nscceUyNGjMj3GDabTQUEBKgff/xRKaVUhw4d1KxZs1RgYKBSSqktW7Yog8GgkpOTlVL27759+/YFnrtSSh0/flwB6uuvv3Ysy76G0dHRBZ4voJYvX+60j127dhVYXimlNmzYoACVkJBQYJlBgwap559/3vE5NDRUtWrVStlsNseyqVOnqlatWimllDp69KjSNE2dOXPGaT/9+vVT06ZNU0opNW/ePOXt7V3gMfP9Hc1S1LxWI1okQQ82+5yS0r0thBCiKNq1a+f0uXbt2sTHxwMQHR1NSEgIISEhjvWtW7fGx8eH6Ohox7IGDRpQq1atQvcdFBQE4NR1GxQURFpaGklJ9kGi165dY8qUKY5jmM1mDh48eNMtkjnrodfr8ff3z1MPwHHeAJ9//jldunShVq1amM1mvvrqK0c9EhMTOX/+PN26dXPab+fOnR2fDxw4QFpaGv3793fcy2g2m/nuu++cuvNz0jSN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t7c3Dz74IMnJyQXWI6f58+fz+uuv89dffzm++/nz5xdp21WrVtGrVy98fHzw9/dn8ODBxMTE5Cl38OBBevTogaurK7fccgvh4eFO6w8cOMCgQYMwm80EBQUxatQoLl68WKQ61AQ1J0h6ukLWPZIy2EYIISqGUoqUzJQKeZV06rdly5ZRr149Zs6cyblz5zh37lyxtn/ttdeYPn06O3fuxGAwMGLECKZMmcIHH3xAZGQkMTExvPrqq47yycnJjBkzhsjISP7880+aNWvGoEGDHOHLZrMxbNgw3N3d2bp1K19++SUvv/yy0zFTUlLo27cvZrOZjRs3smnTJkdozcjIyLeeYWFhjhCllCIyMhJfX182bdoEwIYNGwgODqZFixZ5to2KigJg3rx5nDt3zvEZICYmhhUrVrBy5UpWrlxJREQEb7/9dpG+u+HDh/P8889zyy23OL774cOHF2nba9euMXnyZKKioli3bh06nY577rkHm83mVO7FF1/k+eefZ9euXfTo0YMhQ4Zw6dIlwH6rQmhoKB06dGD79u2sWrWK8+fP88ADDxSpDjVBjenalknJhRCi4qVaUrn1P7dWyLG3PrQVd6N7sbfz8/NDr9fj6elZoq7rF154gYEDBwIwceJERowYwbp16+jZsycAjz32mFMr22233ea0/RdffIGvry8REREMHjyY1atXExMTQ3h4uKM+b775Jv3793dss2TJEnQ6HV9//bWjBXXevHn4+PgQHh7OgAED8tQzLCyMb775BpvNxt69e9Hr9Tz88MOEh4czaNAgwsPDCQ0Nzfccs7u5fXx88nxHNpuN+fPn4+npCcCoUaNYt24db7755g2/Ozc3N8xmMwaDodjf/d///nenz9988w2BgYEcOHCANm3aOJZPmDDBUfazzz5j1apVfPPNN0yZMoXPPvuMTp068dZbbznKf/vtt4SEhHD48GGaN29erDpVRzWnRTJH1/aVNAmSQgghyke7du0c74OCggBo27at07L4+HjH5/j4eMaNG0fz5s3x9vbG29ubq1evcurUKQAOHTpESEiIU7Dq1q2b0zF37NjB0aNH8fT0xGw2Yzab8fPzIy0tLd/uXYA+ffqQnJzMrl27iIiIIDQ0lL59+xIREQFQaJAsTMOGDR0hEqB27dpO51tWYmJieOihh2jcuDFeXl40atQIwPE9ZuvevbvjvcFgoEuXLkRHRwP273HDhg2O79BsNtOyZUvH/kUNapH0N5vAZu/avpCSUMG1qaIyUiDqK4jdBnU6QpPboHYH0NWY/48IIW6Sm8GNrQ9trbBjVwSj0eh4n906mHtZzu7WsWPHcuHCBebOnUuDBg0wmUx0797d0SWtlCr0Pk2wtwJ27tyZRYsW5VlX0CAZb29vOnToQHh4OFu2bOG2226jd+/e7N69myNHjnD48GHCwsKKfN7Zcp4r5D3fsnL33XcTEhLCV199RZ06dbDZbLRp06bArv3cdQT793j33Xcze/bsPGVq165d6nWuimpMkNTrNDxdvMgALqdeqejqVC2WDNi5ADa+C1fP25cdXAnr/wVuftA4zB4qm/QF73oVWlUhROWmaVqJupcrmouLC1artVyOFRkZyaeffsqgQYMAiI2NdRrc0bJlS06dOsX58+cdLZw570kE6NSpE0uXLiUwMBAvL68iHzssLIwNGzawdetWZs6ciY+PD61bt+aNN94gMDCQVq1aFbit0Wgsk++oJN/9pUuXiI6O5osvvqB3794Ajns9c/vzzz/p06cPABaLhR07djBhwgTA/j3+73//o2HDhhgMNSYyFUuNakryc/UB4EraFTgWAZb00j+IJR2smaW/34pgs8Lu/8DHneH/XrCHSJ/6EPYStBwMJi9IvQz7l8HPE+D9W+DjrvDbVDi0CtKvVvQZCCFEqWjYsCEbN27kzJkzZT5it2nTpixcuJDo6Gi2bt3KyJEjcXO73prav39/mjRpwpgxY9izZw+bN292DLbJbkkbOXIkAQEBDB06lMjISI4fP05ERAQTJ07k9OnTBR47LCyMVatWoWkarVu3dixbtGjRDbu1GzZsyLp164iLiyMhofR6/ho2bMjx48fZvXs3Fy9eJD39xv92Z49U//LLLzl69Cjr169n8uTJ+Zb95JNPWL58OQcPHmT8+PEkJCTw6KOPAjB+/HguX77MiBEj2LZtG8eOHWP16tU8+uij5fYfi8quRgXJAHdfADJST8N3Q+CTWyF6JZRwJF8e1y7BR53hnSbw+8tw+Xjp7Le8KQUHfoJPu8OKf8CVU2AOhkHvwYQdEDYVHlwEU47Bo79D6D+hXjfQdHDxMGz9HBYPh9kNYd5dsPE9OLPTHkyFEKIKmjlzJidOnKBJkyZlPn/it99+S0JCAh07dmTUqFE8++yzBAYGOtbr9XpWrFjB1atX6dq1K48//jjTp08HwNXVFQB3d3c2btxI/fr1uffee2nVqhWPPvooqamphbZQZrfMhYaGOkJpaGgoVqv1hkFyzpw5rFmzhpCQEDp27HhT30FOf//737njjjvo27cvtWrVYvHixTfcRqfTsWTJEnbs2EGbNm147rnnePfdd/Mt+/bbbzN79mzat29PZGQkP/30EwEBAQDUqVOHzZs3Y7VaGThwIG3atGHixIl4e3ujk9u6ANBUSedDKKGkpCS8vb1JTEwsVnN7aZj0v3WsuzoJV5uNqJM5/kfWKBTueBuCWt/cAX6aALsW5ligQfM74Nan7N2/N7inpcIpBUfX2busz+22L3PzhV7PQdcnwOUG3VGpV+D4Rji2wb6fKyed17v5Xu8Gb9wXfELK4CSEEJVFWloax48fp1GjRo6AI8rG5s2b6dWrF0ePHqVJkyYVXR1RRRT2O1rUvFajOvzrefnDVUjT6UhrNQTXgOaw5SM4HgGf94Quj9q7bT38i7/z2G3XQ+TAtyBmPRxdC4d/s79qtYRuT0L7B8HFo3RPrDSc3ALr/gWnttg/u5ih+3j7y9W7aPtw84HWQ+wvgMvH7N9DzAZ7wExNgP3L7S8A/2ZZ91beBg17gclc6qclhBDV0fLlyzGbzTRr1oyjR48yceJEevbsKSFSlLsaFSQ7ZR7me6WwahpJvSfiWqcLdBoFq1+B6J8h6ms48DM8ugr8i/HLaLXAr1n3XnR4+HoAu3gEtn1pv8/wwkF7mbWv24/Z9XHwa1Q2J1ocZ3fD+jfg6Br7Z70Juj1hb4X0CLi5ffs1tr+6Pm7/js7ssAfLYxvg9Ha4dMT+2vYF6IwQ0s0+YMcxGlx/s2cnhBDVUnJyMlOmTCE2NpaAgABuv/12p6fSCFFeak7XtlIkfdyHwR6XSNDrWTZkGc18m11ffzzSHvQuHgafBvDYGvAMKtq+t34Bv02xt9xN2AHmXPfPpCXaw+S2L+2tdABo0OJOe7d3o9Dy7/a+cAg2vGm/FxJAZ4COo6DPi+Bdt+yPn3oFTkReb7FMyHU/qZuv/Xtpcpu9O9ynfuW/NUAI4US6toWo3KRruzgOrsTr0h48XeuQoM/n6TaNesPYX+Gb/pBwAhbdZ//seoOwm3ze3qIH0O/VvCES7AHzb/+Abk/Zu7u3fg4x6+DQ/9lf5dntnXASImbDX4tB2QAN2j0AYf+0tx6WFzcfaHW3/QVZ3eAb7MHyeKS9G/zACvsLwOBmv6fSO8T+06c+eNe3//QJsQ8GkhufhRBCiHJVM4KkzWq//w9Is3oBKVxOu5K3nDkQHl4G3wyAuD2w9GEY+SMYXAre95pXID3JPkF350cKr4dOB80H2F8XDuft9l73ur1VsNsT4NuwpGebv+Q4++jpHfPBljU9UcvB0Pflmx9kVBoc3eCP2bvBz+683lp5OgosqfbW4ouH899eZ7TPYekUMrPfh4BXXdDXjD/uQlQ25dzxJYQootL43awZXdu7FsFPT6PcfGnv2RHlcZTJHabzSPsCHvx+ZifMHwyZ16DNfXDvV/m3dp3YBPPvAjR4Yh3U7Vz8uqUl2uu37csc3bsatBiU1e3d5+a6dFMuw+YP7N3vllT7ssZ94bZXoF4J6lsRLBmQdBquxNqnIkrM+nklFhJPQeIZUDeYWkjTg1edrBbNXCHTp749hBpM5XM+QtQQVquVw4cPExgYiL9/CQYxCiHK1KVLl4iPj6d58+bo9c7jEqRrO1tmGoTPAkDrNRnD3p1kAueSLxe8Td1OMPw7+M9w2PcjeAbDwFwPl7dmwq8v2N93HluyEAn2bu/uT8Ot4+wDXrZ+bm+JO/Sr/VWrFdz6JLQbXrxu7/Rk+PMz+6j09CT7snrdoN8r9nBalRhcrrdY5sdqgeRzOUJmrH3qoezAmXgarBn2z4mx10em52YOvh4yHYGz/vXAeaPpj4QQTvR6PT4+Po7nKru7u9/w0X5CiLKnlCIlJYX4+Hh8fHzyhMjiqP4tkn98Cr9PA8868OxOei2YSqJxA7cFj+CDgS8Vvu1fS2D5U/b3/s1AbwQ0ewthZipcjgF3f5iwHdz9Sq/OObu9M6/Zl7l6Q6fR9vkcfRsUvG1mGmz/BiLnQMol+7KgtvYA2WxAzRywYrPBtfisVsxTuQJn1vvMlBvvx93fuRXT6X1I0adJEqIGUUoRFxfHlStXKroqQohcfHx8CA4Ozvc/eNIiCZCWBJHv2d+H/ROMbngZvUgELhXledvtH4Sr8fb7IC8dyb9M/3+VbogEqNUc7nrPHv52LbJPj5Nwwt66+Mcn0PzOvN3e1kzY9T1EvAPJZ+3L/JrAbS9D63tq9kAUnc7equwZbJ9iKDel7KE7d7d5zs/pSfYyKZfg7K78j+PqnffeTEcLZ337n5OaGORFjaZpGrVr1yYwMJDMzGry+FghqgGj0XhTLZHZqneQ/Gux/R9+/6bQYSQAvm4+xKbClfQrRdtHz2ftT6dJPgeorMcpZv109Snb+wwd3d5PwZE19kCZp9v7KTC627vvs++x9KpnD87tR8gAk6LQNPucmR4B9tsa8pN6Jde9mVnd59mBM/Wy/X7XtL1wfm/++zB65AqZuUafmwMlaIpqS6/Xl8o/WkKIyuWmUsasWbN46aWXmDhxInPnzi2lKpWirk/YuyNdfRyBKsDdB1LhakZy0fdTq7n9VVF0emhxh/114VBWt/diuBANKyddL+dRC3q/AF0ekYEjpc3Nx/4Kbpv/+vSr9nsxr5yyDwByCpyn4Op5+20KFw7aX/nRm7JGntfPf/S5Z22ZpF0IIUSlUuIgGRUVxZdffkm7du1Ksz6lS6eDtvc5LQo2+8ElSLEmVVClblKtFnDXHPuo692L7E/jSb8Kfxtnn6dSHjNYMUxmCGxpf+UnM80eNBPz6Ta/Emu/HcGabr/v9nJM/vvQGezTGOXuNs85xVFhU1UJIYQQpaxEQfLq1auMHDmSr776ijfeeKO061Sm6njZ72fMsF2r4JrcJDef649iFJWf0RUCmtpf+bFmQtKZXCEzx+jzxNNgs2R1p58s4CBa3imOnAYG1QOjW5mdohBCiJqnREFy/Pjx3HXXXdx+++03DJLp6emkp6c7PiclVWxLYH1v+/OjrVoVD5KietEb7ZPQFzQRvc1qn1Te0YqZa/R5YixY0uxhNOkMxP6Z/348AvMZDJTjnk2TZ1mdoRBCiGqo2EFyyZIl7Ny5k6ioqCKVnzVrFq+//nqxK1ZWGvkF2t/o0riano7ZJPcSiipAp7c/A927LtT/W971SsG1C7kCZq5u9Iyr9mmQrsXDmR35H8fN9wZTHPnIgCAhhBAOxQqSsbGxTJw4kdWrV+d5uHdBpk2bxuTJkx2fk5KSCAkJKV4tS1FdL1/H+xOXL9Gmdp0bbpNhsWHUazKRrqi8NM0+6tscCPW65F2vlP355XmeDJRj9HnaFXuZ1AQ491f+x3HxzOfJQDkGBnkESNAUQogapFhBcseOHcTHx9O58/Upb6xWKxs3buTjjz8mPT09z/QOJpMJUyVq9TPqjWBzBV0aJxIuFBokj5xP5uMNR/nlr7M82K0+b91TwIhdISo7TbPPY+nuB3U65F8mLSnXRO25Rp9fuwAZyRC/3/7Kj8Et172ZIeDTwH5/pjnIPpen3KcphBDVRrGCZL9+/di713mOvEceeYSWLVsyderUKjNHmBEPMknj8MV4lFJ5WhoPnE3i4w1H+G1fHNnP/fnP1lOENa/FgFuCK6DGQpQDVy9wvQWCbsl/fUZKrimOco0+T46zP8/94mH7qyAmb/AMuh4sPYPtj6f0DL6+zBxkv19TWjeFEKJSK1aQ9PT0pE2bNk7LPDw88Pf3z7O8MjPpzGRyiU8i9jBvnY0mgWaaBZppEmhm+4kE1kafd5QdeEsQnq5GftxxmpdX7KNbIz983GWKFVEDubgXPqeqJT1r5HnukJnVonn1vH1AUHqi/VVY2AT7RPs5g6XjZ+2sIJoVPt18JXAKIUQFqZGPPQnxDiA68SQ6QyrJ1yzsjr3C7tgrjvWaBoPb1WFC36a0CPYkLdPKrlMJxFy4xsxfDvDv4R0qrO5CVFoGE/g1tr/yo5T96T9Xz9tbLwv6mRxn70LPTLE/rSn7iU0F0bvYA2a+oTNHi6dHgEzoLoQQpeymg2R4eHgpVKN81fcNIDoR/jm4Hr1q9eFo/FWOxCdzNP4qPu5GHunZiCa1rk/s7WrU8+797bnvsy0s23WGu9rVpl+roAo8AyGqIE27/oSgWi0KL5txrfCwmf0z9TJYM7Lm2oy9wfF19umPHK2ZuX8GXw+kMrG7EEIUSY1skWzu25zfT/zOH2c38VjbsbQI9gRqF7pNp/q+PNG7MV9sPMZLy/eyuoEf3u7G8qmwEDWNiwf4N7G/CmNJzwqV5+FqXMGh89oFUDZ7matxQAGj0rO5+xcQNnP9dHEvtVMWQoiqSFMqezhJ+UhKSsLb25vExES8vLzK89AOZ66e4Y7/3YGGxu9//53a5sJDZLa0TCuDPojk2MVr3Ne5Hu/d376MayqEKBVWC6RchORzOUJnfj/Pgy2z6Ps1eeXfnZ47dJq85D5OIUSVUtS8ViNbJOua69I1uCtRcVGsPLaSJ9o9UaTt7F3c7bjv8z/4ccdp7mpbm74tA8u4tkKIm6Y3XL9fsjA2m30ezatxNw6dllRIT7K/bjRwyODm3IVeUPh095PAKYSoUmpkiyTA8iPLeXXLqzT0asjPw34u1mTjb6w8wNebjhPoaWJwuzq4uehwM+pxNepxc9HTrq4Pbet5l2HthRAVSil7gMzZpV5Qt3p6MR4LqzNmBcsbhE6PWjJwSAhRpoqa12pskLyWeY2+P/Ql1ZLKokGLaFerXZG3Tc2wMujDSI5fLPh53cO7hPDPO1vi6yE37QtRo2Wk5GrNLCB0pl4u+j41nT1MFjRCXQYOCSFukgTJIpgWOY2Vx1YyvMVwpv9terG2PXnpGr/8dZZrGVbSMu2v1Awrl1My2Xj4AgB+Hi5Mv6sV93SsK49XFEIUzpJhD5WOgFlA6MweOFRUbn4FdKXnmpNTBg4JIXKQIFkEW85u4ak1T+Hl4sWGBzbgoi+d/7lvP3GZl5bv5fD5qwD0aOLPG8Pa0DjHlEJCCFEiNqs9TBY0B+fNDBwqaC5Oc5D9MZc+Dez3mwohqj0JkkVgtVkZ8L8BxKfE8++wf9O/Qf9S23eGxcbXm47x4bojpGXacNHrGN+3KePCGmMyyL1NQogy5jRw6Aah05JatH3qDPYw6d8E/LKmZ/JrbP/pHSL3bQpRjUiQLKL3d7zPt/u+JSwkjI9u+6jU93/qUgrTf9rn6O5uXMuDN4e1pXsT/1I/lhBCFFuegUP5zMmZHGef8N2SVvB+dEbwbZgjZDa+Hja96oFOV26nJIS4eRIki+jYlWMM/WkoBs3AugfW4efqV+rHUEqxcs85Zq48wIXkdADu61yPlwa1wk8G4wghqgKbDZLPwqUYuByT9fOY/WfCcfsThgqiN+UImY2dWzQ960jIFKISkiBZDCNWjmDfpX1M7TqVh1s/XGbHSUzN5N3fD7Jo6ymUAl93Iy/f1Zq/d5LBOEKIKsxmhaQzOULmsethM+FE4fdqGlyvP6M9T8isLfNqClFBJEgWw3+i/8OsbbNo5deKH+7+ocyPt+NkAi8v38vBuGQA/tbYjzeGtaVpoAzGEUJUM1aLvVv8cgxcPu7connlJNgsBW9rdM8VMHN0l5uDJGQKUYYkSBZDQloCt/33Niw2C8uGLKOZb7MyP2am1ca3m47z/trDjsE448Ka8HRYE1yNcsO6EKIGsGbClVPXu8gv52jJvHIKlLXgbV3M4Ncox6CfHN3mHrUkZApxkyRIFtPE9RNZH7ueR255hMldJpfbcWMvp/DqT/vYcMg+GKdRgAdvDmtDj6YB5VYHIYSodCwZWSEz5norZnbgTIwtfC5Nk1fekJndounuLyFTiCKQIFlM606tY9KGSdRyq8Vvf/8Nk95UbsdWSvHbvjhm/Lyf+KzBOPd2rMvLd7XC31x+9RBCiCrBkg4JJ51D5qWsrvPEWKCQf9ZM3s4jyp1CZukPthSiqpIgWUyZ1kwG/m8gF1IvMKb1GF7o+kK51yEpLZP3fj/Ewj9PohT4uBt56c5W3N+lngzGEUKIoshMsw/wyRMyj9kHBBXGzdf5Psyc0xi5+ZRH7YWoNCRIlkBEbAQT1k9AQ+PrAV/TrXa3CqnH7tgrTFu2l+hzSQB0a+THW/e0oWmgZ4XURwghqoXMVHurpVPIzLovM/lc4du6+zvfh5lzhLlr5fq3TIjSIEGyhF7/43V+PPwjwR7B/G/I//ByqZg6Wqw25m85wZzVh0nNtGLUa4wLbcL4vk1lMI4QQpS2jGsFh8yr5wvf1qNWjpDZ2Lm73CQNAKJqkiBZQimZKdz/y/2cSj7FoEaDmN1ndoXW53RCCjN+3s/a6HgAGvq788awtvRqJoNxhBCiXKQn5wqZx66HzWsXCt/WHJSjizxXyHTxKJ/6C1ECEiRvwp4Lexj922isyso7fd7hzkZ3Vmh9lFL8vv88M37eT1yS/RFlwzrUYfrg1gTIYBwhhKg4aUnOg31ytmimXCp8W8/aeR8nmT1vptGtfOovRAEkSN6kT3d/ymd/fYaniyfLhiwj2CPYsU4pxdErR4lPiadLcJdyG+GdnJbJnNWH+e6PE9gUeLkamDaoFcO7hKDTyWAcIYSoVFKvOHeR52zJTE0ofFuvunmf9OPXxP6oSaNredRe1HASJG9Spi2T0f83mn2X9nFr8K28E/oOW89tZfOZzfxx9g/iU+1dzX6ufjzY4kEeaPEA/m7+5VK3Paev8NLyvew7Yx+M0yjAg1qeJtxd9LgZ9bi56HO8NzgtdzNmrXO8t693zVruatSjL8dQqpTCalNYsl9WG5lWhcVmw2K1L7PaFK5GnaOuJoNORrELIaq2lMvOwTLnhOxpiYVsqIF3vYJDpsGlvM5AVHMSJEvBicQTPLDyAVItqXnWmfQmPIweXE67DICLzoXBTQYzqtUomvo2LfO6Waw2FvxxkjmrD5GSUcjTH0rAZNA5h08XPe5GgyN8mow6R+izWBWZNoXVlhUArbasddfDYKbNhjWrXPY29uBo36a4NA3cc4TknEHYHpINWetzLcsRsN1dDLnWZy0r5yAthBBOlMoKmbmnL8pq2cxILnhbTZcVMnPPkdkEfBuA3lh+5yGqPAmSpeS/h//LzD9mAtDMtxk9avegR90edA7qjE7TsfbkWr7b/x37Lu1zbNOjTg8eafMItwbfWuYtZxevprPn9BVSMqykZlhJzbT/TMn1Pi3TSkqGJcf7vGUrE4NOw6DXMOh06DRIs9jIsBTyJItSlB2kc4ZNN0dQNeQKrc7hNWcozbk+O4i7GHTlcg5CiGpIKbh2seCQmXmt4G01PYR0g5Z32V9+jcuv3qJKkiBZiqIvRePv5k+ge2C+65VS7L6wm4UHFrLu1DpsWY/uauXXikfaPEL/Bv0x6AzlWeViU0qRlmkjNStwZofS/AJnhsWGQaeh12kYs8KeIcdPxzKdhkGfvc6+zKjPWpYjKGa/N2Yt1+u0fAO4xWpzqou9Ppbr7x3Lc9U/w0pKppXUjFxlMy1O51UevwkGnZajJdTgdKuBU3jNvtXA8T5HqM0ZVJ0CrnT5C1HT2GyKDKuN9EwrmUlx9mB5KQZdwjH0V45hvHIcU/JJ9Ll71gJbXw+VtTvIYyNFHhIkK0hsciwLDyxk+ZHlpFntI6zrmusyuvVohjUdhrvRvYJrKPKTHaSzW22zQ2h2KL0eVC2kZFpJyw6tmTmWZzgH7pzLLLay/zXTNJyDqTF39/2Nu/yvt8AayN3tL13+oibLDmwZVnvvSIbFRmbW+3SLfXmmxXm9431+21idP18vl3UcizVrvSpwXxlWG9Yi/d2iqKddoJ9uF/e6/0XbzL3oyNEL5VUPWg6yh8oGPaULXAASJCtcQloCSw4tYXH0YhLS7aPzfEw+PNjyQUa0HIGfqzzTtSbJsNgcraD5tZ6m5Go1dWoFzhlUM/MuSy+nLn+X7C5/Y457SnOG0jzh83p4NRl16DUNnU5Dp2noNJze6zV7K7ROw9Einf1ep2loOd7rNLJ+Zr105Pter2loOvu+89uHtN5WTjkDW4HBLDu45QxyjtBlzRG6VI7yVjIdIc2+TWaucJYnGOY4Xnn8Z7A0uOh1uBiyXnodRoOGi16HUnDsor3r25ur9NXtZojrTnryFyZbjtZKV29ofoc9VDbpByZzBZ2JqGgSJCuJVEsqPx39iQX7F3D66mnAPlBnWNNhjGk9hhCvkAquoajqrDbldEtCSq4Aer111R5UncOo8y0CztvbW1/L92+I8qM5AmnOYJor4OYMtdlht4Bwqmka+qwgq2kaei1vwM13fwUEZk27fhynsJyrjvkHcntdcr53qpcu+30Rz1kDm1LOwcxitQc3a84glyv05fycvb6QFrtMa8kG4FWE7MBm1GvOwU2vw2S4HuaMel2ecJfzpzHrp+lG5XPsP095x7r8bwvKdj4pjQ0H41l3MJ5NRy6SmmnFRAY9dfu407CDgYZdeNmuXN9Ab4Imfe2hsvmdYK5V9l+sqDQkSFYyVpuVtafWMm/fPPZf2g+ATtNxe/3beaTNI7QJaFPBNRQiL6UU6RZb3tbTfO5PvR5Qc4XSTPsAL6UUNmUPJDbb9fdWm0Jlv1c53tuc39tU1nRRuba37y/H+6qRQ0QRGfVantCVXyC73gKnw6TPFeRuUN5Fn38wy1M+Ozjqq/79yGmZVv48dol10fGsPxjPmSup6LDRUTvCAP127nbZSR1bzuePa1D/b/ZQ2WKQfTS4qNYkSFZSSim2n9/Ot/u+ZdOZTY7l3YK7MfaWsfSq26vK/wUlREVSquBg6gijuYOpIiucFjXs2tdZs7ZRBbzPub/cwTjn/vKtly3/ujjtN0ed7fvMep9dRxtZ+7/5Ouo1zTnIZYesfEKbKUcLmYtBn6N8VuudXu/UmmfKWpbdDevYn04nD1soB0opDp1PdoTKnacSUErRTDvDAN12Bhl3cAsxzhvVanV9sE6djjJYpxqSIFkFHE44zIL9C/i/Y/+HRVkA+xRDY28Zy50N78QoNzwLIYQoZ5euphNx+ALrDsaz8dAFktMt1OYSt+t3cId+O7fqojE4Ddapa2+lbHkXNOwlg3WqCQmSVUjctTgWHljIj4d/JMWSAkCQexCjWo/ivub34WH0qOAaCiGEqIkyrTaiTlxmfbT93srjF6/hlTVYZ4B+O7fp9+BG2vUNXL2h2UB7qGzaD0yeFVd5cVMkSFZBSRlJ/HDoBxZFL+Ji6kUAPI2eDG85nJGtRhLgFlDBNRRCCFGTHbtwlfUH41kXHU/Uicvoben00O1ngG47Aww78SfH4x31JmgclnVf5Z1gzn8uZlE5SZCswjKsGaw8tpJ5++ZxIukEAEadkSFNhjDmljE08m5UsRUUQghR4yWmZhJ55ALro+PZcCiexJR0OmpH6K/fwR26KBrqzjvKKjQ0x5N1BstgnSpAgmQ1YFM2wmPDmbdvHrsv7AZAQyMsJIxH2zxKh8AOFVk9IYQQArAP3todm8Da6HjWR8dz6HwSTbMG6wzQb6eD7pjzBrVa5niyTkfQyeNjKxsJktXMrvhdzNs3jw2xGxzLOgZ25JFbHiE0JBSdZv8ltI9CtZJpyyTDmkGmLROLzeJ4n3N57veZ1us/M2wZ+b7PtGUC4Ofqh7+rP/5u/gS4BTjey5N7hBBCxF5OYcMhexf4HzGX8LNe4Hb9TgbottNddwCjlmOwjmedHE/W6QUGl4qruHCQIFlNHUs8xnf7v+PnmJ8doc5stD95IDsYKipuIj03gxv+rlnhMlfI9Hfzd1rnZnCrsHoKIYQoH9fSLWw+etF+b+XBeNKTLxOWNVgnTPcXZu36YB1l8kJrnj1Y53YZrFOBJEhWcxdSLrAoehE/HPqB5MzkQsu66Fww6o32nzojRr3R6Wf2+pzvDTpDvsuNOiMKxeXUy1xMvciltEtcSr3EpbRLpFpSC61Hbu4Gd6fA6efq5xQ+s9f5u/rjanC9ma9LCCFEJWCzKfadTXTMWXn4zAW66/YzQLeD/vod1NKuD9ZRehe07ME6ze8Ez6CKq3gNJEGyhkjJTOHctXP2YJgzJGa9N2iGcpvgPCUzxSlcZr+/mHrRHjazAufF1IukW9OLtW9/V3/qedajnmc96prrUs9sfx/iGUItt1rodfoyOishhBBlJedjGzcfiael5RAD9DsYoIuisS7OUU6hodXren2wTkDTCqx1zSBBUlRaSimuZV5zCplOrZs5Auel1Etk2DIK3Z9BZ3AKl3XNde2hM+uzp4t0jQghRGWX/djG9QfjWXfgPK5JMQx0DNZxfrKOCmiBlh0q68hgnbIgQVJUC0opkjKSOHP1DKeTT3P66mnOJJ/h9NXTnE4+zdmrZx1PBSqIl4uXU7DMDpoh5hCCzcEYdfIUBiGEqEyUUhw+f5W10eftzwI/FcPtuh35DtaxmYPRZY8Ab9hbBuuUEgmSokaw2qzEp8Q7gmVscqw9bGYFz8tplwvdXqfpCHYPdnSb5w6bviZfefa5EEJUsMvXMgg/ZO8C33XoBF0yd2QN1tntNFjH5uKJLudgHVfJGSUlQVII7Pdt5m7FzPn5Rvdquhvc8+0ur2euRx1zHRkEJIQQ5SznYxs3Rp+hTsI2Bui2c7t+J4HaFUc5m84FGvVG12qw/VngnsEVV+kqSIKkEDeglOJi6kWngHk62f46c/UM8SnxN5xKKdAt0DloZoXMuua61HKv5ZjfUwghRNnIfmzj+gNxZJyKop8WxQDddprozjmVs9TpgqH14KzBOs0qqLZVhwRJIW5SujWds1fPOoKlU9i8epprmdcK3d5F50Jdz7qOYJm7+9zD6FFOZyKEEDVDzsc2Hj+4i79l/MkA/XY66o46lcvwaYrxlrvRWg2GOp1ksE4+JEgKUYaUUiSmJ+Ztzcz6GXctDquyFroPX5Pv9RZMz+ujzut51iPIPQiDzlBOZyOEENVPzsc27t4fTePLG7MG6+zHJcdgnXS3QAyt7kLfejA07CODdbJIkBSiAllsFuKuxeXpLs8Om1fSrxS6vUEzEOwR7Dx3ZtZI83qe9fBy8ZJBQEIIUQzZj23csv84bifWc5u2jTDdX3hq1x+mkWEwY2vSH9e2d0PT/jV6sI4ESSEqsasZV52CZWxyrOPzmatnHI+/LIjZaM4z+Ce7VbOOuQ4uevkftRBCFCT7sY0RB06TfHADt6b/QX/9DqfBOlbNQErdXpjbD0FrMQi8aldchSuABEkhqiibshGfEp/3vsyskHkh9UKh22toBHkEOU3SnjN0+rv6S2umKJRN2UizpJFuTSfdmk6aJQ2DzoCXyQuz0SyDyES1YrMp9p9NYl30OWL3bqLJ5QgG6LbTVHfWqVyiX3vc2w3FeMvdUKt5BdW2/JRJkJw1axbLli3j4MGDuLm50aNHD2bPnk2LFi1KvWJCiPylWlIdg4By35t55uqZGz7z3FXvmu+URnXNdalrrou70b2czkQUlcVmcQS6dGs6adY00i3pTu/TrGnOZSxpedblVy6/soW1iOs0HWajGW+TN14uXvaXySvf944yWcvMRrP8J0ZUetmPbdy/Zzs+p9bQl210yjVYJ9GjIbpWg/FsPwzqdq6Wg3XKJEjecccdPPjgg3Tt2hWLxcLLL7/M3r17OXDgAB4eRRuBKkFSiLKjlOJy2mWnYJl7ENCNpjTKfq55fnNnBroHynPNgUxbZp5Q5hTabhDy0q3ppFpSbxjusvdhsRX+9KayZNAZcNW7YrFZSLOm3XiDQug0HZ4unnmDZgFhNOd6D6OHhFBR7rIf27ht7wE4+Bvd0v+gh26f02Cdq0Z/UhsPxK/zvegb9wGDqQJrXHrKpWv7woULBAYGEhERQZ8+fUq1YkKI0pdpzeTctXP5tmaevnqa5IzkQrfP+VzzPHNnetbFy6X8f6eVUmTaMgsNcqnW1CKFuzyteQWsv9GI/LLkonPBZDDhqnfFpDfharD/zPneVe96/b2h8HK595V7Wc7/OKRb00lKTyIpI+uVz/vE9MR8199o8v8b0Wt6pxCaX9gsqGVUQqgoDdmPbYzYG0Pyvt9odjmCvrrdToN10nTuXK4Thm+nYbi1vgNcvSuwxjenXILk0aNHadasGXv37qVNmzalWjEhRPlLTE/M04qZ/bm4zzXPOaWRv6s/GdaMArtYixTucgRER2te1vobtbKWpezglV8wyy/w5RfybhTucv6sqvcnZodQp6CZTxhNzEjMsyzDlnFTx9Zr+rxBs4hh1N3gLiFU5OvytQw2HjjN6d2rqXV6LWFEEZRjsI4FA3H+3XBrOwT/TsOq3GCdMg+SSimGDh1KQkICkZGRBZZLT08nPf36/0STkpIICQmRIClEFWO1WTmfct4RLIv7XPPyoKE5hTM3g1uBgS6/8JZzm8ICYs59SMgoe2mWtIJbPW/QMnqjGRBuxKAZ8HTxdIRNT5OnUxjNL4RmL3MzuMmfjxoi02oj6vhFDm6PwBSzim7pf9BMd8apzBmP1libD6L2rfdhDGoJlfzPRpkHyfHjx/Prr7+yadMm6tWrV2C5GTNm8Prrr+dZLkFSiOqlsOeaJ6Qn5A1v2d2oRWyZMxlMuOnd8m/xy/pp1BnlH27hoJQizZp24y74AsJoaYTQgrrbbzRASUJo1XbswlV27NhG5v6VtEzcSCfdEaf1540hJDYYQHC3v+PVtHulHKxTpkHymWeeYcWKFWzcuJFGjRoVWlZaJIUQQlQ1SilSLamFBs3C7gm92QFSBp2h8JHwhYRRCaGVS2JqJtv27Cdh18/UiVtPV7UXk3b9z8cVnS9ng/vi3WEYdToORDO6VmBtryuTIKmU4plnnmH58uWEh4fTrFnxH3ou90gKIYSoznKG0IKCZmHvb3Qv8o0YdcZ8g6ZJb0Kv6dFregw6Awadwf5Zp8egGew/s5YV9DO7THb5gvZVnH3XpNBrtSn2xJzi1LZf8DrxO50zovDKMVgnBVeO+fRE3/ouGve4B5PZr8LqWiZB8umnn+Y///kPP/30k9Pckd7e3ri5uZVqxYQQQoiaJt8QWlALaEYSyenJTssrckaBksoOtyUNqQadc/kCf+YItXn2nbU/o87oeK/Xsj7f7L5z1Vun6Rzh+fTFK0T/8RvaoV9pm7yJIC3B8b1kKj1H3DuQ2vhOGvS8j4A6hfcAl7YyCZIF/a9h3rx5jB07tlQrJoQQQoiiU0qRYkkpsLUz05aJxWbBYrNgVVasNisWlfXZZsWqrI51uX9abfb3FuVcNs/nQvZdFUNuWSkoAFszLWgZqZgsqbiRiUGBHoVBQYbmSh+//jxz35xyqWNR85qhODst56cpCiGEEKKINE3Dw+iBh9GD2lS+qWaUUgWH1azgWdKQWlAALnDf2fsqg33n/GlTtny/C4uyYLFaIL9srQNcNMAl9zdIm9TzpXxVbl6xgqQQQgghRElomuZoiaspbMqWJ2xm2jKvt9LmDK75BNns7S5fiuNsdCRdOt5X0aeUR825mkIIIYQQ5Uin6dDpdRgx3tyO6gHt7y+VOpW2yjdxkRBCCCGEqBIkSAohhBBCiBKRICmEEEIIIUqk3O+RzB75nZSUVN6HFkIIIYQQRZCd0240Y0+5B8nk5GQAQkJCyvvQQgghhBCiGJKTk/H29i5wfYmetX0zbDYbZ8+exdPTs1wei5T9bO/Y2FiZAL2KkmtYtcn1q/rkGlZ9cg2rtoq4fkopkpOTqVOnDjpdwXdClnuLpE6no169euV9WLy8vOSXp4qTa1i1yfWr+uQaVn1yDau28r5+hbVEZpPBNkIIIYQQokQkSAohhBBCiBKp9kHSZDLx2muvYTKZKroqooTkGlZtcv2qPrmGVZ9cw6qtMl+/ch9sI4QQQgghqodq3yIphBBCCCHKhgRJIYQQQghRIhIkhRBCCCFEiUiQFEIIIYQQJVKtg+Snn35Ko0aNcHV1pXPnzkRGRlZ0lUQBZs2aRdeuXfH09CQwMJBhw4Zx6NAhpzJKKWbMmEGdOnVwc3MjLCyM/fv3V1CNRWFmzZqFpmlMmjTJsUyuX+V35swZHn74Yfz9/XF3d6dDhw7s2LHDsV6uYeVmsViYPn06jRo1ws3NjcaNGzNz5kxsNpujjFzDymXjxo3cfffd1KlTB03TWLFihdP6olyv9PR0nnnmGQICAvDw8GDIkCGcPn263M6h2gbJpUuXMmnSJF5++WV27dpF7969ufPOOzl16lRFV03kIyIigvHjx/Pnn3+yZs0aLBYLAwYM4Nq1a44y77zzDv/+97/5+OOPiYqKIjg4mP79+zue3y4qh6ioKL788kvatWvntFyuX+WWkJBAz549MRqN/Pbbbxw4cIA5c+bg4+PjKCPXsHKbPXs2n3/+OR9//DHR0dG88847vPvuu3z00UeOMnINK5dr167Rvn17Pv7443zXF+V6TZo0ieXLl7NkyRI2bdrE1atXGTx4MFartXxOQlVT3bp1U+PGjXNa1rJlS/XPf/6zgmokiiM+Pl4BKiIiQimllM1mU8HBwertt992lElLS1Pe3t7q888/r6hqilySk5NVs2bN1Jo1a1RoaKiaOHGiUkquX1UwdepU1atXrwLXyzWs/O666y716KOPOi2799571cMPP6yUkmtY2QFq+fLljs9FuV5XrlxRRqNRLVmyxFHmzJkzSqfTqVWrVpVLvatli2RGRgY7duxgwIABTssHDBjAli1bKqhWojgSExMB8PPzA+D48ePExcU5XVOTyURoaKhc00pk/Pjx3HXXXdx+++1Oy+X6VX4///wzXbp04f777ycwMJCOHTvy1VdfOdbLNaz8evXqxbp16zh8+DAAf/31F5s2bWLQoEGAXMOqpijXa8eOHWRmZjqVqVOnDm3atCm3a2ool6OUs4sXL2K1WgkKCnJaHhQURFxcXAXVShSVUorJkyfTq1cv2rRpA+C4bvld05MnT5Z7HUVeS5YsYefOnURFReVZJ9ev8jt27BifffYZkydP5qWXXmLbtm08++yzmEwmRo8eLdewCpg6dSqJiYm0bNkSvV6P1WrlzTffZMSIEYD8HlY1RblecXFxuLi44Ovrm6dMeeWdahkks2ma5vRZKZVnmah8JkyYwJ49e9i0aVOedXJNK6fY2FgmTpzI6tWrcXV1LbCcXL/Ky2az0aVLF9566y0AOnbsyP79+/nss88YPXq0o5xcw8pr6dKlfP/99/znP//hlltuYffu3UyaNIk6deowZswYRzm5hlVLSa5XeV7Tatm1HRAQgF6vz5PG4+Pj8yR7Ubk888wz/Pzzz2zYsIF69eo5lgcHBwPINa2kduzYQXx8PJ07d8ZgMGAwGIiIiODDDz/EYDA4rpFcv8qrdu3atG7d2mlZq1atHAMU5Xew8nvxxRf55z//yYMPPkjbtm0ZNWoUzz33HLNmzQLkGlY1RblewcHBZGRkkJCQUGCZslYtg6SLiwudO3dmzZo1TsvXrFlDjx49KqhWojBKKSZMmMCyZctYv349jRo1clrfqFEjgoODna5pRkYGERERck0rgX79+rF37152797teHXp0oWRI0eye/duGjduLNevkuvZs2eeKbcOHz5MgwYNAPkdrApSUlLQ6Zz/Wdfr9Y7pf+QaVi1FuV6dO3fGaDQ6lTl37hz79u0rv2taLkN6KsCSJUuU0WhU33zzjTpw4ICaNGmS8vDwUCdOnKjoqol8/OMf/1De3t4qPDxcnTt3zvFKSUlxlHn77beVt7e3WrZsmdq7d68aMWKEql27tkpKSqrAmouC5By1rZRcv8pu27ZtymAwqDfffFMdOXJELVq0SLm7u6vvv//eUUauYeU2ZswYVbduXbVy5Up1/PhxtWzZMhUQEKCmTJniKCPXsHJJTk5Wu3btUrt27VKA+ve//6127dqlTp48qZQq2vUaN26cqlevnlq7dq3auXOnuu2221T79u2VxWIpl3OotkFSKaU++eQT1aBBA+Xi4qI6derkmEpGVD5Avq958+Y5ythsNvXaa6+p4OBgZTKZVJ8+fdTevXsrrtKiULmDpFy/yu+XX35Rbdq0USaTSbVs2VJ9+eWXTuvlGlZuSUlJauLEiap+/frK1dVVNW7cWL388ssqPT3dUUauYeWyYcOGfP/tGzNmjFKqaNcrNTVVTZgwQfn5+Sk3Nzc1ePBgderUqXI7B00ppcqn7VMIIYQQQlQn1fIeSSGEEEIIUfYkSAohhBBCiBKRICmEEEIIIUpEgqQQQgghhCgRCZJCCCGEEKJEJEgKIYQQQogSkSAphBBCCCFKRIKkEEIIIYQoEQmSQgghhBCiRCRICiGEEEKIEpEgKYQQQgghSkSCpBBCCCGEKJH/Bw0z3kjgM4bmAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "np.mean(distill_entropy_dict[(1, 1)][:20])\n",
    "\n",
    "def compute_top20_entropy(spec_or_ir_list, fixed_value, mode, softmax_dict):\n",
    "    \"\"\"\n",
    "    Compute the top-20 class probability for different modes.\n",
    "    \n",
    "    Args:\n",
    "        spec_or_ir_list (list): List of spec_number or model_ir values to iterate over.\n",
    "        fixed_value (int): Fixed value for spec_number or model_ir.\n",
    "        mode (str): Mode of operation ('lt_normal', 'normal_lt', 'lt_lt').\n",
    "        softmax_dict (dict): Dictionary containing softmax and label data.\n",
    "        \n",
    "    Returns:\n",
    "        list: Computed top-20 class probabilities.\n",
    "    \"\"\"\n",
    "    top20 = []\n",
    "    for value in spec_or_ir_list:\n",
    "        if mode == \"lt_normal\":\n",
    "            entropy = np.mean(softmax_dict[(value, fixed_value)][:20])\n",
    "        elif mode == \"normal_lt\":\n",
    "            entropy = np.mean(softmax_dict[(fixed_value, value)][:20])\n",
    "        elif mode == \"lt_lt\":\n",
    "            entropy = np.mean(softmax_dict[(value, value)][:20])\n",
    "        else:\n",
    "            raise ValueError(\"Invalid mode specified.\")\n",
    "        \n",
    "        top20.append(entropy)\n",
    "    return top20\n",
    "\n",
    "# Define spec_number_list and model_ir\n",
    "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
    "\n",
    "plt.figure(figsize=(8, 2))\n",
    "\n",
    "# Plot for \"lt image with normal label\"\n",
    "top20_lt_normal = compute_top20_entropy(spec_number_list, 100, \"lt_normal\", distill_entropy_dict)\n",
    "plt.plot(spec_number_list, top20_lt_normal, label=\"lt image with normal label\")\n",
    "\n",
    "# Plot for \"normal image with lt label\"\n",
    "top20_normal_lt = compute_top20_entropy(spec_number_list, 100, \"normal_lt\", distill_entropy_dict)\n",
    "plt.plot(spec_number_list, top20_normal_lt, label=\"normal image with lt label\")\n",
    "\n",
    "# Plot for \"lt image with lt label\"\n",
    "top20_lt_lt = compute_top20_entropy(spec_number_list, None, \"lt_lt\", distill_entropy_dict)\n",
    "plt.plot(spec_number_list, top20_lt_lt, label=\"lt image with lt label\")\n",
    "\n",
    "# Finalize plot\n",
    "plt.title(\"Top20 Class Entropy\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "spec_number_list_entropy = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
      "top20_lt_normal_entropy = [np.float32(5.6648626), np.float32(3.8422647), np.float32(3.8123982), np.float32(3.9025292), np.float32(3.6237488), np.float32(3.616661), np.float32(3.0400279), np.float32(3.0016918), np.float32(3.0187619), np.float32(2.860466), np.float32(2.826674), np.float32(2.9241517), np.float32(1.8249185)]\n",
      "top20_normal_lt_entropy = [np.float32(4.1526685), np.float32(4.5011816), np.float32(4.394666), np.float32(4.1888804), np.float32(4.188092), np.float32(4.4936137), np.float32(4.097073), np.float32(4.5800586), np.float32(4.328223), np.float32(3.8746536), np.float32(3.5122585), np.float32(2.9795494), np.float32(1.8249185)]\n",
      "top20_lt_lt_entropy = [np.float32(6.4173517), np.float32(3.771934), np.float32(3.2715278), np.float32(3.0069776), np.float32(3.0580797), np.float32(2.9762578), np.float32(2.551225), np.float32(2.5741076), np.float32(2.4895694), np.float32(2.0019598), np.float32(2.1331477), np.float32(1.8858362), np.float32(1.8249185)]\n"
     ]
    }
   ],
   "source": [
    "print(f\"spec_number_list_entropy = {spec_number_list}\")\n",
    "print(f\"top20_lt_normal_entropy = {top20_lt_normal}\")\n",
    "print(f\"top20_normal_lt_entropy = {top20_normal_lt}\")\n",
    "print(f\"top20_lt_lt_entropy = {top20_lt_lt}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "def compute_tail80(spec_or_ir_list, fixed_value, mode, softmax_dict):\n",
    "    \"\"\"\n",
    "    Compute the tail-80 class probability for different modes.\n",
    "    \n",
    "    Args:\n",
    "        spec_or_ir_list (list): List of spec_number or model_ir values to iterate over.\n",
    "        fixed_value (int): Fixed value for spec_number or model_ir.\n",
    "        mode (str): Mode of operation ('lt_normal', 'normal_lt', 'lt_lt').\n",
    "        softmax_dict (dict): Dictionary containing softmax and label data.\n",
    "        \n",
    "    Returns:\n",
    "        list: Computed tail-80 class probabilities.\n",
    "    \"\"\"\n",
    "    tail80 = []\n",
    "    for value in spec_or_ir_list:\n",
    "        if mode == \"lt_normal\":\n",
    "            softmaxs, labels = softmax_dict[value][fixed_value]\n",
    "        elif mode == \"normal_lt\":\n",
    "            softmaxs, labels = softmax_dict[fixed_value][value]\n",
    "        elif mode == \"lt_lt\":\n",
    "            softmaxs, labels = softmax_dict[value][value]\n",
    "        else:\n",
    "            raise ValueError(\"Invalid mode specified.\")\n",
    "        \n",
    "        softmaxs_bin = bin5(softmaxs)\n",
    "        new_labels = labels // 20\n",
    "        mean = np.mean(softmaxs_bin[new_labels == 0], axis=0)\n",
    "        tail80.append(np.mean(mean[1:]))\n",
    "    return tail80\n",
    "\n",
    "# Define spec_number_list and model_ir\n",
    "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
    "\n",
    "plt.figure(figsize=(8, 2))\n",
    "\n",
    "# Plot for \"lt image with normal label\"\n",
    "tail80_lt_normal = compute_tail80(spec_number_list, 100, \"lt_normal\", softmax_dict)\n",
    "plt.plot(spec_number_list, tail80_lt_normal, label=\"lt image with normal label\")\n",
    "\n",
    "# Plot for \"normal image with lt label\"\n",
    "tail80_normal_lt = compute_tail80(spec_number_list, 100, \"normal_lt\", softmax_dict)\n",
    "plt.plot(spec_number_list, tail80_normal_lt, label=\"normal image with lt label\")\n",
    "\n",
    "# Plot for \"lt image with lt label\"\n",
    "tail80_lt_lt = compute_tail80(spec_number_list, None, \"lt_lt\", softmax_dict)\n",
    "plt.plot(spec_number_list, tail80_lt_lt, label=\"lt image with lt label\")\n",
    "\n",
    "# Finalize plot\n",
    "plt.title(\"tail80 Class Probability\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "spec_number_list = [0, 1, 2, 3, 4, 5, 10, 15, 20, 40, 60, 80, 100]\n",
      "tail80_lt_normal_probability = [np.float64(0.009663803949473991), np.float64(0.008454102539020434), np.float64(0.008440087957611532), np.float64(0.008540587990355562), np.float64(0.008149019556090431), np.float64(0.008320983846438139), np.float64(0.007988034460721402), np.float64(0.00792989107783699), np.float64(0.007371849590536905), np.float64(0.007485946289852368), np.float64(0.007689507100660811), np.float64(0.007776554375725157), np.float64(0.007441437461694217)]\n",
      "tail80_normal_lt_probability = [np.float64(0.011954195417553949), np.float64(0.011469806129584217), np.float64(0.011485524887589237), np.float64(0.011445172988162864), np.float64(0.011505333069156094), np.float64(0.011590765387544317), np.float64(0.011566831365740394), np.float64(0.011330878647791646), np.float64(0.011099635660184504), np.float64(0.010233414586377226), np.float64(0.009479656104673008), np.float64(0.008629214104588365), np.float64(0.007441437461694217)]\n",
      "tail80_lt_lt_probability = [np.float64(0.01173845558825373), np.float64(0.01144803901967472), np.float64(0.011400451174856375), np.float64(0.011306341582014413), np.float64(0.011353086443991092), np.float64(0.011431328415390324), np.float64(0.011354747698408444), np.float64(0.01109731932298538), np.float64(0.010607226281192978), np.float64(0.009522395100763918), np.float64(0.0089763929618344), np.float64(0.008181663302943239), np.float64(0.007441437461694217)]\n"
     ]
    }
   ],
   "source": [
    "print(f\"spec_number_list = {spec_number_list}\")\n",
    "print(f\"tail80_lt_normal_probability = {tail80_lt_normal}\")\n",
    "print(f\"tail80_normal_lt_probability = {tail80_normal_lt}\")\n",
    "print(f\"tail80_lt_lt_probability = {tail80_lt_lt}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch251",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
