{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d5d296b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "187233af",
   "metadata": {},
   "source": [
    "### Diagonal Targets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "0451d115",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 468x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "methods = [\"nem\", \"pfb\", \"fb\", \"pklm\", \"klm\"]\n",
    "colors = [\"blue\", \"red\", \"purple\", \"orange\", \"green\"]\n",
    "\n",
    "target = \"diag\"\n",
    "d = 10\n",
    "lr = 1e-2\n",
    "n_epochs = 1500\n",
    "\n",
    "absc = np.array(range(n_epochs)) * lr\n",
    "\n",
    "figure, ax = plt.subplots(1, 1, figsize=(6.5, 2.5))\n",
    "\n",
    "for i, method in enumerate(methods):\n",
    "    L_kl = np.loadtxt(\"./results/KL_method_\"+method+\"_target\"+target+\"_d\"+str(d)+\"_lr\"+str(lr))\n",
    "    mean = np.mean(L_kl, axis=0)\n",
    "    std = np.std(L_kl, axis=0)\n",
    "\n",
    "    plt.plot(absc, mean, label=method.upper(), c=colors[i])\n",
    "    plt.fill_between(absc, mean-std, mean+std, alpha=0.5, color=colors[i])\n",
    "\n",
    "plt.yscale(\"log\")\n",
    "# plt.ylabel(\"KL\", rotation=0, fontsize=13)\n",
    "plt.title(r\"KL($\\mu_t$||$\\mu^*$)\", fontsize=13)\n",
    "plt.xlabel(r\"Time ($\\tau \\cdot$ Iterations)\", fontsize=13)\n",
    "plt.grid(True)\n",
    "legend = plt.legend(fontsize=13, loc=\"lower left\")\n",
    "# plt.savefig(\"./KL_conv_Gaussians_diag_d10_full.pdf\", format=\"pdf\", bbox_inches=\"tight\") #, dpi=150)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "7b3d3427",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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e3diYip24Hbv3k1KSoqHllWPmrRXVcnNzWXdOisSETXhAWsP+tprMHcu/PWve3r5PPKITcMdd5zFP3tAerrFOZxwggXZvfaaLTmNGmV9ff7xD0syLVFizuFwVJEGM722c+dOWrVqtU/BaeyICImJibRr147NHq+llEtMjIWQzZhhiyw9e8LChfbtf8opsGyZp+ZkZNjU2sSJJjgZGVa9+je/gTPOsKILLtjA4ageDeYbOhQKERsbG20z6gUJCQkUepgzs18CAYtrnjsXxo6F1q1t2u3QQ62u25YtnplSlFz62GPm9Zx5poVdv/OO9e+58UaXXOpwVIcGIzpgf8k79k+d/ZxSU+FPf7JggxtvtD7Vzz5rwQb//Ke1DvWIouTS//7XkkuHDLHc1ieegCOOgAcfdMmlDkdVaFCi42ggtG4N//63hVmfcYZFtt1+u+X6vPIKBIOemZKcDOeea+s8Y8aY87VxI/zlLxbpNmWK61zqcBwITnSiwNChQxERZs+eXWq8a9euPP/886xcuRIRISkpiTZt2pCcnExycjJHHXVU8bkigt/vZ32ZDp73338/IsJll13mxY9Se4hA9+72rf7hh9arYM0auOgiSzr97DNPF1hatrRI70mTLLm0WzcrIDpypC1BzZvn1nscjsrgRCdKNGvWjD//+c9Fze7K5ccff2TDhg1kZWWRlZXF559/Xur4wQcfzIQJE4r3VZVx48bRs2fPWrPbc2JibDFlxgwrItqjB3z9tfXyOe00+OknT83p1g3uv9+m3S680MRo9mxLLr3wQpdc6nDsDyc6UWLUqFGsXbuWiRMnVvkeV111Fc8991yxcM2aNYtAIFDKI2owxMVZ0szcufat37IlvPsuDBhgOT/bt3tmSkyMres8+yw8/bRV9YmNtai3I46Av/3NU3McjnqFE50okZSUxD333MPtt99Ofn5+le4xaNAgUlJS+PjjjwF49tlnGTVqVE2aWfdo0gRuucVima+91r7t//Mf84D+9S9PW4XGx1tk9yuvWGDBkUdCVpbl9QwaZPmurnOpw1GaBpMcWpY//AG++Wbv8VAoocaT/Pr3t5zGA+Xyyy/nkUce4d///je33HLLXsd79+5dKtLsggsu4Mknnyx1zqhRo3jmmWc49NBDeffdd3nsscf461//euDG1DfatLFQshtusNIB06dbkukzz9i3/tlne5bNmZ4Ol19uU2zPP78nufTqq+HJJ+G++1xyqcNRhPN0oojP52Ps2LH84x//YFs5xb4WL17MmjVr2LlzJzt37txLcAAuuugipk+fzgMPPMApp5xCs2bNvDC9biBi4dRTp9pU2+DBsHKlre4feaRNxXm4up+RAXfcYZ7PqFFw0EG2/HTaaZZg6pJLHY4G7OlU5Hns3p1bp8rgnHTSSRx++OHcc889Vbo+LS2N008/nfvvv58ZM2bUsHX1BJ/PXImZMy3abcwYm34bMgROOslqvXXu7IkpRcmljz4K//ufdTD97DN47z2LAD//fCs116aNJ+Y4HHUOzzwdEeksIs+JyOQSY0ki8oKIPCsiF3plS13jgQce4Omnn2ZLFTPv77vvPqZPn86QIUNq2LJ6Rny8hZB98YVNsbVsaX2qDznEpuF27PDMlKLk0uefNwEaNgxCIVt+OvxwK7zgkksdjZFKiY6IjBeRzSLyfZnxESLyo4gsF5Fb93UPVV2hqleWGT4LmKyqo4DfHJDlDYhDDjmEkSNHkpmZWWq8e/fupfJ02rdvX+71bdq0Yfjw4XW30oDXpKXZOs+8eXDNNVa1+oknLNjggQesb7VHFHUunTjRimgfdphV9fnrXy3SbfJkl1zqaFxUdnrteeBx4L9FAyLiA54ATgDWAl+JyNuAD/hnmeuvUNXyKky2BxZF3ocqb3b9ZtasWXuNTZgwYa+cG6i4yvS+8nvGjRtXfSMbAu3aWZnoomCDjz+2UgLPPGNldc44wzNTWrWypNJTTrFQ62nT4Mcf4YILbClq7FiLeHN/NzgaOpXydFR1NlA282AQsDziwRQAk4DTVXWRqp5aZquopPFaTHgqbYvDcUCIWPmcN9+0qp2DBsGKFeZ+HHMM/i1bPFvdF7Hk0vvus2m3iy6yij9z5sDw4Rb/sHKlJ6Y4HFFD9vUXc6kTRToC76hqn8j+OcAIVb0qsn8xcISq3lDB9c2AezHPaJyq/lNEkjAPKg/4TFVfLue6q4GrAVq1ajVw0qRJ5drXpEkTunbtut+fIxQK4atHsau1Ze/y5cvZtWtXjd83KyuL5OTkGr9vjaFKYOVKOk2YQOvPPqMwKYlVZ5/N+t/+Fk1M9NoUMjNh7tw0Jk7swurVKXTunMkVVyxn8ODMckOs6/znWwZnb+1SV+0dNmzY16p6WLkHVbVSG9AR+L7E/jmYeBTtXww8Xtn7VWUbOHCgVsQPP/xQ4bGSZGZmVuq8ukJt2VvZz+tAmTlzZq3ct8bZvl11zBjd1ru3KqimpKjedJPqjh1RMWX8eNWjj1ZNTDRzOnVSfeYZ1Zyc0ufWm883grO3dqmr9gLztYLv8epMaa0DMkrst4+MORx1n/R0uOMOvnvoIbjqKqtt8+ijFmzwyCNQxSoRVTXl8sst2OC226BfP6tt+rvfwTHHwEcfWeSbw9EQqI7ofAV0E5FOIhIAzgferhmzHA6PCAQssGD2bMvp2bULbr7ZvvnfeAPCYc9Myciwum0vvWTJpZ06wYIFllh66qnw/ff7v4fDUdepbMj0RGAu0F1E1orIlaoaBG4APgSWAK+p6uLaM9XhqCVETGSmTYO33rJEmp9/hnPOMVdj/nxPgw369rV2QuPGmQnp6fDBB2bKBx80dZ1LHfWaykavjVTVNqoaq6rtVfW5yPh7qnqwqnZR1Xtr11SHo5bx+eDEE+HTT+0bv0sXK6VzzDHWyW31as9MKUounTDBBGj4cNO9++/vx8CBVmjbJZc66iMuTNnhKEtCAlx2mVU2GD3aXI0pU8wF+eMfbQrOI4qSS19+2ZJLL7jgJ7Zvh1tvtejv11+3NtoOR33BiY7DURFNm8Ldd5v4XH65jT38MPTsaUXVPAw2aNUKbroJLrlkHb//vZmwbJkllw4b5nltU4ejyjjRcTj2R4cO8NxzNu32619bh7Ybb7SeFtOmeRZsIGK97P75T5t2u/hiaNvWCosefzycd57rXOqo+zjRiQJDhw4lLi6O5ORkmjRpwoABA5gyZQoAHTt2JD4+vrjeWps2bRgzZgwAo0ePxu/3lzp2zTXXkOs6hdU+IiYy77xjUW0DB5qrccYZVs16wQLPTCnqXPqf/1i/nlNPhcREm2o7/HDrcec6lzrqKk50osSdd95JVlYW27ZtY+TIkZx33nksW7YMsNppWVlZZGVlsWHDBu68887i64YOHVp8bP78+cydO7dYlBwe4PdbaPXs2darunNn611w1FHmaqxd65kpRZ1L//tfCyw45hirZTp2LBx6qJnn/h5x1DWc6EQZv9/PddddRygUYtGiRfu/oATt2rXj17/+Nd+7BA7vSUy0pNIvvrDObWlp1jK0Tx/485+tvo1HpKfDFVdYsMGtt5pDtm4dXHedaeGHH7rkUkfdocE2cauoX3VCKFTzfYOr2q8aKCgo4IknniA2NpZDDjnkgK5dtWoV77//PpdcckmVnu2oAZo1s6ZxV15pQQdvvAEPPmjlBf72NxOmQMATUw46yB55+uk29fbRR/Dtt5ZcOnSodXXo08dVsnZEF+fpRIl7772XtLQ02rdvz1tvvcWUKVOKC5Zec801pKWlkZaWRkZGBuvXry++7tNPPyUtLY3U1FQ6duxISkoKV1xxRbR+DEcRHTta6ehZs+CEE2DrVrj+evuD5N13PQ026NvX/gZ69llLL2re3ATo6KOt0oFLLnVEk4br6VTgeeRW0J/Ga/72t79xxx13lHvs6aef5qKLLgL27qczZMgQPv744+Jjd9xxB0cffTTfffcdcXFxtW+4o2JEbDHlvfdsTuvOO83VOP10+8Z/9FHrYuoBRcmlhx1m5jz7rBVWeO4508CbbrI2Q3Xgv4KjkeE8nXpMSkoKo0aNYtmyZW5dpy7h99sK/5w51rG0Y0cLPBg82JrmrPOuLm5RculLL1me6xFHwM6dcPvtJkivvuo6lzq8xYlOPSYnJ4fnnnuOpKQkunTpEm1zHGVJSrJS0XPn2rd8aipMmgS9e9uKv4fBBkXJpS++aB1Me/eG5cvhwgvNI/r8c5dc6vAGJzr1jFmzZhXn6bRr144FCxbw3nvvkZaWFm3THBXRogXce69Ful10ka3v3H8/9OplFa49cjWKOpf+4x82zXbxxVbZeu5cSy495xyrc+pw1CYNd02nDjNr1qwKj63cR7/i0aNHM3r06Bq3x+ERnTpZUs38+dY4Z84cuOYaW+sZO9aqHcTU/t+BRcmlhxwCn3xikW7z5sHUqTBzpoVf33abBeY5HDWN83QcDi8RsbIB778PkyfbN/+SJXDaafCrX5Ub5l9blEwuve8+OO44Kx764IMwYIAtR7nkUkdN40TH4YgGsbEmNJ99Zp7OQQdZbbcjj7SFlhJh8rVNUXLpiy/aUtOAAbBxo5WXO+IIKy/nkksdNYUTHYcjmiQnWz7P3LlWySAlBV55xVb6b7kFduzwzJSDDrJ4hwkT4Oqrbf3n++/h7LOtzdCCBS7YwFF9nOg4HHWBVq1sXWfuXKvhFgzaft++VkQtL88TM0Rsxu/hh+2xv/0ttGwJM2ZYXdOLLoI1azwxxdFAcaLjcNQlunQxT+eDD2yRZcsWC7s+9FB4803PXI2i5NJx4+Chh6zIQmysmXbYYeYRbdvmiSmOBoZnoiMinUXkORGZXGY8SUTmi8ipXtnicNRpYmKsgsH06Za92bcvLF0K55xDx8ces9Brj8rqFCWXTphgJeYGD7Y22f/8p3UufeopyMryxBRHA6FSoiMi40Vks4h8X2Z8hIj8KCLLReTWfd1DVVeo6pXlHPor8FrlTXY4GgmBgPXrmT3b3I2MDDq+8YZFuZ11Fnz3nWeeT7t2VrV63Di49lorHLpqlQUbDB1qdU6d+DgqQ2U9neeBESUHRMQHPAGcBPQCRopILxHpKyLvlNlalndTETkB+AHYXOWfwOFo6KSlWdX0uXNZMHq0VTp46y1bZDn3XPjyS1sDqmVELL5h7Fhb7znvPGuq+vXX1jb7zDOtsKgrq+PYF5VKDlXV2SLSsczwIGC5qq4AEJFJwOmq+k+gslNlQ4EkTLRyReQ9VfVm3sDhqG+0bk3mkCG21nPffVa7ZsoUKy46aJCt/Rx7LLRuXatmxMRYn56ePe3R48dbXdOPP7bXQYPgT3+ydCSHoyyilXTPI6Lzjqr2ieyfA4xQ1asi+xcDR6jqDRVc3wy4FzgBGBcRp6JjlwFbVfWdcq67GrgaoFWrVgMnTZpUrn1NmjQpbg2wL0KhEL6a7qdzgJx88sl8+eWXxMbGFo+dffbZHHnkkVx33XUkJiYCEB8fz5AhQ3jggQdo3rx5jdqwfPlydu3aVaP3BMjKyiI5ObnG71tb1Ft7QyFk61ZafPIJXSdNIrB7NwDLLrmE9WecYd6QR3188vMtqOCDD9ry+uudycvz07fvNkaO/JmePTcTH59MXFz96ONTb38f6hjDhg37WlUPK/egqlZqAzoC35fYPwcTj6L9i4HHK3u/qmwDBw7Uivjhhx8qPFaSzMzMSp1XmwwZMkTHjBmz1/iECRO0S5cuxfvbtm3ToUOH6siRI2vchsp+XgfKzJkza+W+tUW9t3f5ctWbblI96CBVW+Gx7ZBDVP/1L9UXX1RdtUq1oKBW7QoGVd99V/WCC1S7dVMVMTPat9+txx2neuONqq++qjptmurq1bVqSrWo978PdQRgvlbwPV6d2mvrgIwS++0jY44aomnTppx66qm88MIL0TbFUVfp0sV6R110Edx1F3z1lbkd335rW5cu0K+fJds0b27vDz7YXkVqzP3w+eDkk62G6cMPw+LFVsV61apk1q61WIhvv7Uu3xkZFhUXCFiPu1NOsZzYwkJbmgoEwBej9cM1chww1RGdr4BuItIJE5vzgQtqxCoHAFu2bGHatGkcc8wx0TbFUZcpqud25pkmKPPn23oPWNnon3+28YwMWLbMwq3btbPXvn2ty2l6uhUcLXr/xRdW++bCC60K6DHHwA8/mB/l81lEgd9vFRPS0myhZ9o0Oi5YwMMd0pi0vQef+nuxdUCIqW92Bkx4irjyiEWEtu3kh7lhFr+TwbBfJrCu7eFsbNoLf7dO3LDuNtadcT1J8SGe+bADhxV+TpcjWlAoAZo2jyExLkRSq2SyPv+WlPggc0OD8DdNJSk+RE/9gV9yWrF9/JsMuOlYCrr0JG77BjbFHUTa7jXkN20DmzaR3irAp5O30LllFmu2xHPkFT3JyQpT+PGn/JTTjoW7u9IteQN9s79gc59fkeVrwtsv7+ba5P+yprANve44i+VLgxzcYge6bj2r1sQwa04Ml97diSdvWcmlV8USyg8SDoO2aUty9iY+/xz8XTvSIXEL7d55mtCpp7NkV1vCYWjVIsyq/NbMX+jj2jM2sGmbn3CzFrRoAf51q/B1zGDZF9tZtzpEj1Y78M3/gnCf1oRnzaZwwCA+f2kFffsJgWAOGhtgbU5TuqyeSSi/kLWDz6Vd1wSSC3dAZiYaDFGQr2zdHUdcoo8tOUlIUiId3nmCnSt30vqZe2pN8yu1piMiE7FF/+bAJuBuVX1ORE4GHgF8wHhVvbd2zDQOO+wwnT9/frnHlixZQs+ePYv3P/jDB2z8ZuNe59XGmk7r/q0Z8ciI/Z8YYejQocybN69Up88PPviApUuXcuWVVxZ3Ct21axfdunXj/fffr/F+OWU/r5pi1qxZDB06tMbvW1s0OHuXLLG+BUuWQHY2LFy4d9+e666zSp6ZmbYgUyQkBx1kyaiq0KSJjSUkWB241q1h1y5zR2JjoU0byMmx+8XH2+uuXTYmgiYmsfyHfJaccxzbnt7Ktt2xPLnlXH7JKR3kcG76x1yS8Bpx4TzCcQnkawBNSKRtaA1LEg+lfWg128LpdMn6hqzElhTGxBFXmIU/NobcQCqxubvxJ8WhmbvZndKW3FCAjNBKdiS2JWbrFqRJCvkaR5P8Tez2pZEYG6QwKAQDCSSEc5CCPOKlgF0x6ZCYSNZlfUl/7itC2XlkaSJxAWiev46dye3ZSGua5q8n1ZdDYYGS26Q1qJIa3kl4Zybh1DR0x07iU/wU5oYoTE4nnF9Iiu6igAAF/iQS83eQH0hht6TQIrgRTUgke2cheYlNkXCImOQEsrOFNjGbIBwmKyYViY8juWA72YF0wnkFBILZkJxCk52rWPeHU2n65BzyAqkU7s6DpER8GiRB8inQWIiLwxcuJKsggCTEk0Q24dw8kjWLQn88BSE/PgmTG5MIPj/J2ZsoCCQz4NNHSE6ruk8iIhWu6VQ2em1kBePvAe9V2bJGTHntqpcuXUqnTp1Yvnw5AHl5eYwdO5bBgwezePFiWrYsN/Lc4dhDz56WWJqVBStWwPDhJhKvlUiFe/JJ81yWL7dsz/h481Z+/hmaNjVPZ8ECe5+VZeKzZYv1BWrWzMTsm2/2JKgWrSTFxVnmaGwsEhtLl+4dWBWvNMn6llYxKUxvdTGf5xzCJZseKDbl9R3H8/qO4zk9bRa3p08gkR0UZuUTk5vNQP8X6O4sRJvzU3wvOhX+Qlr2KjY36YovO4cmGxYRFh++XT7C+QW0ztqEBuIoyA2RHlpPYoKStzOFcFjQrCxI8ROXu4GUcB4aF08oLGymBQmhTTSRLaj4yCnsRmD1T8QGc0kFNsV3IC+YS8rW70hK/IWEwkzIy8Ef62PVjnySJRsfBaTG5JC5Yxv5/iS2+VuRsm0liTs2E/IHWJ/YkYSc7bQIL2VZbG9a7t5EUuFmEmJ2EBIfKVJI1s41JMcVsnlHS1IKsvHHBNmS2IHEgg2k5W9iZ6AF6QXL2RHbkrTCjRRsiWdlem98IWX3tgJSC5bSKpDHrp1JxAez2BloSWJoN4W+eGL9YZrnZBFOScOftZOg+FmX1Jl2eSuIDYfIjW1CUjCPYCCJ3BDExhcSEyygtjrfNNh+OhV5Hrt37y72JOo68fHxXHXVVdx1113MmTOHs88+O9omOeoDI0bAokXmycTEmKdyySXWw6CIzz6z1zff3DOWmmrX3Hnnnum5u+4yQSnZ56dFC0vQETGRSU6293//u027nXkm+HzEAP7EALubdSIchi8ym9G6izCzx2hW5zRj+sZ+vLRmiD1652qu23kjy+nKsU2+Y9quISyL/xWfNzuZt9cMpF/CGhYV9ECkgFNSv2NTYkf0oA70+GkaOQlNWXvw0QhKQu52/Ns2sr3tIB5acRwXFr7CwXErKWiRTGbrDHy7wmQlpBPyBQj544lT2FzQkfx82L4dPvpoIJd2WMHywg5szE3j2GY/kBfoQJ4qvlAB2f44hn76dwC2HZTBrrh2HJy3iPUdBrMprwmzd/Slfe4Kbt3+KM/2e4yOKdvYvQmSuqaxSzMY/d21dGAVd7Z5hkA4h/XtBgGm39mivLOyN+O3nsSjBz2ICCR0bM3WUHdEYKdAKAhLcw8hmJmN5BeS6I9DOnciFG7B5kAS+TtzGLD0afJDqczvPwpfYR47V20luU8fUrI3sq1tD55adTJntJyPZiUTVqFJ6wTysoOs3RRLn8BS0jN/IRSsvaTjBis6DYHCwkLGjx+Pz+ejd+/e0TbHUV9ISICbb4Y77rAV+m3bYOdOaxU6Y4at3r/77t7XFU3DPfjgnrH1682rOfZYW+eJjbV1oObNYfVqm2YrOfm/eLF5TD17QpcudFq4kJ1NOtPxy9dY1HI4v2zsTDikDNHJDA+9yEVJGbyQfTb/5dI994hE8ietXcrlaz8BYOqOEs/YCBta9+eHLqfRdtNCAE5b+RjbaUrL5Gxea3MzCbs2ENiwkvP8j3JS8/ls3pZIq8wsHpI/sbbdETTd8TNdln9IbCifzJg0xnR5nmbZy8l5dyUdEt5ja24vnuEWLst4ki5rPuU3KTOJS41j8rojUUx0clp2IDEpjg2FhxMTDvHEd8dyXsGLJCbH8Aoj+WDHKLqmz6ZdOzNbiUV27+JrutElOJtWuSvpuPJTJqZeze+2/4NcEpkmD7JDU/CnJ9N240I+W/crlgc7kR2M59jmS+gb9yOfLmzB3+UhmusWvv7mJn7a3RIS23PvN2fTJn4HJxY8SFxBFtt/3MKxzGF7emd6fTYOgHt6T+LdjQNZk92UsQMmsvB7Hzcvu5vLfC8SF8pmFKMBeO+J7zh5zJFV+OWrBBWFtdXFrTGETIuIJiUlaVJSkqampuqAAQN06tSpNW6DC5k2Gqy9hYWqd96pumyZ6kUXqQ4frnr33Xu23/5W1eezibGi16puf/6z6rBhlT7/h7TBlTovn1jNJU63kV5l2y5lgi6jqyroE1xb4XlTOHO/9zqML3UrTUuNncHU4vd5BPa65pKW7+o4rig19iEn6CJ6lxq7nf8rfv8wv9dN/jbF+8OZXnzqvuy7l9v0/7i93GNN2arx5OhRiQt0Eb11PW10SsebS53zOmcXv59x14xq/Z6yj5DpSieH1gUOJJCgIurT9BrUnr0ukMBoFPb+8Y/w008wcGDp8W3brF/14MFW0dOxTx7lRm7isag8+1qe5AsGs5BDa+0ZG2lFazYB8PnoDznq7hOrfK9qBxI4HI56TFKSBQsURZ4V0ayZlZD2qFdPfSdaggPwFNfV+jOKBAcgsTBzH2dWD9dPx+Fo6Fx5pa3zLF1a/vH4eAsMABMiR51gHW2j9mytxd8DJzoOR0MnKck8nN27K65G3a+fvVa3WGh6epUuW9NuMCs6Da/UuS9wCXnE7f/EKNCHRXuN/ULHKt3rCwbv83gBsfs8XhU+Zjg38W92966lIAKc6DgcjYeCAksa3R833midSisibh9f+FVssbC1eQ8K/QmVOvd6nmBBLa5tVIfF9EFQDubH4rF3OaX4/RYqX7h3LH/Z53EfoQM3MMIzjCp3fCpn8Rg3Vfm+lcGJjsPRmKiMKDRtaiHRFTFsWMXHItWu90deILVS55UlM74lV3SdzVralxpvws4q3a8ivqL8AsmV5ScOLn5/C/8qfv8xx1f6HiH2XTnFR9W7wFQk2rmY8Cck1F6AWYMSnfoUiRdNwh61OnbUY/ZVeKsyRbnOOsuKkJbDitT+fHH4jQdkTljsqyqYkEL7hG1czTOljmfShE6sOKB77oul9KixexWwp8XE65y71/HVpeome0M2SeWOT+UsAHr3dKKzX+Lj49m2bZsTnn2gqhQUFLBu3TqSksr/pXM4gH334ompxNdG27ZW4boc5rU+nXDMgQXO7mpyUOl90orfF0aCcFfS6YCmr6JBuJyv3Bi8/87KL7Emdj+3ALCNpmTShOa+HbX67AYTMt2+fXvWrl3Lli1b9nleXl4e8UUFCusBNW2v3++nSZMmNd4UzlFPqGzjvn79rIrBnDl7xk44wabnMir4y/yKK6yNaCX5JbEXnXJ+qPT5FfFsyzsYlfQxgZgg/Fz5636mM11q0DuqKgm+fA5keWYsfyaXBNqwgVGMO+DnXcN/UPZ4q8GIDFRnjehAaDCiExsbS6dOnfZ73qxZsxgwYIAHFtUM9c1eRwPB74df/aq06CQlwSGHwObN5V9zgH/IrEnoXiOiM6j9OnqlfMaMzQdWKupThrCcrvyaj5jBMH7FzGrbUhV8cmCeTmIgyC0F9/AY5TZp3ifL6cIzXMM5vH7A19YUDWZ6zeFwOBx1Hyc6DofD4fAMJzoOh8Ph8AwnOg6Hw+HwDCc6DofD4fCMetXaQES2AKuqeZvmwNYaMMcrnL21i7O3dnH21i511d4OqtqivAP1SnRqAhGZX1Gfh7qIs7d2cfbWLs7e2qW+2Qtues3hcDgcHuJEx+FwOBye0RhF55n9n1KncPbWLs7e2sXZW7vUN3sb35qOw+FwOKJHY/R0HA6HwxElGo3oiMgIEflRRJaLyK3RtmdfiEiGiMwUkR9EZLGI/D7aNlUGEfGJyEIReSfatuwPEUkTkckislRElohI7fXnrQFE5ObI78L3IjJRROpcqXQRGS8im0Xk+xJjTUVkuoj8FHmtWj/rWqACe8dGfie+E5E3RCQtiiaWojx7Sxz7k4ioiNT58vGNQnRExAc8AZwE9AJGikiv6Fq1T4LAn1S1FzAYuL6O21vE74FK9EOuE/wb+EBVewCHUIftFpF2wE3AYaraB/AB50fXqnJ5HhhRZuxW4BNV7QZ8EtmvKzzP3vZOB/qoaj9gGXCb10btg+fZ215EJAM4EVjttUFVoVGIDjAIWK6qK1S1AJgEnB5lmypEVTeo6oLI+93YF2K76Fq1b0SkPXAKVKHBh8eISBPgOOA5AFUtUNWdUTVq//iBBBHxA4nA+ijbsxeqOhvYXmb4dOCFyPsXgDO8tGlflGevqn6kqkU9vb+AMn2xo0gFny/Aw8AtEIVucFWgsYhOO2BNif211PEv8SJEpCMwAJgXZVP2xyPYL3596IXdCdgCTIhMB44TkTrbSlVV1wEPYH/JbgB2qepH0bWq0rRS1Q2R9xuBVtE05gC5Ang/2kbsCxE5HVinqt9G25bK0lhEp14iIsnAFOAPqpoZbXsqQkROBTar6tfRtqWS+IFDgadUdQCQTd2a9ilFZB3kdEws2wJJInJRdK06cNRCZevFX+Mi8jdsmvvlaNtSESKSCNwO3BVtWw6ExiI664CSPXbbR8bqLCISiwnOy6o6Ndr27Iejgd+IyEps6vJXIvJSdE3aJ2uBtapa5D1OxkSornI88IuqblHVQmAqcFSUbaosm0SkDUDktYK2o3UHEbkMOBW4UOt2TkkX7A+RbyP/99oDC0SkdVSt2g+NRXS+ArqJSCcRCWCLsG9H2aYKERHB1huWqOpD0bZnf6jqbaraXlU7Yp/tDFWts3+Jq+pGYI2IdI8MDQeq3ze59lgNDBaRxMjvxnDqcOBDGd4GLo28vxR4K4q27BcRGYFNE/9GVXOibc++UNVFqtpSVTtG/u+tBQ6N/H7XWRqF6EQWBm8APsT+s76mqouja9U+ORq4GPMYvolsJ0fbqAbGjcDLIvId0B/4R3TNqZiIRzYZWAAswv7f1rlMdBGZCMwFuovIWhG5ErgPOEFEfsI8tvuiaWNJKrD3cSAFmB75f/efqBpZggrsrXe4igQOh8Ph8IxG4ek4HA6Ho27gRMfhcDgcnuFEx+FwOBye4UTH4XA4HJ7hRMfhcDgcnuFEx+FwOBye4UTH4XA4HJ7hRMdRpxGR90Xklig899ciMsfr50YLLz9nEZlUXxMbHdXHJYc6ooqIZJXYjYu85hcNqGqytxYVlyFaDNygqjNq8TmzgI9V9f/K2/fquV4jIj2AT4GOqpobDRsc0cN5Oo6ooqrJRRvWb+XlMmPR4EQgAMyM0vOrTKRQbJ1GVZcCy4GR0bbF4T1OdBx1GhGZJSJ3lNhfKSJ3RNp5Z4nIIhHpJyIjI63Id0X64/hLXJMoIg+IyC8isl1EPhCRrvt47BmYJ1A8DRCxI0tEciJtgbMi28c19HM+DhwL3Bm574+VsT3yedxV9HkAZ4vI7yMtl3eLyGoR+Weke+6+nlP2c24mIv8VkY2R7QURaVrmubeLyCeR+3wvIkeVOH5TxObdIrJORMrWtptOHWro5vAOJzqO+silwHVAOvAt8AYwDGs73Rf4DXBeifOfBXpgrb9bYw3x3tmHV3AoZapOq+rQiOd1ObCihDd2fMnzRORyEfnDgf5AqnoDMAcYE7lvUQXsytg+CvgjVqjyLaza8ElAKtaH5wrgqv08pywvY59vz8jWHHixzDlXYG20m2Ai8kLkMzgYK+x5qqqmAL3Zu6r7Iup2OwlHLeFEx1EfeUZVl0R6y7wCdAb+pqrZqroamAUcBiAizYELgOtUdVOkXfnfgTbAERXcPx2oqGlef2DhPmwbQjl97KvCAdj+rKouVCNXVaeo6i+R/YWYWAw/gOe2BX4N/FFVd6jqDkzUTi7qjRPhaVVdrKohrE15V7FW4EFAgN4ikqyqO1X1izKPyQSa4mh0ONFx1Ec2lHifA4RUdUuZsZTI+06R1+9EZKeI7MT6zMdSurFfSXZgXkJ59Ae+qcgwVb1MVWtEdKi87StLXhSZavxKRLaJyC7geqDFATy36N6/lBj7ucwxKP3vkB15TVHVFcCFmAe2XkQ+E5ETyzwjNfKzOBoZ/v2f4nDUa1ZFXruVEaZ9sRDoVcGxXsCT1baqfMJl9itre/F1IpIBvAScBbyvqgUi8gARz6+C55RlTeS1I7bgD+ZNljy2TyLdbqeKNU38HfCWiDQr0RitD/v2GB0NFOfpOBo0qroZm4J7UkTaAYhImoicKSIVRce9ScXTUWlAYU3bGWEjUBwkUEXbk7H/11uAQhEZjDUErPA5ZVHV9cBHwIOR56UDD2IitqGi64oQke4iMkJEErHPaheglBa7E7DP2dHIcKLjaAyMAn4EZonIbmwR+1zsi7A8PgSCIjK0nGNPAK+JyL9rwc6HgcMiU2lFnW0PyHZVXQLcjQUU7ARuBSZW4jlluQjYHXn20si9LqnkzxEA7sKm33ZiwQZnq2oemCgB3TBBdTQyXHKow1EOIjICuF1Vj4u2LQ0NsbbLn6jquGjb4vAeJzoOh8Ph8Aw3veZwOBwOz3Ci43A4HA7PcKLjcDgcDs9wouNwOBwOz3Ci43A4HA7PcKLjcDgcDs9wouNwOBwOz3Ci43A4HA7P+H+I6Jw10H9Y8gAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 468x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "methods = [\"nem\", \"pfb\", \"fb\"] #, \"pklm\", \"klm\"]\n",
    "colors = [\"blue\", \"red\", \"purple\", \"orange\", \"green\"]\n",
    "\n",
    "target = \"diag\"\n",
    "d = 10\n",
    "lr = 1e-2\n",
    "n_epochs = 1500\n",
    "\n",
    "absc = np.array(range(n_epochs)) * lr\n",
    "\n",
    "figure, ax = plt.subplots(1, 1, figsize=(6.5, 2.5))\n",
    "\n",
    "for i, method in enumerate(methods):\n",
    "    L_kl = np.loadtxt(\"./results/KL_method_\"+method+\"_target\"+target+\"_d\"+str(d)+\"_lr\"+str(lr))\n",
    "    mean = np.mean(L_kl, axis=0)\n",
    "    std = np.std(L_kl, axis=0)\n",
    "\n",
    "    plt.plot(absc, mean, label=method.upper(), c=colors[i])\n",
    "    plt.fill_between(absc, mean-std, mean+std, alpha=0.5, color=colors[i])\n",
    "\n",
    "plt.yscale(\"log\")\n",
    "# plt.ylabel(\"KL\", rotation=0, fontsize=13)\n",
    "plt.title(r\"KL($\\mu_t$||$\\mu^*$)\", fontsize=13)\n",
    "plt.xlabel(r\"Time ($\\tau \\cdot$ Iterations)\", fontsize=13)\n",
    "plt.grid(True)\n",
    "legend = plt.legend(fontsize=13, loc=\"lower left\")\n",
    "# plt.savefig(\"./KL_conv_Gaussians_diag_d10.pdf\", format=\"pdf\", bbox_inches=\"tight\") #, dpi=150)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bcf50890",
   "metadata": {},
   "source": [
    "### Non Diagonal Targets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0b79c435",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 468x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "methods = [\"nem\", \"pfb\", \"fb\", \"klm\", \"pklm\"]\n",
    "colors = [\"blue\", \"red\", \"purple\", \"orange\", \"green\"]\n",
    "\n",
    "target = \"non_diag\"\n",
    "d = 10\n",
    "lr = 1e-2\n",
    "n_epochs = 1500\n",
    "\n",
    "absc = np.array(range(n_epochs)) * lr\n",
    "\n",
    "figure, ax = plt.subplots(1, 1, figsize=(6.5, 2.5))\n",
    "\n",
    "for i, method in enumerate(methods):\n",
    "    L_kl = np.loadtxt(\"./results/KL_method_\"+method+\"_target\"+target+\"_d\"+str(d)+\"_lr\"+str(lr))\n",
    "    mean = np.mean(L_kl, axis=0)\n",
    "    std = np.std(L_kl, axis=0)\n",
    "\n",
    "    plt.plot(absc, mean, label=method.upper(), c=colors[i])\n",
    "    plt.fill_between(absc, mean-std, mean+std, alpha=0.5, color=colors[i])\n",
    "\n",
    "plt.yscale(\"log\")\n",
    "# plt.ylabel(\"KL\", rotation=0, fontsize=13)\n",
    "plt.title(r\"KL($\\mu_t$||$\\mu^*$)\", fontsize=13)\n",
    "plt.xlabel(r\"Time ($\\tau \\cdot$ Iterations)\", fontsize=13)\n",
    "plt.grid(True)\n",
    "legend = plt.legend(fontsize=13, loc=\"lower left\")\n",
    "# plt.savefig(\"./KL_conv_Gaussians_nondiag_d10_full.pdf\", format=\"pdf\", bbox_inches=\"tight\") #, dpi=150)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a0f8f0b8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 468x180 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "methods = [\"nem\", \"pfb\", \"fb\"]\n",
    "colors = [\"blue\", \"red\", \"purple\", \"orange\", \"green\"]\n",
    "\n",
    "target = \"non_diag\"\n",
    "d = 10\n",
    "lr = 1e-2\n",
    "n_epochs = 1500\n",
    "\n",
    "absc = np.array(range(n_epochs)) * lr\n",
    "\n",
    "figure, ax = plt.subplots(1, 1, figsize=(6.5, 2.5))\n",
    "\n",
    "for i, method in enumerate(methods):\n",
    "    L_kl = np.loadtxt(\"./results/KL_method_\"+method+\"_target\"+target+\"_d\"+str(d)+\"_lr\"+str(lr))\n",
    "    mean = np.mean(L_kl, axis=0)\n",
    "    std = np.std(L_kl, axis=0)\n",
    "\n",
    "    plt.plot(absc, mean, label=method.upper(), c=colors[i])\n",
    "    plt.fill_between(absc, mean-std, mean+std, alpha=0.5, color=colors[i])\n",
    "\n",
    "plt.yscale(\"log\")\n",
    "# plt.ylabel(\"KL\", rotation=0, fontsize=13)\n",
    "plt.title(r\"KL($\\mu_t$||$\\mu^*$)\", fontsize=13)\n",
    "plt.xlabel(r\"Time ($\\tau \\cdot$ Iterations)\", fontsize=13)\n",
    "plt.grid(True)\n",
    "legend = plt.legend(fontsize=13, loc=\"lower left\")\n",
    "# plt.savefig(\"./KL_conv_Gaussians_nondiag_d10.pdf\", format=\"pdf\", bbox_inches=\"tight\") #, dpi=150)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "495918a5",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.7"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": true,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
