{
 "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": 490,
   "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": 492,
   "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": 508,
   "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(), density=True, histtype='stepfilled', label='p')\n",
    "plt.hist(q_samples.numpy(), 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.00001, 0.00001)\n",
    "plt.ylim(0, 3.0)\n",
    "plt.legend()\n",
    "# plt.savefig('1D_demo_cauchy_hist.png')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "p_q_over_p = p.log_pdf(p_samples) - q.log_pdf(p_samples)\n",
    "p_q_over_q = p.log_pdf(q_samples) - q.log_pdf(q_samples)"
   ]
  },
  {
   "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": "iVBORw0KGgoAAAANSUhEUgAAAX0AAAD8CAYAAACb4nSYAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAASCElEQVR4nO3df6xc513n8ffHjlNH2YSuXENZ28j+wyWNmjibtZJqQ4FAGuyCarrSSqka2GWx3EiN2EpbQSBSyVIhFQEFihKMCRENoo2QaFR34/woEqhIjcE3xI2Tpo5c1zS3TjeOW1qqKnXcfvljxmG4net7ru/cO3Pv835JI88553lmvjPj+5kzz5zzTKoKSVIbVo27AEnS0jH0Jakhhr4kNcTQl6SGGPqS1BBDX5Ia0in0k+xIcjTJsSR3DNn+riRP9S+fSbJtYNuJJEeSHE4yNcriJUnzk7mO00+yGngOeCswDRwC3llVnxto81+BZ6vqa0l2AndV1fX9bSeA7VX10uI8BElSV1329K8DjlXV8ao6AzwA7BpsUFWfqaqv9RcPAhtHW6YkaRQu6tBmA/D8wPI0cP152v8i8PDAcgGPJSngj6tq37BOSfYAewAuvfTS/3LFFVd0KE2T6siXvz7uEpaFqzZ837hL0ArxxBNPvFRV6+dq1yX0M2Td0DGhJDfSC/0fGVh9Q1WdTPL9wKeSfL6qPv09N9h7M9gHsH379pqacvh/Odt8x0PjLmFZmPrgT4+7BK0QSf6pS7suwzvTwKaB5Y3AySF3eDVwL7Crqk6fW19VJ/v/vgg8SG+4SJI0Bl1C/xCwNcmWJBcDtwD7Bxsk+SHg48DPVdVzA+svTXLZuevAzcDToypekjQ/cw7vVNXZJLcDjwKrgfuq6pkkt/W37wXeD6wD7kkCcLaqtgM/ADzYX3cR8NGqemRRHokkaU5dxvSpqgPAgRnr9g5c3w3sHtLvOLBt5npJWmyvvPIK09PTvPzyy+MuZaTWrl3Lxo0bWbNmzQX17xT6krTcTE9Pc9lll7F582b6ow3LXlVx+vRppqen2bJlywXdhtMwSFqRXn75ZdatW7diAh8gCevWrVvQpxdDX9KKtZIC/5yFPiZDX5Ia4pi+pCaM+oTBEws8se5jH/sYx48f58477xxRRd24py9JY/DII4+wY8eOJb9f9/QlaZGcOHGCHTt2cP311/Pkk0/yhje8gfvvv59LLrmEw4cPc+2113LXXXfxxS9+kRdeeIHnnnuOD33oQxw8eJCHH36YDRs28MlPfvKCD88cxj19aYyco2jlO3r0KHv27OGpp57i8ssv55577uHJJ59k27Ztr34p+4UvfIGHHnqIT3ziE9x6663ceOONHDlyhEsuuYSHHhrt/xH39CVpEW3atIkbbrgBgFtvvZUPf/jDnDlzhp07d77aZufOnaxZs4arrrqK73znO68O+1x11VWcOHFipPW4py9Ji2jmIZZJeOyxx7j55ptfXfea17wGgFWrVrFmzZpX+6xatYqzZ8+OtB5DX5IW0Ze+9CUef/xxoHfEzjXXXMPZs2dZt27dWOpxeEdSExZ6iOWFeuMb38hHPvIR3v3ud7N161be8pa3cNNNN42lFjD0JWlRrVq1ir17X52fkt27d7N797/NT3nXXXf9u/bf/OY3Z902Coa+JC2he++9d6z375i+Rs7DEKWezZs38/TTk/W7UYa+pBWraujPeS9rC31Mhr6kFWnt2rWcPn16RQX/ufn0165de8G34Zi+pBVp48aNTE9Pc+rUqXGXMlLnfjnrQhn6klakNWvWXPCvS61kDu9IUkMMfUlqiKEvSQ0x9CWpIYa+JDXE0Jekhhj6ktQQQ1+SGmLoS1JDDH1JaoihL0kNMfQlqSGGviQ1xNCXxsxfGtNSMvQ1UgaYNNkMfUlqSKfQT7IjydEkx5LcMWT7u5I81b98Jsm2rn0lSUtnztBPshq4G9gJXAm8M8mVM5p9Efixqroa+ACwbx59JUlLpMue/nXAsao6XlVngAeAXYMNquozVfW1/uJBYGPXvpKkpdMl9DcAzw8sT/fXzeYXgYfn2zfJniRTSaZW2g8ZS9Kk6BL6GbKuhjZMbqQX+r8y375Vta+qtlfV9vXr13coS5I0Xxd1aDMNbBpY3gicnNkoydXAvcDOqjo9n76SpKXRZU//ELA1yZYkFwO3APsHGyT5IeDjwM9V1XPz6StJWjpz7ulX1dkktwOPAquB+6rqmSS39bfvBd4PrAPuSQJwtj9UM7TvIj0WSdIcugzvUFUHgAMz1u0duL4b2N21ryRpPDwjV5IaYuhLUkMMfUlqiKEvSQ0x9CWpIYa+JDXE0Jekhhj6ktQQQ18j408lSpPP0Jekhhj6ktQQQ1+aAA6NaakY+pLUEENfkhpi6EtSQwx9SWqIoS9JDTH0Jakhhr4kNcTQl6SGGPqS1BBDX5IaYuhLUkMMfUlqiKGvkXDCMGl5MPQlqSGGviQ1xNCXpIYY+pLUEENfkhpi6EtSQwx9aUJ42KuWgqEvSQ0x9CWpIZ1CP8mOJEeTHEtyx5DtVyR5PMm3k7xvxrYTSY4kOZxkalSFS5Lm76K5GiRZDdwNvBWYBg4l2V9Vnxto9lXgl4CfneVmbqyqlxZYqyRpgbrs6V8HHKuq41V1BngA2DXYoKperKpDwCuLUKMkaUS6hP4G4PmB5en+uq4KeCzJE0n2zNYoyZ4kU0mmTp06NY+blyR11SX0M2RdzeM+bqiqa4GdwHuS/OiwRlW1r6q2V9X29evXz+PmJUlddQn9aWDTwPJG4GTXO6iqk/1/XwQepDdcpBXE48ul5aNL6B8CtibZkuRi4BZgf5cbT3JpksvOXQduBp6+0GIlSQsz59E7VXU2ye3Ao8Bq4L6qeibJbf3te5O8HpgCLge+m+S9wJXA64AHk5y7r49W1SOL8kgkSXOaM/QBquoAcGDGur0D179Cb9hnpm8A2xZSoCRpdDwjV5IaYuhLUkMMfUlqiKEvSQ0x9CWpIYa+JDXE0Jekhhj60gRxSgstNkNfkhpi6EtSQwx9LYjDEdLyYuhLUkMMfUlqiKEvSQ0x9CWpIYa+JDXE0Jekhhj6ktQQQ1+SGmLoS1JDDH1JaoihL0kNMfQlqSGGvi6Yk60tDp9XLSZDX5IaYuhLUkMMfUlqiKEvSQ0x9CWpIYa+JDXE0Jekhhj6ktQQQ1+SGmLoS1JDDH1dEKcKkJanTqGfZEeSo0mOJbljyPYrkjye5NtJ3jefvpKkpTNn6CdZDdwN7ASuBN6Z5MoZzb4K/BLwOxfQV5K0RLrs6V8HHKuq41V1BngA2DXYoKperKpDwCvz7StJWjpdQn8D8PzA8nR/XRed+ybZk2QqydSpU6c63ry0MvmdiRZLl9DPkHXV8fY7962qfVW1vaq2r1+/vuPNS5Lmo0voTwObBpY3Aic73v5C+kqSRqxL6B8CtibZkuRi4BZgf8fbX0hfSdKIXTRXg6o6m+R24FFgNXBfVT2T5Lb+9r1JXg9MAZcD303yXuDKqvrGsL6L9FgkSXOYM/QBquoAcGDGur0D179Cb+imU19J0nh4Rq4kNcTQ17x5OKG0fBn6ktQQQ1+SGmLoS1JDDH1JaoihL0kNMfSlCeVRUloMhr4kNcTQl6SGGPqaF4ccpOXN0Jekhhj6ktQQQ1+SGmLoS1JDDH1JaoihL0kNMfQlqSGGviQ1xNBXZ56YtfR8zjVqhr4kNcTQl6SGGPqS1BBDX5IaYuhLUkMMfUlqiKGvTjx0UFoZDH1JaoihL0kNMfSlCefQmkbJ0Jekhhj6ktQQQ1+SGmLoa06OKUsrR6fQT7IjydEkx5LcMWR7kny4v/2pJNcObDuR5EiSw0mmRlm8JGl+LpqrQZLVwN3AW4Fp4FCS/VX1uYFmO4Gt/cv1wB/1/z3nxqp6aWRVS5IuSJc9/euAY1V1vKrOAA8Au2a02QXcXz0Hgdcm+cER1ypJWqAuob8BeH5gebq/rmubAh5L8kSSPbPdSZI9SaaSTJ06dapDWVI7/F5Fo9Il9DNkXc2jzQ1VdS29IaD3JPnRYXdSVfuqantVbV+/fn2HsiRJ89Ul9KeBTQPLG4GTXdtU1bl/XwQepDdcpGXCPUxpZekS+oeArUm2JLkYuAXYP6PNfuDn+0fxvBn4elW9kOTSJJcBJLkUuBl4eoT1S5LmYc6jd6rqbJLbgUeB1cB9VfVMktv62/cCB4C3AceAbwG/0O/+A8CDSc7d10er6pGRPwpJUidzhj5AVR2gF+yD6/YOXC/gPUP6HQe2LbBGSdKIeEauJDXE0Nes/BJXWnkMfWmZ8E1Yo2DoS1JDDH1JaoihL0kNMfQ1lOPH0spk6EtSQwx9aRnxE5gWytCXpIYY+voe7k1KK5ehL0kNMfQlqSGGvrTMOPymhTD09e8YKNLKZuhLUkMMfUlqiKGvVzm0I618hr60DPkGrQtl6EtSQwx9Ae45Sq0w9KVlyjdqXQhDX4aH1BBDX5IaYuhLy5if0jRfhn7jDA2pLYa+tMz5xq35MPQbZlhI7TH0G2Xgryy+nurK0Jekhhj6DXKvcGXydVUXhn5jDIaVzddXczH0G2IgtGHzHQ/5WmtWF427AC0NQ6A9C33NT3zwp0dUiSaJob/CGfa6UMP+7/hGsPx1Cv0kO4A/AFYD91bVB2dsT3/724BvAf+zqv6xS19Jy8fMNwLfBJafOUM/yWrgbuCtwDRwKMn+qvrcQLOdwNb+5Xrgj4DrO/aVtEzN9knSN4PJ1WVP/zrgWFUdB0jyALALGAzuXcD9VVXAwSSvTfKDwOYOfSWtMF2HFX1zWHpdQn8D8PzA8jS9vfm52mzo2BeAJHuAPf3Fbyd5ukNt4/Q64KVxF9GBdY6WdY5Qfmt51MnyeD5/uEujLqGfIeuqY5sufXsrq/YB+wCSTFXV9g61jc1yqBGsc9Ssc7Ssc3SSTHVp1yX0p4FNA8sbgZMd21zcoa8kaYl0OTnrELA1yZYkFwO3APtntNkP/Hx63gx8vape6NhXkrRE5tzTr6qzSW4HHqV32OV9VfVMktv62/cCB+gdrnmM3iGbv3C+vh3q2nchD2aJLYcawTpHzTpHyzpHp1ON6R1wI0lqgXPvSFJDDH1JashEhn6Su5J8Ocnh/uVt467pfJK8L0kled24axkmyQeSPNV/Lh9L8p/GXdMwSX47yef7tT6Y5LXjrmmYJP89yTNJvptkog7jS7IjydEkx5LcMe56ZpPkviQvTvL5OEk2JfmbJM/2X+//Pe6ahkmyNsk/JPlsv87/e772Exn6fb9XVdf0LwfGXcxskmyiN83El8Zdy3n8dlVdXVXXAP8PeP+Y65nNp4A3VdXVwHPAr465ntk8Dfw34NPjLmTQwLQnO4ErgXcmuXK8Vc3qz4Ad4y5iDmeB/1NVbwTeDLxnQp/PbwM/UVXbgGuAHf2jKIea5NBfLn4P+GVmOelsElTVNwYWL2VCa62qx6rqbH/xIL3zOiZOVT1bVUfHXccQr06ZUlVngHPTnkycqvo08NVx13E+VfXCuYkjq+pfgGfpzTIwUarnm/3FNf3LrH/jkxz6t/c/5t+X5D+Ou5hhkrwd+HJVfXbctcwlyW8meR54F5O7pz/ofwEPj7uIZWa26VC0QEk2A/8Z+PsxlzJUktVJDgMvAp+qqlnrHNt8+kn+Gnj9kE130pul8wP03q0+APwuvRBYcnPU+WvAzUtb0XDnq7OqPlFVdwJ3JvlV4Hbg15e0wL656uy3uZPeR+u/WMraBnWpcwJ1nvZE3SX5D8BfAe+d8al5YlTVd4Br+t+DPZjkTVU19PuSsYV+Vd3UpV2SP6E3Dj0Ws9WZ5CpgC/DZ3s8JsBH4xyTXVdVXlrBEoPvzCXwUeIgxhf5cdSb5H8DPAD9ZYzyJZB7P5yTpMmWK5iHJGnqB/xdV9fFx1zOXqvrnJH9L7/uSoaE/kcM7/WmZz3kHsxQ/TlV1pKq+v6o2V9Vmen9w144j8OeSZOvA4tuBz4+rlvPp/+DOrwBvr6pvjbueZchpT0ao/+NQfwo8W1UfGnc9s0my/tyRbkkuAW7iPH/jE3lGbpI/p/ctdAEngHf35/KZWElOANurauKmX03yV/SmXf0u8E/AbVX15fFW9b2SHANeA5zurzpYVbeNsaShkrwD+ENgPfDPwOGq+qmxFtXXP7z59/m3aU9+c7wVDZfkY8CP05uy+P8Dv15VfzrWomZI8iPA3wFH6P3tAPzapB1NmORq4CP0XvNVwF9W1W/M2n4SQ1+StDgmcnhHkrQ4DH1JaoihL0kNMfQlqSGGviQ1xNCXpIYY+pLUkH8F5DFuEP9Ll6kAAAAASUVORK5CYII=\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": "iVBORw0KGgoAAAANSUhEUgAAAXQAAAD4CAYAAAD8Zh1EAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAAAeB0lEQVR4nO3df5BcdZnv8fczSUMmw88Mo0QSmEAFwQowcIfR3eQKUcgm7JZoGdzLNRSui4Ou3AVLLYGtWtFburIqYFlXIfwQVDZ3QbRAIGy4XH4YFJOBxBA2QCQmIRLJOCEXmCQkkzz3j3M6mXSmp3u6z+nzoz+vqqk+3XO6+2kyPPPM8/1xzN0REZHsa0k6ABERiYYSuohITiihi4jkhBK6iEhOKKGLiOTE+Ea+2THHHOOdnZ2NfEsRkcx79tln/+zuHZXOa2hC7+zspK+vr5FvKSKSeWa2oZrz1HIREckJJXQRkZxQQhcRyYmG9tBFRKKwe/duNm3axM6dO5MOJVITJkxgypQpFAqFmp6vhC4imbNp0yYOP/xwOjs7MbOkw4mEuzMwMMCmTZuYNm1aTa+hlouIZM7OnTtpb2/PTTIHMDPa29vr+qtDCV1EMilPybyo3s+klkve9K+F+z8Hb2yE8YfAx38Ex5+ddFQi0gBK6HkxOABPfBNW3A1DO/Y//qO50P13cO410NaeXHwiEju1XPJi6U2w/Lb9ybzQBi3jwYdg+a1wzyVB0heR3KqY0M1sgpktM7PfmdkLZva18PHrzOyPZrYy/Log/nBlRBuXB0kbYNwEOPszcNXz8KlHYHxr8PiGp+HpG5OLUSRH1q9fzymnnMKll17K6aefzvz589m+fXvSYVVVob8DfMjdzwC6gLlm9oHweze6e1f49XBcQcoo+tfCTz4SVOaFifDZpfDX3wnaK8efDZf/ClonBeeuuDs4X0Tq9tJLL9Hb28uqVas44ogj+MEPfpB0SJUTugfeDu8Wwi9diDQtFn8Zdm8PKvFLHoCO6Qd+v2M6fHpJkNR3bIVFn1DrRZrS1sFd3PLkK2wd3BXJ602dOpWZM2cCsGDBApYuXRrJ69ajqh66mY0zs5XAFuBRd/9t+K0rzGyVmd1hZkfHFaSU0b8Wtq4LjnsuKz+bpWM6dC0Ijreug2W3NCY+kRS5t+9V/mXxi9zb92okr1c6xTAN0yirSujuvsfdu4ApQI+ZzQB+CJxE0IbZDHx3pOeaWa+Z9ZlZX39/fyRBC0GVvegTsG0DTDoJZn5h9PNnXQUn/GVwvH6pqnRpOhd1T+WaeadwUffUSF5v48aN/OY3vwFg0aJFzJo1K5LXrceYZrm4+zbgCWCuu78eJvq9wK1AT5nnLHT3bnfv7uiouD+7VGvZwv3V+SkXVJ6S2NYOnR8Mjjc8rSpdms6ktkO4/JyTmNR2SCSvd+qpp3LXXXdx+umns3XrVj73uc9F8rr1qDgP3cw6gN3uvs3MWoHzgOvNbLK7bw5P+xiwOsY4pdTucET9hJmVq/Oinl5Y/xRs+PX+Kl1z00Vq0tLSws0335x0GAeopkKfDDxuZquA5QQ99AeBfzWz58PHZwNVZhWpW/9aePHB4LhzVvVJWVW6SK5VrNDdfRVw5giPXxJLRFLZ4i8H7ZZJJ0HP5WN77vAqffeOyueLyEE6OztZvTp9TQmtFM2awQHY805wXE3vvNTwKv1Pz2twVCRHlNCzZtnCoLo+cXb1vfNSPb1w4rmw7nG1XURyRAk9a4qDoceeVvuAZls7HHt6+Hpqu4jkhRJ6lgwOwJ9WBceF1vpeqzAxuFXbRSQ3lNCzZNlCWPdE0G4Z62BoKbVdRGKxaNEivvGNbyTy3kroWRJFu6VIbReRWDzyyCPMnTs3kffWBS6yIsp2S1Fp20WLjESqsn79eubOncv73/9+VqxYwcknn8yPf/xjWltbWblyJWeddRbXXXcdf/jDH9i8eTMvv/wyN9xwA8888wyLFy/muOOO45e//CWFQiHSuFShZ0WU7ZYitV1EajbS9rkrVqzgjDPO2LdR1yuvvMJDDz3E/fffz4IFC5g9ezbPP/88ra2tPPTQQ5HHpISeFVG2W4ra2mFquLX9q8s0OCr5NjgAT38vsp/zkbbPfeSRR5g3b96+c+bNm0ehUOC0005jz549+1oxp512GuvXr48kjuGU0LMgjnZLkap0aRYrfwqP/nNwG4GRts9dsmQJc+bM2ffYoYceCgT7vhQKhX3PaWlpYWhoKJI4hlNCz4I42i1FGhyVZtG1AM7/+v5rA9SpdPvcrq4uhoaGaG9PbixKCT0L4mi3DFccHC3eiuRRWzvMvDKy/4dKt8+dNm0a5513XiSvXSvNcsmCYpsl6nZLUU8v+64qqNkuIlUp3T73sssu47LLLtt3/7rrrjvg/Lfffrvs96KihJ52xQGcc64OE28Mign8yW8BDrOvjed9RHLstttuSzoEtVxSb9lCePL64DjOyrnYP1cfXaQibZ8rtSn2z4u3cdHeLpIx7p50CJGr9zMpoadZnNMVS/X0wvQ5wfTFiKZ1icRlwoQJDAwM5CqpuzsDAwNMmDCh5tdQDz3N4pyuWKqtHeZ8Mzg++YJ430ukTlOmTGHTpk309/cnHUqkJkyYwJQpU2p+vhJ6qoXVx9Sexsw8WX0vrF0C7zlTA6OSaoVCgWnTpiUdRupUbLmY2QQzW2ZmvzOzF8zsa+Hjk8zsUTNbG94eHX+4TWbGRUEbZMZFDXrDcOWbtgEQyaRqeujvAB9y9zOALmCumX0AuBp4zN2nA4+F9yUqgwOw5NqgYn754ca8p/roIplWseXiwahDcUZ8Ifxy4ELg3PDxu4AngK9EHmGzWrYwSOYnzo5sqXJF6qOLZFpVs1zMbJyZrQS2AI+6+2+Bd7v7ZoDw9l1lnttrZn1m1pe3AYx4Nbh/XlTso6++t3HvKSKRqCqhu/sed+8CpgA9Zjaj2jdw94Xu3u3u3R0dHTWG2YQa3j8vspJbEcmKMc1ycfdtZvYEMBd43cwmu/tmM5tMUL1LFIb3zztnQceVjXtv7esiklnVzHLpMLOjwuNW4DzgReAB4NLwtEuB+2OKsfkk0T8vGr6vi/ZHF8mUair0ycBdZjaO4BfAPe7+oJn9BrjHzP4e2Ag0ujeQYwn1z4u0r4tIJlUzy2UVcOYIjw8AH44jqKY34yJ4bUUC/fOQ9kcXySStFE2bJPvnReqji2SSNudKmyT750Xqo4tkkhJ66iTcP99H0xdFskYtl7RJun++L4758Npzwa2IZIIq9DRJYv+Wcl5+OIhjybXaqEskI5TQ02TlT4MkOn1Ocv3zoq4FQRxrl2ijLpGMUMslTU6+ANYvDTbISnpmiTbqEskcVehpsvpn4cZYP0s6kkCx7ZJ0+0dEqqIKPVW85DZhxb8YVKGLZIISeloUBx7PuTpc2JMCxQod4KM3J98GEpFRqeWSFssWwpPXB8dpSZwaGBXJFFXoqZGydgtoYFQkY1Shp0ViF7SoQFcwEskMJfQ0SNOCooNoCwCRrFDLJQ3StKColHZeFMkMVehpcPIFQTJPw4KiUm3tcEhbsPOiBkZFUk0JPQ3StqCoVPEXjgZGRVJNCT0VUjjDZTgNjIpkQjUXiZ5qZo+b2Roze8HMrgwfv87M/mhmK8MvlW+1OGBB0eXJxlKWBkZFsqCaQdEh4Ivu/pyZHQ48a2aPht+70d2/E194TaC4oOicq9PXPy/SwKhIJlSs0N19s7s/Fx6/BawBjos7sOaR8nYL6JJ0Ihkxph66mXUCZwK/DR+6wsxWmdkdZnZ01ME1hbQuKDqI2i4iaVd1Qjezw4D7gKvc/U3gh8BJQBewGfhumef1mlmfmfX19/fXH3GepHpBUYkZ88NfPLoknUhaVZXQzaxAkMzvdvefA7j76+6+x933ArcCPSM9190Xunu3u3d3dHREFXc+pHlBUSntjS6SehUHRc3MgNuBNe5+w7DHJ7v75vDux4DV8YSYY2m6QlElXQtg1yDs2q6BUZGUqqZCnwlcAnyoZIriv5rZ82a2CpgNfCHOQHMp7QuKhtPAqEjqVazQ3X0pI4+E6W/vumVghssBNDAqkmbanCspabxCUSUz5sNrz2lgVCSltPQ/KWm8QlElGhgVSTVV6InJWrsFDYyKpJwq9KRkZkHRMNpKVyTVlNCTktX2hbbSFUktJfQkDA4ErYtzrk7/gqJS2kpXJLWU0JOQxQHRfTR1USStNCiaiAwOiBZpK12R1FKFnoQsDogWaWBUJLWU0BstSzsslqOBUZFUUkJvtCztsFiOBkZFUkk99EbL0g6LZWlgVCSNlNAbrbjD4nvOgtnXJB1NbTQwKpJKark0XIZnuBRpYFQklVShN1IWd1gsp9g60sCoSGqoQm+klT8NFhQdMjH7bYqsbl0gkmOq0BspT1Vtnj6LSE6oQm+kLF1yrpJihb7k2v2tJBFJlBJ6Q+VgQLSoa0Ewl37tEg2MiqRExYRuZlPN7HEzW2NmL5jZleHjk8zsUTNbG94eHX+4GXbAgOjlycYShbb2YC69VoyKpEY1FfoQ8EV3PxX4APB5M3sfcDXwmLtPBx4L70s5md5hsQwNjIqkSsWE7u6b3f258PgtYA1wHHAhcFd42l3AR2OKMSdy1G4p0p4uIqkyph66mXUCZwK/Bd7t7pshSPrAu8o8p9fM+sysr7+/v85wMyzLOyyWowpdJFWqTuhmdhhwH3CVu79Z7fPcfaG7d7t7d0dHRy0xZl8edlgcSdcCOOcr+y8aLSKJqiqhm1mBIJnf7e4/Dx9+3cwmh9+fDGyJJ8QcyMMOiyMpjgU8+S1YdkuysYhIVbNcDLgdWOPuNwz71gPApeHxpcD90YeXE8Vec6Z3WCxHOy+KpEU1FfpM4BLgQ2a2Mvy6APgWcL6ZrQXOD+/LSPK0oKjUjPnh2MD8pCMRaXoVl/67+1LKl18fjjacvMrhDJei4sBo5yzouDLpaESamvZyiVuedlgcSdcC2DW4f2A0dy0lkezQ0v+45XFB0XAaGBVJDSX02OW43bKPBkZF0kAtl7jNuAheW5GvBUWlZsyH157TwKhIwlShxymvC4pKacWoSCqoQo9TXhcUldLAqEgqqEKPU64XFA2jgVGRVFBCj1OeFxQdRAOjIklTyyVWzTDDJaSBUZHEqUKPS96uUFSJBkZFEqeEHpe8Lygqpa10RRKnhB6bJmq3QPBL65C2YGBUF40WSYR66HFphgVFpU6+ANYv1SXpRBKiCj0OzbKgqNTqe8NZPfcmHYlIU1JCj0OzLCg6iKYuiiRJLZc4FFsPeV9QVKqnl31jBloxKtJwqtDj0FQLiobRwKhIolShx6LJZrgMp4FRkcRUc5HoO8xsi5mtHvbYdWb2x5JrjAo034KiUhoYFUlMNS2XO4G5Izx+o7t3hV9NNJWjgmZbUHQQDYyKJKWai0Q/ZWadDYglJ5q43QIaGBVJUD2DoleY2aqwJXN0uZPMrNfM+sysr7+/v463y4gZFwXTFZtpQdFw2kpXJDG1JvQfAicBXcBm4LvlTnT3he7e7e7dHR0dNb5dRjTrgqKDqO0ikoSaZrm4++vFYzO7FXgwsoiybNnCIJmfOLvJFhSV0Fa6IomoqUI3s8nD7n4MWF3u3OYS9o6n9jR371hb6YokomKFbmaLgHOBY8xsE/BV4Fwz6yLIYOuBJpyfN4Jm3JBrJLrGqEgiqpnlcvEID98eQyzZNrx/3jkLOq5MOqLkDB8YxWH2tYmGI9IstPQ/Kuqfl9DAqEijael/ZNQ/P4AGRkUaTgk9KuqfH6g4MArw0Zv1S06kAdRyiYLmnx+sa0GwwGrtEu28KNIgqtCjoP75wdrag/3gQTsvijSIKvRIqH8+Iu28KNJQqtCjoP55GZrpItJISuj10vzz8rTzokhDqeVSL/XPy9POiyINpYReN/XPR6e2i0ijqOVSL/XPR6cFRiINowq9Hpp/XllxgdGSa/dfb1VEYqGEXg/1zyvTAiORhlHLpR67twe3x56m/nk5WmAk0jCq0OtRaD3wVkamBUYiDaEKvVbFfvA5V4fzraU8zXQRaQRV6LVathCevD44VrtldD29cM5XgmMNjIrERgm9VsX+efFWytMCI5GGUEKvxeAA/GlVcKz+eXV27zjwVkQiVzGhm9kdZrbFzFYPe2ySmT1qZmvD26PjDTNlli2EdU8E0xV7dH3sqhQmHngrIpGrpkK/E5hb8tjVwGPuPh14LLzfPDRdcezURxeJXcWE7u5PAVtLHr4QuCs8vgv4aLRhpZymK46d+ugisau1h/5ud98MEN6+q9yJZtZrZn1m1tff31/j26XIAdMV1W4ZG01fFIlT7IOi7r7Q3bvdvbujoyPut4ufpivWbsb8YBsAbdQlEotaE/rrZjYZILzdEl1IKafpirXTRl0isao1oT8AXBoeXwrcH004KafpivXpWgAnnhskdfXRRSJXzbTFRcBvgPea2SYz+3vgW8D5ZrYWOD+8n3+arliftnY49vTgWPPRRSJXcS8Xd7+4zLc+HHEs6afpivXTfHSR2Ghzrmqp3RINXThaJDZa+l8ttVuiofnoIrFRQq+W2i3R0b4uIrFQQq+G2i3RKvbP//S8pi+KREgJvRpqt0SrpzdYYLTucV1nVCRCGhSthtot0dJ1RkVioQq9ErVb4qHrjIpETgm9ErVbYhJu0PXqMvXRRSKihF6J2i3x6OkNtgFY97imL4pERAl9NGq3xEfbAIhETgl9NGq3xEvTF0UipYRezuAArH8qOFa7JR5qu4hESgm9nGULYcOvg2O1W+KhtotIpJTQyykOhp4wU+2WOKntIhIZJfSRDB8M7Zyldkuc1HYRiYwS+kg0GNo4aruIREYJvZQGQxtPbReRSCihl9JgaOOp7SISiboSupmtN7PnzWylmfVFFVSiNBjaeGq7iEQiit0WZ7v7nyN4neT1r4UXHwyONRjaWKVtF/23FxkztVyGW/xl2LoOJp2k6rzR1HYRqVu9Cd2BJWb2rJn1jnSCmfWaWZ+Z9fX399f5djHqXxskc4BTLlCF2Ghqu4jUrd6EPtPdzwLmAZ83sw+WnuDuC9292927Ozo66ny7mAwOwL9fDNs2wDHTYeYXko6oOWm2i0hd6kro7v5aeLsF+AXQE0VQDbf0JvjzWjjqBPjbRarOk6K2i0hdak7oZtZmZocXj4E5wOqoAmuYwQF4KRwInTQNOqYnG08zG952Wb9UVbrIGNVTob8bWGpmvwOWAQ+5+yPRhNVAS28KeudHnQDzvpN0NFJsu2x4WlW6yBjVPG3R3dcBZ0QYS+P1r91/1XlV5+nQ0xus1N3waw2OioxRc09bXPxl2LEVWiepOk+LtnboDMfWNTgqMibNm9CHT1M885OqztOkpxdO+MtgcPTpG5OORiQzmjOhDw7Aok8E0xQnnaRpimnT1g7jDg2OX3xYVbpIlZozoRcHQkGLiNJq3reDgeqtr6hKF6lS8yX0AwZCT1R1nlYd04N/H1CVLlKl5kroxVZLcSD04ntUnaeZqnSRMWmehD44APdcooHQLBlepa+4O/jrSkTKap6EvvSmYLEKqNWSJfO+Hfw1tWMrLP5S0tGIpFpzJPSNy2H5rcGxWi3Z0jEduhYEx1v/oCpdZBT5T+gbl8Od82BoR7Cs/NNL1GrJmllXBX9VbdsQjIFogFRkRPlO6MVkvnc3tBTgkgeUzLOorR3e+zfB8dZ1GiAVKSO/Cb00mX9qMRx/dtJRSa2KVTrAstuCf18ROUA+E7qSef60tQdjH4WJQfvsJx9RP12kRL4S+uAAPPRFuHOuknkedUwP2mbjW2H3drhjjpK6yDD5Segbl8P3z4Llt8HeISXzvDr+bDj7M8Hxjq1K6iLDZD+h96+F284LqvKd24LHxrcqmefZrKvghJnBsZK6yD7ZTejFRH7zLNi0PKjKGQdTeuDyXymZ51lbO3ziJwcm9Vv+qwZKpenVfMWixGxcDj/7FAz2w5539j8+4Sj47z9TIg+90v82X7pnJZu27sDxsue1mHHUxAJvDO4e9bwotZgxZdJEvn3RGZzUcVhtL1JM6vdcEqwAHtoBP5oL3X8H516jhWPSlMy9Mf8TA3R3d3tfX9/Yn1hM4kPvwM43wmo8dOgRcPrfNsX/xFsHd3HToy/xHy+8zp69e0c9962dQ7yzp3H/trUoGBw5sTDqOePHtTDnfcdy1fknM6ntkINPGByAJ74Jz965/+eiiX4mpDmY2bPu3l3xvHoSupnNBb4HjANuc/dvjXZ+VQm9fy3c/zl4YyN4mLRKkzgtcPixcMpfZ/5/2uc2vMEV//Ycu4b2VDx3x+69DO6qfN5wEw8xJhbK/yGWRIUex+d4356XuJmvM5Fd+x8stMHESfDxH+kvN8m02BO6mY0DXgbOBzYBy4GL3f0/yz2ne/qx3nf50cGUwnLeefPAVso+LTCxHQoTEv8fdCyVciVv7Bhiz96x/RtEUtkmKK6/NKbxGtcXbuY020Bry/6fsV3AGxyx7/5exvMUPdx72CfZsKN1xF9kFdtCxb8M1jw8+s9zKWuBo0+AC3+gVctStUYk9L8ArnP3vwrvXwPg7v9S7jnd7xnnfb3V9UzfYgLbCRLREIdwDVfxn+PeW1Os1RhLpVpLhTkaA9rbRk/QEFHvOWOqHQsoemPHEMfv/SPXF25mqvVzDG9RaBn5l8bmvUcCYKO8rsGIUwda2cUR7KzmI4xoO+N5i4k1P79Wzjje5nAO402M+oqRLMny53YK/MUPXt/xhy2DFX9g6hkUPQ54ddj9TcD7S08ys16gF+D4I41te1vZSfnktYfxPLrnv/C9PR8/oKoKjKESqsGWt3dVPmmYairlSg4tjOP7F5/FWSccXdfr5NVJHYfxi8/Pqvr8YgvrH4aCuuJ9e17im9xIYdjPzpFsZwJDTG75f3XHN7h3HG/RVvX5E9nFES07mcgQE3mz7vevzRsJvW/Ssvu528fvbK3mvHoSuo3w2EGljrsvBBYCTJvybp8//n+xzQ4f/ZULQVP+mDqCG6uxVOjNWClnxVknHM2vr/nwsEfmAP/jwJP618KD/wg73oLBLfvHaobZAwzuHGLH3r2M8GON08KfeBdfG/cPvNpyXNXxHelv8pm9/8459NHCUOUnRCzLlWo9svy5nQIDQ0M7qjm3sS2XWme5iIg0sWp76PUsLFoOTDezaWZ2CPDfgAfqeD0REalDzS0Xdx8ysyuA/yDokNzh7i9EFpmIiIxJXStF3f1h4OGIYhERkTpkdy8XERE5gBK6iEhOKKGLiOSEErqISE40dLdFM3sLeKlhb9h4xwB/TjqIGOX58+X5s4E+X9a9190rrMhs/H7oL1UzOT6rzKxPny+b8vzZQJ8v68ysqhWZarmIiOSEErqISE40OqEvbPD7NZo+X3bl+bOBPl/WVfX5GjooKiIi8VHLRUQkJ5TQRURyouEJ3cz+p5mtMrOVZrbEzN7T6BjiYmbfNrMXw8/3CzM7KumYomRmF5nZC2a218xyM0XMzOaa2Utm9nszuzrpeKJkZneY2RYzW510LHEws6lm9riZrQl/Nq9MOqaomNkEM1tmZr8LP9vXKj6n0T10MzvC3d8Mj/8ReJ+7f7ahQcTEzOYA/zfcWvh6AHf/SsJhRcbMTgX2ArcAX3L3zF+tpJaLnWeJmX0QeBv4sbvPSDqeqJnZZGCyuz9nZocDzwIfzcO/n5kZ0Obub5tZAVgKXOnuz5R7TsMr9GIyD7Ux0vW9Msrdl7h78bpizwBTkownau6+xt3zttK3B/i9u69z913A/wYuTDimyLj7U8DWpOOIi7tvdvfnwuO3gDUE1zvOPA+8Hd4thF+j5stEeuhm9g0zexX4JPDPScTQAJ8GFicdhFQ00sXOc5EQmo2ZdQJnAr9NOJTImNk4M1sJbAEedfdRP1ssCd3M/o+ZrR7h60IAd/8nd58K3A1cEUcMcan02cJz/gkYIvh8mVLN58uZqi52LulmZocB9wFXlXQBMs3d97h7F8Ff+z1mNmrbLJa9XNz9vCpP/TfgIeCrccQRh0qfzcwuBf4G+LBncJL/GP7t8mITMHXY/SnAawnFIjUI+8v3AXe7+8+TjicO7r7NzJ4A5gJlB7iTmOUyfdjdjwAvNjqGuJjZXOArwEfcfXvS8UhVdLHzDAsHDm8H1rj7DUnHEyUz6yjOlDOzVuA8KuTLJGa53Ae8l2C2xAbgs+7+x4YGERMz+z1wKDAQPvRMXmbwAJjZx4DvAx3ANmClu/9VokFFwMwuAG5i/8XOv5FsRNExs0XAuQTby74OfNXdb080qAiZ2SzgV8DzBDkF4NrweseZZmanA3cR/Fy2APe4+9dHfU4GuwIiIjICrRQVEckJJXQRkZxQQhcRyQkldBGRnFBCFxHJCSV0EZGcUEIXEcmJ/w/7mTYZIXm47QAAAABJRU5ErkJggg==\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
}
