{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "eb39fe7e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-02-01 12:10:43.718156: E tensorflow/compiler/xla/stream_executor/cuda/cuda_dnn.cc:9360] Unable to register cuDNN factory: Attempting to register factory for plugin cuDNN when one has already been registered\n",
      "2024-02-01 12:10:43.718220: E tensorflow/compiler/xla/stream_executor/cuda/cuda_fft.cc:609] Unable to register cuFFT factory: Attempting to register factory for plugin cuFFT when one has already been registered\n",
      "2024-02-01 12:10:43.718238: E tensorflow/compiler/xla/stream_executor/cuda/cuda_blas.cc:1537] Unable to register cuBLAS factory: Attempting to register factory for plugin cuBLAS when one has already been registered\n",
      "2024-02-01 12:10:43.725051: I tensorflow/core/platform/cpu_feature_guard.cc:183] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: SSE3 SSE4.1 SSE4.2 AVX, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import time\n",
    "import numpy as np\n",
    "import tensorflow as tf\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from src.datasets import load_dataset, preprocess_dataset, prefetch_dataset\n",
    "from src.utils import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "19fea9c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "cfg = { 'dataset' : 'stl10',\n",
    "        'model' : 'pretrained_inception',\n",
    "        'batch_size' : 512,\n",
    "        'optimizer' : 'Adam',\n",
    "        'learning_rate' : 0.001,\n",
    "        'max_epoch' : 300,\n",
    "        'patience' : 10,}    \n",
    "\n",
    "model_name = cfg['model']\n",
    "dataset_name = cfg['dataset']"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "69980cb5",
   "metadata": {},
   "source": [
    "### Softmax"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "be643c90",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-02-01 12:11:09.330763: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1883] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 78835 MB memory:  -> device: 0, name: NVIDIA A100-SXM4-80GB, pci bus id: 0000:0f:00.0, compute capability: 8.0\n",
      "2024-02-01 12:11:35.955092: I tensorflow/compiler/xla/stream_executor/cuda/cuda_dnn.cc:442] Loaded cuDNN version 8906\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ds_train, ds_val, ds_test, ds_info = load_dataset(cfg, shuffle=False)\n",
    "n_classes = ds_info.features['label'].num_classes\n",
    "ds_test = preprocess_dataset(ds_test, cfg, n_classes, resize=True, normalize=True, onehot=True)\n",
    "\n",
    "bin_counts = []\n",
    "bin_acc = []\n",
    "bin_conf = []\n",
    "avg_acc = []\n",
    "avg_conf = []\n",
    "gaps = []\n",
    "ece = []\n",
    "\n",
    "all_result = {}\n",
    "\n",
    "for run in range(5):\n",
    "    tf.keras.utils.set_random_seed(run+10) # set random seed for Python, NumPy, and TensorFlow\n",
    "#     print(f'Run: {run+1}')\n",
    "    model = tf.keras.models.load_model(f'../results/PI_Explainability/{model_name}_{dataset_name}/run_{run+1}/trained_model.keras')\n",
    "    preds = model.predict(ds_test.batch(cfg['batch_size']), verbose=0)\n",
    "    true_y = np.argmax([y for x,y in ds_test], axis=1)\n",
    "    pred_y = np.argmax(preds, axis=1)\n",
    "    true_label = np.equal(true_y, pred_y).astype(int) # assign 0 if true_y != pred_y, assign 1 if true_y == pred_y\n",
    "    softmax_val = np.max(preds, axis=1)\n",
    "    \n",
    "    result = reliability_diagram(softmax_val, true_y, pred_y, n_bins=10)\n",
    "    \n",
    "    bin_counts.append(result['bin_counts'])\n",
    "    bin_acc.append(result['bin_acc'])\n",
    "    bin_conf.append(result['bin_conf'])\n",
    "    avg_acc.append(result['avg_acc'])\n",
    "    avg_conf.append(result['avg_conf'])\n",
    "    gaps.append(result['gaps'])\n",
    "    ece.append(result['ece'])\n",
    "    \n",
    "all_result = {\n",
    "    'bins' : result['bins'],\n",
    "    'bin_size' : result['bin_size'],\n",
    "    'bin_counts' : np.mean(bin_counts, axis=0),\n",
    "    'bin_acc' : np.mean(bin_acc, axis=0),\n",
    "    'bin_conf' : np.mean(bin_conf, axis=0),\n",
    "    'avg_acc' : np.mean(avg_acc),\n",
    "    'avg_conf' : np.mean(avg_conf),\n",
    "    'gaps' : np.mean(gaps, axis=0),\n",
    "    'ece' : np.mean(ece)\n",
    "}\n",
    "\n",
    "plot_reliability_diagram(all_result, metric = 'Softmax')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0d8ffa22",
   "metadata": {},
   "source": [
    "### PMI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0eb9b337",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "critic = 'separable'\n",
    "estimator = 'density_ratio_fitting'\n",
    "\n",
    "ds_train, ds_val, ds_test, ds_info = load_dataset(cfg, shuffle=False)\n",
    "n_classes = ds_info.features['label'].num_classes\n",
    "ds_test = preprocess_dataset(ds_test, cfg, n_classes, resize=True, normalize=True, onehot=True)\n",
    "\n",
    "bin_counts = []\n",
    "bin_acc = []\n",
    "bin_conf = []\n",
    "avg_acc = []\n",
    "avg_conf = []\n",
    "gaps = []\n",
    "ece = []\n",
    "\n",
    "all_result = {}\n",
    "\n",
    "for run in range(5):\n",
    "    tf.keras.utils.set_random_seed(run+10) # set random seed for Python, NumPy, and TensorFlow\n",
    "    model = tf.keras.models.load_model(f'../results/PI_Explainability/{model_name}_{dataset_name}/run_{run+1}/trained_model.keras')\n",
    "    preds = model.predict(ds_test.batch(cfg['batch_size']), verbose=0)\n",
    "    true_y = np.argmax([y for x,y in ds_test], axis=1)\n",
    "    pred_y = np.argmax(preds, axis=1)\n",
    "    true_label = np.equal(true_y, pred_y).astype(int) # assign 0 if true_y != pred_y, assign 1 if true_y == pred_y\n",
    "    \n",
    "    exp_name = f'../results/PI_Explainability/{model_name}_{dataset_name}/run_{run+1}/calibration/pmi/{critic}_{estimator}'\n",
    "    pmi_class = np.load(f'{exp_name}/pmi_class_test.npy')\n",
    "    pmi_class = np.array([softmax(x) for x in pmi_class])\n",
    "    pmi = np.array([pmi_value[pred_value] for pmi_value, pred_value in zip(pmi_class, pred_y)])\n",
    "    \n",
    "    result = reliability_diagram(pmi, true_y, pred_y, n_bins=10)\n",
    "    \n",
    "    bin_counts.append(result['bin_counts'])\n",
    "    bin_acc.append(result['bin_acc'])\n",
    "    bin_conf.append(result['bin_conf'])\n",
    "    avg_acc.append(result['avg_acc'])\n",
    "    avg_conf.append(result['avg_conf'])\n",
    "    gaps.append(result['gaps'])\n",
    "    ece.append(result['ece'])\n",
    "    \n",
    "all_result = {\n",
    "    'bins' : result['bins'],\n",
    "    'bin_size' : result['bin_size'],\n",
    "    'bin_counts' : np.mean(bin_counts, axis=0),\n",
    "    'bin_acc' : np.mean(bin_acc, axis=0),\n",
    "    'bin_conf' : np.mean(bin_conf, axis=0),\n",
    "    'avg_acc' : np.mean(avg_acc),\n",
    "    'avg_conf' : np.mean(avg_conf),\n",
    "    'gaps' : np.mean(gaps, axis=0),\n",
    "    'ece' : np.mean(ece)\n",
    "}\n",
    "\n",
    "plot_reliability_diagram(all_result, metric='PMI')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5748adba",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
