{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Internal imports\n",
    "import sys; sys.path.insert(0, '..')\n",
    "from src import *\n",
    "\n",
    "import torch\n",
    "import torch.distributions as D\n",
    "from scipy.linalg import block_diag\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "p1 = D.normal.Normal(-5, 1)\n",
    "q1 = D.normal.Normal(5, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(50.)"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "D.kl.kl_divergence(p1,q1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "metadata": {},
   "outputs": [],
   "source": [
    "p2 = D.normal.Normal(0, 1)\n",
    "q2 = D.normal.Normal(0, 9.7e-2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(50.3076)"
      ]
     },
     "execution_count": 163,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "D.kl.kl_divergence(p2,q2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [],
   "source": [
    "p3 = D.normal.Normal(-1.5, 0.5)\n",
    "q3 = D.normal.Normal(1, 0.25)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(50.8069)"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "D.kl.kl_divergence(p3,q3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set up viz\n",
    "fig, [ax1,ax2,ax3] = plt.subplots(3, 1,figsize=(4,4))\n",
    "\n",
    "p1_samples = p1.sample([1000])\n",
    "\n",
    "q1_samples = q1.sample([1000])\n",
    "\n",
    "\n",
    "p2_samples = p2.sample([1000])\n",
    "\n",
    "q2_samples = q2.sample([1000])\n",
    "\n",
    "p3_samples = p3.sample([1000])\n",
    "\n",
    "q3_samples = q3.sample([1000])\n",
    "\n",
    "ax1.hist(p1_samples.numpy(), density=True, histtype='stepfilled', color='green', label='p')\n",
    "ax1.hist(q1_samples.numpy(), density=True, histtype='stepfilled', color='orange', label='q')\n",
    "ax1.set_xlim(-7.5, 7.5)\n",
    "ax1.set_ylim(0, 2)\n",
    "ax1.set_title('FOD Only')\n",
    "\n",
    "ax2.hist(q2_samples.numpy(), density=True, histtype='stepfilled', color='orange', label='q')\n",
    "ax2.hist(p2_samples.numpy(), density=True, histtype='stepfilled', color='green', label='p')\n",
    "\n",
    "ax2.set_xlim(-7.5, 7.5)\n",
    "ax2.set_ylim(0, 2)\n",
    "ax2.set_title('HOD Only')\n",
    "\n",
    "ax3.hist(q3_samples.numpy(), density=True, histtype='stepfilled', color='orange', label='q')\n",
    "ax3.hist(p3_samples.numpy(), density=True, histtype='stepfilled', color='green', label='p')\n",
    "ax3.set_xlim(-7.5, 7.5)\n",
    "ax3.set_ylim(0, 2)\n",
    "ax3.set_title('FOD + HOD')\n",
    "# ax3.hist(p3_samples)\n",
    "\n",
    "\n",
    "ax1.get_xaxis().set_visible(False)\n",
    "ax2.get_xaxis().set_visible(False)\n",
    "ax1.get_yaxis().set_visible(False)\n",
    "ax2.get_yaxis().set_visible(False)\n",
    "ax3.get_yaxis().set_visible(False)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.subplots_adjust(wspace=0, hspace=0.3)\n",
    "ax1.legend()\n",
    "plt.draw()\n",
    "plt.savefig('fod_hod.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.hist(p2_samples.numpy(), bins=1, density=True, histtype='stepfilled')\n",
    "ax.hist(q2_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([-9.3022e-24, -4.5362e-23,  2.1857e-22,  ..., -7.4994e-23,\n",
       "        -3.2973e-24, -7.6339e-23])"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p2_samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 5.0)"
      ]
     },
     "execution_count": 103,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(p2_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.hist(q2_samples.numpy(), density=True, histtype='stepfilled')\n",
    "plt.ylim([0,5])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "torch1.8",
   "language": "python",
   "name": "torch1.8"
  },
  "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.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
