{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import json\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from generate_plots.uncertainty_quantification import plot_uncertainty_quantification\n",
    "from generate_plots.value_comparison import plot_bayesian_value, plot_relative_bayesian_value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x302.4 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# aleatoric/epistemic uncertainty for different dataset sizes\n",
    "# a pdf figure is saved in the figures folder\n",
    "\n",
    "config = json.load(open(os.path.join(\"experiments\",\"uncertainty_quantification\",\"data\",\"config.json\")))\n",
    "p_succs = config[\"env_args\"][\"p_successful_step\"]\n",
    "\n",
    "dataset_sizes = config[\"data_args\"][\"num_transitions\"]\n",
    "\n",
    "results_dir = os.path.join(\"results\",\"uncertainty_quantification\")\n",
    "\n",
    "# load results\n",
    "\n",
    "epistemic_uncertainties = []\n",
    "aleatoric_uncertainties = []\n",
    "\n",
    "for p in p_succs:\n",
    "    ep_unc = []\n",
    "    al_unc = []\n",
    "    for size in dataset_sizes:\n",
    "        size = str(size)\n",
    "        ep = np.load(os.path.join(results_dir, f\"p_{p}\", size, \"ep_std.npy\"))\n",
    "        al = np.load(os.path.join(results_dir, f\"p_{p}\", size, \"al_std.npy\"))\n",
    "        ep_unc.append(ep)\n",
    "        al_unc.append(al)\n",
    "    epistemic_uncertainties.append(ep_unc)\n",
    "    aleatoric_uncertainties.append(al_unc)\n",
    "    \n",
    "# plot results\n",
    "\n",
    "plot_uncertainty_quantification(dataset_sizes, p_succs, epistemic_uncertainties, aleatoric_uncertainties, state=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# bayesian values of different policies\n",
    "num_eval_samples = 10000\n",
    "seed = 0\n",
    "\n",
    "config = json.load(open(os.path.join(\"experiments\",\"policies\",\"data\",\"config.json\")))\n",
    "\n",
    "dataset_sizes = config[\"data_args\"][\"num_transitions\"]\n",
    "\n",
    "policies = [\"mle\", \"nominal\", \"second_order\", \"grad_stochastic_mle\"]\n",
    "labels = {\"mle\":\"MLE-optimal\",\"grad_stochastic_mle\":\"Gradient (ours)\",\"msbi\":\"MSBI\",\"nominal\":\"Nominal\",\"second_order\":\"Second order\"}\n",
    "\n",
    "results_dir = os.path.join(\"results\",\"policies\")\n",
    "values_dict = {}\n",
    "\n",
    "for policy in policies:\n",
    "    vals = []\n",
    "    for dataset_size in dataset_sizes:\n",
    "        vals.append(np.load(os.path.join(results_dir,policy,str(dataset_size),str(seed),f\"value{num_eval_samples}samples.npy\")))\n",
    "\n",
    "    vals = np.array(vals).mean(1)\n",
    "    values_dict[policy] = vals\n",
    "\n",
    "plot_bayesian_value(dataset_sizes, policies, labels, values_dict, state=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 288x252 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# bayesian values of different policies with error bars\n",
    "policies = [\"mle\", \"grad_stochastic\", \"msbi\",\"nominal\",\"second_order\"]\n",
    "reference_policy = \"grad_stochastic\"\n",
    "compared_policy = \"msbi\"\n",
    "\n",
    "num_eval_samples = 10000\n",
    "num_seeds = 50\n",
    "\n",
    "config = json.load(open(os.path.join(\"experiments\",\"policies\",\"data\",\"config.json\")))\n",
    "\n",
    "dataset_sizes = config[\"data_args\"][\"num_transitions\"]\n",
    "\n",
    "labels = {\"mle\":\"MLE-optimal\",\"nominal\":\"Nominal\", \"grad\":\"Gradient Policy\", \"msbi\":\"MSBI\"}\n",
    "\n",
    "results_dir = os.path.join(\"results\",\"policies\")\n",
    "values_dict = {}\n",
    "\n",
    "for policy in policies:\n",
    "    values_dict[policy] = {}\n",
    "    for seed in range(num_seeds):\n",
    "\n",
    "        vals = []\n",
    "\n",
    "        for dataset_size in dataset_sizes:\n",
    "            vals.append(np.load(os.path.join(results_dir,policy,str(dataset_size),str(seed),f\"value{num_eval_samples}samples.npy\")))\n",
    "\n",
    "        vals = np.array(vals)\n",
    "        values_dict[policy][seed] = vals\n",
    "\n",
    "plot_relative_bayesian_value(dataset_sizes, reference_policy, compared_policy, values_dict, num_seeds, scatter = False, state=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "policy = \"second_order\"\n",
    "\n",
    "loss_dict = {}\n",
    "first_term_dict = {}\n",
    "second_term_dict = {}\n",
    "for seed in range(num_seeds):\n",
    "\n",
    "    losses = []\n",
    "    first_terms = []\n",
    "    second_terms = []\n",
    "\n",
    "    for dataset_size in dataset_sizes:\n",
    "        losses.append(np.load(os.path.join(results_dir,policy,str(dataset_size),str(seed),f\"losses.npy\")))\n",
    "        first_terms.append(np.load(os.path.join(results_dir,policy,str(dataset_size),str(seed),f\"first_terms.npy\")))\n",
    "        second_terms.append(np.load(os.path.join(results_dir,policy,str(dataset_size),str(seed),f\"second_terms.npy\")))\n",
    "\n",
    "    losses = np.array(losses)\n",
    "    first_terms = np.array(first_terms)\n",
    "    second_terms = np.array(second_terms)\n",
    "    loss_dict[seed] = losses\n",
    "    first_term_dict[seed] = first_terms\n",
    "    second_term_dict[seed] = second_terms\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch",
   "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.7"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
