{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d1dbfa03",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pickle\n",
    "import matplotlib.pyplot as plt\n",
    "import tensorflow as tf\n",
    "\n",
    "from src.datasets import load_dataset, preprocess_dataset, prefetch_dataset\n",
    "from src.smi_estimator import compute_smi\n",
    "from src.psi_estimators import psi_bin_train, psi_bin_val, psi_gaussian_train, psi_gaussian_val\n",
    "from src.utils import *\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "67f03f63",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-07-26 14:10:48.348802: I tensorflow/core/common_runtime/gpu/gpu_device.cc:1926] Created device /job:localhost/replica:0/task:0/device:GPU:0 with 78833 MB memory:  -> device: 0, name: NVIDIA A100-SXM4-80GB, pci bus id: 0000:47:00.0, compute capability: 8.0\n"
     ]
    }
   ],
   "source": [
    "cfg = { 'dataset' : 'mnist',\n",
    "        'model' : 'mlp',\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']\n",
    "\n",
    "run = 0\n",
    "\n",
    "ds_train, ds_val, ds_test, ds_info = load_dataset(cfg)\n",
    "n_classes = ds_info.features['label'].num_classes\n",
    "ds_train = preprocess_dataset(ds_train, cfg, n_classes, resize=False, normalize=True, onehot=True)\n",
    "ds_val = preprocess_dataset(ds_val, cfg, n_classes, resize=False, normalize=True, onehot=True)\n",
    "ds_test = preprocess_dataset(ds_test, cfg, n_classes, resize=False, normalize=True, onehot=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac8704bb",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run: 1\n",
      "Epoch 001/100:\n",
      "SMI (KSG): 0.524\n",
      "SMI (PSI bin): 0.521\n",
      "SMI (PSI Gauss): 0.550\n",
      "Epoch 006/100:\n",
      "SMI (KSG): 0.645\n",
      "SMI (PSI bin): 0.652\n",
      "SMI (PSI Gauss): 0.695\n",
      "Epoch 011/100:\n",
      "SMI (KSG): 0.665\n",
      "SMI (PSI bin): 0.657\n",
      "SMI (PSI Gauss): 0.718\n",
      "Epoch 016/100:\n",
      "SMI (KSG): 0.693\n",
      "SMI (PSI bin): 0.680\n",
      "SMI (PSI Gauss): 0.752\n",
      "Epoch 021/100:\n",
      "SMI (KSG): 0.716\n",
      "SMI (PSI bin): 0.693\n",
      "SMI (PSI Gauss): 0.780\n",
      "Epoch 026/100:\n",
      "SMI (KSG): 0.698\n",
      "SMI (PSI bin): 0.689\n",
      "SMI (PSI Gauss): 0.741\n",
      "Epoch 031/100:\n",
      "SMI (KSG): 0.718\n",
      "SMI (PSI bin): 0.716\n",
      "SMI (PSI Gauss): 0.786\n",
      "Epoch 036/100:\n",
      "SMI (KSG): 0.749\n",
      "SMI (PSI bin): 0.741\n",
      "SMI (PSI Gauss): 0.819\n",
      "Epoch 041/100:\n",
      "SMI (KSG): 0.713\n",
      "SMI (PSI bin): 0.707\n",
      "SMI (PSI Gauss): 0.783\n",
      "Epoch 046/100:\n",
      "SMI (KSG): 0.738\n",
      "SMI (PSI bin): 0.729\n",
      "SMI (PSI Gauss): 0.797\n",
      "Epoch 051/100:\n",
      "SMI (KSG): 0.734\n",
      "SMI (PSI bin): 0.742\n",
      "SMI (PSI Gauss): 0.810\n",
      "Epoch 056/100:\n",
      "SMI (KSG): 0.741\n",
      "SMI (PSI bin): 0.733\n",
      "SMI (PSI Gauss): 0.806\n",
      "Epoch 061/100:\n",
      "SMI (KSG): 0.773\n",
      "SMI (PSI bin): 0.733\n",
      "SMI (PSI Gauss): 0.821\n",
      "Epoch 066/100:\n",
      "SMI (KSG): 0.759\n",
      "SMI (PSI bin): 0.734\n",
      "SMI (PSI Gauss): 0.816\n",
      "Epoch 071/100:\n",
      "SMI (KSG): 0.771\n",
      "SMI (PSI bin): 0.761\n",
      "SMI (PSI Gauss): 0.837\n",
      "Epoch 076/100:\n",
      "SMI (KSG): 0.766\n",
      "SMI (PSI bin): 0.744\n",
      "SMI (PSI Gauss): 0.838\n",
      "Epoch 081/100:\n",
      "SMI (KSG): 0.761\n",
      "SMI (PSI bin): 0.729\n",
      "SMI (PSI Gauss): 0.833\n",
      "Epoch 086/100:\n",
      "SMI (KSG): 0.763\n",
      "SMI (PSI bin): 0.742\n",
      "SMI (PSI Gauss): 0.841\n",
      "Epoch 091/100:\n",
      "SMI (KSG): 0.773\n",
      "SMI (PSI bin): 0.766\n",
      "SMI (PSI Gauss): 0.867\n",
      "Epoch 096/100:\n",
      "SMI (KSG): 0.763\n",
      "SMI (PSI bin): 0.739\n",
      "SMI (PSI Gauss): 0.819\n",
      "Run: 2\n",
      "Epoch 001/100:\n",
      "SMI (KSG): 0.523\n",
      "SMI (PSI bin): 0.528\n",
      "SMI (PSI Gauss): 0.556\n",
      "Epoch 006/100:\n",
      "SMI (KSG): 0.644\n"
     ]
    }
   ],
   "source": [
    "all_smi_list_1 = []\n",
    "all_smi_list_2 = []\n",
    "all_smi_list_3 = []\n",
    "for run in range(5):\n",
    "    print(f'Run: {run+1}')\n",
    "    smi_list_1 = []\n",
    "    smi_list_2 = []\n",
    "    smi_list_3 = []\n",
    "    for epoch in range (1,100,5):\n",
    "        print(f'Epoch {epoch:03}/100:')\n",
    "        model = tf.keras.models.load_model(f'../results/PI_Explainability/{model_name}_{dataset_name}/run_{run+1}/saved_models/epoch_{epoch:03}.keras')\n",
    "        int_model = tf.keras.Model(inputs=model.inputs, outputs=model.layers[-2].output)\n",
    "        \n",
    "        ds_activity = ds_val.batch(cfg['batch_size']).map(lambda x, y: (int_model(x), y)).unbatch()\n",
    "        x, y = zip(*ds_activity)\n",
    "        x_val = np.array([val.numpy() for val in x])\n",
    "        y_val = np.array([val.numpy() for val in y])\n",
    "        y_val = np.argmax(y_val, axis=1)\n",
    "        pred_y_val = np.argmax(model.predict(ds_val.batch(cfg['batch_size']), verbose=0), axis=1)\n",
    "        \n",
    "        smi_list_1.append(compute_smi(x_val, np.expand_dims(y_val,1), proj_x=True, proj_y=False, n_projs=500, method='ksg_cd'))\n",
    "        print(f'SMI (KSG): {smi_list_1[-1]:.3f}')\n",
    "        \n",
    "        psi_bin_data = psi_bin_train(x_val, y_val, n_projs=500, n_bins=20)\n",
    "        psi, pmi_arr = psi_bin_val(x_val, psi_bin_data)\n",
    "        smi_list_2.append(np.mean(psi))\n",
    "        print(f'SMI (PSI bin): {smi_list_2[-1]:.3f}')\n",
    "        \n",
    "        psi_bin_data = psi_gaussian_train(x_val, y_val, n_projs=500)\n",
    "        psi, pmi_arr = psi_gaussian_val(x_val, psi_bin_data)\n",
    "        smi_list_3.append(np.mean(psi))\n",
    "        print(f'SMI (PSI Gauss): {smi_list_3[-1]:.3f}')\n",
    "        \n",
    "    all_smi_list_1.append(smi_list_1)\n",
    "    all_smi_list_2.append(smi_list_2)\n",
    "    all_smi_list_3.append(smi_list_3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "e63e9569",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Fi1axOLFi/nuu+8YN24cs2bNCgY4OxOv18vMmTMpLi7mH//4B/n5+bz55pukpqZ2uc6eRFEUjtnU4fiouFEotjJilGaDvFghL+h+Ro4cicPhaPXY/fffz/r167nxxhuJjo7uUv0TJkwgLy+vhYG8mXvuuYd33nmHxx57jN/97nft1hUdHU1ycnKwvXfccQf5+fl8/PHHHWrL/v370ev1jBol3O/7in415fXKK6+wYMEC7rvvPkD1b//ss89Yvnw5TzzxRIvyy5cvp66ujk2bNqHX6wFaGOM6W2dPUumsxOl3okHDoMhB1O76lDhOGuSzhEFe0HVqa2u59dZbuf/++xk7dizh4eHs2LGDl19+mRtvvLHVc0aMGEFNTc05xSybPn06drudAwcOMHr06FbLzJ8/H41Gwz333IOiKPz85z/n//2//8fu3bu5+eabycnJwe128+c//5kDBw7w+9//HoDbb7+dDz/8kNtvv50nn3ySWbNmkZiYyLFjx1i5cmWLYIcbN27ksssuC059CXqffjNC8Xq97Ny5kxkzZgT3aTQaZsyYwebNm1s955NPPmHq1Kk89NBDJCYmMnr0aF566aWgH3tX6uxJmnPIJ4UlYdAaqD20EYAi3SCMut5NhCMYWFitVnJzc3n11Ve5/PLLGT16NM8++ywLFizgD3/4Q5vnxcbGntMNODY2lptvvpl333233XLz5s3jL3/5C08++SS/+c1vmDx5Mna7nR//+MeMGjWKK664gi1btvDRRx8F3Z4lSWLlypUsXbqUVatWcfXVVzNs2DDuv/9+0tPT+eabb0Ku8cEHH7BgwYIu90Vw7vSbEUpNTQ2BQIDExNBYVomJieTl5bV6TmFhIV999RXz5s1j1apVHD16lJ/85Cf4fD4WL17cpToBPB4PHo8n+LrZ88Tn8501aufp2f3OZE/VHgAGRQxSj5err+siRvRaNNDupL2+ns/4fD4URUGWZWRZDu5vntZpPtaf0Ov1/OpXv+JXv/pVq8eb29u8kryt9jfbIZr7WlBQEMwF0xbNo4cnn3wSq9UKEPxTd/p5t912G7fddlvw9YoVK9ptazMLFixoUyiay37++edoNBq+973vdfqz6c+f67kiyzKKouDz+YIjup783fYbQekKsiyTkJDA//3f/6HVapk4cSKlpaX89re/bdUQ2VGWLFnCCy+80GL/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N2/m3nvvZdq0acycOTNYZvLkyWzcuLHDfehp+p2g3HbbbVRXV/Pcc89RUVHB+PHjWb16ddBQf/z48ZBhaX19PQsWLKCiooLo6GgmTpzIpk2bgrmhtVote/fuZcWKFTQ0NJCSksI111zDL3/5y15ZixLWeHJ9TMpFPX4twYWLTqfjnXfeYcGCBSxbtoyLLrqIK664gttvvz0kf3oz999/P//zP//D008/zT/+8Q9ycnIYP358p6977Nixs07nOJ1OnnnmGbRaLVdccUWn29oa1dXVNDQ0MGzYsJD9EydODK5Jmzt3bvCf//333x8sM2jQIF577TUuvvhi7HZ7hx1tjh8/zs9//nOGD1fzGQ0ZMiTk2C233MKYMWOC12iL1NRUfvaznwVf//d//zdffPEFf/vb30IEZezYsSxevDh4rT/84Q+sXbs2RFBSUlI4duxYh9rfG/Q7QQFYuHAhCxcubPXYunXrQl6/+uqrvPrqq23WZTab+eKLL7qzeR3HWUe0vwaAuKEiZP35jFlnZvPtm2lqaiI8PLzXbChmXcfXLd1yyy3MmTOHjRs3smXLFj7//HNefvll/vSnP7WIBjxnzhx+9KMfsWHDBpYvXx5yw+0MLperRWSKZu64445gOt74+HjeeuutoGB0pq2d4V//+hder5fHH388JA3wzp07ef7559mzZw/19fVBu8nx48eDAnE2Fi1axAMPPMBf/vIXZsyYwa233kpOTg4AP/3pT3nwwQf58ssvmTFjBrfcckub4hgIBHjppZf429/+RmlpKV6vF4/H00LYzjw/OTk5ZJoO1Pub0+nsUPt7g35lQxloyCczNBbJiQwXIevPayRJwqK3YNaZsegtvbZ1NpCoyWRi5syZPPvss2zatIl77703+C/3dHQ6HfPnz2fx4sVs3bqVefPmdel9iYuLo76+vtVjr776Krt376aiooKKigruueeeLrW1NeLj44mKigqJkAGQkZHB4MGDQ6bgHA4Hs2bNIiIignfffZft27fzr3/9CyDoFq7RaFrYq85cp/H8889z4MAB5syZw1dffcXIkSOD9TzwwAMUFhYyf/589u3bx6RJk/j973/fatt/+9vf8r//+788/vjjfP311+zevZtZs2a1cFE/02guSVKLdTJ1dXXEx8e3+171JkJQepD6o2oMsoNkkxPf+nyqQNCTjBw5EofD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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "mean_1, ci_1 = calculate_confidence_interval(np.array(all_smi_list_1))\n",
    "mean_2, ci_2 = calculate_confidence_interval(np.array(all_smi_list_2))\n",
    "mean_3, ci_3 = calculate_confidence_interval(np.array(all_smi_list_3))\n",
    "\n",
    "plt.figure(figsize=(4,3), dpi=100)\n",
    "plt.plot(range(1, 100, 5), mean_1, label='SMI (KSG)')\n",
    "plt.fill_between(range(1, 100, 5), mean_1 - ci_1, mean_1 + ci_1, alpha=0.5)\n",
    "plt.plot(range(1, 100, 5), mean_2, label='SMI (PSI Bin)')\n",
    "plt.fill_between(range(1, 100, 5), mean_2 - ci_2, mean_2 + ci_2, alpha=0.5)\n",
    "plt.plot(range(1, 100, 5), mean_3, label='SMI (PSI Gaussian)')\n",
    "plt.fill_between(range(1, 100, 5), mean_3 - ci_3, mean_3 + ci_3, alpha=0.5)\n",
    "plt.xlabel('Epoch', fontsize=12)\n",
    "plt.ylabel('SI(T;Y)', fontsize=12)\n",
    "plt.grid(True)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "048fab98",
   "metadata": {},
   "outputs": [],
   "source": [
    "results = {}\n",
    "results['smi_ksg'] = np.array(all_smi_list_1)\n",
    "results['smi_bin'] = np.array(all_smi_list_2)\n",
    "results['smi_gauss'] = np.array(all_smi_list_2)\n",
    "\n",
    "with open(f'../results/PI_Explainability/{model_name}_{dataset_name}/psi_sanity_check.pkl', 'wb') as f:\n",
    "    pickle.dump(results, f)"
   ]
  }
 ],
 "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
}
