{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "2901c43c-fad3-497b-8925-1e0be4e3db87",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Arguments: ########################\n",
      "dir=../noise_celebA_0.1/\n",
      "data_path=../data\n",
      "epochs=100\n",
      "save_epochs=5\n",
      "batch_size=64\n",
      "data_type=celebA\n",
      "device_id=None\n",
      "seed=1\n",
      "pretrained=True\n",
      "l2=0.0005\n",
      "lr=0.5\n",
      "p_noise=0.1\n",
      "###################################\n",
      "==> Preparing data..\n",
      "==> Building model..\n"
     ]
    }
   ],
   "source": [
    "from __future__ import print_function\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "import torch.backends.cudnn as cudnn\n",
    "\n",
    "import torchvision\n",
    "import torchvision.transforms as transforms\n",
    "from torchvision.models import resnet34, resnet50, densenet121\n",
    "from models.resnet_alea import resnet50_alea, sample_softmax\n",
    "import argparse\n",
    "from scipy.stats import entropy\n",
    "\n",
    "from torch.autograd import Variable\n",
    "from utils.dataloader import *\n",
    "from utils.loss import GeneralizedCELoss\n",
    "import numpy as np\n",
    "import random, pickle, os, heapq, pdb, glob\n",
    "\n",
    "parser = argparse.ArgumentParser()\n",
    "parser.add_argument('--dir', type=str, default=None, help='path to save checkpoints (default: None)')\n",
    "parser.add_argument('--data_path', type=str, default='../data', metavar='PATH',\n",
    "                    help='path to datasets location (default: None)')\n",
    "parser.add_argument('--epochs', type=int, default=100,\n",
    "                    help='number of epochs to train (default: 8)')\n",
    "parser.add_argument('--save_epochs', type=int, default=5,\n",
    "                    help='Saving period')\n",
    "parser.add_argument('--batch-size', type=int, default=128, metavar='N',\n",
    "                    help='input batch size for training (default: 64)')\n",
    "parser.add_argument('--data_type', type=str, default='iwildcam',\n",
    "                    help='Dataset type of WILDS (default: iwildcam)')\n",
    "parser.add_argument('--device_id',type = int, help = 'device id to use')\n",
    "parser.add_argument('--seed', type=int, default=1,\n",
    "                    help='random seed')\n",
    "parser.add_argument('--pretrained', action='store_true',\n",
    "                    help='Use ResNet50, pretrained with ImageNet')\n",
    "parser.add_argument('--l2', type=float, default=5e-4,\n",
    "                    help='weight decay')\n",
    "parser.add_argument('--lr', type=float, default=0.5,\n",
    "                    help='initial learning rate')\n",
    "parser.add_argument('--p_noise', type=float, default=0.0,\n",
    "                    help='proportion of noisy labels')\n",
    "\n",
    "args = parser.parse_args(args=[])\n",
    "device_id = args.device_id\n",
    "use_cuda = torch.cuda.is_available()\n",
    "torch.manual_seed(args.seed)\n",
    "np.random.seed(args.seed)\n",
    "random.seed(args.seed)\n",
    "args.data_type = 'celebA'\n",
    "args.pretrained = True\n",
    "args.dir = '../noise_celebA_0.1/'\n",
    "args.batch_size = 64\n",
    "args.p_noise = 0.1\n",
    "\n",
    "print(\"Arguments: ########################\")\n",
    "print('\\n'.join(f'{k}={v}' for k, v in vars(args).items()))\n",
    "print(\"###################################\")\n",
    "# Data\n",
    "print('==> Preparing data..')\n",
    "\n",
    "dataset = WildsDataset(args.data_type, args)\n",
    "dataset.inject_label_noise(args.p_noise)\n",
    "trainloader, valloader, testloader = dataset.get_loader(args) \n",
    "args.temperature = 1/dataset.N_training\n",
    "kld_weight = args.batch_size/dataset.N_training\n",
    "\n",
    "\n",
    "# Model\n",
    "print('==> Building model..')\n",
    "if args.pretrained:\n",
    "    if args.data_type in ['iwilds','rxrx1', 'waterbirds', 'celebA']:\n",
    "        net = resnet50(pretrained=True)#* Load pre-trained model\n",
    "        net.fc = torch.nn.Linear(net.fc.in_features, dataset.target_dim) #* change output dimension\n",
    "    elif args.data_type in ['fmow']:\n",
    "        net = densenet121(pretrained=True)\n",
    "        net.classifier = torch.nn.Linear(net.classifier.in_features, dataset.target_dim) #* change output dimension\n",
    "else:\n",
    "    if args.data_type in ['waterbirds']:\n",
    "        net = resnet50(pretrained=False)\n",
    "        net.fc = torch.nn.Linear(net.fc.in_features, dataset.target_dim) #* change output dimension\n",
    "    elif args.data_type in ['camelyon17']:\n",
    "        net = densenet121(pretrained=False)\n",
    "        net.classifier = torch.nn.Linear(net.classifier.in_features, dataset.target_dim) #* change output dimension\n",
    "    else:\n",
    "        from models import *\n",
    "        net = ResNet18(num_classes=dataset.target_dim)\n",
    "\n",
    "if use_cuda:\n",
    "    net.cuda(device_id)\n",
    "    cudnn.benchmark = True\n",
    "    cudnn.deterministic = True\n",
    "\n",
    "\n",
    "def get_hard_index(model_paths, criterion, p=0.1):\n",
    "    ens_score_list = []\n",
    "    \n",
    "    for model_path in model_paths:\n",
    "        net.load_state_dict(torch.load(model_path))\n",
    "        model = net\n",
    "        \n",
    "        trainloader_ordered, _ = dataset.get_loader(args, shuffle_train=False) \n",
    "        model.eval()\n",
    "        score_list = []\n",
    "        with torch.no_grad():\n",
    "            for batch_idx, (inputs, targets, metadata) in enumerate(trainloader_ordered):\n",
    "                if use_cuda:\n",
    "                    inputs, targets = inputs.cuda(device_id), targets.cuda(device_id)\n",
    "                outputs = model(inputs)\n",
    "                loss = criterion(outputs, targets)\n",
    "                score_list.append(loss.cpu().numpy())\n",
    "        score_list = np.concatenate(score_list)\n",
    "        ens_score_list.append(score_list)\n",
    "\n",
    "    score_list = np.mean(ens_score_list, axis=0)\n",
    "    score_dict = dict(zip(dataset.train_data.indices, score_list))\n",
    "    large_index = heapq.nlargest(int(len(score_list)*p), score_dict, key=score_dict.get) #* get top k proportion from score_dict\n",
    "    return large_index\n",
    "\n",
    "\n",
    "def get_errorset_index(model_paths, criterion):\n",
    "    ens_pred_list = []\n",
    "    ens_target_list = []\n",
    "    ens_metadata_list = []\n",
    "    ens_loss_list = []\n",
    "    for model_path in model_paths:\n",
    "        net.load_state_dict(torch.load(model_path))\n",
    "        model = net\n",
    "        \n",
    "        trainloader_ordered, _ = dataset.get_loader(args, shuffle_train=False) \n",
    "        model.eval()\n",
    "        pred_list = []\n",
    "        target_list = []\n",
    "        metadata_list = []\n",
    "        loss_list = []\n",
    "        with torch.no_grad():\n",
    "            for batch_idx, (inputs, targets, metadata) in enumerate(trainloader_ordered):\n",
    "                if use_cuda:\n",
    "                    inputs, targets = inputs.cuda(device_id), targets.cuda(device_id)\n",
    "                pred = F.softmax(model(inputs), dim=1)\n",
    "                target_list.append(targets.cpu().numpy())\n",
    "                pred_list.append(pred.cpu().numpy())\n",
    "                metadata_list.append(metadata.cpu().numpy())\n",
    "                loss_list.append(criterion(model(inputs), targets).detach().to('cpu').numpy())\n",
    "        pred_list = np.concatenate(pred_list)\n",
    "        target_list = np.concatenate(target_list)\n",
    "        loss_list = np.concatenate(loss_list)\n",
    "        ens_metadata_list = np.concatenate(metadata_list)\n",
    "        ens_pred_list.append(pred_list)\n",
    "        ens_target_list.append(target_list)\n",
    "        ens_loss_list.append(loss_list)\n",
    "        \n",
    "    indices = dataset.train_data.indices\n",
    "    #ens_pred_list = np.mean(ens_pred_list, axis=0)\n",
    "    ens_pred_list = np.array(ens_pred_list)\n",
    "    ens_target_list = np.mean(ens_target_list, axis=0)\n",
    "    topk = np.argsort(-entropy(ens_pred_list, axis=1))[:100]\n",
    "    error_index = np.where(np.argmax(ens_pred_list, axis=1) != ens_target_list)\n",
    "    return indices[error_index], ens_pred_list, ens_target_list, ens_metadata_list, ens_loss_list\n",
    "\n",
    "glob_tensor = None\n",
    "\n",
    "def get_uncertain_index_vae(model_path):\n",
    "    net.load_state_dict(torch.load(model_path))\n",
    "    model = net\n",
    "    global glob_tensor\n",
    "    trainloader_ordered, _ = dataset.get_loader(args, shuffle_train=False) \n",
    "    model.eval()\n",
    "    target_list = []\n",
    "    metadata_list = []\n",
    "    loss_list = []\n",
    "    with torch.no_grad():\n",
    "        for i in range(5):\n",
    "            losses = []\n",
    "            for batch_idx, (inputs, targets, metadata) in enumerate(trainloader_ordered):\n",
    "                if use_cuda:\n",
    "                    inputs, targets = inputs.cuda(device_id), targets.cuda(device_id)\n",
    "                outputs = net(inputs)\n",
    "                if i == 0:\n",
    "                    target_list.append(targets.cpu().numpy())\n",
    "                    metadata_list.append(metadata.cpu().numpy())\n",
    "                loss = net.loss_function(*outputs, M_N=kld_weight*1e-4, reduction='none')['loss'].detach()\n",
    "                losses.append(loss)\n",
    "            losses = torch.cat(losses)\n",
    "            loss_list.append(losses.detach().to('cpu').numpy())\n",
    "    target_list = np.concatenate(target_list)\n",
    "    loss_list = np.array(loss_list)\n",
    "    metadata_list = np.concatenate(metadata_list)\n",
    "\n",
    "    print(loss_list.shape)\n",
    "    indices = dataset.train_data.indices\n",
    "    topk = np.argsort(-loss_list)[:100]\n",
    "    return topk, target_list, metadata_list, loss_list\n",
    "\n",
    "def get_uncertain_index_alea(model_paths):\n",
    "    ens_mu_list = []\n",
    "    ens_sigma_list = []\n",
    "    ens_target_list = []\n",
    "    ens_metadata_list = []\n",
    "    ens_loss_list = []\n",
    "\n",
    "    for model_path in model_paths:\n",
    "        print(f\"Inf with [{model_path}]\")\n",
    "        net.load_state_dict(torch.load(model_path))\n",
    "        model = net\n",
    "        \n",
    "        trainloader_ordered, _,  _ = dataset.get_loader(args, shuffle_train=False) \n",
    "        model.eval()\n",
    "        mu_list = []\n",
    "        sigma_list = []\n",
    "        \n",
    "        target_list = []\n",
    "        metadata_list = []\n",
    "        loss_list = []\n",
    "        with torch.no_grad():\n",
    "            for batch_idx, (inputs, targets, metadata) in enumerate(trainloader_ordered):\n",
    "                if use_cuda:\n",
    "                    inputs, targets = inputs.cuda(device_id), targets.cuda(device_id)\n",
    "                mu, sigma = model(inputs)\n",
    "                log_probs = sample_softmax(mu, sigma, device_id=0)\n",
    "                mu = torch.softmax(mu, dim=-1)\n",
    "                target_list.append(targets.cpu().numpy())\n",
    "                mu_list.append(mu.cpu().numpy())\n",
    "                sigma_list.append(sigma.cpu().numpy())\n",
    "                metadata_list.append(metadata.cpu().numpy())\n",
    "                loss_list.append(nn.NLLLoss(reduction='none')(log_probs, targets).detach().to('cpu').numpy())\n",
    "        mu_list = np.concatenate(mu_list)\n",
    "        sigma_list = np.concatenate(sigma_list)\n",
    "        target_list = np.concatenate(target_list)\n",
    "        loss_list = np.concatenate(loss_list)\n",
    "        ens_metadata_list = np.concatenate(metadata_list)\n",
    "        ens_mu_list.append(mu_list)\n",
    "        ens_sigma_list.append(sigma_list)\n",
    "        ens_target_list.append(target_list)\n",
    "        ens_loss_list.append(loss_list)\n",
    "        \n",
    "    indices = dataset.train_data.indices\n",
    "    ens_mu_list = np.array(ens_mu_list)\n",
    "    ens_sigma_list = np.array(ens_sigma_list)\n",
    "    ens_target_list = np.mean(ens_target_list, axis=0)\n",
    "    return ens_mu_list, ens_sigma_list, ens_target_list, ens_metadata_list, ens_loss_list\n",
    "\n",
    "def get_scf_idxes(ents, p=0.01):\n",
    "    fit_alpha, fit_loc, fit_beta = gamma.fit(ents) # Assume the entropy follows Gamma distribution.\n",
    "    p_vals = 1 - gamma.cdf(ents, fit_alpha, loc=fit_loc, scale=fit_beta)\n",
    "    scf_idxes = np.where(p_vals < p)[0]\n",
    "    \n",
    "    return scf_idxes\n",
    "\n",
    "def count_noise(cond, noisy_idx):\n",
    "    return len(np.intersect1d(np.where(cond), noisy_idx))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "926d3b82-4058-44b8-bbba-420077a2b912",
   "metadata": {},
   "source": [
    "## Load IWsgld-alea model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "282e7bee-f0b4-47b5-b834-303874c5eafd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Inf with [../results_gamma/celebA_exp/seed_1/0.1_noise/celebA_id_model_1.pt]\n",
      "Inf with [../results_gamma/celebA_exp/seed_1/0.1_noise/celebA_id_model_2.pt]\n",
      "Inf with [../results_gamma/celebA_exp/seed_1/0.1_noise/celebA_id_model_3.pt]\n",
      "Inf with [../results_gamma/celebA_exp/seed_1/0.1_noise/celebA_id_model_4.pt]\n",
      "Inf with [../results_gamma/celebA_exp/seed_1/0.1_noise/celebA_id_model_5.pt]\n"
     ]
    }
   ],
   "source": [
    "net = resnet50_alea(pretrained=False, num_classes=dataset.target_dim).cuda(args.device_id)#* Load pre-trained model\n",
    "lr_0 = args.lr\n",
    "criterion = nn.NLLLoss()\n",
    "dirs = sorted(glob.glob('../results_gamma/celebA_exp/seed_1/0.1_noise/celebA_id_model_*.pt'), key=lambda x: int(x.rsplit('_', 1)[1].split('.')[0]))\n",
    "ens_preds, ens_sigmas, targets, metadatas, losses = get_uncertain_index_alea(dirs)\n",
    "preds = ens_preds.mean(axis=0)\n",
    "\n",
    "true_label = np.array(list(map(lambda x: x[1], metadatas)))\n",
    "noisy_idx = np.where(targets != true_label)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "21c9f9e6-c2b6-4be6-8ba3-2e2e92021a96",
   "metadata": {},
   "source": [
    "### Sort by aleatoric uncertainty"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "1d4ba1a2-11ea-4367-9bb6-1731cbcc1cc9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((array([[0, 0, 1],\n",
       "         [0, 1, 1],\n",
       "         [1, 0, 1],\n",
       "         [1, 1, 1]]),\n",
       "  array([ 72,  32, 193,   3])),\n",
       " 0.056666666666666664,\n",
       " (array([[0, 0, 1],\n",
       "         [0, 1, 1],\n",
       "         [1, 0, 1]]),\n",
       "  array([ 2,  1, 14])))"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "topk = np.argsort(-0.25*(2*np.pi*ens_sigmas.mean(axis=0).sum(axis=-1)))[:300]\n",
    "np.unique(metadatas[topk], axis=0, return_counts=True), len(np.intersect1d(topk, noisy_idx))/300, np.unique(metadatas[np.intersect1d(topk, noisy_idx)], axis=0, return_counts=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d3e7ae26-1470-405d-974f-2cb4b550ff16",
   "metadata": {},
   "source": [
    "### Sort by epistemic uncertainty"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "e6336986-f39f-4ada-adbb-029466401ec2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((array([[0, 0, 1],\n",
       "         [0, 1, 1],\n",
       "         [1, 0, 1],\n",
       "         [1, 1, 1]]),\n",
       "  array([218, 227,  26,  29])),\n",
       " 0.12666666666666668,\n",
       " (array([[0, 0, 1],\n",
       "         [0, 1, 1],\n",
       "         [1, 0, 1],\n",
       "         [1, 1, 1]]),\n",
       "  array([15, 20,  2,  1])))"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total_ent = entropy(ens_preds.mean(axis=0), axis=-1) # - 0.5 - 0.25*(2*np.pi*ens_sigmas[:5].mean(axis=0).sum(axis=-1))\n",
    "topk = np.argsort(-total_ent,axis=-1)[:500]\n",
    "errors = np.where(np.argmax(ens_preds.mean(axis=0), -1) != targets)[0]\n",
    "np.unique(metadatas[topk], axis=0, return_counts=True), len(np.intersect1d(topk, noisy_idx))/300, np.unique(metadatas[np.intersect1d(topk, noisy_idx)], axis=0, return_counts=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "72653972-83f6-4220-88ed-bcc07d5ca8a8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[6145 7825 1092  672]\n",
      "15734 [6145 7825 1092  672]\n",
      "[8256 9130 1730  865]\n",
      "19981 [8256 9130 1730  865]\n",
      "[6538 7337 1246  773]\n",
      "15894 [6538 7337 1246  773]\n",
      "[6318 7072 1201  774]\n",
      "15365 [6318 7072 1201  774]\n",
      "14999 [6797 6099 1352  751]\n",
      "18529 [7308 8641 1682  898]\n",
      "20737 [8632 9360 1780  965]\n",
      "17422 [7190 7793 1556  883]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA5UAAAIuCAYAAAAv0izRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAACXiklEQVR4nOzdd3RU1d7G8e9OCAkJAQMBQu8gVZSgFKmioIKIIqiIggLqVfS9YsUGNhTLtetVvOIVVFSs14KggAKiBrGg9Cq9SU8ISfb7x57JTCAJ6Sfl+aw1K2fPnHPym6gxz+xmrLWIiIiIiIiI5EWI1wWIiIiIiIhIyaVQKSIiIiIiInmmUCkiIiIiIiJ5plApIiIiIiIieaZQKSIiIiIiInmmUCkiIiIiIiJ5Vs7rArwSGxtrGzRo4HUZIiIiIiIinlm8ePEua221/NyjzIbKBg0akJCQ4HUZIiIiIiIinjHGbMjvPTT8VURERERERPJMoVJERERERETyTKFSRERERERE8kyhUkRERERERPJMoVJERERERETyTKFSRERERERE8kyhUkRERERERPJMoVJERERERETyTKFSRERERERE8kyhUkRERERERPJMoVJERERERETyTKFSRERERERE8kyhUkRERERERPJMoVJERERERETyTKFSRERERERE8kyhUkRERERERPJMoVJERERERETyTKFSRERERERE8kyhUkRERERERPJMoVJERERESqWUFK8rECkbFCpFREREpNRISoIPP4RLL4V69VxbRApXOa8LEBERERHJj+Rk+OormD4dPv4YDhyA2FgYNAgOHoSICK8rFCndFCpFREREpMQ5ehS++cYFyQ8/hL17ISYGBg+GIUOgZ08op790RYqE/lMTERERkRIhNRXmzXNBcsYM2L0bKlWCCy90QbJ3byhf3usqRcoehUoRERERKbbS0mDBAhck338ftm+HqCi44AIXJPv00fBWEa8pVIqIiIhIsWIt/PCDC5LvvQebN7vg2K+fC5LnnQeRkV5XKSJ+CpUiIiIi4jlr4eefXZB8913YsMENZT33XHj8cejfHypW9LpKEcmMQqWIiIiIeMJaWLrUBcnp02H1are4ztlnwwMPwIABULmy11WKyIkoVIqIiIhIkVq+PBAkly2DkBDo1QvuuAMGDoSqVb2uUERyQ6FSRERERArdmjWB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3f/YhXoy2+IjK23atMnQ/uGHH7jooov49ttv2bdvH9Y/994nKSkpV7X57dq1K/24bt266cd16tRJP965c2ee7i0CmlMpIlI0jIFHH3UrvGoPShEpwebODRyHhWVsR0ZmbFeunLEdG5uxHReXsV23bsZ2o0YZ27l14MABoqOjffeuy/Dhw7n44oupVKkSAHv27AGgffv2xMbGsmvXLmbNmsWyZcto0aJFhnulpqYW+LzKiIiIDO2PPvqIFN+0iE8//ZQ+ffpw5MiR9PcQLDe9q7GxsenHmzZtyvQ4+ByR3NLH5CIihentt+Gll9xxx47gmwMjIiKFr3///owePZq5c+dy4MABDh8+nGHuYPPmzQEICwvjrrvuAlx4vPDCC/nmm284cuQIu3fv5u2336Zbt26FXm9ycnL6cXR0NElJSYwbNy7Tc2NiYgDXC7lt27Zs79usWTPq168PwPvvv893333H3r17ue+++9LPOeecc/JbvpRhCpUiIoXFWjex6L33IGjjbRERKRpJSUm8+uqr9OzZk0qVKhEVFZW+eE9UVBT/+Mc/0s/95z//yciRIwE3B/Gss85K31Lk8ssv548//ij0es8///z04x49elCpUiU+//zzTM/t0KEDAIcOHaJmzZoYY9L32TyWMYZnnnmG0NBQDhw4kD6n8r///S8AnTp1Sl+0RyQvFCpFRArakSOwf78b8jptGnzxheZPioh44KGHHuK6666jTZs2xMbGUq5cOapVq8aFF17It99+m95TCS54vfrqq3z66af069ePatWqERYWRu3atenbty8vvvhiodfbq1cvXnrpJRo0aECFChXo1atX+uqvxxozZgzDhg3L8bDVAQMG8M0339CnTx8qV65MWFgYjRs35s4772T27NnaTkTyxRw7AbisiI+PtwkJCV6XISKljbVw9tkuUH71lfsqIlICZTavUERKpuz+ezbGLLbWxufn/lotQkSkIBkDV13lVq9QoBQREZEyQKFSRKQgzJ3reil79oRhw7yuRkRERKTIKFSKiORXWhrccgtUqADz56uHUkRERMoUhUoRkbxKS3O9k6Gh8PHHEB2tQCkiIiJljpYjFBHJi9RUuPRS+Oc/XbtuXTjpJE9LEhEREfGCeipFRPIiNBTq14caNVxvpXooRUREpIxSqBQRyY0//oCICGjcGB5/3OtqRERERDynUCkiklNHj0L//tCgAXzzjdfViIiIiBQLCpUiIjkVFgZvvQW1a3tdiYiIiEixoYV6RESyk5oKY8fCa6+5dseOblEeEREp9oYPH44xBmMMp556aobXxo8fn/7a/Pnzc33vBg0aYIyhR48eBVTtic2dOze95ilTpuTq2vXr16dfO378+AKppzDumZ29e/cyfvx4xo8fz9y5cz2tRTJST6WISHasdfMoRUSkRPvll1/4/PPPOe+887wuRfJo7969TJgwIb1dlIFesqdQKSKSmS1boGJFqFQJPvkEypf3uiIREcmniRMnFlioXL9+fYHcp6xLSkoiIiIi3/dp0KAB1toCqEjyQsNfRUSOlZgInTvDqFGurUApIlLihYaGMn/+fL799ttsz0tMTOTee++lefPmhIeHExMTQ9++fY8bIpvZ8NfFixfTr18/4uLiCA8PJy4ujp49ezJ58uQM186cOZOzzjqLypUrExERQZs2bXjhhRfyFIpSUlIYPnw4rVq1IiYmhrCwMGrWrMnll1/OunXrMr3GWsvEiROpU6cOkZGR9OvXj40bN2Y4Z/PmzYwePZq6detSvnx5atWqxciRI9m2bVuuawTXq2iMoUGDBsycOZNTTjmFsLAwvvzyS1asWMFFF11Ew4YNqVixIuHh4TRp0oTbb7+dQ4cOATBlyhQaNmyYfr8JEyakD3edO3dulsNfU1NTefLJJ2nbti0VKlQgOjqabt268cknn+TpfUgWrLU5egD1gKnATiAJ+BW4JofXVgFeBLYAR4DlwG1AaDbXTAWs77E6m/NaAMlB516Rk5rat29vRUSyNHWqtb/+6nUVIiKe+fPPP70uId+uuuoq/9+H9tJLL7WA7dOnj7XW2vvvvz/9te+++85aa21ycrI988wzbdDflemP0NBQ++mnn6bfu379+haw3bt3t9Zae/DgQVu1atVMrz3//PPTr5s8eXKm5wD2hhtuyPb9zJkzJ/3c119/3VprbWJiYpb3q1+/vk1MTLTWWrtu3br05+Pi4o47t0WLFjYlJcVaa+2mTZtszZo1s7znzp07j7vn/fffn23t3bt3t4CNjIy04eHh6dd9+OGH9osvvsjyPQwePNhaa+3rr7+e5Tlz5szJspbBgwdned2LL76Ybc2lSXb/PQMJNoeZMKtHjnoqjTFxwEJgKBALhANtgcnGmLtPcG0kMBe4HqgJlAeaA5OAl7O4pqvve+XEc0BYDs8VEcmctfDss+D/JHroUGjb1tuaRESkwIwdO5bw8HBmzpzJzz//nOk506ZNS++RHDp0KHv27GHevHlUrFiR1NRUxowZk2Vv4vLly9m9ezcAM2bMIDk5mU2bNvHxxx/Tv39/AA4ePMgtt9wCwEUXXcTWrVs5ePAgY8eOBeDFF19k2bJluXpfYWFhvPPOO2zYsIGkpCQOHTqU3jO6YcMGPv/88+OuOXDgAHPmzGHPnj0MHer+5F62bBlvvfUWAPfddx9bt24lNjaWRYsWceTIEb777jvCw8PZsGEDTzzxRK5qDHb48GHOO+88tm7dyrZt2+jcuTMnn3wyM2fOZNu2bSQnJ7N7925G+UYLvffee+zevZvhw4dn6Hm9//770wNNVnMr586dy7vvvgtAr1692LZtG7/++iu1atUC4I477uDAgQN5fi8SkNM5lRMA/xr6w4DZwEfAGcD9xpg3rbUbs7j2ZqCN7/guYDLwCjAQGGmMec1au8h/sjEmFHgBSMP1QGY5yNoYMxg4CzgMRObwvYiIHO/wYXj+eejWDc480+tqRESKpf/7P/jlF2++d7t28PTTeb8+Li6OESNG8PLLL/PII4/QunXr486ZOXNm+vHDDz9MTEwM3bp1Y9CgQUyZMoX169ezatUqmjVrdty1tWvXJjQ0lNTUVF544QVWr15Nq1at6NKlC1WrVgVg4cKF7N+/H4APPviADz74IMM9rLXMnTuXFi1a5Ph9hYaGcvjwYQYNGsSyZcs4ePBghtdXrlx53DUDBw5MD2IPPPAA06ZNA2DBggUMGzaML774AoBdu3bRsWPH466fM2dOjus7ljGGl19+merVq6c/d+TIEV555RVuuukm1q9fz5EjR9Jfs9ayatWq9J9hbgT/87zvvvuoUaMGNWrUYPTo0YwfP54DBw7w/fffc8455+T5/Yhzwp5KY0wIMMTXXGatnWqt3QY85XsuDBiUzS0u9309ADxurd0FPJrJ63434ELoZGB7NnVFAU/ghuI+eaL3ISKSqYMHIS0NoqLgu+/glVe8rkhERArJ7bffTrly5fjwww9Zvnz5ca/v2rUr/bhOnTqZHu/cuTPTe8fFxfHss89SuXJlvvnmG+644470+ZX+FUuzujbYnj17cvx+wPWKXn311fz000/HBUpwC+Ecq27Q1li1g/Ze3rx5c47qzG2NwapXr54hUALcdtttTJw4kRUrVmQIlH6ZvYecCP7nGfyec/LPU3InJz2VjYHKvuPgjzqCjzNu/ONjjIkAWvqaa621qdlda4ypDjwA7AbGAX2yqeseoC6uF3V9tu9ARCQz+/dDly5w/vnw6KNQo4bXFYmIFGv56SksDho2bMill17K1KlTef/99497PTY2Nv148+bN1KtXD4BNmzZles6x/vGPfzBq1Ch++eUXVq1axdSpU/niiy+YMGEC11xzTYZrn376aW6++eYM11trMcbk6j3530dERATz5s2jffv2LFu2jDZt2mR5TfD78QdJCATM2NhYtm3bRrt27ViyZMlx12c1BDgnMlvp9b333gOgdevWfP7559StW5fnn3+eMWPGZDgvtz+b4J/3pk2baNSoUfpxZudI3uVkTmXwT3p/FscZP24IiAn6Hjm5dhIuwI6z1u7OqiBjTDPgFmAdGXs9RURyLjoazjsPevf2uhIRESkid911F8YYUlNTj3steBjkPffcw969e5k/fz4zZswA3IqvmQ19Bdi+fTt33nknP//8M40aNeLiiy/mTN90Cmstu3btonPnzkRHRwPw+OOPs2DBAo4cOcKWLVt44403OO2003L9fpKTkwEXuKKjo9m7d2+G1U8z88EHH/Dtt9+yd+9e7rvvvvTnu3TpAkDfvn0Bt7fnpEmT2LdvHwcPHmTu3LlceeWV6cNlC4r/PYSFhREVFcWKFSt44YUXjjsvJiYm/Xj58uUcPXo02/sG//N88MEH2bFjB0uXLk2fc1qxYkU6d+5cEG+hzMvPliLBHxXk9uOK4641xnQCrgQScENfs/MsbsGfm621Oe4PN8aMNsYkGGMS1NUtUoZ99BFs3AjGwGOPKVSKiJQhLVu2ZMCAAZm+dsUVV9CpUycA3nzzTWJiYujatSsHDhwgNDSUp59+OsvessTERB577DE6duxIbGwsERER3H23W8+ybt26tGzZkujoaB5//HHA9RCeeeaZREREULt2bYYPH84veZiwev7556d//5YtWxIbG3vC+0RHR9O9e3diYmLSA2KLFi24/HI3K23ChAnU8I3eueOOOzjppJOIjo6mZ8+evPnmm6SkpOS6zpy8hyVLllC1alVOPvnkTANjpUqV0kP99OnTKV++PMaYLOvp2bMnF198MQCzZ8+mRo0atGnTJr2ncuLEiekhX/InJ6FyV9BxpaDj4H8CWSW0PbgFd3Jy7d24sPkK0NYY0w4XHAHKG2PaGWOqGGPiccNifwb+8p1XL+h+9YwxLcmEtfYVa228tTa+WrVqWZQsIqXa33/DiBHwwANeVyIiIh4ZN25cps+HhYUxe/Zsxo0bR5MmTQgLC6Ny5cqcc845fPPNN1mGUYCqVaty0003ceqpp6bvF1m7dm0uv/xyZs+eTXnfnsfXXnstX3zxRfo+leHh4TRs2JCLLrooTz2AI0aMYPz48dSqVYuoqCguuugi3n777WyvGT16NA8//DC1atUiIiKC8847jy+//JLQ0FAA6tWrR0JCAqNGjaJu3bqEhYVRvXp1OnXqxMMPP5zek1lQnnnmGS6//HJOOukkYmNjuf3227nrrrsyPfeNN96gQ4cOVKhQIUf3fuedd5g0aRKtWrUiPDycqKgounTpwgcffMCNN95YkG+jTDMnGhPtW6hnD25Y6jJrbUvf84OB6b7Txlprn8ri+t+B1riFemKstanGmNOBH3ynPGetvckYMxfofoJ6R+DmT55oyakN1toG2Z0QHx9vExISTnAbESk10tIgxPc52pIl0KIFZDKvQ0REnGXLluVqFVIRKb6y++/ZGLPYWhufn/ufsKfSWptGIDy2MMYM9e1beYvvuaPAe76CrO8xJegWb/m+RgO3GWNigTszeV1EpHDs2wdnnw3+T4BPPVWBUkRERKSA5HRO5f2Af2moqcBW3B6VABOstX9lc+3TwO++44m44a4Dfe3J/j0qrbU9rLUm+AFs8J23xvfcFGvt3EzOGxH0/YadqJdSRMqYChWgXDnIx2p1IiIiIpK5HIVK376UnXG9iruBI8BvwEhr7cMnuDYR6Am8BGwDknFbitwOXJfnykVETuSnn+DQIShfHr78Eq64wuuKREREREqdnOxTCYC1diMw9ATnZLoclm97kH/4HjmW0x5Ha+0UYEpu7i0ipdy2bdC9O4waBc8841Z6FREREZECl+NQKSJSosTFwX//C716eV2JiIiISKmWn30qRUSKl6QkGDnSDXsFGDQIqlTxtiYRERGRUk6hUkRKjwMHYM4cWLTI60pEREREygwNfxWRkm/TJqhdG6pVg99+g6gorysSERERKTPUUykiJdv69dCmDUya5NoKlCIiIiJFSqFSREq2+vXhn/+EIUO8rkRERESkTFKoFJGSJy0NHnkEtmxxW4Xcdx80aOB1VSIiUgwtXLiQvn37UqtWLSIiIqhVqxZdunThpptuIjU19bjzP/vsMy644ALi4uIIDw+nTp06nHvuubz99tvp5/To0QNjTKaPBkX0/6MpU6Ywfvx4nn766eNe89dXkLUcPXqUZ555hlNOOYXo6GgqVapE48aNueCCCzL8bPwOHz7Mv/71L7p06UJMTAzh4eHUq1eP7t278/jjj7Nr167j6jXGsH79+ky//9y5czP8nMPCwqhatSqnnXYat956Kxs3biyw9yq5pzmVIlLyrFvnQmW5cnD77V5XIyIixdSsWbPo27cvaWlp6c9t3bqVrVu3snDhQiZNmkRoaCgA1lpGjx7N5MmTM9xj8+bNbN68me+//57LLrusSOvPzpQpU5g3bx7169fn//7v/wr9+11zzTW8+eabGZ47cOAAa9euJTIyMsPPZuPGjfTt25dly5ZlOP+vv/7ir7/+4ttvv6Vp06ZceOGFea4nJSWFPXv2sGfPHpYsWcKrr77KjBkz6N27d57vKXmnnkoRKTmSktzXxo3h11/httu8rUdERIq1J598krS0NBo0aMDvv/9OUlIS69at491336V///4YY9LPfeqpp9IDZZMmTZg1axaJiYns3LmTt956i9atW2f6PdatW4e1Nv2RVU/biSQmJubpuszMnTs3X7Uca+vWremBctSoUezcuZODBw/y66+/8uijj9K8efP0c9PS0rjooovSA+WgQYP4/fffSU5OZteuXXz++ecMHTqUcuXy3rd11VVXkZaWxubNm5k4cSLlypVj//79XHzxxeqx9IhCpYiUDGvXQosWMGOGazdu7Ia+ioiIZGHdunUANGvWjNatWxMeHk6DBg245JJL+OSTTwgPDwfc0M6JEycCEBISwscff0zv3r2JiIggNjaWyy67jHnz5hVITVOmTEkfwvnuu+8yePBgoqOj03v6xo4dS7t27ahatSphYWFUq1aNAQMG8Msvv6TfwxiTXs+GDRvS7zd8+HAg6+GvCxYs4LzzzksfjtqsWTPuueeeEwba4HDas2dPYmNjiYqKom3bttxxxx1MmDAh/fVPPvmExYsXA9ChQwfeffddWrdunT5c9dxzz2Xq1Kn069cvjz/BwM+gVq1a3Hnnndxxxx0A7N+/n6eeeipf95W8UagUkZKhVi1o3x4aNvS6EhERKSFq1aoFwFdffUWHDh249957+eqrr44LUQkJCezevRuAs88+m5YtWx53L/8w2YJ03XXX8d5773Hw4MH056ZNm8avv/7Knj17SElJYdeuXXzyySf06NGDrVu35vl7ffrpp3Tv3p0vvviCvXv3kpyczKpVq3j44Yc555xzOHr0aJbX+n+OAFdffTWDBg3i+eefZ+nSpcedO3PmzPTjW265JUNvcGG56aab0o+//PLLQv9+cjyFShEp3t57zw17jYiA99+H007zuiIRESkhrr/++vTjhIQEHnroIfr06UNcXFx6zySQYcjkySefnKvv0bBhwwwLyORmfmN4eDjz58/n4MGDTPJtjfX888+zevVqDh06RGJiYnpI27dvX/qCONZaunfvDkD9+vXTh95OmTIl0+9jrU1fmKhixYrMmzePPXv2cMUVVwAwf/58pk2blmWd9evX59xzzwUgKSmJGTNmMGbMGNq0aUPbtm1ZtGhR+rkbNmxIPw4eFtu3b98MP6eCnPtYvXp1KleuDKDhrx5RqBSR4uvXX2HwYHjxRa8rERERvx49wB9ejh517alTXfvwYdeePt219+1z7Q8+cO1du1z7009de9s21/b3Lv31l2vPnu3aa9e6dh6Hng4ePJgPPviA9u3bZ3h+//79jBs3jum+OouiNy0zt9xyC126dCEqKopmzZoBLmheffXV1KpVi8jISPr06ZN+/sqVK/P0fVauXJk+hHXQoEF069aNmJgYHnroofRzvvrqq2zvMWPGDG677TaqV6+e4fnff/+dCy+8kP379x93TVH+XK21Rfa95HgKlSJS/Pj/x3DKKTBrFtx8s7f1iIhIiTVw4EASEhLYuHEjr7/+Oh07dkx/7eOPPwagXr166c+tWLEiV/c/dqGezLb4yEqbNm0ytH/44Qcuuugivv32W/bt23dcUEryL1iXS8Hbd9StWzf9uE6dOunHO3fuzPYeFSpUYNKkSWzZsoUff/yR8ePHU6VKFQC2b9+e3lsZ/LMMDsFffvlloQW/HTt2pIfa+vXrF8r3kOxpSxER8d7Ro+4RGQmHDkHfvvD88y5UamlwEZHiZe7cwHFYWMZ2ZGTGduXKGduxsRnbcXEZ23XrZmw3apSxnUsHDhwgOjrad+u6DB8+nIsvvphKlSoBsGfPHgDat29PbGwsu3btYtasWSxbtowWLVpkuFdqamqBz6uMiIjI0P7oo49ISUkB3BzIPn36cOTIkfT3ECw3vYCxsbHpx5s2bcr0OPicYx05coSQkBDCwsIIDQ2lQ4cOdOjQgSpVqqTPZ/T/LPv06cO///1vAJ577jkGDx6c4zrz6plnnkk/7tu3b6F/PzmeeipFpPB98w0sWRJojxgB//mPO05Lc3+E+Oe2hIfD0qWwY0fR1ykiIqVK//79GT16NHPnzuXAgQMcPnw4w9xB/5y/sLAw7rrrLsCFxwsvvJBvvvmGI0eOsHv3bt5++226detW6PUmJyenH0dHR5OUlMS4ceMyPTcmJgZwvZDbtm3L9r7NmjVL78F7//33+e6779i7dy/33Xdf+jnnnHNOltevW7eO5s2b88QTT7B8+XKSk5PZsmULX3zxRfo5/p/lgAEDaNeuHeDmao4YMYLVq1dz9OhRVq1alW2dAPPmzePLL7/M8MiMtZatW7fy2GOPpc9HrVy5MrfccssJv4cUguDu+rL0aN++vRWRPFq92to//wy0H3/c2n//O9Du0MHaESMC7Tp1rB0+PNDu1Mnahx7KeP3cuYH23r0FX7OIiOTKn8G/50uoM844wwKZPqKiouzy5cvTz01LS7MjR47M8vzKlSunn9u9e/f059etW5erml5//fX0a+fMmZPhta+//vq479u4ceP046uuuir93EceeeS4c1999dUM9dWvXz/9/I8++siGhoZm+t46depkk5OTs6x52bJlWf5cAHvWWWdlOH/t2rW2SZMmOb4m+OeZ2cNaa+fMmZPtOZUrV7azZ8/O1T+LsiS7/56BBJvPbKWeShFxQ043bw60P/oIXnst0L72WvDtnwXAlVfCjTcG2v/7H8yZE2gPGAC+VekA+OQTePDBQHvhQrj77kD71lsznu9bwU1ERCQ/HnroIa677jratGlDbGws5cqVo1q1alx44YV8++23GVYnNcbw6quv8umnn9KvXz+qVatGWFgYtWvXpm/fvrxYBIvG9erVi5deeokGDRpQoUIFevXqlWGLjmBjxoxh2LBh2Q5bDTZgwAC++eYb+vTpQ+XKlQkLC6Nx48bceeedzJ49m7CwsCyvrVevHs8//zwXXHABjRo1IioqivLly9O0aVNuv/12PvroowznN2zYkJ9//plHHnmE9u3bU7FiRcqVK0f1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Z926dZleY61l4sSJ1KlTh8jISPr168fGjRsznLN582ZGjx5N3bp1KV++PLVq1WLkyJFs27Yt1zUC9OjRA2MMDRo0YObMmZxyyimEhYXx5ZdfsmLFCi666CIaNmxIxYoVCQ8Pp0mTJtx+++0cOnQIgClTptCwYcP0+02YMCF9WOjcuXOzHP6amprKk08+Sdu2balQoQLR0dF069aNTz755IQ1+39+FStWpFevXkRERFCjRg3OOussXn31Vc4888z0cx988EGO+qaEPfHEE4wZM4bq1asTFhZGo0aNGD16NHP8f5PnQ/ny5TnttNP4+OOP038eH330EUuWLMn3vfPFn+jL2qN9+/a2WEhKsnb/fneclmbtK69YO3++ax85Ym2XLu45a63dt89asHbSJNf++29rjbH2+edde+9ea6+80tpvv3Xtw4et/fpra3fuLLK3IyIiIqXDn3/+6XUJ+XbVVVdZwAL20ksvtYDt06ePtdba+++/P/217777zlprbXJysj3zzDPTnw9+hIaG2k8//TT93vXr17eA7d69u7XW2oMHD9qqVatmeu3555+fft3kyZMzPQewN9xwQ7bvZ86cOennvv7669ZaaxMTE7O8X/369W1iYqK11tp169alPx8XF3fcuS1atLApKSnWWms3bdpka9asmeU9d/r+tgy+5/33359t7d27d7eAjYyMtOHh4enXffjhh/aLL77I8j0MHjzYWmvt66+/nuU5c+bMybKWwYMHZ3ndiy++mG3N48ePz/C+b7zxRvvuu++mv3+/lJQUGxUVZQFbsWJFe/To0Wzve+zPzv/vUGaC/x2eM2dOhtcee+yx9NcmTpyY7ffL7r9nIMHmM1upp7KoXXutW8DGLy7OzUsENzx07Fh47z3XLl8eKlUKrFoaHQ1vvAH9+7t25cpukZwbbgi033jD9TiC60Xs1SvjthoiIiIiZdDYsWMJDw9n5syZ/Pzzz5meM23atPQeyaFDh7Jnzx7mzZtHxYoVSU1NZcyYMVn2Ji5fvpzdu3cDMGPG/7d351FSVmcex7/PNEWTIJu0zRZkkaAGSTBIlGUSTRjNMEc2GReULRww4RhkklGWOAgaSAZnTlzAEBNQAgLBA4hJBI8MooHIREQyOGlZ4tCRpYOAjY3ddgN55o/3raK6qOqlmu5q6N/nnDrvW/e97/veqvZ66+G+997V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\n",
      "text/plain": [
       "<Figure size 936x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA5UAAAIuCAYAAAAv0izRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAACFkElEQVR4nOzdd5hURdaA8bfIoEQRXVTAHBBRghEFUZIJUHQxh09ZwxpWXbOYWFxd4xrWtGtWVkwYkYxiRgUDKgZQ1wiCgIKATH1/VDMMOMAAM3MnvL/nuc/cvl339mlmmu7TVXUqxBiRJEmSJGl1VMk6AEmSJElS+WVSKUmSJElabSaVkiRJkqTVZlIpSZIkSVptJpWSJEmSpNVmUilJkiRJWm3Vsg6gvGjcuHFs0aJF1mFIkiRJUrF56623pscY112Ta5hUFlGLFi0YP3581mFIkiRJUrEJIXyxptdw+KskSZIkabWZVEqSJEmSVptJpSRJkiRptZlUSpIkSZJWm0mlJEmSJGm1mVRKkiRJklabS4pIkiSpULNnz+aHH35g4cKFWYciaTVUr16dJk2aUK9evRJ9HJNKSZIk/c7s2bP5/vvv2WCDDahduzYhhKxDkrQKYozMmzePr7/+GqBEE0uHv0qSJOl3fvjhBzbYYAPq1KljQimVQyEE6tSpwwYbbMAPP/xQoo9lUilJkqTfWbhwIbVr1846DElrqHbt2iU+hN2kUpIkSYWyh1Iq/0rjdWxSKUmSJElabSaVkiRJqrBeeeUVunfvTtOmTalVqxZNmzZlt91247TTTmPRokW/a//ss89ywAEHsP7661OzZk023HBDevTowcMPP5zfplOnToQQCt1atGhRis9u9SyO9Zhjjsk6lFV2zz33cOmll3LDDTf87r7Fv5fy8DuoaKz+KkmSpApp+PDhdO/enby8vPxj3377Ld9++y2vvPIKV199NVWrVgVSpcx+/fpx1113LXWNr7/+mq+//ppXX32VQw89tFTj1+/dc889jB07lubNm3PGGWdkHY5y7KmUJElShXTttdeSl5dHixYteO+99/j111+ZMmUKjzzyCPvvv/9Sc82uu+66/IRys802Y/jw4cybN49p06bx0EMPse222xb6GFOmTCHGmL9NnTq1NJ7aGlkc6z333JN1KMybN6/YrjVmzJhy8zuoaEwqJUmSVCFNmTIFgC222IJtt92WmjVr0qJFCw4++GCeeuopatasCaRKt1deeSUAVapUYciQIey9997UqlWLxo0bc+ihhzJ27NhMnkOLFi0IIdCpUyceffRRWrZsSZ06ddhpp5146623lmr7448/cvrpp9OiRQtq1KjBuuuuS58+fXj//feXalfY8NcRI0aw5557su6661KzZk022GADunfvzpNPPrnUuQ899BC77LILa6+9NrVr12bHHXfkv//970qfxz333JP/uI888giHHHIIdevWze/9Peuss9h+++1ZZ511qF69Ouuuuy49e/ZkwoQJS8W9+PfwxRdf/O55LG/468svv8w+++xDw4YNqVmzJltssQUXXXRRsSa0lZ3DXyVJklQhNW3alMmTJzNs2DDat29P9+7d2X333dl9992XWi5l/Pjx/PjjjwB06dKFbbbZ5nfXWjxMNivvvPMOhxxyCDFGAN544w169+7NZ599RvXq1Zk1axa77rorkydPzj9n+vTpPPbYYzz//PO8+OKLtG3bttBrf/HFF+y///78+uuv+ce++eYbvvnmGzbbbDN69eoFQP/+/bniiiuWOvfNN9+kb9++fPXVV5x99tlFei4nnngiM2fOXOrYgw8+yPfff79U7E899RRjx47lww8/5A9/+EORrr2sp59+mt69ey81f/aTTz7hb3/7G2PHjmXUqFFUr159ta6tJeyplCRJUpGccQZ06pTNtjrT50466aT8/fHjxzNgwAC6devG+uuvn98zCfDll1/m72+11Var9Bgbb7zxUoV6Smqe3+zZsxkwYAAzZ87M75n76quveP311wG4/vrr8xPKc889l1mzZvH4449TpUoV5s6dy1lnnbXca48fPz4/oXzzzTeZP38+X3zxBQ899BAdOnQAUq/vwIEDATjllFOYMWMGM2fOzO9p7N+//+8SxeWpWbMm48aN4+eff+bqq68G4Oabb+bTTz/ll19+Yd68ebzwwgsAzJo1K79IUoyRjh07AtC8efOVDuONMeYXZFp77bUZO3YsM2bM4IgjjgBg3LhxPPjgg0WKWStmUilJkqQK6ZBDDuHxxx//XQ/d7NmzueCCC/KHbZaH9TjXX399zjvvPBo0aMAhhxySf/yrr74CyE/CatWqxWWXXUa9evXo3bs3e+yxB5ASqOUN92zevHn+/sCBA7nlllv46KOP2G+//ejbty+Qih4t7u275ZZbaNSoEQ0bNsxP+ObNm8drr71WpOdy5plnsttuu7HWWmuxxRZbACnRPO6442jatCl16tShW7du+e0L9r6uismTJ+fPr+zTpw977LEHDRs2ZMCAAflthg0btlrX1tIc/lrGzZ0LdepkHYUkSRIUsopDmde7d2969+7NV199xciRI7n99tvzk58hQ4bwxz/+kWbNmuW3//jjj1fp+lOmTFmlJSxatGjBF198kX+7Y8eOjBkzZqXnbbrpplSpkvqDatWqlX98/vz5QBouCuTPiVxsww03BGDRokXMmDGDDTbY4HfXbteuHRdeeCHXXXcdTzzxBE888QQAtWvX5p///CfHH38806ZNW2mMM2bMWGkbgFatWi11+/XXX+fAAw/kt99+K7R9wWG5q2LxvwnARhttlL+/+N8EKNLz0srZU1mG/ec/0LIlfPpp1pFIkiSVP3PmzMnf32ijjTjmmGOW6planAS1bduWxo0bA6lH7sMPP/zdtQpb07I0Vau2pC+osJ7VxfFPmzYtP9EE+N///gekOaENGzZc7vUHDBjA9OnTefnll7nnnnvYeeedmTdvHqeddhq//fZb/vUBnnzyyaUq3sYYycvL4/DDDy/ScymYFC++3uKE8umnn2bBggVL/e4KWpVe5YIxL/53WHa/YButPpPKMqx1a5gzB3bfHZYp2iVJkqSV2H///enXrx9jxoxhzpw5zJ07d6k5dFtuuSUA1atX5/zzzwdS8tirVy9GjRrF/Pnz+fHHH3n44Yfzh5GuqalTpy6VjBWll7IounbtCqRevcsuu4zZs2czZMgQXnzxRQB222036ixn+Nt7773HFVdcweTJk2nZsiV9+vRhhx12ANKw1jlz5tClS5f8ntKLLrqId999lwULFjB16lRuueUWunTpstqxL1iwIH+/bt26/Prrr1xwwQWFtl2cGE+fPp3vvvtuhdfdYost8of2Pvroo7z00kv89NNP9O/fP7/N4n83raFlv2VwK3xr27ZtzMIHH8TYtGmMjRrF+PrrmYQgSZIqoUmTJmUdwhrbaaedIlDottZaa8WPPvoov21eXl48/vjjl9u+fv36+W07duyYf3zKlCkl+hyaN28egdixY8f8Y6NHj85//LvvvjvGGOPMmTPjZpttVmjstWvXjm+88Ub++YuPH3300b+73rLbTjvtlH/e+eefv9x2zZs3X+HzuPvuu/Pbjh49eqn7Ro4c+bvrbbrppr+LM8YYBw4c+Lu2d955Z4xxye+lYCxPPvlkrFq1aqEx77LLLnHBggVF/l2UZyt6PQPj4xrmSvZUlnHbbAPjxkGDBrDXXlBMX2ZJkiRVeAMGDODEE0+kVatWNG7cmGrVqrHuuuvSq1cvXnzxxfyeSkjDKu+8806efvpp9ttvP9Zdd12qV6+ev17jrbfemuEzWbkGDRrw6quvcsopp9CsWTOqVavGOuusQ+/evXnttddo3779cs/dbLPN6NevHy1btqR+/fr563n269dvqXUqBw4cyAMPPMCuu+6av07lZpttxhFHHLFG/z6dO3fmX//6Fy1atKB27dp07tw5v/DQsk499VSOPPLIIg9b7dmzJ6NGjaJbt27Ur1+f6tWrs+mmm3LeeecxYsQIlxMpJiHm1rrRirVr1y6OHz8+s8f/5hvo2jXNr3z0Udhvv8xCkSRJlcCHH37I1ltvnXUYkorBil7PIYS3Yozt1uT69lSWE02bwtix0KoV9O4NuerNkiRJkpQpk8pyZJ11YORI2G03OPxwuOOOrCOSJEmSVNmZVJYz9erB88/DPvvAn/4E//hH1hFJkiRJqsxMKsuh2rXh8cfhj3+Ec86Biy4Cp8ZKkiRJykK1lTdRWVSjBjz4YOq5/NvfYPZsuOEGqOLXBJIkSZJKkUllOVa1Ktx+O9SvD9dcA7Nmwb//DdX8rUqSJEkqJaYf5VwIcPXVKbG8+GKYMydVhq1ZM+vIJEmSJFUGDpasAEJI8ypvvBGeeAL23x9++SXrqCRJkiRVBiaVFchpp8Hdd6dlR7p2hZ9+yjoiSZIkSRWdSWUFc8wxMHgwvPkm7Lkn/PBD1hFJkiRl55VXXqF79+40bdqUWrVq0bRpU3bbbTdOO+00Fi1a9Lv2zz77LAcccADrr78+NWvWZMMNN6RHjx48/PDD+W06depECKHQrUWLFqX47FbP4liPOeaYrENZZffccw+XXnopN9xww+/uW/x7Kc7fwcKFC7nxxhtp3bo1devWpV69emy66aYccMABS/1NLDZ37lyuv/56dtttNxo2bEjNmjVp1qwZHTt25B//+AfTp0//XbwhBKZOnVro448ZM2apv6/q1auzzjrr0KZNG84++2y+/PLLYnuua8I5lRXQgQfCM89Ar16w++4wYgRstFHWUUmSJJWu4cOH0717d/Ly8vKPffvtt3z77be88sorXH311VStWhWAGCP9+vXjrrvuWuoaX3/9NV9//TWvvvoqhx56aKnGr9+75557GDt2LM2bN+eMM84o8cf7v//7P+6///6ljs2ZM4fPP/+cOnXqLPU38eWXX9K9e3c+/PDDpdp/9dVXfPXVV7z44otsvvnm9OrVa7Xj+e2335gxYwYzZszgnXfe4c477+Sxxx5j7733Xu1rFgd7Kiuorl1h+HD47jvo0AE++STriCRJkkrXtddeS15eHi1atOC9997j119/ZcqUKTzyyCPsv//+hBDy21533XX5CeVmm23G8OHDmTdvHtOmTeOhhx5i2223LfQxpkyZQowxf1tej1NZsjjWe+65J+tQmDdvXrFda8yYMcX6O/j222/zE8oTTjiBadOm8fPPPzNx4kT+/ve/s+WWW+a3zcvL48ADD8xPKPv06cN7773HggULmD59Os899xyHH3441dZgmYajjz6avLw8vv76a6688kqqVavG7NmzOeigg7LvsSz4InBb/ta2bdtYHr39doyNG8e43noxTpyYdTSSJKm8mDRpUtYhrLEtttgiArFr164rbLdgwYK4zjrrRCBWqVIlfvDBB79r89tvv+Xvd+zYMQIRiFOmTCnusJfSvHnzCMSOHTvGwYMHx2222SbWrl077rjjjnH8+PFLtZ0+fXo87bTTYvPmzWP16tVj48aN40EHHRTfe++9pdotjv3oo4/OPzZ8+PDYqVOn2Lhx41ijRo3YtGnT2K1bt/jEE08sde6DDz4Yd95557jWWmvFWrVqxfbt28dBgwat9Hncfffd+Y/73//+Nx588MFx7bXXjj179owxxnjmmWfG1q1bx0aNGsVq1arFxo0bxwMOOCC+8847v4t72W3x81j8e2nevPlSjz1u3LjYo0eP2KBBg1ijRo24+eabxwsvvDDOnTt3hTG/8sor+Y/x0EMPrbDtE088kd+2ffv2MS8vb6X/JkX5Oxo9enShv68YY7zwwgvz7zv99NNX+Fgrej0D4+Ma5kqZJ2vlZSuvSWWMMX74YYwbbBBjgwYxvvpq1tFIkqTyoCIklZ06dcr/0N2uXbt40UUXxRdeeOF3yUTB5KFbt24rvW4WSWW9evViCGGpZGqjjTaKCxYsiDHG+NNPP+Un0ctuderUWSoBXTZJmTp1aqxVq1ah555yyin551188cXLTez+8Y9/rPB5FEwqGzZsmL+/OKlcb731Cr1u/fr14zfffLNU3KuSVD711FOxatWqhZ7XoUOH/H+/wkydOjW/ba1ateJBBx0Ub7rppt8l6THGeOKJJ+a3ffjhh1f4b7HYmiaV33//ff59W2655Qofq6STSoe/VgJbbQXjxkHjxrD33jBqVNYRSZIklbyTTjopf3/8+PEMGDCAbt26sf7663PllVfm31dw6OBWW221So+x8cYbL1VIpaTm+c2ePZsBAwYwc+bM/AI7X331Fa+//joA119/PZMnTwbg3HPPZdasWTz++ONUqVKFuXPnctZZZy332uPHj+fXX38F4M0332T+/Pl88cUXPPTQQ3To0AFIw3wHDhwIwCmnnMKMGTOYOXNm/pzC/v37M3PmzCI9l5o1azJu3Dh+/vlnrr76agBuvvlmPv30U3755RfmzZvHCy+8AMCsWbPyC+LEGOnYsSMAzZs3z09oljeMN8aYX5Bp7bXXZuzYscyYMYMjjjgCgHHjxvHggw8uN87mzZvTo0cPAH799Vcee+wxTj31VFq1asV2223Ha6+9lt/2iy++yN8vOCy2e/fuS/19FOfcxyZNmlC/fn2AzIe/WqinkmjRAl56Cbp0gX32gUcegQMOyDoqSZJUrpxxBkyYkM1jb789FFLxc0UOOeQQqlevzt/+9jfeeuut/OOzZ8/mggsuYJNNNuGPf/zjUnMry6r111+f8847jypVqnDIIYfkJ1JfffUVQH4SVqtWLS677DJq1qxJ79692WOPPRgzZgzjxo1j3rx51K5d+3fXbt68ef7+wIED2X333WnZsiX77bcfdevWBVLRo8XVcm+55RZuueWWpa4xb948XnvttfwkbEXOPPNMdtttNwC22GILICWaxx13HBMnTmT27NlpSGXO4mR5VU2ePDl/fmWfPn3YY489ABgwYAAPPPAAAMOGDVthFdzHHnuMSy65hHvvvZcfCiyr8N5779GrVy8mT55MvXr1ljqnNP+eCv47Zcmeykpk/fVh7Fho3TpViF3BFzOSJEkVQu/evRk/fjxffvkld999NzvvvHP+fUOGDAGgWbNm+cc+/vjjVbr+soV6ClvqoqAWLVos1XPVqVOnIj3OpptuSpUq6aN7rVq18o/Pnz8fIH+pinXXXZeaNWvm37/hhhsCsGjRImbMmFHotdu1a8eFF15I7dq1eeKJJzjzzDPp1q0b6623Xn7xomnTpq00xuVdf1mtWrVa6vbrr7/OgQceyIsvvsisWbN+lygt7kVdVQWX79iowFIIi/9NYOXPq3bt2lx99dV88803vPHGG1x66aU0atQIgO+//z6/t7Lg31DBJHjo0KEllvj98MMPzJ49G1j6i4Es2FNZyTRqlJYY6dkTjjwSZs+GAiNDJEmSlm8VewqzNmfOnPyeto022ohjjjmGgw46KL9naXES1LZtWxo3bsz06dMZPnw4H374IVtvvfVS11q0aFH+8iNZKFg1tLCesMaNG/Ppp58ybdo05s+fn59Y/u9//wOgatWqNGzYcLnXHzBgABdccAETJkzgk08+4bbbbuO1117jtNNO45hjjqFx48b5bZ988kl69uy51PkxxiL30BVMihdf77fffgPg6aefplu3bsyfPz//d1fQqvQCFox58b/DsvsF2yxr/vz5VKlSherVq1O1alXat29P+/btadSoEaeddhqw5G+oW7du3H777QDcdNNNHHLIIUWOc3XdeOON+fvdu3cv8cdbkRLrqQwh9AwhvBpCmBtCmBlCGBJCaLkK53cIIYwKIczJbaNCCB0KaVcnhDAwhDA1hDA/93NgCOH3fftLzhkQQoi57bfVfY7lVd268NxzsN9+cPLJ8Pe/Zx2RJElS8dt///3p168fY8aMYc6cOcydO3epOXSL575Vr16d888/H0jJY69evRg1ahTz58/nxx9/5OGHH84fOrmmpk6dulTP5pgxY4rlul27dgVSr95ll13G7NmzGTJkCC+++CIAu+22G3Xq1Cn03Pfee48rrriCyZMn07JlS/r06cMOO+wApGGtc+bMoUuXLvk9pRdddBHvvvsuCxYsYOrUqdxyyy106dJltWNfsGBB/n7dunX59ddfueCCCwptuzgxnj59Ot99990Kr7vFFlvk9+A9+uijvPTSS/z000/0798/v83if7fCTJkyhS233JJrrrmGjz76iAULFvDNN9/w/PPP57dZ/DfUs2dPtt9+eyDN1Tz22GP59NNPWbhwIZ8UYW2/sWPHMnTo0KW2wsQY+fbbb7nqqqvy56PWr1+fM888c6WPUaLWtNJPYRtwJIVXZ5oFbFOE8zsDCwo5fwGwZ4F2ARi+nMcaBoRCrr0Z8GuBdr8V5TmV5+qvy7NgQYyHHhojxHjeeTEWofKxJEmqJCpC9deddtppuRVD11prrfjRRx/lt83Ly4vHH3/8ctvXr18/v21WS4osVrAi6N133x1jjHHmzJlxs802KzT22rVrxzfeeCP//MXHF1cTLXi9Zbeddtop/7zzzz9/ue2WXcZjWQWrv44ePXqp+0aOHPm762266aaFVj0dOHDg79reeeedMcbCq78++eSTy63+ussuu6yw+uuHH3643OcLxL322mup9p9//vlyfweFnVPw76iwbWW/m8V/lyNGjFjhv32M5bD6awihDrC4L3YKsDGwNykhrAdcV4TL3ApUB2YC2+e2mbljtxZo1zd3bYBbgMa5nwBdgD8Wcu0bgZrA3CLEUaFVrw733w8nnph6K//8Z8jLyzoqSZKk4jFgwABOPPFEWrVqRePGjalWrRrrrrsuvXr14sUXX1yqSmcIgTvvvJOnn36a/fbbj3XXXZfq1auzwQYb0L17d2699dYVPFL2GjRowKuvvsopp5xCs2bNqFatGuussw69e/fmtddeo3379ss9d7PNNqNfv360bNmS+vXrU7NmTVq0aEG/fv148skn89sNHDiQBx54gF133ZW1116b2rVrs9lmm3HEEUes0b9P586d+de//kWLFi2oXbs2nTt3zi88tKxTTz2VI488coXDVgvq2bMno0aNolu3btSvX5/q1auz6aabct555zFixAiqV6++3HObNWvGzTffzAEHHMAmm2zCWmutRY0aNdh8880555xzlvq3gVQJ+O2332bgwIG0bduWtddem2rVqtGkSRP23HNPBg4cuNxKtUVVtWpVGjVqxA477MBf//pX3n//ffbaa681umZxCLGYJ46GEA4CHs3dPDfGeHXu+HNADyAPWC/GOH0557cFxudu/ivGeHLu+K3A4tl/bWOMb4cQngb2yx1bL8b4QwihCfB97tjTMcYDClz7AGAIqRezJtARWBRjXOnc0nbt2sXx48evrFm5FCOcdx5cfTUccQTcfTdUc7atJEmVWmHzCiWVTyt6PYcQ3ooxtluT65fEnMo2BfYnF7JfBWi9BucD7LBM21kxxh8Acj9nLdOOEEIt4AZSj+mpK3j8SicEuOoqGDgQHngA+vSB1SyyJUmSJKmSKYmksmBf9Ozl7DcppvMbF3JfwdsFH+c80lDca2OMq7fY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\n",
      "text/plain": [
       "<Figure size 936x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "length = len(dirs)\n",
    "xticks = [5*(i+1) for i in range(length - 1)]\n",
    "\n",
    "counts_ens = []\n",
    "noise_ratio_ens = []\n",
    "noise_counts_ens = []\n",
    "SCF_ratio_ens = []\n",
    "\n",
    "for i in range(1,length):\n",
    "    topk = np.argsort(-entropy(ens_preds[0:i].mean(axis=0), axis=-1))[:500]\n",
    "    topk = get_scf_idxes(entropy(ens_preds[0:i].mean(axis=0), axis=-1), p=0.05)\n",
    "    try:\n",
    "        counts = np.unique(metadatas[topk], axis=0, return_counts=True)[1]\n",
    "        print(counts)\n",
    "        noise_ratio = len(np.intersect1d(topk, noisy_idx))/len(topk)\n",
    "        SCF_ratio = counts[-1]/sum(counts)\n",
    "    except:\n",
    "        counts = 0\n",
    "        noise_ratio = 0.0\n",
    "        SCF_ratio = 0.0\n",
    "        \n",
    "    print(len(topk) , counts)\n",
    "    noise_counts = np.unique(metadatas[np.intersect1d(topk, noisy_idx)], axis=0, return_counts=True)\n",
    "    \n",
    "    counts_ens.append(counts)\n",
    "    noise_ratio_ens.append(noise_ratio)\n",
    "    noise_counts_ens.append(noise_counts)\n",
    "    SCF_ratio_ens.append(SCF_ratio)\n",
    "\n",
    "counts_l = []\n",
    "noise_ratio_l = []\n",
    "noise_counts_l = []\n",
    "SCF_ratio_l = []\n",
    "\n",
    "for i in range(1, length):\n",
    "    topk = np.argsort(-entropy(ens_preds[i], axis=-1))[:500]\n",
    "    topk = get_scf_idxes(entropy(ens_preds[i], axis=-1), p=0.05)\n",
    "    \n",
    "    try:\n",
    "        counts = np.unique(metadatas[topk], axis=0, return_counts=True)[1]\n",
    "        noise_ratio = len(np.intersect1d(topk, noisy_idx))/len(topk)\n",
    "        SCF_ratio = counts[-1]/sum(counts)\n",
    "    except:\n",
    "        counts = 0\n",
    "        noise_ratio = 0.0\n",
    "        SCF_ratio = 0.0\n",
    "        \n",
    "    print(len(topk) , counts)\n",
    "    noise_counts = np.unique(metadatas[np.intersect1d(topk, noisy_idx)], axis=0, return_counts=True)\n",
    "    \n",
    "    counts_l.append(counts)\n",
    "    noise_ratio_l.append(noise_ratio)\n",
    "    noise_counts_l.append(noise_counts)\n",
    "    SCF_ratio_l.append(SCF_ratio)\n",
    "    \n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "font = {'weight' : 'bold', 'size': 15}\n",
    "matplotlib.rc('font', **font)\n",
    "\n",
    "plt.figure(figsize=(13,8))\n",
    "plt.plot(xticks, SCF_ratio_l, c='b',linestyle=':', label='SCF ratio')\n",
    "plt.plot(xticks, noise_ratio_l, c='b', linestyle='-', label='Noise label ratio')\n",
    "plt.plot(xticks, SCF_ratio_ens, c='r',linestyle=':', label='SCF ratio SGLD')\n",
    "plt.plot(xticks, noise_ratio_ens, c='r',linestyle='-', label='Noise label ratio SGLD')\n",
    "plt.xlabel(\"Epochs\", fontsize=20)\n",
    "plt.xticks([5*(i+1) for i in range(length)])\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"0.1noise_50epochs_celeba.png\", dpi=200)\n",
    "\n",
    "plt.figure(figsize=(13,8))\n",
    "plt.plot(xticks, np.array(SCF_ratio_l) - np.array(noise_ratio_l), c='b',linestyle='-', label='SCF - noise ratio')\n",
    "plt.plot(xticks, np.array(SCF_ratio_ens) - np.array(noise_ratio_ens), c='r',linestyle='-', label='SCF - noise ratio SGLD')\n",
    "plt.xlabel(\"Epochs\", fontsize=20)\n",
    "plt.xticks([5*(i+1) for i in range(length)])\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"0.1noise_50epochs_diff_celeba.png\", dpi=200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "1548796b-85a8-4ab9-b90e-4a0c773e9e50",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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LlzIVlttBcCsWbN69N46WrRoEWeddRYPPfQQy5YtA7p/z8UwY8YMHnjgAaZMmcLChQuLXY40MJWUQuXQxKMvxJgMl5lhtIBe1pa1vXxda28OER7SfltZlde1biL5hMqZGcvjko9sImColKTN1NNPP82f/vQnDj300F453p133pkOfoUEr83ZF7/4Re64445ilyFpcxBCInhV1ACjev/4qetaN7aXNdW2YXnn4+R7XSuhZzMB9yjIZhkiXF7jda1J+YTKrfqsCknSgHL55Zf3WqhUbqke3O22246nnnqKqqri3RpHkrqUeV1r9Yi+OUfqutacvazZJmXqEGQzr2vtGGQLuq61qovrVztco9qTIJvaXlWXWB4gehwqY4yv9VURIYTJwGXAQcAw4EXgqhjj9d3s9wngeGAaMB5oAv4FfC/GeHuHtguBKTkOtetgvf+mJOWrtLSUhx9+mAcffJB99903Z7uGhgYuu+wyfvWrX7Fw4UJqamrYY489uOiii9JDZKdOncprr2348ZKaRGS//fZj7ty53dZSX1/Pqaeeyu23305paSnHH3883/3ud6ms7Hqyjueee47Zs2fzwAMPsHLlSsaPH8/hhx/OJZdcwqhRib/gz507l/333x+Aa665hn/961/ceuutABx++OFcffXVDBkyJH3M7373u1x55ZWsWLGCj370o5x33nnd1p9L5tBZgBdeeCE9g3BqGO+8efO49NJLeeSRR1i9ejVTp07lxBNP5Ctf+Qrl5Yn772UOFf7Vr37Fbbfdxp///GcmTZrElVdeyf7778+XvvQlfv7znzN8+HA+//nPc+6556bP+7Of/YwbbriBl19+meXLl1NVVcWOO+7IOeecwzHHHNPt++hJjZLUY31+XWvbhiCaGUDzHi7ckLyuteNx8riuda8vwMe+0Tfvsy/EGHv0AL4G7NtNm32Ar/X0mMl9xgFvkvgKd3x8tZt9/5xjvwic36Htwi7a7tJdnbvvvnuUpEL885//LHYJG+3kk09Of8887rjjIhAPOuigGGOMs2bNSm976KGHYowxNjc3x7333jvr99zS0tL4+9//PsYY45QpU7K22W+//XLWcsMNN6TbjRs3rtO+p59+eta6U+bPnx9ramqynnfbbbeNK1eujDHGOGfOnPT6urq6Tm3PP//89DGvv/76Ttsza5s1a1ZeX+8FCxbk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uOKKK3rtvUmSBr58QuWhwO9ijHO6aPM6MGHjSpIk9Wfjxo3jlFNOAeCyyy7L2uaee+5JL1966aWMGDGCfffdl2OOOQZIDO18+eWXN7qWL33pS2y99dZMmTKFc845B4DW1lbmzZuXtf26det46KGHANh33305+uijqa2tZfbs2VRVVQFw7733dtrvtNNOY/r06UydOpV9990XgDfeeAOAN998k9dffx2AY445hj333JPRo0dz4YUXbvT7SzniiCOYPn06O+20E2PHjgVg8uTJnHrqqYwdO5a99tqrXU0AEydO5Je//CXTp0+npqaGcePG8cc//hGAVatW8c477+Q839133w3AsmXL2HPPPamsrGSfffZJDy2eM6erXwUkSYNNPvep3ALo7jeAFmBI4eVI0iBxyDeLXcFGOe+887juuuu44447KCvr/KNk2bJl6eWJEydmXV66dCnbbrvtRtUxadKk9PKWW26ZXs51PeOKFSvSPXSZ+1ZWVjJ69GjefPNNli5d2mm/9773venlVPhsbm4GYPHixVlrmDCh9/7GmuqJzDx/Zv0VFRXtagI46aST+P3vf5/zmI2NjTm3ZfsaZFq+fHnXBUuSBpV8eiqXA5O6abMt4BX8krSZ22qrrTjuuONoa2trN+QyZfTo0enlzID35ptvdmqzMfeQzDxe5nkyw12mESNGUFJS0mnfpqamdBDOrD0lMzh3rHf8+PFZa3jrrbd69B56Iltwz7YupaGhId0r+dGPfpS3336bGCNf/vKXe3S+1Ndgl112yTrPwEsvvVTAu5Akba7yCZWPAIeHEMZl2xhCeC9wMBkzwkqSNl8XXHABIQRaW1s7bfvYxz6WXr7oootYuXIlDz/8MLfffjuQmPU11Us5YsSIdNt//OMfedVw5ZVXsmDBAl577bX0tZClpaXsscceWdvX1NSw9957A/DAAw9w5513snr1ambPnp3uucusvScmTpzI5MmTgcQ1jfPmzWPZsmU5b7syY8YMQghMnTo1r/Pko6WlJd0jW1lZSXV1NfPnz+fmm2/u0f4HH3wwkLgn6be//W1WrVrFmjVrmDt3LieddBK33nprn9UuSRp48gmV3wGqgAdCCIcANZC+Z+UhwO+BNuC7vV6lJKnf+cAHPsARRxyRddunPvUpPvShDwFw8803M2LECPbZZx9Wr15NaWkp3//+99M9ftOnT0/vt9NOOxFC4KKLLupRDcuWLWPrrbdm6tSpPPfccwCceuqpbLXVVjn3ueKKK6iurqatrY2jjjqK2tradADcZptt0tdm9lRJSQmzZs0CErc42XPPPRkzZkzOSYw2hdraWvbZJ3Er6T/+8Y/U1tYyffp0hg0b1qP9Z8+ezRZbbAHA+eefz/Dhwxk2bBj7778/N998c49uSSJJGjx6HCpjjPOAzwBTgT8A/5PcVJ98vRVwWozx+V6uUZLUT+WajKa8vJy//vWvXHjhhWyzzTaUl5dTV1fHxz72Me6///52YfSTn/wkZ599drthpD314x//mJkzZ1JbW8vw4cM588wzueqqq7rcZ/r06Tz++OMcffTRjBo1irKyMiZNmsTnPvc5HnvsMYYPH553HaeeeipXXHEFEyZMoLq6mkMPPTTdK9tR6l6Yu+yyS97nycett97KYYcdxtChQ9lyyy35zne+w6c+9ake7Tt58mTmz5/P6aefzqRJkygvL2fs2LF86EMf4tJLL033ZEqSBBAStxvJY4fEMNfPAXsCo4BVwOPAD2OML/Z6hf3EtGnT4vz584tdhqQB6IUXXmC77bYrdhnqB9555x3GjRvHsGHDeP7559tNXCRtKn5PklSoEMKTMcZpHdfnM/srADHGl4H8xgZJkiT++te/EmPk29/+toFSkrTZyDtUSpKkwhx//PEcf/zxxS5DkqRelc9EPZIkSZIktWOolCRJkiQVzFApSZIkSSqYoVKSJEmSVDBDpSRJkiSpYIZKSZIkSVLB8r6lSAihHDgA2A4YGmP8RnJ9FVALLIsxtvVqlZIkSZKkfimvnsoQwsHAQuCPwHeBSzI27wIsBo7tndIkSf3FzJkzCSG0ewwdOpSdd96Zb3zjGzQ3N6fb3njjjek2c+fO3eS1Tp06lRACM2bM2OTn7qm5c+emv0Y33nhjscuRJGmj9LinMoQwDbgTWAacA3wQ+K/U9hjj4yGEBcBRwG29W6Ykqb9Zu3Ytzz77LM8++yyLFy/mmmuuKXZJkiSpCPLpqbwYWAdMizFeBbycpc3fgJ17ozBJUv80Z84cYozcf//9hBAA+OUvf1nkqiRJUrHkEyo/DNwZY1zSRZs3gPEbV5IkaSDYf//9GTt2LACNjY3dtn/33Xc5++yzmTp1KhUVFYwZM4ZjjjmG5557rl271LDQmTNncs0117D11lszdOhQDjjgAF599dV2be+991523HFHqqqqmDZtGo888shGv6/M4bO33HILW221FUOHDuXEE09k7dq13Hfffey0004MGzasU01Lly7lv/7rv9h2222pra2loqKCyZMn85nPfIZly5Z1e+6mpia+/vWvs91221FVVcXw4cM57LDDePLJJzf6fUmS1FfymahnKImhr12pwRllJWlQePDBB1m6dCkAH//4x7tsu2rVKvbaay9eeuml9Lply5Zx++23c/fdd/Pggw+y++67t9vnzjvv5Kabbkq/vv/++zn++ON5/PHHAXjhhRf4xCc+kb6e88knn+Sggw5K955urGeffZaTTjqJGCMAt9xyC0uXLmXu3Lk0NTVlrendd9/lF7/4RbvjvPHGG1x77bU8/fTTzJs3L+f51q9fzyGHHMKcOXPS65qamvjTn/7Efffdx3333ceHP/zhXnlvkiT1pnwC4CJg+27a7AK82k0bSdIAtv/++xNCYL/99qOtrY1JkyZx1VVXdbnPlVdemQ6U559/PqtWreK3v/0tJSUlrFu3ji9/+cud9lm1ahU33XQTy5cv58ADDwRg3rx5vPnmmwBceuml6UB57bXXsmrVKs4++2zWrFnTK+9zxYoVXHvttSxbtoz3vOc9ANxzzz2ceOKJrFixgqOPPrpTTWPHjuXOO+9k0aJFNDU1sWrVKi655BIAnnjiCZ566qmc57vtttvSgfKmm26ioaGBBQsWsN1229HU1JT1ayRJUn+QT0/l3cBnQwh7xxgf7rgxhHAIsBfwzd4qTpI2V9964lv8a/m/inLu9498P+d/8PxeO94bb7zBscce2+VMr/fccw8AVVVVzJ49m8rKSo466ij23Xdf5s6dy8MPP0xDQwPV1dXpfT74wQ9y0kknAXDUUUfxl7/8JX2+iRMn8uijjwKw9dZbc/rppwNw8cUXc8UVV7SbjbZQkyZN4tOf/jQA06ZN45VXXgHgggsuYPjw4Rx00EH89re/bVfTiBEjeOmll/ja177Gyy+/TENDQ7tjvvTSS+y2225Zz3f33Xenl08++WROPvnkdtufeOIJ1q1bR01NzUa/N0mSelM+PZWXAyuBe0MI3wI+ABBCOCz5+tckbinyvd4uUpLUf6Qm6lmwYAE77LADAA888ECXQztT1xOOGTOGysrK9PqJEycC0NrayvLly9vt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5sQYY3zggQdiSUlJBOInP/nJdNsbbrihU9uVK1fGbbfdNuv36pqamjh//vz0/qn1dXV1ndruscce6Xb//Oc/Y0VFRbvtQ4YMiUOHDo1A3G+//fJ+n1OmTMla45w5c+Kbb74Zx48fn3X7lClT4tKlS2OMMS5YsCC9fuTIkZ3aHn744Z3WnX/++ekafvSjH+X8uXbeeeel282aNSu9fsGCBTHG2OMacznnnHMiEMePH5/za/Oe97wnHn/88RGIs2fPjitXrozV1dUxhBAvvvji9PluvvnmTv+mJ598cqfj1dbWxhBCu1onTZoUm5ubY4yFfXZGjBjRrt2KFSuyvt9sn6GhQ4fGYcOGdfoM7bfffulzVlZWptvfcccdceHChXHs2LFZaxw7dmxcuHBhjDHGOXPmpNffcMMN6WNn/veV7d931KhRnY576aWXtnsv//rXv9Lb/vCHP3T577w5fE+SVBzA/JglK+Uz/PVk4MUY48wYY+oaxZUxxsdjjN8kcZuR/wA+kscxIfEd9PUY4wkxxtExxqoY484xxus7tAnJx8yMdTMy1md7zO1wjOuTx65KnuuEmOjFlKRNaslll/HaiScV5bHksss2qvb999+fEAL77bcfbW1tTJo0KT1kMpcrr7ySl15K3HHq/PPPZ9WqVfz2t7+lpKSEdevW8eUvf7nTPqtWreKmm25i+fLl6Wv75s2bx5tvvgnApZdemp4g6Nprr2XVqlWcffbZrFmT7RbGPbNw4cJ2wz5TPyxnzJjB1772NRYvXszo0aN5/PHHaWpq4qGHHqKyspLXXnuNK664otPxWlpaeOKJJ3jmmWfSvVC/+93vuP7663n77beZMmUKAL/5zW/S++y99948+OCDLF26lJaWFpYsWcJhhx0GJK737GooZyE1ZnrqqcSP9+23377LdqeddhoAN9xwA7fccgsNDQ3sv//+bL311l3ul019fT3/7//9P1asWJHuyXzjjTeYN28eUNhnZ8WKFVx22WWsWrWKF154gSFDhmQ9d+Zn6Mc//jErV67kv//7v1m9enXOetetW8ehhx7K4sWLWbJkCXvttRezZs3inXcSV99cffXVrFq1iquvvhqAd955h1mzZuX9dcm0ww47sGTJEp599lkmTJgAwLe//e12dW677baUl5cDdOrplaS+lk+ofD9wf4d16VuSxBj/DvwB+Fwv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\n",
      "text/plain": [
       "<Figure size 936x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "length = len(dirs)\n",
    "xticks = [5*(i+1) for i in range(length)]\n",
    "\n",
    "ent_nbfm = []\n",
    "ent_nbm = []\n",
    "ent_bm = []\n",
    "ent_bfm = []\n",
    "\n",
    "for i in range(len(ens_preds)):\n",
    "    ent_nbfm.append(entropy(ens_preds[i][(metadatas == [0,0,1]).all(axis=1)], axis=-1).mean())\n",
    "    ent_nbm.append(entropy(ens_preds[i][(metadatas == [0,1,1]).all(axis=1)], axis=-1).mean())\n",
    "    ent_bm.append(entropy(ens_preds[i][(metadatas == [1,0,1]).all(axis=1)], axis=-1).mean())\n",
    "    ent_bfm.append(entropy(ens_preds[i][(metadatas == [1,1,1]).all(axis=1)], axis=-1).mean())\n",
    "\n",
    "plt.figure(figsize=(13,8))\n",
    "plt.plot(xticks, ent_nbfm, label='Not blond, female')\n",
    "plt.plot(xticks, ent_nbm, label='Not blond, male')\n",
    "plt.plot(xticks, ent_bm, label='Blond, male')\n",
    "plt.plot(xticks, ent_bfm, label='Blond, female (Minor group)')\n",
    "plt.xlabel(\"Epochs\", fontsize=20)\n",
    "plt.ylabel(\"Average entropy\", fontsize=20)\n",
    "plt.xticks([5*(i+1) for i in range(length)])\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"celebA_{args.p_noise}_ent_bygrounp_map_strong.png\", dpi=200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "8e84ba33-34b8-4026-ab30-e14da956543d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnUAAAGdCAYAAAB0CIUmAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8/fFQqAAAACXBIWXMAAAsTAAALEwEAmpwYAAAt1klEQVR4nO3deZhcZZn38e+djSRAIpCEQFiaLQqyiIZhCUhQBGQRGJZxhi0Cr4gwLDIsvmwBZRFGGVmVAQkzyIuygw4wzsiiwICBibIHgQQJWydIQsgKPO8fdbpz0unuVHVXV1Wf/n6uq64+y3NO3fWkOvnlOVuklJAkSVLv1q/eBUiSJKn7DHWSJEkFYKiTJEkqAEOdJElSARjqJEmSCmBAvQvoKSNGjEhNTU31LkOSJKmqnnrqqVkppZFtlxc21DU1NTFlypR6lyFJklRVETGjveUefpUkSSoAQ50kSVIBGOokSZIKwFAnSZJUAIY6SZKkAjDUSZIkFUBhb2kiSSqWuXPn8u6777JkyZJ6lyL1iIEDBzJq1CiGDRvWpe0NdZKkhjd37lzeeecdxowZw5AhQ4iIepckVVVKiQULFjBz5kyALgU7D79Kkhreu+++y5gxYxg6dKiBToUUEQwdOpQxY8bw7rvvdmkfhjpJUsNbsmQJQ4YMqXcZUo8bMmRIl08xMNRJknoFR+jUF3Tne26okyRJKgBDnSRJUgF49askqddqOuPXdXnf6RfvVfE2EydO5MYbb+xwfUqp4n3eddddTJ06FYBJkyZVvH2jmzBhAg8//DDrr78+06dPb7hapk6dyl133QWU/nybmprqVh8Y6iRJ6rXuuuuu1qBYxFDX6KZOncp5550HlEKfoa6Xa+9/iV35H5wkqe948MEHmTBhQl3ee+HChQwePLgu792bPfTQQ/UuYYU8p06SpAYyadIkIoKI4OGHH2bfffdl5ZVXZv311+fSSy9tbdfU1LTM4dyWbVrC4sSJE1uXTZkyhe23356VVlqJn/zkJwDMnj2bE088kaamJgYNGsTIkSM58MADefbZZ5epp2UfEydO5Oqrr2bDDTdk8ODB7LTTTjzzzDMAvP766/Tv35+I4Pvf//4y248fP56IYKuttur0cz/11FNst912DB48mM0226z1sGZ7nnjiCb72ta+xxhprMGjQIMaOHcv3vve9ZW4FMnny5Nbab7/9dg4//HCGDx/OWmutxWmnncZHH320zHvvvffejB49mpVWWonRo0ezyy67cN1117W2mTBhAhHROho3ceJEvvGNb7Su32WXXVrf79FHH22dvummm1rbpJRYZ511iAj23XffTvujKxypkySpQe27777MmTMHKAWn0047jS222II99tijov3stttu/PWvf22dnzNnDjvssAPTpk1rXTZr1ixuv/127rvvPh555BG+8IUvLLOPX/3qV8uEyN///vd8+ctf5uWXX2a99dZjr7324t5772Xy5MmceeaZRARvvvkmjz/+OACHH354h/XNnj2bXXfdlffffx+AF154gQMPPJDVVlttubYPPPAA++yzzzIB7uWXX+acc87hySef5N57711um6OOOqq1H+fOncull17KhhtuyLe+9S0+/PBDdt99d2bPnt3a/p133uGdd95h5ZVX5uijj+6w7o6MHz+eLbbYgmeeeYaf/exnHHrooUApjLY8MaKz/uiquo3URcRhEfF4RMyLiA8j4sWIuCS3vn9EnBoRL0XEooh4MyKujojV61WzJEnVkB/ViQj222+/dtt95jOfYebMmTzwwAOty2677TYApk+fzhFHHNG6PKVESqndw4SbbbYZr776Ku+99x4HHHAAl112WWugO/3005kzZw533HEH/fr1Y/78+ZxyyinL7eO9997j1ltvZc6cOZx22mkANDc3c/nllwNw7LHHAvDKK6/w8MMPA3DnnXeSUqJ///4ccsghHfbHZZdd1hrozjnnHObMmcMVV1zBrFmzlmt73HHHsWTJEnbYYQemT5/OggULuOyyy4BS8Lz//vuX22bEiBG89NJLTJ06tfXQc0s/vvjii62B7vbbb2fx4sW88cYb3H333eyzzz4d1jx58mRuuOGG1vkHH3yw9c8g3x8PPfQQr732Wuv+AVZbbTX23nvvDvfdVXUJdRFxJfBvwHbAysBQ4NPAP+Sa/RS4BBgLDALWAo4FHooIbysuSSq8c889l7XXXpvddtuNUaNGAfCXv/yl4v1cdtllbLDBBqy22mqsu+66rSFx8ODBnHfeeQwbNoz999+fL37xi0BpFG7BggXL7GP8+PEceOCBDBs2jEmTJjFo0CAAHn30UQB23313NthgA4DWsHPHHXcAsOuuuzJ69OgO63vssceA0tMUzjzzTIYNG8axxx7Leuutt0y7adOm8corr7Ru09TUxJAhQzj55JNb2zz44IPL7f+UU05h7NixbLXVVmy55ZbA0n4cM2YM/fv3B+Cqq67isssuY+rUqYwfP55jjjmmk17t3KGHHsoqq6xCSonJkycDS/vj4IMPZqWVVuryvjtS81AXEXsDx2Wzt1IKbUOBzYELszbbA0dlbe4ERgLfzea3AE6sVb2SJFVbflQnpdTh+WObbLJJ63TLCNOiRYsqfr8ttthimfmWEbCRI0cuEy7WWWcdAD7++GPee++9ZbZZd911W6eHDBnC6quXDpy1HE7s169fawi67bbbeO2111pH7FZ0qPGtt94CSiNqLWERYO21116mXXNzc6f7AZarGzrvx9GjR3P55ZczfPhwfvvb33L66ae3nl/XcmVrV6y66qqth11vvPFGnn76aV599VWgZw69Qn1G6k7Ifk4HDk0pvZxSWpBSei6ldHW2Lj9id3FKaRZwKfBBO+slSSqkAQOWnvre3uOjyn2kVNurXUeMGAGUQlI+JL7xxhsA9O/ff7nz2VrWQekK2pbwNGbMmNblRx55JIMGDWL+/PkcdthhfPzxx6y66qodHl5usdZaawGlsLl48eLW5W+++Wa7dQOcdNJJywTjlte111673P5X1I/f/va3aW5u5sknn+TnP/85X/3qV/noo48477zzlvncba2o/1sOwc6YMYMTTijFn4022ogddtih0+26qqahLiL6A+Oz2TeAOyPi/Yh4LyJ+HhFrZes+n9tsGkBK6WPg1WzZZhFR/XFLSZJ6kXzwarkStRy77bYbUApn5513HnPnzuXuu+/mkUceAUqHWocOHbrMNr///e+54447mDt3Lueee25r+Bo/fnxrm5YraGHpYdkDDjhguX211bKPBQsWcMEFFzB37lyuueYaXn/99WXajR07tvUQ73XXXcd9993HwoULaW5u5rbbbmPnnXdmxowZZfcDlC6KOOOMM3j66afZcMMNOeCAA9hxxx2B0nmK7Z3X1yLf/88999xyN5DecsstWwNcS38cdthhFdVXiVqP1K1B6VArwI7AnsBwYDVKo28PRcRQYERum7ntTPcHlrtgIiK+GRFTImJKOUO0kiTVQ9sLJSKiS09M2GabbVqnt9xySyKCs846a4XbnXzyyWy88cYAXHTRRQwfPpz99tuPTz75hCFDhvDP//zPy22z5ppr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\n",
      "text/plain": [
       "<Figure size 648x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import gamma\n",
    "\n",
    "ents = entropy(ens_preds.mean(axis=0), axis=-1)\n",
    "#ents = entropy(ens_preds[-1], axis=-1)\n",
    "fit_alpha, fit_loc, fit_beta = gamma.fit(ents) # Assume the entropy follows Gamma distribution.\n",
    "\n",
    "x = np.linspace(gamma.ppf(0.01, fit_alpha, loc=fit_loc, scale=fit_beta),\n",
    "                gamma.ppf(0.99, fit_alpha, loc=fit_loc, scale=fit_beta),\n",
    "                100)\n",
    "\n",
    "p_vals = 1 - gamma.cdf(ents, fit_alpha, loc=fit_loc, scale=fit_beta)\n",
    "scf_idxes = np.where(p_vals < 0.05)[0]\n",
    "\n",
    "plt.figure(figsize=(9,6))\n",
    "plt.hist(ents, bins=100, density=True, label='Entropy density')\n",
    "#plt.plot(x, gamma.pdf(x,fit_alpha, loc=fit_loc, scale=fit_beta), linewidth=5, label='Gamma Pdf')\n",
    "plt.ylabel(\"Density\")\n",
    "plt.xlabel(\"Entropy\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f\"entropy_gammafit_celebA_{args.p_noise}.png\", dpi=200)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "47ec3ff1-e2a7-4548-84c1-1ce6298332cc",
   "metadata": {},
   "source": [
    "## Total dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "62e2b634-0558-43c7-af42-adadd216a6cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([[0, 0, 1],\n",
       "        [0, 1, 1],\n",
       "        [1, 0, 1],\n",
       "        [1, 1, 1]]),\n",
       " array([71629, 22880, 66874,  1387]))"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "counts = np.unique(metadatas, axis=0, return_counts=True)\n",
    "counts"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6cca4940-24ba-4ca0-bdb6-fd516e0e02d7",
   "metadata": {},
   "source": [
    "## Errorset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "58cce6ab-7753-4e43-b2d1-3affc99e3d0a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((array([[0, 0, 1],\n",
       "         [0, 1, 1],\n",
       "         [1, 0, 1],\n",
       "         [1, 1, 1]]),\n",
       "  array([6180, 5252, 3506, 1022])),\n",
       " 22.095100864553313)"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.unique(metadatas[preds.argmax(1) != targets], axis=0, return_counts=True), len(np.intersect1d(np.where(preds.argmax(1) != targets), noisy_idx))/347"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c5219aa0-3259-4318-bfda-f8ca4d2ea374",
   "metadata": {},
   "source": [
    "## Uncertain set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d0679806-fd21-4f13-b3d8-20cefe0e9089",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((array([[0, 0, 1],\n",
       "         [0, 1, 1],\n",
       "         [1, 0, 1],\n",
       "         [1, 1, 1]]),\n",
       "  array([ 23,   3,  48, 126])),\n",
       " 0.065)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "topk = np.argsort(-entropy(preds, axis=1))[:200]\n",
    "np.unique(metadatas[topk], axis=0, return_counts=True), len(np.intersect1d(topk, noisy_idx))/200"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7c890d2d-2799-4cc9-95b7-52b2286be584",
   "metadata": {},
   "source": [
    "## Hard set"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f5cbdc40-f563-46dd-9f66-60dfde8be591",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((array([[0, 0, 1],\n",
       "         [0, 1, 1],\n",
       "         [1, 0, 1],\n",
       "         [1, 1, 1]]),\n",
       "  array([169,  39,  31,  61])),\n",
       " 0.6533333333333333)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss = nn.CrossEntropyLoss(reduction='none')\n",
    "topk = np.argsort(-loss(torch.from_numpy(preds), torch.from_numpy(targets).long()))[:300]\n",
    "np.unique(metadatas[topk], axis=0, return_counts=True), len(np.intersect1d(topk, noisy_idx))/300"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c557cefa-1969-4404-8219-0997a157ebd4",
   "metadata": {},
   "source": [
    "## Variance of loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "92bdffb3-f0ac-474f-af80-805dfdefdcf6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "((array([[0, 0, 1],\n",
       "         [0, 1, 1],\n",
       "         [1, 0, 1],\n",
       "         [1, 1, 1]]),\n",
       "  array([129,  42,  49,  80])),\n",
       " 0.5133333333333333,\n",
       " (array([[0, 0, 1],\n",
       "         [1, 0, 1],\n",
       "         [1, 1, 1]]),\n",
       "  array([124,   1,  29])))"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "loss_var = np.var(losses, axis=0)\n",
    "topk = np.argsort(-loss_var)[:300]\n",
    "np.unique(metadatas[topk], axis=0, return_counts=True), len(np.intersect1d(topk, noisy_idx))/300,  np.unique(metadatas[np.intersect1d(topk, noisy_idx)], axis=0, return_counts=True)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
