{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "cc505f83",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "plt.set_loglevel(level = 'warning')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "689196b3-0e3f-4cc3-a62d-e901491779f2",
   "metadata": {},
   "source": [
    "# Load Model Predictions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "8041da2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "base_dir = '/shared/share_mala/implicitbayes/dataset_files/synthetic_data/beta/N=500,D=25000,D_eval=10000,cnts=5/models/0423_synthetic_bb/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c77eca79-1828-4dab-a46d-7cf18c9a0960",
   "metadata": {},
   "outputs": [],
   "source": [
    "model_paths = {\n",
    "    'seq_bb': base_dir+'/sequential:epochs=2000,bs=500,lr=0.001,wd=0.01,MLP_layers=3,MLP_width=100,weight_factor=1,max_obs=500,repeat_suffstat=10,Zdim=1,sched=constant,BB=True,alphabeta=True,seed=2340923'\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c08799ac-4d71-466d-bd10-8308e3511a9c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['seq_bb'])"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "prediction_dicts = {}\n",
    "for name, run_dir in model_paths.items():\n",
    "    preds = torch.load(run_dir + '/best_loss_predictions.pt')\n",
    "    prediction_dicts[name] = preds\n",
    "\n",
    "prediction_dicts.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "83342eea",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'val'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "d35651da-9118-4f6c-b7d3-20921a0e14d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "from closed_form_models import BetaBernoulli"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "5f2bb6a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "new_prediction_dicts = {}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "7cc60246",
   "metadata": {},
   "outputs": [],
   "source": [
    "onekey = list(prediction_dicts.keys())[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "0fd6fe39-2575-4ef2-b1c2-e68bdd6de982",
   "metadata": {},
   "outputs": [],
   "source": [
    "# BETA BERNOULLI MODELS =====================================================================================\n",
    "\n",
    "all_BB_models = {}\n",
    "\n",
    "\n",
    "# Standard beta comparison =============================\n",
    "prior_means_eval = preds[dataset]['theta_hats']\n",
    "true_means_train = preds['train']['click_rates']\n",
    "prior_dict = {\n",
    "                \"alpha\": prior_means_eval[:,0]*0+1,\n",
    "                \"beta\": prior_means_eval[:,0]*0+1,\n",
    "                }\n",
    "bb_model_eval_marginal = BetaBernoulli(prior_dict)\n",
    "obs_seq_eval = preds[dataset]['click_obs']\n",
    "post_alpha, post_beta = bb_model_eval_marginal.compute_posterior_seq(obs_seq_eval)\n",
    "post_means, post_vars = bb_model_eval_marginal.compute_post_mean_var(post_alpha, post_beta)\n",
    "\n",
    "new_prediction_dicts[f\"Beta-Bernoulli (Standard)\"] = { dataset : { \"theta_hats\": post_means,\n",
    "                                                        \"click_rates\": preds[dataset]['click_rates'].squeeze()\n",
    "                                                                        } }\n",
    "all_BB_models['Standard'] = bb_model_eval_marginal\n",
    "\n",
    "\n",
    "# Oracle beta comparison =============================\n",
    "Zvec = prediction_dicts[onekey][dataset]['Z']\n",
    "cnts=5\n",
    "alpha = Zvec*cnts+1\n",
    "beta = (1-Zvec)*cnts+1\n",
    "prior_dict = {\n",
    "                \"alpha\": alpha,\n",
    "                \"beta\": beta,\n",
    "                }\n",
    "bb_model_eval_marginal = BetaBernoulli(prior_dict)\n",
    "obs_seq_eval = preds[dataset]['click_obs']\n",
    "post_alpha, post_beta = bb_model_eval_marginal.compute_posterior_seq(obs_seq_eval)\n",
    "post_means, post_vars = bb_model_eval_marginal.compute_post_mean_var(post_alpha, post_beta)\n",
    "\n",
    "new_prediction_dicts[f\"Beta-Bernoulli (Oracle)\"] = { dataset : { \"theta_hats\": post_means,\n",
    "                                                        \"click_rates\": preds[dataset]['click_rates'].squeeze()\n",
    "                                                                        } }\n",
    "all_BB_models['Oracle'] = bb_model_eval_marginal\n",
    "\n",
    "all_prediction_dicts = {**prediction_dicts, **new_prediction_dicts}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "94d16f95-e5b1-4d7f-9139-d05d91a1a03d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "seq_bb\n",
      "Beta-Bernoulli (Standard)\n",
      "Beta-Bernoulli (Oracle)\n"
     ]
    }
   ],
   "source": [
    "# Process the prediction dictionaries\n",
    "model2predictions = {}\n",
    "for name, pred_dict in all_prediction_dicts.items():\n",
    "    print(name)\n",
    "    model2predictions[name] = {\n",
    "        'p_hats_eval': pred_dict[dataset]['theta_hats'],\n",
    "        'true_p_eval': pred_dict[dataset]['click_rates'].squeeze(),\n",
    "    }"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1f04f8b3-c70e-4242-97b7-198cb5bc3dbc",
   "metadata": {},
   "source": [
    "# Evaluate Model Predictions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "3a462ca0-c104-42fd-a695-22037f760929",
   "metadata": {},
   "outputs": [],
   "source": [
    "import imp\n",
    "import eval_metrics_and_plotting\n",
    "from collections import defaultdict, OrderedDict\n",
    "imp.reload(eval_metrics_and_plotting)\n",
    "\n",
    "from eval_metrics_and_plotting import get_prediction_metric_values, make_plot_from_predictions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "49b7d9e1-edb5-4871-9fb0-8e214f5f14c4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['seq_bb', 'Beta-Bernoulli (Standard)', 'Beta-Bernoulli (Oracle)']"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_plot_keys = [k for k in model2predictions.keys()]\n",
    "all_plot_keys"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7a5529c8-e76f-4238-ad01-a877aa1d434e",
   "metadata": {},
   "source": [
    "# Posterior Evaluation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "af0b16c9-ce5f-441b-a1e2-9aa9847c82b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "from eval_metrics_and_plotting import credible_interval_results, draw_posterior_samples_MIND\n",
    "\n",
    "all_posteriors_dict = {}\n",
    "all_num_prev_obs = [0]\n",
    "num_repetitions = 10000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "188cdec6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['Standard', 'Oracle'])"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "all_BB_models.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "2af56f0f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Draw posterior samples from Beta-Bernoulli models ---------------------\n",
    "true_p_eval = model2predictions[all_plot_keys[0]]['true_p_eval']\n",
    "all_prev_obs = prediction_dicts[all_plot_keys[0]][dataset]['click_obs']\n",
    "\n",
    "for name, bbmodel in all_BB_models.items():\n",
    "    if name != 'Oracle': continue\n",
    "    all_posteriors_dict[name] = {}\n",
    "    for num_prev_obs in all_num_prev_obs:\n",
    "        prev_obs = all_prev_obs[:,:num_prev_obs]\n",
    "        posterior_samples = bbmodel.posterior_samples(prev_obs, num_repetitions)\n",
    "        all_posteriors_dict[name][num_prev_obs] = {\n",
    "            'val_post_samples': posterior_samples[:1000],\n",
    "            'val_true_p': true_p_eval[:1000]\n",
    "        }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "8a86a0da-1d24-4848-b080-185ccff1709d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load posterior samples from other models\n",
    "post_sample_models = ['seq_bb'] \n",
    "for name in post_sample_models:\n",
    "    \n",
    "    all_posteriors_dict[name] = {}\n",
    "    run_dir = model_paths[name]\n",
    "    post_samples = torch.load(run_dir + '/best_loss_posterior_samples.pt')\n",
    "    \n",
    "    for num_prev_obs in all_num_prev_obs:\n",
    "        tuplekey = (num_prev_obs, 500, 10000)\n",
    "        all_posteriors_dict[name][num_prev_obs] = {\n",
    "            'val_post_samples': post_samples[dataset][tuplekey]['post_samples'],\n",
    "            'val_true_p': true_p_eval[:1000]\n",
    "        }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "6e00b6c6",
   "metadata": {},
   "outputs": [],
   "source": [
    "from eval_metrics_and_plotting import compare_posteriors, mean_abs_diff_from_mean, plot_scatter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "ef628b34",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_prev = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "d1e9d441",
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_draws = all_posteriors_dict['seq_bb'][num_prev]['val_post_samples'][:100,:10000]\n",
    "oracle_draws = all_posteriors_dict['Oracle'][num_prev]['val_post_samples'][:100,:10000]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "7ec79415",
   "metadata": {},
   "outputs": [],
   "source": [
    "from util import make_plots_good\n",
    "make_plots_good()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "75e4e3ef",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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aNmypSSx1cSY7dZt29WrV2tcrivX1atvO0RE9cHxguMFmQdvZUoWpburRHJycp3qZ2RkAABGjhxpsGzfvn3SBVYLY+N97LHHANQcW3JyMsrKyqQL7iH5+/vD2dkZBw8exJ9//mmwPCkpCQDQrVs3M0dGRMTxguMFmQuTA7Ko3r17o0+fPli/fj3i4+MNlldUVOgPMgDQtm1bAMD+/fur1UtKSjL4ZcgURo0ahTZt2mDZsmXYu3evwfLS0tJqsY0aNQru7u6Ii4vDmTNnqtX74IMPTB6vMZycnDBx4kTk5eVh8eLF1Zbt3LkTv/zyC9q3b4/HH3/cQhESUUPG8UI+OF7YNk4rIpM6fvx4rQ846dGjB15//XWsX78eISEhmDBhApYvX46ePXvC2dkZFy5cQHJyMnJzc3Hnzh0AwIgRI+Dj44PY2FicOHECXbp0QXp6On766SeMHj0aCQkJJt0epVKJTZs24cknn8SgQYMwZMgQ/YVvFy5cwL59++Dh4aG/ME6tVmPFihWIiIhAUFAQJkyYALVajZ9++gkqlQrNmzc3abzGWrp0KZKSkrBw4UIcOHAAffr00d+32sXFBatXr4adHX9TICLpcbzgeEHywOSATConJ6fWeZ35+fl4/fXX4evri8OHD2PZsmXYvHkz4uLiYG9vj+bNm2PgwIEYN26c/jWurq7YvXs3/va3v2Hv3r1ITExEQEAAvvnmG3h7e5v8YA8AQUFBOHr0KD766CP8/PPP2L9/P5RKJVq2bInRo0dj4sSJ1epPnjwZarUaCxcuxNq1a6FWqzFy5EjExsaie/fuJo/XGI888ghSU1OxYMEC/PDDD9i3bx/UajVGjRoFjUajH9iIiKTG8YLjBcmDQgghLB0EERERERFZHs/3EBERERERACYHRERERERUickBEREREREBYHJARERERESVmBwQEREREREAJgdERERERFSJyQEREREREQFgckBERERERJWYHBAREREREQAmB0REREREVInJARERERERAWByQERERERElZgcEBERERERAOD/AWXLlDwtBNtnAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "figsize=(8,4)\n",
    "fig,ax = plt.subplots(1,2,figsize=figsize)\n",
    "s = 5\n",
    "metrics = {\n",
    "    'Mean': lambda x: x.mean(1),\n",
    "    'Mean |sample - mean|': lambda x: mean_abs_diff_from_mean(x).mean(1),\n",
    "}\n",
    "sd_metrics = {\n",
    "    'Mean': lambda x: x.std(1) / x.shape[1] ** 0.5,\n",
    "    'Mean |sample - mean|': lambda x: mean_abs_diff_from_mean(x).std(1) / x.shape[1] ** 0.5,\n",
    "}\n",
    "for i, (metric, fn) in enumerate(metrics.items()):\n",
    "    x = fn(sample_draws)\n",
    "    y = fn(oracle_draws)\n",
    "    plot_scatter(x, y, ax=ax[i], title=metric, s=s)  \n",
    "    if metric in sd_metrics.keys():\n",
    "        xerr = sd_metrics[metric](sample_draws)\n",
    "        yerr = sd_metrics[metric](oracle_draws)\n",
    "        ax[i].errorbar(x, y, xerr=xerr, yerr=yerr, fmt=\"none\", c='r', alpha=0.5)\n",
    "\n",
    "ax[0].set_title('Prior mean')\n",
    "ax[1].set_title('Prior width\\n(Mean Absolute Deviation)')\n",
    "xlabel = 'Learned Prior'\n",
    "for a in ax:\n",
    "    a.set_xlabel(xlabel)\n",
    "    a.set_ylabel('Oracle Prior')\n",
    "fig.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "757508ea-572a-4de2-a4f7-7329e51d1edd",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
