{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_runs = 250\n",
    "num_visits_list = range(1,11)\n",
    "\n",
    "msbi_rel = {}\n",
    "msbi_std = {}\n",
    "msbi_bayes_rel = {}\n",
    "msbi_bayes_std = {}\n",
    "\n",
    "\n",
    "for num_visits in num_visits_list:\n",
    "    thing = \"_ground_truths\"\n",
    "    for string, name in [(\"msbi\", \"msbi\"+thing), (\"grad\", \"grad\"+thing)]:\n",
    "        globals()[name] = np.array([(np.load(f\"synthetic_mdps/msbi/M{num_visits}/run{run}/{string}{thing}.npy\")) for run in range(num_runs)])\n",
    "\n",
    "    thing = \"_bayes_values\"\n",
    "    for string, name in [(\"msbi\", \"msbi\"+thing), (\"grad\", \"grad\"+thing)]:\n",
    "        globals()[name] = np.array([(np.load(f\"synthetic_mdps/msbi/M{num_visits}/run{run}/{string}{thing}.npy\")) for run in range(num_runs)])\n",
    "\n",
    "    msbi_rel[num_visits] = (grad_ground_truths - msbi_ground_truths).mean()\n",
    "    msbi_std[num_visits] = (grad_ground_truths - msbi_ground_truths).std(ddof=1)\n",
    "    msbi_bayes_rel[num_visits] = (grad_bayes_values - msbi_bayes_values).mean()\n",
    "    msbi_bayes_std[num_visits] = (grad_bayes_values - msbi_bayes_values).std(ddof=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": [
    "dataset_sizes = [25*m for m in num_visits_list]\n",
    "policy = \"msbi\"\n",
    "\n",
    "plt.figure(figsize=(4,3.5))\n",
    "    \n",
    "x = (np.array(dataset_sizes))\n",
    "\n",
    "y = msbi_rel\n",
    "std = msbi_std\n",
    "\n",
    "y = np.array([y[i] for i in num_visits_list])\n",
    "std = np.array([std[i] for i in num_visits_list])/np.sqrt(num_runs)\n",
    "\n",
    "plt.hlines(0, x[0], x[-1], color='r', linestyles='dashed')\n",
    "plt.plot(x, y, color='b')\n",
    "\n",
    "plt.fill_between((np.array(dataset_sizes)), y+std, y-std, color='b', alpha = 0.25)\n",
    "\n",
    "plt.xlabel(\"dataset size\", fontsize=12)\n",
    "plt.ylabel(f\"value difference\", fontsize=12)\n",
    "plt.tight_layout()\n",
    "\n",
    "if not os.path.isdir(\"synthetic_msbi_figures\"):\n",
    "    os.mkdir(\"synthetic_msbi_figures\")\n",
    "plt.savefig(f'synthetic_msbi_figures/{policy}_ground_truth.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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": [
    "dataset_sizes = [25*m for m in num_visits_list]\n",
    "policy = \"msbi\"\n",
    "\n",
    "plt.figure(figsize=(4,3.5))\n",
    "    \n",
    "x = (np.array(dataset_sizes))\n",
    "\n",
    "y = msbi_bayes_rel\n",
    "std = msbi_bayes_std\n",
    "\n",
    "y = np.array([y[i] for i in num_visits_list])\n",
    "std = np.array([std[i] for i in num_visits_list])\n",
    "\n",
    "plt.hlines(0, x[0], x[-1], color='r', linestyles='dashed')\n",
    "plt.plot(x, y, color='b')\n",
    "\n",
    "plt.fill_between((np.array(dataset_sizes)), y+std, y-std, color='b', alpha = 0.25)\n",
    "\n",
    "plt.xlabel(\"dataset size\", fontsize=12)#, labelsize=9)\n",
    "plt.ylabel(f\"value difference\", fontsize=12)#, labelsize=9)\n",
    "plt.tight_layout()\n",
    "\n",
    "if not os.path.isdir(\"synthetic_msbi_figures\"):\n",
    "    os.mkdir(\"synthetic_msbi_figures\")\n",
    "plt.savefig(f'synthetic_figures/{policy}_bayes.pdf')\n",
    "plt.show()"
   ]
  }
 ],
 "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
