{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Python Path non-sense\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import sys\n",
    "import os\n",
    "\n",
    "sys.path = [x for x in sys.path if 'bayes_gsl' not in x]\n",
    "new_path = '/Users/maxw/projects/gsl-bnn/' ## change this to the path of the src directory!\n",
    "if new_path not in sys.path:\n",
    "    sys.path.append(new_path)\n",
    "    \n",
    "# Now try importing your module using the absolute path as a check\n",
    "from src.models import dpg_bnn\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "\"\"\"\n",
    "    Compare all models on NLL, BS, Error, ECE.\n",
    "    Plot the calibration curves and the distribution of probabilities within each bin.\n",
    "\n",
    "\"\"\"\n",
    "import os\n",
    "import pickle\n",
    "import arviz\n",
    "import matplotlib.pyplot as plt\n",
    "import numpyro.infer\n",
    "import seaborn as sns\n",
    "from sklearn.calibration import calibration_curve\n",
    "import numpy as np\n",
    "\n",
    "import jax.numpy as jnp\n",
    "import jax\n",
    "\n",
    "\n",
    "from src import TMLR_TEXTWIDTH, TMLR_PLOT_DEPTH, FIGURES_PATH\n",
    "\n",
    "from src.models import dpg_bnn, dpg_mimo_bnn, dpg_mimo_stochastic_head, pds_bnn\n",
    "#from src.data import load_data\n",
    "from src.metrics import compute_metrics\n",
    "\n",
    "from src.config import num_samples_to_generate, w_init_scale, lam_init_scale, altered_prior\n",
    "from experiments.iid_generalization.config import dpg_hyperparameters, pds_hyperparameters, dpg_mimo_hyperparameters, dpg_mimo_e_hyperparameters, experiment_settings\n",
    "from src import NUM_BINS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from experiments.iid_generalization.config import dpg_hyperparameters, pds_hyperparameters, dpg_mimo_hyperparameters, dpg_mimo_e_hyperparameters, experiment_settings\n",
    "models = {\n",
    "        'DPG': (dpg_bnn, dpg_hyperparameters, f\"dpg_D={dpg_hyperparameters['depth']}.pkl\"),\n",
    "        'PDS': (pds_bnn, pds_hyperparameters, f\"pds_D={dpg_hyperparameters['depth']}.pkl\"),\n",
    "        'DPG-MIMO': (dpg_mimo_bnn, dpg_mimo_hyperparameters, f\"dpg_mimo_D={dpg_mimo_hyperparameters['depth']}_C={dpg_mimo_hyperparameters['num_channels']}.pkl\"),\n",
    "        'DPG-MIMO-E': (dpg_mimo_stochastic_head, dpg_mimo_e_hyperparameters, f\"dpg_mimo_e_D={dpg_mimo_e_hyperparameters['mimo_base']['depth']}_C={dpg_mimo_e_hyperparameters['mimo_base']['num_channels']}_stoch_head_C={dpg_mimo_e_hyperparameters['num_stochastic_channels']}_D={dpg_mimo_e_hyperparameters['stochastic_head_depth']}.pkl\")\n",
    "    }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of CPU cores: 1\n",
      "DPG\n",
      "expected\n",
      "Test Error: 0.01573682 \\pm 0.01008262\n",
      "Test NLL: 10.333 \\pm 5.378\n",
      "Test BS: 0.01286086 \\pm 0.00716473\n",
      "Test ECE:0.00341998\n",
      "\n",
      "10\n",
      "Test Error: 0.13584214 \\pm 0.05149131\n",
      "Test NLL: 132.161 \\pm 49.024\n",
      "Test BS: 0.12377965 \\pm 0.04657596\n",
      "Test ECE:0.11222789\n",
      "\n",
      "20\n",
      "Test Error: 0.09515780 \\pm 0.04152015\n",
      "Test NLL: 78.087 \\pm 34.818\n",
      "Test BS: 0.08350260 \\pm 0.03659543\n",
      "Test ECE:0.07142366\n",
      "\n",
      "100\n",
      "Test Error: 0.03599995 \\pm 0.01675503\n",
      "Test NLL: 22.087 \\pm 9.398\n",
      "Test BS: 0.02892044 \\pm 0.01254435\n",
      "Test ECE:0.01646109\n",
      "\n",
      "1000\n",
      "Test Error: 0.01805252 \\pm 0.01134341\n",
      "Test NLL: 11.277 \\pm 5.571\n",
      "Test BS: 0.01429300 \\pm 0.00769689\n",
      "Test ECE:0.00375998\n",
      "\n",
      "10000\n",
      "Test Error: 0.01599991 \\pm 0.01052421\n",
      "Test NLL: 10.458 \\pm 5.478\n",
      "Test BS: 0.01303431 \\pm 0.00735640\n",
      "Test ECE:0.00329874\n",
      "\n",
      "PDS\n",
      "expected\n",
      "Test Error: 0.01589471 \\pm 0.01025924\n",
      "Test NLL: 10.317 \\pm 5.391\n",
      "Test BS: 0.01285023 \\pm 0.00717723\n",
      "Test ECE:0.00374968\n",
      "\n",
      "10\n",
      "Test Error: 0.13578951 \\pm 0.05164335\n",
      "Test NLL: 132.389 \\pm 49.210\n",
      "Test BS: 0.12369286 \\pm 0.04655752\n",
      "Test ECE:0.11232916\n",
      "\n",
      "20\n",
      "Test Error: 0.09536839 \\pm 0.04148410\n",
      "Test NLL: 78.072 \\pm 34.881\n",
      "Test BS: 0.08340914 \\pm 0.03656698\n",
      "Test ECE:0.07162641\n",
      "\n",
      "100\n",
      "Test Error: 0.03605258 \\pm 0.01673278\n",
      "Test NLL: 22.025 \\pm 9.375\n",
      "Test BS: 0.02888292 \\pm 0.01251042\n",
      "Test ECE:0.01645188\n",
      "\n",
      "1000\n",
      "Test Error: 0.01799989 \\pm 0.01134158\n",
      "Test NLL: 11.256 \\pm 5.574\n",
      "Test BS: 0.01428124 \\pm 0.00770221\n",
      "Test ECE:0.00359901\n",
      "\n",
      "10000\n",
      "Test Error: 0.01599991 \\pm 0.01057672\n",
      "Test NLL: 10.440 \\pm 5.490\n",
      "Test BS: 0.01302383 \\pm 0.00736769\n",
      "Test ECE:0.00311214\n",
      "\n",
      "DPG-MIMO\n",
      "expected\n",
      "Test Error: 0.01415789 \\pm 0.00940604\n",
      "Test NLL: 9.191 \\pm 5.155\n",
      "Test BS: 0.01188410 \\pm 0.00664590\n",
      "Test ECE:0.00350250\n",
      "\n",
      "10\n",
      "Test Error: 0.13689476 \\pm 0.05249189\n",
      "Test NLL: 191.648 \\pm 82.783\n",
      "Test BS: 0.12329419 \\pm 0.04634406\n",
      "Test ECE:0.11189530\n",
      "\n",
      "20\n",
      "Test Error: 0.09700000 \\pm 0.04222519\n",
      "Test NLL: 110.271 \\pm 57.830\n",
      "Test BS: 0.08419283 \\pm 0.03672949\n",
      "Test ECE:0.07407020\n",
      "\n",
      "100\n",
      "Test Error: 0.03678942 \\pm 0.01732043\n",
      "Test NLL: 24.180 \\pm 11.977\n",
      "Test BS: 0.02924340 \\pm 0.01258687\n",
      "Test ECE:0.01748522\n",
      "\n",
      "1000\n",
      "Test Error: 0.01684207 \\pm 0.00956100\n",
      "Test NLL: 10.334 \\pm 5.541\n",
      "Test BS: 0.01344271 \\pm 0.00695085\n",
      "Test ECE:0.00389153\n",
      "\n",
      "10000\n",
      "Test Error: 0.01463151 \\pm 0.00937315\n",
      "Test NLL: 9.360 \\pm 5.316\n",
      "Test BS: 0.01210054 \\pm 0.00671386\n",
      "Test ECE:0.00347660\n",
      "\n",
      "DPG-MIMO-E\n",
      "expected\n",
      "Test Error: 0.01289469 \\pm 0.00823394\n",
      "Test NLL: 8.354 \\pm 4.738\n",
      "Test BS: 0.01065306 \\pm 0.00604091\n",
      "Test ECE:0.00240069\n",
      "\n",
      "10\n",
      "Test Error: 0.13931584 \\pm 0.05279687\n",
      "Test NLL: 191.754 \\pm 80.984\n",
      "Test BS: 0.12600273 \\pm 0.04745768\n",
      "Test ECE:0.11624993\n",
      "\n",
      "20\n",
      "Test Error: 0.09799999 \\pm 0.04213670\n",
      "Test NLL: 109.861 \\pm 56.174\n",
      "Test BS: 0.08539225 \\pm 0.03688290\n",
      "Test ECE:0.07584728\n",
      "\n",
      "100\n",
      "Test Error: 0.03557897 \\pm 0.01742606\n",
      "Test NLL: 24.126 \\pm 12.557\n",
      "Test BS: 0.02886158 \\pm 0.01363468\n",
      "Test ECE:0.01768863\n",
      "\n",
      "1000\n",
      "Test Error: 0.01510525 \\pm 0.00913594\n",
      "Test NLL: 9.575 \\pm 5.205\n",
      "Test BS: 0.01237822 \\pm 0.00651512\n",
      "Test ECE:0.00308210\n",
      "\n",
      "10000\n",
      "Test Error: 0.01310527 \\pm 0.00820429\n",
      "Test NLL: 8.543 \\pm 4.905\n",
      "Test BS: 0.01088753 \\pm 0.00606743\n",
      "Test ECE:0.00248101\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# load the results from dictionary\n",
    "from experiments.covariate_shift.run import PATH2COVARIATE_SHIFT_RESULTS, display_metrics\n",
    "covariate_shift_metrics_file = os.path.join(PATH2COVARIATE_SHIFT_RESULTS, 'covariate_shift_metrics.pkl')\n",
    "\n",
    "# ensure the file exists, if not warn user\n",
    "if not os.path.exists(covariate_shift_metrics_file):\n",
    "    print(f\"The file {covariate_shift_metrics_file} does not exist. Please run the covariate shift experiment first.\")\n",
    "\n",
    "with open(covariate_shift_metrics_file, 'rb') as f:\n",
    "    model_metrics_dicts = pickle.load(f)\n",
    "\n",
    "for model_name, num_signals_to_metrics_dict in model_metrics_dicts.items():\n",
    "    print(model_name)\n",
    "    for num_signals, metrics_dict in num_signals_to_metrics_dict.items():\n",
    "        print(num_signals)\n",
    "        display_metrics(metrics_dict)\n",
    "        print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def list2str(l):\n",
    "    return [\"{:.3f}\".format(x) for x in l]\n",
    "\n",
    "def print_metrics(dict, name, num_signals):\n",
    "    print(f\"{name} metrics:\")\n",
    "    print('\\tNLL: ', list2str([-1 * dict[num_signal]['log_likelihoods'].mean()._value for num_signal in num_signals]))\n",
    "    print('\\tBS: ', list2str([dict[num_signal]['brier_scores'].mean()._value for num_signal in num_signals]))\n",
    "    print('\\tError: ', list2str([1 - dict[num_signal]['accuracies'].mean()._value for num_signal in num_signals]))\n",
    "    print('\\tECE: ', list2str([dict[num_signal]['calibration_dict']['ece'] for num_signal in num_signals]))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['expected', '10000', '1000', '100', '20', '10']\n",
      "DPG metrics:\n",
      "\tNLL:  ['10.333', '10.458', '11.277', '22.087', '78.087', '132.161']\n",
      "\tBS:  ['0.013', '0.013', '0.014', '0.029', '0.084', '0.124']\n",
      "\tError:  ['0.016', '0.016', '0.018', '0.036', '0.095', '0.136']\n",
      "\tECE:  ['0.003', '0.003', '0.004', '0.016', '0.071', '0.112']\n",
      "PDS metrics:\n",
      "\tNLL:  ['10.317', '10.440', '11.256', '22.025', '78.072', '132.389']\n",
      "\tBS:  ['0.013', '0.013', '0.014', '0.029', '0.083', '0.124']\n",
      "\tError:  ['0.016', '0.016', '0.018', '0.036', '0.095', '0.136']\n",
      "\tECE:  ['0.004', '0.003', '0.004', '0.016', '0.072', '0.112']\n",
      "DPG-MIMO metrics:\n",
      "\tNLL:  ['9.191', '9.360', '10.334', '24.180', '110.271', '191.648']\n",
      "\tBS:  ['0.012', '0.012', '0.013', '0.029', '0.084', '0.123']\n",
      "\tError:  ['0.014', '0.015', '0.017', '0.037', '0.097', '0.137']\n",
      "\tECE:  ['0.004', '0.003', '0.004', '0.017', '0.074', '0.112']\n",
      "DPG-MIMO-E metrics:\n",
      "\tNLL:  ['8.354', '8.543', '9.575', '24.126', '109.861', '191.754']\n",
      "\tBS:  ['0.011', '0.011', '0.012', '0.029', '0.085', '0.126']\n",
      "\tError:  ['0.013', '0.013', '0.015', '0.036', '0.098', '0.139']\n",
      "\tECE:  ['0.002', '0.002', '0.003', '0.018', '0.076', '0.116']\n"
     ]
    }
   ],
   "source": [
    "num_signals = list(model_metrics_dicts['DPG'].keys())\n",
    "# 'expected' should be first, then the tail should be in decreasing order\n",
    "num_signals = ['expected'] + [str(x) for x in sorted([int(x) for x in num_signals if x != 'expected'], reverse=True)]\n",
    "# replace 'expected' with inf\n",
    "#num_signals = [np.inf if x == 'expected' else float(x) for x in num_signals]\n",
    "# ensure sorted in decreasing order\n",
    "#num_signals = sorted(num_signals, reverse=True)\n",
    "print(num_signals)\n",
    "\n",
    "for model_name, num_signals_to_metrics_dict in model_metrics_dicts.items():\n",
    "    print_metrics(num_signals_to_metrics_dict, model_name, num_signals)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array(-10.332913, dtype=float32)"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model_metrics_dicts['DPG']['expected']['log_likelihoods'].mean()._value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['10', '20', '100', '1000', '10000']"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "num_signals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "# remove 'expected' from num_signals and then sort in increasing order (cast to int)\n",
    "num_signals = [str(x) for x in num_signals if x != 'expected']\n",
    "num_signals = sorted(num_signals, key=lambda x: int(x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 650.127x175 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "colors = {'DPG': '#1f77b4', 'PDS': '#ff7f0e', \n",
    "          'DPG-MIMO': 'red',\n",
    "          'DPG-MIMO-E': '#2ca02c'}\n",
    "\n",
    "num_plots = 4\n",
    "tick_fontsize = 6\n",
    "label_fontsize = 10\n",
    "alpha, markersize = 0.5, 4\n",
    "fig, axes = plt.subplots(1, num_plots, figsize=(TMLR_TEXTWIDTH, TMLR_PLOT_DEPTH))\n",
    "nll_ax, bs_ax, err_ax, ece_ax = axes\n",
    "stdv_scale = 1\n",
    "\n",
    "for ax, title in zip(axes, ['NLL', 'BS', 'Error', 'ECE']):\n",
    "    ax.set_xscale('log')\n",
    "    ax.set_yscale('log')\n",
    "    #ax.title.set_text(title)\n",
    "    ax.set_title(title, y=.97)\n",
    "    ax.tick_params(axis='both', which='both', direction='in', pad=2, labelsize=tick_fontsize)\n",
    "    ax.set_xlabel('P', fontsize=label_fontsize, labelpad=-5)\n",
    "    ax.set_xlim([5, 20000])\n",
    "    ax.set_xticks([10, 100, 1000, 10000])\n",
    "    ax.set_xticklabels([r'$10^1$', r'$10^2$', r'$10^3$', r'$10^4$'], fontsize=tick_fontsize)\n",
    "    # set size of y tick labels\n",
    "\n",
    "\n",
    "\n",
    "\"\"\" NLL \"\"\"\n",
    "for name in model_metrics_dicts.keys():\n",
    "    nll_ax.errorbar(\n",
    "        [int(x) for x in num_signals],\n",
    "        [-1 * model_metrics_dicts[name][num_signal]['log_likelihoods'].mean()._value for num_signal in num_signals],\n",
    "        yerr=[stdv_scale * model_metrics_dicts[name][num_signal]['log_likelihoods'].std()._value for num_signal in num_signals],\n",
    "        label=name,\n",
    "        color = colors[name],\n",
    "        alpha=alpha,\n",
    "        markersize=markersize,\n",
    "        marker='o') #markersize=2, linewidth=0.5)\n",
    "nll_ax.set_ylim([6, 220])\n",
    "#nll_ax.set_yticks([10, 15, 20, 25])\n",
    "# clear all yticklabels and set manually\n",
    "#nll_ax.set_yticklabels([10, 15, 20, 25], fontsize=tick_fontsize)\n",
    "\n",
    "# Brier Score\n",
    "for name in model_metrics_dicts.keys():\n",
    "    bs_ax.errorbar(\n",
    "        [int(x) for x in num_signals],\n",
    "        [model_metrics_dicts[name][num_signal]['brier_scores'].mean()._value for num_signal in num_signals],\n",
    "        yerr=[stdv_scale * model_metrics_dicts[name][num_signal]['brier_scores'].std()._value for num_signal in num_signals],\n",
    "        label=name,\n",
    "        color = colors[name],\n",
    "        alpha=alpha,\n",
    "        markersize=markersize,\n",
    "        marker='o') #markersize=2, linewidth=0.5)\n",
    "bs_ax.set_ylim([0.005, 0.2])\n",
    "#bs_ax.set_yticks([0.1, 0.2, 0.3, 0.4])\n",
    "#bs_ax.set_yticklabels(['.1', '.2', '.3', '.4'], fontsize=tick_fontsize)\n",
    "#bs_ax.legend(loc='upper right', fontsize=label_fontsize-3)\n",
    "\n",
    "# Error\n",
    "for name in model_metrics_dicts.keys():\n",
    "    err_ax.errorbar(\n",
    "        [int(x) for x in num_signals],\n",
    "        [1 - model_metrics_dicts[name][num_signal]['accuracies'].mean() for num_signal in num_signals],\n",
    "        yerr=[stdv_scale * model_metrics_dicts[name][num_signal]['accuracies'].std() for num_signal in num_signals],\n",
    "        label=name,\n",
    "        color = colors[name],\n",
    "        alpha=alpha,\n",
    "        markersize=markersize,\n",
    "        marker='o') #markersize=2, linewidth=0.5)\n",
    "err_ax.set_ylim([0.005, 0.2])\n",
    "#err_ax.set_yticks([0.01, 0.1, 0.2])\n",
    "#err_ax.set_yticklabels(['.01', '.1', '.2'], fontsize=tick_fontsize)\n",
    "\n",
    "# ECE\n",
    "for name in model_metrics_dicts.keys(): #['dpg', 'pds', 'mimo', 'partial_stoch']:\n",
    "    ece_ax.errorbar(\n",
    "        [int(x) for x in num_signals],\n",
    "        [model_metrics_dicts[name][num_signal]['calibration_dict']['ece'].mean() for num_signal in num_signals],\n",
    "        yerr=[stdv_scale * model_metrics_dicts[name][num_signal]['calibration_dict']['ece'].std() for num_signal in num_signals],\n",
    "        label=name,\n",
    "        color = colors[name],\n",
    "        alpha=alpha,\n",
    "        markersize=markersize,\n",
    "        marker='o') #markersize=2, linewidth=0.5)\n",
    "ece_ax.set_ylim([.002, .2])\n",
    "#ece_ax.set_yticks([.01, .1])\n",
    "#ece_ax.set_yticklabels(['.01', '.1'], fontsize=tick_fontsize)\n",
    "ece_ax.legend(loc='upper right', fontsize=label_fontsize-3)\n",
    "\n",
    "\n",
    "space = .175\n",
    "plt.subplots_adjust(wspace=space, hspace=space, bottom=0.0, top=1, left=0.0, right=1.0)\n",
    "plt.savefig(FIGURES_PATH + 'covariate_shift', dpi=1000, bbox_inches=\"tight\", pad_inches=0.02)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gsl-bnn-mac-m2",
   "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.9.18"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
