{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import torch.autograd as autograd\n",
    "import torch.optim as optim\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def kl_divergence(mu1, mu2, sigma_1, sigma_2):\n",
    "\n",
    "    sigma_2_inv = torch.inverse(sigma_2)\n",
    "\n",
    "    kl = 0.5 * ((torch.det(sigma_2) / torch.det(sigma_1)).log()\n",
    "                - sigma_1.shape[0] \n",
    "                + torch.trace(torch.matmul(sigma_2_inv, sigma_1))\n",
    "                + torch.matmul(torch.matmul((mu2 - mu1).reshape(1,-1),\n",
    "                                            sigma_2_inv),\n",
    "                               (mu2 - mu1).reshape(-1,1)))\n",
    "\n",
    "    return kl\n",
    "\n",
    "\n",
    "def multivariate_gaussian(pos, mu, Sigma):\n",
    "    \"\"\"Return the multivariate Gaussian distribution on array pos.\"\"\"\n",
    "\n",
    "    n = mu.shape[0]\n",
    "    Sigma_det = np.linalg.det(Sigma)\n",
    "    Sigma_inv = np.linalg.inv(Sigma)\n",
    "    N = np.sqrt((2*np.pi)**n * Sigma_det)\n",
    "\n",
    "    fac = np.einsum('...k,kl,...l->...', pos-mu, Sigma_inv, pos-mu)\n",
    "\n",
    "    return np.exp(-fac / 2) / N\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "mu_opt = torch.tensor([20.,20])\n",
    "Sigma_opt = torch.tensor([[100.,0.],[.0,1]])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAD8CAYAAACfF6SlAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Z1A+gAAAACXBIWXMAAAsTAAALEwEAmpwYAAAieElEQVR4nO3de3RU5b3/8fcXEkjEQAQiBEKLiMRAwABBSg7UggICWsH2R1FbbZXi6cILPS3W2nNsyjmrtSgH6KKr/eFleSmC2kq94BUaKxV/aIBAgBRQxEVCuN+VQDJ5fn/MJE0ggYTZw+zMfF5rzcrMs2f2/rKZfLLn2c/sx5xziIhIfGkV7QJEROTCU/iLiMQhhb+ISBxS+IuIxCGFv4hIHFL4i4jEobDD38ySzOwjM1tvZpvM7Feh9svMbLWZfWJmL5hZm/DLFRERL3hx5H8SGOWcuwrIAa43s68BvwXmOud6A4eAuzzYloiIeCDs8HdBx0MPE0M3B4wC/hxqfwaYGO62RETEGwlerMTMWgNrgN7A74FPgcPOuarQU0qB7o28dhowDaBdu3aDr7zySi9KEhGJG2vWrNnvnEtrzms8CX/nXADIMbNUYCnQ5AR3zi0EFgLk5ua6wsJCL0oSEYkbZvZ5c1/j6Wgf59xhoAAYBqSaWc0flwygzMttiYjI+fNitE9a6IgfM0sGRgMlBP8IfDv0tDuAV8LdloiIeMOLbp904JlQv38r4EXn3OtmthlYYmb/A6wDnvRgWyIi4oGww985twEY2ED7duDqcNcvIvGnsrKS0tJSKioqol2KryQlJZGRkUFiYmLY6/LkhK+IiJdKS0tJSUmhZ8+emFm0y/EF5xwHDhygtLSUyy67LOz16fIOIuI7FRUVdOrUScFfh5nRqVMnzz4NKfxFxJcU/Gfycp8o/EVE4pDCX0QkDin8RUTikMJfRKQBTzzxBDk5OeTk5NCqVava+z/+8Y+bva633nqLzMxMevfuzSOPPBKBaptPQz1FpMX767oyHn17C7sOn6BbajIzx2YycWCD15JssqlTpzJ16lTKysrIy8ujqKjovNYTCASYPn067777LhkZGQwZMoRvfvOb9O3bN6z6wqUjfxFp0f66royfv1xM2eETOKDs8Al+/nIxf13nzeXENm7cSP/+/c/79R999BG9e/emV69etGnThilTpvDKK9G/2o2O/EWkRXv07S2cqAzUaztRGeDRt7eEffQPUFxcTHZ2doPLRowYwbFjx85of+yxx7juuusAKCsro0ePHrXLMjIyWL16ddh1hUvhLyIt2q7DJ5rV3lwbN25k9OjRDS5buXKlJ9uIBoW/iLRo3VKTKWsg6LulJnuy/uLi4kZP8jblyL979+7s3LmzdllpaSndu4f/iSRcCn8RadFmjs3k5y8X1+v6SU5szcyxmWGvu7q6mm3btpGVldXg8qYc+Q8ZMoRt27bx2Wef0b17d5YsWcLzzz8fdm3hUviLSItW06/v9WgfgE8++YSMjAzatGlz3utISEhgwYIFjB07lkAgwJ133km/fv3Cri1c5pyLdg21NI2jiACUlJQ0erQd7xraN2a2xjmX25z1aKiniEgcUviLiMQhhb+ISBzyYgL3HmZWYGabzWyTmd0fas83szIzKwrdxodfroiIeMGL0T5VwE+cc2vNLAVYY2bvhpbNdc495sE2RETEQ15M4F4OlIfuHzOzEiD632AQEZFGedrnb2Y9gYFAzYUr7jGzDWb2lJld4uW2RETk/HkW/mZ2MfAXYIZz7ijwB+ByIIfgJ4M5jbxumpkVmlnhvn37vCpHRETOwpPwN7NEgsG/yDn3MoBzbo9zLuCcqwYeB65u6LXOuYXOuVznXG5aWpoX5YiIhO1CT+Zy5513cumllzZ6BVGveTHax4AngRLn3P/WaU+v87RJwMZwtyUi0qANL8LcbMhPDf7c8GLYq5w6dSpFRUUsW7aMHj16UFRURFFREXPnzm3Wemomc3nzzTfZvHkzixcvZvPmzWc87/vf/z5vvfVW2HU3lRejff4N+B5QbGZFobaHgFvMLAdwwA7gbg+2JSJS34YX4bX7oDJ0Zc8jO4OPAQZMDnv1Xk7mAtRO5nL6TF5f//rX2bFjRzilNosXo33+AVgDi94Id90iIue0Yta/gr9G5Ylguwfhr8lcRET86Ehp89qbSZO5iIj4UYeMYFdPQ+0e0GQuIiJ+dO3D9fv8ARKTg+1hiuXJXHRhNxFp2QZMhht/Bx16ABb8eePvPOnv93oyl6ysLCZPnlw7mcv48ePZtWsXALfccgvDhg1jy5YtZGRk8OSTT4Zd/9loMhcR8R1N5tI4TeYiIiLnTeEvIhKHFP4iInFI4S8iEocU/iIicUjhLyIShxT+IiJxSOEvIhKHFP4iIg3wcjKXCz1RS1Mo/EWkxVu2fRlj/jyGAc8MYMyfx7Bs+7Kw1+nVZC5w4SdqaQpd2E1EWrRl25eRvyqfikAFAOVflJO/Kh+ACb0mhL3+cCdzgQs/UUtTKPxFpEWbv3Z+bfDXqAhUMH/tfE/CP9zJXPxK4S8iLdruL3Y3q725NJmLiIgPdW3XlfIvyhts90K4k7n4Vdjhb2Y9gGeBLgQna1/onJtvZh2BF4CeBCdwn+ycOxTu9kSk5SpZWcDKJc9y7MB+Ujp1ZsSU28kaMTKsdd4/6P56ff4ASa2TuH/Q/eGW68lkLn7lxWifKuAnzrm+wNeA6WbWF3gQWOGcuwJYEXosInGqZGUB7yxcwLH9+8A5ju3fxzsLF1CysiCs9U7oNYH8vHzS26VjGOnt0snPy/ekv9+LyVzgwk/U0hRhH/k758qB8tD9Y2ZWAnQHbgK+EXraM8B7wM/C3Z6ItEwrlzxL1amT9dqqTp1k5ZJnwz76n9Brgidhf7o+ffqwefPmsNezePFiD6rxlqfj/M2sJzAQWA10Cf1hANhNsFuooddMM7NCMyvct2+fl+WIiI8cO7C/We0SWZ6Fv5ldDPwFmOGcO1p3mQvOFdngfJHOuYXOuVznXG5aWppX5YiIz6R06tysdoksT8LfzBIJBv8i59zLoeY9ZpYeWp4O7PViWyLSMo2YcjsJbdrWa0to05YRU26PUkXxLezwNzMDngRKnHP/W2fRq8Adoft3AK+Euy0R8b+TJ08S/LBfX9aIkYyZdg8pndPAjJTOaYyZdk/Y/f1yfrwY5/9vwPeAYjMrCrU9BDwCvGhmdwGfA5M92JaI+FxVVRVr165l2LBhZyzLGjFSYe8TXoz2+QdgjSy+Ntz1i4i/VVVV8ac//YlFixbxxhtv0K5dO/r27RvtsuQcdFVPETkvgUCA559/nn79+vGDH/yAgwcPUl4eHODXoUOHKFcn56LLO4jIWW1dvZsPX/mU4wdPcnHHtgy76XIu7lHNmDFj2LRpE9nZ2bz88stMnDiR4ClAaQl05C8ijdq6ejcFi/7J8YPBk7iffbadgkX/5OjnkJWVxZIlS1i/fj2TJk2KueD3ajKXnTt3MnLkSPr27Uu/fv2YP39+hCpuHh35i0ijPnzlUypPBti88yOWFT7DviNl/OrWRax+7TNeeumlaJdX68hrr7F37jyqystJSE/n0h/PoMONN4a1zqlTpzJ16lTKysrIy8ujqKjovNaTkJDAnDlzGDRoEMeOHWPw4MGMHj066udFFP4i0iDnHIUbVrGs8Gk+27OZjhd3YdKwu2mbkMTxgyfPvYIL5Mhrr1H+Xw/jKoIXdqvatYvy/3oYIOw/ABD+ZC7p6emkp6cDkJKSQlZWFmVlZQp/EfGnDRs2sGDZA6S2S2PKiBl8LfN6ElonAnBxx7bnePWFs3fuvNrgr+EqKtg7d54n4e/lZC47duxg3bp1DB06NOy6wqXwF5Fau3btoqCggNtuu42rrrqKPzz6DFWfdcUC/4qKhDatGHbT5VGssr6q8jOv5X+29ubyajKX48eP861vfYt58+bRvn17T2oLh074igiBQIDf/e539OnTh2nTpnHw4EEA/v2ntzPm9gG1R/oXd2zLyNuupM9QbyZK8UJCqEulqe3Nda4j/5oTwXVvy5cvr/e8yspKvvWtb3Hbbbdx8803e1JXuHTkLxKH6p4g3dG+PQ8fPkTh1q2MGzeOBQsW0LFjx9rn9hna1Vdhf7pLfzyjXp8/gCUlcemPZ4S9bi8mc3HOcdddd5GVlcV//Md/hF2TVxT+InGm7gnSo4EAkws/JtGMx3/yE+569NEWN2Szpl/f69E+4M1kLh988AHPPfcc/fv3JycnB4Bf//rXjB8/Puz6wqHwF4kze+fOo/rECcyM9q1b8+uu6eQkJ9N17boWF/w1Otx4oydhfzovJnMZPnx4gxe6izb1+YvEmSNlZfx7WSlvHwtOu3FdSgqdExI8O0EqLYPCXySOVFRUcM/ePaz64gu+qK6ut8yrE6TSMqjbRyROBAIBbr31VlYfPszsr3yFG5Ivql3m1QlSaTl05C8SB5xz3HvvvSxdupR58+YxbcECErp1AzMSunUj/b9nRaTPXPxLR/4icaJDhw7MnDmT+++/P/hYYR/XFP4iMWjZ9mXMXzuf8uPldKzqyAOjHuA3v/mNL0edSHQo/EVizLLty8hflc/xQ8fZ9ewuSraU8NB/PwQ3woReE6JdnviEJ33+ZvaUme01s4112vLNrMzMikK36H6jQSROPPL2I+xYvIOtM7dybN0xOl/fmUD7APPX+uM68uIPXp3wfRq4voH2uc65nNDtDY+2JSKnOXHiBBCcOOQf0//B/jf3kzIwhd7/05u0CWlYK2P3F7ujXGXL4tVkLjUCgQADBw7khhtu8LjS8+NJt49z7n0z6+nFukTk7A4cOMCGDRtqb++//z4DBgzgL3/5Cz169CDr7iwCvQO06Vz/kgRd2/n3+jzhamiqyXCvR+TVZC415s+fT1ZWFkePHg1rPV6J9FDPe8xsQ6hb6JKGnmBm08ys0MwK9+3bF+FyRFqOU6dOUVxczKJFi+pN/XfTTTcxatQoZsyYwWuvvUZmZiYTJvyrL//RmY/Svkv9SwYntU7i/kH3X7DaL6S6U00CHD94koJF/2Tram8+6YQ7mQtAaWkpy5YtY+rUqZ7U5IVInvD9A/DfgAv9nAPcefqTnHMLgYUAubm5Googccc5x549e+jaNXikumDBAh5//HFKSkqorKwEgsM07733Xlq1akV+fj7OOQYMGECXLl3OWF/NSd35a+ez+4vddG3XlfsH3R+zJ3s/fOVTqk7V/7Zy1alqPnzlU0+uRurFZC4zZsxg9uzZDT43WiIW/s65PTX3zexx4PVIbUukJfn888/529/+Vq/rZv/+/ezdu5e0tDTMjIyMDMaPH8+AAQPo378/mZmZtGoV/KDe0AxRp5vQa0LMhv3pGptS0qupJsOdzOX111/n0ksvZfDgwbz33nue1OSFiIW/maU752quFDUJ2Hi254vEmkOHDrF+/XqKioooKirioYceok+fPqxYsYK77rqLiy66iOzsbCZOnEj//v1JSAj+Ok6fPp3p06dHufqW4+KObRsMeq+mmiwuLm70JG9Tjvw/+OADXn31Vd544w0qKio4evQo3/3ud/nTn/7kSX3ny7z40oeZLQa+AXQG9gC/DD3OIdjtswO4u84fgwbl5ua6wsLCsOsRudCqq6s5deoUSUlJrFu3jilTprB169ba5enp6Tz33HNce+21HDx4kP3793P55ZfTunXrKFbtXyUlJY1OoHK6mj7/ul0/CW1aeTLjWHV1Nampqezfvz+sa/rXeO+993jsscd4/fXz7whpaN+Y2RrnXG5z1uPVaJ9bGmh+0ot1i/jR8ePH+eijj/jggw9YtWoVH374IQ899BAPPPAAGRkZZGVl8f3vf59BgwaRk5NTr2++Y8eO9WbKkvDUBLzXo33Am8lc/MqTI3+v6Mhf/Mg5x+eff87hw4fJycnh1KlTpKamciI0IUq/fv3Iy8tjypQpjBw5MtrlxoTmHPnHG18d+YvEmjVr1vD3v/+dVatWsWrVKsrLyxk+fDgrV66kTZs2zJ07l549ezJ06FBSU1OjXa5Isyn8Je6Vl5fz4YcfsnXrVh588EEAfvnLX7Js2TJ69uzJqFGjyMvLY/jw4bWvufvuu6NVrognFP4Sl1asWMFTTz3FqlWr2LFjBwBJSUlMnz6dlJQU5syZw+OPP066ZreSGKXwl5j15ZdfUlRURGFhIWvWrGHNmjUsXbqUK664gm3btlFQUEBeXh733nsveXl5DBw4kLZtg8MDMzMzo1y9SGQp/KXFc86xa9cuNm7cSGZmJj179mT58uWMHTuW6tA8tV26dGHw4MFUVFQA8MMf/pC7774bM4tm6SJRo/CXFqW6uppWrVpx4MABHn74YTZu3EhxcTGHDh0CYO7cucyYMYPs7Gx+8YtfkJuby+DBg+nWrVu9oNf4eol3Cn/xJecc69evp7i4uDbgi4uLueWWW5g9ezYXXXQRixcvJisri8mTJ5OdnU3//v256qqrAOjatSuzZs2K8r9CxL8U/hJVgUCA7du31wZ8amoq9913HwCjR49m//79JCYmkpWVxTXXXMOQIUMASE5O5sCBA+q2ETlPCn+5IJxz7N69m9LS0toA/+53v8vSpUv58ssvATAzxo8fz3333YeZ8cILL9C1a1euuOIKEhMTz1ingl8i6YknnmDBggUAbNiwgQEDBgAwcuRI5s6dG83SPKHwl4h56623WLZsWe1R/YEDB+jUqRP79u3DzOjfvz9paWn079+f/v3707dvX9q1a1f7+lGjRkWxemlJSlYWsHLJsxw7sJ+UTp0ZMeV2skaE921rrydz8RuFv5w35xw7duxg3bp1rF27lvXr17Np0yaKi4tp164dBQUFPP3002RnZ3PzzTfX9svX+NnPfhbF6iVWlKws4J2FC6g6Fbyy57H9+3hnYfCIPdw/AODNZC5+pPCXJgkEAmzdupW1a9cyZswY0tLS+P3vf8+9994LBEfPXHnllQwdOpRjx47Rrl078vPz+c1vflN7HXqRSFi55Nna4K9RdeokK5c860n4ezGZy5tvvsns2bMZPnw4o0aNIj8/n9zcXObMmRN2fedL4S+N2rFjB/PmzePjjz+mqKiotm9+6dKlTJw4kdGjR/PHP/6RQYMGkZ2dTXJycr3Xn/5YJBKOHdjfrPbmCncyFwh+o7ygoIDZs2czd+5cli9fzuLFi9m8eTN9+/b1pM7mUvgLR48e5eOPP2b16tWsXr2a73znO9x6661UVlaycOFCBg8ezA9/+EMGDRrEwIEDufLKK4Hgt2D1TViJtpROnTm2/8z5v1M6dfZk/eFO5gLBLlIIXs77+PHjBAIBnHNE86rKCv84dOrUKdq0aUNFRQVDhw6luLi49k2YmZlZe4Tfu3dvjhw50uBIGxG/GDHl9np9/gAJbdoyYsrtYa+7urqabdu2NXp56aYe+V933XVce+215OTkkJ+fz5gxY7jqqqu44447wq7xfCn8Y92GF2HFLL7Yt5PfFyezaGtbvpp5Fa+++ipJSUkMGTKESZMmMWzYMK6++mouueSS2peamYJffK+mX9/r0T7g3WQu48aNY9y4cbWP33///XBLC5vCP5ZteBFeu4+9h7/gmqe/5J/7jzKsRyLX9//Xx9EnnngiigWKeCNrxEhPwv50ffr0YfPmzZ6v1w88CX8zewq4AdjrnMsOtXUEXgB6EpzDd7Jz7pAX25MmWjELKk/wk3dO8tmhat793kVc1ysBOqyOdmUiEmVejcF7Grj+tLYHgRXOuSuAFaHHciEdKSVQ7dhxuJrpQ9oEgz/ULiLxzasJ3N83s56nNd8EfCN0/xngPUDf6rmQOmTQ+shOVv6gHdV1RxV0yIheTSJN5JzTJTxO4+XooEh++6aLc648dH830KWhJ5nZNDMrNLPCffvOHK4lYbj2YUgMjrVvVfNLlJgcbBfxsaSkJA4cOBDVoZB+45zjwIEDJCUlebI+82rnho78X6/T53/YOZdaZ/kh59wljbwcgNzcXFdYWOhJPRL0zW/k0vXkdhaOrQ4e8V/7MAyYHO2yRM6qsrKS0tLS2sl3JCgpKYmMjIwzRuGZ2RrnXG5z1hXJ0T57zCzdOVduZunA3ghuSxrx0T9LueGGmyFfo3qk5UhMTOSyyy6LdhkxLZLdPq8CNd9guAN4JYLbkgZUVVWxd+9eMjLUxy8i9XkS/ma2GPgQyDSzUjO7C3gEGG1m24DrQo/lAtqzZw/OOdLT06Ndioj4jFejfW5pZNG1Xqxfzs+uXbsA6NatW5QrERG/0bV2Y1hycjLf/va36d27d7RLERGf0eUdYlh2djYvvfRStMsQER/Skb+ISBxS+Mew//zP/6RLlwa/WycicU7hH8MOHTpEIBCIdhki4kMK/xh25MgROnToEO0yRMSHFP4x7OjRo7Rv3z7aZYiIDyn8Y5jCX0Qao6GeMWzChAkkJOi/WETOpGSIYTNnzox2CSLiU+r2iWFVVVXRLkFEfErhH8NSU1P56U9/Gu0yRMSHFP4xrKKiwrNZf0Qktij8Y1RlZSWBQEDhLyINUvjHqJrp7xT+ItIQhX+Mqgn/5OTkKFciIn6k8I9Rbdu25YEHHmDQoEHRLkVEfEjj/GNU+/bt+e1vfxvtMkTEpyIe/ma2AzgGBIAq51xupLcpwRO+x48fJyUlRd/yFZEzXKhun5HOuRwF/4Wzdu1aOnbsyDvvvBPtUkTEh9TnH6M02kdEzuZChL8D3jGzNWY27fSFZjbNzArNrHDfvn0XoJz4oPAXkbO5EOE/3Dk3CBgHTDezr9dd6Jxb6JzLdc7lpqWlXYBy4oOGeorI2UQ8/J1zZaGfe4GlwNWR3qbAiRMnAB35i0jDIhr+ZtbOzFJq7gNjgI2R3KYEZWdnM2vWLE3gLiINivQYwC7AUjOr2dbzzrm3IrxNIRj+2dnZ0S5DRHwqouHvnNsOXBXJbUjDjh49yuHDh8nIyKBVKw3qEpH6lAox6sknn+SrX/0qR48ejXYpIuJDCv8YVVlZCUBiYmKUKxERP1L4xyiFv4icjcI/Rin8ReRsFP4xqrKyktatWxMaaSUiUo8u9xijJkyYQNeuXaNdhoj4lMI/RuXl5ZGXlxftMkTEp9TtE6PKysrYsmVLtMsQEZ9S+MeoWbNmcc0110S7DBHxKYV/jKqsrNRIHxFplMI/Rp06dUrhLyKNUvjHKB35i8jZKPxjlMJfRM5GQz1j1D333MORI0eiXYaI+JTCP0aNGjUq2iWIiI+p2ydGbdq0iZKSkmiXISI+pSP/GPWjH/2I1q1bU1BQEO1SRMSHdOQfo3TCV0TOJuLhb2bXm9kWM/vEzB6M9PYE/rqujOKdB/nHp4f4t0f+xl/XlUW7JBHxmYiGv5m1Bn4PjAP6AreYWd9IbjPe/XVdGT9/uZhTp05B6wTKDp/g5y8X6w+AiNQT6SP/q4FPnHPbnXOngCXATRHeZlx79O0tnKgMQHUAa9UagBOVAR59Wxd5E5F/ifQJ3+7AzjqPS4GhdZ9gZtOAaQBf+cpXIlxO7Nt1+AQAl4yaSqu2F53RLiICPjjh65xb6JzLdc7lpqWlRbucFq9bajIAyb0G07Z71hntIiIQ+fAvA3rUeZwRapMImTk2k+TE1vXakhNbM3NsZpQqEhE/inS3z8fAFWZ2GcHQnwLcGuFtxrWJA7sDwb7/XYdP0C01mZljM2vbRUQgwuHvnKsys3uAt4HWwFPOuU2R3KYE/wAo7EXkbCL+DV/n3BvAG5HejoiINF3UT/iKiMiFp/AXEYlDCn8RkTik8BcRiUMKfxGROKTwFxGJQwp/EZE4pPAXEYlDCn8RkTik8BcRiUMKfxGROKTwFxGJQwp/EZE4pPAXEYlDCn8RkTik8BcRiUMKfxGROKTwFxGJQxELfzPLN7MyMysK3cZHalsiItI8kZ7Dd65z7rEIb0NERJpJ3T4iInEo0uF/j5ltMLOnzOySCG9LRESaKKzwN7PlZraxgdtNwB+Ay4EcoByY08g6pplZoZkV7tu3L5xyRESkicw5F/mNmPUEXnfOZZ/tebm5ua6wsDDi9YiIxBIzW+Ocy23OayI52ie9zsNJwMZIbUtERJonkqN9ZptZDuCAHcDdEdyWiIg0Q8TC3zn3vUitW0REwqOhniIicUjhLyIShxT+IiJxSOEvIhKHFP4iInFI4S8iEocU/iIicUjhLyIShxT+IiJxSOEvIhKHFP4iInFI4S8iEocU/iIicUjhLyIShxT+IiJxSOEvIhKHFP4iInFI4S8iEocU/iIicSis8Dez/2Nmm8ys2sxyT1v2czP7xMy2mNnY8MoUEREvhTuB+0bgZuD/1m00s77AFKAf0A1YbmZ9nHOBMLcnIiIeCOvI3zlX4pzb0sCim4AlzrmTzrnPgE+Aq8PZloiIeCfcI//GdAf+X53HpaG2M5jZNGBa6OFJM9sYoZq81BnYH+0imkB1eqsl1NkSagTV6bXM5r7gnOFvZsuBrg0s+oVz7pXmbvB0zrmFwMLQtgqdc7nneEnUqU5vqU7vtIQaQXV6zcwKm/uac4a/c+6686ilDOhR53FGqE1ERHwgUkM9XwWmmFlbM7sMuAL4KELbEhGRZgp3qOckMysFhgHLzOxtAOfcJuBFYDPwFjC9iSN9FoZTzwWkOr2lOr3TEmoE1em1ZtdpzrlIFCIiIj6mb/iKiMQhhb+ISBzyRfi3xMtEmFm+mZWZWVHoNj7aNdUws+tD++sTM3sw2vU0xsx2mFlxaP81e6hapJjZU2a2t+53Tsyso5m9a2bbQj8viWaNoZoaqtN370sz62FmBWa2OfR7fn+o3Vf79Cx1+mafmlmSmX1kZutDNf4q1H6Zma0O/c6/YGZtzrky51zUb0AWwS8pvAfk1mnvC6wH2gKXAZ8CraNdb6i2fOCn0a6jgbpah/ZTL6BNaP/1jXZdjdS6A+gc7ToaqOvrwCBgY5222cCDofsPAr/1aZ2+e18C6cCg0P0UYGvod9tX+/QsdfpmnwIGXBy6nwisBr5GcIDNlFD7H4EfnWtdvjjyd7pMhJeuBj5xzm13zp0ClhDcj9JEzrn3gYOnNd8EPBO6/www8ULW1JBG6vQd51y5c25t6P4xoITgN/59tU/PUqdvuKDjoYeJoZsDRgF/DrU3aV/6IvzPojuws87jRi8TESX3mNmG0MfvqHcDhPh9n9XlgHfMbE3oMh9+1sU5Vx66vxvoEs1izsGP70sAzKwnMJDgEatv9+lpdYKP9qmZtTazImAv8C7BT/qHnXNVoac06Xf+goW/mS03s40N3Hx7VHqOmv8AXA7kAOXAnGjW2kINd84NAsYB083s69EuqClc8LO1X8dI+/Z9aWYXA38BZjjnjtZd5qd92kCdvtqnzrmAcy6H4JUTrgauPJ/1ROrCbmdwLfAyEU2t2cweB16PcDlN1WIureGcKwv93GtmSwm+kd+PblWN2mNm6c65cjNLJ3jU5TvOuT019/30vjSzRIKBusg593Ko2Xf7tKE6/bpPnXOHzayA4JdsU80sIXT036Tfeb93+/j2MhGhN2uNSQTnNvCDj4ErQmf/2xCcV+HVKNd0BjNrZ2YpNfeBMfhnHzbkVeCO0P07gLAvahgJfnxfmpkBTwIlzrn/rbPIV/u0sTr9tE/NLM3MUkP3k4HRBM9NFADfDj2tafsy2mevQ2enJxHspzoJ7AHerrPsFwT7tLYA46Jda526ngOKgQ0E38Tp0a6pTm3jCY5U+JTg1VejXlMDNfYiOBJpPbDJT3UCiwl+vK8MvS/vAjoBK4BtwHKgo0/r9N37EhhOsEtnA1AUuo332z49S52+2afAAGBdqJaNwMOh9l4ED4w/AV4C2p5rXbq8g4hIHPJ7t4+IiESAwl9EJA4p/EVE4pDCX0QkDin8RUTikMJfRCQOKfxFROLQ/wcHuq4HlK2U3gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#### SVGD version 0\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "Sigma_0 = torch.tensor([[1.,.0],[.0,1.]])\n",
    "X0 = torch.matmul(torch.randn(1000,2),Sigma_0**0.5)\n",
    "\n",
    "\n",
    "\n",
    "Sigma_opt_inv = torch.inverse(Sigma_opt)\n",
    "mu0 = torch.tensor([0.,0])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "K = torch.eye(2)\n",
    "X = X0.clone()\n",
    "X = X.T\n",
    "I = torch.eye(2)\n",
    "N = 100\n",
    "XX = np.linspace(-10, 50, N)\n",
    "YY = np.linspace(-10, 50, N)\n",
    "XX, YY = np.meshgrid(XX, YY)\n",
    "pos = np.empty(XX.shape + (2,))\n",
    "pos[:, :, 0] = XX\n",
    "pos[:, :, 1] = YY\n",
    "m = np.array([0.,0.]) \n",
    "\n",
    "lr = 1e-3\n",
    "I = torch.eye(2)\n",
    "\n",
    "\n",
    "cov = Sigma_0.clone()\n",
    "mu = mu0.clone()\n",
    "\n",
    "T=10\n",
    "samples = []\n",
    "kls = []\n",
    "\n",
    "H = I\n",
    "K = I\n",
    "mu_opt_mu_opt = (mu_opt).reshape(-1,1).matmul((mu_opt).reshape(1,-1))\n",
    "def covfunc(a,b):\n",
    "    return (a).reshape(-1,1).matmul((b).reshape(1,-1))\n",
    "\n",
    "\n",
    "c = mu0\n",
    "\n",
    "cov1 = cov\n",
    "for i in range(int(T/lr)):\n",
    "    cov_inv = torch.inverse(cov)\n",
    "\n",
    "    A = Sigma_opt_inv.matmul(cov + covfunc(mu-mu_opt,mu-c)).matmul(K)\n",
    "    \n",
    "    B = cov_inv.matmul(cov - covfunc(c,mu)+covfunc(mu,c)).matmul(K)\n",
    "    \n",
    "    func1 = lambda x:-A.matmul(x-c) + Sigma_opt_inv.matmul(mu_opt-mu)\n",
    "    func2 = lambda x:B.matmul(x-c)\n",
    "    \n",
    "    mu += lr * (func1(mu)+func2(mu))\n",
    "    \n",
    "\n",
    "    diff = I + lr*(-A+B)\n",
    " \n",
    "\n",
    "    cov1 = torch.matmul(diff,cov1).matmul(diff.t())\n",
    "    cov = cov1\n",
    "\n",
    "    samples.append(mu.clone().numpy())\n",
    "\n",
    "    \n",
    "    X = X + lr*((B-A).matmul(X-c.reshape(-1,1)))\n",
    "    kls.append(kl_divergence(mu, mu_opt, cov, Sigma_opt).numpy())\n",
    "\n",
    "\n",
    "X = X.T\n",
    "\n",
    "ZZ = multivariate_gaussian(pos,mu.numpy(),cov.numpy())\n",
    "plt.figure(111)\n",
    "plt.contourf(XX,YY,ZZ)\n",
    "\n",
    "samples = np.array(samples)\n",
    "\n",
    "plt.figure(0)\n",
    "plt.plot([0],[0],'o',label=r'$T=0$')\n",
    "\n",
    "\n",
    "plt.plot(samples[int(0.1/lr),0],samples[int(0.1/lr),1],'o',label=r'$T=0.1$')\n",
    "plt.plot(samples[int(1/lr),0],samples[int(1/lr),1],'o',label=r'$T=1$')\n",
    "plt.plot(samples[int(2/lr),0],samples[int(2/lr),1],'o',label=r'$T=2$')\n",
    "plt.plot(samples[int(4/lr),0],samples[int(4/lr),1],'o',label=r'$T=4$')\n",
    "\n",
    "plt.plot([20],[20],'o',label=r'$T=\\infty$')\n",
    "plt.plot(samples[:,0],samples[:,1],'--k')\n",
    "plt.xlim([-10,30])\n",
    "plt.ylim([-10,30])\n",
    "plt.legend()\n",
    "\n",
    "svgd_linear = samples\n",
    "svgd_linear_kl = np.squeeze(np.array(kls))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAD8CAYAAACfF6SlAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/Z1A+gAAAACXBIWXMAAAsTAAALEwEAmpwYAAAi70lEQVR4nO3de3hU1b3/8feXEC5CAoRwCQQKlkoJco83DloRAZEqKkrhxxFUIv31wFPw9jvaVuRI6wVBQLD2UPUnaIXjUY8oIAgUBSkqQcJFUC6CJSFAwCIBAUOyzh8zoUECJsye7En25/U882Rmz8za32cz82HPmjVrmXMOEREJlmp+FyAiIhVP4S8iEkAKfxGRAFL4i4gEkMJfRCSAFP4iIgEUcfibWS0z+8TM1pvZZ2b2H+Htrc3sYzPbbmb/ZWY1Ii9XRES84MWZ/wngGudcJ6AzcJ2ZXQ48CUxxzrUB/gGM8GBfIiLigYjD34UcCd+MD18ccA3wenj7LOCmSPclIiLeqO5FI2YWB6wF2gDPAjuAQ865k+GHZAPNz/LckcBIgDp16nT76U9/6kVJIiKBsXbt2gPOuUbleY4n4e+cKwQ6m1l94H+AMie4c24mMBMgPT3dZWZmelGSiEhgmNlX5X2Op6N9nHOHgOXAFUB9Myv+zyUVyPFyXyIicv68GO3TKHzGj5nVBnoDWwj9J3Br+GHDgXmR7ktERLzhRbdPCjAr3O9fDXjNOTffzDYDc83s98A64AUP9iUiIh6IOPydcxuALqVs/xK4NNL2RSR4CgoKyM7O5vjx436XElNq1apFamoq8fHxEbflyRe+IiJeys7OJiEhgVatWmFmfpcTE5xzHDx4kOzsbFq3bh1xe5reQURizvHjx2nYsKGCvwQzo2HDhp59GlL4i0hMUvCfyctjovAXEQkghb+ISAAp/EVEAkjhLyJSiueff57OnTvTuXNnqlWrdur6PffcU+62Fi1aRNu2bWnTpg1PPPFEFKotPw31FJFK7611OTy1+Av2HDpGs/q1eaBvW27qUupckmWWkZFBRkYGOTk5dO/enaysrPNqp7CwkFGjRrFkyRJSU1O55JJLuPHGG0lLS4uovkjpzF9EKrW31uXw0JsbyTl0DAfkHDrGQ29u5K113kwntmnTJjp06HDez//kk09o06YNF154ITVq1GDw4MHMm+f/bDc68xeRSu2pxV9wrKDwtG3HCgp5avEXEZ/9A2zcuJGLL7641PuuvPJK8vPzz9g+adIkrr32WgBycnJo0aLFqftSU1P5+OOPI64rUgp/EanU9hw6Vq7t5bVp0yZ69+5d6n0rV670ZB9+UPiLSKXWrH5tckoJ+mb1a3vS/saNG8/6JW9ZzvybN2/O7t27T92XnZ1N8+aRfyKJlMJfRCq1B/q25aE3N57W9VM7Po4H+raNuO2ioiK2bdtGu3btSr2/LGf+l1xyCdu2bWPnzp00b96cuXPn8uqrr0ZcW6QU/iJSqRX363s92gdg+/btpKamUqNGjfNuo3r16syYMYO+fftSWFjIXXfdRfv27SOuLVLmnPO7hlO0jKOIAGzZsuWsZ9tBV9qxMbO1zrn08rSjoZ4iIgGk8BcRCSCFv4hIAHmxgHsLM1tuZpvN7DMzGxPePt7McswsK3y5PvJyRUTEC16M9jkJ3Oec+9TMEoC1ZrYkfN8U59wkD/YhIiIe8mIB91wgN3w938y2AP7/gkFERM7K0z5/M2sFdAGKJ64YbWYbzOxFM2vg5b5EROT8eRb+ZlYXeAMY65w7DDwH/BjoTOiTweSzPG+kmWWaWWZeXp5X5YiIyDl4Ev5mFk8o+P/inHsTwDm3zzlX6JwrAv4MXFrac51zM51z6c659EaNGnlRjohIxCp6MZe77rqLxo0bn3UGUa95MdrHgBeALc65p0tsTynxsJuBTZHuS0SkVBtegykXw/j6ob8bXou4yYyMDLKysliwYAEtWrQgKyuLrKwspkyZUq52ihdzeffdd9m8eTNz5sxh8+bNZzzujjvuYNGiRRHXXVZejPb5F+B2YKOZZYW3/QYYYmadAQfsAn7pwb5ERE634TV459dQEJ7Z85vdodsAHQdF3LyXi7kApxZz+f5KXldddRW7du2KpNRy8WK0z4eAlXLXwkjbFhH5Qcse/WfwFys4FtruQfhrMRcRkVj0TXb5tpeTFnMREYlF9VJDXT2lbfeAFnMREYlFvcad3ucPEF87tD1CVXkxF03sJiKVW8dBcMMzUK8FYKG/NzzjSX+/14u5tGvXjkGDBp1azOX6669nz549AAwZMoQrrriCL774gtTUVF544YWI6z8XLeYiIjFHi7mcnRZzERGR86bwFxEJIIW/iEgAKfxFRAJI4S8iEkAKfxGRAFL4i4gEkMJfRCSAFP4iIqXwcjGXil6opSwU/iJS6S34cgF9Xu9Dx1kd6fN6HxZ8uSDiNr1azAUqfqGWstDEbiJSqS34cgHj/zae44XHAcg9msv4v40HoP+F/SNuP9LFXKDiF2opC4W/iFRq0z6ddir4ix0vPM60T6d5Ev6RLuYSqxT+IlKp7T26t1zby0uLuYiIxKCmdZqSezS31O1eiHQxl1gVcfibWQtgNtCE0GLtM51z08wsCfgvoBWhBdwHOef+Een+RKTy2rJyOSvnzib/4AESGiZz5eBhtLuyZ0Rtjuk65rQ+f4BacbUY03VMpOV6sphLrPJitM9J4D7nXBpwOTDKzNKAB4FlzrmfAMvCt0UkoLasXM57M2eQfyAPnCP/QB7vzZzBlpXLI2q3/4X9Gd99PCl1UjCMlDopjO8+3pP+fi8Wc4GKX6ilLDxfzMXM5gEzwpernXO5ZpYCvO+ca3uu52oxF5GqZ+vHe1k9bwcHds6Aonw+2vF3WiU3oGm9BAASkhsx8tn/f9pztJjL2cXkYi5m1groAnwMNHHOFXfE7SXULVTac0aaWaaZZebl5XlZjoj4bOvHe1n+l8/JP3icb49/DUCH1Kbs/eaf/eT5Bw/4VV6geRb+ZlYXeAMY65w7XPI+F/p4UepHDOfcTOdcunMuvVGjRl6VIyIxYPW8HeR9vZc/LfotMz9YQ2FREXVq1qBzy2anHpPQMNnHCoPLk9E+ZhZPKPj/4px7M7x5n5mllOj22e/FvkSkcigqKmLhyteY9/Gfcc7Rv+vPMb4DCk89pnqNmlw5eJh/RQaYF6N9DHgB2OKce7rEXW8Dw4Enwn/nRbovEakc9u7dy6BBg1j54UraNu/KkKvuJTkxhZMntnDy+IdQlE9CciNPRvvI+fHizP9fgNuBjWaWFd72G0Kh/5qZjQC+AgZ5sC8RqQQaNGhAUVERj/1uCg0OdaKwINTrW71mO2oltKfn0J9y0WXejMOX8xNx+DvnPgTsLHf3irR9Eakc1q9fzyOPPMLLL79MQkICK1euxMxOjfY58vUJ6ibV5IoBP1bwxwD9wldEInLixAkmTJjAk08+SVJSElu3bqVbt26EeoThosuaKuxjkKZ0FpHztnr1arp06cIf/vAHhg4dypYtW+jWrZvfZUkZKPxF5LyNGzeOo0ePsmjRIl566SWSkpL8LskzXi3msnv3bnr27ElaWhrt27dn2rRpUaq4fDz/hW8k9Atfkdi3ZMkS0tLSaN68OXv27CEhIYGEhARP91HeX/h+88477J8ylZO5uVRPSaHxPWOpd8MNntSSk5ND9+7d+eqrr87r+bm5ueTm5tK1a1fy8/Pp1q0bb731FmlpaefVXkz+wldEqq5//OMf3HXXXfTp04fHHnsMgGbNmnke/OX1zTvvkPvwOE7u2QPOcXLPHnIfHsc377zjSfuRLuaSkpJC165dAUhISKBdu3bk5OR4Ulsk9IWviJzh+2fSH112Kf/vpZfIy8vjoYceYty4cX6XeMr+KVNxx09fzMUdP87+KVM9Ofv3cjGXXbt2sW7dOi677LKI64qUwl9ETlN8Jl0cqC9/9hkTlv+VDq1bs3DNGrp06eJzhac7mXvmXP7n2l5eXi3mcuTIEQYOHMjUqVNJTEz0pLZIKPxF5DT7p0yl6Ngxvikqon5cHP0SEznhHMNb/oi0GAt+gOopKaEun1K2e8GLxVwKCgoYOHAgQ4cO5ZZbbvGkrkgp/EXkNF/9/e/8R24uXxeeZO6PWlE/Lo47kpJg3z6/SytV43vGnvZJBcBq1aLxPWMjbtuLxVycc4wYMYJ27dpx7733RlyTV/SFr4gAoaCbMWMGA3btZO2xb7m5Xv3TAsKrM2mv1bvhBlImPEr1Zs3AjOrNmpEy4VFP+vu9WMxl1apVvPzyy/z1r389NVx04cKFEdcWKZ35iwi5ubncdtttrFq1il5duvDQ8RM0Kyo6db9XZ9LRUu+GGzwb2lnSRRddxObNmyNqo0ePHsTSkPpiOvMXEZKSkqhWrRqzZs1iydq1pD/5RFTOpCV26MxfJKDWrVvHI488wiuvvEJiYiIffPDBqfl4onUmLbFDZ/4iAXP8+HF+85vfcMkll/DJJ5+wbds2gFPBL8Gg8BcJkA8//JBOnTrx+OOPM2zYME3EFmDq9hEJkEcffZTvvvuO995776w/XJJgUPiLVHGLFy+mffv2pKamMmvWLBISEqhbt67fZYnP1O0jUkUdPHiQ4cOHc9111/HEE08AoUnGFPwCHoW/mb1oZvvNbFOJbePNLMfMssKX673Yl4icm3OO119/nbS0NF599VV+97vfMXnyZL/Lkhjj1Zn/S8B1pWyf4pzrHL74/5M2kQD44x//yG233UaLFi3IzMxkwoQJ1KxZ0++yKh2vFnMpVlhYSJcuXfj5z3/ucaXnx5M+f+fcCjNr5UVbIlJ+zjm+/vprGjZsyJAhQygoKGD06NFUrx6Mr/WisUh8RkYGGRkZpxZzycrKiqi9adOm0a5dOw4fPhxRO16Jdp//aDPbEO4WalDaA8xspJllmllmXl5elMsRqXp27txJnz596N27NwUFBSQlJTF27NhABf/yv3zOka9PAHDk6xMs/8vnbP14ryftR7qYC0B2djYLFiwgIyPDk5q8EM3wfw74MdAZyAVK7XR0zs10zqU759IbNWoUxXJEqpbCwkKeeeYZLr74Yj766CPuvvtu4uLi/C6rwq2et4OT3xWdtu3kd0WsnrfDk/Z/aDGX4u6gkpelS5ee9rixY8cyceJEqlWLnTE2UTs1cM6dmv/VzP4MzI/WvkSCJjc3l4EDB7J69Wr69evHn/70J1q2bOl3Wb4oPuMv6/byinQxl/nz59O4cWO6devG+++/70lNXoha+JtZinOueCmdm4FN53q8iJRdUlIS8fHxvPzyywwdOjTQUzPUTapZatDXTfLmS+5IF3NZtWoVb7/9NgsXLuT48eMcPnyYf/3Xf+WVV17xpL7zZV5MNWpmc4CrgWRgH/BI+HZnwAG7gF+W+M+gVOnp6S4zMzPiekSqorVr1zJu3DjmzJlDYmIizrkqG/pbtmw56wIq31fc51+y66d6jWr0HPrTiL/0LSoqon79+hw4cCCiOf2Lvf/++0yaNIn588+/I6S0Y2Nma51z6eVpx6vRPkNK2fyCF22LBN2xY8cYP348kyZNomnTpuzYsYMuXbpU2eAvr+KA93q0D3izmEusCsZwAJFKasWKFWRkZLBt2zbuvvtuJk6cSP369f0uK+ZcdFlTT8L+jHY9WMylpKuvvpqrr77as/YiofAXiWF/+MMfKCwsZNmyZVxzzTV+lyNViMJfJMYsXLiQDh060KJFi1MTsdWpU8fvsqSKiZ1BpyIBd+DAAW6//Xb69+/PxIkTAWjatKmCX6JCZ/4iPlnw5QKmfTqN3CO52Abj77P+ztHDR3nkkUd46KGH/C5PqjiFv4gPFny5gPF/G8/xwuMcXHaQ3FdyuaD1BUx9ZSqj+o3yuzwJAHX7iPhg6tqpHPnHEQDqX1GflKEptP5da+YdnedzZRIUCn+RCrZjxw5WP7KaXZN24U464urE0bB3QyzO2HvUm8nIRH6Iwl+kghQWFvL000/ToUMHTuw6QdI1SWe8A5vW8X6sukhpFP4iFWDPnj10796d++67j169evH8kudp1qsZVu2fv9KtFVeLMV3H+FillOT1Yi6xRl/4ilSA5ORk6tSpw6uvvsrgwYMxM5JTkpn26TT2Ht1L0zpNGdN1DP0v7O93qZXSlpXLWTl3NvkHD5DQMJkrBw+j3ZU9I2rT68VcYo3CXyRK1qxZw7hx45g7dy716tVj2bJlp83H0//C/gp7D2xZuZz3Zs7g5HehmT3zD+Tx3swZABH/BwDeLOYSi9TtI+Kxb7/9lvvvv5/LL7+cjRs38uWXXwJoIrYoWTl39qngL3byuxOsnDvbk/a9WMzl3XffpWfPnjz88MMsX76cn/3sZ9x3332e1He+dOYv4qH333+fjIwMduzYwS9/+UuefPJJ6tWr53dZVVr+wQPl2l5ekS7mArBs2TKWL1/OxIkTmTJlCkuXLmXOnDls3ryZtLQ0T+osL4W/iIcef/xxAJYvXx4zszdWdQkNk8k/cOb63wkNkz1pP9LFXACK101JSkriyJEjFBYW4pzDi/VUzpfCXyRC77zzDp06daJly5bMnj2bhIQELrjgAr/LCowrBw87rc8foHqNmlw5eFjEbRcVFbFt27azLixT1jP/a6+9ll69etG5c2fGjx9Pnz596NSpE8OHD4+4xvOl8Bc5T3l5eYwZM4Y5c+YwevRopk+fTpMmTfwuK3CKv9T1erQPeLeYS79+/ejXr9+p2ytWrIi0tIgp/EXKyTnHnDlz+PWvf83hw4d59NFH+fd//3e/ywq0dlf29CTsv8/rxVxiiSejfczsRTPbb2abSmxLMrMlZrYt/LeBF/sS8dv06dMZOnQobdq0Yd26dTz88MNVcpk/qdq8Gur5EnDd97Y9CCxzzv0EWBa+LVIpFRUVsX//fgCGDRvGjBkzWLVqFe3bt/e5MpHz40n4O+dWAF9/b/MAYFb4+izgJi/2JVLRtm/fTq9evejbty8FBQXUr1+fUaNGERcX53dpVZqfI2FilZfHJJo/8mrinMsNX98LlPpNmJmNNLNMM8vMyztzuJaIX06ePMmkSZPo0KED69atY/To0VSvrq/JKkKtWrU4ePCg/gMowTnHwYMHqVWrliftVcgr2TnnzKzUf0Xn3ExgJkB6err+pSUm7Nmzh5tuuok1a9YwYMAA/vjHP9KsWTO/ywqM1NRUsrOz0Qnh6WrVqkVqaqonbUUz/PeZWYpzLtfMUoD9UdyXiKeSk5NJTExk7ty5DBo0SFMzVLD4+Hhat27tdxlVWjS7fd4Gin/BMBzQEkUS0z766CP69u3LN998Q40aNVi6dCm/+MUvFPxSJXk11HMOsBpoa2bZZjYCeALobWbbgGvDt0ViztGjR7nnnnvo3r07W7ZsYdeuXX6XJBJ1nnT7OOeGnOWuXl60LxIty5Yt4+6772bnzp3827/9G48//jiJiYl+lyUSdRq6IIH21FNPUb16dT744AOuuuoqv8sRqTAKfwmcefPm0aVLl9MmYqtdu7bfZYlUKC3mIoGxb98+fvGLX3DTTTcxadIkABo3bqzgl0BS+EuV55zjlVdeIS0tjbfeeovf//73TJ482e+yRHyl8Jcqb/r06dx+++20bduWrKwsfvvb3xIfH+93WSK+Up+/VElFRUXk5eXRpEkThg0bRnx8PCNHjtR8PCJhOvOXKmfr1q1cffXV9OnT59REbL/61a8U/CIlKPylyjh58iRPPvkkHTt2PLXuqiZiEymd3hlSJeTk5HDjjTfy6aefcsstt/Dss8/StGlTv8sSiVkKf6kSGjVqRHJyMq+//joDBw70uxyRmKduH6m0/va3v9G7d+9TE7EtXrxYwS9SRgp/qXSOHDnCmDFj6NGjB1u3btVEbCLnQeEvlcp7773HxRdfzPTp0xk1ahSbNm2iU6dOfpclUumoz18qDeccTz/9NLVq1WLFihX06NHD75JEKi2Fv8S8N998k27duvGjH/2I2bNnk5iY6Nk6piJBpW4fiVl79+7l1ltvZeDAgTz99NNAaCI2Bb9I5BT+EnOcc7z00kukpaUxf/58Hn/88VOzcIqINxT+EnOmTZvGnXfeSfv27Vm/fj0PPvigJmIT8VjU+/zNbBeQDxQCJ51z6dHep1Q+RUVF7N+/n6ZNm3LnnXdywQUXkJGRQbVqOj8RiYaK+sK3p3PuQAXtSyqZzz//nIyMDPLz88nMzKRevXqMHDnS77JEqjSdVolvCgoKeOyxx+jUqRObN2/mvvvu00RsIhWkIt5pDnjPzBzwn865mSXvNLORwEiAli1bVkA5Eguys7O54YYbyMrK4tZbb2XGjBk0adLE77JEAqMiwr+Hcy7HzBoDS8zsc+fciuI7w/8ZzARIT093FVCPxIAmTZrQtGlT3njjDW655Ra/yxEJnKh3+zjncsJ/9wP/A1wa7X1KbFq5ciXXXHMNhw4dIj4+nnfffVfBL+KTqIa/mdUxs4Ti60AfYFM09ymxJz8/n1GjRnHVVVexc+dOdu/e7XdJIoEX7TP/JsCHZrYe+ARY4JxbFOV9SgxZtGgR7du357nnnmPs2LFs2rSJDh06+F2WSOBFtc/fOfcloCkXA8o5xzPPPEPdunVZtWoVV1xxhd8liUiYxtWJp5xzvPHGG6Snp9OqVStmz55NQkICNWvW9Ls0ESlB4/zFM7m5uQwcOJDbbruNKVOmAJCcnKzgF4lBCn+JmHOOF198kbS0NN59910mTpzI5MmT/S5LRM5B4S8RmzZtGiNGjKBjx46sX7+eBx54QL/UFYlxeofKeSksLGTfvn00a9aMO++8k4SEBO68805NxCZSSeidKuW2efNmevToQd++fSkoKKBevXqMGDFCwS9SiejdKmX23XffMWHCBLp06cK2bdt48MEH1b0jUknpnStlkp2dTf/+/dmwYQODBw9m2rRpNG7c2O+yROQ8KfzlTBteg2WPwjfZUC8Veo2jSbubSU1NZcKECdx4441+VygiEVL4y+k2vAbv/BoKjvHBrpM88v7nvHVwNPUHwYIFC/yuTkQ8oj5/Od2yRzl85Ft+Nf8YV8/6lt2Hi9h98NvQJwERqTJ05i+nWbBmJ/93wTH25DvuvbwGj/asSZ0aFuoCEpEqQ+EvpzjneHZdNerVNF6/rTaXpZZ4edRL9a8wEfGcun0CzjnH3Llz2blzJ2bG7D9NYe2o5NODP7429BrnX5Ei4jmFf4Dl5OQwYMAAhgwZwjPPPANA8s8yqHnzdKjXArDQ3xuegY6D/C1WRDylbp8Acs7x/PPPc//991NQUMDkyZMZM2bMPx/QcZDCXqSK05l/AE2dOpWRI0fSrVs3Nm7cyL333ktcXJzfZYlIBdKZf0AUFhayd+9emjdvzogRI2jQoAHDhw/HzPwuTUR8EPXwN7PrgGlAHPC8c+6JaO8z6N5al8NTi79gz6FjNKtfm0E/drw66Td8++23fPrppyQmJnLHHXf4XaaI+Ciq4W9mccCzQG8gG1hjZm875zZHc79B9ta6HB56cyPHCgpxhQV8Nv9Vxq5+jcTERP7zuWc1EZuIANE/878U2B5eyB0zmwsMABT+UfLU4i84VlDIycN57P/v8RQc+IoL0n5G21vGMHjwzX6XJyIxItrh3xzYXeJ2NnBZyQeY2UhgJEDLli2jXE7Vt+fQMQDi6jSger3G1P/ZcC5ocyl5BT4XJiIxxffRPs65mc65dOdceqNGjfwup9JrVr82ABZXnca3PsIFbS49bbuICEQ//HOAFiVup4a3SZQ80LctteNPH7ZZOz6OB/q29akiEYlF0e72WQP8xMxaEwr9wcD/ifI+A+2mLs0BThvt80Dftqe2i4hAlMPfOXfSzEYDiwkN9XzROfdZNPcpof8AFPYici5RH/fnnFsILIz2fkREpOx8/8JXREQqnsJfRCSAFP4iIgGk8BcRCSCFv4hIACn8RUQCSOEvIhJACn8RkQBS+IuIBJDCX0QkgBT+IiIBpPAXEQkghb+ISAAp/EVEAkjhLyISQAp/EZEAUviLiASQwl9EJICiFv5mNt7McswsK3y5Plr7EhGR8on2Gr5TnHOTorwPEREpJ3X7iIgEULTDf7SZbTCzF82sQZT3JSIiZRRR+JvZUjPbVMplAPAc8GOgM5ALTD5LGyPNLNPMMvPy8iIpR0REysicc9HfiVkrYL5z7uJzPS49Pd1lZmZGvR4RkarEzNY659LL85xojvZJKXHzZmBTtPYlIiLlE83RPhPNrDPggF3AL6O4LxERKYeohb9z7vZotS0iIpHRUE8RkQBS+IuIBJDCX0QkgBT+IiIBpPAXEQkghb+ISAAp/EVEAkjhLyISQAp/EZEAUviLiASQwl9EJIAU/iIiAaTwFxEJIIW/iEgAKfxFRAJI4S8iEkAKfxGRAFL4i4gEkMJfRCSAIgp/M7vNzD4zsyIzS//efQ+Z2XYz+8LM+kZWpoiIeCnSBdw3AbcA/1lyo5mlAYOB9kAzYKmZXeScK4xwfyIi4oGIzvydc1ucc1+UctcAYK5z7oRzbiewHbg0kn2JiIh3Ij3zP5vmwEclbmeHt53BzEYCI8M3T5jZpijV5KVk4IDfRZSB6vRWZaizMtQIqtNrbcv7hB8MfzNbCjQt5a7fOufmlXeH3+ecmwnMDO8r0zmX/gNP8Z3q9Jbq9E5lqBFUp9fMLLO8z/nB8HfOXXseteQALUrcTg1vExGRGBCtoZ5vA4PNrKaZtQZ+AnwSpX2JiEg5RTrU82YzywauABaY2WIA59xnwGvAZmARMKqMI31mRlJPBVKd3lKd3qkMNYLq9Fq56zTnXDQKERGRGKZf+IqIBJDCX0QkgGIi/CvjNBFmNt7McswsK3y53u+aipnZdeHjtd3MHvS7nrMxs11mtjF8/Mo9VC1azOxFM9tf8jcnZpZkZkvMbFv4bwM/awzXVFqdMfe6NLMWZrbczDaH3+djwttj6pieo86YOaZmVsvMPjGz9eEa/yO8vbWZfRx+z/+XmdX4wcacc75fgHaEfqTwPpBeYnsasB6oCbQGdgBxftcbrm08cL/fdZRSV1z4OF0I1AgfvzS/6zpLrbuAZL/rKKWuq4CuwKYS2yYCD4avPwg8GaN1xtzrEkgBuoavJwBbw+/tmDqm56gzZo4pYEDd8PV44GPgckIDbAaHt/8J+NUPtRUTZ/5O00R46VJgu3PuS+fcd8BcQsdRysg5twL4+nubBwCzwtdnATdVZE2lOUudMcc5l+uc+zR8PR/YQugX/zF1TM9RZ8xwIUfCN+PDFwdcA7we3l6mYxkT4X8OzYHdJW6fdZoIn4w2sw3hj9++dwOExfoxK8kB75nZ2vA0H7GsiXMuN3x9L9DEz2J+QCy+LgEws1ZAF0JnrDF7TL9XJ8TQMTWzODPLAvYDSwh90j/knDsZfkiZ3vMVFv5mttTMNpVyidmz0h+o+Tngx0BnIBeY7GetlVQP51xXoB8wysyu8rugsnChz9axOkY6Zl+XZlYXeAMY65w7XPK+WDqmpdQZU8fUOVfonOtMaOaES4Gfnk870ZrY7QyuEk4TUdaazezPwPwol1NWlWZqDedcTvjvfjP7H0Iv5BX+VnVW+8wsxTmXa2YphM66Yo5zbl/x9Vh6XZpZPKFA/Ytz7s3w5pg7pqXVGavH1Dl3yMyWE/qRbX0zqx4++y/Tez7Wu31idpqI8Iu12M2E1jaIBWuAn4S//a9BaF2Ft32u6QxmVsfMEoqvA32InWNYmreB4eHrw4GIJzWMhlh8XZqZAS8AW5xzT5e4K6aO6dnqjKVjamaNzKx++HptoDeh7yaWA7eGH1a2Y+n3t9fhb6dvJtRPdQLYBywucd9vCfVpfQH087vWEnW9DGwENhB6Eaf4XVOJ2q4nNFJhB6HZV32vqZQaLyQ0Emk98Fks1QnMIfTxviD8uhwBNASWAduApUBSjNYZc69LoAehLp0NQFb4cn2sHdNz1BkzxxToCKwL17IJGBfefiGhE+PtwH8DNX+oLU3vICISQLHe7SMiIlGg8BcRCSCFv4hIACn8RUQCSOEvIhJACn8RkQBS+IuIBND/ArlNvE/akFwdAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "Sigma_0 = torch.tensor([[1.,.0],[.0,1.]])\n",
    "X0 = torch.matmul(torch.randn(1000,2),Sigma_0**0.5)\n",
    "\n",
    "\n",
    "Sigma_opt_inv = torch.inverse(Sigma_opt)\n",
    "mu0 = torch.tensor([0.,0])\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "K = torch.eye(2)\n",
    "X = X0.clone()\n",
    "X = X.T\n",
    "I = torch.eye(2)\n",
    "N = 100\n",
    "XX = np.linspace(-10, 50, N)\n",
    "YY = np.linspace(-10, 50, N)\n",
    "XX, YY = np.meshgrid(XX, YY)\n",
    "pos = np.empty(XX.shape + (2,))\n",
    "pos[:, :, 0] = XX\n",
    "pos[:, :, 1] = YY\n",
    "m = np.array([0.,0.]) \n",
    "\n",
    "lr = 1e-3\n",
    "I = torch.eye(2)\n",
    "\n",
    "\n",
    "cov = Sigma_0.clone()\n",
    "mu = mu0.clone()\n",
    "\n",
    "T=10\n",
    "samples = []\n",
    "kls = []\n",
    "H = Sigma_opt\n",
    "K = I\n",
    "mu_opt_mu_opt = (mu_opt).reshape(-1,1).matmul((mu_opt).reshape(1,-1))\n",
    "for i in range(int(T/lr)):\n",
    "    cov_inv = torch.inverse(cov)\n",
    "    Q = I\n",
    "    P = H\n",
    "\n",
    "    Q = I\n",
    "    PSQ = torch.matmul(P,Sigma_opt_inv).matmul(Q)\n",
    "    mu += lr*torch.matmul(PSQ,mu_opt-mu)\n",
    "    \n",
    "    diff = I + lr*(torch.matmul(P,cov_inv).matmul(Q)-PSQ)\n",
    "    \n",
    "    cov = torch.matmul(diff,cov).matmul(diff.t())\n",
    "    samples.append(mu.clone().numpy())\n",
    "\n",
    "    kls.append(kl_divergence(mu, mu_opt, cov, Sigma_opt).numpy())\n",
    "\n",
    "\n",
    "plt.figure(0)\n",
    "\n",
    "ZZ = multivariate_gaussian(pos,mu.numpy(),cov.numpy())\n",
    "\n",
    "plt.contourf(XX,YY,ZZ)\n",
    "\n",
    "plt.figure(1)\n",
    "\n",
    "samples = np.array(samples)\n",
    "plt.plot([0],[0],'o',label=r'$T=0$')\n",
    "plt.plot(samples[int(0.1/lr),0],samples[int(0.1/lr),1],'o',label=r'$T=0.1$')\n",
    "plt.plot(samples[int(1/lr),0],samples[int(1/lr),1],'o',label=r'$T=1$')\n",
    "plt.plot(samples[int(2/lr),0],samples[int(2/lr),1],'o',label=r'$T=2$')\n",
    "plt.plot(samples[int(4/lr),0],samples[int(4/lr),1],'o',label=r'$T=4$')\n",
    "plt.plot([20],[20],'o',label=r'$T=\\infty$')\n",
    "plt.plot(samples[:,0],samples[:,1],'--k')\n",
    "plt.xlim([-10,30])\n",
    "plt.ylim([-10,30])\n",
    "plt.legend()\n",
    "\n",
    "ours = samples\n",
    "ours_kl = np.squeeze(np.array(kls))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "class SVGD:\n",
    "  def __init__(self, P, K, optimizer):\n",
    "    self.P = P\n",
    "    self.K = K\n",
    "    self.optim = optimizer\n",
    "\n",
    "  def phi(self, X):\n",
    "    X = X.detach().requires_grad_(True)\n",
    "\n",
    "    log_prob = self.P.log_prob(X)\n",
    "    score_func = autograd.grad(log_prob.sum(), X)[0]\n",
    "\n",
    "    K_XX = self.K(X, X.detach())\n",
    "\n",
    "    grad_K = -autograd.grad(K_XX.sum(), X)[0]\n",
    "\n",
    "    phi = (K_XX.detach().matmul(score_func) + grad_K) / X.size(0)\n",
    "\n",
    "    return phi\n",
    "\n",
    "  def step(self, X):\n",
    "    self.optim.zero_grad()\n",
    "    X.grad = -self.phi(X)\n",
    "    self.optim.step()\n",
    "\n",
    "    \n",
    "class RBF(torch.nn.Module):\n",
    "  def __init__(self, sigma=None):\n",
    "    super(RBF, self).__init__()\n",
    "\n",
    "    self.sigma = sigma\n",
    "\n",
    "  def forward(self, X, Y):\n",
    "    XX = X.matmul(X.t())\n",
    "    XY = X.matmul(Y.t())\n",
    "    YY = Y.matmul(Y.t())\n",
    "\n",
    "    dnorm2 = -2 * XY + XX.diag().unsqueeze(1) + YY.diag().unsqueeze(0)\n",
    "\n",
    "    # Apply the median heuristic (PyTorch does not give true median)\n",
    "    if self.sigma is None:\n",
    "      np_dnorm2 = dnorm2.detach().cpu().numpy()\n",
    "      h = np.median(np_dnorm2) / (2 * np.log(X.size(0) + 1))\n",
    "      sigma = np.sqrt(h).item()\n",
    "    else:\n",
    "      sigma = self.sigma\n",
    "\n",
    "    gamma = 1.0 / (1e-8 + 2 * sigma ** 2)\n",
    "    K_XY = (-gamma * dnorm2).exp()\n",
    "\n",
    "    return K_XY\n",
    "  \n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_init = torch.randn([1000,2])\n",
    "\n",
    "gauss = torch.distributions.MultivariateNormal(mu_opt,\n",
    "        covariance_matrix=Sigma_opt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "K = RBF(1)\n",
    "X = X_init.clone()\n",
    "lr = 1e-2\n",
    "svgd = SVGD(gauss, K, optim.SGD([X], lr=lr))\n",
    "samples = []\n",
    "kls = []\n",
    "for _ in range(int(10/lr)):\n",
    "    mu = X.mean(0).clone()\n",
    "    cov = torch.cov(X.t())\n",
    "    samples.append(mu.numpy())\n",
    "    svgd.step(X)\n",
    "    \n",
    "    kls.append(kl_divergence(mu, mu_opt, cov, Sigma_opt).numpy())\n",
    "\n",
    "svgd_rbf = samples\n",
    "svgd_rbf_kl = np.squeeze(np.array(kls))\n",
    "    \n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f8d6d5f9b10>"
      ]
     },
     "execution_count": 9,
     "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.figure(1)\n",
    "\n",
    "samples = np.array(samples)\n",
    "plt.plot([0],[0],'o',label=r'$T=0$')\n",
    "plt.plot(samples[int(0.1/lr),0],samples[int(0.1/lr),1],'o',label=r'$T=0.1$')\n",
    "plt.plot(samples[int(1/lr),0],samples[int(1/lr),1],'o',label=r'$T=1$')\n",
    "plt.plot(samples[int(2/lr),0],samples[int(2/lr),1],'o',label=r'$T=2$')\n",
    "plt.plot(samples[int(4/lr),0],samples[int(4/lr),1],'o',label=r'$T=4$')\n",
    "plt.plot([20],[20],'o',label=r'$T=\\infty$')\n",
    "plt.plot(samples[:,0],samples[:,1],'--k')\n",
    "plt.xlim([-10,30])\n",
    "plt.ylim([-10,30])\n",
    "plt.legend()\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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",
    "Sigma_0 = torch.tensor([[1.,.0],[.0,1.]])\n",
    "X0 = torch.matmul(torch.randn(1000,2),Sigma_0**0.5)\n",
    "\n",
    "\n",
    "Sigma_opt_inv = torch.inverse(Sigma_opt)\n",
    "mu0 = torch.tensor([0.,0])\n",
    "\n",
    "K = torch.eye(2)\n",
    "X = X0.clone()\n",
    "X = X.T\n",
    "I = torch.eye(2)\n",
    "N = 100\n",
    "XX = np.linspace(-10, 50, N)\n",
    "YY = np.linspace(-10, 50, N)\n",
    "XX, YY = np.meshgrid(XX, YY)\n",
    "pos = np.empty(XX.shape + (2,))\n",
    "pos[:, :, 0] = XX\n",
    "pos[:, :, 1] = YY\n",
    "m = np.array([0.,0.]) \n",
    "\n",
    "lr = 1e-3\n",
    "I = torch.eye(2)\n",
    "\n",
    "\n",
    "cov = Sigma_0.clone()\n",
    "mu = mu0.clone()\n",
    "\n",
    "T=10\n",
    "samples = []\n",
    "kls = []\n",
    "H = I\n",
    "K = I\n",
    "mu_opt_mu_opt = (mu_opt).reshape(-1,1).matmul((mu_opt).reshape(1,-1))\n",
    "\n",
    "for i in range(int(T/lr)):\n",
    "    cov_inv = torch.inverse(cov)\n",
    "\n",
    "    K = cov_inv\n",
    "\n",
    "    P = H\n",
    "    \n",
    "  \n",
    "    Q = torch.matmul(cov,K)\n",
    "    PSQ = torch.matmul(P,Sigma_opt_inv).matmul(Q)\n",
    "    mu += lr*torch.matmul(PSQ,mu_opt-mu)\n",
    "    \n",
    "    diff = I + lr*(torch.matmul(P,cov_inv).matmul(Q)-PSQ)\n",
    "    \n",
    "    cov = torch.matmul(diff,cov).matmul(diff)\n",
    "    samples.append(mu.clone().numpy())\n",
    "    kls.append(kl_divergence(mu, mu_opt, cov, Sigma_opt).numpy())\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "samples = np.array(samples)\n",
    "plt.plot([0],[0],'o',label=r'$T=0$')\n",
    "plt.plot(samples[int(0.1/lr),0],samples[int(0.1/lr),1],'o',label=r'$T=0.1$')\n",
    "plt.plot(samples[int(1/lr),0],samples[int(1/lr),1],'o',label=r'$T=1$')\n",
    "plt.plot(samples[int(2/lr),0],samples[int(2/lr),1],'o',label=r'$T=2$')\n",
    "plt.plot(samples[int(4/lr),0],samples[int(4/lr),1],'o',label=r'$T=4$')\n",
    "plt.plot([20],[20],'o',label=r'$T=\\infty$')\n",
    "plt.plot(samples[:,0],samples[:,1],'--k')\n",
    "plt.xlim([-10,30])\n",
    "plt.ylim([-10,30])\n",
    "plt.legend()\n",
    "\n",
    "w_grad = samples\n",
    "w_grad_kl = np.squeeze(np.array(kls))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": [
    "plt.plot(np.arange(len(svgd_linear_kl))/1000,svgd_linear_kl,label='SVGD (Linear)')\n",
    "plt.plot(np.arange(len(svgd_rbf_kl))*10/1000,svgd_rbf_kl,label='SVGD (RBF)')\n",
    "plt.plot(np.arange(len(w_grad_kl))/1000,w_grad_kl,label='Wasserstein Grad')\n",
    "plt.plot(np.arange(len(ours_kl))/1000,ours_kl,'--',label='Ours')\n",
    "plt.xlabel('iterations (K)',fontsize=16)\n",
    "plt.ylabel('KL divergence',fontsize=30)\n",
    "plt.ylim([1e-6,1e3])\n",
    "plt.yscale('log')\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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": [
    "def dist_f(x):\n",
    "    return np.sum((x-mu_opt.numpy().reshape(1,-1))**2,1)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "plt.plot(np.arange(len(svgd_linear_kl))/1000,dist_f(svgd_linear),label='SVGD (Linear)')\n",
    "plt.plot(np.arange(len(svgd_rbf))*10/1000,dist_f(svgd_rbf),label='SVGD (RBF)')\n",
    "plt.plot(np.arange(len(w_grad_kl))/1000,dist_f(w_grad),label='Wasserstein Grad')\n",
    "plt.plot(np.arange(len(ours_kl))/1000,dist_f(ours),'--',label='Ours')\n",
    "plt.xlabel('iterations (K)',fontsize=16)\n",
    "plt.ylabel('$\\Vert\\mu_t - \\mu_*\\Vert^2$',fontsize=30)\n",
    "plt.ylim([5e-6,1e3])\n",
    "plt.yscale('log')\n",
    "plt.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
