{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "dfe42a05-54d1-414b-83a8-5d9fca146f48",
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "import matplotlib.pylab as plt\n",
    "import matplotlib as mpl\n",
    "import seaborn as sns\n",
    "import torch\n",
    "from torch.distributions import MultivariateNormal\n",
    "from labproject.data import toy_mog_2d"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "02d24527-b3af-4d79-bc0f-7bb5088ba094",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[tensor([[3.8583, 1.1977],\n",
       "         [1.1977, 2.2302]]),\n",
       " tensor([[3.9229, 1.1951],\n",
       "         [1.1951, 2.2475]]),\n",
       " tensor([[3.8636, 0.9178],\n",
       "         [0.9178, 1.7540]])]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.manual_seed(2)\n",
    "n_samples = 5000\n",
    "toy_mog = toy_mog_2d()\n",
    "samples_mog = toy_mog.sample(n_samples)\n",
    "samples_np = samples_mog.numpy()\n",
    "samples_normal_approx = MultivariateNormal(samples_mog.mean(dim=0), samples_mog.T.cov()).sample((n_samples,)).numpy()\n",
    "\n",
    "densities = [samples_np, samples_normal_approx, samples_np[-200:]]\n",
    "[torch.Tensor(d).T.cov() for d in densities]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "5a6eec0c-3492-46cd-9613-4723eda2cdc5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x200 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "n_plot = 10\n",
    "samples_to_plot = samples_np[0:10,:]\n",
    "\n",
    "al=0.8\n",
    "ms=10\n",
    "mec='k'\n",
    "\n",
    "\n",
    "samples_plot = [samples_np[:10], samples_normal_approx[10:20], samples_np[-10:]]\n",
    "titles = [r'$p_{true}(x)$', r'$p_{1}(x)$', r'$p_{2}(x)$']\n",
    "cmaps = ['Blues', 'Reds', 'Greens']\n",
    "\n",
    "with mpl.rc_context(fname='../matplotlibrc'):\n",
    "    fig, axs = plt.subplots(ncols=3, nrows=1, figsize=(6,2))\n",
    "    for i_a, ax in enumerate(axs):\n",
    "        density, samples, cmap, title = densities[i_a], samples_plot[i_a], cmaps[i_a], titles[i_a]\n",
    "        sns.kdeplot(x=density[:,0], y=density[:,1], fill=True, thresh=0.05, levels=10, cmap=cmap, ax=ax, alpha=al)\n",
    "        ax.plot(samples[:, 0], samples[:, 1], 'w.', ms=ms, mec=mec, alpha=0.8)\n",
    "        ax.set_xticks([]); ax.set_yticks([])\n",
    "        if i_a==0:\n",
    "            ax.spines['left'].set_bounds(-7, -5)\n",
    "            ax.spines['bottom'].set_bounds(-7, -5)\n",
    "            ax.set_xlabel('dim1', loc='left', fontsize=12); \n",
    "            ax.set_ylabel('dim2', loc='bottom', fontsize=12)\n",
    "        else:\n",
    "            ax.spines['left'].set_visible(False)\n",
    "            ax.spines['bottom'].set_visible(False)\n",
    "        \n",
    "        ax.set_title(title, fontsize=12);\n",
    "        ax.set_xlim([-7,4]); ax.set_ylim([-7,4])\n",
    "    fig.tight_layout(pad=0, w_pad=1)\n",
    "    fig.savefig('../plots/schematic.png', dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cd3f9225-ea54-49e8-9dee-8d674d2518a0",
   "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.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
