{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1137a135",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:35.272470Z",
     "start_time": "2022-05-19T18:30:35.261267Z"
    }
   },
   "outputs": [],
   "source": [
    "%load_ext autoreload"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a2f9c430",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:35.882415Z",
     "start_time": "2022-05-19T18:30:35.274167Z"
    }
   },
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.rc('text.latex', preamble=r'\\usepackage{physics}')\n",
    "matplotlib.use(\"pgf\")\n",
    "matplotlib.rcParams.update({\n",
    "    \"pgf.texsystem\": \"pdflatex\",\n",
    "    'font.family': 'serif',\n",
    "    'text.usetex': True,\n",
    "    'pgf.rcfonts': False,\n",
    "   'axes.labelsize': 12,\n",
    "   'legend.fontsize': 11,\n",
    "   'xtick.labelsize': 12,\n",
    "   'ytick.labelsize': 12,\n",
    "   'figure.figsize': [4.5, 4.5]\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "bd77ba37",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:35.885600Z",
     "start_time": "2022-05-19T18:30:35.883406Z"
    }
   },
   "outputs": [],
   "source": [
    "from IPython.display import display"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "e3567577",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:36.306497Z",
     "start_time": "2022-05-19T18:30:35.886663Z"
    }
   },
   "outputs": [],
   "source": [
    "import jax\n",
    "from jax import vmap\n",
    "\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7240cbcf",
   "metadata": {},
   "source": [
    "# Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a649f458",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:36.310240Z",
     "start_time": "2022-05-19T18:30:36.307485Z"
    }
   },
   "outputs": [],
   "source": [
    "Ndata = 20\n",
    "complexity = 3\n",
    "thetas = np.arange(0, Ndata) / Ndata * (np.pi)\n",
    "inputs = np.swapaxes(np.stack([np.cos(thetas), np.sin(thetas)]), 0, 1)\n",
    "targets = np.sin(complexity*thetas)/2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "99638749",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:36.557256Z",
     "start_time": "2022-05-19T18:30:36.311048Z"
    }
   },
   "outputs": [],
   "source": [
    "from fcnet import square_loss\n",
    "ls_fun = (lambda pred, target: square_loss(pred, target))\n",
    "L_mean = lambda Yd: ls_fun(Yd,targets).mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3951bb30",
   "metadata": {},
   "source": [
    "# Hessian"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "9234f0f5",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:36.563626Z",
     "start_time": "2022-05-19T18:30:36.558924Z"
    }
   },
   "outputs": [],
   "source": [
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2073f8f4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:36.630918Z",
     "start_time": "2022-05-19T18:30:36.565462Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('data/one_hessian_trace.npy', 'rb') as f:\n",
    "    H = np.load(f)\n",
    "    H_std = np.load(f)\n",
    "    pred_H = np.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "0cc8a99a",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:38.339188Z",
     "start_time": "2022-05-19T18:30:36.633635Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x201.6 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 0.8\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "plt.plot(thetas, pred_H, label=\"Our Approximation\")\n",
    "plt.fill_between(thetas,\n",
    "                 H - 3 * H_std,\n",
    "                 H + 3 * H_std,\n",
    "                 alpha=0.3,\n",
    "                 label=\"Hutchinson\")\n",
    "plt.xlim(np.min(thetas),np.max(thetas))\n",
    "plt.legend(loc=\"upper right\")\n",
    "#plt.ylabel(r\"$\\Tr(\\nabla_\\theta^2 y_d(\\theta(0), s(\\tau)))$\")\n",
    "plt.ylabel(r\"Hessian Trace\")\n",
    "plt.xlabel(r\"$\\tau$\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/one_hessian_trace.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/one_hessian_trace.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3127a4af",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:38.344280Z",
     "start_time": "2022-05-19T18:30:38.341286Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('data/hessian_trace_hist.npy', 'rb') as f:\n",
    "    results = np.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "016f6d75",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:38.907942Z",
     "start_time": "2022-05-19T18:30:38.345269Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 201.6x201.6 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 0.8\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(3.5 * fig_scale, 3.5 * fig_scale))\n",
    "\n",
    "kwargs = dict(histtype='stepfilled', alpha=0.3, density=True, ec=\"k\")\n",
    "plt.hist(results, bins=100,range=(-15,15), **kwargs)\n",
    "#plt.hist(results, bins=100, density=True,edgecolor='blue',color=\"lightblue\")\n",
    "#plt.ylabel(r\"$\\Tr(\\nabla_\\theta^2 y_d(\\theta(0), s(\\tau)))$\")\n",
    "plt.yticks([])\n",
    "plt.xlabel(r\"Hessian Trace\")\n",
    "#plt.ylabel(\"Density\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/hessian_trace_hist.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/hessian_trace_hist.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e917015f",
   "metadata": {
    "ExecuteTime": {
     "start_time": "2022-01-27T07:23:24.402Z"
    }
   },
   "source": [
    "# Function Space vs Parameter Space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0026e4fc",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:38.915454Z",
     "start_time": "2022-05-19T18:30:38.908926Z"
    }
   },
   "outputs": [],
   "source": [
    "with open('data/kgd.npy', 'rb') as f:\n",
    "    allT_ode=np.load(f)\n",
    "    Yd=np.load(f)\n",
    "    sY=np.load(f)\n",
    "    TrH=np.load(f)\n",
    "    DeltaV=np.load(f)\n",
    "    DeltaS=np.load(f)\n",
    "with open('data/gd.npy', 'rb') as f:\n",
    "    allT=np.load(f)\n",
    "    allloss=np.load(f)\n",
    "    allV=np.load(f)\n",
    "    allYd=np.load(f)\n",
    "    allsY=np.load(f)\n",
    "    allH=np.load(f)\n",
    "    allH_std=np.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "4823c703",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:39.999837Z",
     "start_time": "2022-05-19T18:30:38.916264Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:absl:No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n",
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x172.8 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig_scale = 0.8\n",
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(5 * fig_scale, 3. * fig_scale))\n",
    "\n",
    "plt.plot(allT_ode, vmap(L_mean)(Yd), label=\"Function Space\", linestyle='-.')\n",
    "plt.plot(allT, [l.mean() for l in allloss], label=\"Parameter Space\")\n",
    "#plt.ylabel(r\"$\\frac{1}{m}\\sum_{a=1}^m l^s(y_d(s_a),t_a)$\")\n",
    "plt.xlabel(\"Training Time\")\n",
    "plt.ylabel(\"Training Loss\")\n",
    "plt.legend(loc=\"upper right\")\n",
    "plt.ylim(0,0.16)\n",
    "plt.xscale('log')\n",
    "plt.xlim((allT[1],allT_ode.max()))\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/comp_loss.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/comp_loss.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "9f73add6",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:40.735877Z",
     "start_time": "2022-05-19T18:30:40.001116Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x172.8 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(5 * fig_scale, 3. * fig_scale))\n",
    "\n",
    "plt.plot(allT_ode, DeltaV, label=\"Function Space\", linestyle='-.')\n",
    "plt.plot(allT, np.array(allV)-allV[0], label=\"Parameter Space\")\n",
    "plt.xlabel(\"Training Time\")\n",
    "plt.ylabel(\"$V(\\\\theta(t))-V(\\\\theta(0))$\")\n",
    "#plt.ylabel(r\"Energy Change\")\n",
    "plt.legend(loc=\"upper left\")\n",
    "plt.xscale('log')\n",
    "plt.xlim((allT[1],allT_ode.max()))\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/comp_dV.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/comp_dV.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "f1b7d840",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:41.529056Z",
     "start_time": "2022-05-19T18:30:40.737148Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x172.8 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(5 * fig_scale, 3. * fig_scale))\n",
    "\n",
    "dfdt = lambda s,t: np.divide((s[1:]-s[:-1]),(t[1:]-t[:-1]))\n",
    "plt.plot(allT_ode[1:], dfdt(DeltaV,allT_ode), label=\"Function Space\", linestyle='-.')\n",
    "plt.plot(allT[1:], dfdt(np.array(allV), allT), label=\"Parameter Space\")\n",
    "plt.xlabel(\"Training Time\")\n",
    "plt.ylabel(\"$\\dv{t} V(\\\\theta(t))$\")\n",
    "#plt.ylabel(r\"Energy Change\")\n",
    "plt.legend(loc=\"lower right\")\n",
    "plt.xscale('log')\n",
    "plt.xlim((allT[1],allT_ode.max()))\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/comp_dVdt.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/comp_dVdt.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "e8211648",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:42.239332Z",
     "start_time": "2022-05-19T18:30:41.530345Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x172.8 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(5 * fig_scale, 3. * fig_scale))\n",
    "\n",
    "i = 14\n",
    "plt.plot(allT_ode, TrH[:, i], label=\"Function Space\")\n",
    "Hi = np.array([H[i] for H in allH])\n",
    "Hi_std = np.array([H_std[i] for H_std in allH_std])\n",
    "plt.fill_between(allT, Hi-3*Hi_std, Hi+3*Hi_std,alpha=0.3, label=\"Parameter Space\")\n",
    "#plt.xlim((0,1))\n",
    "plt.xlabel(\"Training Time\")\n",
    "#plt.ylabel(\"$\\Tr(H_a(\\\\theta(t)))$\")\n",
    "plt.ylabel(r\"Hessian Trace\")\n",
    "plt.legend(loc=\"upper right\")\n",
    "plt.xscale('log')\n",
    "plt.ylim((-7.,1))\n",
    "plt.xlim((allT[1],allT_ode.max()))\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/comp_TrH.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/comp_TrH.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9a02334e",
   "metadata": {},
   "source": [
    "# TransBL"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4fbdbd3c",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:42.288074Z",
     "start_time": "2022-05-19T18:30:42.240443Z"
    }
   },
   "outputs": [],
   "source": [
    "import jax.numpy as np\n",
    "import numpy as onp\n",
    "\n",
    "with open('data/oneshot.npy', 'rb') as f:\n",
    "    allT = np.array(np.load(f))\n",
    "    ens_history = np.array(np.load(f))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "50f5925f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:42.313979Z",
     "start_time": "2022-05-19T18:30:42.289032Z"
    }
   },
   "outputs": [],
   "source": [
    "def get_w(lamb, r, DeltaV, DeltaS1, DeltaS2):\n",
    "    return np.exp(-lamb * r - DeltaV + DeltaS1 + DeltaS2)\n",
    "\n",
    "\n",
    "def get_ens_ws(lamb, rs, DeltaVs, DeltaS1s, DeltaS2s):\n",
    "    return vmap(vmap(get_w, (None, 0, 0, 0, 0)),\n",
    "                (None, 0, 0, 0, 0))(lamb, rs, DeltaVs, DeltaS1s, DeltaS2s)\n",
    "\n",
    "def get_log_w(lamb, r, DeltaV, DeltaS1, DeltaS2):\n",
    "    return -lamb * r - DeltaV + DeltaS1 + DeltaS2\n",
    "\n",
    "\n",
    "def get_log_ens_ws(lamb, rs, DeltaVs, DeltaS1s, DeltaS2s):\n",
    "    return vmap(vmap(get_log_w, (None, 0, 0, 0, 0)),\n",
    "                (None, 0, 0, 0, 0))(lamb, rs, DeltaVs, DeltaS1s, DeltaS2s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "4238dae8",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:42.390901Z",
     "start_time": "2022-05-19T18:30:42.314935Z"
    }
   },
   "outputs": [],
   "source": [
    "def get_eff(ws):\n",
    "    return ws.mean()**2 / np.square(ws).mean()\n",
    "def scale_exp(x):\n",
    "    return np.exp(x-x.max())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "ea55f7ee",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:42.487112Z",
     "start_time": "2022-05-19T18:30:42.394482Z"
    }
   },
   "outputs": [],
   "source": [
    "import bootstrap\n",
    "from bootstrap import bootstrap\n",
    "\n",
    "def get_mean(v, log_ws):\n",
    "    ws = scale_exp(log_ws)\n",
    "    wi = ws / ws.sum()\n",
    "    v_mean = np.dot(wi, v)\n",
    "    return v_mean\n",
    "def get_mean_std(v, log_ws):\n",
    "    ws = scale_exp(log_ws)\n",
    "    wi = ws / ws.sum()\n",
    "    v_mean = np.dot(wi, v)\n",
    "    v_mean_std = np.sqrt(np.dot(np.square(wi), np.square(v-v_mean)))\n",
    "    return v_mean, v_mean_std\n",
    "\n",
    "def pr(ax, v, use_bootstrap=False, bootstrap_num=100, log_ws=None, plot_kwargs={}, **kwargs):\n",
    "    if log_ws is None:\n",
    "        log_ws = np.ones_like(v)\n",
    "\n",
    "    def statistic(x):\n",
    "        v = x[:, 0]\n",
    "        log_ws = x[:, 1]\n",
    "        return vmap(get_mean, (1, 1))(v, log_ws)\n",
    "\n",
    "    v_mean, std = vmap(get_mean_std,(1,1))(v, log_ws)\n",
    "    if use_bootstrap:\n",
    "        data = np.swapaxes(np.stack([v, log_ws]), 0, 1)\n",
    "        SEED = 42\n",
    "        key = jax.random.PRNGKey(SEED)\n",
    "        f = lambda: bootstrap(data,\n",
    "                         statistic,\n",
    "                         jax.random.split(key, bootstrap_num),\n",
    "                         confidence_level=0.99,\n",
    "                         #method=\"BCa\"\n",
    "                         method=\"percentile\",\n",
    "                         loop_kwargs = {\"loop\":True,\"batch_size\":100}\n",
    "                         )\n",
    "        l, u = jax.jit(f)()\n",
    "    else:\n",
    "        l = v_mean-3*std\n",
    "        u = v_mean+3*std\n",
    "    ax.fill_between(allT, l, u, alpha=0.3, **kwargs)\n",
    "    ax.plot(allT, v_mean, **kwargs, **plot_kwargs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c96070b4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:43.636083Z",
     "start_time": "2022-05-19T18:30:42.490372Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x230.4 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig,ax = plt.subplots(figsize=(5 * fig_scale, 4 * fig_scale))\n",
    "\n",
    "pr(ax, ens_history[6] - ens_history[7] - ens_history[8], plot_kwargs={\"label\":\"KL Divergence\"})\n",
    "ax.set_ylabel(\"$D_{KL}(q_t\\|p)$\")\n",
    "ax.set_xlabel(\"Training Time\")\n",
    "ax2=ax.twinx()\n",
    "pr(ax2, ens_history[5] - ens_history[4], color=\"red\", plot_kwargs={\"label\":\"Loss Gap\"})\n",
    "ax2.set_ylabel(\"Loss Gap\")\n",
    "ax.legend(loc=\"upper left\")\n",
    "ax2.legend(loc=\"lower right\")\n",
    "\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/kl_gap.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/kl_gap.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "386fb960",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:43.639970Z",
     "start_time": "2022-05-19T18:30:43.637639Z"
    }
   },
   "outputs": [],
   "source": [
    "lamb = 1.8e2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "58553f44",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:44.427099Z",
     "start_time": "2022-05-19T18:30:43.640826Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "DeviceArray(-43.56632, dtype=float32)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "DeviceArray(0.00693, dtype=float32)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x230.4 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(5 * fig_scale, 4 * fig_scale))\n",
    "\n",
    "i = 9\n",
    "log_ens_ws = get_log_ens_ws(lamb, ens_history[4], ens_history[6],\n",
    "                            ens_history[7], ens_history[8])\n",
    "display(np.log(np.exp(log_ens_ws[:, i]).mean()))\n",
    "display((log_ens_ws[:, i] > np.log(np.exp(log_ens_ws[:, i]).mean())).sum() /\n",
    "        log_ens_ws.shape[0])\n",
    "r = (-120,-30)\n",
    "kwargs = dict(histtype='stepfilled',\n",
    "              alpha=0.3,\n",
    "              density=True,\n",
    "              ec=\"k\",\n",
    "              #range=(-120, ens_ws[:, -1].max())\n",
    "              range=r,\n",
    "              #range=(-120, -29)\n",
    "             )\n",
    "plt.hist(onp.array(log_ens_ws[:, 0]), bins=50, **kwargs, label=\"No Training \")\n",
    "plt.hist(onp.array(log_ens_ws[:, -1]), bins=50, **kwargs, label=\"Trained\")\n",
    "plt.xlim(r)\n",
    "plt.yticks([])\n",
    "plt.xlabel(\"$\\log(w)$\")\n",
    "plt.legend(loc=\"upper left\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/w_dist.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/w_dist.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "16ad4b7e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:45.159953Z",
     "start_time": "2022-05-19T18:30:44.428497Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x230.4 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "plt.figure(figsize=(5 * fig_scale, 4 * fig_scale))\n",
    "\n",
    "#ax.scatter( np.repeat((np.arange(log_ens_ws.shape[1]) + 1)[None, :], log_ens_ws.shape[0], axis=0), log_ens_ws)\n",
    "lew_mean = log_ens_ws.mean(0)\n",
    "lew_std = log_ens_ws.std(0)\n",
    "plt.plot(allT, lew_mean)\n",
    "plt.fill_between(allT, lew_mean - 3 * lew_std, lew_mean + 3 * lew_std, alpha=0.3)\n",
    "plt.xlabel(\"Training Time\")\n",
    "plt.ylabel(\"$\\log(w)$\")\n",
    "plt.xlim(1,10)\n",
    "\n",
    "#pr(ax, log_ens_ws)\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/w_dist_t.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/w_dist_t.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "289cb19c",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:45.985216Z",
     "start_time": "2022-05-19T18:30:45.161397Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "DeviceArray([  9.235834,  14.515546,  22.593966,  37.20087 ,  60.75782 ,\n",
       "              92.7277  , 131.54547 , 182.35844 , 249.43962 , 330.47253 ],            dtype=float32)"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x230.4 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "fig, ax = plt.subplots(figsize=(5 * fig_scale, 4 * fig_scale))\n",
    "\n",
    "log_beta = -40\n",
    "c_log_ens_ws = np.minimum(log_ens_ws, log_beta)\n",
    "effs = vmap(get_eff, 1)(scale_exp(c_log_ens_ws))\n",
    "display(effs * c_log_ens_ws.shape[0])\n",
    "\n",
    "ax.set_xlabel(\"Training Time\")\n",
    "ax.set_ylabel(\"Accuracy\")\n",
    "ax.set_xlim((1,10))\n",
    "ax.set_ylim((0.5,1.00))\n",
    "pr(ax, ens_history[0], plot_kwargs={\"label\": \"GD Train\"})\n",
    "pr(ax, ens_history[1], plot_kwargs={\"label\": \"GD Test\"})\n",
    "pr(ax,\n",
    "   ens_history[1],\n",
    "   log_ws=c_log_ens_ws,\n",
    "   #use_bootstrap=True,\n",
    "   bootstrap_num=1000,\n",
    "   plot_kwargs={\"label\": \"TransBL Test\"})\n",
    "plt.legend(loc=\"lower right\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/losses.pdf', bbox_inches='tight', pad_inches=pad)\n",
    "plt.savefig(f'figure/losses.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "ba88e3a9",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2022-05-19T18:30:47.379909Z",
     "start_time": "2022-05-19T18:30:45.986575Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:matplotlib.backends.backend_ps:The PostScript backend does not support transparency; partially transparent artists will be rendered opaque.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x230.4 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "pad = 0.05\n",
    "#plt.figure(figsize=(4*fig_scale,3.5*fig_scale))\n",
    "fig, ax = plt.subplots(figsize=(5 * fig_scale, 4 * fig_scale))\n",
    "\n",
    "i=9\n",
    "log_betas = np.arange(-80,-40+1,1)\n",
    "def f(log_beta):\n",
    "    c_log_ens_ws = np.minimum(log_ens_ws, log_beta)\n",
    "    eff = get_eff(scale_exp(c_log_ens_ws[:,i]))\n",
    "    test_loss = get_mean(ens_history[1][:,i], c_log_ens_ws[:,i])\n",
    "    \n",
    "    use_bootstrap=False\n",
    "    if use_bootstrap:\n",
    "        data = np.swapaxes(np.stack([ens_history[1][:,i], c_log_ens_ws[:,i]]), 0, 1)\n",
    "        SEED = 42\n",
    "        key = jax.random.PRNGKey(SEED)\n",
    "        statistic = lambda x: get_mean(x[:,0],x[:,1])\n",
    "        f = lambda: bootstrap(data,\n",
    "                         statistic,\n",
    "                         jax.random.split(key, 1000),\n",
    "                         confidence_level=0.99,\n",
    "                         #method=\"BCa\"\n",
    "                         method=\"percentile\",\n",
    "                         loop_kwargs = {\"loop\":True,\"batch_size\":100}\n",
    "                         )\n",
    "        l, u = jax.jit(f)()\n",
    "    else:\n",
    "        v_mean, std = get_mean_std(ens_history[1][:,i], c_log_ens_ws[:,i])\n",
    "        l = v_mean-3*std\n",
    "        u = v_mean+3*std\n",
    "    return eff, test_loss, l,u\n",
    "effs, test_losses,l,u= vmap(f)(log_betas)\n",
    "\n",
    "ax.plot(log_betas,effs)\n",
    "ax.set_xlabel(r\"$\\log\\beta$\")\n",
    "ax.set_yscale('log')\n",
    "ax.set_ylabel(\"Sampling Efficiency\")\n",
    "ax.set_xlim((log_betas.min(),log_betas.max()))\n",
    "ax2=ax.twinx()\n",
    "ax2.plot(log_betas,test_losses,color=\"red\")\n",
    "ax2.fill_between(log_betas,l,u,alpha=0.3,color=\"red\")\n",
    "ax2.set_ylabel(\"Test Accuracy\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'figure/tradeoff.pdf', bbox_inches = 'tight', pad_inches = pad)\n",
    "plt.savefig(f'figure/tradeoff.eps')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "89d7b529",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a62757ad",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:machinelearning]",
   "language": "python",
   "name": "conda-env-machinelearning-py"
  },
  "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.8.12"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {
    "height": "calc(100% - 180px)",
    "left": "10px",
    "top": "150px",
    "width": "288px"
   },
   "toc_section_display": true,
   "toc_window_display": true
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
