{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 175,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.distributions as D\n",
    "from scipy.stats import truncnorm\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 176,
   "metadata": {},
   "outputs": [],
   "source": [
    "p = truncnorm(-2, 2, 0, 0.1)\n",
    "q = 1/4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "metadata": {},
   "outputs": [],
   "source": [
    "p_samples = p.rvs(100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([-0.10628752,  0.14857157, -0.03993252, -0.0475222 , -0.08445995,\n",
       "       -0.03299002,  0.10164827, -0.01174027, -0.03774666, -0.00641023,\n",
       "        0.02710673, -0.08566941, -0.06350307,  0.0338938 ,  0.14764908,\n",
       "       -0.02265916,  0.12538713, -0.09023016,  0.03766629, -0.01807638,\n",
       "       -0.05407361, -0.11481331, -0.12059854,  0.03215679, -0.09331335,\n",
       "       -0.16067447, -0.10797036,  0.11673653, -0.09885559,  0.05246647,\n",
       "       -0.02604798,  0.10102001, -0.12948303,  0.04356655,  0.00253742,\n",
       "        0.04203289,  0.03553118, -0.08287669, -0.00093462, -0.01759008,\n",
       "       -0.11256679,  0.04507452,  0.08436414, -0.17924651,  0.10961439,\n",
       "       -0.08335183,  0.09287538,  0.06837558, -0.00826823, -0.04499608,\n",
       "        0.15076971, -0.10706447,  0.14213624, -0.1212425 ,  0.19947108,\n",
       "        0.01731734,  0.06932572,  0.05494678,  0.11389684,  0.10376565,\n",
       "        0.0114351 ,  0.00557176,  0.14289737,  0.04340966,  0.09552392,\n",
       "       -0.04599498,  0.11965326, -0.12456519, -0.05419851,  0.02185005,\n",
       "       -0.09897943, -0.03343034, -0.16528803, -0.14368109,  0.00901066,\n",
       "        0.01063182,  0.05916485,  0.16744164,  0.15879267, -0.01111561,\n",
       "        0.09028844, -0.10820943,  0.14313797, -0.08076882, -0.10527754,\n",
       "       -0.16595915,  0.06935557, -0.07041198,  0.09896662, -0.04287235,\n",
       "        0.02080841,  0.18111544,  0.1156486 , -0.06437954, -0.13613855,\n",
       "       -0.18708494, -0.04926824,  0.11659771, -0.03958153,  0.0292929 ])"
      ]
     },
     "execution_count": 178,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ceJEJk6cyK9+9SsAZs6cyeTJkznttNNYtGhR0cd76KGH+MAHPsCZZ57JF77wBfr6vNf/9773PU466SSmTp3K6tWrA/1+OUrgEo3DA5ZlipM6rkrugGUtRowtfXuzVacUW7QspCqdStYD7+7uZvny5WzatImuri5uuukmAK699lqmTp3Khg0beP755znttNMAWLx4MWvXrqWzs5N7772XPXv29Hu8F198kR/84AesXr2a9evXk8lkePjhh9m5cyc333wzq1ev5sknn+S3v/1t4N8PlMAlCl1LswN4JbS0el0LzZS8oXw/f7NVp/j9viFch0rWAz/66KMZOnQon/vc51i2bNnhHXueeuqpw4tfZTIZRowYAcC9997LxIkTmTJlCtu2beOll17q93irVq1i7dq1vP/97+fMM89k1apV/OEPf+C5557jvPPOo62tjSFDhvDJT34y8O8HSuAShcdvoGTL2zLp7POuRPssb50XP+Va6Gnj9/uGcB0qWQ988ODB/PrXv+bjH/84K1asYPr06QPOyXn66af52c9+xpo1a9iwYQOTJk3iwIED/c5xzjF79mzWr1/P+vXr2bx5MwsWLPB9/qCUwCVcXUvLTCk3b7JLMybvnNmPFk/iaavEqUSxtWRCug659cAB3/XA//znP7Nv3z4uuugi7r77btavX++FNW0a3/72twHo6+vjj3/8I/v27WPUqFEMGzaM3/3udzz77LMDf51p03jkkUfYtctboLW7u5tXXnmFs88+m6effpo9e/bQ29vLD3/4w8C/HyiBS9jK9V12XNncyTtn9qP9q1PiulhX1NpnRbZoWSXrgf/pT39ixowZtLe3M3XqVO666y4A7rnnHn7+859zxhlnMHnyZDZt2sT06dM5ePAg7e3tfO1rX2PKlCkDHu/UU0/l1ltv5SMf+Qjt7e2cf/757Ny5k+OOO44FCxZwzjnn8OEPf5izzjor8O8HYPWcAd/R0eE6Ozvr9nzSAAtG4tt90mwDlrUq3NYtYRN9XnzxRU455ZSGxrB161ZmzJiRyBUJi10/M1vrnOsoPFczMSW4/A0Z/LSOVvKuROFeoLmyOkhUEpf6UAKXYCpZ36Sl1VtCVcrzK6vTzj5VKbYe+GWXXcaWLVv6Hbvjjju44IIL6hlaqJTAJRi/DRkAr08zeV0ADeVXPuf6EtUSd87Fbhf45cuX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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_pdf = p.pdf(p_samples)\n",
    "p_scaled_pdf = p_pdf / q\n",
    "\n",
    "plt.scatter(p_samples, p_pdf, label='p')\n",
    "plt.scatter(p_samples, p_scaled_pdf, label='p_scaled')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(100,)"
      ]
     },
     "execution_count": 184,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_pdf.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "'Rectangle' object has no property 'normed'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-185-e73dd33f8e3e>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp_pdf\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnormed\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'p'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      2\u001b[0m \u001b[0;31m# plt.hist(p_scaled_pdf, normed=True, label='p_scaled')\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlegend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshow\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/matplotlib/pyplot.py\u001b[0m in \u001b[0;36mhist\u001b[0;34m(x, bins, range, density, weights, cumulative, bottom, histtype, align, orientation, rwidth, log, color, label, stacked, data, **kwargs)\u001b[0m\n\u001b[1;32m   2683\u001b[0m         \u001b[0morientation\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'vertical'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrwidth\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlog\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mFalse\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcolor\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2684\u001b[0m         label=None, stacked=False, *, data=None, **kwargs):\n\u001b[0;32m-> 2685\u001b[0;31m     return gca().hist(\n\u001b[0m\u001b[1;32m   2686\u001b[0m         \u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbins\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mbins\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdensity\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdensity\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mweights\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mweights\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2687\u001b[0m         \u001b[0mcumulative\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcumulative\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbottom\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mbottom\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhisttype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mhisttype\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/matplotlib/__init__.py\u001b[0m in \u001b[0;36minner\u001b[0;34m(ax, data, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1445\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0minner\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1446\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mdata\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1447\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0mmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msanitize_sequence\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1448\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1449\u001b[0m         \u001b[0mbound\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnew_sig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbind\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/matplotlib/axes/_axes.py\u001b[0m in \u001b[0;36mhist\u001b[0;34m(self, x, bins, range, density, weights, cumulative, bottom, histtype, align, orientation, rwidth, log, color, label, stacked, **kwargs)\u001b[0m\n\u001b[1;32m   6813\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0mpatch\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   6814\u001b[0m                 \u001b[0mp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpatch\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 6815\u001b[0;31m                 \u001b[0mp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   6816\u001b[0m                 \u001b[0;32mif\u001b[0m \u001b[0mlbl\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   6817\u001b[0m                     \u001b[0mp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_label\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlbl\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/matplotlib/artist.py\u001b[0m in \u001b[0;36mupdate\u001b[0;34m(self, props)\u001b[0m\n\u001b[1;32m    994\u001b[0m                     \u001b[0mfunc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mgetattr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34mf\"set_{k}\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    995\u001b[0m                     \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0mcallable\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfunc\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 996\u001b[0;31m                         raise AttributeError(f\"{type(self).__name__!r} object \"\n\u001b[0m\u001b[1;32m    997\u001b[0m                                              f\"has no property {k!r}\")\n\u001b[1;32m    998\u001b[0m                     \u001b[0mret\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mAttributeError\u001b[0m: 'Rectangle' object has no property 'normed'"
     ]
    },
    {
     "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(p_pdf, normed=True, label='p')\n",
    "plt.hist(p_scaled_pdf, normed=True, label='p_scaled')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 515,
   "metadata": {},
   "outputs": [],
   "source": [
    "p = D.normal.Normal(0, 0.000001)\n",
    "q = D.normal.Normal(0, 1)\n",
    "p1 = D.normal.Normal(-2, 0.2)\n",
    "q1 = D.normal.Normal(2, 0.2)\n",
    "m1 = D.cauchy.Cauchy(0, 1.0)\n",
    "# m2 = D.cauchy.Cauchy(0, 1.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 491,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(13.3155)\n",
      "tensor(200.)\n"
     ]
    }
   ],
   "source": [
    "print(torch.distributions.kl.kl_divergence(p,q))\n",
    "print(torch.distributions.kl.kl_divergence(p1, q1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 543,
   "metadata": {},
   "outputs": [],
   "source": [
    "p_samples = p.sample([1000])\n",
    "q_samples = q.sample([1000])\n",
    "p1_samples = p1.sample([1000])\n",
    "q1_samples = q1.sample([1000])\n",
    "m_samples = m1.sample([1000])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 496,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([-6.1435e-01, -3.2345e-01, -1.1850e+00,  1.1668e-01,  1.9991e+00,\n",
       "         1.2204e+00, -1.9134e-01,  1.3461e+00, -6.4799e-03,  1.3534e+00,\n",
       "         4.7377e-01,  1.8903e+00,  8.9598e-01,  7.1356e-01,  1.3620e+00,\n",
       "        -3.6831e-01, -3.2213e-01, -3.6893e-01,  2.0182e-01, -5.4263e-01,\n",
       "        -1.7081e+00, -1.7290e+00,  1.8375e+00, -1.6187e-01, -1.3248e+00,\n",
       "        -1.3781e-01, -2.0092e+00,  2.3506e+00,  8.5899e-01, -1.0583e+00,\n",
       "         1.3011e-01, -6.5692e-01,  1.1274e+00, -3.9219e-01, -2.2941e+00,\n",
       "        -5.8621e-01, -9.4151e-01,  2.9185e-01, -3.0042e-01, -7.2276e-01,\n",
       "        -2.5790e-01,  1.0671e+00,  8.4841e-01,  3.8959e-01,  2.0954e-01,\n",
       "        -8.9652e-01,  2.3106e+00, -1.0814e-01, -8.9434e-01, -7.2663e-01,\n",
       "        -3.1426e-01, -1.4550e+00, -3.2270e-01, -9.1440e-01, -4.9068e-01,\n",
       "         8.1841e-02,  1.7418e-01,  1.3419e+00, -5.2455e-01, -5.1438e-01,\n",
       "        -1.9536e+00,  9.0933e-01,  1.6248e-01, -1.5648e+00, -2.7095e-01,\n",
       "         1.6948e+00,  2.5683e-01,  1.5901e+00, -1.4056e+00, -6.4301e-01,\n",
       "         1.0340e+00,  7.3097e-01,  3.6837e-01,  1.6084e-01, -5.1826e-01,\n",
       "         1.2299e+00,  4.4533e-01,  9.1205e-01,  1.5414e+00, -9.4095e-01,\n",
       "         1.6367e+00, -2.6944e-01,  5.1019e-01, -7.9157e-01, -2.9750e-01,\n",
       "        -1.0480e+00, -8.1974e-01, -7.0875e-01,  9.1626e-01,  1.3357e+00,\n",
       "        -1.3912e+00, -1.7501e-01, -1.6958e+00, -3.3705e-01,  5.9779e-01,\n",
       "         1.0639e-01,  1.3978e+00,  1.5609e+00,  6.6848e-01,  4.6015e-01,\n",
       "         3.6937e-01,  1.0782e+00, -1.3294e-01, -9.8308e-01, -6.7777e-01,\n",
       "         1.4794e+00, -1.1339e+00, -3.5408e-01, -1.3018e-01, -2.2545e+00,\n",
       "         2.7844e-01,  1.8786e+00, -7.2131e-01,  8.0194e-01,  6.0765e-02,\n",
       "        -2.5692e-01,  1.7149e+00, -4.0779e-01,  5.7232e-01, -1.9582e+00,\n",
       "        -8.3690e-01, -1.4140e+00,  5.0646e-02,  6.4233e-02, -3.1593e-01,\n",
       "        -1.2068e+00, -4.3518e-01,  8.4592e-02,  2.3939e-01,  8.2261e-01,\n",
       "         4.6827e-02,  3.7744e-02, -1.5736e+00,  6.3312e-01, -1.7795e+00,\n",
       "        -1.0696e-03,  8.9123e-02, -3.3298e-01,  5.8814e-01, -7.2229e-02,\n",
       "         1.2983e+00,  1.6545e+00, -1.4299e+00, -8.3606e-01,  3.5693e-01,\n",
       "         5.4544e-01, -7.0824e-01, -1.4838e-01,  3.8698e-01,  7.8562e-01,\n",
       "         6.7267e-01,  8.0221e-01, -1.0972e+00,  2.5936e-01, -5.8979e-01,\n",
       "        -1.9294e-01,  2.0451e+00, -1.3088e+00, -1.9682e-01,  1.4932e+00,\n",
       "         2.2605e-01, -1.0387e+00, -8.1603e-01,  1.3448e+00, -7.8728e-01,\n",
       "        -4.5811e-01, -1.0892e+00,  1.7971e-01, -1.0499e+00, -2.3597e+00,\n",
       "        -1.2348e-01, -1.3573e+00,  1.0801e+00, -6.8363e-01, -2.6963e-01,\n",
       "        -9.7505e-01,  2.7884e-02, -2.3989e+00, -9.0037e-01,  4.7169e-02,\n",
       "         7.9963e-01, -1.7212e+00,  4.2338e-02,  5.9809e-01, -1.7040e+00,\n",
       "         1.4138e+00,  1.8878e+00, -7.9199e-01, -1.5560e-01,  5.1385e-01,\n",
       "        -1.1162e-01,  1.2121e+00,  8.9805e-01, -1.0497e+00, -5.3028e-01,\n",
       "        -1.1420e-01,  1.2042e+00,  4.9973e-02,  1.0788e+00,  2.3804e+00,\n",
       "         1.4294e-04, -1.4069e-01,  5.6616e-01,  2.9124e-02, -1.4205e+00,\n",
       "        -2.3261e-02,  9.0276e-01,  2.0042e-02,  1.0844e+00, -1.5104e+00,\n",
       "         2.0491e+00,  2.2319e+00,  5.5696e-01,  7.8018e-01, -1.8910e-01,\n",
       "         1.1591e+00, -9.4371e-01,  4.8174e-01,  1.6448e+00, -6.9427e-02,\n",
       "        -1.3923e-01,  5.2096e-02, -1.5830e-01, -6.3847e-01, -1.6844e-01,\n",
       "        -2.3426e-01,  2.0698e-01,  2.5090e-01, -8.3530e-02, -2.0516e-01,\n",
       "        -1.3813e+00,  5.7979e-01, -2.3469e+00, -7.3061e-02,  2.1102e-01,\n",
       "        -1.2985e+00, -8.8739e-01, -2.1118e-01, -8.9829e-02, -1.9911e-01,\n",
       "         2.3952e-02, -1.8142e-01, -3.3434e-01, -5.0070e-02,  2.7114e+00,\n",
       "         1.2079e-01,  3.3597e-02,  1.0551e+00, -1.7873e+00,  9.4342e-01,\n",
       "        -1.5128e+00, -3.2019e-02,  8.0983e-01, -1.1684e+00,  1.9880e+00,\n",
       "         9.1333e-03, -7.3602e-01, -1.5565e+00,  5.7344e-01,  4.9400e-01,\n",
       "         5.3892e-01,  9.2398e-01, -1.2778e+00,  4.1315e-01,  2.7465e+00,\n",
       "        -6.9936e-01, -1.9098e-01,  2.8284e-01, -6.3556e-02, -1.8039e+00,\n",
       "        -1.1040e+00, -1.3839e+00,  9.9669e-02, -2.2452e+00, -2.3513e-01,\n",
       "        -2.7229e+00,  1.6816e+00,  4.5021e-01,  4.1327e-01,  2.9415e-01,\n",
       "        -9.0669e-01, -1.9711e-02, -2.7477e-01, -1.0898e+00, -1.0963e+00,\n",
       "         8.5111e-01,  4.1928e-01, -4.2999e-01, -1.1875e-01,  1.3977e+00,\n",
       "         1.5655e+00,  1.5787e+00, -1.0778e+00, -1.6086e+00,  5.5134e-01,\n",
       "         5.8307e-02, -1.0806e+00, -2.3854e-01,  6.9650e-01,  1.5631e+00,\n",
       "         1.7880e-01, -2.1018e-01, -2.8167e-01, -1.3992e-01,  7.5622e-01,\n",
       "         9.4038e-01,  4.1516e-01, -4.0164e-01, -7.0191e-01,  9.7356e-01,\n",
       "         2.4229e-02, -8.7578e-01, -7.5980e-02,  1.0387e+00, -2.8116e-01,\n",
       "         4.3065e-01, -6.7386e-01, -6.8399e-01, -7.9192e-01, -8.3309e-01,\n",
       "         2.1605e-01, -6.6083e-02, -1.6551e-01, -1.2811e+00, -1.9219e-01,\n",
       "        -1.4042e+00, -1.7240e-01, -1.2037e+00,  1.9769e+00,  8.2088e-01,\n",
       "         2.8066e-01, -1.2119e+00, -1.0697e-01, -1.8864e-02,  1.2909e+00,\n",
       "        -4.8686e-01,  3.9893e-01,  9.1096e-01, -9.1049e-01,  5.5124e-01,\n",
       "         1.2073e+00,  9.2830e-01,  1.9131e+00, -1.6572e+00, -4.7001e-01,\n",
       "         1.7339e-01,  7.7592e-01,  1.0848e+00, -7.9428e-01,  1.9353e-01,\n",
       "         1.0514e+00,  2.9841e-01, -1.7885e+00,  2.0977e+00,  7.9107e-02,\n",
       "        -4.8807e-01, -4.9368e-01, -1.5762e-01,  1.8600e+00,  1.5297e+00,\n",
       "         4.8609e-01, -7.1688e-01, -6.1094e-01,  8.1569e-02, -8.1299e-01,\n",
       "         3.3529e-02, -2.3741e+00, -5.5595e-01, -2.0714e+00,  1.5160e+00,\n",
       "        -9.3885e-01, -3.1056e-01, -1.0333e+00, -4.8601e-01,  2.7617e-01,\n",
       "         3.1688e-01, -2.5841e-01, -1.0411e+00, -2.9298e+00, -4.2510e-01,\n",
       "        -1.0893e+00, -1.1039e+00,  4.0137e-01, -4.1075e-01, -4.5968e-01,\n",
       "         7.5911e-02,  7.7706e-01,  1.1499e+00, -4.6845e-01,  6.9911e-01,\n",
       "        -3.0412e-01, -6.9889e-02, -1.3347e+00, -2.9212e-01, -5.6165e-01,\n",
       "         1.9337e-01, -3.7954e-01,  1.8132e+00,  9.8254e-01, -3.7805e-01,\n",
       "        -1.0631e+00, -7.9638e-02, -5.1352e-01, -1.4231e+00,  1.8374e-01,\n",
       "         9.9003e-01,  1.0742e-01, -3.8646e-01, -4.3043e-01, -8.0088e-01,\n",
       "        -6.0066e-02,  6.8891e-02, -7.6191e-01, -1.2066e+00, -5.6359e-01,\n",
       "         2.2938e-02,  4.8516e-01,  6.2056e-01, -3.5432e-01,  1.9689e-01,\n",
       "         7.4072e-01, -1.4483e+00,  1.2700e-01,  8.6044e-01,  5.6514e-01,\n",
       "         3.8537e-01,  2.5324e-01,  4.9173e-01, -1.0331e+00, -4.6981e-01,\n",
       "        -9.0193e-01,  1.4933e+00, -1.2674e+00,  6.5990e-01, -1.0079e+00,\n",
       "         7.3112e-01,  6.1766e-01, -5.1436e-02,  3.4654e-01,  4.2927e-01,\n",
       "         2.8641e-01,  1.3867e+00,  5.2557e-01, -1.5904e+00, -5.5530e-01,\n",
       "         2.2682e+00, -3.3732e-01, -1.2648e+00, -1.8643e+00, -9.0220e-01,\n",
       "        -5.8964e-01, -4.1410e-01,  1.5083e+00,  6.2778e-01,  6.8565e-01,\n",
       "         2.6922e-02,  1.2627e+00, -3.4067e-01,  1.8786e+00,  7.7603e-02,\n",
       "        -2.1919e+00,  2.6494e-02, -1.9368e+00, -7.5969e-02,  3.5422e-01,\n",
       "        -2.0964e+00,  1.1410e+00, -7.8427e-01, -2.4905e-01,  1.3163e+00,\n",
       "         6.7543e-01,  1.1440e+00,  3.6377e-01, -1.0202e+00, -1.1934e+00,\n",
       "        -2.8817e-01,  2.0207e-01, -1.1147e+00,  3.0026e-02,  3.5373e-01,\n",
       "         2.5069e-01, -1.2841e+00, -3.3689e-01, -2.4947e-01,  2.8915e-01,\n",
       "         1.9026e+00, -4.7325e-01, -6.3396e-01,  1.2657e+00,  6.2319e-01,\n",
       "        -2.3273e-01,  3.9298e-01,  1.8057e-01,  4.4045e-01, -2.1987e+00,\n",
       "        -3.2369e-01,  1.8587e+00, -8.2882e-01,  2.3779e-01,  5.0135e-01,\n",
       "         2.9361e-01, -1.6766e+00, -6.4302e-01, -3.9254e-01,  7.1443e-01,\n",
       "        -1.0901e+00,  1.2409e+00,  4.8078e-01,  1.0498e+00, -1.3524e+00,\n",
       "        -8.4112e-01,  3.1595e-01, -1.1289e+00,  5.8963e-01,  8.1723e-01,\n",
       "        -8.9303e-01,  8.3510e-02, -7.1123e-02,  5.4261e-01,  1.3112e-02,\n",
       "         8.2809e-01, -6.7745e-01, -2.4097e+00, -3.3179e+00, -3.5466e-01,\n",
       "        -8.0772e-01, -1.4604e-01, -4.3790e-01,  3.9957e-01,  6.1917e-01,\n",
       "        -5.0335e-02, -1.0442e+00,  7.5264e-01, -1.0846e+00, -1.8124e+00,\n",
       "        -7.4278e-03, -1.7087e+00, -1.5652e+00,  4.0383e-01, -1.4909e+00,\n",
       "         1.4475e+00,  4.3452e-01, -8.8272e-01, -1.3249e-01,  1.4117e+00,\n",
       "         1.4541e+00, -1.5656e+00,  1.1442e+00, -4.0098e-01, -2.4731e+00,\n",
       "         1.6861e+00,  3.1843e-01, -9.1346e-02, -1.8562e-01,  1.9593e+00,\n",
       "         6.8292e-01,  1.8890e+00, -5.2710e-02,  5.5228e-01,  1.5400e-01,\n",
       "        -5.1594e-01, -7.6130e-01,  2.5000e+00, -7.9810e-01, -4.4321e-01,\n",
       "        -1.4020e+00, -8.9830e-01,  3.8080e-01, -4.4404e-01,  5.6637e-01,\n",
       "        -9.5422e-01, -7.1529e-01, -1.0475e+00,  7.0211e-01,  5.2813e-01,\n",
       "        -5.0907e-01, -8.0389e-01,  4.7325e-02,  4.2108e-01,  7.7966e-02,\n",
       "         7.1136e-01, -3.1159e-01,  1.4907e+00,  6.3089e-01,  7.3585e-02,\n",
       "         9.7968e-01, -7.6845e-01, -1.9634e+00,  6.2159e-02,  8.4905e-01,\n",
       "        -4.9897e-01,  1.3859e-01,  4.6290e-01,  9.7095e-01, -1.5375e+00,\n",
       "         9.2201e-01, -9.4383e-01,  1.5291e-01, -6.0747e-01, -4.3058e-01,\n",
       "         9.7790e-01,  2.4743e-01, -1.6380e-01,  5.7681e-01, -2.1435e-01,\n",
       "         1.4063e+00, -6.4391e-01,  2.3637e-01, -2.6492e-01,  8.5316e-01,\n",
       "         1.7896e-01,  6.5832e-01,  9.0261e-01,  6.4686e-01,  9.5093e-02,\n",
       "        -5.6925e-01, -1.9009e+00,  1.1419e-01,  2.7082e-01, -1.3145e+00,\n",
       "        -1.7192e+00,  2.1494e+00,  5.3701e-01, -5.9126e-01,  2.5666e-01,\n",
       "         3.3334e-01, -7.7779e-01, -2.5156e-01, -5.3814e-01,  5.2531e-01,\n",
       "        -1.5894e+00, -4.0745e-01,  1.5384e+00,  1.1627e+00, -3.7373e-01,\n",
       "         8.8018e-01,  4.9376e-01, -2.6186e-01,  2.4375e-01,  1.0758e+00,\n",
       "        -8.1926e-01,  6.7997e-01, -1.8555e+00,  1.0408e+00,  1.1434e+00,\n",
       "        -7.8365e-01,  1.7298e+00,  2.8081e-01,  2.6480e-02, -3.7914e-01,\n",
       "        -9.4791e-02,  4.0545e-01, -2.2782e-01,  1.4619e+00, -7.5039e-01,\n",
       "         1.4022e-01,  2.8152e-01,  1.4033e+00, -7.2196e-01,  3.1125e-01,\n",
       "         6.7018e-01, -6.6513e-01, -7.8893e-01, -1.6527e+00, -9.7110e-03,\n",
       "         2.4331e+00, -1.4598e+00,  4.2888e-01, -4.5734e-01,  5.0306e-02,\n",
       "         5.9606e-01, -1.0688e+00,  9.6523e-01, -3.6126e-01, -9.7949e-01,\n",
       "         1.2079e-01, -1.1455e+00, -2.9044e-01,  2.3120e+00,  8.4111e-01,\n",
       "         1.5079e+00, -1.6594e+00,  1.5404e-01,  5.8890e-01,  1.2775e+00,\n",
       "         7.3714e-01, -1.9428e+00,  4.9575e-01, -8.8834e-01,  1.5290e-01,\n",
       "        -3.0099e-01,  2.3176e-01,  1.8024e+00,  1.1086e+00,  2.0453e-01,\n",
       "         1.6646e+00, -1.2890e-01, -7.4248e-01,  2.0473e-01,  7.9160e-01,\n",
       "         7.9144e-01,  9.4527e-03, -1.2394e-01, -9.1980e-01,  6.3590e-01,\n",
       "        -3.1986e-01, -8.7641e-02,  6.7226e-01, -2.3539e-01, -4.7261e-01,\n",
       "         1.0953e-01, -3.8851e-01,  1.6736e-01,  1.6344e-01, -6.0100e-01,\n",
       "        -7.2174e-01, -1.6593e+00, -5.7326e-01,  1.3190e+00,  8.8507e-01,\n",
       "         1.2369e+00, -8.5708e-01, -1.0326e+00, -1.6688e+00, -4.6188e-01,\n",
       "         9.4407e-01,  1.9908e-01, -1.8200e+00,  3.3062e-01, -1.2838e+00,\n",
       "         4.4042e-01, -9.7343e-01,  8.3428e-01,  3.5218e-01, -2.3000e+00,\n",
       "        -2.2585e+00,  8.4780e-01, -1.4759e+00, -1.7351e-01,  1.1068e+00,\n",
       "        -4.8810e-01, -5.7823e-01,  1.2448e+00,  1.1358e+00,  1.7867e+00,\n",
       "         2.5639e-01, -8.9362e-01,  1.3131e-01,  1.0013e+00,  7.2854e-01,\n",
       "         6.8545e-01, -7.1499e-01,  6.9646e-02,  1.5434e+00,  4.1555e-01,\n",
       "         1.4202e+00,  9.0094e-01, -6.0880e-01, -1.2128e+00, -1.3746e+00,\n",
       "         1.7548e+00, -1.2304e+00, -3.0169e-01, -7.3292e-02,  1.5249e+00,\n",
       "        -1.2803e+00,  8.4720e-01, -8.4238e-01,  5.8282e-01, -1.3246e+00,\n",
       "         4.2500e-01,  4.9437e-01,  1.1821e+00,  1.5645e+00,  1.0123e+00,\n",
       "         9.0660e-01,  3.6268e-01, -1.2123e+00, -7.0570e-01, -2.0428e-01,\n",
       "        -2.3087e-01, -7.1122e-01,  3.6073e-01,  6.4377e-01, -8.1458e-01,\n",
       "         8.3140e-01, -1.1724e+00,  1.1606e+00,  7.7156e-02,  8.6121e-03,\n",
       "         2.1470e-02, -1.4583e+00, -1.4237e+00, -5.4458e-01,  4.6376e-01,\n",
       "        -8.3737e-01,  2.3251e+00,  1.7541e+00, -7.6696e-01, -4.2349e-01,\n",
       "         9.8111e-02,  9.0216e-01,  1.3417e+00,  4.4418e-01,  5.4167e-01,\n",
       "        -1.8835e+00, -2.0628e+00, -4.4642e-01, -8.3116e-01,  1.5178e+00,\n",
       "         4.4278e-01, -2.0930e-01, -1.1237e-01, -5.0294e-01,  1.5560e+00,\n",
       "         1.8689e+00, -3.2439e-01,  6.5050e-01,  8.3586e-01,  8.1001e-01,\n",
       "        -1.1270e+00, -1.1326e+00,  9.7770e-01,  2.5258e-01,  1.7276e-01,\n",
       "         9.3868e-02,  8.9856e-01,  1.8547e+00,  3.8556e-03,  2.0383e-01,\n",
       "        -1.5187e+00,  8.1100e-01, -1.6737e+00,  9.9250e-01, -2.0197e-01,\n",
       "        -1.0940e+00, -1.3762e+00, -9.3218e-02,  3.2188e-02,  1.3958e+00,\n",
       "         7.8177e-01,  3.7259e-01,  2.4521e+00, -3.6116e+00, -7.6196e-01,\n",
       "        -7.8895e-01, -7.8905e-01, -5.1845e-01,  3.8083e-02, -7.3900e-01,\n",
       "        -6.3549e-01,  1.1193e+00,  1.4276e+00, -1.2820e+00, -8.1227e-01,\n",
       "         5.0511e-01, -8.3364e-01,  3.6989e-01,  1.1825e+00, -6.3171e-04,\n",
       "         2.6688e-02, -3.9039e-01, -1.1782e+00,  4.2481e-01, -4.8306e-01,\n",
       "        -2.3371e+00, -8.9905e-01, -1.5107e+00,  2.3348e-02,  7.1511e-01,\n",
       "        -8.6994e-01, -7.1071e-01,  9.0702e-01,  1.4852e+00, -1.7609e-01,\n",
       "        -1.5650e+00, -1.2210e+00,  9.6658e-01,  4.3303e-01,  3.1957e-01,\n",
       "        -3.8398e-01, -1.7595e+00, -2.1199e-02,  5.4028e-01,  1.6835e-01,\n",
       "         2.9318e-01,  1.6975e+00,  8.4460e-01,  7.0655e-01,  5.2791e-01,\n",
       "        -4.9749e-01, -1.7688e-01,  1.3988e-01,  1.1794e+00,  6.8959e-01,\n",
       "         9.8061e-02,  1.0275e+00,  6.9901e-03, -3.2421e-01, -5.4801e-01,\n",
       "         1.1733e+00,  6.5279e-01, -1.9254e+00, -7.3282e-01,  1.3246e+00,\n",
       "         2.6563e-01,  3.4050e-01, -8.0974e-01, -1.9681e+00,  1.6760e+00,\n",
       "         1.4100e+00, -8.1522e-03,  8.1877e-01,  1.1494e+00, -1.7089e+00,\n",
       "        -1.8411e+00,  1.6782e+00, -1.1545e+00,  3.5553e-01, -1.1144e-02,\n",
       "        -1.5283e+00,  1.1191e+00, -1.1274e+00, -1.2254e+00, -1.0123e+00,\n",
       "        -3.5793e-01,  6.2645e-01, -1.4327e+00,  1.8511e-01,  5.4226e-01,\n",
       "        -3.5621e-01, -4.0978e-01, -1.0698e-01, -2.7735e-01, -1.5902e-01,\n",
       "        -1.1835e+00,  1.0851e+00, -1.8794e+00, -3.9656e-01,  1.1637e+00,\n",
       "        -2.2361e-01, -1.8816e+00, -4.7873e-01,  1.4960e+00, -1.7671e+00,\n",
       "        -4.6268e-01,  7.2127e-01,  3.5259e-01,  5.2606e-01, -2.0490e-01,\n",
       "        -9.8574e-01,  2.1597e+00,  6.9129e-01, -1.8955e+00,  6.0503e-01,\n",
       "        -3.3782e-01,  9.9567e-01,  1.9076e+00, -1.0471e-01, -6.8102e-01,\n",
       "         1.0116e+00, -1.5172e+00,  1.5439e+00,  1.7654e+00,  8.9279e-01,\n",
       "         1.2562e+00,  1.3049e+00, -1.0350e+00,  4.3561e-01, -7.2088e-02,\n",
       "        -2.0531e+00,  9.8233e-01,  5.5706e-01,  5.3759e-01,  4.2055e-01,\n",
       "         4.5418e-01,  1.4346e+00, -8.8018e-02,  4.7222e-01, -1.2641e+00,\n",
       "         1.5058e+00,  1.6026e-01, -8.0692e-01, -6.8054e-01,  1.5286e+00,\n",
       "        -4.4189e-01,  1.0541e-01,  5.5307e-01,  7.9282e-01,  1.7391e+00,\n",
       "        -5.4740e-01,  1.6617e-01,  1.1552e+00, -2.2599e-01, -8.8537e-01,\n",
       "        -2.4149e+00, -7.7232e-01,  1.1927e+00, -2.5175e-01, -1.9646e-01])"
      ]
     },
     "execution_count": 496,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "q_samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 550,
   "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": [
    "\n",
    "\n",
    "plt.hist(p_samples.numpy(), bins=1, density=True, histtype='stepfilled', label='p')\n",
    "plt.hist(q_samples.numpy(), bins=50000, density=True, histtype='stepfilled', label='q')\n",
    "# plt.hist(m_samples.numpy(), density=True, histtype='stepfilled', label='m')\n",
    "# plt.hist(q1_samples.numpy(), density=True, histtype='stepfilled', label='q2')\n",
    "plt.xlim([-0.002, 0.002])\n",
    "plt.ylim(0, 3.0)\n",
    "plt.legend()\n",
    "plt.savefig('1D_demo_hod_separation.png')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 530,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No handles with labels found to put in legend.\n"
     ]
    },
    {
     "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": [
    "p_q_over_p = p.log_prob(p_samples) - q.log_prob(p_samples)\n",
    "p_q_over_q = p.log_prob(q_samples) - q.log_prob(q_samples)\n",
    "\n",
    "\n",
    "plt.scatter(p_q_over_p, p_q_over_q)\n",
    "# plt.hist(p_q_over_q.numpy(), label='q samples')\n",
    "# plt.hist(p_q_over_p.numpy(), label='p samples')\n",
    "# plt.xlim([0, ])\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 526,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([  1.,   0.,   1.,   3.,  10.,  15.,  21.,  56., 144., 749.]),\n",
       " array([ 7.138718,  7.806391,  8.474063,  9.141736,  9.809408, 10.47708 ,\n",
       "        11.144753, 11.812426, 12.480098, 13.147771, 13.815443],\n",
       "       dtype=float32),\n",
       " <BarContainer object of 10 artists>)"
      ]
     },
     "execution_count": 526,
     "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": []
  },
  {
   "cell_type": "code",
   "execution_count": 416,
   "metadata": {},
   "outputs": [],
   "source": [
    "p = D.normal.Normal(-1, .1)\n",
    "q = D.normal.Normal(1, .2)\n",
    "m1 = D.cauchy.Cauchy(0, 0.2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 417,
   "metadata": {},
   "outputs": [],
   "source": [
    "p_samples = p.sample([1000])\n",
    "p_samples = torch.from_numpy(np.linspace(-2, 2, 1000))\n",
    "# p_samples = m1.sample([1000])\n",
    "p_lp = torch.exp(p.log_prob(p_samples))\n",
    "m_lp = torch.exp(m1.log_prob(p_samples))\n",
    "q_lp = torch.exp(q.log_prob(p_samples))\n",
    "p_m_lp = torch.exp(p.log_prob(p_samples) - m1.log_prob(p_samples))\n",
    "q_m_lp = torch.exp(q.log_prob(p_samples) - m1.log_prob(p_samples))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 421,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fbc730ca280>"
      ]
     },
     "execution_count": 421,
     "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": [
    "\n",
    "plt.bar(p_samples, p_m_lp, label='p/m')\n",
    "plt.bar(p_samples, q_m_lp, label='q/m')\n",
    "plt.bar(p_samples, p_lp, label='p')\n",
    "plt.bar(p_samples, q_lp, label='q')\n",
    "plt.xlim([-3, 1.0])\n",
    "# plt.ylim([0, 1])\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 473,
   "metadata": {},
   "outputs": [],
   "source": [
    "p = D.normal.Normal(-1, 0.5)\n",
    "q = D.normal.Normal(1, .2)\n",
    "m1 = D.cauchy.Cauchy(0, 0.2)\n",
    "\n",
    "# p_samples = p.sample([1000])\n",
    "p_samples = torch.from_numpy(np.linspace(-3, 1, 10000))\n",
    "# p_samples = m1.sample([1000])\n",
    "p_lp = torch.exp(p.log_prob(p_samples))\n",
    "m_lp = torch.exp(m1.log_prob(p_samples))\n",
    "q_lp = torch.exp(q.log_prob(p_samples))\n",
    "p_m_lp = torch.exp(p.log_prob(p_samples) - m1.log_prob(p_samples)) / torch.sum(torch.exp(p.log_prob(p_samples) - m1.log_prob(p_samples)) * 2.0/10000)\n",
    "q_m_lp = torch.exp(q.log_prob(p_samples) - m1.log_prob(p_samples))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 475,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fbc07913e20>"
      ]
     },
     "execution_count": 475,
     "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.bar(p_samples, p_m_lp, width=0.01, label='p/m')\n",
    "# plt.bar(p_samples, p_lp, width=0.1, label='p')\n",
    "plt.xlim([-5, 3.0])\n",
    "plt.ylim([0, 0.25])\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 391,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7fbcaea251f0>"
      ]
     },
     "execution_count": 391,
     "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.scatter(p_samples, p_lp, label='p', s=1)\n",
    "# plt.scatter(p_samples, m_lp, label='m')\n",
    "plt.scatter(p_samples, p_m_lp, label='p/m', s=1)\n",
    "plt.xlim([-3, 3])\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 316,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(3.6091)\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import expon\n",
    "\n",
    "\n",
    "\n",
    "p1 = expon(1\n",
    "q1 = expon(1, loc=30, scale=10, validate_args=None)\n",
    "p1_samples = p1.sample([1000])\n",
    "print((p1.log_prob(p1_samples) - q1.log_prob(p1_samples)).mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 346,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-1.6676)\n"
     ]
    },
    {
     "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": [
    "p1 = torch.distributions.exponential.Exponential(0.65)\n",
    "q1 = torch.distributions.exponential.Exponential(0.55)\n",
    "p1_samples = -1.0 * p1.sample([1000]) + 20\n",
    "q1_samples = q1.sample([1000])\n",
    "print((p1.log_prob(p1_samples) - q1.log_prob(p1_samples)).mean())\n",
    "plt.hist(p1_samples.numpy(), density=True, histtype='stepfilled', label='p1')\n",
    "plt.hist(q1_samples.numpy(), density=True, histtype='stepfilled', label='q1')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 301,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(-98256880.) tensor(98572744.)\n"
     ]
    },
    {
     "ename": "AssertionError",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAssertionError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-301-9ca58d20607a>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[0mq1_samples\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mq1\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msample\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m100000\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      2\u001b[0m \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp1_samples\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mq1_samples\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmin\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 3\u001b[0;31m \u001b[0;32massert\u001b[0m \u001b[0mp1_samples\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmax\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m>\u001b[0m \u001b[0mq1_samples\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmin\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      4\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0;31m# plt.hist(p1_samples.numpy(), density=True, histtype='stepfilled', label='p1')\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mAssertionError\u001b[0m: "
     ]
    }
   ],
   "source": [
    "q1_samples = q1.sample([100000])\n",
    "\n",
    "assert p1_samples.max() > q1_samples.min()\n",
    "\n",
    "# plt.hist(p1_samples.numpy(), density=True, histtype='stepfilled', label='p1')\n",
    "# plt.hist(q1_samples.numpy(), density=True, histtype='stepfilled', label='q2')\n",
    "# plt.ylim([0, 0.00])\n",
    "# plt.legend()\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "x and y must be the same size",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-159-6a32ae2a2994>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp_samples\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mexp\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp_l\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'p'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ms\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1.\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      2\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp_samples\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mexp\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mm_l\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'm'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ms\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1.\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatter\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp_samples\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mexp\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mp_l\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mm_l\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'ratio p'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ms\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1.\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0;31m# plt.scatter(p_samples, np.exp(p_l.numpy() - m_l.numpy()), label='ratio p')\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlegend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/matplotlib/pyplot.py\u001b[0m in \u001b[0;36mscatter\u001b[0;34m(x, y, s, c, marker, cmap, norm, vmin, vmax, alpha, linewidths, verts, edgecolors, plotnonfinite, data, **kwargs)\u001b[0m\n\u001b[1;32m   2888\u001b[0m         \u001b[0mverts\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcbook\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdeprecation\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_deprecated_parameter\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2889\u001b[0m         edgecolors=None, *, plotnonfinite=False, data=None, **kwargs):\n\u001b[0;32m-> 2890\u001b[0;31m     __ret = gca().scatter(\n\u001b[0m\u001b[1;32m   2891\u001b[0m         \u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ms\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0ms\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mc\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmarker\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmarker\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcmap\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcmap\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnorm\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mnorm\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2892\u001b[0m         \u001b[0mvmin\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mvmin\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvmax\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mvmax\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0malpha\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0malpha\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlinewidths\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mlinewidths\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/matplotlib/__init__.py\u001b[0m in \u001b[0;36minner\u001b[0;34m(ax, data, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1445\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0minner\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1446\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mdata\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1447\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0mmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msanitize_sequence\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   1448\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1449\u001b[0m         \u001b[0mbound\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnew_sig\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbind\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/matplotlib/cbook/deprecation.py\u001b[0m in \u001b[0;36mwrapper\u001b[0;34m(*inner_args, **inner_kwargs)\u001b[0m\n\u001b[1;32m    409\u001b[0m                          \u001b[0;32melse\u001b[0m \u001b[0mdeprecation_addendum\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    410\u001b[0m                 **kwargs)\n\u001b[0;32m--> 411\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minner_args\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0minner_kwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    412\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    413\u001b[0m     \u001b[0;32mreturn\u001b[0m \u001b[0mwrapper\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/disk_c/han/ananconda3/envs/torch1.8/lib/python3.8/site-packages/matplotlib/axes/_axes.py\u001b[0m in \u001b[0;36mscatter\u001b[0;34m(self, x, y, s, c, marker, cmap, norm, vmin, vmax, alpha, linewidths, verts, edgecolors, plotnonfinite, **kwargs)\u001b[0m\n\u001b[1;32m   4439\u001b[0m         \u001b[0my\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mma\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mravel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   4440\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m \u001b[0;34m!=\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 4441\u001b[0;31m             \u001b[0;32mraise\u001b[0m \u001b[0mValueError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"x and y must be the same size\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m   4442\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   4443\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0ms\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mValueError\u001b[0m: x and y must be the same size"
     ]
    },
    {
     "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.scatter(p_samples, np.exp(p_l.numpy()), label='p', s=1.)\n",
    "plt.scatter(p_samples, np.exp(m_l.numpy()), label='m', s=1.)\n",
    "plt.scatter(p_samples, np.exp(p_l.numpy() - m_l.numpy()), label='ratio p', s=1.)\n",
    "# plt.scatter(p_samples, np.exp(p_l.numpy() - m_l.numpy()), label='ratio p')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "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
}
