{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "05f9ec3e-46b3-4e0c-a6ea-d3ba13e021f1",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "0bfe0a12-b0c3-4aaf-9930-edf95e66b2b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pickle\n",
    "import warnings\n",
    "\n",
    "import numpy as np\n",
    "import torch\n",
    "from torch import softmax\n",
    "\n",
    "from nnlib.nnlib import utils\n",
    "from nnlib.nnlib.matplotlib_utils import import_matplotlib\n",
    "\n",
    "matplotlib, plt = import_matplotlib()\n",
    "%matplotlib inline\n",
    "\n",
    "#from modules.bound_utils import estimate_fcmi_bound_classification, estimate_default_bound_classification, estimate_proposed_bound_classification, estimate_sgld_bound, estimate_kl_bound_classification, estimate_lg_bound_classification, estimate_interp_bound_classification\n",
    "from modules.bound_utils import estimate_fcmi_bound_classification, estimate_sgld_bound, estimate_kl_bound_classification, estimate_lg_bound_classification, estimate_interp_bound_classification\n",
    "from scripts.fcmi_train_classifier import mnist_ld_schedule, \\\n",
    "    cifar_resnet50_ld_schedule  # for pickle to be able to load LD methods\n",
    "import methods\n",
    "from torchmetrics.classification import MulticlassCalibrationError as ECE\n",
    "\n",
    "from sklearn.feature_selection import mutual_info_classif, mutual_info_regression\n",
    "\n",
    "from tqdm.auto import tqdm\n",
    "from modules.data_utils import load_data_from_arguments\n",
    "from nnlib.nnlib.data_utils.wrappers import SubsetDataWrapper, LabelSubsetWrapper, ResizeImagesWrapper\n",
    "from nnlib.nnlib.data_utils.base import get_loaders_from_datasets, get_input_shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "34553a28-a99c-499b-b524-446e669ef901",
   "metadata": {},
   "outputs": [],
   "source": [
    "def interpolate_nan(a):\n",
    "    \"\"\"Linear interpolation for nan values in a 1d array.\n",
    "    Nans on the boundary are filled with the nearest non-nan value.\n",
    "    \"\"\"\n",
    "    b = a.copy()\n",
    "    nans = np.isnan(b)\n",
    "    i = np.arange(len(b))\n",
    "    b[nans] = np.interp(i[nans], i[~nans], b[~nans])\n",
    "    return torch.tensor(b).float()\n",
    "\n",
    "def load_all_data(saved_data):\n",
    "    args = saved_data['args']\n",
    "    examples ,_ ,_ ,_ = load_data_from_arguments(args, build_loaders=False)\n",
    "    examples = LabelSubsetWrapper(examples, which_labels=args.which_labels)\n",
    "    \n",
    "    return examples\n",
    "\n",
    "def preds_recalibrate(saved_data, all_data, n_data=100):\n",
    "    all_examples = saved_data['all_examples'] ## train, val data\n",
    "    #args = saved_data['args']\n",
    "    #examples ,_ ,_ ,_ = load_data_from_arguments(args, build_loaders=False)\n",
    "    #examples = LabelSubsetWrapper(examples, which_labels=args.which_labels)\n",
    "    \n",
    "    assert len(all_data) >= n_data\n",
    "    np.random.seed(args.seed)\n",
    "    include_indices = all_examples.include_indices\n",
    "    exclude_indices = np.arange(len(all_data))[~np.isin(np.arange(len(all_data)), include_indices)]\n",
    "    if n_data >= len(exclude_indices):\n",
    "        raise ValueError(f\" The number of recalibration data is larger than that of all data\")\n",
    "    exclude_indices = np.random.choice(exclude_indices, size=n_data, replace=False)\n",
    "    examples = SubsetDataWrapper(all_data, include_indices=exclude_indices)\n",
    "    \n",
    "    return examples\n",
    "\n",
    "def calc_recalibration(ps, n_bins):\n",
    "    #idx = torch.bucketize(ps, n_bins, right=True) - 1\n",
    "    idx = idx_bins(ps, n_bins)\n",
    "    bin_total = torch.bincount(idx, minlength=len(n_bins)-1).float().to(ps.device) ## the number of samples per bins\n",
    "    bin_true = torch.bincount(idx, weights=ps, minlength=len(n_bins)-1).float().to(ps.device) ## the number of samples per bins weighted by labels\n",
    "    with warnings.catch_warnings():\n",
    "        warnings.filterwarnings('ignore')\n",
    "        bin_mean = interpolate_nan(bin_true.numpy() / bin_total.numpy()) ## \\hat{\\mu} in Eq.(9) of Sun et al. (2023)\n",
    "    return bin_mean[idx]\n",
    "\n",
    "def multi_pred_to_binary(preds, labels, target_label=3):\n",
    "    idx = np.arange(0,len(torch.unique(labels)))\n",
    "    preds = preds.softmax(1)\n",
    "    #binary_preds = torch.zeros_like(preds)\n",
    "    binary_preds = torch.zeros(len(preds), 2)\n",
    "    #binary_preds[:,0] = preds[:,idx!=target_label].sum(1)\n",
    "    binary_preds[:,0] = 1 - preds[:,idx==target_label].sum(1)\n",
    "    binary_preds[:,1] = preds[:,idx==target_label].sum(1)\n",
    "    labels[labels!=target_label] = 0\n",
    "    labels[labels==target_label] = 1\n",
    "    return binary_preds, labels\n",
    "\n",
    "def compute_bins(num_bins, confidences=None, method='uniform'):\n",
    "    if method == 'uniform':\n",
    "        n_bins = torch.linspace(0, 1, num_bins + 1)\n",
    "        n_bins[0], n_bins[-1] = 0., 1.\n",
    "    elif method == 'quantile':\n",
    "        if confidences == None:\n",
    "            raise ValueError(f\"confidence values are needed.\")\n",
    "        n_bins = torch.tensor(np.quantile(confidences, torch.linspace(0, 1, num_bins + 1)))\n",
    "        n_bins[0], n_bins[-1] = 0., 1.\n",
    "    else:\n",
    "        raise ValueError(f\"Unexpected binning method: {method}\")\n",
    "    \n",
    "    return n_bins\n",
    "\n",
    "def idx_bins(confidence, n_bins):\n",
    "    binids = np.minimum(np.digitize(confidence.numpy(), n_bins), len(n_bins) - 1)\n",
    "    binids -= 1\n",
    "    return torch.tensor(binids)\n",
    "\n",
    "def compute_ece(preds, mask, dataset, n_bins, norm='l1', recalibrate=False, strategy='label'):\n",
    "    labels = [y for x, y in dataset]\n",
    "    labels = torch.tensor(labels).long()\n",
    "    indices = 2*np.arange(len(mask)) + mask\n",
    "    ece = calc_ECE(preds[indices], labels[indices], n_bins, norm=norm, recalibrate=recalibrate, strategy=strategy)\n",
    "    #n_class = preds.shape[1]\n",
    "    #metrics = ECE(num_classes=n_class, n_bins=n_bins, norm=norm) ## norm='l1' (ECE); norm='l2' (RMSCE); bins=15 (default). Top-1 calibration error\n",
    "    #ece = metrics(preds[indices],labels[indices])\n",
    "    return utils.to_numpy(ece)\n",
    "\n",
    "def compute_ece_cifar(preds, mask, dataset, n_bins, target_label=3, norm='l1', recalibrate=False, strategy='label'):\n",
    "    labels = [y for x, y in dataset]\n",
    "    labels = torch.tensor(labels).long()\n",
    "    labels[labels!=target_label] = 0\n",
    "    labels[labels==target_label] = 1\n",
    "    indices = 2*np.arange(len(mask)) + mask\n",
    "    ece = calc_ECE(preds[indices], labels[indices], n_bins, norm=norm, recalibrate=recalibrate, strategy=strategy)\n",
    "    return utils.to_numpy(ece)\n",
    "\n",
    "def calc_ECE(confidences, labels, n_bins, norm='l1', recalibrate=False, strategy='label'):\n",
    "    if not torch.all(torch.abs(torch.sum(confidences, dim=1) - 1) < 1e-10):\n",
    "        print(\"make softmax prob.\")\n",
    "        confidences = confidences.softmax(1)\n",
    "    \n",
    "    if not torch.all((confidences >= 0) & (confidences <= 1)):\n",
    "        raise ValueError(f\"This is not softmax prob.\")\n",
    "        \n",
    "    #if not torch.all((confidences >= 0) * (confidences <= 1)):\n",
    "    #if confidences.softmax(1).sum(1).sum() == len(confidences):\n",
    "    #    print(\"softmax\")\n",
    "    #    p = confidences.softmax(1)\n",
    "    confidences, _ = confidences.max(dim=1)\n",
    "    confidences[labels==0] = 1 - confidences[labels==0] ## MEMO: Reverse prob. for label y=0.\n",
    "\n",
    "    with torch.no_grad():\n",
    "        conf_bin = torch.zeros(len(n_bins), device=confidences.device, dtype=confidences.dtype)\n",
    "        count_bin = torch.zeros(len(n_bins), device=confidences.device, dtype=confidences.dtype)\n",
    "        label_bin = torch.zeros(len(n_bins), device=labels.device, dtype=labels.dtype)\n",
    "        \n",
    "        #idx = torch.bucketize(confidences, n_bins, right=True) - 1\n",
    "        idx = idx_bins(confidences, n_bins)\n",
    "        if recalibrate:\n",
    "            bin_total = torch.bincount(idx, minlength=len(n_bins)-1).float().to(confidences.device) ## the number of samples per bins\n",
    "            if strategy == 'label':\n",
    "                bin_true = (torch.bincount(idx, weights=labels, minlength=len(n_bins)-1)).float().to(confidences.device) ## the number of samples per bins weighted by labels    \n",
    "            elif strategy == 'probability':\n",
    "                bin_true = (torch.bincount(idx, weights=confidences, minlength=len(n_bins)-1)).float().to(confidences.device) ## the number of samples per bins weighted by labels\n",
    "            else:\n",
    "                raise ValueError(f\"Unexpected strategy: {strategy}.\")\n",
    "            \n",
    "            with warnings.catch_warnings():\n",
    "                warnings.filterwarnings('ignore')\n",
    "                # fill nan by interpolation assuming smoothness\n",
    "                bin_mean = interpolate_nan(bin_true.numpy() / bin_total.numpy()) ## \\hat{\\mu} in Eq.(9) of Sun et al. (2023)\n",
    "                confidences = bin_mean[idx]\n",
    "\n",
    "        count_bin.scatter_add_(dim=0, index=idx, src=torch.ones_like(confidences))\n",
    "        conf_bin.scatter_add_(dim=0, index=idx, src=confidences)\n",
    "        conf_bin = torch.nan_to_num(conf_bin / count_bin)\n",
    "        prop_bin = count_bin / count_bin.sum()\n",
    "        \n",
    "        label_bin.scatter_add_(dim=0, index=idx, src=labels)\n",
    "        label_bin = torch.nan_to_num(label_bin / count_bin)\n",
    "    \n",
    "    if norm == 'l1':\n",
    "        ece = torch.sum(torch.abs(label_bin - conf_bin) * prop_bin)\n",
    "    elif norm == 'l2':\n",
    "        ece = torch.sqrt(torch.sum(torch.pow(label_bin - conf_bin, 2) * prop_bin))\n",
    "    else:\n",
    "        raise ValueError(f\"Unexpected norm type: {norm}\")\n",
    "    \n",
    "    return ece"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "c82a87dd-5cc2-43a8-bc7b-67d07ecafc40",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "n_bins = 5\n",
    "n_bins_bound = compute_bins(num_bins=5)\n",
    "len(n_bins_bound)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b25e5689-6e59-494e-9dbb-a9a784977e47",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading the model from results/cifar10-pretrained-resnet50/n=20000,lr=0.01,seed=0,S_seed=10/checkpoints/epoch39.mdl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/fujisawa/.pyenv/versions/3.11.6/lib/python3.11/site-packages/torchvision/models/_utils.py:208: UserWarning: The parameter 'pretrained' is deprecated since 0.13 and may be removed in the future, please use 'weights' instead.\n",
      "  warnings.warn(\n",
      "/Users/fujisawa/.pyenv/versions/3.11.6/lib/python3.11/site-packages/torchvision/models/_utils.py:223: UserWarning: Arguments other than a weight enum or `None` for 'weights' are deprecated since 0.13 and may be removed in the future. The current behavior is equivalent to passing `weights=ResNet50_Weights.IMAGENET1K_V1`. You can also use `weights=ResNet50_Weights.DEFAULT` to get the most up-to-date weights.\n",
      "  warnings.warn(msg)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "output.shape: [None, 10]\n"
     ]
    }
   ],
   "source": [
    "#n = 500\n",
    "n = 20000\n",
    "lr = 0.01\n",
    "seed = 0\n",
    "S_seed = 10\n",
    "results_dir = \"results\"\n",
    "exp_name = \"cifar10-pretrained-resnet50\"\n",
    "epoch = 40\n",
    "\n",
    "dir_name = f'n={n},lr={lr},seed={seed},S_seed={S_seed}'\n",
    "dir_path = os.path.join(results_dir, exp_name, dir_name)\n",
    "#if not os.path.exists(dir_path):\n",
    "#    print(f\"Did not find results for {dir_name}\")\n",
    "#    continue\n",
    "\n",
    "with open(os.path.join(dir_path, 'saved_data.pkl'), 'rb') as f:\n",
    "    saved_data = pickle.load(f)\n",
    "\n",
    "model = utils.load(path=os.path.join(dir_path, 'checkpoints', f'epoch{epoch - 1}.mdl'),\n",
    "                           methods=methods, device='mps')\n",
    "\n",
    "all_examples = saved_data['all_examples']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 457,
   "id": "26f94824-3f9f-4bef-867c-df6edf2cc8d0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|█████████████████████████████████████████| 625/625 [01:44<00:00,  5.96it/s]\n",
      "100%|█████████████████████████████████████████| 625/625 [01:49<00:00,  5.72it/s]\n"
     ]
    }
   ],
   "source": [
    "cur_preds = utils.apply_on_dataset(model=model, dataset=all_examples,\n",
    "                                           batch_size=64)['pred']\n",
    "        \n",
    "cur_labels = utils.apply_on_dataset(model=model, dataset=all_examples, \n",
    "                                            batch_size=64)['label_0']\n",
    "cur_mask = saved_data['mask']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 458,
   "id": "ef3f28df-7b6e-416b-b112-55c9572d2b24",
   "metadata": {},
   "outputs": [],
   "source": [
    "target_label = 3\n",
    "cur_preds, cur_labels = multi_pred_to_binary(cur_preds, cur_labels, target_label=target_label)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 459,
   "id": "52a9bd83-3923-4482-a631-fcaec3e046f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "#n_bins = 1000\n",
    "start, end, num_candidates = 6, 10**3, 10\n",
    "int_candidates = np.ceil(np.logspace(np.log10(start), np.log10(end), num=num_candidates)).astype(int) ## bin candidates\n",
    "res = []\n",
    "for n_b in int_candidates:\n",
    "    conf = cur_preds[train_idx].max(1).values\n",
    "    n_bins_l1_umb = compute_bins(num_bins=int(n_b), confidences=conf, method='quantile') ## for L1-ECE\n",
    "    cur_bins = idx_bins(conf, n_bins_l1_umb)\n",
    "    tra_ece = compute_ece(preds=cur_preds, mask=cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb)\n",
    "    tes_ece = compute_ece(preds=cur_preds, mask=1-cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb)\n",
    "    res.append(tra_ece - tes_ece)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 466,
   "id": "4346c299-99e3-4c84-aae9-1079882fc4a1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.01715159, 0.01715183, 0.01715302, 0.01715255, 0.01715231,\n",
       "       0.01715231, 0.01715255, 0.01715231, 0.01715255, 0.01715231],\n",
       "      dtype=float32)"
      ]
     },
     "execution_count": 466,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.abs(res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 464,
   "id": "ec15e421-82d3-4cb4-9734-a6917a2f33c2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([<matplotlib.axis.XTick at 0x3cb604d50>,\n",
       "  <matplotlib.axis.XTick at 0x3cb615c10>,\n",
       "  <matplotlib.axis.XTick at 0x3cb60e2d0>,\n",
       "  <matplotlib.axis.XTick at 0x3cb651610>,\n",
       "  <matplotlib.axis.XTick at 0x3cb65add0>,\n",
       "  <matplotlib.axis.XTick at 0x3cb65bd50>,\n",
       "  <matplotlib.axis.XTick at 0x3cb6627d0>,\n",
       "  <matplotlib.axis.XTick at 0x3cb669310>,\n",
       "  <matplotlib.axis.XTick at 0x3cb66b3d0>,\n",
       "  <matplotlib.axis.XTick at 0x3cb671890>],\n",
       " [Text(6, 0, '6'),\n",
       "  Text(11, 0, '11'),\n",
       "  Text(19, 0, '19'),\n",
       "  Text(34, 0, '34'),\n",
       "  Text(59, 0, '59'),\n",
       "  Text(103, 0, '103'),\n",
       "  Text(182, 0, '182'),\n",
       "  Text(321, 0, '321'),\n",
       "  Text(567, 0, '567'),\n",
       "  Text(1000, 0, '1000')])"
      ]
     },
     "execution_count": 464,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#plt.plot(int_candidates, (1/10000)*np.log(int_candidates))\n",
    "#plt.plot(int_candidates, (1/100000)*np.sqrt(int_candidates))\n",
    "#plt.plot(int_candidates, (1/100000)*int_candidates)\n",
    "plt.plot(int_candidates, np.abs(res))\n",
    "plt.xticks(int_candidates, fontsize=10, rotation=45)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 467,
   "id": "17e88067-a914-4a1f-a93c-9ed5846eda9b",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_idx = 2*np.arange(len(cur_mask)) + cur_mask\n",
    "conf = cur_preds[train_idx].max(1).values ## since it has already been \"softmax\"-ed."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 485,
   "id": "a903fbbc-dcb5-414c-ba4a-c37da2b76eeb",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_bins = 9\n",
    "n_bins_l1_umb = compute_bins(num_bins=n_bins, confidences=conf, method='quantile') ## for L1-ECE\n",
    "cur_bins = idx_bins(conf, n_bins_l1_umb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 486,
   "id": "625c688d-3a44-4ee8-ae0a-1f8b52da4f71",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([1, 7, 3,  ..., 1, 8, 6])"
      ]
     },
     "execution_count": 486,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cur_bins"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 487,
   "id": "6864d388-bad7-4c5a-9e30-115f6424814a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(1.9969963e-05, dtype=float32)"
      ]
     },
     "execution_count": 487,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "compute_ece_cifar(preds=cur_preds, mask=cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb, target_label=target_label)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 352,
   "id": "c05a414f-67d8-4cec-8c4b-5275eea58fb3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(0.00228549, dtype=float32)"
      ]
     },
     "execution_count": 352,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "compute_ece_cifar(preds=cur_preds, mask=1-cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb, target_label=target_label)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 439,
   "id": "b6f319c5-964a-4fc9-a15b-1b7cfb18d610",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading the model from results/fcmi-mnist-4vs9-CNN/n=1000,lr=0.001,seed=0,S_seed=10/checkpoints/epoch199.mdl\n",
      "[None, 1, 28, 28]\n",
      "[None, 32, 14, 14]\n",
      "[None, 32, 7, 7]\n",
      "[None, 64, 3, 3]\n",
      "[None, 256, 1, 1]\n",
      "[None, 256]\n",
      "[None, 128]\n",
      "output.shape: [None, 2]\n"
     ]
    }
   ],
   "source": [
    "n = 1000\n",
    "lr = 0.001\n",
    "seed = 0\n",
    "S_seed = 10\n",
    "results_dir = \"results\"\n",
    "epoch = 200\n",
    "exp_name = \"fcmi-mnist-4vs9-CNN\"\n",
    "\n",
    "dir_name = f'n={n},lr={lr},seed={seed},S_seed={S_seed}'\n",
    "dir_path = os.path.join(results_dir, exp_name, dir_name)\n",
    "#if not os.path.exists(dir_path):\n",
    "#    print(f\"Did not find results for {dir_name}\")\n",
    "#    continue\n",
    "\n",
    "with open(os.path.join(dir_path, 'saved_data.pkl'), 'rb') as f:\n",
    "    saved_data = pickle.load(f)\n",
    "\n",
    "model = utils.load(path=os.path.join(dir_path, 'checkpoints', f'epoch{epoch - 1}.mdl'),\n",
    "                           methods=methods, device='mps')\n",
    "\n",
    "all_examples = saved_data['all_examples']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 440,
   "id": "8220fa16-223b-4920-98fe-dc8318d46f49",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████| 32/32 [00:00<00:00, 148.23it/s]\n",
      "100%|██████████████████████████████████████████| 32/32 [00:00<00:00, 234.02it/s]\n"
     ]
    }
   ],
   "source": [
    "cur_preds = utils.apply_on_dataset(model=model, dataset=all_examples,\n",
    "                                           batch_size=64)['pred']\n",
    "        \n",
    "cur_labels = utils.apply_on_dataset(model=model, dataset=all_examples, \n",
    "                                            batch_size=64)['label_0']\n",
    "cur_mask = saved_data['mask']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 441,
   "id": "a6000cd8-9b2b-40bd-83ae-de9c734eb95c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n",
      "make softmax prob.\n"
     ]
    }
   ],
   "source": [
    "#n_bins = 1000\n",
    "start, end, num_candidates = 6, 10**3, 10\n",
    "int_candidates = np.ceil(np.logspace(np.log10(start), np.log10(end), num=num_candidates)).astype(int) ## bin candidates\n",
    "res = []\n",
    "for n_b in int_candidates:\n",
    "    conf = cur_preds[train_idx].softmax(1).max(1).values\n",
    "    n_bins_l1_umb = compute_bins(num_bins=int(n_b), confidences=conf, method='quantile') ## for L1-ECE\n",
    "    cur_bins = idx_bins(conf, n_bins_l1_umb)\n",
    "    tra_ece = compute_ece(preds=cur_preds, mask=cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb)\n",
    "    tes_ece = compute_ece(preds=cur_preds, mask=1-cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb)\n",
    "    res.append(tra_ece - tes_ece)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 442,
   "id": "4fba27c2-d55a-4a80-b25c-d871c533bb38",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([<matplotlib.axis.XTick at 0x3cb12c8d0>,\n",
       "  <matplotlib.axis.XTick at 0x3cb1107d0>,\n",
       "  <matplotlib.axis.XTick at 0x3cb1344d0>,\n",
       "  <matplotlib.axis.XTick at 0x3cb174190>,\n",
       "  <matplotlib.axis.XTick at 0x3cb176dd0>,\n",
       "  <matplotlib.axis.XTick at 0x3cb17e290>,\n",
       "  <matplotlib.axis.XTick at 0x3cb1899d0>,\n",
       "  <matplotlib.axis.XTick at 0x3cb191210>,\n",
       "  <matplotlib.axis.XTick at 0x3cb194910>,\n",
       "  <matplotlib.axis.XTick at 0x3cb1900d0>],\n",
       " [Text(6, 0, '6'),\n",
       "  Text(11, 0, '11'),\n",
       "  Text(19, 0, '19'),\n",
       "  Text(34, 0, '34'),\n",
       "  Text(59, 0, '59'),\n",
       "  Text(103, 0, '103'),\n",
       "  Text(182, 0, '182'),\n",
       "  Text(321, 0, '321'),\n",
       "  Text(567, 0, '567'),\n",
       "  Text(1000, 0, '1000')])"
      ]
     },
     "execution_count": 442,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#plt.plot(int_candidates, (1/10000)*np.log(int_candidates))\n",
    "#plt.plot(int_candidates, (1/100000)*np.sqrt(int_candidates))\n",
    "#plt.plot(int_candidates, (1/100000)*int_candidates)\n",
    "plt.plot(int_candidates, np.abs(res))\n",
    "plt.xticks(int_candidates, fontsize=10, rotation=45)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 392,
   "id": "af2c797a-cff8-4401-bbe3-9554cf0498ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "make softmax prob.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array(0.0002144, dtype=float32)"
      ]
     },
     "execution_count": 392,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 332,
   "id": "4ae5676c-df05-4caf-b01a-4f52eabc8f3f",
   "metadata": {},
   "outputs": [],
   "source": [
    "target_label = 1\n",
    "cur_preds, cur_labels = multi_pred_to_binary(cur_preds, cur_labels, target_label=target_label)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 333,
   "id": "d515c9ed-892b-4268-a9a1-ba04d5aa1079",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_idx = 2*np.arange(len(cur_mask)) + cur_mask\n",
    "conf = cur_preds[train_idx].max(1).values ## since it has already been \"softmax\"-ed."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 334,
   "id": "9b67a36b-3f72-47e2-bfc6-ac417001dc5d",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_bins = 10\n",
    "n_bins_l1_umb = compute_bins(num_bins=n_bins, confidences=conf, method='quantile') ## for L1-ECE\n",
    "cur_bins = idx_bins(conf, n_bins_l1_umb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 335,
   "id": "740c8ac4-64ac-46a4-8f26-92559d881381",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(1.9223896e-07, dtype=float32)"
      ]
     },
     "execution_count": 335,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "compute_ece(preds=cur_preds, mask=cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 336,
   "id": "5d5534e8-7f2c-4ee2-b5d4-4290bd0c1971",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(0.0002144, dtype=float32)"
      ]
     },
     "execution_count": 336,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "compute_ece(preds=cur_preds, mask=1-cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "id": "866b852b-94f1-477a-97ac-6eff15b55a8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_idx = 2*np.arange(len(cur_mask)) + cur_mask\n",
    "conf = cur_preds[train_idx].softmax(1).max(1).values\n",
    "cur_preds2, cur_labels2 = multi_pred_to_binary(cur_preds, cur_labels, target_label=target_label)\n",
    "conf2 = cur_preds2[train_idx].max(1).values ## since it has already been \"softmax\"-ed."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "id": "9535736e-dee8-4824-9508-fea9dc104c51",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(4000)"
      ]
     },
     "execution_count": 172,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(conf == conf2).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "id": "b472827e-a30f-4229-a1e8-10be7e76b8f1",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_bins = 10\n",
    "n_bins_l1_umb = compute_bins(num_bins=n_bins, confidences=conf, method='quantile') ## for L1-ECE\n",
    "cur_bins = idx_bins(conf, n_bins_l1_umb)\n",
    "\n",
    "n_bins_l1_umb2 = compute_bins(num_bins=n_bins, confidences=conf2, method='quantile') ## for L1-ECE\n",
    "cur_bins2 = idx_bins(conf2, n_bins_l1_umb2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "id": "fe7affb7-e82f-4fd0-918f-6e942ddb9fd2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(4000)"
      ]
     },
     "execution_count": 182,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(cur_bins == cur_bins2).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 192,
   "id": "05444797-d40f-4d3c-bdf5-88ee6a7b0e6a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "softmax\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array(1.9223896e-07, dtype=float32)"
      ]
     },
     "execution_count": 192,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "compute_ece(preds=cur_preds, mask=cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 193,
   "id": "75cb9dcc-0c30-4a2b-bba0-a57e5aec7d55",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "softmax\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "array(0.00026906, dtype=float32)"
      ]
     },
     "execution_count": 193,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "compute_ece(preds=cur_preds2, mask=cur_mask, dataset=all_examples, n_bins=n_bins_l1_umb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 190,
   "id": "d0591799-883e-44e2-aa5e-4d0b2148af3b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(True)"
      ]
     },
     "execution_count": 190,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cur_preds.softmax(1).sum(1).sum() == len(cur_preds2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 203,
   "id": "8804d8e2-d9b3-49ae-8fe3-bda08129d1d9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([8000])"
      ]
     },
     "execution_count": 203,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(cur_preds2.sum(1) == 1).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 237,
   "id": "e1935ba7-e2a0-47ac-bc12-494e21d4caea",
   "metadata": {},
   "outputs": [],
   "source": [
    "#cur_preds, cur_labels, target_label=target_label\n",
    "idx = np.arange(0,len(torch.unique(cur_labels)))\n",
    "preds = cur_preds.softmax(1)\n",
    "#binary_preds = torch.zeros_like(preds)\n",
    "binary_preds = torch.zeros(len(preds), 2)\n",
    "binary_preds[:,0] = 1 - preds[:,idx==target_label].sum(1)\n",
    "#binary_preds[:,0] = preds[:,idx!=target_label].sum(1)\n",
    "binary_preds[:,1] = preds[:,idx==target_label].sum(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 242,
   "id": "6331a946-428a-46a0-8317-8d604e920495",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[1.0000e+00, 8.5624e-16],\n",
       "        [0.0000e+00, 1.0000e+00],\n",
       "        [1.0000e+00, 1.3592e-21],\n",
       "        ...,\n",
       "        [0.0000e+00, 1.0000e+00],\n",
       "        [1.0000e+00, 4.2622e-24],\n",
       "        [1.0000e+00, 6.3680e-12]])"
      ]
     },
     "execution_count": 242,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "binary_preds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "id": "7c3bafe0-e5dd-47c9-918d-e646f93ced1c",
   "metadata": {},
   "outputs": [],
   "source": [
    "predictions = np.random.rand(10, 3)  # 10サンプル×3ラベルの予測確率行列\n",
    "\n",
    "# 2値分類の予測確率行列の計算\n",
    "binary_predictions = np.zeros((predictions.shape[0], 2))\n",
    "binary_predictions[:, 0] = 1 - predictions[:, 1]  # 1列目には2列目以外の予測確率\n",
    "binary_predictions[:, 1] = predictions[:, 1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "id": "b2fc427f-79c0-49b0-b299-3d2b20a8d0e0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([8.5624e-16, 1.0000e+00, 1.3592e-21,  ..., 1.0000e+00, 4.2622e-24,\n",
       "        6.3680e-12])"
      ]
     },
     "execution_count": 236,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(preds[:,idx==target_label]).sum(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 372,
   "id": "8970f723-be72-42cd-88c8-c2778d63fec3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([   4,    6,    9,   15,   21,   44,   96,  210,  458, 1000])"
      ]
     },
     "execution_count": 372,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ns = [75, 250, 1000, 4000]\n",
    "opt_bin = np.floor((np.array(ns) ** (1/3))).astype(int)\n",
    "opt_bin\n",
    "start, end, num_candidates = max(opt_bin)+5, 10**3, (10 - len(opt_bin))\n",
    "int_candidates = np.ceil(np.logspace(np.log10(start), np.log10(end), num=num_candidates)).astype(int) ## bin candidates\n",
    "int_candidates = np.concatenate([opt_bin, int_candidates]).astype(int)\n",
    "int_candidates"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 402,
   "id": "a1048c7c-f30f-4a91-8773-5562b189fd9f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([   6,   11,   19,   34,   59,  103,  182,  321,  567, 1000])"
      ]
     },
     "execution_count": 402,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "start, end, num_candidates = 6, 10**3, 10\n",
    "int_candidates2 = np.ceil(np.logspace(np.log10(start), np.log10(end), num=num_candidates)).astype(int) ## bin candidates\n",
    "int_candidates2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 378,
   "id": "017571e8-d893-4734-9662-93f5d038bede",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x36c55b690>]"
      ]
     },
     "execution_count": 378,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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/N7zKhqGYfDMM8/wr3/9C5vNxlNPPcWAAQNqfR+73e6RovHDvc/V3oKT3PnaRnKPlhJss/Do9V24vVei1mO4UW3GQzxP4+FdNB7eReNxdvVSNBwOB+PGjWP16tWEhYUxffp0+vXrV9fbme6T3GPcsyiDE44aGkeF8o/h3bmgtX8saBURETFLnYpGWVkZI0aMICMjg9jYWObNm3fGx119gctlMPfTnUxfsx3DgO6JDfjH7T1oGh1mdjQRERGfV+uiUV1dzciRI8nIyCAxMZF//etfJCYmeiKbx5U6qrn/jU2s3noUgOG9Enns+i6EBNV6HzMRERE5g1oXjTlz5rBhwwYaN27MggULaNrUN49D33msjDtf+55d+ScJsVmZdFNXBl/Y0uxYIiIifqVWRaOoqIhXXnkFgEaNGvHMM8+c9b0TJ0702oPVVmcfYewbmyirrKF5TBj/uL0HaS0bmB1LRETE79SqaHz33XenH/HMyckhJyfnrO+9++67va5ouFwGz320ndkf7wSgV5tYXhjenbhI399cTERExBvVqmhcddVV5ObmeiqLR5VUVHPv4gw+yc0H4A+XtOahazsRbNN6DBEREU9x6xbk3ir3SCl3vvY9e4+XExpk5elbUhiYnvDrf1BERETOi98XjfeyDjPuzU2UVzlJaGhn3u096NoixuxYIiIiAcFvi0aN08Wza3byr6/2A9C7fRzPD02nYUSIyclEREQCh18WDUe1kxGvfM8XOwsA+Eufdozrn4zNqq3ERURE6pNfFo0vdhTwxc4CwoNtTBvUjeu6xZsdSUREJCD5ZdHonRTHpJu60r1FBJ1betcjtiIiIoHEL4tGWLCN2/+vlY51FxERMZk2kRARERGPUdEQERERj1HREBEREY9R0RARERGPUdEQERERj1HREBEREY9R0RARERGPUdEQERERj1HREBEREY9R0RARERGPUdEQERERj1HREBEREY9R0RARERGPMfX0VsMwAHA6nR65v9Pp9Ni9pfY0Ht5F4+FdNB7eRePxy374/+aH3+O/xNSi4XK5ANi8ebOZMURERKQOfvg9/kssxrnUEQ9xuVzU1NRgtVqxWCxmxRAREZFaMAwDl8tFUFAQVusvr8IwtWiIiIiIf9NiUBEREfEYFQ0RERHxGBUNERER8RgVDREREfEYFQ0RERHxGBUNERER8RgVDRER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479++Cez1atXk5ubS69evUxOGzj69OkDnDpb46eOHz9OdnY2ISEh+rmpB40aNaJBgwaUl5efcVOu0tJStmzZAkCnTp3qO57P85uiceutt2K325k/fz4bN248/fru3bt57rnnAE7v7iaeN2fOHDZs2EDjxo1ZsGCBDocS+YkhQ4YQHh7OypUrWbp06enXy8vLefjhhykvL2fgwIFaCFoPrFYrgwcPBuDRRx/90TqMsrIyHnzwQYqLi+nTp4/OBKoDvzpUbenSpTzyyCNYrVZ69epFSEgIX3/9NZWVldx///0/2uZXPKeoqIi+fftSUVFBx44df/Eph4kTJ+pgNRNdfvnlHDx4UIeqmWT16tWMHTuW6upqOnToQEJCAps3byY/P5+OHTuyYMECoqKizI4ZEKqqqhg5ciRff/01wcHB9OzZk6CgoNPrZNq2bctrr72mz6s68KuiAbBu3TpeeukltmzZgs1mo3379vzxj3/kqquuMjtawFi9ejV33333Ob9Xv+DMo6JhvtzcXObNm8f69espLS0lPj6eAQMGMGLECD0lV89qampYsmQJb7/9Njt37qSmpoaWLVvSv39//vSnPxEZGWl2RJ/kd0VDREREvIffrNEQERER76OiISIiIh6joiEiIiIeo6IhIiIiHqOiISIiIh6joiEiIiIeo6IhIiIiHqOiISIiIh6joiEiIiIeo6IhIiIiHqOiISIiIh6joiEiIiIeo6IhIiIiHvP/AMjYOS3GwwbBAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#plt.plot(np.log(int_candidates))\n",
    "plt.plot(np.log(int_candidates2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cd50a28f-7a6f-4787-afd4-d23a9101a7be",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
