{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "cd8edf4c",
   "metadata": {},
   "source": [
    "# Dataset-Size Dependence of Rate-Distortion Curve and Threshold of Posterior Collapse in Linear VAE: Supplementary Code"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ab831c96",
   "metadata": {},
   "source": [
    "## Import Following Packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "96454dff",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import random\n",
    "\n",
    "from main import data\n",
    "from main import utils\n",
    "from main import vae\n",
    "from main import experiment\n",
    "\n",
    "device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bbf47e19",
   "metadata": {},
   "source": [
    "## Fix Seed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b87febac",
   "metadata": {},
   "outputs": [],
   "source": [
    "utils.fix_seed(100)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8245e544",
   "metadata": {},
   "source": [
    "## Visualization of Data Generated from Spiked Covariance Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5b2df33f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAATYAAAEiCAYAAABz+/4kAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy88F64QAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA/AklEQVR4nO3deXyU5bn4/8/sk3USMpCAhBBIJEDQhlC2JGqtZXFD6jmi2PyserB8PahIW5WiorigPf21FnFrD27nWPV8q9RSkYK1x7JErBhklRINJIEkZJ1JMslMMvN8/4gzzSQz2chkllzv12temifPM7lnyFy5r+e6F5WiKApCCBFB1MFugBBCDDUJbEKIiCOBTQgRcSSwCSEijgQ2IUTEkcAmhIg4EtiEEBFHApsQIuJIYBNCRBwJbEKIiKMNdgOEcHM6nZSWlnq+Tk9PR6PRBLFFIlxJYBMho7S0lBXPfUB0Ugq2uip++++LycjICHazRBiSwCaCqmsv7fTp00SNSiFuzPggt0qEOwlsYlj4SzO79tJqvzpM7AWZACguF6dPn/Y6V1JV0V8S2MSw6BrAWmrO8tC12aSlpXn10lrqqjzn2xrO8dC75ei1R7zOfexPx4iRVFX0QQKbCCh3L6t7AHvo3WISx9Z79dK6i0pMxtnS2OPcuDHjvXp0IL034U0Cmwgod0/N1ljjFcCiEpN79NL88XWuu0eXOLZeem+iBwlsIuCik1IIxDLN7oAnRHcS2MSQ617plMXnxXCTwCaGRPdg5r7J39s9tKEi99tEdxLYxJDwNWyjv/fQzlfX+21dK64S4EYumSsqBs3pdFJSUkJJSYlX1TMqYfSwt8Vzv02t5qF3i1nx3AdeY97EyCI9NjFo/gbXBltUYjJGozHYzRBBJIFNDIi/KVDDkXIK0V8S2MSAhGovrTspKIxsEthEv/ibQRCq/BUUQILcSCCBTfSLvxkEoazrjAX3tCyZpTAySGAT/RaoGQTDwR3kJEUdGSSwiRFF5piODBLYxIgjc0wjnwzQFUJEHOmxCb8r00b6ZPau99ucTicAGo1G7rtFAAlsotfVbYdzMvtw63q/rfarw2ii4zHoDXLfLQJIYBNAZ8XT3+q2oT5m7Xx0HRKiiUnAoNdL1TQCSGATPQxkddtII1XTyCCBbYRx3zfrek8pEu+fnQ8Z8xb+JLCNMF1nEGii40kcmxaR98+GgkzLCl8S2EYAXytyKIAmJmHEppz9JdOywpMEtggVzKW6I5WkqOFDAluECuZS3ZHOV4o6fnznTAZ3gJNgF1wS2MJc155Z94JAOCwvFK66p6hO28eee5ZyPy74JLCFEV9BrKKiwivNlILA8ItKTMapN3jds5T7ccElgS3IugYrX1OZuvfCugcxp83qlWZKQSA0+Lof1/XfUqZwBdaIDGyKotDU1NTneV999VXA21JeXs6jb/4NgPU3XUJqaqrnmNGURGNFCRpjDHHmsTRWlBAzNh19TDxOhx1F24bLYaep+jQaXDSfq0AdbenX/7tsTf0+V64b/HX1pce491Cr59+v67+lxhiDTqf3/LsH2uTJk/t1XlxcHCqVKsCtCSyVooy8oZlWqxWTyRTsZggRkiwWC/Hx8cFuxnkZkYGtvz22oWS1Wj29sXD/pQkUeY/6J9DvUyT02EZkKqpSqYL2wYmPj5cPbR/kPeofeZ/8k4UmhRARRwKbECLiSGAbJgaDgfXr12MwGILdlJAl71H/yPvUtxFdPIiEm6RCBFo4fl5GZI+tqakJk8k07JVRIcJROH5eRmRgE0JENglsQoiII4FNCBFxJLAJISLOiJx5IMRIYrE5qG12YG1rJz5KhzlGjylaH+xmBZQENiEi2NnGVu5/5xC7T9Z6jl2Saeap6y9iXEJUEFsWWJKKChGhLDZHj6AG8LeTtTzwziEsNkeQWhZ4EtiEiFC1zY4eQc3tbydrqW0eWGBzL44ZDiSwCRGhrG3tvX6/qY/vd3fq1KnzaM3wksAmRISKN+p6/X5cH98PZxLYhIhQ5lg9l2SafX7vkkwz5tjIrYxKYBMiQpmi9Tx1/UU9gtslmWaevv6iAQ/5mDhx4hC2LrBkuIcQEcLXeLVxCVE8e1MOtc0OmtraiTPqMMcObhxbOO2kJYFNiDDVNZDF6LUcKGvgsT8dw+borF52Ha82FANypSoqhAioysZWth+p4lRdC5WWNioaW1EUheeWzyRa39mzGurxauFUFZUemxBhxmJzcLrexp8OnWVvSZ3neF5GEqu+k8GPLp3Er3adBP45Xi3Sp1B1Jz02IcJMo62dZz866RXUAPaW1LH5ryVcPiXZ6/hAx6v5I6moECJgWhwdPYKa296SOrqv3h3J49X8CXhge/7550lPT8doNJKbm8vu3bv9nltZWcny5cuZMmUKarWa1atX+zzvnXfeYdq0aRgMBqZNm8bWrVsD1HohQovF5kABnr95Ji//8NusujzDc0/NzV08gKEdrxZOVdGABra3336b1atXs27dOoqLiykoKGDx4sWUlZX5PN9utzN69GjWrVvHxRdf7POcoqIili1bRmFhIV988QWFhYXccMMN7N+/P5AvRYigO9vYyqo3i7lq0x7ufONzbnv17xSXNbDpphyv4BZr6Pz/wY5X8yecUtGA7lI1Z84cZs6cyQsvvOA5NnXqVK677jo2btzY67WXXXYZ3/rWt3jmmWe8ji9btgyr1coHH3zgObZo0SISExN58803+9Uuq9WKyWTCYrHITtoiLFhsDla9WexzUnteRhI5ExLZ/FEJBRlmHl0yHUVh0OPVunN/Xv7+978za9as836+4RCwHpvD4eDAgQMsWLDA6/iCBQvYt2/foJ+3qKiox3MuXLjwvJ5TiFB1ztpGaU0zZy1tflfq2FtSR05qAgUZSay6PIOkGD2Tx8QOeSU0nFLRgA33qK2txel0kpzsXaFJTk6mqqpq0M9bVVU14Oe02+3Y7XbP11arddA/X4jhUl7XQkVjK5v/WsLNc9J6PTfGoOXKi8aRNir6vAOav89LOKWiAS8edN9gVVGU8950daDPuXHjRkwmk+eRmpp6Xj9fiEA7Z23jjKUVlwI3z0kjdVR0r+cnROm4MjuFlCFYFTcSPi8BC2xmsxmNRtOjJ3Xu3LkePa6BSElJGfBzrl27FovF4nmUl5cP+ucLMRza2p24XGBpbceo03DO2kZ+RpLPcy/JNDPWZByy1NPf5yWcUtGABTa9Xk9ubi67du3yOr5r1y7mz58/6OedN29ej+fcuXNnr89pMBiIj4/3eggRqsrqWthTUktr+z9Tv7pmOw9fM71HcBvqyif4/7yEUyoa0ClVa9asobCwkFmzZjFv3jx+85vfUFZWxsqVK4HOvwxnzpzh9ddf91xz8OBBAJqbm6mpqeHgwYPo9XqmTZsGwD333MMll1zC008/zZIlS3jvvff48MMP2bNnTyBfihDDoqqxlRZ7B2lJMZ7e2udlDRw7ayEtKZrb89O5f3EW5fWtTDLHDGlPLZIENLAtW7aMuro6NmzYQGVlJdnZ2Wzfvp20tM4boZWVlT3GtOXk5Hj+/8CBA/zud78jLS3NMwF3/vz5vPXWWzz44IM89NBDTJ48mbfffps5c+YE8qUIEXBVja20dbh4cvtxdnebA3prXjov/e1rVl9xIeX1rbz5aRmbb8oZ1qAWTqloQMexhSoZxyZCicXmoKbZjkal4sH3jvicLuUeq7ZgWjLNbR2MS4hiojlmWNon49iEEANytrGVn209TFu7k9Z2J7flpfucLuUeq9bqcJISbyQxeuTN/xwIWbZIiCCp/OZ+2qrLM9BpNDz6xyM9UtBNN+Vw95vF2BxO7B0uxpp0WNocTBoTO+ztDadUVAKbEEFQVtfC2cZWnv1rCTkTEikua/C5DBHAbfnpbP6ohIQoHX89Uc2i6WOD0eSwqopKKirEMDvbYOOspZX/3P01ORMSWTg9mZvnpPlcreOf06XMxBm1HCxrjOjdpYaK9NiEGEbnrG3YnS4UBW6ck8Yre0vZ/FGJ5/vd00+3h66ZxqYP/8GGJdlBG94RTqmo9NiEGCZnG2w0tXXw8B+OYNRpeGVvqc/085W9pdyWn+45dkFiFDq1iieWzmDsEEyZGixJRYUQXirqbdz/ziFO1bWwu6QOrUbV6yq4OakJABRkmhkbbyR99NCv1hHJJLAJEWDV1jbONLZy13cvJP6bZbobWnrfh8De4aIg08zPh3i61PmoqKgIm16b3GMTIoAq6m2sffeQZxjHlls6B7h2uHofF59ujuEX/3oxyfHGgLexv/5jx3GmT59OZmZmsJvSJwlsQgRIZYONikYb9y+eyl0OJ3FGLXqNmiuyxvB5WQN5GUk+09GCTDMmozakghpATFJwhpkMhgQ2IYaYxeag0eZApVLhckFZvQ2jTsPfTtZw7KyF+xdN5dcfnuDWvM4CQdfgVpBp5rEl2YxL7H39tWBoqC7D6Zwb7Gb0iwQ2IYZQZWMrZxpsJMToeWr7MbLGmchJTaCt3Une5CQWTkvmmQ9P8C+5qcToNTx01TQUoNneQZROg1ZNyE6XcrU0BbsJ/SaBTYghYrE52FNSy4wL4nlq+3Gf49TyM5L46cIsGloc3Pjb/Wy5ZRZjE6L41xeLyM9IGvK11YZS0qTpYTOWTaqiQgyRptZ2ZqePQkHFfYun8pqPcWp7Sur4xc4TmLr0yjqcnRXQp75/EReEYArq1lBdxqlTp8KiMiqBTYghUFbXwhlLG49tO8qZxlZqmuxeE9q72n2yFq2mc4+OCxKjQHHxi3+9mPF97GsQbAadgce3HeHrr78OdlP6JIFNiPNUUdfC/q/r+LqmmbuvuJDX9pZiae19nFqDrZ2CTDNOp8LouKiQq4D6kpyVS+zoC4LdjH6Re2xCDILF5uBckx2DRoWiwOxJSVQ0tGKzO7k1fxLxxt4/Wjq1isevyyYhShey99S6q634CkeLhVOnEpk0aVJI32+TwCbEAJ1tbOX+3x+i2trGy7fMol1ReHDrYa/7aU8uzaYgw8zukp6bHBdkmhmfEEVq0vCsgDtUnM2NGAxGHt92hIkTJ4b0QF0JbEIMgMXm4P7fH8LS6uC3t8xi39d1bPvibI8iwePvH/9mloHida+tINPM49dlEx8VmkM6epOclYsuKoam6tDfvlICmxADUNvswN7RwXPLZ/LotqPc870Lue+dwz3Oszmc3P7aZ7x1x1x+2GTH3uEiIUpHamIURo06bNLPrmorvkJriMJWX4XTeVGwm9MrKR4IMQBOxcF//Ou3OGtp5ea5aZyz2v2ea3M4qWho5fbXPuN3+09zQWIU8VE6Rgdx6aHz4WxuxNncgLPFGuym9El6bEIMQLTWwKen6smZkIit3Ql97PGWOiqK9/49j8RoHVFqVVj21Ny6pqKhXDgA6bEJ0W8VdS20tDvJviCBh987wlWb9vDB0Sryuu3O7pafkUScQYu9w4kWGB3Cg2/7o7biK2rKTlJfeSrkB+pKYBOiH07XtbDxg+PYO1y0O13c+Z1M/nRXPrkTErijYFKP4FaQ0TmZvabJzpg4A+PCrALqizsVNehDf6CupKJC9KG8roUX/nqSnyzK4uE/eG+Rl5+RxMPXTGf+5CRuy0snxqClxd7BuSY7CnCqtoW0CAhq8M9UFAj5yqj02ITwo8baRlltCzZHB7fmT+LrmhZuzZ/ktZPUnpI6Nmw7SlZKPLe/9hn1LQ5e3lvK7PRRPPn+ceZMSmJMGMwq6A93KhoO6aj02ITwoaKuhXaXwrkmO5s/OtnrRsZ7Suq4f3EW0FksuPqicXQ4XWy4LptxYVoB9cXZ3IiqvQ3Ak46G6kDdgPfYnn/+edLT0zEajeTm5rJ79+5ez//444/Jzc3FaDQyadIkXnzxRa/vv/rqq6hUqh6Ptra2QL4MMYJUNrbS4VJQgGe7BTXwvZNUc5uTgowkjpyxkjkmlmi9NqKCGnSmoinTZnseoTxvNKCB7e2332b16tWsW7eO4uJiCgoKWLx4MWVlZT7PLy0t5corr6SgoIDi4mJ+9rOfcffdd/POO+94nRcfH09lZaXXw2iMjO6+CB6LzcGp2mYe+sNhXECLo4M9/dhJCiDeqOXRJdnkTU4iJc5Aaoiv1DEYXVPRrunoyZMnQy4lDWgq+stf/pLbb7+df/u3fwPgmWee4c9//jMvvPACGzdu7HH+iy++yIQJE3jmmWcAmDp1Kp999hm/+MUvuP766z3nqVQqUlJSAtl0McJU1NvYfbKGD49XUzhvIs1tHei1arbdlU9DiwOnS+FAWQMv7yn1bGRs73ABnRVQjVpFXbOd8YnRQd37M5C6pqLQmY7+al8dtveP8dt/vzKkUtKABTaHw8GBAwd44IEHvI4vWLCAffv2+bymqKiIBQsWeB1buHAhW7Zsob29HZ2uc35dc3MzaWlpOJ1OvvWtb/HYY4+Rk5MTmBciIt6ZBhuP/PEIaxZcyPzJSdjanRi0Gta/d6TXe2sGrZr8jCQeX5qNvcPJmDhjxAY18K6KdqVSh14NMmCBrba2FqfTSXJystfx5ORkqqqqfF5TVVXl8/yOjg5qa2sZO3YsWVlZvPrqq8yYMQOr1cqvf/1r8vLy+OKLL/z+xbDb7djt/5z6YrWG/pQQMTwsNgdV1jZuz08nWqflrKWN0toW3j9c6XOXdoDb8tP5oqyBsSYjG5fOQAscrGzisgtHB+EVDD1/nxf3XNHubPVVIbeUUcBDrUql8vpaUZQex/o6v+vxuXPn8oMf/ICLL76YgoIC/ud//ocLL7yQZ5991u9zbty4EZPJ5HmkpqYO9uWICGKxOahvaWN0rJ4UUxRFX9ex+a8lJMcbe92lff6kJDYsye7cfAX49f+WMHviqLCeLtWVv8+LZ65ot0coDtgNWGAzm81oNJoevbNz58716JW5paSk+Dxfq9WSlOR72oparebb3/42J0+e9NuWtWvXYrFYPI/y8tAeXCgC72xjK6/vLUWj1rBh2zFaHE7GfBPQ3PfO/NFq1Hx2qh6NWoXN5WLt4qkRlYL6+7x0r4qGcoU0YKmoXq8nNzeXXbt2sXTpUs/xXbt2sWTJEp/XzJs3j23btnkd27lzJ7NmzfLcX+tOURQOHjzIjBkz/LbFYDBgMBgG8SpEJLLYHLz41xJWXDKJn209zLyMJFodTk9AM2h7/3sfZ9QyY3wCWmDC6LhhaPHw8vd58ZeKwj/TUbdgp6UBrYquWbOGwsJCZs2axbx58/jNb35DWVkZK1euBDr/Mpw5c4bXX38dgJUrV7J582bWrFnDihUrKCoqYsuWLbz55pue53z00UeZO3cumZmZWK1WNm3axMGDB3nuuecC+VJEBKlvcbDykklY250cr2riiaUzaGrrYHxi54e2uLyx113aVYBWoyImDBeLPB/dq6JduSukqk8aaKmrDHqVNKCBbdmyZdTV1bFhwwYqKyvJzs5m+/btpKWlAVBZWek1pi09PZ3t27dz77338txzzzFu3Dg2bdrkNdSjsbGRO+64g6qqKkwmEzk5Ofztb39j9uzZgXwpIkJYbA4MahXtClQ1tvGft3ybdVsPs7ukjlWXZ5CXkcTLe0rZdFNnlb37Lu2PX5dNq6ODWH347FUwVDSxCWj89NgA7O2Ozv867EEf16ZS3HfnRxCr1YrJZMJisRAfHx/s5ohh0rlLewtj46P4W0kt304fxaN/POoZ0hGt17Dpphxe2VtKcVkjt+WnewbhXpAYRaxOg0EBffTICmruz0veyqfQGvoeCG9rqOH1tT8gKytrGFrnm8wVFSNCdWMrzfZ2YqP0VDbZSTPH0Ghr9xqnZnM4ufvNYm7LT+e2vHTijDrUKhgVo+dElZWLx5kYbY6MlToGw984tu5CYSFKCWwi4lXVteBQYMO2Y16BrHOzFW82h5PNH5UA8PzNM3nz0zIeumoq2eNMEbGm2vnorXjQVddCQrCKCBLYRESrabDhBNb94bDfndn9MUXpePy6bHQw4goFvvRWPOgqFKZaSWATEetcXQttwJnGVp9BrdfqZ4aZCYlRqAGdKrz3Khgq/U1F3YI51UoCm4hIFfU2FGD/13VMNMf6PMdd/VRDj70/118zHR2gUqvCfq+CodLfVNQtmGPbJLCJiFNRb8Pm6MAFZI83YW/3Xfh3Fwvce38CjEuI4sgZC0aNiqiokVX97Et/U1G3YI5tk8AmIkplg422Dhc/3/ElsyeNYsHUFKJ1Kn73b3NobG3HqNPweZflh3ImJLDzWDVflDeyYcl02l0u8tJHjfhCgS8DTUWDSQKbiBiVja04XC5+ufNLVn9vCiqgusmOU1HY93WdJ5i5lx96a38ZP100hfoWB9d96wLanS5itBopFPgx0FS0q+FOS2WArgzQjQgVdS0oKLjnrz/sYy21W/PSPWupFWSa+eH8ibyx/zQrCiZT0WBjfvoo9Bp12O7UHigDHaDrT3RiMiq1eljSUumxibB3ztpGS7sTi80BKhUdToWb5qRxa/4kT9rZdS21zR+VsPtkLfctmsL3pqagVsGc9FHodRpGR8iOUoEgqagQw8je7qS9w8XoOCOVljave2nHzlo8q97uLanjtrx/bsDS5nAxd9IodGoVBrVKglofzicV7cpWX4XTedEQtMg/CWwirJXVtfD0B8e554opPdLPggwzP144hZc+LvH01LqutRZr1KJWd+5yJkM6+jbQqqjf52kJ/ArWEthEWKqxttHe7mTDtqPcfcWFPPqnoz0G2u4uqUVB4b5FWdQ3d6484V5rrSDTTIxegwa4IAJ3lAqEoUpFh2MuqQQ2EXbO1LXQ6nTiVODmuWk0t3X4Xcp7T0kd/6etA1O0joIMM8XljRRkmnlsyfTOoCbDOvptKFPRrhVSGPoqqQQ2EVbK6m1s2HaUnyycgk6rYUyckdP1tl6vsbS2kxClY/2107F3dHD9zAuIUqtJlp7agAxVKtp14C4QkCqpBDYRNiw2B+vePUTBFDMxei2flzUQa9T1uZS3Qaumyd6BWq3iV7tO8ti100mWe2oDJlVRIQKgytpGtdXOldPGYncqXJgST7vTxc5j1b1OZi8ubyRvchLHKy2sv2Y6YyWoDcpQpaLdBWKZIwlsIixU1rUQrdPw7M052NpdPPano57lvI+dtXDrN8M4uga3/IwkfrJwCpv+8g+W5Y5nYmI0YyX9HLShSkW7C8QyRxLYRMg7U9dCuwIP/eEwF09IpLiswRPA3Ct0/G7/aXImJHJbXjr2DhemKB1xRi0vffwVD18znQ6Xk9TRMsvkfAQ6FR3KZY4ksImQZbE5aGptx0VnUNtdUscP89I9K9yC93LeMyckEmvQMkavRlHAoFPzwKIsfrv7a368YErwXkiECFQq6jaU80klsImQVN3YSrvTRXVTG9EGnWfgra/NjLsv5/3G/tM8eu10nC6Fz8sauOOSybL80BAIVCrqNpTLHElgEyHnnLUNnC7aXS7+Ud3M5NGxrLo8g5zUBEbH9b7xdeqoKK6eMRajRo2iVpiVNkoG4A4RqYoKMUiVja002duI1eqpttrZdbya3LRRFJc1sPmjEs/en74roEkcqbAyP8OM0+XEoNWSIhXQIRPoVLSrjqYGIGfQ10tgEyHDYnNQ22QjIdqI3aXw7F9LyJmQyIYu06V628x4w7XT0ahVNNsdxBsNEtSGWKBTUTdbQw1P/OBSJk2aNOjnkMAmQkZTq4OkaCMWRwcuF57VOPwVC27LSyfeqCMuSsvhCgt2p4sYlZpEo0GGdQTAcKWiTdXlTJw48bzGs0lgEyGhxtqGGhVNHU50GjV2xcXzN89kTJyBVZdneFa/Be9iwcs/nEVSrJ656aM8m6/IrILAGK5UdCiWNZLAJoKupsGGzaXw8w+Oc8dlGfxix5c9Vr91r6nmDm5uyXFG9GoVBgBZfiighisVHYpljQK+8d/zzz9Peno6RqOR3Nxcdu/e3ev5H3/8Mbm5uRiNRiZNmsSLL77Y45x33nmHadOmYTAYmDZtGlu3bg1U80WA1dTbcHwT1FYvmNIjqEFnSvrK3lJuy0/3Ol6QkUS8UYsB0EfpGC3pZ0BpYhPQxCYG/hETT3l5OSdPnvR6OJ3Ovhv5jYD22N5++21Wr17N888/T15eHi+99BKLFy/m2LFjTJgwocf5paWlXHnllaxYsYL//u//Zu/evdx5552MHj2a66+/HoCioiKWLVvGY489xtKlS9m6dSs33HADe/bsYc6cOYF8OWIIWWwOalvaMKo12FxO7l88lRaH0+9u7d1Xvy3INPP4ddkYgdGy9NCwGK4eW/fVP2DgK4AEdDOXOXPmMHPmTF544QXPsalTp3LdddexcePGHufff//9/PGPf+T48eOeYytXruSLL76gqKgIgGXLlmG1Wvnggw885yxatIjExETefPPNfrVLNnMJrrONrWz68AR3fieTKksbSbEGHvnjEW6ak8adb3zu97r/+6N5tHY40alVjE+IQq0oXOBnM2QxdNyfl+8/syto49iaqst55sacfge2gPXYHA4HBw4c4IEHHvA6vmDBAvbt2+fzmqKiIhYsWOB1bOHChWzZsoX29nZ0Oh1FRUXce++9Pc555pln/LbFbrdjt9s9X1utgV+aWPhmsTn4xY7j3PO9Kazb6j3384d56b1ea9Cp2fTRSR6/LptjVVbmpicNU6tHFn+fl+Ecx9bdQMe1BSyw1dbW4nQ6SU5O9jqenJxMVVWVz2uqqqp8nt/R0UFtbS1jx471e46/5wTYuHEjjz766CBfiRhK1U1t3HVFJg9u7Tn3s7i80e/g27yMJGINWp64LpuvapqZNtYk06QCxN/nZbhS0e4GM64t4FVRlUrl9bWiKD2O9XV+9+MDfc61a9eyZs0az9dWq5XU1NS+Gy+GjMXmwNrajkYNjg7F59xPf4Nv8zKSuOs7mTTa7IyONTJ1dCwpUigIGH+fl2BNqRrMuLaABTaz2YxGo+nRkzp37lyPHpdbSkqKz/O1Wi1JSUm9nuPvOQEMBgMGQ+9zDEXgVDa2cs7ailNRGBNrpL3DyZZbZmHvcDFhVLTXOLWug2/tHS5SR0Vx5IyVMfEGdGqVFAuGgb/Py3Cnoga9EZWqs3Aw0OlVAQtser2e3Nxcdu3axdKlSz3Hd+3axZIlS3xeM2/ePLZt2+Z1bOfOncyaNQudTuc5Z9euXV732Xbu3Mn8+fMD8CrE+bLYHByttHDhmDgURaFdUXji/WNe1c/8buPU3KlpQYaZDUumM3fSKPQqFXqVSoZ0BNFwpqK2hhoe+MGlTJw4EcgZ8PSqgKaia9asobCwkFmzZjFv3jx+85vfUFZWxsqVK4HOLu+ZM2d4/fXXgc4K6ObNm1mzZg0rVqygqKiILVu2eFU777nnHi655BKefvpplixZwnvvvceHH37Inj17AvlSxCA1ttjJGhOHw6XQ1NZBbbOdW/MncfGERE8vbU+3XdqhM9g9vjSb/9p3isL5E9GrZfBtsA1nKupOP0Ny2aJly5ZRV1fHhg0bqKysJDs7m+3bt5OWlgZAZWUlZWVlnvPT09PZvn079957L8899xzjxo1j06ZNnjFsAPPnz+ett97iwQcf5KGHHmLy5Mm8/fbbMoYtBFlsDnRqNQ4F1nfbzLj7bII9JXWsXTyVSy8cTaxBS6xeQ7vLycUTEjp7ahLUgm44U9Hz3QchoOPYQpWMYwu8qgYbKpeCA3hg62G/lc6cCYmeXtob/zYHrVrF6LjO+2lP7fiS+xZlkSb31ILK/XnJW/kUWoNx2H5udGIytobqQS04KXNFxZCrqrfhVBQcikJlY5vfzYy7zyaI0WtxOJ3o1SrsLic/W5QlGxqHkGBURQe7D4IENjGkaqxt2BWFx7YdZfX3ptDY2t7r+e7hHgUZZgw6NaNidOw4eparpo9jrAS1kDIcqai7Euo2mIooSGATQ+hMvQ2n4uJwhYWHr5lOtdXer82M8zKS2HDddOqa7UTr1CyYPo7oKN0wtVr0V6Crot6VULeBV0RBApsYImcbbKC4ABWTx8Rx8lwzY+KNfHyyptfNjEfHGbh6xljanS4Sow1oVCoMGrXMKghBgU5Fz7cS2pUENnHeztTbqG5qJTHGwMPfbJMHsOryDI73sZnxrz/8Bw9fMx0d4FTAoNMwOn74blCL/huO7ffOd4FJNwls4rxYbA7qWloxxxrZW1LLD/PSuWlOGkadhkMVjfxg7kT++5NTXpsZJ0TpGJcQRWt7O+uvmY4BqGxpIzkuSoJaCAt0KjoUC0y6SWAT58Vi69ynwO5S+NPhyh5zPC8ab+Ki1AQuzxpDeX0r4xOj2Hmsmpf3lDJzQgIbl87g1f1l3Dw3jbEyVi2kDUcqej77HHQlgU0MWnVdC2qVCodLYf17R3rcR3N/nTMhkfL6Vu5843O23DKLzR+VeBaKVLmcrLxMNjQOB4FMRQ16I7b6wVVAfZHAJgalpq4FO7C3pJbs8aZ+rXzrLhbsWF1ArE6DQa1idJIMkA4XgUpF/1kNHVwF1BcJbGLAzjbYaGp30mhrJ80cQ4dTIVqv6bHRSlfnrHYeuXY6GhWo6HzINKnwEqhUdCiroW4S2MSAnK5r8SwS6VaQYfa7ixTABYlRJMcb2PjBcdZfPQ1FUYiVcWphJxCp6FCnoG4S2ES/lde18DMf8z53l9SioHitzuFWkGlGcSkcPmPl4aunUdfSRkpclNxTC0NDnYoGIgV1k8Am+mSxObC1tlPe0Op33ueekjr+z2UZXoEtPyOJtYuziDVomTdpFK0dTkbHRpEiKWhYGupUNBApqJsENtGrqsZWHE4nNoerz3mfTkXxrIw7MSkGFRBr0NBgayMx2khKnFF6amFsKFLRrnNBBzsPtD8ksAm/LDYHTfYOntl1gh/mTyJa3/sYI5dL4fbXPqMg08yj105Hp1bhcimMijYyXia0h73zTUV7zgUd+hTUTQKb8Kna2oa9vTOorVmYRVNrB0kxevIzkjwr3naVn5FEUoyegszO5bz1KhUqQKdWkSJBLSKcbyoayNSzOwlsooeKuhYsbQ50Wg0rv5OB4lI4VmkhZ0IiP8xLR6HnLlI/zEtHp1Xz6DXT0dAZ1FyATjc0I8lF8J1vKnq+q+IOhAQ24aXG2obdpYDiQoWGIxUW/nK8muzxCbhcCk6XwgOLpmLvcFLTbEevUVNc3sjdbxbz6q3fBmBsvBENnb9cMvczcpxvKmrQG/jVvjps7x8b1Kq4AyGBTXixtzs5VdvM1DFxNLU7GWuK4sY5abyyt5RnPjzpOS8vI4lb89K5q8vYtTijjji9Bh2gqFUkS/UzomhiE9AMsMfWfeHI4SKBTXjUNNhwKQpTx8ThBDpcCsnxRh7ffszvPFD32LX8jCSidRoUoAO4QIJaxBloj833wpEQyKKBmwQ2AcDZuhY0ACoVjfYONm4/zu6SOrbdldfnngX5GUk8cm02KApGvVbSzwg10OLBcBYLupPAJqhusOECnECTvYMqS5tn789GW+9j1+KMOlZdnkGjzc6EUTES1CLYQIoHgZoq1V8S2Ea48roWWto7sNg62PzRyR57fy6cntzr9VF6DUfONJM/OYkxEtQiWn9T0UBOleovCWwj2DlrG7UtDr6stPL+4coe49P2ltRxuMJCQUaSz2WJCjLNxOg05E9OIlXGqkW8/qaiwUxB3SSwjVAWm4NWRwd6rZox8Uafg24BHn//OH+4M49H/3TU616be6HIKJ1GemojRH9T0aHcu2CwJLCNQGcbW/nkq1qcLoWJ5ljP3p6+2BxOSutayJmQyJ2XZaDXqIkxaIgzaKWXNsL0NxUdyr0LBksC2whjsTl4+A9HeODKLFTQr70/tWoVxWUN5GeYSYk30NrhJF7WUxtxBpKKBnJWQX8Mbv/4fmpoaKCwsBCTyYTJZKKwsJDGxsZer1EUhUceeYRx48YRFRXFZZddxtGjR73Oueyyy1CpVF6PG2+8MYCvJHKca27jnisyKT7dgFqlQq9VMzrOQEGm2ef5BRlJnr0/U+INOF0u4g06WaVjBKqt+IqaspN+H9aqcpqqy79ZtSO4AtpjW758ORUVFezYsQOAO+64g8LCQrZt2+b3mp///Of88pe/5NVXX+XCCy/k8ccf53vf+x4nTpwgLi7Oc96KFSvYsGGD5+uoqMDtdxgJqq1tOO0dGDUa6h0Oxo+K5uH3jrC7pI5ovYZNN+WgKIrXvbaCDDMPXTMNp9PFnElJaFUq4qL1EtRGqN5SUe/BuMGrhroFLLAdP36cHTt28MknnzBnzhwAfvvb3zJv3jxOnDjBlClTelyjKArPPPMM69at4/vf/z4Ar732GsnJyfzud7/jRz/6kefc6OhoUlJSAtX8iFJW18Lre0u5JS+dZoeTKL2W/9jxpafSaXM4ufvNYm7LT++8j6ZVE6XXYNRqUKtAr9ZwrrmN9KRYCWojWG+paChUQrsKWCpaVFSEyWTyBDWAuXPnYjKZ2Ldvn89rSktLqaqqYsGCBZ5jBoOBSy+9tMc1b7zxBmazmenTp/OTn/yEpqYmv22x2+1YrVavx0hRbW3jzU9Oc0teOuUNrZTWdm6Zd/GERK/11WwOJ5s/KmH5f+7H0trOk9uPA53LDv38z1+SEi+bGY8U/j4vvaWizbXBTz+7CliPraqqijFjxvQ4PmbMGKqqqvxeA5Cc7D0oNDk5mdOnT3u+vvnmm0lPTyclJYUjR46wdu1avvjiC3bt2uXzeTdu3Mijjz462JcS1mx2BzfOTeOBbnsV5GUk9boBy13fycSgUWF3OVl/bTbJEtRGDH+fF3+pqK2hhid+cGnQ08+uBhzYHnnkkT6DxN///ncAVD6m9SuK4vN4V92/3/2aFStWeP4/OzubzMxMZs2axeeff87MmTN7PN/atWtZs2aN52ur1UpqamqvbYgElfU2NGoN63xswNJ9EntXSbEGEqK0qIDJo2Xfz5HG3+fFXyrqTkODXQntasCBbdWqVX1WICdOnMihQ4eorq7u8b2ampoePTI39z2zqqoqxo4d6zl+7tw5v9cAzJw5E51Ox8mTJ30GNoPBgMFg6LXNkeZMXQvtioLN4eKmOWncmj+Jz8saeHlPqaeH1nUzY7eCTDNJ0Tqqm9pIGyXj1EYif58XfwN0O5oaCNacUH8GHNjMZjNms++hAV3NmzcPi8XCp59+yuzZswHYv38/FouF+fPn+7zGnV7u2rWLnJzON8rhcPDxxx/z9NNP+/1ZR48epb293SsYjmRldS002zt4cvtxPi9r5Lb8dHJSE8hJTeB/fjSPD49X85u/fY3N4fQanFuQaWb9NdP54kwjF12QIPfUhBdfqWgopqEQwHtsU6dOZdGiRaxYsYKXXnoJ6BzucfXVV3tVRLOysti4cSNLly5FpVKxevVqnnzySTIzM8nMzOTJJ58kOjqa5cuXA/DVV1/xxhtvcOWVV2I2mzl27Bg//vGPycnJIS8vL1AvJ2xUW9vY/3Udf/ziLJ+XNbLpphxe2VvqlW4WdLm/ljYqmtdvn01SjJ5onQaNCmZPlAntoidfqWgopqEQ4HFsb7zxBnfffbenynnttdeyefNmr3NOnDiBxWLxfH3ffffR2trKnXfeSUNDA3PmzGHnzp2eMWx6vZ6//OUv/PrXv6a5uZnU1FSuuuoq1q9fH3Jv7nCz2BxY2xxkj0/gp+8cZtXlGbyyt9THBsd1uICHrpqKU1FY+V8H2HrnfPRqFRfINCnhh69UNBTTUACVoihKsBsx3KxWKyaTCYvFQnx8ZNwcr2lsxeV04QCqm+z8y4tFbLllFre/9pnfa7bfXcD/9/J+po6N5/HrphOtk0UiRU/uz0veyqfQGv75++FOQy+//PKQ61TIXNEIUG1to6W9Hb2685cr6pudoXqb3A5wur6FqWPjWXflVDSoJKiJXnVPRUM1DQUJbGGvoq6FepudxGgDbR0uHt12lIsnJJKXkdTn5PaJSTE8cV02KpANjUWfuqaiwV4hty8S2MJYZV0LTgV0Wg27S2p5/3Ale0vqOPBN0aDa2kZeRpLPPQsKMs3E6jXoNWqSE2SereibuyoaCivk9iWgq3uIwKlpbMUJOBWFhpZ2si8weQKYe+5nTbOd9VdPpyAjyevagkwzT1yXTXyUToKa6LfkrFxSps1mdMZFnnmhoZiGgvTYwlar00WVtY1n/9K5T8HzN3sPTLY5nPxq10le+vhrbstP56eLsqhpsjM+MYo4nQadWiUT2sWAuFPRUFghty/SYwtDZxpsFJc1eIIa4Pd+mntye1NbB2lJMSToNKhUKkbLvp9igJzNjTibG0Jihdy+SI8tDLU4OpiSEu+1wUpxeWOv99NGxeiJ0qgwRskikWJw3FXRUFghty8S2MJIZWMr1rZ2FAUsrd77fb68p5RNN3VWqLpvurJhyXT0Khl8K85PbcVXxMQlhnQ11E0CW5g4XdfCg1sPe3Znj9J7/8XsuljkbXnpxBl1xBq0GLQqdCoVel1o/4UVoa+5ooQHb1sQ0tVQN7nHFuIsNgcVXYIaQENLZ28tr1u1030/7eW9pZhj9Pxy1wn0GjUakMG34rypYzqnNU6aNCnkU1EJbCGsurGVumYHTQ6n1/20DpfCX0+cY9V3MnoEt7yMJO76Tia1LXYevnoaRp2GsZKCiiFg0Bl4fNsRvv7662A3pU+SioYoi82Brd3JE9uPcdd3M9lyyyzsHS6MOg2KovBFeefSQlfNGMtteenYO1wYtGrOWdsYl2BEC4yTgCaGUHJWLm3W+mA3o18ksIUoa2s7T7x/jJvmpPH///mEV4/t8qzR3L9oKk/vOM60cSbPst1ROg15GWY0SFATQ6+24itwtBHqhQOQwBaybO1OssaZfC479NGXNQDcPCcNo06DXqsm1qAlSqdGDcTKZsYiAJorSnjqtgUhXzgAuccWks5Z22hq6yAnNcHnuDToDG5GnYbWdif1LQ7UKmjrcKGVGQUiQJImTQ/Z1Ty6k8AWYs7U2zhV20y0XkOMvvcOtVNRuPvNYuIMWgxaNXF6LSkyo0AESEN1GU5nzx3NQpEEthBypsHG3q9qcSrw5PbjtDg6ej2/vcPFzAkJpCZGEaXVcMEoCWoicFwt/vfuDTUS2EKExeagrN5G1th4Nv+1hD0ldZ5pUr7kZSRxrsnOE0tnoAFZpUMEXNKk6WGRhoIUD0KCxeagytqGis69U9331fxOk8ronCblcLrQq1WMlfRTDIOWup7baYYqCWxBVG1to77FgcXWTkK0jvgoLc1t/0w/u0+Tsne4SBsVTaxRy4FTDXx7YqIENTFsfrpoSlhUREECW9CU1bWwduthirvs+wlwQWIUq6/I9Oz76Z4m5fbn1QWcs7Yyd3IS4yT9FMMoLS1NUlHhX7W1jZ99E9T62vfTvWs7dK7U8WWllYtTEyWoiWEXLhVRkOJBUDTYHOwpqeO2/HS/+36+ureU2/LTPcfcyw85FUiMlgG4QvRGemxB0NTaeR8tJzXBq6fW1Z6SOu5fnMW0sfEkROkYnxjFMx/+g58uzJIBuCIowiUNBemxDTuLzUGssfPvSV/7fpbXt/K7/ae5IDEKl0th/TXTGSspqAgSSUWFT2cbW/nx//0CFfRr3890cww//5eLSUuKYeLoWOmpCdFPEtiGydnGVhpaHKwomAQquDUv3bPvpy8FmWbijVopEoiQIanoNxoaGigsLMRkMmEymSgsLKSxsbHXa959910WLlyI2WxGpVJx8ODBHufY7XbuuusuzGYzMTExXHvttVRUVATmRQyBsroWfvr7L7jq2T0s+80n/OlQJW/tP+1/38+MJJ5YOoMLZIyaCCGSin5j+fLlHDx4kB07drBjxw4OHjxIYWFhr9e0tLSQl5fHU0895fec1atXs3XrVt566y327NlDc3MzV199dUi+8dXWNtZuPexV+Xx5TynL56bxWWkD1z2/l4snJLLllllsuWUW79+Vz5NLZzBB5n0KMWgqRVGUQDzx8ePHmTZtGp988glz5swB4JNPPmHevHl8+eWXTJkypdfrT506RXp6OsXFxXzrW9/yHLdYLIwePZr/+q//YtmyZQCcPXuW1NRUtm/fzsKFC/tsm9VqxWQyYbFYiI+PH/yL7IPF5uCspY3Fv97d43vReg13XDKJRdkpWFs7iNFr0GpU6DVqRsXo5X6aCBnuz8vnn39OTk7oLzIJAeyxFRUVYTKZPEENYO7cuZhMJvbt2zfo5z1w4ADt7e0sWLDAc2zcuHFkZ2f7fV673Y7VavV6BNrZxla2H6nCYmv3+X2bw8kzH56koaWdG14q4qpn9/D4n45h0KolqImg8vd5CcWMyJ+ABbaqqirGjBnT4/iYMWOoqqo6r+fV6/UkJiZ6HU9OTvb7vBs3bvTc5zOZTKSmpg765/eHxebg/ncOMSbOQIyx9xuusd98vyDTzMbvX8Q4ua8mgmy4Py+BMODA9sgjj6BSqXp9fPbZZwCoVKoe1yuK4vP4+ertedeuXYvFYvE8ysvLh/znd2Vtbee+RVOINWjRadRsXJpNtL5ngMvPSMKg1bDjngI235TDeLmvJkKAv89LOFVFBzzzYNWqVdx44429njNx4kQOHTpEdXXPZU5qampITk4e6I/1SElJweFw0NDQ4NVrO3fuHPPnz/d5jcFgwGAwDPpnDoR7cnv33di33DKL21/7zDP3Mz8jiYevmc6mD//BE0tnSPopQoa/z0s4paIDDmxmsxmz2dznefPmzcNisfDpp58ye/ZsAPbv34/FYvEbgPojNzcXnU7Hrl27uOGGGwCorKzkyJEj/PznPx/08w4FXxVQgN0nawHYtiqfc012Yo0azlntbPrwH6y7apoENSGGWMDmik6dOpVFixaxYsUKXnrpJQDuuOMOrr76aq+KaFZWFhs3bmTp0qUA1NfXU1ZWxtmzZwE4ceIE0NlTS0lJwWQycfvtt/PjH/+YpKQkRo0axU9+8hNmzJjBFVdcEaiX45fF5qC22YG1rR2jTuN385XdJ2uxd7iwOTqwOToYnxglPTURViI6FR2IN954g7vvvttTwbz22mvZvHmz1zknTpzAYrF4vv7jH//Irbfe6vnanfauX7+eRx55BIBf/epXaLVabrjhBlpbW/nud7/Lq6++Ouxv/NnGVu5/55CnR/b8zTN7Pb+prZ3xiVGkxBsloImwE06paMDGsYWyoRjHZrE5WPVmsSeoAZ77aP7suKeArLGBGzcnRCC4Py9///vfmTVrVrCb0y8yV3SQapsdXkEN6HXzlfyMJBJjpJcmwlc4paIS2AbJ2tZz4O3Le0q5NS+9R3DLz0jiyaUzSI43DlfzhBhyEydODHYT+k0WmhykeGPPVWy7br7y4FXTaGrrIN6oJTFGL0FNhD3psY0ARp2afB9pp83h5FB5I+NMRmanjyJrbLwENRERwql4ID22fuo6rCPWoOVgeSO3509CwXvPT3faKVVPEWlOnTrVYypjqJLA1g/dh3VA5wq4t+enMzt9lGfPT4NWTXF5Iw5n70t+CyECSwJbHyw2B/f//hC7S7wroO5eWs6ExB5DPK7I6jn5X4hwF06pqNxj60OVta1HUHPbW1Ln2ei4qzgfhQUhxPCRwNYLi81BRUNrr+d032nqkkwz5li5vyYiTzhVRSUV9cFdKKi3ORjTR0Wz605Tl2Saefr6i6RwICJSOKWiEti66V4oWHV5BvkZSezxMbm9INNMxuhY/nDnfOKMOsyxsqS3EKFAAlsX7pVvu1Y/X95TyqabOtd57xrc8jKSeGxJNmnmGNKIGfa2CjHcJBUNU77mf3adTXD/4izK61sxaNWca7KTGC1FAiFCkRQPuvA1/xM6g9vmj0oor2/lzjc+57V9p7jswtGSdooRReaKhilf8z+7mpgUzV/WXCr30sSIFE6pqPTYujDH6rkk0/ey55dkmrkgIYrJY2IlqAkR4iSwdWGK1vPU9Rf1CG4yjEOI8CKpaDfjEqJ49qYcapsdNLW1yzAOIcKQBDYfTNESyIQIZ5KKCiEijgQ2IUTEGZGpqHtjLqvVGuSWCBF64uLiUKlUwW7GeRmRga2pqQmA1NTUILdEiNBzPttShooRua+oy+Xi7Nmzw/qXyWq1kpqaSnl5edj/0gSKvEf9E+j3qfvnQlEUmpqawqonNyJ7bGq1mvHjxwflZ8fHx8uHtg/yHvXPcL1PKpUq7P49pHgghIg4EtiEEBFHAtswMRgMrF+/HoPBEOymhCx5j/pH3qe+jcjigRAiskmPTQgRcSSwCSEijgQ2IUTEkcAmhIg4EtgCqKGhgcLCQkwmEyaTicLCQhobG3u95t1332XhwoWYzWZUKhUHDx4clrYOl+eff5709HSMRiO5ubns3r271/M//vhjcnNzMRqNTJo0iRdffHGYWho8A3mPKisrWb58OVOmTEGtVrN69erha2gIk8AWQMuXL+fgwYPs2LGDHTt2cPDgQQoLC3u9pqWlhby8PJ566qlhauXwefvtt1m9ejXr1q2juLiYgoICFi9eTFlZmc/zS0tLufLKKykoKKC4uJif/exn3H333bzzzjvD3PLhM9D3yG63M3r0aNatW8fFF188zK0NYYoIiGPHjimA8sknn3iOFRUVKYDy5Zdf9nl9aWmpAijFxcUBbOXwmj17trJy5UqvY1lZWcoDDzzg8/z77rtPycrK8jr2ox/9SJk7d27A2hhsA32Purr00kuVe+65J0AtCy/SYwuQoqIiTCYTc+bM8RybO3cuJpOJffv2BbFlweFwODhw4AALFizwOr5gwQK/70dRUVGP8xcuXMhnn31Ge7vvrRLD2WDeI+GbBLYAqaqqYsyYMT2OjxkzhqqqqiC0KLhqa2txOp0kJyd7HU9OTvb7flRVVfk8v6Ojg9raWp/XhLPBvEfCNwlsA/TII4+gUql6fXz22WcAPpd4URQlbJZ+CYTur72v98PX+b6OR5KBvkeipxG5bNH5WLVqFTfeeGOv50ycOJFDhw5RXV3d43s1NTU9/iKPBGazGY1G06Pnce7cOb/vR0pKis/ztVotSUlJAWtrsAzmPRK+SWAbILPZjNnse1PlrubNm4fFYuHTTz9l9uzZAOzfvx+LxcL8+fMD3cyQo9fryc3NZdeuXSxdutRzfNeuXSxZssTnNfPmzWPbtm1ex3bu3MmsWbPQ6XQBbW8wDOY9En4Et3YR2RYtWqRcdNFFSlFRkVJUVKTMmDFDufrqq73OmTJlivLuu+96vq6rq1OKi4uV999/XwGUt956SykuLlYqKyuHu/lD7q233lJ0Op2yZcsW5dixY8rq1auVmJgY5dSpU4qiKMoDDzygFBYWes7/+uuvlejoaOXee+9Vjh07pmzZskXR6XTK73//+2C9hIAb6HukKIpSXFysFBcXK7m5ucry5cuV4uJi5ejRo8FofsiQwBZAdXV1ys0336zExcUpcXFxys0336w0NDR4nQMor7zyiufrV155RQF6PNavXz+sbQ+U5557TklLS1P0er0yc+ZM5eOPP/Z875ZbblEuvfRSr/P/93//V8nJyVH0er0yceJE5YUXXhjmFg+/gb5Hvn5f0tLShrfRIUaWLRJCRBypigohIo4ENiFExJHAJoSIOBLYhBARRwKbECLiSGATQkQcCWxCiIgjgU0IEXEksAkhIo4ENiFExJHAJoSIOBLYhBAR5/8BfwX90eCBD0oAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 300x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "dataset=data.make_dataset_from_SCM(P=10000, N=1000, M=1, W0=None, eta=0.000001, rho=1.0)\n",
    "sns.jointplot(x=dataset[:, 0], y=dataset[:, 1], height=3)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "abbb51d1",
   "metadata": {},
   "source": [
    "## Example of Linear VAE Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "0236117e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 0, eg: 2.2939, (elbo, recon, kl)=(53048.8984, 51964.0000, 961.7963)\n",
      "Epoch: 1000, eg: 1.4070, (elbo, recon, kl)=(51336.4023, 50557.4180, 727.0120)\n",
      "Epoch: 2000, eg: 0.8199, (elbo, recon, kl)=(51107.5859, 50382.8828, 688.2391)\n",
      "Epoch: 3000, eg: 0.3508, (elbo, recon, kl)=(50970.2422, 50124.9141, 798.4910)\n",
      "Epoch: 4000, eg: 0.1981, (elbo, recon, kl)=(50912.4961, 49996.3086, 859.7677)\n",
      "Epoch: 5000, eg: 0.1595, (elbo, recon, kl)=(50899.9414, 49962.1992, 877.5621)\n",
      "Epoch: 6000, eg: 0.1505, (elbo, recon, kl)=(50897.9531, 49954.5000, 882.0622)\n",
      "Epoch: 7000, eg: 0.1489, (elbo, recon, kl)=(50897.7852, 49953.0508, 883.0253)\n",
      "Epoch: 8000, eg: 0.1488, (elbo, recon, kl)=(50897.7773, 49952.8789, 883.1447)\n",
      "Epoch: 9000, eg: 0.1488, (elbo, recon, kl)=(50897.7773, 49952.8750, 883.1495)\n"
     ]
    }
   ],
   "source": [
    "feature_dim=1\n",
    "x_dim, z_dim=100, 1\n",
    "W0=torch.ones(x_dim, feature_dim)\n",
    "\n",
    "model = vae.LinearVAE(x_dim, z_dim).to(device)\n",
    "dataset=data.make_dataset_from_SCM(P=1000, N=x_dim, M=feature_dim, W0=W0, eta=1, rho=1.0).to(device)\n",
    "\n",
    "history, model = vae.batchfit_linearvae(dataset, model, num_epoch=10000, beta=1.0, lr=0.001, reg_param=1.0, device=device)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e3bbd8f5",
   "metadata": {},
   "source": [
    "## Reproduce Dataset Size Dependence of Generalization Error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "75055887",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "alpha: 0.40\n",
      "Epoch: 0, eg: 1.9342, (elbo, recon, kl)=(13068.4912, 12714.5430, 101.4312)\n",
      "Epoch: 500, eg: 1.4324, (elbo, recon, kl)=(12810.0283, 12609.0244, 70.2559)\n",
      "Epoch: 1000, eg: 1.2174, (elbo, recon, kl)=(12720.3174, 12590.2881, 61.0269)\n",
      "Epoch: 1500, eg: 1.1197, (elbo, recon, kl)=(12679.0674, 12584.7969, 57.2967)\n",
      "Epoch: 2000, eg: 1.0817, (elbo, recon, kl)=(12659.2402, 12581.7266, 56.2809)\n",
      "Epoch: 2500, eg: 1.0684, (elbo, recon, kl)=(12649.8037, 12577.9844, 56.8377)\n",
      "Epoch: 3000, eg: 1.0749, (elbo, recon, kl)=(12645.1943, 12571.4570, 58.9716)\n",
      "Epoch: 3500, eg: 1.1031, (elbo, recon, kl)=(12642.5879, 12560.4326, 63.0522)\n",
      "Epoch: 4000, eg: 1.1332, (elbo, recon, kl)=(12640.9785, 12546.8018, 68.2656)\n",
      "Epoch: 4500, eg: 1.1574, (elbo, recon, kl)=(12640.1699, 12536.1826, 72.3847)\n",
      "Epoch: 5000, eg: 1.1688, (elbo, recon, kl)=(12639.8516, 12530.6621, 74.5417)\n",
      "Epoch: 5500, eg: 1.1726, (elbo, recon, kl)=(12639.7314, 12528.4170, 75.4229)\n",
      "Epoch: 6000, eg: 1.1750, (elbo, recon, kl)=(12639.6797, 12527.5762, 75.7529)\n",
      "Epoch: 6500, eg: 1.1798, (elbo, recon, kl)=(12639.6445, 12527.2109, 75.8945)\n",
      "Epoch: 7000, eg: 1.1888, (elbo, recon, kl)=(12639.6123, 12526.9580, 75.9911)\n",
      "Epoch: 7500, eg: 1.2036, (elbo, recon, kl)=(12639.5713, 12526.6660, 76.1012)\n",
      "Epoch: 8000, eg: 1.2022, (elbo, recon, kl)=(12639.5088, 12526.2197, 76.2693)\n",
      "Epoch: 8500, eg: 1.1730, (elbo, recon, kl)=(12639.4082, 12525.4600, 76.5565)\n",
      "Epoch: 9000, eg: 1.1365, (elbo, recon, kl)=(12639.2627, 12524.3232, 76.9867)\n",
      "Epoch: 9500, eg: 1.1029, (elbo, recon, kl)=(12639.1338, 12523.2578, 77.3909)\n",
      "Epoch: 10000, eg: 1.0818, (elbo, recon, kl)=(12639.0703, 12522.7520, 77.5827)\n",
      "Epoch: 10500, eg: 1.0720, (elbo, recon, kl)=(12639.0547, 12522.6309, 77.6286)\n",
      "Epoch: 11000, eg: 1.0683, (elbo, recon, kl)=(12639.0508, 12522.6182, 77.6333)\n",
      "Epoch: 11500, eg: 1.0672, (elbo, recon, kl)=(12639.0498, 12522.6182, 77.6328)\n",
      "Epoch: 12000, eg: 1.0670, (elbo, recon, kl)=(12639.0498, 12522.6182, 77.6326)\n",
      "Epoch: 12500, eg: 1.0669, (elbo, recon, kl)=(12639.0498, 12522.6182, 77.6326)\n",
      "Epoch: 13000, eg: 1.0669, (elbo, recon, kl)=(12639.0498, 12522.6182, 77.6326)\n",
      "Epoch: 13500, eg: 1.0669, (elbo, recon, kl)=(12639.0498, 12522.6182, 77.6326)\n",
      "Epoch: 14000, eg: 1.0669, (elbo, recon, kl)=(12639.0498, 12522.6182, 77.6326)\n",
      "Epoch: 14500, eg: 1.0669, (elbo, recon, kl)=(12639.0498, 12522.6191, 77.6321)\n",
      "Epoch: 0, eg: 1.9238, (elbo, recon, kl)=(12953.0137, 12579.5117, 108.3301)\n",
      "Epoch: 500, eg: 1.4465, (elbo, recon, kl)=(12703.9717, 12490.8008, 76.7587)\n",
      "Epoch: 1000, eg: 1.2238, (elbo, recon, kl)=(12613.4883, 12476.7305, 64.8972)\n",
      "Epoch: 1500, eg: 1.1094, (elbo, recon, kl)=(12571.5498, 12473.3975, 59.4453)\n",
      "Epoch: 2000, eg: 1.0531, (elbo, recon, kl)=(12551.4805, 12472.5732, 56.9645)\n",
      "Epoch: 2500, eg: 1.0260, (elbo, recon, kl)=(12541.8721, 12472.0381, 55.9169)\n",
      "Epoch: 3000, eg: 1.0110, (elbo, recon, kl)=(12537.2139, 12470.2227, 56.0051)\n",
      "Epoch: 3500, eg: 1.0003, (elbo, recon, kl)=(12534.4863, 12463.9990, 58.0582)\n",
      "Epoch: 4000, eg: 0.9999, (elbo, recon, kl)=(12531.8184, 12447.4941, 64.1848)\n",
      "Epoch: 4500, eg: 1.0136, (elbo, recon, kl)=(12529.2988, 12424.3906, 72.9939)\n",
      "Epoch: 5000, eg: 1.0234, (elbo, recon, kl)=(12527.9863, 12409.3467, 78.7801)\n",
      "Epoch: 5500, eg: 1.0277, (elbo, recon, kl)=(12527.4922, 12402.9932, 81.2302)\n",
      "Epoch: 6000, eg: 1.0309, (elbo, recon, kl)=(12527.3252, 12400.7480, 82.1057)\n",
      "Epoch: 6500, eg: 1.0334, (elbo, recon, kl)=(12527.2764, 12400.0312, 82.3935)\n",
      "Epoch: 7000, eg: 1.0350, (elbo, recon, kl)=(12527.2656, 12399.8076, 82.4876)\n",
      "Epoch: 7500, eg: 1.0356, (elbo, recon, kl)=(12527.2646, 12399.7383, 82.5182)\n",
      "Epoch: 8000, eg: 1.0358, (elbo, recon, kl)=(12527.2617, 12399.7178, 82.5267)\n",
      "Epoch: 8500, eg: 1.0358, (elbo, recon, kl)=(12527.2627, 12399.7139, 82.5284)\n",
      "Epoch: 9000, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5285)\n",
      "Epoch: 9500, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5286)\n",
      "Epoch: 10000, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5286)\n",
      "Epoch: 10500, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5284)\n",
      "Epoch: 11000, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5286)\n",
      "Epoch: 11500, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5286)\n",
      "Epoch: 12000, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5285)\n",
      "Epoch: 12500, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5287)\n",
      "Epoch: 13000, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5286)\n",
      "Epoch: 13500, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5282)\n",
      "Epoch: 14000, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5287)\n",
      "Epoch: 14500, eg: 1.0359, (elbo, recon, kl)=(12527.2637, 12399.7148, 82.5285)\n",
      "Epoch: 0, eg: 1.8389, (elbo, recon, kl)=(13040.1738, 12715.6846, 104.0303)\n",
      "Epoch: 500, eg: 1.4270, (elbo, recon, kl)=(12814.3096, 12630.7607, 70.9105)\n",
      "Epoch: 1000, eg: 1.2200, (elbo, recon, kl)=(12738.7578, 12616.7100, 62.4506)\n",
      "Epoch: 1500, eg: 1.1078, (elbo, recon, kl)=(12704.4053, 12610.0615, 60.1137)\n",
      "Epoch: 2000, eg: 1.0496, (elbo, recon, kl)=(12687.9766, 12602.6221, 61.0989)\n",
      "Epoch: 2500, eg: 1.0341, (elbo, recon, kl)=(12679.4600, 12589.5576, 65.3179)\n",
      "Epoch: 3000, eg: 1.0629, (elbo, recon, kl)=(12674.2949, 12569.5137, 72.6792)\n",
      "Epoch: 3500, eg: 1.1163, (elbo, recon, kl)=(12671.2725, 12550.5371, 79.8664)\n",
      "Epoch: 4000, eg: 1.1650, (elbo, recon, kl)=(12669.8057, 12538.7959, 84.3351)\n",
      "Epoch: 4500, eg: 1.2001, (elbo, recon, kl)=(12669.1572, 12532.8750, 86.5761)\n",
      "Epoch: 5000, eg: 1.2231, (elbo, recon, kl)=(12668.8828, 12530.1543, 87.5976)\n",
      "Epoch: 5500, eg: 1.2373, (elbo, recon, kl)=(12668.7725, 12529.0010, 88.0264)\n",
      "Epoch: 6000, eg: 1.2454, (elbo, recon, kl)=(12668.7373, 12528.5605, 88.1891)\n",
      "Epoch: 6500, eg: 1.2495, (elbo, recon, kl)=(12668.7256, 12528.4082, 88.2441)\n",
      "Epoch: 7000, eg: 1.2514, (elbo, recon, kl)=(12668.7236, 12528.3623, 88.2607)\n",
      "Epoch: 7500, eg: 1.2520, (elbo, recon, kl)=(12668.7236, 12528.3496, 88.2652)\n",
      "Epoch: 8000, eg: 1.2522, (elbo, recon, kl)=(12668.7256, 12528.3477, 88.2662)\n",
      "Epoch: 8500, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 9000, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 9500, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 10000, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 10500, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 11000, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 11500, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 12000, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 12500, eg: 1.2522, (elbo, recon, kl)=(12668.7227, 12528.3447, 88.2666)\n",
      "Epoch: 13000, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 13500, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2665)\n",
      "Epoch: 14000, eg: 1.2522, (elbo, recon, kl)=(12668.7236, 12528.3457, 88.2664)\n",
      "Epoch: 14500, eg: 1.2522, (elbo, recon, kl)=(12668.7227, 12528.3457, 88.2655)\n",
      "Epoch: 0, eg: 2.0068, (elbo, recon, kl)=(13158.4102, 12806.5840, 89.6367)\n",
      "Epoch: 500, eg: 1.4794, (elbo, recon, kl)=(12926.9268, 12724.1846, 67.8549)\n",
      "Epoch: 1000, eg: 1.2475, (elbo, recon, kl)=(12842.8184, 12710.8633, 61.4434)\n",
      "Epoch: 1500, eg: 1.1347, (elbo, recon, kl)=(12801.8584, 12704.0146, 59.2027)\n",
      "Epoch: 2000, eg: 1.0968, (elbo, recon, kl)=(12781.1670, 12693.8975, 61.0221)\n",
      "Epoch: 2500, eg: 1.1219, (elbo, recon, kl)=(12769.8604, 12675.0039, 67.3520)\n",
      "Epoch: 3000, eg: 1.1911, (elbo, recon, kl)=(12763.0254, 12648.9033, 76.9288)\n",
      "Epoch: 3500, eg: 1.2591, (elbo, recon, kl)=(12759.3730, 12627.2061, 85.0224)\n",
      "Epoch: 4000, eg: 1.2993, (elbo, recon, kl)=(12757.8203, 12615.4824, 89.3833)\n",
      "Epoch: 4500, eg: 1.3175, (elbo, recon, kl)=(12757.2207, 12610.6162, 91.1755)\n",
      "Epoch: 5000, eg: 1.3249, (elbo, recon, kl)=(12756.9932, 12608.8867, 91.8002)\n",
      "Epoch: 5500, eg: 1.3279, (elbo, recon, kl)=(12756.9180, 12608.3613, 91.9836)\n",
      "Epoch: 6000, eg: 1.3293, (elbo, recon, kl)=(12756.8955, 12608.2402, 92.0203)\n",
      "Epoch: 6500, eg: 1.3302, (elbo, recon, kl)=(12756.8896, 12608.2324, 92.0191)\n",
      "Epoch: 7000, eg: 1.3307, (elbo, recon, kl)=(12756.8867, 12608.2402, 92.0140)\n",
      "Epoch: 7500, eg: 1.3309, (elbo, recon, kl)=(12756.8877, 12608.2461, 92.0114)\n",
      "Epoch: 8000, eg: 1.3310, (elbo, recon, kl)=(12756.8857, 12608.2461, 92.0106)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 8500, eg: 1.3310, (elbo, recon, kl)=(12756.8877, 12608.2480, 92.0105)\n",
      "Epoch: 9000, eg: 1.3310, (elbo, recon, kl)=(12756.8867, 12608.2471, 92.0105)\n",
      "Epoch: 9500, eg: 1.3310, (elbo, recon, kl)=(12756.8867, 12608.2471, 92.0105)\n",
      "Epoch: 10000, eg: 1.3310, (elbo, recon, kl)=(12756.8867, 12608.2471, 92.0105)\n",
      "Epoch: 10500, eg: 1.3310, (elbo, recon, kl)=(12756.8867, 12608.2471, 92.0105)\n",
      "Epoch: 11000, eg: 1.3310, (elbo, recon, kl)=(12756.8867, 12608.2471, 92.0105)\n",
      "Epoch: 11500, eg: 1.3310, (elbo, recon, kl)=(12756.8867, 12608.2471, 92.0105)\n",
      "Epoch: 12000, eg: 1.3310, (elbo, recon, kl)=(12756.8867, 12608.2471, 92.0105)\n",
      "Epoch: 12500, eg: 1.3310, (elbo, recon, kl)=(12756.8867, 12608.2471, 92.0105)\n",
      "Epoch: 13000, eg: 1.3310, (elbo, recon, kl)=(12756.8877, 12608.2480, 92.0105)\n",
      "Epoch: 13500, eg: 1.3310, (elbo, recon, kl)=(12756.8877, 12608.2480, 92.0107)\n",
      "Epoch: 14000, eg: 1.3310, (elbo, recon, kl)=(12756.8867, 12608.2471, 92.0106)\n",
      "Epoch: 14500, eg: 1.3310, (elbo, recon, kl)=(12756.8877, 12608.2480, 92.0106)\n",
      "Epoch: 0, eg: 1.9969, (elbo, recon, kl)=(13252.7607, 12868.9873, 112.6941)\n",
      "Epoch: 500, eg: 1.4839, (elbo, recon, kl)=(12994.9639, 12773.2695, 76.7998)\n",
      "Epoch: 1000, eg: 1.2413, (elbo, recon, kl)=(12905.9805, 12757.9111, 66.1695)\n",
      "Epoch: 1500, eg: 1.1306, (elbo, recon, kl)=(12863.3770, 12752.9756, 61.8166)\n",
      "Epoch: 2000, eg: 1.0887, (elbo, recon, kl)=(12841.5000, 12749.6357, 60.4529)\n",
      "Epoch: 2500, eg: 1.0842, (elbo, recon, kl)=(12829.7266, 12744.7197, 61.0770)\n",
      "Epoch: 3000, eg: 1.1070, (elbo, recon, kl)=(12822.8955, 12735.3145, 64.0316)\n",
      "Epoch: 3500, eg: 1.1504, (elbo, recon, kl)=(12818.4961, 12720.3135, 69.4605)\n",
      "Epoch: 4000, eg: 1.1953, (elbo, recon, kl)=(12815.6992, 12704.3857, 75.4382)\n",
      "Epoch: 4500, eg: 1.2233, (elbo, recon, kl)=(12814.1299, 12693.2383, 79.6575)\n",
      "Epoch: 5000, eg: 1.2349, (elbo, recon, kl)=(12813.1816, 12686.6660, 82.1388)\n",
      "Epoch: 5500, eg: 1.2391, (elbo, recon, kl)=(12812.4453, 12682.0781, 83.8633)\n",
      "Epoch: 6000, eg: 1.2419, (elbo, recon, kl)=(12811.8340, 12678.2314, 85.3072)\n",
      "Epoch: 6500, eg: 1.2445, (elbo, recon, kl)=(12811.4326, 12675.4111, 86.3665)\n",
      "Epoch: 7000, eg: 1.2461, (elbo, recon, kl)=(12811.2559, 12673.9053, 86.9331)\n",
      "Epoch: 7500, eg: 1.2469, (elbo, recon, kl)=(12811.2031, 12673.3359, 87.1466)\n",
      "Epoch: 8000, eg: 1.2474, (elbo, recon, kl)=(12811.1953, 12673.1816, 87.2048)\n",
      "Epoch: 8500, eg: 1.2477, (elbo, recon, kl)=(12811.1953, 12673.1504, 87.2168)\n",
      "Epoch: 9000, eg: 1.2478, (elbo, recon, kl)=(12811.1934, 12673.1426, 87.2188)\n",
      "Epoch: 9500, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2187)\n",
      "Epoch: 10000, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2190)\n",
      "Epoch: 10500, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2190)\n",
      "Epoch: 11000, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2189)\n",
      "Epoch: 11500, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2190)\n",
      "Epoch: 12000, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2190)\n",
      "Epoch: 12500, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2189)\n",
      "Epoch: 13000, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2188)\n",
      "Epoch: 13500, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2190)\n",
      "Epoch: 14000, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2190)\n",
      "Epoch: 14500, eg: 1.2479, (elbo, recon, kl)=(12811.1943, 12673.1436, 87.2191)\n",
      "alpha: 0.80\n",
      "Epoch: 0, eg: 1.8886, (elbo, recon, kl)=(25815.8262, 25380.1895, 193.1885)\n",
      "Epoch: 500, eg: 1.4854, (elbo, recon, kl)=(25487.2148, 25206.3848, 148.2363)\n",
      "Epoch: 1000, eg: 1.2821, (elbo, recon, kl)=(25383.9082, 25171.9688, 132.9936)\n",
      "Epoch: 1500, eg: 1.1612, (elbo, recon, kl)=(25336.5586, 25156.8164, 127.5947)\n",
      "Epoch: 2000, eg: 1.0904, (elbo, recon, kl)=(25311.5820, 25138.7422, 130.1463)\n",
      "Epoch: 2500, eg: 1.0599, (elbo, recon, kl)=(25295.3340, 25107.3867, 141.0397)\n",
      "Epoch: 3000, eg: 1.0613, (elbo, recon, kl)=(25283.9316, 25069.9609, 155.8172)\n",
      "Epoch: 3500, eg: 1.0698, (elbo, recon, kl)=(25277.4375, 25043.6250, 166.4611)\n",
      "Epoch: 4000, eg: 1.0716, (elbo, recon, kl)=(25274.2578, 25030.1367, 171.8576)\n",
      "Epoch: 4500, eg: 1.0679, (elbo, recon, kl)=(25272.7129, 25023.7988, 174.3261)\n",
      "Epoch: 5000, eg: 1.0627, (elbo, recon, kl)=(25271.9316, 25020.6973, 175.4945)\n",
      "Epoch: 5500, eg: 1.0580, (elbo, recon, kl)=(25271.5430, 25019.1230, 176.0727)\n",
      "Epoch: 6000, eg: 1.0546, (elbo, recon, kl)=(25271.3613, 25018.3418, 176.3537)\n",
      "Epoch: 6500, eg: 1.0525, (elbo, recon, kl)=(25271.2852, 25017.9844, 176.4796)\n",
      "Epoch: 7000, eg: 1.0515, (elbo, recon, kl)=(25271.2598, 25017.8398, 176.5294)\n",
      "Epoch: 7500, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7891, 176.5462)\n",
      "Epoch: 8000, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7754, 176.5510)\n",
      "Epoch: 8500, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5520)\n",
      "Epoch: 9000, eg: 1.0511, (elbo, recon, kl)=(25271.2500, 25017.7695, 176.5522)\n",
      "Epoch: 9500, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5522)\n",
      "Epoch: 10000, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5522)\n",
      "Epoch: 10500, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5522)\n",
      "Epoch: 11000, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5522)\n",
      "Epoch: 11500, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5522)\n",
      "Epoch: 12000, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5522)\n",
      "Epoch: 12500, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5522)\n",
      "Epoch: 13000, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5523)\n",
      "Epoch: 13500, eg: 1.0511, (elbo, recon, kl)=(25271.2480, 25017.7676, 176.5519)\n",
      "Epoch: 14000, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5522)\n",
      "Epoch: 14500, eg: 1.0511, (elbo, recon, kl)=(25271.2520, 25017.7715, 176.5523)\n",
      "Epoch: 0, eg: 1.9348, (elbo, recon, kl)=(25558.9199, 25113.9902, 194.7825)\n",
      "Epoch: 500, eg: 1.3949, (elbo, recon, kl)=(25207.5645, 24924.9023, 147.2248)\n",
      "Epoch: 1000, eg: 1.1569, (elbo, recon, kl)=(25096.6094, 24884.8105, 132.6855)\n",
      "Epoch: 1500, eg: 1.0575, (elbo, recon, kl)=(25046.6152, 24866.7520, 128.0536)\n",
      "Epoch: 2000, eg: 1.0348, (elbo, recon, kl)=(25022.5625, 24851.3945, 129.7203)\n",
      "Epoch: 2500, eg: 1.0570, (elbo, recon, kl)=(25010.2207, 24833.8164, 135.2812)\n",
      "Epoch: 3000, eg: 1.1047, (elbo, recon, kl)=(25003.4336, 24814.7910, 142.7147)\n",
      "Epoch: 3500, eg: 1.1593, (elbo, recon, kl)=(24999.6738, 24798.4258, 149.5265)\n",
      "Epoch: 4000, eg: 1.2081, (elbo, recon, kl)=(24997.6328, 24787.0273, 154.3644)\n",
      "Epoch: 4500, eg: 1.2480, (elbo, recon, kl)=(24996.4883, 24779.8164, 157.4313)\n",
      "Epoch: 5000, eg: 1.2807, (elbo, recon, kl)=(24995.7773, 24775.1855, 159.3939)\n",
      "Epoch: 5500, eg: 1.3078, (elbo, recon, kl)=(24995.3027, 24772.0996, 160.6996)\n",
      "Epoch: 6000, eg: 1.3297, (elbo, recon, kl)=(24994.9941, 24770.1172, 161.5392)\n",
      "Epoch: 6500, eg: 1.3455, (elbo, recon, kl)=(24994.8281, 24769.0234, 162.0056)\n",
      "Epoch: 7000, eg: 1.3547, (elbo, recon, kl)=(24994.7578, 24768.5508, 162.2086)\n",
      "Epoch: 7500, eg: 1.3578, (elbo, recon, kl)=(24994.7305, 24768.3965, 162.2741)\n",
      "Epoch: 8000, eg: 1.3564, (elbo, recon, kl)=(24994.7246, 24768.3555, 162.2910)\n",
      "Epoch: 8500, eg: 1.3526, (elbo, recon, kl)=(24994.7227, 24768.3398, 162.2975)\n",
      "Epoch: 9000, eg: 1.3482, (elbo, recon, kl)=(24994.7227, 24768.3301, 162.3021)\n",
      "Epoch: 9500, eg: 1.3445, (elbo, recon, kl)=(24994.7188, 24768.3223, 162.3053)\n",
      "Epoch: 10000, eg: 1.3420, (elbo, recon, kl)=(24994.7207, 24768.3184, 162.3072)\n",
      "Epoch: 10500, eg: 1.3406, (elbo, recon, kl)=(24994.7188, 24768.3145, 162.3082)\n",
      "Epoch: 11000, eg: 1.3400, (elbo, recon, kl)=(24994.7207, 24768.3145, 162.3085)\n",
      "Epoch: 11500, eg: 1.3398, (elbo, recon, kl)=(24994.7207, 24768.3145, 162.3087)\n",
      "Epoch: 12000, eg: 1.3398, (elbo, recon, kl)=(24994.7207, 24768.3145, 162.3087)\n",
      "Epoch: 12500, eg: 1.3398, (elbo, recon, kl)=(24994.7207, 24768.3145, 162.3087)\n",
      "Epoch: 13000, eg: 1.3398, (elbo, recon, kl)=(24994.7207, 24768.3145, 162.3086)\n",
      "Epoch: 13500, eg: 1.3398, (elbo, recon, kl)=(24994.7207, 24768.3145, 162.3087)\n",
      "Epoch: 14000, eg: 1.3398, (elbo, recon, kl)=(24994.7207, 24768.3145, 162.3087)\n",
      "Epoch: 14500, eg: 1.3398, (elbo, recon, kl)=(24994.7207, 24768.3145, 162.3089)\n",
      "Epoch: 0, eg: 1.8658, (elbo, recon, kl)=(25907.7539, 25456.4141, 203.0721)\n",
      "Epoch: 500, eg: 1.4580, (elbo, recon, kl)=(25561.6289, 25277.8301, 148.1210)\n",
      "Epoch: 1000, eg: 1.2554, (elbo, recon, kl)=(25455.5586, 25245.1035, 130.6630)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 1500, eg: 1.1460, (elbo, recon, kl)=(25405.9648, 25231.2188, 124.0710)\n",
      "Epoch: 2000, eg: 1.1142, (elbo, recon, kl)=(25380.8359, 25217.5098, 124.6949)\n",
      "Epoch: 2500, eg: 1.1415, (elbo, recon, kl)=(25367.3613, 25198.6953, 130.6196)\n",
      "Epoch: 3000, eg: 1.2092, (elbo, recon, kl)=(25359.3223, 25175.3398, 139.8294)\n",
      "Epoch: 3500, eg: 1.2917, (elbo, recon, kl)=(25354.1270, 25153.3223, 148.9749)\n",
      "Epoch: 4000, eg: 1.3071, (elbo, recon, kl)=(25350.4805, 25135.9492, 156.2559)\n",
      "Epoch: 4500, eg: 1.3014, (elbo, recon, kl)=(25347.6445, 25122.3887, 161.9168)\n",
      "Epoch: 5000, eg: 1.2908, (elbo, recon, kl)=(25345.5723, 25112.2910, 166.1121)\n",
      "Epoch: 5500, eg: 1.2808, (elbo, recon, kl)=(25344.3535, 25105.9922, 168.7135)\n",
      "Epoch: 6000, eg: 1.2739, (elbo, recon, kl)=(25343.8086, 25102.8848, 169.9894)\n",
      "Epoch: 6500, eg: 1.2706, (elbo, recon, kl)=(25343.6133, 25101.6758, 170.4794)\n",
      "Epoch: 7000, eg: 1.2700, (elbo, recon, kl)=(25343.5566, 25101.3027, 170.6258)\n",
      "Epoch: 7500, eg: 1.2709, (elbo, recon, kl)=(25343.5449, 25101.2148, 170.6587)\n",
      "Epoch: 8000, eg: 1.2721, (elbo, recon, kl)=(25343.5469, 25101.2012, 170.6636)\n",
      "Epoch: 8500, eg: 1.2728, (elbo, recon, kl)=(25343.5469, 25101.1992, 170.6635)\n",
      "Epoch: 9000, eg: 1.2731, (elbo, recon, kl)=(25343.5449, 25101.1973, 170.6632)\n",
      "Epoch: 9500, eg: 1.2732, (elbo, recon, kl)=(25343.5469, 25101.1992, 170.6632)\n",
      "Epoch: 10000, eg: 1.2732, (elbo, recon, kl)=(25343.5449, 25101.1992, 170.6630)\n",
      "Epoch: 10500, eg: 1.2732, (elbo, recon, kl)=(25343.5469, 25101.2012, 170.6632)\n",
      "Epoch: 11000, eg: 1.2732, (elbo, recon, kl)=(25343.5469, 25101.1992, 170.6632)\n",
      "Epoch: 11500, eg: 1.2732, (elbo, recon, kl)=(25343.5469, 25101.1992, 170.6631)\n",
      "Epoch: 12000, eg: 1.2732, (elbo, recon, kl)=(25343.5469, 25101.1992, 170.6634)\n",
      "Epoch: 12500, eg: 1.2732, (elbo, recon, kl)=(25343.5488, 25101.2012, 170.6632)\n",
      "Epoch: 13000, eg: 1.2732, (elbo, recon, kl)=(25343.5449, 25101.1992, 170.6630)\n",
      "Epoch: 13500, eg: 1.2732, (elbo, recon, kl)=(25343.5469, 25101.1992, 170.6633)\n",
      "Epoch: 14000, eg: 1.2732, (elbo, recon, kl)=(25343.5449, 25101.1992, 170.6640)\n",
      "Epoch: 14500, eg: 1.2732, (elbo, recon, kl)=(25343.5449, 25101.1992, 170.6630)\n",
      "Epoch: 0, eg: 1.7620, (elbo, recon, kl)=(26030.6914, 25591.6680, 200.1213)\n",
      "Epoch: 500, eg: 1.3381, (elbo, recon, kl)=(25720.3359, 25440.0000, 151.4663)\n",
      "Epoch: 1000, eg: 1.1492, (elbo, recon, kl)=(25622.6680, 25415.1680, 132.3966)\n",
      "Epoch: 1500, eg: 1.0558, (elbo, recon, kl)=(25578.7031, 25407.7852, 124.0656)\n",
      "Epoch: 2000, eg: 1.0201, (elbo, recon, kl)=(25556.9785, 25400.4531, 122.4173)\n",
      "Epoch: 2500, eg: 1.0369, (elbo, recon, kl)=(25544.7051, 25385.0977, 126.8359)\n",
      "Epoch: 3000, eg: 1.1085, (elbo, recon, kl)=(25536.0371, 25357.9160, 137.5443)\n",
      "Epoch: 3500, eg: 1.2064, (elbo, recon, kl)=(25529.6250, 25327.7949, 150.0963)\n",
      "Epoch: 4000, eg: 1.2877, (elbo, recon, kl)=(25525.4883, 25306.1289, 159.1416)\n",
      "Epoch: 4500, eg: 1.3418, (elbo, recon, kl)=(25523.1172, 25293.5391, 164.3178)\n",
      "Epoch: 5000, eg: 1.3755, (elbo, recon, kl)=(25521.9316, 25286.9453, 166.9933)\n",
      "Epoch: 5500, eg: 1.3968, (elbo, recon, kl)=(25521.4004, 25283.8203, 168.2484)\n",
      "Epoch: 6000, eg: 1.4117, (elbo, recon, kl)=(25521.1758, 25282.4785, 168.7803)\n",
      "Epoch: 6500, eg: 1.4108, (elbo, recon, kl)=(25521.0879, 25281.9531, 168.9882)\n",
      "Epoch: 7000, eg: 1.4032, (elbo, recon, kl)=(25521.0566, 25281.7617, 169.0630)\n",
      "Epoch: 7500, eg: 1.3977, (elbo, recon, kl)=(25521.0449, 25281.6992, 169.0859)\n",
      "Epoch: 8000, eg: 1.3945, (elbo, recon, kl)=(25521.0410, 25281.6836, 169.0912)\n",
      "Epoch: 8500, eg: 1.3932, (elbo, recon, kl)=(25521.0410, 25281.6816, 169.0921)\n",
      "Epoch: 9000, eg: 1.3928, (elbo, recon, kl)=(25521.0410, 25281.6816, 169.0921)\n",
      "Epoch: 9500, eg: 1.3927, (elbo, recon, kl)=(25521.0430, 25281.6836, 169.0923)\n",
      "Epoch: 10000, eg: 1.3927, (elbo, recon, kl)=(25521.0430, 25281.6836, 169.0922)\n",
      "Epoch: 10500, eg: 1.3927, (elbo, recon, kl)=(25521.0449, 25281.6855, 169.0921)\n",
      "Epoch: 11000, eg: 1.3927, (elbo, recon, kl)=(25521.0410, 25281.6816, 169.0922)\n",
      "Epoch: 11500, eg: 1.3927, (elbo, recon, kl)=(25521.0410, 25281.6816, 169.0922)\n",
      "Epoch: 12000, eg: 1.3927, (elbo, recon, kl)=(25521.0449, 25281.6855, 169.0921)\n",
      "Epoch: 12500, eg: 1.3927, (elbo, recon, kl)=(25521.0449, 25281.6855, 169.0921)\n",
      "Epoch: 13000, eg: 1.3927, (elbo, recon, kl)=(25521.0449, 25281.6855, 169.0921)\n",
      "Epoch: 13500, eg: 1.3927, (elbo, recon, kl)=(25521.0430, 25281.6836, 169.0925)\n",
      "Epoch: 14000, eg: 1.3927, (elbo, recon, kl)=(25521.0410, 25281.6816, 169.0912)\n",
      "Epoch: 14500, eg: 1.3927, (elbo, recon, kl)=(25521.0410, 25281.6816, 169.0926)\n",
      "Epoch: 0, eg: 1.9119, (elbo, recon, kl)=(25703.4277, 25228.8867, 217.9347)\n",
      "Epoch: 500, eg: 1.4479, (elbo, recon, kl)=(25335.6230, 25034.1562, 157.8589)\n",
      "Epoch: 1000, eg: 1.2267, (elbo, recon, kl)=(25222.0078, 24995.6797, 137.3306)\n",
      "Epoch: 1500, eg: 1.1047, (elbo, recon, kl)=(25168.4258, 24978.9531, 129.9221)\n",
      "Epoch: 2000, eg: 1.0447, (elbo, recon, kl)=(25139.2910, 24960.9902, 131.2646)\n",
      "Epoch: 2500, eg: 1.0385, (elbo, recon, kl)=(25122.0078, 24935.7695, 139.1480)\n",
      "Epoch: 3000, eg: 1.0751, (elbo, recon, kl)=(25111.5547, 24907.9688, 149.7803)\n",
      "Epoch: 3500, eg: 1.1239, (elbo, recon, kl)=(25105.9727, 24887.6289, 157.9805)\n",
      "Epoch: 4000, eg: 1.1648, (elbo, recon, kl)=(25103.3516, 24876.5703, 162.5027)\n",
      "Epoch: 4500, eg: 1.1972, (elbo, recon, kl)=(25102.1836, 24871.2637, 164.6796)\n",
      "Epoch: 5000, eg: 1.2240, (elbo, recon, kl)=(25101.6543, 24868.7910, 165.6956)\n",
      "Epoch: 5500, eg: 1.2464, (elbo, recon, kl)=(25101.4043, 24867.6270, 166.1742)\n",
      "Epoch: 6000, eg: 1.2644, (elbo, recon, kl)=(25101.2969, 24867.0820, 166.4000)\n",
      "Epoch: 6500, eg: 1.2775, (elbo, recon, kl)=(25101.2520, 24866.8359, 166.5011)\n",
      "Epoch: 7000, eg: 1.2859, (elbo, recon, kl)=(25101.2344, 24866.7363, 166.5421)\n",
      "Epoch: 7500, eg: 1.2905, (elbo, recon, kl)=(25101.2305, 24866.6992, 166.5579)\n",
      "Epoch: 8000, eg: 1.2926, (elbo, recon, kl)=(25101.2305, 24866.6836, 166.5641)\n",
      "Epoch: 8500, eg: 1.2934, (elbo, recon, kl)=(25101.2266, 24866.6758, 166.5666)\n",
      "Epoch: 9000, eg: 1.2936, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5675)\n",
      "Epoch: 9500, eg: 1.2937, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5677)\n",
      "Epoch: 10000, eg: 1.2937, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5678)\n",
      "Epoch: 10500, eg: 1.2937, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5678)\n",
      "Epoch: 11000, eg: 1.2937, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5676)\n",
      "Epoch: 11500, eg: 1.2937, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5679)\n",
      "Epoch: 12000, eg: 1.2937, (elbo, recon, kl)=(25101.2324, 24866.6797, 166.5677)\n",
      "Epoch: 12500, eg: 1.2937, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5676)\n",
      "Epoch: 13000, eg: 1.2937, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5681)\n",
      "Epoch: 13500, eg: 1.2937, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5679)\n",
      "Epoch: 14000, eg: 1.2937, (elbo, recon, kl)=(25101.2285, 24866.6777, 166.5673)\n",
      "Epoch: 14500, eg: 1.2937, (elbo, recon, kl)=(25101.2305, 24866.6777, 166.5676)\n",
      "alpha: 1.20\n",
      "Epoch: 0, eg: 1.7804, (elbo, recon, kl)=(38586.2422, 38050.7578, 294.9635)\n",
      "Epoch: 500, eg: 1.3482, (elbo, recon, kl)=(38147.6055, 37797.5469, 221.4364)\n",
      "Epoch: 1000, eg: 1.1552, (elbo, recon, kl)=(38015.0273, 37743.8203, 195.0390)\n",
      "Epoch: 1500, eg: 1.0604, (elbo, recon, kl)=(37955.3125, 37716.1016, 187.3984)\n",
      "Epoch: 2000, eg: 1.0382, (elbo, recon, kl)=(37924.0586, 37683.6797, 194.0434)\n",
      "Epoch: 2500, eg: 1.0708, (elbo, recon, kl)=(37905.2578, 37642.3203, 209.8036)\n",
      "Epoch: 3000, eg: 1.1239, (elbo, recon, kl)=(37894.3594, 37606.5156, 225.0618)\n",
      "Epoch: 3500, eg: 1.1669, (elbo, recon, kl)=(37888.9219, 37584.9102, 234.4907)\n",
      "Epoch: 4000, eg: 1.1940, (elbo, recon, kl)=(37886.3047, 37573.6484, 239.3928)\n",
      "Epoch: 4500, eg: 1.2121, (elbo, recon, kl)=(37884.8438, 37567.3047, 242.1247)\n",
      "Epoch: 5000, eg: 1.2295, (elbo, recon, kl)=(37883.7969, 37562.8594, 244.0265)\n",
      "Epoch: 5500, eg: 1.2525, (elbo, recon, kl)=(37882.9062, 37559.0938, 245.6367)\n",
      "Epoch: 6000, eg: 1.2831, (elbo, recon, kl)=(37882.1836, 37555.8594, 247.0350)\n",
      "Epoch: 6500, eg: 1.3176, (elbo, recon, kl)=(37881.7031, 37553.4492, 248.0900)\n",
      "Epoch: 7000, eg: 1.3482, (elbo, recon, kl)=(37881.4414, 37552.0078, 248.7250)\n",
      "Epoch: 7500, eg: 1.3661, (elbo, recon, kl)=(37881.3086, 37551.2891, 249.0414)\n",
      "Epoch: 8000, eg: 1.3603, (elbo, recon, kl)=(37881.1797, 37550.7656, 249.2616)\n",
      "Epoch: 8500, eg: 1.3113, (elbo, recon, kl)=(37880.7617, 37549.3125, 249.8546)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 9000, eg: 1.2084, (elbo, recon, kl)=(37879.3711, 37544.4453, 251.8682)\n",
      "Epoch: 9500, eg: 1.1287, (elbo, recon, kl)=(37877.7148, 37538.8984, 254.1648)\n",
      "Epoch: 10000, eg: 1.1091, (elbo, recon, kl)=(37876.9766, 37536.5039, 255.1428)\n",
      "Epoch: 10500, eg: 1.1124, (elbo, recon, kl)=(37876.7812, 37535.7344, 255.4594)\n",
      "Epoch: 11000, eg: 1.1168, (elbo, recon, kl)=(37876.7461, 37535.5117, 255.5519)\n",
      "Epoch: 11500, eg: 1.1186, (elbo, recon, kl)=(37876.7461, 37535.4609, 255.5750)\n",
      "Epoch: 12000, eg: 1.1191, (elbo, recon, kl)=(37876.7422, 37535.4453, 255.5798)\n",
      "Epoch: 12500, eg: 1.1191, (elbo, recon, kl)=(37876.7500, 37535.4492, 255.5808)\n",
      "Epoch: 13000, eg: 1.1191, (elbo, recon, kl)=(37876.7461, 37535.4453, 255.5803)\n",
      "Epoch: 13500, eg: 1.1191, (elbo, recon, kl)=(37876.7461, 37535.4453, 255.5810)\n",
      "Epoch: 14000, eg: 1.1191, (elbo, recon, kl)=(37876.7461, 37535.4453, 255.5803)\n",
      "Epoch: 14500, eg: 1.1191, (elbo, recon, kl)=(37876.7461, 37535.4453, 255.5804)\n",
      "Epoch: 0, eg: 1.9281, (elbo, recon, kl)=(38307.1602, 37767.4805, 287.6853)\n",
      "Epoch: 500, eg: 1.5137, (elbo, recon, kl)=(37879.1250, 37516.8359, 223.2068)\n",
      "Epoch: 1000, eg: 1.2889, (elbo, recon, kl)=(37751.0234, 37466.3672, 199.9866)\n",
      "Epoch: 1500, eg: 1.1693, (elbo, recon, kl)=(37693.2422, 37448.1406, 189.1539)\n",
      "Epoch: 2000, eg: 1.1138, (elbo, recon, kl)=(37664.5117, 37434.6367, 186.9832)\n",
      "Epoch: 2500, eg: 1.1034, (elbo, recon, kl)=(37647.9883, 37414.6328, 192.2916)\n",
      "Epoch: 3000, eg: 1.1271, (elbo, recon, kl)=(37635.9102, 37382.7148, 205.1271)\n",
      "Epoch: 3500, eg: 1.1615, (elbo, recon, kl)=(37626.7109, 37347.3984, 220.5694)\n",
      "Epoch: 4000, eg: 1.1789, (elbo, recon, kl)=(37620.9414, 37321.0156, 232.3827)\n",
      "Epoch: 4500, eg: 1.1747, (elbo, recon, kl)=(37617.8867, 37305.1797, 239.5448)\n",
      "Epoch: 5000, eg: 1.1575, (elbo, recon, kl)=(37616.4531, 37296.6875, 243.4008)\n",
      "Epoch: 5500, eg: 1.1363, (elbo, recon, kl)=(37615.8203, 37292.4961, 245.2984)\n",
      "Epoch: 6000, eg: 1.1171, (elbo, recon, kl)=(37615.5312, 37290.5000, 246.1954)\n",
      "Epoch: 6500, eg: 1.1026, (elbo, recon, kl)=(37615.3711, 37289.5117, 246.6362)\n",
      "Epoch: 7000, eg: 1.0931, (elbo, recon, kl)=(37615.2656, 37288.9883, 246.8669)\n",
      "Epoch: 7500, eg: 1.0874, (elbo, recon, kl)=(37615.1992, 37288.7188, 246.9839)\n",
      "Epoch: 8000, eg: 1.0842, (elbo, recon, kl)=(37615.1602, 37288.6016, 247.0323)\n",
      "Epoch: 8500, eg: 1.0826, (elbo, recon, kl)=(37615.1445, 37288.5703, 247.0430)\n",
      "Epoch: 9000, eg: 1.0819, (elbo, recon, kl)=(37615.1406, 37288.5781, 247.0390)\n",
      "Epoch: 9500, eg: 1.0816, (elbo, recon, kl)=(37615.1367, 37288.5859, 247.0331)\n",
      "Epoch: 10000, eg: 1.0814, (elbo, recon, kl)=(37615.1367, 37288.5938, 247.0297)\n",
      "Epoch: 10500, eg: 1.0814, (elbo, recon, kl)=(37615.1367, 37288.5977, 247.0284)\n",
      "Epoch: 11000, eg: 1.0814, (elbo, recon, kl)=(37615.1328, 37288.5938, 247.0281)\n",
      "Epoch: 11500, eg: 1.0814, (elbo, recon, kl)=(37615.1328, 37288.5938, 247.0281)\n",
      "Epoch: 12000, eg: 1.0814, (elbo, recon, kl)=(37615.1367, 37288.5977, 247.0281)\n",
      "Epoch: 12500, eg: 1.0814, (elbo, recon, kl)=(37615.1367, 37288.5977, 247.0281)\n",
      "Epoch: 13000, eg: 1.0814, (elbo, recon, kl)=(37615.1367, 37288.5977, 247.0280)\n",
      "Epoch: 13500, eg: 1.0814, (elbo, recon, kl)=(37615.1367, 37288.5977, 247.0281)\n",
      "Epoch: 14000, eg: 1.0814, (elbo, recon, kl)=(37615.1367, 37288.5977, 247.0280)\n",
      "Epoch: 14500, eg: 1.0814, (elbo, recon, kl)=(37615.1367, 37288.5977, 247.0283)\n",
      "Epoch: 0, eg: 2.0548, (elbo, recon, kl)=(38546.0586, 38023.1484, 268.3583)\n",
      "Epoch: 500, eg: 1.6312, (elbo, recon, kl)=(38128.8398, 37770.0625, 213.4298)\n",
      "Epoch: 1000, eg: 1.3535, (elbo, recon, kl)=(38007.7812, 37717.1094, 198.3256)\n",
      "Epoch: 1500, eg: 1.1940, (elbo, recon, kl)=(37949.4492, 37692.1406, 192.6015)\n",
      "Epoch: 2000, eg: 1.1060, (elbo, recon, kl)=(37918.1523, 37669.6133, 195.3691)\n",
      "Epoch: 2500, eg: 1.0611, (elbo, recon, kl)=(37900.4531, 37645.2812, 203.3067)\n",
      "Epoch: 3000, eg: 1.0386, (elbo, recon, kl)=(37889.6797, 37620.4141, 213.3539)\n",
      "Epoch: 3500, eg: 1.0254, (elbo, recon, kl)=(37882.4141, 37597.1562, 223.3184)\n",
      "Epoch: 4000, eg: 1.0213, (elbo, recon, kl)=(37876.8867, 37575.9922, 232.4948)\n",
      "Epoch: 4500, eg: 1.0294, (elbo, recon, kl)=(37872.8867, 37558.8320, 239.9822)\n",
      "Epoch: 5000, eg: 1.0421, (elbo, recon, kl)=(37870.5586, 37548.0625, 244.7195)\n",
      "Epoch: 5500, eg: 1.0497, (elbo, recon, kl)=(37869.3789, 37542.5859, 247.1475)\n",
      "Epoch: 6000, eg: 1.0515, (elbo, recon, kl)=(37868.5938, 37539.4375, 248.5164)\n",
      "Epoch: 6500, eg: 1.0538, (elbo, recon, kl)=(37867.7539, 37536.4961, 249.7472)\n",
      "Epoch: 7000, eg: 1.0656, (elbo, recon, kl)=(37866.7422, 37533.1055, 251.1388)\n",
      "Epoch: 7500, eg: 1.0920, (elbo, recon, kl)=(37865.7383, 37529.8398, 252.4673)\n",
      "Epoch: 8000, eg: 1.1281, (elbo, recon, kl)=(37865.0234, 37527.4961, 253.4212)\n",
      "Epoch: 8500, eg: 1.1633, (elbo, recon, kl)=(37864.6758, 37526.2422, 253.9390)\n",
      "Epoch: 9000, eg: 1.1891, (elbo, recon, kl)=(37864.5586, 37525.7383, 254.1519)\n",
      "Epoch: 9500, eg: 1.2033, (elbo, recon, kl)=(37864.5273, 37525.5781, 254.2200)\n",
      "Epoch: 10000, eg: 1.2090, (elbo, recon, kl)=(37864.5312, 37525.5430, 254.2381)\n",
      "Epoch: 10500, eg: 1.2105, (elbo, recon, kl)=(37864.5273, 37525.5312, 254.2428)\n",
      "Epoch: 11000, eg: 1.2108, (elbo, recon, kl)=(37864.5234, 37525.5273, 254.2435)\n",
      "Epoch: 11500, eg: 1.2108, (elbo, recon, kl)=(37864.5273, 37525.5312, 254.2435)\n",
      "Epoch: 12000, eg: 1.2108, (elbo, recon, kl)=(37864.5273, 37525.5312, 254.2435)\n",
      "Epoch: 12500, eg: 1.2108, (elbo, recon, kl)=(37864.5273, 37525.5312, 254.2436)\n",
      "Epoch: 13000, eg: 1.2108, (elbo, recon, kl)=(37864.5273, 37525.5312, 254.2436)\n",
      "Epoch: 13500, eg: 1.2108, (elbo, recon, kl)=(37864.5273, 37525.5312, 254.2436)\n",
      "Epoch: 14000, eg: 1.2108, (elbo, recon, kl)=(37864.5273, 37525.5312, 254.2434)\n",
      "Epoch: 14500, eg: 1.2108, (elbo, recon, kl)=(37864.5273, 37525.5312, 254.2437)\n",
      "Epoch: 0, eg: 2.0007, (elbo, recon, kl)=(38915.4570, 38351.3711, 302.8055)\n",
      "Epoch: 500, eg: 1.5682, (elbo, recon, kl)=(38376.7070, 37999.0898, 229.3563)\n",
      "Epoch: 1000, eg: 1.3811, (elbo, recon, kl)=(38222.6562, 37924.4375, 203.1471)\n",
      "Epoch: 1500, eg: 1.2697, (elbo, recon, kl)=(38156.1836, 37900.6250, 190.5732)\n",
      "Epoch: 2000, eg: 1.2035, (elbo, recon, kl)=(38122.4336, 37887.3711, 186.6131)\n",
      "Epoch: 2500, eg: 1.1708, (elbo, recon, kl)=(38103.2734, 37873.0000, 188.5215)\n",
      "Epoch: 3000, eg: 1.1645, (elbo, recon, kl)=(38090.9062, 37851.8594, 196.0123)\n",
      "Epoch: 3500, eg: 1.1746, (elbo, recon, kl)=(38082.1562, 37825.4023, 207.2364)\n",
      "Epoch: 4000, eg: 1.1878, (elbo, recon, kl)=(38076.1328, 37801.0000, 218.0984)\n",
      "Epoch: 4500, eg: 1.2008, (elbo, recon, kl)=(38072.1953, 37782.7422, 226.3012)\n",
      "Epoch: 5000, eg: 1.2200, (elbo, recon, kl)=(38069.6133, 37769.8672, 232.0570)\n",
      "Epoch: 5500, eg: 1.2516, (elbo, recon, kl)=(38067.8711, 37760.8242, 236.0667)\n",
      "Epoch: 6000, eg: 1.3002, (elbo, recon, kl)=(38066.6523, 37754.5078, 238.8490)\n",
      "Epoch: 6500, eg: 1.3726, (elbo, recon, kl)=(38065.6094, 37749.7070, 240.9251)\n",
      "Epoch: 7000, eg: 1.4285, (elbo, recon, kl)=(38064.3945, 37744.9492, 242.9384)\n",
      "Epoch: 7500, eg: 1.3158, (elbo, recon, kl)=(38062.7344, 37738.9688, 245.4339)\n",
      "Epoch: 8000, eg: 1.2093, (elbo, recon, kl)=(38060.9531, 37732.6094, 248.0876)\n",
      "Epoch: 8500, eg: 1.1408, (elbo, recon, kl)=(38059.8086, 37728.4453, 249.8410)\n",
      "Epoch: 9000, eg: 1.1074, (elbo, recon, kl)=(38059.3711, 37726.7266, 250.5735)\n",
      "Epoch: 9500, eg: 1.0932, (elbo, recon, kl)=(38059.2656, 37726.2383, 250.7854)\n",
      "Epoch: 10000, eg: 1.0879, (elbo, recon, kl)=(38059.2500, 37726.1406, 250.8308)\n",
      "Epoch: 10500, eg: 1.0864, (elbo, recon, kl)=(38059.2500, 37726.1211, 250.8391)\n",
      "Epoch: 11000, eg: 1.0861, (elbo, recon, kl)=(38059.2461, 37726.1172, 250.8405)\n",
      "Epoch: 11500, eg: 1.0860, (elbo, recon, kl)=(38059.2461, 37726.1172, 250.8409)\n",
      "Epoch: 12000, eg: 1.0860, (elbo, recon, kl)=(38059.2461, 37726.1172, 250.8406)\n",
      "Epoch: 12500, eg: 1.0860, (elbo, recon, kl)=(38059.2461, 37726.1172, 250.8406)\n",
      "Epoch: 13000, eg: 1.0860, (elbo, recon, kl)=(38059.2461, 37726.1172, 250.8405)\n",
      "Epoch: 13500, eg: 1.0860, (elbo, recon, kl)=(38059.2461, 37726.1172, 250.8405)\n",
      "Epoch: 14000, eg: 1.0860, (elbo, recon, kl)=(38059.2461, 37726.1172, 250.8406)\n",
      "Epoch: 14500, eg: 1.0860, (elbo, recon, kl)=(38059.2461, 37726.1172, 250.8406)\n",
      "Epoch: 0, eg: 1.9909, (elbo, recon, kl)=(38570.8320, 37992.1797, 323.0633)\n",
      "Epoch: 500, eg: 1.5386, (elbo, recon, kl)=(38067.7383, 37684.4219, 237.4299)\n",
      "Epoch: 1000, eg: 1.3303, (elbo, recon, kl)=(37916.9258, 37616.5586, 207.3026)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 1500, eg: 1.2204, (elbo, recon, kl)=(37847.7188, 37586.7656, 195.9971)\n",
      "Epoch: 2000, eg: 1.1795, (elbo, recon, kl)=(37810.3203, 37557.3047, 198.6049)\n",
      "Epoch: 2500, eg: 1.1912, (elbo, recon, kl)=(37786.6992, 37517.0195, 212.1425)\n",
      "Epoch: 3000, eg: 1.2322, (elbo, recon, kl)=(37771.1992, 37474.4570, 229.4148)\n",
      "Epoch: 3500, eg: 1.2692, (elbo, recon, kl)=(37762.5430, 37444.9141, 241.8625)\n",
      "Epoch: 4000, eg: 1.2891, (elbo, recon, kl)=(37758.3633, 37429.2852, 248.4822)\n",
      "Epoch: 4500, eg: 1.2973, (elbo, recon, kl)=(37756.4180, 37421.8477, 251.6464)\n",
      "Epoch: 5000, eg: 1.3021, (elbo, recon, kl)=(37755.4961, 37418.3438, 253.1576)\n",
      "Epoch: 5500, eg: 1.3077, (elbo, recon, kl)=(37755.0586, 37416.6094, 253.9204)\n",
      "Epoch: 6000, eg: 1.3146, (elbo, recon, kl)=(37754.8477, 37415.7148, 254.3235)\n",
      "Epoch: 6500, eg: 1.3216, (elbo, recon, kl)=(37754.7656, 37415.2695, 254.5337)\n",
      "Epoch: 7000, eg: 1.3274, (elbo, recon, kl)=(37754.7422, 37415.0664, 254.6354)\n",
      "Epoch: 7500, eg: 1.3314, (elbo, recon, kl)=(37754.7344, 37414.9844, 254.6783)\n",
      "Epoch: 8000, eg: 1.3337, (elbo, recon, kl)=(37754.7227, 37414.9531, 254.6929)\n",
      "Epoch: 8500, eg: 1.3347, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6963)\n",
      "Epoch: 9000, eg: 1.3351, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6967)\n",
      "Epoch: 9500, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6966)\n",
      "Epoch: 10000, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6966)\n",
      "Epoch: 10500, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6966)\n",
      "Epoch: 11000, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6966)\n",
      "Epoch: 11500, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6966)\n",
      "Epoch: 12000, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6965)\n",
      "Epoch: 12500, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6966)\n",
      "Epoch: 13000, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6966)\n",
      "Epoch: 13500, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6962)\n",
      "Epoch: 14000, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6966)\n",
      "Epoch: 14500, eg: 1.3352, (elbo, recon, kl)=(37754.7305, 37414.9531, 254.6965)\n",
      "alpha: 1.60\n",
      "Epoch: 0, eg: 1.7895, (elbo, recon, kl)=(51558.1523, 50898.6406, 406.7950)\n",
      "Epoch: 500, eg: 1.4446, (elbo, recon, kl)=(50972.1445, 50523.6094, 306.8276)\n",
      "Epoch: 1000, eg: 1.2839, (elbo, recon, kl)=(50796.5781, 50437.8086, 268.7217)\n",
      "Epoch: 1500, eg: 1.1872, (elbo, recon, kl)=(50718.8164, 50406.4531, 251.0624)\n",
      "Epoch: 2000, eg: 1.1406, (elbo, recon, kl)=(50679.1211, 50385.6016, 246.5274)\n",
      "Epoch: 2500, eg: 1.1364, (elbo, recon, kl)=(50656.2422, 50361.1211, 251.5287)\n",
      "Epoch: 3000, eg: 1.1708, (elbo, recon, kl)=(50640.5820, 50327.2617, 264.7595)\n",
      "Epoch: 3500, eg: 1.2379, (elbo, recon, kl)=(50628.3203, 50287.5508, 282.5153)\n",
      "Epoch: 4000, eg: 1.3251, (elbo, recon, kl)=(50618.9531, 50251.2578, 299.2043)\n",
      "Epoch: 4500, eg: 1.4182, (elbo, recon, kl)=(50612.7344, 50225.0156, 311.2457)\n",
      "Epoch: 5000, eg: 1.4513, (elbo, recon, kl)=(50609.0391, 50209.1133, 318.4642)\n",
      "Epoch: 5500, eg: 1.3992, (elbo, recon, kl)=(50606.8477, 50199.9961, 322.5665)\n",
      "Epoch: 6000, eg: 1.3212, (elbo, recon, kl)=(50605.3359, 50194.1016, 325.1984)\n",
      "Epoch: 6500, eg: 1.2213, (elbo, recon, kl)=(50603.9727, 50189.3008, 327.3063)\n",
      "Epoch: 7000, eg: 1.1078, (elbo, recon, kl)=(50602.5703, 50184.7969, 329.2282)\n",
      "Epoch: 7500, eg: 0.9972, (elbo, recon, kl)=(50601.2695, 50180.8203, 330.8926)\n",
      "Epoch: 8000, eg: 0.9076, (elbo, recon, kl)=(50600.3203, 50177.9336, 332.0939)\n",
      "Epoch: 8500, eg: 0.8472, (elbo, recon, kl)=(50599.8203, 50176.3164, 332.7781)\n",
      "Epoch: 9000, eg: 0.8126, (elbo, recon, kl)=(50599.6289, 50175.6172, 333.0815)\n",
      "Epoch: 9500, eg: 0.7957, (elbo, recon, kl)=(50599.5820, 50175.3906, 333.1877)\n",
      "Epoch: 10000, eg: 0.7888, (elbo, recon, kl)=(50599.5742, 50175.3242, 333.2186)\n",
      "Epoch: 10500, eg: 0.7867, (elbo, recon, kl)=(50599.5664, 50175.3047, 333.2263)\n",
      "Epoch: 11000, eg: 0.7862, (elbo, recon, kl)=(50599.5625, 50175.3008, 333.2278)\n",
      "Epoch: 11500, eg: 0.7861, (elbo, recon, kl)=(50599.5664, 50175.3047, 333.2280)\n",
      "Epoch: 12000, eg: 0.7861, (elbo, recon, kl)=(50599.5664, 50175.3047, 333.2277)\n",
      "Epoch: 12500, eg: 0.7861, (elbo, recon, kl)=(50599.5664, 50175.3047, 333.2279)\n",
      "Epoch: 13000, eg: 0.7861, (elbo, recon, kl)=(50599.5664, 50175.3047, 333.2281)\n",
      "Epoch: 13500, eg: 0.7861, (elbo, recon, kl)=(50599.5664, 50175.3047, 333.2281)\n",
      "Epoch: 14000, eg: 0.7861, (elbo, recon, kl)=(50599.5664, 50175.3047, 333.2282)\n",
      "Epoch: 14500, eg: 0.7861, (elbo, recon, kl)=(50599.5664, 50175.3047, 333.2282)\n",
      "Epoch: 0, eg: 1.6620, (elbo, recon, kl)=(50975.1133, 50365.5352, 376.1116)\n",
      "Epoch: 500, eg: 1.2795, (elbo, recon, kl)=(50475.1055, 50040.6367, 300.2864)\n",
      "Epoch: 1000, eg: 1.1048, (elbo, recon, kl)=(50331.1641, 49968.2227, 273.5544)\n",
      "Epoch: 1500, eg: 1.0147, (elbo, recon, kl)=(50267.4609, 49935.3125, 264.9702)\n",
      "Epoch: 2000, eg: 0.9827, (elbo, recon, kl)=(50234.4805, 49907.6836, 267.8139)\n",
      "Epoch: 2500, eg: 0.9981, (elbo, recon, kl)=(50214.8516, 49877.0000, 277.7845)\n",
      "Epoch: 3000, eg: 1.0509, (elbo, recon, kl)=(50201.7227, 49845.2461, 290.6287)\n",
      "Epoch: 3500, eg: 1.1222, (elbo, recon, kl)=(50192.7695, 49819.4062, 301.5393)\n",
      "Epoch: 4000, eg: 1.1942, (elbo, recon, kl)=(50186.8867, 49801.9805, 308.8648)\n",
      "Epoch: 4500, eg: 1.2581, (elbo, recon, kl)=(50183.1641, 49790.9922, 313.4605)\n",
      "Epoch: 5000, eg: 1.3103, (elbo, recon, kl)=(50180.9492, 49784.1641, 316.3539)\n",
      "Epoch: 5500, eg: 1.3494, (elbo, recon, kl)=(50179.7109, 49780.0039, 318.1520)\n",
      "Epoch: 6000, eg: 1.3753, (elbo, recon, kl)=(50179.0938, 49777.6289, 319.2029)\n",
      "Epoch: 6500, eg: 1.3884, (elbo, recon, kl)=(50178.8047, 49776.3711, 319.7695)\n",
      "Epoch: 7000, eg: 1.3900, (elbo, recon, kl)=(50178.6680, 49775.7109, 320.0709)\n",
      "Epoch: 7500, eg: 1.3820, (elbo, recon, kl)=(50178.5703, 49775.2969, 320.2554)\n",
      "Epoch: 8000, eg: 1.3670, (elbo, recon, kl)=(50178.4922, 49774.9883, 320.3954)\n",
      "Epoch: 8500, eg: 1.3476, (elbo, recon, kl)=(50178.4180, 49774.7227, 320.5132)\n",
      "Epoch: 9000, eg: 1.3268, (elbo, recon, kl)=(50178.3594, 49774.5117, 320.6080)\n",
      "Epoch: 9500, eg: 1.3073, (elbo, recon, kl)=(50178.3203, 49774.3594, 320.6747)\n",
      "Epoch: 10000, eg: 1.2914, (elbo, recon, kl)=(50178.3047, 49774.2812, 320.7136)\n",
      "Epoch: 10500, eg: 1.2803, (elbo, recon, kl)=(50178.2969, 49774.2422, 320.7321)\n",
      "Epoch: 11000, eg: 1.2738, (elbo, recon, kl)=(50178.2930, 49774.2266, 320.7395)\n",
      "Epoch: 11500, eg: 1.2708, (elbo, recon, kl)=(50178.2891, 49774.2188, 320.7419)\n",
      "Epoch: 12000, eg: 1.2697, (elbo, recon, kl)=(50178.2969, 49774.2227, 320.7425)\n",
      "Epoch: 12500, eg: 1.2694, (elbo, recon, kl)=(50178.2930, 49774.2188, 320.7426)\n",
      "Epoch: 13000, eg: 1.2694, (elbo, recon, kl)=(50178.2891, 49774.2188, 320.7433)\n",
      "Epoch: 13500, eg: 1.2694, (elbo, recon, kl)=(50178.2891, 49774.2188, 320.7431)\n",
      "Epoch: 14000, eg: 1.2694, (elbo, recon, kl)=(50178.2930, 49774.2188, 320.7428)\n",
      "Epoch: 14500, eg: 1.2694, (elbo, recon, kl)=(50178.2930, 49774.2188, 320.7429)\n",
      "Epoch: 0, eg: 1.9101, (elbo, recon, kl)=(51560.7109, 50830.6719, 453.4667)\n",
      "Epoch: 500, eg: 1.5115, (elbo, recon, kl)=(50924.0859, 50428.2422, 337.2541)\n",
      "Epoch: 1000, eg: 1.3425, (elbo, recon, kl)=(50740.5703, 50350.0547, 288.2286)\n",
      "Epoch: 1500, eg: 1.2520, (elbo, recon, kl)=(50662.3008, 50328.4219, 263.4102)\n",
      "Epoch: 2000, eg: 1.2192, (elbo, recon, kl)=(50621.0742, 50309.5898, 256.8007)\n",
      "Epoch: 2500, eg: 1.2518, (elbo, recon, kl)=(50593.0977, 50271.1953, 267.7665)\n",
      "Epoch: 3000, eg: 1.3342, (elbo, recon, kl)=(50571.3164, 50215.9766, 290.6221)\n",
      "Epoch: 3500, eg: 1.4150, (elbo, recon, kl)=(50556.5781, 50170.1445, 310.4759)\n",
      "Epoch: 4000, eg: 1.4730, (elbo, recon, kl)=(50547.7695, 50141.4570, 322.8344)\n",
      "Epoch: 4500, eg: 1.5131, (elbo, recon, kl)=(50542.9180, 50124.6992, 330.0700)\n",
      "Epoch: 5000, eg: 1.5407, (elbo, recon, kl)=(50540.5430, 50115.4062, 334.1433)\n",
      "Epoch: 5500, eg: 1.5571, (elbo, recon, kl)=(50539.5430, 50110.7344, 336.2316)\n",
      "Epoch: 6000, eg: 1.5548, (elbo, recon, kl)=(50539.1836, 50108.6797, 337.1668)\n",
      "Epoch: 6500, eg: 1.5494, (elbo, recon, kl)=(50539.0664, 50107.9102, 337.5221)\n",
      "Epoch: 7000, eg: 1.5433, (elbo, recon, kl)=(50539.0391, 50107.6758, 337.6316)\n",
      "Epoch: 7500, eg: 1.5381, (elbo, recon, kl)=(50539.0273, 50107.6211, 337.6552)\n",
      "Epoch: 8000, eg: 1.5343, (elbo, recon, kl)=(50539.0234, 50107.6172, 337.6562)\n",
      "Epoch: 8500, eg: 1.5320, (elbo, recon, kl)=(50539.0312, 50107.6250, 337.6548)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 9000, eg: 1.5307, (elbo, recon, kl)=(50539.0273, 50107.6250, 337.6541)\n",
      "Epoch: 9500, eg: 1.5300, (elbo, recon, kl)=(50539.0234, 50107.6211, 337.6540)\n",
      "Epoch: 10000, eg: 1.5297, (elbo, recon, kl)=(50539.0234, 50107.6211, 337.6541)\n",
      "Epoch: 10500, eg: 1.5296, (elbo, recon, kl)=(50539.0273, 50107.6250, 337.6541)\n",
      "Epoch: 11000, eg: 1.5296, (elbo, recon, kl)=(50539.0273, 50107.6250, 337.6540)\n",
      "Epoch: 11500, eg: 1.5296, (elbo, recon, kl)=(50539.0273, 50107.6250, 337.6541)\n",
      "Epoch: 12000, eg: 1.5296, (elbo, recon, kl)=(50539.0273, 50107.6250, 337.6540)\n",
      "Epoch: 12500, eg: 1.5296, (elbo, recon, kl)=(50539.0273, 50107.6250, 337.6541)\n",
      "Epoch: 13000, eg: 1.5296, (elbo, recon, kl)=(50539.0273, 50107.6250, 337.6540)\n",
      "Epoch: 13500, eg: 1.5296, (elbo, recon, kl)=(50539.0273, 50107.6250, 337.6540)\n",
      "Epoch: 14000, eg: 1.5296, (elbo, recon, kl)=(50539.0273, 50107.6250, 337.6540)\n",
      "Epoch: 14500, eg: 1.5296, (elbo, recon, kl)=(50539.0312, 50107.6250, 337.6547)\n",
      "Epoch: 0, eg: 1.7377, (elbo, recon, kl)=(51489.1562, 50888.8008, 379.9300)\n",
      "Epoch: 500, eg: 1.3760, (elbo, recon, kl)=(50996.4766, 50578.8477, 295.8800)\n",
      "Epoch: 1000, eg: 1.2183, (elbo, recon, kl)=(50861.8672, 50520.8594, 264.3354)\n",
      "Epoch: 1500, eg: 1.1372, (elbo, recon, kl)=(50806.6055, 50500.2031, 252.1819)\n",
      "Epoch: 2000, eg: 1.1020, (elbo, recon, kl)=(50779.3594, 50481.1250, 252.4359)\n",
      "Epoch: 2500, eg: 1.1000, (elbo, recon, kl)=(50762.6133, 50452.3750, 262.4131)\n",
      "Epoch: 3000, eg: 1.1218, (elbo, recon, kl)=(50750.5469, 50416.5039, 277.9804)\n",
      "Epoch: 3500, eg: 1.1509, (elbo, recon, kl)=(50741.8242, 50383.9258, 292.7792)\n",
      "Epoch: 4000, eg: 1.1716, (elbo, recon, kl)=(50735.9023, 50360.4688, 303.4927)\n",
      "Epoch: 4500, eg: 1.1754, (elbo, recon, kl)=(50732.1992, 50345.4375, 310.3868)\n",
      "Epoch: 5000, eg: 1.1581, (elbo, recon, kl)=(50730.0898, 50336.2656, 314.6530)\n",
      "Epoch: 5500, eg: 1.1169, (elbo, recon, kl)=(50728.9062, 50330.6719, 317.2978)\n",
      "Epoch: 6000, eg: 1.0520, (elbo, recon, kl)=(50728.1367, 50326.8555, 319.1165)\n",
      "Epoch: 6500, eg: 0.9690, (elbo, recon, kl)=(50727.4258, 50323.5625, 320.6626)\n",
      "Epoch: 7000, eg: 0.8819, (elbo, recon, kl)=(50726.6641, 50320.3359, 322.1415)\n",
      "Epoch: 7500, eg: 0.8109, (elbo, recon, kl)=(50725.9141, 50317.5000, 323.4050)\n",
      "Epoch: 8000, eg: 0.7692, (elbo, recon, kl)=(50725.3242, 50315.5234, 324.2542)\n",
      "Epoch: 8500, eg: 0.7552, (elbo, recon, kl)=(50724.9492, 50314.4453, 324.6967)\n",
      "Epoch: 9000, eg: 0.7576, (elbo, recon, kl)=(50724.7812, 50314.0000, 324.8741)\n",
      "Epoch: 9500, eg: 0.7654, (elbo, recon, kl)=(50724.7070, 50313.8594, 324.9234)\n",
      "Epoch: 10000, eg: 0.7720, (elbo, recon, kl)=(50724.6953, 50313.8398, 324.9281)\n",
      "Epoch: 10500, eg: 0.7756, (elbo, recon, kl)=(50724.6992, 50313.8477, 324.9245)\n",
      "Epoch: 11000, eg: 0.7769, (elbo, recon, kl)=(50724.6914, 50313.8477, 324.9223)\n",
      "Epoch: 11500, eg: 0.7773, (elbo, recon, kl)=(50724.6953, 50313.8516, 324.9217)\n",
      "Epoch: 12000, eg: 0.7773, (elbo, recon, kl)=(50724.6914, 50313.8477, 324.9216)\n",
      "Epoch: 12500, eg: 0.7773, (elbo, recon, kl)=(50724.6953, 50313.8516, 324.9217)\n",
      "Epoch: 13000, eg: 0.7773, (elbo, recon, kl)=(50724.6953, 50313.8516, 324.9215)\n",
      "Epoch: 13500, eg: 0.7773, (elbo, recon, kl)=(50724.6953, 50313.8516, 324.9216)\n",
      "Epoch: 14000, eg: 0.7773, (elbo, recon, kl)=(50724.6953, 50313.8516, 324.9216)\n",
      "Epoch: 14500, eg: 0.7773, (elbo, recon, kl)=(50724.6953, 50313.8516, 324.9216)\n",
      "Epoch: 0, eg: 1.9016, (elbo, recon, kl)=(51195.9219, 50543.8477, 402.1185)\n",
      "Epoch: 500, eg: 1.4708, (elbo, recon, kl)=(50659.3516, 50204.0664, 312.5798)\n",
      "Epoch: 1000, eg: 1.3176, (elbo, recon, kl)=(50501.6211, 50131.3828, 277.5471)\n",
      "Epoch: 1500, eg: 1.2267, (elbo, recon, kl)=(50429.9766, 50102.8281, 261.7475)\n",
      "Epoch: 2000, eg: 1.1368, (elbo, recon, kl)=(50391.5664, 50078.3398, 259.8994)\n",
      "Epoch: 2500, eg: 1.0724, (elbo, recon, kl)=(50367.0820, 50043.2344, 270.1373)\n",
      "Epoch: 3000, eg: 1.0176, (elbo, recon, kl)=(50349.6445, 49999.1719, 288.1311)\n",
      "Epoch: 3500, eg: 0.9599, (elbo, recon, kl)=(50338.0430, 49961.3711, 304.6315)\n",
      "Epoch: 4000, eg: 0.8998, (elbo, recon, kl)=(50330.8711, 49935.7695, 315.8466)\n",
      "Epoch: 4500, eg: 0.8470, (elbo, recon, kl)=(50326.4258, 49919.6016, 322.8366)\n",
      "Epoch: 5000, eg: 0.8083, (elbo, recon, kl)=(50323.6055, 49909.6797, 327.0211)\n",
      "Epoch: 5500, eg: 0.7847, (elbo, recon, kl)=(50321.8320, 49903.8750, 329.3900)\n",
      "Epoch: 6000, eg: 0.7736, (elbo, recon, kl)=(50320.7617, 49900.7109, 330.6302)\n",
      "Epoch: 6500, eg: 0.7708, (elbo, recon, kl)=(50320.1719, 49899.1562, 331.2093)\n",
      "Epoch: 7000, eg: 0.7723, (elbo, recon, kl)=(50319.8867, 49898.5039, 331.4360)\n",
      "Epoch: 7500, eg: 0.7750, (elbo, recon, kl)=(50319.7734, 49898.2852, 331.5032)\n",
      "Epoch: 8000, eg: 0.7771, (elbo, recon, kl)=(50319.7305, 49898.2266, 331.5145)\n",
      "Epoch: 8500, eg: 0.7781, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5132)\n",
      "Epoch: 9000, eg: 0.7784, (elbo, recon, kl)=(50319.7148, 49898.2188, 331.5116)\n",
      "Epoch: 9500, eg: 0.7785, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5109)\n",
      "Epoch: 10000, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5109)\n",
      "Epoch: 10500, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5109)\n",
      "Epoch: 11000, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5108)\n",
      "Epoch: 11500, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5108)\n",
      "Epoch: 12000, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5106)\n",
      "Epoch: 12500, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5102)\n",
      "Epoch: 13000, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5108)\n",
      "Epoch: 13500, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5107)\n",
      "Epoch: 14000, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5110)\n",
      "Epoch: 14500, eg: 0.7784, (elbo, recon, kl)=(50319.7188, 49898.2227, 331.5103)\n",
      "alpha: 2.00\n",
      "Epoch: 0, eg: 1.7917, (elbo, recon, kl)=(64234.1523, 63521.0117, 486.4741)\n",
      "Epoch: 500, eg: 1.4174, (elbo, recon, kl)=(63602.2422, 63093.8867, 379.2194)\n",
      "Epoch: 1000, eg: 1.2337, (elbo, recon, kl)=(63426.1562, 63006.0898, 337.1300)\n",
      "Epoch: 1500, eg: 1.1352, (elbo, recon, kl)=(63349.9492, 62972.0508, 319.2252)\n",
      "Epoch: 2000, eg: 1.0976, (elbo, recon, kl)=(63312.7109, 62946.8789, 317.1246)\n",
      "Epoch: 2500, eg: 1.1197, (elbo, recon, kl)=(63291.8242, 62916.2656, 326.3304)\n",
      "Epoch: 3000, eg: 1.2186, (elbo, recon, kl)=(63277.2383, 62875.5039, 344.3321)\n",
      "Epoch: 3500, eg: 1.3740, (elbo, recon, kl)=(63265.5234, 62831.1016, 365.4211)\n",
      "Epoch: 4000, eg: 1.2710, (elbo, recon, kl)=(63255.1641, 62791.1055, 384.2325)\n",
      "Epoch: 4500, eg: 1.1107, (elbo, recon, kl)=(63245.2227, 62757.0234, 399.7203)\n",
      "Epoch: 5000, eg: 0.9503, (elbo, recon, kl)=(63237.1445, 62731.0391, 411.3030)\n",
      "Epoch: 5500, eg: 0.8318, (elbo, recon, kl)=(63232.4648, 62715.7578, 418.1117)\n",
      "Epoch: 6000, eg: 0.7582, (elbo, recon, kl)=(63230.4961, 62708.9062, 421.1957)\n",
      "Epoch: 6500, eg: 0.7162, (elbo, recon, kl)=(63229.8477, 62706.4570, 422.3158)\n",
      "Epoch: 7000, eg: 0.6933, (elbo, recon, kl)=(63229.6758, 62705.7695, 422.6340)\n",
      "Epoch: 7500, eg: 0.6815, (elbo, recon, kl)=(63229.6484, 62705.6484, 422.6936)\n",
      "Epoch: 8000, eg: 0.6760, (elbo, recon, kl)=(63229.6328, 62705.6367, 422.6938)\n",
      "Epoch: 8500, eg: 0.6739, (elbo, recon, kl)=(63229.6328, 62705.6484, 422.6894)\n",
      "Epoch: 9000, eg: 0.6732, (elbo, recon, kl)=(63229.6406, 62705.6562, 422.6861)\n",
      "Epoch: 9500, eg: 0.6731, (elbo, recon, kl)=(63229.6367, 62705.6562, 422.6865)\n",
      "Epoch: 10000, eg: 0.6731, (elbo, recon, kl)=(63229.6328, 62705.6523, 422.6864)\n",
      "Epoch: 10500, eg: 0.6731, (elbo, recon, kl)=(63229.6367, 62705.6562, 422.6864)\n",
      "Epoch: 11000, eg: 0.6731, (elbo, recon, kl)=(63229.6367, 62705.6562, 422.6863)\n",
      "Epoch: 11500, eg: 0.6731, (elbo, recon, kl)=(63229.6367, 62705.6562, 422.6863)\n",
      "Epoch: 12000, eg: 0.6731, (elbo, recon, kl)=(63229.6328, 62705.6523, 422.6868)\n",
      "Epoch: 12500, eg: 0.6731, (elbo, recon, kl)=(63229.6328, 62705.6523, 422.6864)\n",
      "Epoch: 13000, eg: 0.6731, (elbo, recon, kl)=(63229.6328, 62705.6523, 422.6865)\n",
      "Epoch: 13500, eg: 0.6731, (elbo, recon, kl)=(63229.6289, 62705.6523, 422.6852)\n",
      "Epoch: 14000, eg: 0.6731, (elbo, recon, kl)=(63229.6328, 62705.6523, 422.6859)\n",
      "Epoch: 14500, eg: 0.6731, (elbo, recon, kl)=(63229.6328, 62705.6484, 422.6890)\n",
      "Epoch: 0, eg: 1.9922, (elbo, recon, kl)=(63924.6523, 63151.8945, 513.1428)\n",
      "Epoch: 500, eg: 1.5773, (elbo, recon, kl)=(63242.4961, 62697.7266, 396.2904)\n",
      "Epoch: 1000, eg: 1.3980, (elbo, recon, kl)=(63038.8672, 62590.0234, 350.9346)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 1500, eg: 1.3025, (elbo, recon, kl)=(62948.9492, 62547.0000, 330.8128)\n",
      "Epoch: 2000, eg: 1.2689, (elbo, recon, kl)=(62904.0156, 62518.1680, 327.0470)\n",
      "Epoch: 2500, eg: 1.2799, (elbo, recon, kl)=(62879.3242, 62489.7852, 333.2266)\n",
      "Epoch: 3000, eg: 1.3196, (elbo, recon, kl)=(62864.5039, 62459.9453, 344.7427)\n",
      "Epoch: 3500, eg: 1.3690, (elbo, recon, kl)=(62855.0508, 62432.4609, 357.0648)\n",
      "Epoch: 4000, eg: 1.3989, (elbo, recon, kl)=(62848.7891, 62410.2461, 367.5251)\n",
      "Epoch: 4500, eg: 1.4212, (elbo, recon, kl)=(62844.6875, 62393.8086, 375.4461)\n",
      "Epoch: 5000, eg: 1.4355, (elbo, recon, kl)=(62842.1367, 62382.6133, 380.9190)\n",
      "Epoch: 5500, eg: 1.4411, (elbo, recon, kl)=(62840.6172, 62375.6055, 384.3696)\n",
      "Epoch: 6000, eg: 1.4368, (elbo, recon, kl)=(62839.6445, 62371.3359, 386.4530)\n",
      "Epoch: 6500, eg: 1.4198, (elbo, recon, kl)=(62838.9102, 62368.4883, 387.8103)\n",
      "Epoch: 7000, eg: 1.3869, (elbo, recon, kl)=(62838.2383, 62366.1758, 388.8796)\n",
      "Epoch: 7500, eg: 1.3360, (elbo, recon, kl)=(62837.5625, 62363.9961, 389.8661)\n",
      "Epoch: 8000, eg: 1.2708, (elbo, recon, kl)=(62836.8945, 62361.9375, 390.7890)\n",
      "Epoch: 8500, eg: 1.2013, (elbo, recon, kl)=(62836.3438, 62360.2148, 391.5625)\n",
      "Epoch: 9000, eg: 1.1402, (elbo, recon, kl)=(62835.9766, 62359.0195, 392.1024)\n",
      "Epoch: 9500, eg: 1.0962, (elbo, recon, kl)=(62835.7930, 62358.3555, 392.4091)\n",
      "Epoch: 10000, eg: 1.0711, (elbo, recon, kl)=(62835.7031, 62358.0352, 392.5558)\n",
      "Epoch: 10500, eg: 1.0610, (elbo, recon, kl)=(62835.6875, 62357.9102, 392.6192)\n",
      "Epoch: 11000, eg: 1.0595, (elbo, recon, kl)=(62835.6719, 62357.8555, 392.6444)\n",
      "Epoch: 11500, eg: 1.0610, (elbo, recon, kl)=(62835.6680, 62357.8359, 392.6538)\n",
      "Epoch: 12000, eg: 1.0624, (elbo, recon, kl)=(62835.6680, 62357.8281, 392.6567)\n",
      "Epoch: 12500, eg: 1.0631, (elbo, recon, kl)=(62835.6719, 62357.8320, 392.6574)\n",
      "Epoch: 13000, eg: 1.0633, (elbo, recon, kl)=(62835.6680, 62357.8281, 392.6571)\n",
      "Epoch: 13500, eg: 1.0633, (elbo, recon, kl)=(62835.6719, 62357.8320, 392.6576)\n",
      "Epoch: 14000, eg: 1.0633, (elbo, recon, kl)=(62835.6719, 62357.8320, 392.6576)\n",
      "Epoch: 14500, eg: 1.0633, (elbo, recon, kl)=(62835.6758, 62357.8320, 392.6594)\n",
      "Epoch: 0, eg: 1.9773, (elbo, recon, kl)=(64485.7500, 63702.5000, 519.8354)\n",
      "Epoch: 500, eg: 1.4865, (elbo, recon, kl)=(63735.3047, 63197.7148, 390.9323)\n",
      "Epoch: 1000, eg: 1.2461, (elbo, recon, kl)=(63506.7695, 63076.0430, 338.9548)\n",
      "Epoch: 1500, eg: 1.1001, (elbo, recon, kl)=(63403.3750, 63023.5625, 316.5333)\n",
      "Epoch: 2000, eg: 1.0121, (elbo, recon, kl)=(63350.2812, 62981.2695, 316.5407)\n",
      "Epoch: 2500, eg: 0.9589, (elbo, recon, kl)=(63319.3047, 62931.7422, 332.4885)\n",
      "Epoch: 3000, eg: 0.9190, (elbo, recon, kl)=(63299.6641, 62880.7031, 354.5270)\n",
      "Epoch: 3500, eg: 0.8712, (elbo, recon, kl)=(63287.0469, 62840.1133, 373.1642)\n",
      "Epoch: 4000, eg: 0.8115, (elbo, recon, kl)=(63278.4141, 62810.6172, 386.7676)\n",
      "Epoch: 4500, eg: 0.7493, (elbo, recon, kl)=(63271.8594, 62788.2227, 397.0085)\n",
      "Epoch: 5000, eg: 0.6976, (elbo, recon, kl)=(63266.6445, 62770.5508, 405.0252)\n",
      "Epoch: 5500, eg: 0.6676, (elbo, recon, kl)=(63262.7734, 62757.1289, 411.1123)\n",
      "Epoch: 6000, eg: 0.6613, (elbo, recon, kl)=(63260.3438, 62748.1367, 415.2395)\n",
      "Epoch: 6500, eg: 0.6717, (elbo, recon, kl)=(63259.1055, 62743.1016, 417.5890)\n",
      "Epoch: 7000, eg: 0.6887, (elbo, recon, kl)=(63258.5938, 62740.8125, 418.6780)\n",
      "Epoch: 7500, eg: 0.7053, (elbo, recon, kl)=(63258.4180, 62739.9688, 419.0861)\n",
      "Epoch: 8000, eg: 0.7185, (elbo, recon, kl)=(63258.3672, 62739.7109, 419.2119)\n",
      "Epoch: 8500, eg: 0.7279, (elbo, recon, kl)=(63258.3555, 62739.6406, 419.2458)\n",
      "Epoch: 9000, eg: 0.7340, (elbo, recon, kl)=(63258.3477, 62739.6250, 419.2534)\n",
      "Epoch: 9500, eg: 0.7375, (elbo, recon, kl)=(63258.3398, 62739.6172, 419.2542)\n",
      "Epoch: 10000, eg: 0.7390, (elbo, recon, kl)=(63258.3438, 62739.6211, 419.2540)\n",
      "Epoch: 10500, eg: 0.7396, (elbo, recon, kl)=(63258.3477, 62739.6250, 419.2538)\n",
      "Epoch: 11000, eg: 0.7397, (elbo, recon, kl)=(63258.3438, 62739.6211, 419.2540)\n",
      "Epoch: 11500, eg: 0.7397, (elbo, recon, kl)=(63258.3477, 62739.6250, 419.2544)\n",
      "Epoch: 12000, eg: 0.7397, (elbo, recon, kl)=(63258.3477, 62739.6250, 419.2538)\n",
      "Epoch: 12500, eg: 0.7397, (elbo, recon, kl)=(63258.3398, 62739.6172, 419.2551)\n",
      "Epoch: 13000, eg: 0.7397, (elbo, recon, kl)=(63258.3477, 62739.6250, 419.2537)\n",
      "Epoch: 13500, eg: 0.7397, (elbo, recon, kl)=(63258.3477, 62739.6250, 419.2539)\n",
      "Epoch: 14000, eg: 0.7397, (elbo, recon, kl)=(63258.3477, 62739.6250, 419.2544)\n",
      "Epoch: 14500, eg: 0.7397, (elbo, recon, kl)=(63258.3477, 62739.6250, 419.2534)\n",
      "Epoch: 0, eg: 1.8934, (elbo, recon, kl)=(64317.8477, 63591.1289, 484.1725)\n",
      "Epoch: 500, eg: 1.4571, (elbo, recon, kl)=(63656.4062, 63150.2422, 373.5342)\n",
      "Epoch: 1000, eg: 1.2562, (elbo, recon, kl)=(63475.9570, 63057.3164, 333.5178)\n",
      "Epoch: 1500, eg: 1.1152, (elbo, recon, kl)=(63397.7070, 63020.0430, 317.1313)\n",
      "Epoch: 2000, eg: 1.0120, (elbo, recon, kl)=(63356.8203, 62986.2266, 319.0752)\n",
      "Epoch: 2500, eg: 0.9346, (elbo, recon, kl)=(63331.4531, 62941.5078, 335.1398)\n",
      "Epoch: 3000, eg: 0.8776, (elbo, recon, kl)=(63314.4961, 62892.5664, 357.2075)\n",
      "Epoch: 3500, eg: 0.8324, (elbo, recon, kl)=(63304.3750, 62855.1094, 375.0212)\n",
      "Epoch: 4000, eg: 0.7910, (elbo, recon, kl)=(63298.8984, 62832.4727, 385.8908)\n",
      "Epoch: 4500, eg: 0.7514, (elbo, recon, kl)=(63295.8633, 62819.5859, 392.0663)\n",
      "Epoch: 5000, eg: 0.7162, (elbo, recon, kl)=(63294.0938, 62811.9141, 395.7473)\n",
      "Epoch: 5500, eg: 0.6872, (elbo, recon, kl)=(63293.0312, 62807.0859, 398.0734)\n",
      "Epoch: 6000, eg: 0.6650, (elbo, recon, kl)=(63292.3555, 62803.9609, 399.5835)\n",
      "Epoch: 6500, eg: 0.6496, (elbo, recon, kl)=(63291.8672, 62801.8516, 400.5903)\n",
      "Epoch: 7000, eg: 0.6416, (elbo, recon, kl)=(63291.4688, 62800.3359, 401.2983)\n",
      "Epoch: 7500, eg: 0.6431, (elbo, recon, kl)=(63291.1250, 62799.1797, 401.8265)\n",
      "Epoch: 8000, eg: 0.6572, (elbo, recon, kl)=(63290.8281, 62798.2461, 402.2471)\n",
      "Epoch: 8500, eg: 0.6888, (elbo, recon, kl)=(63290.5547, 62797.3867, 402.6339)\n",
      "Epoch: 9000, eg: 0.7463, (elbo, recon, kl)=(63290.2422, 62796.3906, 403.0801)\n",
      "Epoch: 9500, eg: 0.8404, (elbo, recon, kl)=(63289.8711, 62795.1562, 403.6377)\n",
      "Epoch: 10000, eg: 0.9711, (elbo, recon, kl)=(63289.4883, 62793.8828, 404.2086)\n",
      "Epoch: 10500, eg: 1.1128, (elbo, recon, kl)=(63289.2148, 62792.9766, 404.6123)\n",
      "Epoch: 11000, eg: 1.2310, (elbo, recon, kl)=(63289.0820, 62792.5508, 404.7985)\n",
      "Epoch: 11500, eg: 1.3084, (elbo, recon, kl)=(63289.0391, 62792.4219, 404.8533)\n",
      "Epoch: 12000, eg: 1.3483, (elbo, recon, kl)=(63289.0352, 62792.4023, 404.8620)\n",
      "Epoch: 12500, eg: 1.3640, (elbo, recon, kl)=(63289.0312, 62792.3984, 404.8620)\n",
      "Epoch: 13000, eg: 1.3684, (elbo, recon, kl)=(63289.0391, 62792.4062, 404.8616)\n",
      "Epoch: 13500, eg: 1.3692, (elbo, recon, kl)=(63289.0352, 62792.4023, 404.8616)\n",
      "Epoch: 14000, eg: 1.3693, (elbo, recon, kl)=(63289.0273, 62792.3945, 404.8615)\n",
      "Epoch: 14500, eg: 1.3693, (elbo, recon, kl)=(63289.0312, 62792.3984, 404.8617)\n",
      "Epoch: 0, eg: 1.8907, (elbo, recon, kl)=(63990.3086, 63185.5117, 546.3057)\n",
      "Epoch: 500, eg: 1.4631, (elbo, recon, kl)=(63260.1875, 62700.3047, 411.3723)\n",
      "Epoch: 1000, eg: 1.2748, (elbo, recon, kl)=(63046.5898, 62593.9297, 354.9593)\n",
      "Epoch: 1500, eg: 1.1746, (elbo, recon, kl)=(62956.0430, 62557.5625, 328.4555)\n",
      "Epoch: 2000, eg: 1.1178, (elbo, recon, kl)=(62910.9297, 62534.5469, 320.1985)\n",
      "Epoch: 2500, eg: 1.0889, (elbo, recon, kl)=(62883.5352, 62504.3867, 325.8415)\n",
      "Epoch: 3000, eg: 1.0825, (elbo, recon, kl)=(62863.0820, 62459.4297, 343.8711)\n",
      "Epoch: 3500, eg: 1.0809, (elbo, recon, kl)=(62848.2344, 62413.5508, 364.8541)\n",
      "Epoch: 4000, eg: 1.0595, (elbo, recon, kl)=(62839.0742, 62382.1250, 379.4665)\n",
      "Epoch: 4500, eg: 1.0090, (elbo, recon, kl)=(62833.4727, 62363.1680, 388.1308)\n",
      "Epoch: 5000, eg: 0.9307, (elbo, recon, kl)=(62829.4766, 62349.9336, 394.0979)\n",
      "Epoch: 5500, eg: 0.8344, (elbo, recon, kl)=(62825.9609, 62338.1406, 399.4173)\n",
      "Epoch: 6000, eg: 0.7413, (elbo, recon, kl)=(62822.7344, 62327.0977, 404.4125)\n",
      "Epoch: 6500, eg: 0.6719, (elbo, recon, kl)=(62820.2266, 62318.5195, 408.2793)\n",
      "Epoch: 7000, eg: 0.6312, (elbo, recon, kl)=(62818.7109, 62313.4062, 410.5675)\n",
      "Epoch: 7500, eg: 0.6114, (elbo, recon, kl)=(62818.0000, 62311.0391, 411.6157)\n",
      "Epoch: 8000, eg: 0.6032, (elbo, recon, kl)=(62817.7383, 62310.1875, 411.9843)\n",
      "Epoch: 8500, eg: 0.6002, (elbo, recon, kl)=(62817.6758, 62309.9688, 412.0768)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 9000, eg: 0.5991, (elbo, recon, kl)=(62817.6562, 62309.9258, 412.0907)\n",
      "Epoch: 9500, eg: 0.5987, (elbo, recon, kl)=(62817.6562, 62309.9219, 412.0912)\n",
      "Epoch: 10000, eg: 0.5986, (elbo, recon, kl)=(62817.6562, 62309.9219, 412.0910)\n",
      "Epoch: 10500, eg: 0.5986, (elbo, recon, kl)=(62817.6523, 62309.9180, 412.0909)\n",
      "Epoch: 11000, eg: 0.5986, (elbo, recon, kl)=(62817.6523, 62309.9180, 412.0912)\n",
      "Epoch: 11500, eg: 0.5986, (elbo, recon, kl)=(62817.6484, 62309.9141, 412.0910)\n",
      "Epoch: 12000, eg: 0.5986, (elbo, recon, kl)=(62817.6523, 62309.9180, 412.0910)\n",
      "Epoch: 12500, eg: 0.5986, (elbo, recon, kl)=(62817.6523, 62309.9180, 412.0910)\n",
      "Epoch: 13000, eg: 0.5986, (elbo, recon, kl)=(62817.6523, 62309.9180, 412.0910)\n",
      "Epoch: 13500, eg: 0.5986, (elbo, recon, kl)=(62817.6484, 62309.9141, 412.0909)\n",
      "Epoch: 14000, eg: 0.5986, (elbo, recon, kl)=(62817.6523, 62309.9180, 412.0910)\n",
      "Epoch: 14500, eg: 0.5986, (elbo, recon, kl)=(62817.6523, 62309.9180, 412.0910)\n",
      "alpha: 2.40\n",
      "Epoch: 0, eg: 2.0543, (elbo, recon, kl)=(77154.2031, 76224.8125, 634.1207)\n",
      "Epoch: 500, eg: 1.6268, (elbo, recon, kl)=(76260.1250, 75586.6641, 495.5417)\n",
      "Epoch: 1000, eg: 1.4406, (elbo, recon, kl)=(76002.1016, 75437.3984, 442.4065)\n",
      "Epoch: 1500, eg: 1.3341, (elbo, recon, kl)=(75887.5859, 75386.4688, 411.8299)\n",
      "Epoch: 2000, eg: 1.2904, (elbo, recon, kl)=(75827.7188, 75358.8281, 398.8413)\n",
      "Epoch: 2500, eg: 1.2644, (elbo, recon, kl)=(75792.8828, 75332.5391, 398.5973)\n",
      "Epoch: 3000, eg: 1.2088, (elbo, recon, kl)=(75769.6406, 75297.1641, 409.8129)\n",
      "Epoch: 3500, eg: 1.1171, (elbo, recon, kl)=(75751.3125, 75252.0469, 429.3680)\n",
      "Epoch: 4000, eg: 0.9803, (elbo, recon, kl)=(75735.3281, 75204.8125, 451.1607)\n",
      "Epoch: 4500, eg: 0.8278, (elbo, recon, kl)=(75721.8906, 75163.8516, 470.0590)\n",
      "Epoch: 5000, eg: 0.7007, (elbo, recon, kl)=(75712.1250, 75133.6875, 483.8659)\n",
      "Epoch: 5500, eg: 0.6194, (elbo, recon, kl)=(75706.0938, 75114.2891, 492.7353)\n",
      "Epoch: 6000, eg: 0.5818, (elbo, recon, kl)=(75702.8125, 75103.0312, 497.9026)\n",
      "Epoch: 6500, eg: 0.5748, (elbo, recon, kl)=(75701.2031, 75097.1094, 500.6454)\n",
      "Epoch: 7000, eg: 0.5835, (elbo, recon, kl)=(75700.5312, 75094.3203, 501.9620)\n",
      "Epoch: 7500, eg: 0.5960, (elbo, recon, kl)=(75700.2891, 75093.1328, 502.5309)\n",
      "Epoch: 8000, eg: 0.6057, (elbo, recon, kl)=(75700.2188, 75092.6875, 502.7527)\n",
      "Epoch: 8500, eg: 0.6110, (elbo, recon, kl)=(75700.2031, 75092.5312, 502.8305)\n",
      "Epoch: 9000, eg: 0.6130, (elbo, recon, kl)=(75700.2109, 75092.5000, 502.8540)\n",
      "Epoch: 9500, eg: 0.6135, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8593)\n",
      "Epoch: 10000, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8600)\n",
      "Epoch: 10500, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8604)\n",
      "Epoch: 11000, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8602)\n",
      "Epoch: 11500, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8607)\n",
      "Epoch: 12000, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8603)\n",
      "Epoch: 12500, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8599)\n",
      "Epoch: 13000, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8598)\n",
      "Epoch: 13500, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8599)\n",
      "Epoch: 14000, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8603)\n",
      "Epoch: 14500, eg: 0.6136, (elbo, recon, kl)=(75700.2109, 75092.4844, 502.8599)\n",
      "Epoch: 0, eg: 1.8597, (elbo, recon, kl)=(76783.5547, 75924.1094, 596.3274)\n",
      "Epoch: 500, eg: 1.4312, (elbo, recon, kl)=(75974.3984, 75350.6250, 472.2261)\n",
      "Epoch: 1000, eg: 1.2153, (elbo, recon, kl)=(75737.3438, 75215.9766, 421.8268)\n",
      "Epoch: 1500, eg: 1.0801, (elbo, recon, kl)=(75635.2969, 75163.2891, 399.4361)\n",
      "Epoch: 2000, eg: 0.9911, (elbo, recon, kl)=(75585.8672, 75128.1484, 396.5523)\n",
      "Epoch: 2500, eg: 0.9231, (elbo, recon, kl)=(75558.4609, 75091.8359, 406.1267)\n",
      "Epoch: 3000, eg: 0.8610, (elbo, recon, kl)=(75540.3594, 75050.4297, 423.3405)\n",
      "Epoch: 3500, eg: 0.8022, (elbo, recon, kl)=(75526.8438, 75009.3125, 442.3871)\n",
      "Epoch: 4000, eg: 0.7548, (elbo, recon, kl)=(75516.9375, 74975.7344, 458.3510)\n",
      "Epoch: 4500, eg: 0.7266, (elbo, recon, kl)=(75510.6172, 74953.0703, 469.2103)\n",
      "Epoch: 5000, eg: 0.7165, (elbo, recon, kl)=(75507.1875, 74940.2266, 475.4094)\n",
      "Epoch: 5500, eg: 0.7179, (elbo, recon, kl)=(75505.5625, 74933.8750, 478.4975)\n",
      "Epoch: 6000, eg: 0.7251, (elbo, recon, kl)=(75504.8125, 74930.9688, 479.9195)\n",
      "Epoch: 6500, eg: 0.7343, (elbo, recon, kl)=(75504.4844, 74929.6719, 480.5599)\n",
      "Epoch: 7000, eg: 0.7427, (elbo, recon, kl)=(75504.3516, 74929.1094, 480.8487)\n",
      "Epoch: 7500, eg: 0.7490, (elbo, recon, kl)=(75504.2969, 74928.8594, 480.9763)\n",
      "Epoch: 8000, eg: 0.7529, (elbo, recon, kl)=(75504.2891, 74928.7734, 481.0295)\n",
      "Epoch: 8500, eg: 0.7548, (elbo, recon, kl)=(75504.2812, 74928.7266, 481.0508)\n",
      "Epoch: 9000, eg: 0.7555, (elbo, recon, kl)=(75504.2656, 74928.7109, 481.0586)\n",
      "Epoch: 9500, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0612)\n",
      "Epoch: 10000, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0619)\n",
      "Epoch: 10500, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0619)\n",
      "Epoch: 11000, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0620)\n",
      "Epoch: 11500, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0619)\n",
      "Epoch: 12000, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0620)\n",
      "Epoch: 12500, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0619)\n",
      "Epoch: 13000, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0620)\n",
      "Epoch: 13500, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0621)\n",
      "Epoch: 14000, eg: 0.7557, (elbo, recon, kl)=(75504.2812, 74928.7109, 481.0610)\n",
      "Epoch: 14500, eg: 0.7557, (elbo, recon, kl)=(75504.2734, 74928.7031, 481.0619)\n",
      "Epoch: 0, eg: 1.8754, (elbo, recon, kl)=(77062.0938, 76237.6797, 588.9257)\n",
      "Epoch: 500, eg: 1.4393, (elbo, recon, kl)=(76364.9766, 75767.6406, 463.8369)\n",
      "Epoch: 1000, eg: 1.2200, (elbo, recon, kl)=(76167.0469, 75667.0234, 413.1957)\n",
      "Epoch: 1500, eg: 1.0843, (elbo, recon, kl)=(76079.9531, 75622.0625, 394.0509)\n",
      "Epoch: 2000, eg: 0.9792, (elbo, recon, kl)=(76033.4844, 75577.6562, 398.3489)\n",
      "Epoch: 2500, eg: 0.8755, (elbo, recon, kl)=(76002.5547, 75519.8125, 419.4333)\n",
      "Epoch: 3000, eg: 0.7718, (elbo, recon, kl)=(75979.8203, 75457.6875, 446.9545)\n",
      "Epoch: 3500, eg: 0.6844, (elbo, recon, kl)=(75964.5156, 75408.4062, 469.6382)\n",
      "Epoch: 4000, eg: 0.6243, (elbo, recon, kl)=(75955.4922, 75376.6719, 484.3727)\n",
      "Epoch: 4500, eg: 0.5909, (elbo, recon, kl)=(75950.7969, 75358.6719, 492.8603)\n",
      "Epoch: 5000, eg: 0.5767, (elbo, recon, kl)=(75948.6562, 75349.5625, 497.2485)\n",
      "Epoch: 5500, eg: 0.5732, (elbo, recon, kl)=(75947.7812, 75345.5234, 499.2374)\n",
      "Epoch: 6000, eg: 0.5742, (elbo, recon, kl)=(75947.4844, 75343.9922, 500.0043)\n",
      "Epoch: 6500, eg: 0.5765, (elbo, recon, kl)=(75947.3750, 75343.5000, 500.2473)\n",
      "Epoch: 7000, eg: 0.5786, (elbo, recon, kl)=(75947.3438, 75343.3828, 500.3068)\n",
      "Epoch: 7500, eg: 0.5800, (elbo, recon, kl)=(75947.3359, 75343.3516, 500.3177)\n",
      "Epoch: 8000, eg: 0.5807, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3201)\n",
      "Epoch: 8500, eg: 0.5810, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3207)\n",
      "Epoch: 9000, eg: 0.5810, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3210)\n",
      "Epoch: 9500, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3214)\n",
      "Epoch: 10000, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3215)\n",
      "Epoch: 10500, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3212)\n",
      "Epoch: 11000, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3209)\n",
      "Epoch: 11500, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3215)\n",
      "Epoch: 12000, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3214)\n",
      "Epoch: 12500, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3210)\n",
      "Epoch: 13000, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3218)\n",
      "Epoch: 13500, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3221)\n",
      "Epoch: 14000, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3220)\n",
      "Epoch: 14500, eg: 0.5811, (elbo, recon, kl)=(75947.3281, 75343.3438, 500.3230)\n",
      "Epoch: 0, eg: 2.0548, (elbo, recon, kl)=(77183.0547, 76306.8203, 605.6117)\n",
      "Epoch: 500, eg: 1.5880, (elbo, recon, kl)=(76374.2891, 75738.5703, 478.4410)\n",
      "Epoch: 1000, eg: 1.3829, (elbo, recon, kl)=(76144.0000, 75612.0469, 426.1220)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 1500, eg: 1.2423, (elbo, recon, kl)=(76045.7109, 75570.6719, 397.7321)\n",
      "Epoch: 2000, eg: 1.1367, (elbo, recon, kl)=(75995.7500, 75544.2031, 388.8887)\n",
      "Epoch: 2500, eg: 1.0557, (elbo, recon, kl)=(75965.3906, 75510.5000, 395.7089)\n",
      "Epoch: 3000, eg: 0.9934, (elbo, recon, kl)=(75943.8438, 75464.9453, 414.4469)\n",
      "Epoch: 3500, eg: 0.9400, (elbo, recon, kl)=(75928.1328, 75419.4766, 435.6227)\n",
      "Epoch: 4000, eg: 0.8913, (elbo, recon, kl)=(75916.9688, 75383.4375, 452.7535)\n",
      "Epoch: 4500, eg: 0.8544, (elbo, recon, kl)=(75909.2344, 75357.2031, 465.2599)\n",
      "Epoch: 5000, eg: 0.8348, (elbo, recon, kl)=(75904.1172, 75339.5312, 473.6703)\n",
      "Epoch: 5500, eg: 0.8335, (elbo, recon, kl)=(75900.8516, 75328.4766, 478.8867)\n",
      "Epoch: 6000, eg: 0.8492, (elbo, recon, kl)=(75898.7891, 75321.6719, 482.0613)\n",
      "Epoch: 6500, eg: 0.8793, (elbo, recon, kl)=(75897.4219, 75317.3672, 484.0554)\n",
      "Epoch: 7000, eg: 0.9191, (elbo, recon, kl)=(75896.5234, 75314.6094, 485.3253)\n",
      "Epoch: 7500, eg: 0.9619, (elbo, recon, kl)=(75895.9688, 75312.9688, 486.0845)\n",
      "Epoch: 8000, eg: 1.0005, (elbo, recon, kl)=(75895.6875, 75312.1250, 486.4793)\n",
      "Epoch: 8500, eg: 1.0296, (elbo, recon, kl)=(75895.5859, 75311.7656, 486.6493)\n",
      "Epoch: 9000, eg: 1.0475, (elbo, recon, kl)=(75895.5547, 75311.6484, 486.7087)\n",
      "Epoch: 9500, eg: 1.0560, (elbo, recon, kl)=(75895.5469, 75311.6172, 486.7260)\n",
      "Epoch: 10000, eg: 1.0591, (elbo, recon, kl)=(75895.5391, 75311.6016, 486.7305)\n",
      "Epoch: 10500, eg: 1.0598, (elbo, recon, kl)=(75895.5469, 75311.6094, 486.7316)\n",
      "Epoch: 11000, eg: 1.0599, (elbo, recon, kl)=(75895.5469, 75311.6094, 486.7318)\n",
      "Epoch: 11500, eg: 1.0599, (elbo, recon, kl)=(75895.5469, 75311.6094, 486.7318)\n",
      "Epoch: 12000, eg: 1.0599, (elbo, recon, kl)=(75895.5469, 75311.6094, 486.7313)\n",
      "Epoch: 12500, eg: 1.0599, (elbo, recon, kl)=(75895.5469, 75311.6094, 486.7306)\n",
      "Epoch: 13000, eg: 1.0599, (elbo, recon, kl)=(75895.5469, 75311.6094, 486.7320)\n",
      "Epoch: 13500, eg: 1.0599, (elbo, recon, kl)=(75895.5391, 75311.6094, 486.7299)\n",
      "Epoch: 14000, eg: 1.0599, (elbo, recon, kl)=(75895.5469, 75311.6094, 486.7319)\n",
      "Epoch: 14500, eg: 1.0599, (elbo, recon, kl)=(75895.5469, 75311.6094, 486.7316)\n",
      "Epoch: 0, eg: 2.0063, (elbo, recon, kl)=(76745.8672, 75862.2266, 621.8212)\n",
      "Epoch: 500, eg: 1.5652, (elbo, recon, kl)=(75906.4297, 75282.1562, 476.4233)\n",
      "Epoch: 1000, eg: 1.3587, (elbo, recon, kl)=(75664.4609, 75152.5469, 415.7344)\n",
      "Epoch: 1500, eg: 1.2311, (elbo, recon, kl)=(75563.1562, 75111.1094, 384.7571)\n",
      "Epoch: 2000, eg: 1.1457, (elbo, recon, kl)=(75514.9375, 75089.0000, 373.8313)\n",
      "Epoch: 2500, eg: 1.0808, (elbo, recon, kl)=(75488.6562, 75064.3359, 376.8568)\n",
      "Epoch: 3000, eg: 1.0151, (elbo, recon, kl)=(75470.6562, 75026.7891, 392.1743)\n",
      "Epoch: 3500, eg: 0.9285, (elbo, recon, kl)=(75454.9609, 74976.7969, 416.2131)\n",
      "Epoch: 4000, eg: 0.8261, (elbo, recon, kl)=(75440.7812, 74925.7109, 441.3277)\n",
      "Epoch: 4500, eg: 0.7359, (elbo, recon, kl)=(75430.2031, 74886.5547, 460.4163)\n",
      "Epoch: 5000, eg: 0.6716, (elbo, recon, kl)=(75424.1172, 74863.2891, 471.6624)\n",
      "Epoch: 5500, eg: 0.6292, (elbo, recon, kl)=(75421.2422, 74851.7188, 477.2580)\n",
      "Epoch: 6000, eg: 0.6021, (elbo, recon, kl)=(75420.0391, 74846.5312, 479.7847)\n",
      "Epoch: 6500, eg: 0.5852, (elbo, recon, kl)=(75419.6016, 74844.4297, 480.8290)\n",
      "Epoch: 7000, eg: 0.5755, (elbo, recon, kl)=(75419.4531, 74843.6641, 481.2201)\n",
      "Epoch: 7500, eg: 0.5709, (elbo, recon, kl)=(75419.4219, 74843.4141, 481.3558)\n",
      "Epoch: 8000, eg: 0.5696, (elbo, recon, kl)=(75419.4062, 74843.3281, 481.4024)\n",
      "Epoch: 8500, eg: 0.5701, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4186)\n",
      "Epoch: 9000, eg: 0.5713, (elbo, recon, kl)=(75419.3906, 74843.2891, 481.4237)\n",
      "Epoch: 9500, eg: 0.5724, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4249)\n",
      "Epoch: 10000, eg: 0.5732, (elbo, recon, kl)=(75419.3828, 74843.2812, 481.4247)\n",
      "Epoch: 10500, eg: 0.5737, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4239)\n",
      "Epoch: 11000, eg: 0.5739, (elbo, recon, kl)=(75419.3906, 74843.2891, 481.4240)\n",
      "Epoch: 11500, eg: 0.5739, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4242)\n",
      "Epoch: 12000, eg: 0.5740, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4240)\n",
      "Epoch: 12500, eg: 0.5740, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4242)\n",
      "Epoch: 13000, eg: 0.5740, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4241)\n",
      "Epoch: 13500, eg: 0.5740, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4241)\n",
      "Epoch: 14000, eg: 0.5740, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4242)\n",
      "Epoch: 14500, eg: 0.5740, (elbo, recon, kl)=(75419.3984, 74843.2969, 481.4248)\n",
      "alpha: 2.80\n",
      "Epoch: 0, eg: 2.0198, (elbo, recon, kl)=(89701.2344, 88743.3750, 697.8486)\n",
      "Epoch: 500, eg: 1.6042, (elbo, recon, kl)=(88772.0547, 88080.0000, 543.9647)\n",
      "Epoch: 1000, eg: 1.4065, (elbo, recon, kl)=(88509.2969, 87924.2656, 485.5138)\n",
      "Epoch: 1500, eg: 1.2810, (elbo, recon, kl)=(88395.5859, 87863.6406, 457.8934)\n",
      "Epoch: 2000, eg: 1.1830, (elbo, recon, kl)=(88338.6562, 87826.9531, 450.3198)\n",
      "Epoch: 2500, eg: 1.0831, (elbo, recon, kl)=(88305.9922, 87791.8281, 456.0977)\n",
      "Epoch: 3000, eg: 0.9589, (elbo, recon, kl)=(88282.5547, 87745.8359, 474.1689)\n",
      "Epoch: 3500, eg: 0.8073, (elbo, recon, kl)=(88260.8125, 87685.8906, 502.2497)\n",
      "Epoch: 4000, eg: 0.6654, (elbo, recon, kl)=(88240.0938, 87623.1094, 532.4538)\n",
      "Epoch: 4500, eg: 0.5751, (elbo, recon, kl)=(88224.7031, 87574.8125, 555.5732)\n",
      "Epoch: 5000, eg: 0.5353, (elbo, recon, kl)=(88216.1797, 87546.2500, 569.2439)\n",
      "Epoch: 5500, eg: 0.5247, (elbo, recon, kl)=(88212.3750, 87532.0703, 576.1318)\n",
      "Epoch: 6000, eg: 0.5264, (elbo, recon, kl)=(88210.8984, 87525.8047, 579.2512)\n",
      "Epoch: 6500, eg: 0.5310, (elbo, recon, kl)=(88210.3672, 87523.2734, 580.5420)\n",
      "Epoch: 7000, eg: 0.5347, (elbo, recon, kl)=(88210.2031, 87522.3359, 581.0347)\n",
      "Epoch: 7500, eg: 0.5372, (elbo, recon, kl)=(88210.1641, 87522.0156, 581.2081)\n",
      "Epoch: 8000, eg: 0.5386, (elbo, recon, kl)=(88210.1562, 87521.9219, 581.2622)\n",
      "Epoch: 8500, eg: 0.5393, (elbo, recon, kl)=(88210.1406, 87521.8906, 581.2766)\n",
      "Epoch: 9000, eg: 0.5396, (elbo, recon, kl)=(88210.1406, 87521.8828, 581.2796)\n",
      "Epoch: 9500, eg: 0.5397, (elbo, recon, kl)=(88210.1328, 87521.8750, 581.2800)\n",
      "Epoch: 10000, eg: 0.5397, (elbo, recon, kl)=(88210.1406, 87521.8828, 581.2800)\n",
      "Epoch: 10500, eg: 0.5397, (elbo, recon, kl)=(88210.1406, 87521.8828, 581.2800)\n",
      "Epoch: 11000, eg: 0.5397, (elbo, recon, kl)=(88210.1406, 87521.8828, 581.2801)\n",
      "Epoch: 11500, eg: 0.5397, (elbo, recon, kl)=(88210.1328, 87521.8750, 581.2802)\n",
      "Epoch: 12000, eg: 0.5397, (elbo, recon, kl)=(88210.1406, 87521.8828, 581.2798)\n",
      "Epoch: 12500, eg: 0.5397, (elbo, recon, kl)=(88210.1406, 87521.8828, 581.2799)\n",
      "Epoch: 13000, eg: 0.5397, (elbo, recon, kl)=(88210.1406, 87521.8828, 581.2799)\n",
      "Epoch: 13500, eg: 0.5397, (elbo, recon, kl)=(88210.1328, 87521.8750, 581.2810)\n",
      "Epoch: 14000, eg: 0.5397, (elbo, recon, kl)=(88210.1406, 87521.8828, 581.2793)\n",
      "Epoch: 14500, eg: 0.5397, (elbo, recon, kl)=(88210.1406, 87521.8828, 581.2802)\n",
      "Epoch: 0, eg: 1.8978, (elbo, recon, kl)=(89466.2812, 88541.6016, 677.2634)\n",
      "Epoch: 500, eg: 1.5158, (elbo, recon, kl)=(88627.2031, 87950.8906, 538.9364)\n",
      "Epoch: 1000, eg: 1.3686, (elbo, recon, kl)=(88395.6797, 87820.3125, 484.9090)\n",
      "Epoch: 1500, eg: 1.3043, (elbo, recon, kl)=(88298.3047, 87770.7500, 460.2523)\n",
      "Epoch: 2000, eg: 1.2730, (elbo, recon, kl)=(88252.6953, 87738.4062, 456.1851)\n",
      "Epoch: 2500, eg: 1.2222, (elbo, recon, kl)=(88228.4297, 87705.9844, 464.5896)\n",
      "Epoch: 3000, eg: 1.1520, (elbo, recon, kl)=(88211.6328, 87665.1094, 482.5394)\n",
      "Epoch: 3500, eg: 1.0479, (elbo, recon, kl)=(88196.1953, 87614.3594, 507.4823)\n",
      "Epoch: 4000, eg: 0.9308, (elbo, recon, kl)=(88182.0938, 87565.0000, 532.0808)\n",
      "Epoch: 4500, eg: 0.8323, (elbo, recon, kl)=(88171.5859, 87529.4453, 549.5379)\n",
      "Epoch: 5000, eg: 0.7643, (elbo, recon, kl)=(88165.0312, 87508.0000, 559.8965)\n",
      "Epoch: 5500, eg: 0.7212, (elbo, recon, kl)=(88161.4297, 87496.0391, 565.6443)\n",
      "Epoch: 6000, eg: 0.6947, (elbo, recon, kl)=(88159.6875, 87489.6719, 568.7397)\n",
      "Epoch: 6500, eg: 0.6788, (elbo, recon, kl)=(88158.9141, 87486.4688, 570.3300)\n",
      "Epoch: 7000, eg: 0.6703, (elbo, recon, kl)=(88158.6094, 87485.0000, 571.0691)\n",
      "Epoch: 7500, eg: 0.6667, (elbo, recon, kl)=(88158.5078, 87484.4375, 571.3594)\n",
      "Epoch: 8000, eg: 0.6658, (elbo, recon, kl)=(88158.4688, 87484.2578, 571.4471)\n",
      "Epoch: 8500, eg: 0.6659, (elbo, recon, kl)=(88158.4609, 87484.2266, 571.4641)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 9000, eg: 0.6661, (elbo, recon, kl)=(88158.4609, 87484.2188, 571.4639)\n",
      "Epoch: 9500, eg: 0.6661, (elbo, recon, kl)=(88158.4688, 87484.2266, 571.4642)\n",
      "Epoch: 10000, eg: 0.6662, (elbo, recon, kl)=(88158.4688, 87484.2266, 571.4641)\n",
      "Epoch: 10500, eg: 0.6662, (elbo, recon, kl)=(88158.4688, 87484.2344, 571.4641)\n",
      "Epoch: 11000, eg: 0.6662, (elbo, recon, kl)=(88158.4766, 87484.2344, 571.4641)\n",
      "Epoch: 11500, eg: 0.6662, (elbo, recon, kl)=(88158.4688, 87484.2344, 571.4640)\n",
      "Epoch: 12000, eg: 0.6662, (elbo, recon, kl)=(88158.4688, 87484.2344, 571.4643)\n",
      "Epoch: 12500, eg: 0.6662, (elbo, recon, kl)=(88158.4766, 87484.2344, 571.4640)\n",
      "Epoch: 13000, eg: 0.6662, (elbo, recon, kl)=(88158.4688, 87484.2344, 571.4647)\n",
      "Epoch: 13500, eg: 0.6662, (elbo, recon, kl)=(88158.4766, 87484.2344, 571.4635)\n",
      "Epoch: 14000, eg: 0.6662, (elbo, recon, kl)=(88158.4766, 87484.2344, 571.4656)\n",
      "Epoch: 14500, eg: 0.6662, (elbo, recon, kl)=(88158.4766, 87484.2344, 571.4641)\n",
      "Epoch: 0, eg: 1.8457, (elbo, recon, kl)=(89675.2422, 88742.2422, 689.6138)\n",
      "Epoch: 500, eg: 1.4268, (elbo, recon, kl)=(88787.0938, 88119.1484, 536.1569)\n",
      "Epoch: 1000, eg: 1.2431, (elbo, recon, kl)=(88548.6328, 87990.2031, 473.5554)\n",
      "Epoch: 1500, eg: 1.1283, (elbo, recon, kl)=(88456.8047, 87949.6875, 445.5870)\n",
      "Epoch: 2000, eg: 1.0383, (elbo, recon, kl)=(88412.9844, 87918.1172, 442.2034)\n",
      "Epoch: 2500, eg: 0.9507, (elbo, recon, kl)=(88382.9609, 87863.2891, 462.5720)\n",
      "Epoch: 3000, eg: 0.8617, (elbo, recon, kl)=(88357.3047, 87786.7969, 499.4430)\n",
      "Epoch: 3500, eg: 0.7742, (elbo, recon, kl)=(88338.1328, 87722.6094, 531.1390)\n",
      "Epoch: 4000, eg: 0.6964, (elbo, recon, kl)=(88325.2812, 87681.0156, 551.1458)\n",
      "Epoch: 4500, eg: 0.6373, (elbo, recon, kl)=(88317.0938, 87655.0234, 563.4875)\n",
      "Epoch: 5000, eg: 0.5982, (elbo, recon, kl)=(88312.2500, 87639.1094, 571.1002)\n",
      "Epoch: 5500, eg: 0.5745, (elbo, recon, kl)=(88309.6562, 87629.9844, 575.5500)\n",
      "Epoch: 6000, eg: 0.5607, (elbo, recon, kl)=(88308.3594, 87625.1484, 577.9333)\n",
      "Epoch: 6500, eg: 0.5528, (elbo, recon, kl)=(88307.7109, 87622.7188, 579.1272)\n",
      "Epoch: 7000, eg: 0.5487, (elbo, recon, kl)=(88307.3984, 87621.4922, 579.7244)\n",
      "Epoch: 7500, eg: 0.5471, (elbo, recon, kl)=(88307.2578, 87620.8594, 580.0401)\n",
      "Epoch: 8000, eg: 0.5468, (elbo, recon, kl)=(88307.2031, 87620.5156, 580.2135)\n",
      "Epoch: 8500, eg: 0.5469, (elbo, recon, kl)=(88307.1875, 87620.3438, 580.3036)\n",
      "Epoch: 9000, eg: 0.5470, (elbo, recon, kl)=(88307.1797, 87620.2656, 580.3432)\n",
      "Epoch: 9500, eg: 0.5470, (elbo, recon, kl)=(88307.1875, 87620.2500, 580.3564)\n",
      "Epoch: 10000, eg: 0.5470, (elbo, recon, kl)=(88307.1797, 87620.2422, 580.3594)\n",
      "Epoch: 10500, eg: 0.5470, (elbo, recon, kl)=(88307.1719, 87620.2344, 580.3603)\n",
      "Epoch: 11000, eg: 0.5470, (elbo, recon, kl)=(88307.1719, 87620.2344, 580.3604)\n",
      "Epoch: 11500, eg: 0.5470, (elbo, recon, kl)=(88307.1719, 87620.2344, 580.3597)\n",
      "Epoch: 12000, eg: 0.5470, (elbo, recon, kl)=(88307.1719, 87620.2344, 580.3601)\n",
      "Epoch: 12500, eg: 0.5470, (elbo, recon, kl)=(88307.1875, 87620.2500, 580.3605)\n",
      "Epoch: 13000, eg: 0.5470, (elbo, recon, kl)=(88307.1875, 87620.2500, 580.3602)\n",
      "Epoch: 13500, eg: 0.5470, (elbo, recon, kl)=(88307.1719, 87620.2344, 580.3602)\n",
      "Epoch: 14000, eg: 0.5470, (elbo, recon, kl)=(88307.1719, 87620.2344, 580.3604)\n",
      "Epoch: 14500, eg: 0.5470, (elbo, recon, kl)=(88307.1719, 87620.2344, 580.3601)\n",
      "Epoch: 0, eg: 1.8658, (elbo, recon, kl)=(89746.0078, 88805.2109, 687.2606)\n",
      "Epoch: 500, eg: 1.4437, (elbo, recon, kl)=(88917.2969, 88230.3828, 545.3630)\n",
      "Epoch: 1000, eg: 1.2784, (elbo, recon, kl)=(88688.8984, 88109.0938, 486.4834)\n",
      "Epoch: 1500, eg: 1.2013, (elbo, recon, kl)=(88596.1406, 88069.8125, 458.3281)\n",
      "Epoch: 2000, eg: 1.1969, (elbo, recon, kl)=(88550.9141, 88041.4297, 452.5492)\n",
      "Epoch: 2500, eg: 1.2726, (elbo, recon, kl)=(88523.0625, 88000.9219, 464.7413)\n",
      "Epoch: 3000, eg: 1.2909, (elbo, recon, kl)=(88502.2500, 87947.6172, 488.7733)\n",
      "Epoch: 3500, eg: 1.2458, (elbo, recon, kl)=(88487.1719, 87898.1562, 512.8580)\n",
      "Epoch: 4000, eg: 1.1732, (elbo, recon, kl)=(88477.2891, 87862.7656, 530.3780)\n",
      "Epoch: 4500, eg: 1.0827, (elbo, recon, kl)=(88470.9062, 87839.7344, 541.7827)\n",
      "Epoch: 5000, eg: 0.9856, (elbo, recon, kl)=(88466.4141, 87824.2266, 549.3841)\n",
      "Epoch: 5500, eg: 0.8924, (elbo, recon, kl)=(88462.9219, 87812.6797, 554.9537)\n",
      "Epoch: 6000, eg: 0.8129, (elbo, recon, kl)=(88460.1719, 87803.6094, 559.3010)\n",
      "Epoch: 6500, eg: 0.7545, (elbo, recon, kl)=(88458.1328, 87796.7812, 562.5707)\n",
      "Epoch: 7000, eg: 0.7182, (elbo, recon, kl)=(88456.7812, 87792.2031, 564.7706)\n",
      "Epoch: 7500, eg: 0.6995, (elbo, recon, kl)=(88456.0000, 87789.5234, 566.0621)\n",
      "Epoch: 8000, eg: 0.6919, (elbo, recon, kl)=(88455.6094, 87788.1797, 566.7155)\n",
      "Epoch: 8500, eg: 0.6895, (elbo, recon, kl)=(88455.4609, 87787.6094, 566.9980)\n",
      "Epoch: 9000, eg: 0.6888, (elbo, recon, kl)=(88455.4062, 87787.4062, 567.1028)\n",
      "Epoch: 9500, eg: 0.6886, (elbo, recon, kl)=(88455.4062, 87787.3438, 567.1369)\n",
      "Epoch: 10000, eg: 0.6884, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1464)\n",
      "Epoch: 10500, eg: 0.6883, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1489)\n",
      "Epoch: 11000, eg: 0.6883, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1492)\n",
      "Epoch: 11500, eg: 0.6883, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1491)\n",
      "Epoch: 12000, eg: 0.6883, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1493)\n",
      "Epoch: 12500, eg: 0.6883, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1495)\n",
      "Epoch: 13000, eg: 0.6883, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1488)\n",
      "Epoch: 13500, eg: 0.6883, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1493)\n",
      "Epoch: 14000, eg: 0.6883, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1494)\n",
      "Epoch: 14500, eg: 0.6883, (elbo, recon, kl)=(88455.4062, 87787.3281, 567.1494)\n",
      "Epoch: 0, eg: 1.8325, (elbo, recon, kl)=(89293.8828, 88268.9453, 777.5159)\n",
      "Epoch: 500, eg: 1.4675, (elbo, recon, kl)=(88409.2812, 87670.2422, 594.3934)\n",
      "Epoch: 1000, eg: 1.2989, (elbo, recon, kl)=(88156.5859, 87543.1250, 515.3260)\n",
      "Epoch: 1500, eg: 1.1863, (elbo, recon, kl)=(88044.0703, 87492.5469, 478.4407)\n",
      "Epoch: 2000, eg: 1.1054, (elbo, recon, kl)=(87984.3828, 87450.1641, 470.8906)\n",
      "Epoch: 2500, eg: 1.0332, (elbo, recon, kl)=(87948.3984, 87401.0312, 482.6097)\n",
      "Epoch: 3000, eg: 0.9509, (elbo, recon, kl)=(87924.4688, 87349.3906, 503.0683)\n",
      "Epoch: 3500, eg: 0.8558, (elbo, recon, kl)=(87907.7109, 87304.6406, 522.9141)\n",
      "Epoch: 4000, eg: 0.7606, (elbo, recon, kl)=(87895.8750, 87270.0234, 538.6918)\n",
      "Epoch: 4500, eg: 0.6796, (elbo, recon, kl)=(87887.7891, 87244.9453, 550.2404)\n",
      "Epoch: 5000, eg: 0.6191, (elbo, recon, kl)=(87882.5625, 87228.1172, 558.0278)\n",
      "Epoch: 5500, eg: 0.5791, (elbo, recon, kl)=(87879.2812, 87217.6328, 562.8680)\n",
      "Epoch: 6000, eg: 0.5570, (elbo, recon, kl)=(87877.3828, 87211.5781, 565.6649)\n",
      "Epoch: 6500, eg: 0.5481, (elbo, recon, kl)=(87876.3906, 87208.3828, 567.1501)\n",
      "Epoch: 7000, eg: 0.5469, (elbo, recon, kl)=(87875.9375, 87206.8984, 567.8453)\n",
      "Epoch: 7500, eg: 0.5486, (elbo, recon, kl)=(87875.7656, 87206.3203, 568.1166)\n",
      "Epoch: 8000, eg: 0.5504, (elbo, recon, kl)=(87875.7188, 87206.1406, 568.1994)\n",
      "Epoch: 8500, eg: 0.5515, (elbo, recon, kl)=(87875.7109, 87206.1094, 568.2162)\n",
      "Epoch: 9000, eg: 0.5519, (elbo, recon, kl)=(87875.7031, 87206.1016, 568.2162)\n",
      "Epoch: 9500, eg: 0.5520, (elbo, recon, kl)=(87875.7031, 87206.1094, 568.2145)\n",
      "Epoch: 10000, eg: 0.5520, (elbo, recon, kl)=(87875.7031, 87206.1094, 568.2136)\n",
      "Epoch: 10500, eg: 0.5520, (elbo, recon, kl)=(87875.7031, 87206.1094, 568.2137)\n",
      "Epoch: 11000, eg: 0.5520, (elbo, recon, kl)=(87875.7031, 87206.1094, 568.2135)\n",
      "Epoch: 11500, eg: 0.5520, (elbo, recon, kl)=(87875.7031, 87206.1094, 568.2136)\n",
      "Epoch: 12000, eg: 0.5520, (elbo, recon, kl)=(87875.6953, 87206.1016, 568.2140)\n",
      "Epoch: 12500, eg: 0.5520, (elbo, recon, kl)=(87875.7031, 87206.1094, 568.2136)\n",
      "Epoch: 13000, eg: 0.5520, (elbo, recon, kl)=(87875.7031, 87206.1094, 568.2134)\n",
      "Epoch: 13500, eg: 0.5520, (elbo, recon, kl)=(87875.7031, 87206.1094, 568.2134)\n",
      "Epoch: 14000, eg: 0.5520, (elbo, recon, kl)=(87875.7031, 87206.1094, 568.2123)\n",
      "Epoch: 14500, eg: 0.5520, (elbo, recon, kl)=(87875.6953, 87206.0938, 568.2156)\n",
      "alpha: 3.20\n",
      "Epoch: 0, eg: 2.0162, (elbo, recon, kl)=(102475.4609, 101351.0469, 848.9390)\n",
      "Epoch: 500, eg: 1.5827, (elbo, recon, kl)=(101401.9297, 100580.7891, 660.0616)\n",
      "Epoch: 1000, eg: 1.4030, (elbo, recon, kl)=(101091.9922, 100394.2578, 585.7137)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 1500, eg: 1.3072, (elbo, recon, kl)=(100956.2812, 100318.0312, 551.6177)\n",
      "Epoch: 2000, eg: 1.2720, (elbo, recon, kl)=(100885.6172, 100263.1797, 546.6693)\n",
      "Epoch: 2500, eg: 1.2828, (elbo, recon, kl)=(100844.2422, 100212.1172, 557.7332)\n",
      "Epoch: 3000, eg: 1.3234, (elbo, recon, kl)=(100817.8438, 100165.2422, 574.7354)\n",
      "Epoch: 3500, eg: 1.3854, (elbo, recon, kl)=(100800.3359, 100125.9453, 591.5073)\n",
      "Epoch: 4000, eg: 1.4750, (elbo, recon, kl)=(100788.5156, 100095.0625, 605.6557)\n",
      "Epoch: 4500, eg: 1.4721, (elbo, recon, kl)=(100779.6719, 100069.9141, 617.5290)\n",
      "Epoch: 5000, eg: 1.3182, (elbo, recon, kl)=(100771.3828, 100045.6562, 629.0754)\n",
      "Epoch: 5500, eg: 1.0971, (elbo, recon, kl)=(100762.3203, 100019.5156, 641.4431)\n",
      "Epoch: 6000, eg: 0.8742, (elbo, recon, kl)=(100753.9531, 99995.7969, 652.5553)\n",
      "Epoch: 6500, eg: 0.7112, (elbo, recon, kl)=(100748.4844, 99980.2500, 659.7991)\n",
      "Epoch: 7000, eg: 0.6153, (elbo, recon, kl)=(100745.8516, 99972.5938, 663.3627)\n",
      "Epoch: 7500, eg: 0.5659, (elbo, recon, kl)=(100744.8516, 99969.4531, 664.8451)\n",
      "Epoch: 8000, eg: 0.5430, (elbo, recon, kl)=(100744.5703, 99968.2891, 665.4254)\n",
      "Epoch: 8500, eg: 0.5336, (elbo, recon, kl)=(100744.5156, 99967.8594, 665.6537)\n",
      "Epoch: 9000, eg: 0.5305, (elbo, recon, kl)=(100744.4922, 99967.7031, 665.7399)\n",
      "Epoch: 9500, eg: 0.5296, (elbo, recon, kl)=(100744.5078, 99967.6641, 665.7665)\n",
      "Epoch: 10000, eg: 0.5295, (elbo, recon, kl)=(100744.5156, 99967.6641, 665.7720)\n",
      "Epoch: 10500, eg: 0.5295, (elbo, recon, kl)=(100744.5000, 99967.6484, 665.7728)\n",
      "Epoch: 11000, eg: 0.5295, (elbo, recon, kl)=(100744.5000, 99967.6484, 665.7726)\n",
      "Epoch: 11500, eg: 0.5295, (elbo, recon, kl)=(100744.5000, 99967.6484, 665.7726)\n",
      "Epoch: 12000, eg: 0.5295, (elbo, recon, kl)=(100744.5000, 99967.6484, 665.7728)\n",
      "Epoch: 12500, eg: 0.5295, (elbo, recon, kl)=(100744.5000, 99967.6484, 665.7729)\n",
      "Epoch: 13000, eg: 0.5295, (elbo, recon, kl)=(100744.5000, 99967.6484, 665.7729)\n",
      "Epoch: 13500, eg: 0.5295, (elbo, recon, kl)=(100744.5000, 99967.6484, 665.7719)\n",
      "Epoch: 14000, eg: 0.5295, (elbo, recon, kl)=(100744.5000, 99967.6484, 665.7725)\n",
      "Epoch: 14500, eg: 0.5295, (elbo, recon, kl)=(100744.5000, 99967.6484, 665.7729)\n",
      "Epoch: 0, eg: 2.0048, (elbo, recon, kl)=(102369.4766, 101385.1641, 748.0231)\n",
      "Epoch: 500, eg: 1.5205, (elbo, recon, kl)=(101430.4297, 100701.9531, 596.9794)\n",
      "Epoch: 1000, eg: 1.3008, (elbo, recon, kl)=(101177.0781, 100545.8047, 542.3299)\n",
      "Epoch: 1500, eg: 1.1489, (elbo, recon, kl)=(101070.2812, 100483.0547, 519.3121)\n",
      "Epoch: 2000, eg: 1.0281, (elbo, recon, kl)=(101016.3281, 100434.9375, 521.1349)\n",
      "Epoch: 2500, eg: 0.9220, (elbo, recon, kl)=(100982.9297, 100376.9531, 542.4040)\n",
      "Epoch: 3000, eg: 0.8258, (elbo, recon, kl)=(100957.7500, 100308.3125, 575.3423)\n",
      "Epoch: 3500, eg: 0.7486, (elbo, recon, kl)=(100938.7109, 100246.3750, 606.5111)\n",
      "Epoch: 4000, eg: 0.6983, (elbo, recon, kl)=(100926.3516, 100203.6953, 627.9482)\n",
      "Epoch: 4500, eg: 0.6712, (elbo, recon, kl)=(100919.4688, 100179.0391, 640.2579)\n",
      "Epoch: 5000, eg: 0.6597, (elbo, recon, kl)=(100916.0234, 100166.1953, 646.6718)\n",
      "Epoch: 5500, eg: 0.6567, (elbo, recon, kl)=(100914.4844, 100160.1172, 649.7306)\n",
      "Epoch: 6000, eg: 0.6574, (elbo, recon, kl)=(100913.8359, 100157.5391, 651.0327)\n",
      "Epoch: 6500, eg: 0.6592, (elbo, recon, kl)=(100913.5703, 100156.5625, 651.5193)\n",
      "Epoch: 7000, eg: 0.6608, (elbo, recon, kl)=(100913.5000, 100156.2500, 651.6801)\n",
      "Epoch: 7500, eg: 0.6618, (elbo, recon, kl)=(100913.4844, 100156.1562, 651.7281)\n",
      "Epoch: 8000, eg: 0.6623, (elbo, recon, kl)=(100913.4844, 100156.1328, 651.7412)\n",
      "Epoch: 8500, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7449)\n",
      "Epoch: 9000, eg: 0.6624, (elbo, recon, kl)=(100913.4766, 100156.1250, 651.7458)\n",
      "Epoch: 9500, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7457)\n",
      "Epoch: 10000, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7460)\n",
      "Epoch: 10500, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7460)\n",
      "Epoch: 11000, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7460)\n",
      "Epoch: 11500, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7452)\n",
      "Epoch: 12000, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7459)\n",
      "Epoch: 12500, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7456)\n",
      "Epoch: 13000, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7455)\n",
      "Epoch: 13500, eg: 0.6624, (elbo, recon, kl)=(100913.4766, 100156.1172, 651.7465)\n",
      "Epoch: 14000, eg: 0.6624, (elbo, recon, kl)=(100913.4688, 100156.1172, 651.7457)\n",
      "Epoch: 14500, eg: 0.6624, (elbo, recon, kl)=(100913.4766, 100156.1250, 651.7458)\n",
      "Epoch: 0, eg: 1.7545, (elbo, recon, kl)=(102185.9062, 101161.4609, 794.5092)\n",
      "Epoch: 500, eg: 1.4240, (elbo, recon, kl)=(101302.5469, 100551.5156, 621.6127)\n",
      "Epoch: 1000, eg: 1.2819, (elbo, recon, kl)=(101062.6797, 100425.4922, 551.4501)\n",
      "Epoch: 1500, eg: 1.1868, (elbo, recon, kl)=(100964.2500, 100379.3984, 521.0332)\n",
      "Epoch: 2000, eg: 1.1180, (elbo, recon, kl)=(100916.0312, 100343.4922, 516.6354)\n",
      "Epoch: 2500, eg: 1.0411, (elbo, recon, kl)=(100885.5703, 100293.3516, 533.2117)\n",
      "Epoch: 3000, eg: 0.9256, (elbo, recon, kl)=(100858.6719, 100218.0703, 569.2146)\n",
      "Epoch: 3500, eg: 0.7883, (elbo, recon, kl)=(100835.0625, 100139.0391, 609.3190)\n",
      "Epoch: 4000, eg: 0.6677, (elbo, recon, kl)=(100819.1172, 100085.4688, 635.9990)\n",
      "Epoch: 4500, eg: 0.5837, (elbo, recon, kl)=(100810.1797, 100056.2109, 650.1415)\n",
      "Epoch: 5000, eg: 0.5350, (elbo, recon, kl)=(100805.7344, 100041.7188, 657.0250)\n",
      "Epoch: 5500, eg: 0.5107, (elbo, recon, kl)=(100803.8203, 100035.0625, 660.2090)\n",
      "Epoch: 6000, eg: 0.5000, (elbo, recon, kl)=(100803.1250, 100032.1953, 661.6389)\n",
      "Epoch: 6500, eg: 0.4955, (elbo, recon, kl)=(100802.9141, 100031.0000, 662.2720)\n",
      "Epoch: 7000, eg: 0.4936, (elbo, recon, kl)=(100802.8594, 100030.5156, 662.5498)\n",
      "Epoch: 7500, eg: 0.4927, (elbo, recon, kl)=(100802.8594, 100030.3281, 662.6690)\n",
      "Epoch: 8000, eg: 0.4924, (elbo, recon, kl)=(100802.8438, 100030.2422, 662.7172)\n",
      "Epoch: 8500, eg: 0.4923, (elbo, recon, kl)=(100802.8516, 100030.2266, 662.7339)\n",
      "Epoch: 9000, eg: 0.4922, (elbo, recon, kl)=(100802.8438, 100030.2188, 662.7380)\n",
      "Epoch: 9500, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7389)\n",
      "Epoch: 10000, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7390)\n",
      "Epoch: 10500, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7390)\n",
      "Epoch: 11000, eg: 0.4922, (elbo, recon, kl)=(100802.8438, 100030.2188, 662.7383)\n",
      "Epoch: 11500, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7388)\n",
      "Epoch: 12000, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7391)\n",
      "Epoch: 12500, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7391)\n",
      "Epoch: 13000, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7388)\n",
      "Epoch: 13500, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7391)\n",
      "Epoch: 14000, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7402)\n",
      "Epoch: 14500, eg: 0.4922, (elbo, recon, kl)=(100802.8516, 100030.2188, 662.7392)\n",
      "Epoch: 0, eg: 1.9114, (elbo, recon, kl)=(102641.9766, 101582.8281, 810.8727)\n",
      "Epoch: 500, eg: 1.5436, (elbo, recon, kl)=(101619.9062, 100841.0469, 634.8622)\n",
      "Epoch: 1000, eg: 1.4139, (elbo, recon, kl)=(101339.3516, 100671.2891, 568.0977)\n",
      "Epoch: 1500, eg: 1.3462, (elbo, recon, kl)=(101225.5156, 100610.4141, 538.2521)\n",
      "Epoch: 2000, eg: 1.3192, (elbo, recon, kl)=(101170.8828, 100572.9531, 531.6705)\n",
      "Epoch: 2500, eg: 1.3303, (elbo, recon, kl)=(101140.5703, 100536.7266, 539.3167)\n",
      "Epoch: 3000, eg: 1.3486, (elbo, recon, kl)=(101121.9062, 100499.0781, 554.6013)\n",
      "Epoch: 3500, eg: 1.3592, (elbo, recon, kl)=(101110.1016, 100465.5625, 570.7906)\n",
      "Epoch: 4000, eg: 1.3453, (elbo, recon, kl)=(101102.5078, 100439.9844, 583.8325)\n",
      "Epoch: 4500, eg: 1.2960, (elbo, recon, kl)=(101097.2734, 100421.5156, 593.3328)\n",
      "Epoch: 5000, eg: 1.1973, (elbo, recon, kl)=(101092.8750, 100406.4766, 600.9764)\n",
      "Epoch: 5500, eg: 1.0297, (elbo, recon, kl)=(101087.4375, 100389.0469, 609.6294)\n",
      "Epoch: 6000, eg: 0.8075, (elbo, recon, kl)=(101079.0078, 100363.2422, 622.1652)\n",
      "Epoch: 6500, eg: 0.6247, (elbo, recon, kl)=(101070.0391, 100335.9531, 635.2754)\n",
      "Epoch: 7000, eg: 0.5324, (elbo, recon, kl)=(101064.6562, 100319.6094, 643.0898)\n",
      "Epoch: 7500, eg: 0.4980, (elbo, recon, kl)=(101062.5234, 100312.8750, 646.3372)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 8000, eg: 0.4880, (elbo, recon, kl)=(101061.8984, 100310.5625, 647.4899)\n",
      "Epoch: 8500, eg: 0.4858, (elbo, recon, kl)=(101061.7812, 100309.8516, 647.8767)\n",
      "Epoch: 9000, eg: 0.4856, (elbo, recon, kl)=(101061.7500, 100309.6172, 648.0035)\n",
      "Epoch: 9500, eg: 0.4856, (elbo, recon, kl)=(101061.7656, 100309.5703, 648.0403)\n",
      "Epoch: 10000, eg: 0.4856, (elbo, recon, kl)=(101061.7578, 100309.5469, 648.0482)\n",
      "Epoch: 10500, eg: 0.4856, (elbo, recon, kl)=(101061.7578, 100309.5469, 648.0494)\n",
      "Epoch: 11000, eg: 0.4856, (elbo, recon, kl)=(101061.7500, 100309.5391, 648.0495)\n",
      "Epoch: 11500, eg: 0.4856, (elbo, recon, kl)=(101061.7500, 100309.5391, 648.0495)\n",
      "Epoch: 12000, eg: 0.4856, (elbo, recon, kl)=(101061.7500, 100309.5391, 648.0493)\n",
      "Epoch: 12500, eg: 0.4856, (elbo, recon, kl)=(101061.7578, 100309.5469, 648.0494)\n",
      "Epoch: 13000, eg: 0.4856, (elbo, recon, kl)=(101061.7500, 100309.5391, 648.0495)\n",
      "Epoch: 13500, eg: 0.4856, (elbo, recon, kl)=(101061.7578, 100309.5469, 648.0494)\n",
      "Epoch: 14000, eg: 0.4856, (elbo, recon, kl)=(101061.7500, 100309.5391, 648.0493)\n",
      "Epoch: 14500, eg: 0.4856, (elbo, recon, kl)=(101061.7500, 100309.5391, 648.0502)\n",
      "Epoch: 0, eg: 1.9067, (elbo, recon, kl)=(101881.5625, 100739.7969, 878.4462)\n",
      "Epoch: 500, eg: 1.5529, (elbo, recon, kl)=(100792.3125, 99963.6562, 676.8060)\n",
      "Epoch: 1000, eg: 1.3657, (elbo, recon, kl)=(100483.1094, 99791.0938, 589.0251)\n",
      "Epoch: 1500, eg: 1.2455, (elbo, recon, kl)=(100362.9375, 99738.9375, 546.3412)\n",
      "Epoch: 2000, eg: 1.1617, (elbo, recon, kl)=(100308.9062, 99711.6094, 531.7277)\n",
      "Epoch: 2500, eg: 1.0872, (elbo, recon, kl)=(100278.6328, 99681.0156, 535.0087)\n",
      "Epoch: 3000, eg: 1.0001, (elbo, recon, kl)=(100256.8594, 99639.3750, 551.0955)\n",
      "Epoch: 3500, eg: 0.8865, (elbo, recon, kl)=(100238.3359, 99589.6328, 574.4180)\n",
      "Epoch: 4000, eg: 0.7570, (elbo, recon, kl)=(100222.0938, 99539.7422, 598.8515)\n",
      "Epoch: 4500, eg: 0.6419, (elbo, recon, kl)=(100209.4609, 99498.9766, 618.9213)\n",
      "Epoch: 5000, eg: 0.5623, (elbo, recon, kl)=(100201.3594, 99472.1172, 632.1345)\n",
      "Epoch: 5500, eg: 0.5181, (elbo, recon, kl)=(100197.0703, 99457.4844, 639.3339)\n",
      "Epoch: 6000, eg: 0.4980, (elbo, recon, kl)=(100195.1875, 99450.6797, 642.7014)\n",
      "Epoch: 6500, eg: 0.4909, (elbo, recon, kl)=(100194.5078, 99447.9766, 644.0575)\n",
      "Epoch: 7000, eg: 0.4890, (elbo, recon, kl)=(100194.3438, 99447.0938, 644.5182)\n",
      "Epoch: 7500, eg: 0.4888, (elbo, recon, kl)=(100194.3125, 99446.8359, 644.6503)\n",
      "Epoch: 8000, eg: 0.4888, (elbo, recon, kl)=(100194.3125, 99446.7812, 644.6829)\n",
      "Epoch: 8500, eg: 0.4889, (elbo, recon, kl)=(100194.3047, 99446.7656, 644.6895)\n",
      "Epoch: 9000, eg: 0.4889, (elbo, recon, kl)=(100194.3047, 99446.7656, 644.6904)\n",
      "Epoch: 9500, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7578, 644.6906)\n",
      "Epoch: 10000, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7578, 644.6906)\n",
      "Epoch: 10500, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7578, 644.6907)\n",
      "Epoch: 11000, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7578, 644.6906)\n",
      "Epoch: 11500, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7578, 644.6904)\n",
      "Epoch: 12000, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7578, 644.6905)\n",
      "Epoch: 12500, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7578, 644.6904)\n",
      "Epoch: 13000, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7500, 644.6929)\n",
      "Epoch: 13500, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7578, 644.6906)\n",
      "Epoch: 14000, eg: 0.4889, (elbo, recon, kl)=(100194.3047, 99446.7656, 644.6874)\n",
      "Epoch: 14500, eg: 0.4889, (elbo, recon, kl)=(100194.2969, 99446.7578, 644.6903)\n",
      "alpha: 3.60\n",
      "Epoch: 0, eg: 1.6829, (elbo, recon, kl)=(114865.0781, 113773.6406, 852.7884)\n",
      "Epoch: 500, eg: 1.3007, (elbo, recon, kl)=(113889.0312, 113064.7344, 687.8448)\n",
      "Epoch: 1000, eg: 1.1025, (elbo, recon, kl)=(113625.6719, 112906.6953, 624.6881)\n",
      "Epoch: 1500, eg: 0.9551, (elbo, recon, kl)=(113512.9922, 112836.2969, 601.9123)\n",
      "Epoch: 2000, eg: 0.8178, (elbo, recon, kl)=(113450.7266, 112765.3516, 614.0051)\n",
      "Epoch: 2500, eg: 0.6871, (elbo, recon, kl)=(113405.9062, 112675.4375, 650.5933)\n",
      "Epoch: 3000, eg: 0.5845, (elbo, recon, kl)=(113371.1484, 112588.0547, 690.9717)\n",
      "Epoch: 3500, eg: 0.5210, (elbo, recon, kl)=(113346.6719, 112523.2734, 721.1211)\n",
      "Epoch: 4000, eg: 0.4900, (elbo, recon, kl)=(113331.7109, 112482.3125, 740.1226)\n",
      "Epoch: 4500, eg: 0.4790, (elbo, recon, kl)=(113323.8516, 112459.2031, 750.9990)\n",
      "Epoch: 5000, eg: 0.4778, (elbo, recon, kl)=(113320.3359, 112447.4688, 756.7018)\n",
      "Epoch: 5500, eg: 0.4798, (elbo, recon, kl)=(113318.9922, 112442.1562, 759.3732)\n",
      "Epoch: 6000, eg: 0.4816, (elbo, recon, kl)=(113318.5469, 112440.0547, 760.4642)\n",
      "Epoch: 6500, eg: 0.4825, (elbo, recon, kl)=(113318.4297, 112439.3281, 760.8463)\n",
      "Epoch: 7000, eg: 0.4828, (elbo, recon, kl)=(113318.4141, 112439.1250, 760.9602)\n",
      "Epoch: 7500, eg: 0.4828, (elbo, recon, kl)=(113318.4141, 112439.0625, 760.9884)\n",
      "Epoch: 8000, eg: 0.4828, (elbo, recon, kl)=(113318.3984, 112439.0469, 760.9946)\n",
      "Epoch: 8500, eg: 0.4828, (elbo, recon, kl)=(113318.3984, 112439.0469, 760.9957)\n",
      "Epoch: 9000, eg: 0.4828, (elbo, recon, kl)=(113318.3984, 112439.0469, 760.9958)\n",
      "Epoch: 9500, eg: 0.4828, (elbo, recon, kl)=(113318.3984, 112439.0469, 760.9959)\n",
      "Epoch: 10000, eg: 0.4828, (elbo, recon, kl)=(113318.3984, 112439.0391, 760.9962)\n",
      "Epoch: 10500, eg: 0.4828, (elbo, recon, kl)=(113318.3906, 112439.0391, 760.9960)\n",
      "Epoch: 11000, eg: 0.4828, (elbo, recon, kl)=(113318.3906, 112439.0391, 760.9955)\n",
      "Epoch: 11500, eg: 0.4828, (elbo, recon, kl)=(113318.3984, 112439.0469, 760.9957)\n",
      "Epoch: 12000, eg: 0.4828, (elbo, recon, kl)=(113318.3984, 112439.0469, 760.9959)\n",
      "Epoch: 12500, eg: 0.4828, (elbo, recon, kl)=(113318.3906, 112439.0391, 760.9951)\n",
      "Epoch: 13000, eg: 0.4828, (elbo, recon, kl)=(113318.3906, 112439.0391, 760.9956)\n",
      "Epoch: 13500, eg: 0.4828, (elbo, recon, kl)=(113318.3984, 112439.0469, 760.9954)\n",
      "Epoch: 14000, eg: 0.4828, (elbo, recon, kl)=(113318.4062, 112439.0469, 760.9965)\n",
      "Epoch: 14500, eg: 0.4828, (elbo, recon, kl)=(113318.3984, 112439.0391, 760.9973)\n",
      "Epoch: 0, eg: 1.9500, (elbo, recon, kl)=(115378.0234, 114171.6953, 949.8009)\n",
      "Epoch: 500, eg: 1.4927, (elbo, recon, kl)=(114179.7109, 113311.2578, 724.3804)\n",
      "Epoch: 1000, eg: 1.2618, (elbo, recon, kl)=(113828.8359, 113099.6406, 633.0211)\n",
      "Epoch: 1500, eg: 1.1020, (elbo, recon, kl)=(113683.7656, 113010.8047, 598.9165)\n",
      "Epoch: 2000, eg: 0.9787, (elbo, recon, kl)=(113614.1641, 112945.3750, 601.3156)\n",
      "Epoch: 2500, eg: 0.8739, (elbo, recon, kl)=(113573.8281, 112877.6641, 624.8290)\n",
      "Epoch: 3000, eg: 0.7798, (elbo, recon, kl)=(113546.3516, 112810.2891, 655.8589)\n",
      "Epoch: 3500, eg: 0.6959, (elbo, recon, kl)=(113526.8125, 112755.0156, 682.7880)\n",
      "Epoch: 4000, eg: 0.6276, (elbo, recon, kl)=(113513.2891, 112715.1094, 702.3064)\n",
      "Epoch: 4500, eg: 0.5804, (elbo, recon, kl)=(113504.7344, 112688.5781, 715.3577)\n",
      "Epoch: 5000, eg: 0.5537, (elbo, recon, kl)=(113499.9453, 112672.4219, 723.4499)\n",
      "Epoch: 5500, eg: 0.5421, (elbo, recon, kl)=(113497.5859, 112663.4531, 728.0657)\n",
      "Epoch: 6000, eg: 0.5390, (elbo, recon, kl)=(113496.6094, 112658.9688, 730.4602)\n",
      "Epoch: 6500, eg: 0.5396, (elbo, recon, kl)=(113496.2422, 112656.9688, 731.5660)\n",
      "Epoch: 7000, eg: 0.5409, (elbo, recon, kl)=(113496.1641, 112656.2188, 732.0082)\n",
      "Epoch: 7500, eg: 0.5420, (elbo, recon, kl)=(113496.1094, 112655.9453, 732.1568)\n",
      "Epoch: 8000, eg: 0.5427, (elbo, recon, kl)=(113496.1172, 112655.8906, 732.1972)\n",
      "Epoch: 8500, eg: 0.5429, (elbo, recon, kl)=(113496.1094, 112655.8750, 732.2055)\n",
      "Epoch: 9000, eg: 0.5430, (elbo, recon, kl)=(113496.1094, 112655.8750, 732.2068)\n",
      "Epoch: 9500, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2071)\n",
      "Epoch: 10000, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2070)\n",
      "Epoch: 10500, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2070)\n",
      "Epoch: 11000, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2070)\n",
      "Epoch: 11500, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2072)\n",
      "Epoch: 12000, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2072)\n",
      "Epoch: 12500, eg: 0.5430, (elbo, recon, kl)=(113496.1172, 112655.8828, 732.2070)\n",
      "Epoch: 13000, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2072)\n",
      "Epoch: 13500, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2073)\n",
      "Epoch: 14000, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2076)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 14500, eg: 0.5430, (elbo, recon, kl)=(113496.1250, 112655.8828, 732.2072)\n",
      "Epoch: 0, eg: 1.8251, (elbo, recon, kl)=(114623.1016, 113529.6875, 867.2842)\n",
      "Epoch: 500, eg: 1.4893, (elbo, recon, kl)=(113686.8516, 112872.1641, 687.3259)\n",
      "Epoch: 1000, eg: 1.3208, (elbo, recon, kl)=(113440.5859, 112738.2891, 615.3747)\n",
      "Epoch: 1500, eg: 1.1930, (elbo, recon, kl)=(113340.7812, 112689.8359, 584.7151)\n",
      "Epoch: 2000, eg: 1.0961, (elbo, recon, kl)=(113288.3750, 112642.8281, 585.7054)\n",
      "Epoch: 2500, eg: 0.9887, (elbo, recon, kl)=(113251.8516, 112573.0312, 613.0782)\n",
      "Epoch: 3000, eg: 0.8405, (elbo, recon, kl)=(113220.8984, 112488.4531, 653.9629)\n",
      "Epoch: 3500, eg: 0.6829, (elbo, recon, kl)=(113194.3125, 112409.4297, 692.9945)\n",
      "Epoch: 4000, eg: 0.5704, (elbo, recon, kl)=(113175.9688, 112354.1172, 719.9314)\n",
      "Epoch: 4500, eg: 0.5099, (elbo, recon, kl)=(113166.1641, 112323.7344, 734.5681)\n",
      "Epoch: 5000, eg: 0.4831, (elbo, recon, kl)=(113161.7891, 112309.3438, 741.5598)\n",
      "Epoch: 5500, eg: 0.4738, (elbo, recon, kl)=(113160.1094, 112303.1797, 744.6515)\n",
      "Epoch: 6000, eg: 0.4720, (elbo, recon, kl)=(113159.5938, 112300.7969, 745.9164)\n",
      "Epoch: 6500, eg: 0.4722, (elbo, recon, kl)=(113159.4609, 112299.9922, 746.3760)\n",
      "Epoch: 7000, eg: 0.4724, (elbo, recon, kl)=(113159.4375, 112299.7578, 746.5154)\n",
      "Epoch: 7500, eg: 0.4724, (elbo, recon, kl)=(113159.4297, 112299.7109, 746.5479)\n",
      "Epoch: 8000, eg: 0.4724, (elbo, recon, kl)=(113159.4453, 112299.7109, 746.5531)\n",
      "Epoch: 8500, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5534)\n",
      "Epoch: 9000, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5536)\n",
      "Epoch: 9500, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5536)\n",
      "Epoch: 10000, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5536)\n",
      "Epoch: 10500, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5535)\n",
      "Epoch: 11000, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5536)\n",
      "Epoch: 11500, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5538)\n",
      "Epoch: 12000, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5533)\n",
      "Epoch: 12500, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5538)\n",
      "Epoch: 13000, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5532)\n",
      "Epoch: 13500, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5541)\n",
      "Epoch: 14000, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5537)\n",
      "Epoch: 14500, eg: 0.4723, (elbo, recon, kl)=(113159.4375, 112299.7031, 746.5535)\n",
      "Epoch: 0, eg: 1.9238, (elbo, recon, kl)=(115138.4922, 114009.3516, 884.3836)\n",
      "Epoch: 500, eg: 1.6008, (elbo, recon, kl)=(114063.5469, 113236.0078, 688.7267)\n",
      "Epoch: 1000, eg: 1.4290, (elbo, recon, kl)=(113768.2031, 113062.4609, 613.0157)\n",
      "Epoch: 1500, eg: 1.3116, (elbo, recon, kl)=(113644.4531, 112996.0234, 579.4557)\n",
      "Epoch: 2000, eg: 1.2472, (elbo, recon, kl)=(113583.4766, 112949.3203, 574.9966)\n",
      "Epoch: 2500, eg: 1.2132, (elbo, recon, kl)=(113548.2344, 112898.9766, 589.7341)\n",
      "Epoch: 3000, eg: 1.1717, (elbo, recon, kl)=(113524.0312, 112841.4609, 615.9906)\n",
      "Epoch: 3500, eg: 1.0850, (elbo, recon, kl)=(113505.4219, 112784.7734, 644.6395)\n",
      "Epoch: 4000, eg: 0.9461, (elbo, recon, kl)=(113489.9453, 112735.0469, 670.0613)\n",
      "Epoch: 4500, eg: 0.7863, (elbo, recon, kl)=(113476.8047, 112693.7734, 690.8397)\n",
      "Epoch: 5000, eg: 0.6475, (elbo, recon, kl)=(113466.8203, 112662.7188, 706.2676)\n",
      "Epoch: 5500, eg: 0.5505, (elbo, recon, kl)=(113460.6016, 112642.7344, 716.2205)\n",
      "Epoch: 6000, eg: 0.4930, (elbo, recon, kl)=(113457.4453, 112631.7109, 721.8134)\n",
      "Epoch: 6500, eg: 0.4632, (elbo, recon, kl)=(113456.1641, 112626.5000, 724.5521)\n",
      "Epoch: 7000, eg: 0.4493, (elbo, recon, kl)=(113455.7500, 112624.4219, 725.6891)\n",
      "Epoch: 7500, eg: 0.4434, (elbo, recon, kl)=(113455.6406, 112623.7500, 726.0721)\n",
      "Epoch: 8000, eg: 0.4412, (elbo, recon, kl)=(113455.6094, 112623.5703, 726.1722)\n",
      "Epoch: 8500, eg: 0.4407, (elbo, recon, kl)=(113455.6016, 112623.5391, 726.1907)\n",
      "Epoch: 9000, eg: 0.4406, (elbo, recon, kl)=(113455.6172, 112623.5391, 726.1937)\n",
      "Epoch: 9500, eg: 0.4406, (elbo, recon, kl)=(113455.6250, 112623.5469, 726.1942)\n",
      "Epoch: 10000, eg: 0.4406, (elbo, recon, kl)=(113455.6172, 112623.5391, 726.1938)\n",
      "Epoch: 10500, eg: 0.4406, (elbo, recon, kl)=(113455.6172, 112623.5391, 726.1946)\n",
      "Epoch: 11000, eg: 0.4406, (elbo, recon, kl)=(113455.6172, 112623.5391, 726.1942)\n",
      "Epoch: 11500, eg: 0.4406, (elbo, recon, kl)=(113455.6172, 112623.5391, 726.1945)\n",
      "Epoch: 12000, eg: 0.4406, (elbo, recon, kl)=(113455.6172, 112623.5391, 726.1943)\n",
      "Epoch: 12500, eg: 0.4406, (elbo, recon, kl)=(113455.6172, 112623.5391, 726.1943)\n",
      "Epoch: 13000, eg: 0.4406, (elbo, recon, kl)=(113455.6094, 112623.5312, 726.1947)\n",
      "Epoch: 13500, eg: 0.4406, (elbo, recon, kl)=(113455.6172, 112623.5391, 726.1945)\n",
      "Epoch: 14000, eg: 0.4406, (elbo, recon, kl)=(113455.6172, 112623.5391, 726.1927)\n",
      "Epoch: 14500, eg: 0.4406, (elbo, recon, kl)=(113455.6094, 112623.5312, 726.1942)\n",
      "Epoch: 0, eg: 1.9939, (elbo, recon, kl)=(114694.4375, 113573.8281, 870.2849)\n",
      "Epoch: 500, eg: 1.5596, (elbo, recon, kl)=(113556.4766, 112723.1172, 692.3322)\n",
      "Epoch: 1000, eg: 1.3814, (elbo, recon, kl)=(113239.6719, 112529.3125, 617.2514)\n",
      "Epoch: 1500, eg: 1.3014, (elbo, recon, kl)=(113110.0000, 112462.3906, 579.5459)\n",
      "Epoch: 2000, eg: 1.2458, (elbo, recon, kl)=(113050.4844, 112427.9531, 566.7925)\n",
      "Epoch: 2500, eg: 1.2333, (elbo, recon, kl)=(113019.0547, 112396.1094, 570.5776)\n",
      "Epoch: 3000, eg: 1.2771, (elbo, recon, kl)=(112998.8984, 112354.1250, 588.3870)\n",
      "Epoch: 3500, eg: 1.3205, (elbo, recon, kl)=(112984.4453, 112305.6953, 613.8470)\n",
      "Epoch: 4000, eg: 1.2588, (elbo, recon, kl)=(112972.7969, 112259.1875, 639.3109)\n",
      "Epoch: 4500, eg: 1.0796, (elbo, recon, kl)=(112958.4297, 112208.2500, 666.1084)\n",
      "Epoch: 5000, eg: 0.8263, (elbo, recon, kl)=(112938.6406, 112148.8906, 695.5170)\n",
      "Epoch: 5500, eg: 0.6173, (elbo, recon, kl)=(112921.0547, 112099.7500, 718.9836)\n",
      "Epoch: 6000, eg: 0.5007, (elbo, recon, kl)=(112911.4609, 112072.0000, 732.2188)\n",
      "Epoch: 6500, eg: 0.4487, (elbo, recon, kl)=(112907.8594, 112059.9844, 738.1543)\n",
      "Epoch: 7000, eg: 0.4281, (elbo, recon, kl)=(112906.8203, 112055.5469, 740.4789)\n",
      "Epoch: 7500, eg: 0.4207, (elbo, recon, kl)=(112906.6094, 112054.0547, 741.3253)\n",
      "Epoch: 8000, eg: 0.4182, (elbo, recon, kl)=(112906.5625, 112053.5625, 741.6141)\n",
      "Epoch: 8500, eg: 0.4174, (elbo, recon, kl)=(112906.5625, 112053.4219, 741.7005)\n",
      "Epoch: 9000, eg: 0.4172, (elbo, recon, kl)=(112906.5469, 112053.3828, 741.7206)\n",
      "Epoch: 9500, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7239)\n",
      "Epoch: 10000, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7242)\n",
      "Epoch: 10500, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7249)\n",
      "Epoch: 11000, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7241)\n",
      "Epoch: 11500, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7244)\n",
      "Epoch: 12000, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7245)\n",
      "Epoch: 12500, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7243)\n",
      "Epoch: 13000, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7242)\n",
      "Epoch: 13500, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7241)\n",
      "Epoch: 14000, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7239)\n",
      "Epoch: 14500, eg: 0.4172, (elbo, recon, kl)=(112906.5625, 112053.3906, 741.7230)\n",
      "alpha: 4.00\n",
      "Epoch: 0, eg: 1.9198, (elbo, recon, kl)=(127359.3906, 126227.4141, 910.8881)\n",
      "Epoch: 500, eg: 1.5544, (elbo, recon, kl)=(126355.7188, 125488.5000, 740.9960)\n",
      "Epoch: 1000, eg: 1.4145, (elbo, recon, kl)=(126093.0469, 125324.6953, 679.9967)\n",
      "Epoch: 1500, eg: 1.3290, (elbo, recon, kl)=(125984.5859, 125255.4375, 658.0941)\n",
      "Epoch: 2000, eg: 1.2812, (elbo, recon, kl)=(125931.3203, 125202.8125, 662.7050)\n",
      "Epoch: 2500, eg: 1.2507, (elbo, recon, kl)=(125900.5625, 125150.5859, 681.7791)\n",
      "Epoch: 3000, eg: 1.2049, (elbo, recon, kl)=(125879.4141, 125098.1094, 706.7639)\n",
      "Epoch: 3500, eg: 1.1022, (elbo, recon, kl)=(125861.8516, 125046.6250, 732.8666)\n",
      "Epoch: 4000, eg: 0.9131, (elbo, recon, kl)=(125842.9453, 124990.2891, 761.2421)\n",
      "Epoch: 4500, eg: 0.6922, (elbo, recon, kl)=(125820.5312, 124924.6250, 793.6896)\n",
      "Epoch: 5000, eg: 0.5470, (elbo, recon, kl)=(125802.7969, 124871.6328, 819.7736)\n",
      "Epoch: 5500, eg: 0.4855, (elbo, recon, kl)=(125793.9531, 124844.1797, 833.3056)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 6000, eg: 0.4654, (elbo, recon, kl)=(125790.5703, 124833.3281, 838.6708)\n",
      "Epoch: 6500, eg: 0.4604, (elbo, recon, kl)=(125789.4922, 124829.7422, 840.4540)\n",
      "Epoch: 7000, eg: 0.4598, (elbo, recon, kl)=(125789.2188, 124828.8047, 840.9307)\n",
      "Epoch: 7500, eg: 0.4599, (elbo, recon, kl)=(125789.1719, 124828.6406, 841.0143)\n",
      "Epoch: 8000, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0172)\n",
      "Epoch: 8500, eg: 0.4600, (elbo, recon, kl)=(125789.1562, 124828.6250, 841.0143)\n",
      "Epoch: 9000, eg: 0.4600, (elbo, recon, kl)=(125789.1562, 124828.6250, 841.0136)\n",
      "Epoch: 9500, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0135)\n",
      "Epoch: 10000, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0135)\n",
      "Epoch: 10500, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0135)\n",
      "Epoch: 11000, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0135)\n",
      "Epoch: 11500, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0133)\n",
      "Epoch: 12000, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0136)\n",
      "Epoch: 12500, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0135)\n",
      "Epoch: 13000, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0135)\n",
      "Epoch: 13500, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0136)\n",
      "Epoch: 14000, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0135)\n",
      "Epoch: 14500, eg: 0.4600, (elbo, recon, kl)=(125789.1641, 124828.6328, 841.0136)\n",
      "Epoch: 0, eg: 1.8087, (elbo, recon, kl)=(127714.7734, 126468.4844, 1012.7794)\n",
      "Epoch: 500, eg: 1.4540, (elbo, recon, kl)=(126654.0078, 125727.2422, 794.4210)\n",
      "Epoch: 1000, eg: 1.3062, (elbo, recon, kl)=(126354.7656, 125574.3984, 693.2927)\n",
      "Epoch: 1500, eg: 1.2299, (elbo, recon, kl)=(126228.5469, 125524.1328, 642.0116)\n",
      "Epoch: 2000, eg: 1.1673, (elbo, recon, kl)=(126166.1094, 125491.3438, 623.6642)\n",
      "Epoch: 2500, eg: 1.1066, (elbo, recon, kl)=(126129.0938, 125446.3203, 631.9877)\n",
      "Epoch: 3000, eg: 1.0031, (elbo, recon, kl)=(126100.0781, 125377.3750, 663.3283)\n",
      "Epoch: 3500, eg: 0.8292, (elbo, recon, kl)=(126071.7109, 125291.3516, 707.5121)\n",
      "Epoch: 4000, eg: 0.6479, (elbo, recon, kl)=(126045.8203, 125208.0781, 750.7318)\n",
      "Epoch: 4500, eg: 0.5307, (elbo, recon, kl)=(126028.6641, 125150.6719, 780.3665)\n",
      "Epoch: 5000, eg: 0.4719, (elbo, recon, kl)=(126019.5469, 125120.0234, 795.9725)\n",
      "Epoch: 5500, eg: 0.4452, (elbo, recon, kl)=(126015.0000, 125104.8828, 803.6185)\n",
      "Epoch: 6000, eg: 0.4353, (elbo, recon, kl)=(126012.8672, 125097.3438, 807.4913)\n",
      "Epoch: 6500, eg: 0.4336, (elbo, recon, kl)=(126011.9688, 125093.6719, 809.4626)\n",
      "Epoch: 7000, eg: 0.4346, (elbo, recon, kl)=(126011.7109, 125092.0625, 810.3978)\n",
      "Epoch: 7500, eg: 0.4357, (elbo, recon, kl)=(126011.6328, 125091.4062, 810.7910)\n",
      "Epoch: 8000, eg: 0.4363, (elbo, recon, kl)=(126011.6250, 125091.1797, 810.9341)\n",
      "Epoch: 8500, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.1094, 810.9774)\n",
      "Epoch: 9000, eg: 0.4365, (elbo, recon, kl)=(126011.6094, 125091.0938, 810.9880)\n",
      "Epoch: 9500, eg: 0.4365, (elbo, recon, kl)=(126011.6250, 125091.0938, 810.9893)\n",
      "Epoch: 10000, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9899)\n",
      "Epoch: 10500, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9899)\n",
      "Epoch: 11000, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9902)\n",
      "Epoch: 11500, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9891)\n",
      "Epoch: 12000, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9908)\n",
      "Epoch: 12500, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9893)\n",
      "Epoch: 13000, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9894)\n",
      "Epoch: 13500, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9901)\n",
      "Epoch: 14000, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9909)\n",
      "Epoch: 14500, eg: 0.4365, (elbo, recon, kl)=(126011.6172, 125091.0859, 810.9886)\n",
      "Epoch: 0, eg: 1.9355, (elbo, recon, kl)=(127486.6016, 126288.4219, 953.3681)\n",
      "Epoch: 500, eg: 1.5094, (elbo, recon, kl)=(126307.0469, 125411.0312, 759.5138)\n",
      "Epoch: 1000, eg: 1.3274, (elbo, recon, kl)=(125997.1719, 125219.0781, 685.9681)\n",
      "Epoch: 1500, eg: 1.2214, (elbo, recon, kl)=(125875.8984, 125147.0234, 657.5460)\n",
      "Epoch: 2000, eg: 1.1652, (elbo, recon, kl)=(125819.9141, 125097.3359, 658.3929)\n",
      "Epoch: 2500, eg: 1.1464, (elbo, recon, kl)=(125789.2422, 125050.7188, 673.3927)\n",
      "Epoch: 3000, eg: 1.1519, (elbo, recon, kl)=(125769.7500, 125006.8672, 692.9561)\n",
      "Epoch: 3500, eg: 1.1688, (elbo, recon, kl)=(125756.6250, 124970.1172, 711.0511)\n",
      "Epoch: 4000, eg: 1.1860, (elbo, recon, kl)=(125747.9297, 124942.3359, 725.3907)\n",
      "Epoch: 4500, eg: 1.1897, (elbo, recon, kl)=(125742.5234, 124922.7500, 735.9066)\n",
      "Epoch: 5000, eg: 1.1548, (elbo, recon, kl)=(125739.0156, 124908.9141, 743.5320)\n",
      "Epoch: 5500, eg: 1.0348, (elbo, recon, kl)=(125734.7656, 124894.3438, 751.2296)\n",
      "Epoch: 6000, eg: 0.7872, (elbo, recon, kl)=(125723.1016, 124860.2031, 768.1790)\n",
      "Epoch: 6500, eg: 0.5586, (elbo, recon, kl)=(125704.0156, 124804.8828, 795.3470)\n",
      "Epoch: 7000, eg: 0.4743, (elbo, recon, kl)=(125692.8672, 124772.1562, 811.3789)\n",
      "Epoch: 7500, eg: 0.4601, (elbo, recon, kl)=(125689.3359, 124761.0000, 816.9535)\n",
      "Epoch: 8000, eg: 0.4628, (elbo, recon, kl)=(125688.5781, 124758.1406, 818.4576)\n",
      "Epoch: 8500, eg: 0.4658, (elbo, recon, kl)=(125688.4688, 124757.5625, 818.7867)\n",
      "Epoch: 9000, eg: 0.4669, (elbo, recon, kl)=(125688.4609, 124757.4609, 818.8509)\n",
      "Epoch: 9500, eg: 0.4672, (elbo, recon, kl)=(125688.4453, 124757.4375, 818.8618)\n",
      "Epoch: 10000, eg: 0.4672, (elbo, recon, kl)=(125688.4609, 124757.4531, 818.8632)\n",
      "Epoch: 10500, eg: 0.4672, (elbo, recon, kl)=(125688.4609, 124757.4453, 818.8633)\n",
      "Epoch: 11000, eg: 0.4672, (elbo, recon, kl)=(125688.4609, 124757.4453, 818.8634)\n",
      "Epoch: 11500, eg: 0.4672, (elbo, recon, kl)=(125688.4688, 124757.4531, 818.8637)\n",
      "Epoch: 12000, eg: 0.4672, (elbo, recon, kl)=(125688.4609, 124757.4453, 818.8635)\n",
      "Epoch: 12500, eg: 0.4672, (elbo, recon, kl)=(125688.4531, 124757.4453, 818.8630)\n",
      "Epoch: 13000, eg: 0.4672, (elbo, recon, kl)=(125688.4531, 124757.4453, 818.8632)\n",
      "Epoch: 13500, eg: 0.4672, (elbo, recon, kl)=(125688.4531, 124757.4453, 818.8632)\n",
      "Epoch: 14000, eg: 0.4672, (elbo, recon, kl)=(125688.4609, 124757.4453, 818.8634)\n",
      "Epoch: 14500, eg: 0.4672, (elbo, recon, kl)=(125688.4609, 124757.4453, 818.8638)\n",
      "Epoch: 0, eg: 2.0788, (elbo, recon, kl)=(127818.7031, 126625.0938, 933.7122)\n",
      "Epoch: 500, eg: 1.6132, (elbo, recon, kl)=(126656.3359, 125732.4531, 770.3928)\n",
      "Epoch: 1000, eg: 1.4221, (elbo, recon, kl)=(126345.8203, 125525.1406, 711.5935)\n",
      "Epoch: 1500, eg: 1.3049, (elbo, recon, kl)=(126213.7891, 125450.4375, 678.0267)\n",
      "Epoch: 2000, eg: 1.2201, (elbo, recon, kl)=(126148.9062, 125408.0469, 667.8497)\n",
      "Epoch: 2500, eg: 1.1427, (elbo, recon, kl)=(126112.3750, 125369.6875, 673.5805)\n",
      "Epoch: 3000, eg: 1.0457, (elbo, recon, kl)=(126086.2891, 125319.3203, 694.2433)\n",
      "Epoch: 3500, eg: 0.9111, (elbo, recon, kl)=(126062.5391, 125253.0625, 727.2798)\n",
      "Epoch: 4000, eg: 0.7558, (elbo, recon, kl)=(126041.2969, 125188.2891, 760.3386)\n",
      "Epoch: 4500, eg: 0.6193, (elbo, recon, kl)=(126025.5625, 125141.9766, 783.4067)\n",
      "Epoch: 5000, eg: 0.5226, (elbo, recon, kl)=(126015.8516, 125114.4297, 796.8213)\n",
      "Epoch: 5500, eg: 0.4640, (elbo, recon, kl)=(126010.6016, 125099.5703, 804.0034)\n",
      "Epoch: 6000, eg: 0.4324, (elbo, recon, kl)=(126008.1016, 125092.2344, 807.5746)\n",
      "Epoch: 6500, eg: 0.4170, (elbo, recon, kl)=(126007.0625, 125089.0078, 809.1778)\n",
      "Epoch: 7000, eg: 0.4101, (elbo, recon, kl)=(126006.7109, 125087.8047, 809.7964)\n",
      "Epoch: 7500, eg: 0.4074, (elbo, recon, kl)=(126006.6016, 125087.4219, 809.9857)\n",
      "Epoch: 8000, eg: 0.4066, (elbo, recon, kl)=(126006.6016, 125087.3594, 810.0272)\n",
      "Epoch: 8500, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3359, 810.0329)\n",
      "Epoch: 9000, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0335)\n",
      "Epoch: 9500, eg: 0.4063, (elbo, recon, kl)=(126006.6016, 125087.3438, 810.0336)\n",
      "Epoch: 10000, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0336)\n",
      "Epoch: 10500, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0337)\n",
      "Epoch: 11000, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0338)\n",
      "Epoch: 11500, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0342)\n",
      "Epoch: 12000, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0330)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 12500, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0331)\n",
      "Epoch: 13000, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0339)\n",
      "Epoch: 13500, eg: 0.4063, (elbo, recon, kl)=(126006.5938, 125087.3281, 810.0358)\n",
      "Epoch: 14000, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0334)\n",
      "Epoch: 14500, eg: 0.4063, (elbo, recon, kl)=(126006.5859, 125087.3281, 810.0331)\n",
      "Epoch: 0, eg: 1.9841, (elbo, recon, kl)=(127508.0312, 126303.4609, 960.2473)\n",
      "Epoch: 500, eg: 1.5767, (elbo, recon, kl)=(126307.1328, 125412.4062, 758.5981)\n",
      "Epoch: 1000, eg: 1.3762, (elbo, recon, kl)=(125983.8828, 125211.7578, 680.5426)\n",
      "Epoch: 1500, eg: 1.2105, (elbo, recon, kl)=(125846.5078, 125129.2578, 647.8281)\n",
      "Epoch: 2000, eg: 1.0339, (elbo, recon, kl)=(125772.2578, 125059.0156, 651.3419)\n",
      "Epoch: 2500, eg: 0.8203, (elbo, recon, kl)=(125717.1406, 124960.1562, 688.8226)\n",
      "Epoch: 3000, eg: 0.6120, (elbo, recon, kl)=(125670.4453, 124836.3125, 748.8870)\n",
      "Epoch: 3500, eg: 0.4665, (elbo, recon, kl)=(125640.5625, 124743.0000, 796.1553)\n",
      "Epoch: 4000, eg: 0.3838, (elbo, recon, kl)=(125625.5156, 124693.4375, 821.0612)\n",
      "Epoch: 4500, eg: 0.3420, (elbo, recon, kl)=(125618.5312, 124669.7500, 832.9072)\n",
      "Epoch: 5000, eg: 0.3223, (elbo, recon, kl)=(125615.3906, 124658.6953, 838.4722)\n",
      "Epoch: 5500, eg: 0.3133, (elbo, recon, kl)=(125613.9766, 124653.6328, 841.0322)\n",
      "Epoch: 6000, eg: 0.3092, (elbo, recon, kl)=(125613.3828, 124651.4219, 842.1638)\n",
      "Epoch: 6500, eg: 0.3074, (elbo, recon, kl)=(125613.1250, 124650.4766, 842.6486)\n",
      "Epoch: 7000, eg: 0.3067, (elbo, recon, kl)=(125613.0312, 124650.0781, 842.8581)\n",
      "Epoch: 7500, eg: 0.3065, (elbo, recon, kl)=(125613.0156, 124649.9219, 842.9512)\n",
      "Epoch: 8000, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8516, 842.9901)\n",
      "Epoch: 8500, eg: 0.3065, (elbo, recon, kl)=(125613.0000, 124649.8281, 843.0035)\n",
      "Epoch: 9000, eg: 0.3065, (elbo, recon, kl)=(125613.0234, 124649.8359, 843.0070)\n",
      "Epoch: 9500, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8203, 843.0076)\n",
      "Epoch: 10000, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8203, 843.0075)\n",
      "Epoch: 10500, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8203, 843.0076)\n",
      "Epoch: 11000, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8203, 843.0077)\n",
      "Epoch: 11500, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8203, 843.0076)\n",
      "Epoch: 12000, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8203, 843.0076)\n",
      "Epoch: 12500, eg: 0.3065, (elbo, recon, kl)=(125613.0156, 124649.8281, 843.0074)\n",
      "Epoch: 13000, eg: 0.3065, (elbo, recon, kl)=(125613.0156, 124649.8281, 843.0076)\n",
      "Epoch: 13500, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8203, 843.0078)\n",
      "Epoch: 14000, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8203, 843.0076)\n",
      "Epoch: 14500, eg: 0.3065, (elbo, recon, kl)=(125613.0078, 124649.8203, 843.0076)\n",
      "alpha: 4.40\n",
      "Epoch: 0, eg: 2.0369, (elbo, recon, kl)=(140447.6094, 139052.5312, 1134.2650)\n",
      "Epoch: 500, eg: 1.5811, (elbo, recon, kl)=(139042.1250, 138014.9531, 879.2427)\n",
      "Epoch: 1000, eg: 1.3695, (elbo, recon, kl)=(138650.8594, 137778.6875, 772.5464)\n",
      "Epoch: 1500, eg: 1.2124, (elbo, recon, kl)=(138488.9844, 137695.9844, 719.2821)\n",
      "Epoch: 2000, eg: 1.0605, (elbo, recon, kl)=(138407.5156, 137639.4375, 706.0068)\n",
      "Epoch: 2500, eg: 0.8814, (elbo, recon, kl)=(138351.7188, 137556.1250, 731.3660)\n",
      "Epoch: 3000, eg: 0.6942, (elbo, recon, kl)=(138300.6094, 137430.1562, 791.6224)\n",
      "Epoch: 3500, eg: 0.5577, (elbo, recon, kl)=(138262.1250, 137317.5469, 849.2407)\n",
      "Epoch: 4000, eg: 0.4823, (elbo, recon, kl)=(138241.0156, 137251.7188, 882.9470)\n",
      "Epoch: 4500, eg: 0.4452, (elbo, recon, kl)=(138230.9062, 137218.5156, 899.9257)\n",
      "Epoch: 5000, eg: 0.4270, (elbo, recon, kl)=(138226.2500, 137202.2500, 908.2988)\n",
      "Epoch: 5500, eg: 0.4171, (elbo, recon, kl)=(138224.1562, 137194.3438, 912.4226)\n",
      "Epoch: 6000, eg: 0.4111, (elbo, recon, kl)=(138223.2500, 137190.5781, 914.4356)\n",
      "Epoch: 6500, eg: 0.4074, (elbo, recon, kl)=(138222.8906, 137188.8594, 915.3904)\n",
      "Epoch: 7000, eg: 0.4051, (elbo, recon, kl)=(138222.7812, 137188.1094, 915.8278)\n",
      "Epoch: 7500, eg: 0.4038, (elbo, recon, kl)=(138222.7188, 137187.7812, 916.0226)\n",
      "Epoch: 8000, eg: 0.4032, (elbo, recon, kl)=(138222.7500, 137187.6719, 916.1035)\n",
      "Epoch: 8500, eg: 0.4029, (elbo, recon, kl)=(138222.7344, 137187.6250, 916.1321)\n",
      "Epoch: 9000, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1395)\n",
      "Epoch: 9500, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1417)\n",
      "Epoch: 10000, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1408)\n",
      "Epoch: 10500, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1408)\n",
      "Epoch: 11000, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1409)\n",
      "Epoch: 11500, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1411)\n",
      "Epoch: 12000, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1410)\n",
      "Epoch: 12500, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1393)\n",
      "Epoch: 13000, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1408)\n",
      "Epoch: 13500, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1412)\n",
      "Epoch: 14000, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1403)\n",
      "Epoch: 14500, eg: 0.4028, (elbo, recon, kl)=(138222.7188, 137187.5938, 916.1407)\n",
      "Epoch: 0, eg: 2.0229, (elbo, recon, kl)=(141194.5312, 139747.2188, 1173.8779)\n",
      "Epoch: 500, eg: 1.5565, (elbo, recon, kl)=(139677.7500, 138620.9688, 902.6913)\n",
      "Epoch: 1000, eg: 1.3486, (elbo, recon, kl)=(139217.8594, 138334.5000, 781.4099)\n",
      "Epoch: 1500, eg: 1.2509, (elbo, recon, kl)=(139018.7344, 138222.9531, 720.5468)\n",
      "Epoch: 2000, eg: 1.2145, (elbo, recon, kl)=(138921.7344, 138159.6250, 699.7630)\n",
      "Epoch: 2500, eg: 1.2194, (elbo, recon, kl)=(138868.8125, 138107.9688, 702.4329)\n",
      "Epoch: 3000, eg: 1.2564, (elbo, recon, kl)=(138836.0469, 138056.6406, 719.0095)\n",
      "Epoch: 3500, eg: 1.3210, (elbo, recon, kl)=(138813.6094, 138006.2656, 741.7565)\n",
      "Epoch: 4000, eg: 1.3691, (elbo, recon, kl)=(138797.5000, 137960.1250, 765.3216)\n",
      "Epoch: 4500, eg: 1.2978, (elbo, recon, kl)=(138784.5625, 137917.1719, 788.4205)\n",
      "Epoch: 5000, eg: 1.1149, (elbo, recon, kl)=(138769.8281, 137868.0156, 814.7340)\n",
      "Epoch: 5500, eg: 0.8531, (elbo, recon, kl)=(138749.7031, 137805.7500, 846.9913)\n",
      "Epoch: 6000, eg: 0.6412, (elbo, recon, kl)=(138732.1094, 137753.6875, 873.2983)\n",
      "Epoch: 6500, eg: 0.5249, (elbo, recon, kl)=(138722.9531, 137726.1562, 887.1926)\n",
      "Epoch: 7000, eg: 0.4721, (elbo, recon, kl)=(138719.4219, 137714.6250, 893.1541)\n",
      "Epoch: 7500, eg: 0.4505, (elbo, recon, kl)=(138718.3125, 137710.4531, 895.3842)\n",
      "Epoch: 8000, eg: 0.4424, (elbo, recon, kl)=(138717.9375, 137709.0625, 896.1252)\n",
      "Epoch: 8500, eg: 0.4394, (elbo, recon, kl)=(138717.8281, 137708.6250, 896.3495)\n",
      "Epoch: 9000, eg: 0.4382, (elbo, recon, kl)=(138717.8125, 137708.5312, 896.4086)\n",
      "Epoch: 9500, eg: 0.4378, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4194)\n",
      "Epoch: 10000, eg: 0.4377, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4191)\n",
      "Epoch: 10500, eg: 0.4377, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4182)\n",
      "Epoch: 11000, eg: 0.4377, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4182)\n",
      "Epoch: 11500, eg: 0.4377, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4179)\n",
      "Epoch: 12000, eg: 0.4377, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4178)\n",
      "Epoch: 12500, eg: 0.4377, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4175)\n",
      "Epoch: 13000, eg: 0.4377, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4178)\n",
      "Epoch: 13500, eg: 0.4377, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4183)\n",
      "Epoch: 14000, eg: 0.4377, (elbo, recon, kl)=(138717.8125, 137708.5000, 896.4173)\n",
      "Epoch: 14500, eg: 0.4377, (elbo, recon, kl)=(138717.8281, 137708.5156, 896.4185)\n",
      "Epoch: 0, eg: 1.7763, (elbo, recon, kl)=(140005.9062, 138701.4688, 1070.8173)\n",
      "Epoch: 500, eg: 1.4483, (elbo, recon, kl)=(138913.0469, 137922.8750, 856.6786)\n",
      "Epoch: 1000, eg: 1.3599, (elbo, recon, kl)=(138627.8438, 137765.3750, 769.2720)\n",
      "Epoch: 1500, eg: 1.3197, (elbo, recon, kl)=(138510.2031, 137706.3906, 730.4910)\n",
      "Epoch: 2000, eg: 1.2496, (elbo, recon, kl)=(138451.4844, 137660.9531, 724.7109)\n",
      "Epoch: 2500, eg: 1.1852, (elbo, recon, kl)=(138416.2031, 137610.1875, 739.3331)\n",
      "Epoch: 3000, eg: 1.0983, (elbo, recon, kl)=(138390.9219, 137554.0312, 764.5030)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 3500, eg: 0.9694, (elbo, recon, kl)=(138369.6562, 137496.0625, 793.2812)\n",
      "Epoch: 4000, eg: 0.8099, (elbo, recon, kl)=(138349.9219, 137438.5938, 822.3976)\n",
      "Epoch: 4500, eg: 0.6606, (elbo, recon, kl)=(138333.0156, 137388.2031, 847.9849)\n",
      "Epoch: 5000, eg: 0.5542, (elbo, recon, kl)=(138321.5000, 137352.6562, 866.1506)\n",
      "Epoch: 5500, eg: 0.4932, (elbo, recon, kl)=(138315.5000, 137332.6406, 876.6197)\n",
      "Epoch: 6000, eg: 0.4632, (elbo, recon, kl)=(138313.0938, 137323.4062, 881.6443)\n",
      "Epoch: 6500, eg: 0.4498, (elbo, recon, kl)=(138312.3438, 137319.8438, 883.6661)\n",
      "Epoch: 7000, eg: 0.4440, (elbo, recon, kl)=(138312.1562, 137318.6719, 884.3542)\n",
      "Epoch: 7500, eg: 0.4417, (elbo, recon, kl)=(138312.1250, 137318.3594, 884.5498)\n",
      "Epoch: 8000, eg: 0.4407, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5923)\n",
      "Epoch: 8500, eg: 0.4404, (elbo, recon, kl)=(138312.0938, 137318.2656, 884.5975)\n",
      "Epoch: 9000, eg: 0.4403, (elbo, recon, kl)=(138312.0938, 137318.2656, 884.5972)\n",
      "Epoch: 9500, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5968)\n",
      "Epoch: 10000, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5967)\n",
      "Epoch: 10500, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5969)\n",
      "Epoch: 11000, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5969)\n",
      "Epoch: 11500, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5968)\n",
      "Epoch: 12000, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5966)\n",
      "Epoch: 12500, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5967)\n",
      "Epoch: 13000, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5969)\n",
      "Epoch: 13500, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5970)\n",
      "Epoch: 14000, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5967)\n",
      "Epoch: 14500, eg: 0.4403, (elbo, recon, kl)=(138312.1094, 137318.2812, 884.5967)\n",
      "Epoch: 0, eg: 1.9516, (elbo, recon, kl)=(140455.0312, 139138.9844, 1077.5256)\n",
      "Epoch: 500, eg: 1.5362, (elbo, recon, kl)=(139241.8281, 138254.2500, 850.9237)\n",
      "Epoch: 1000, eg: 1.3709, (elbo, recon, kl)=(138930.8438, 138070.7031, 765.3512)\n",
      "Epoch: 1500, eg: 1.2680, (elbo, recon, kl)=(138807.4062, 138011.8906, 723.1441)\n",
      "Epoch: 2000, eg: 1.1977, (elbo, recon, kl)=(138747.9688, 137977.3594, 709.0566)\n",
      "Epoch: 2500, eg: 1.1274, (elbo, recon, kl)=(138713.1875, 137937.2344, 716.2004)\n",
      "Epoch: 3000, eg: 1.0173, (elbo, recon, kl)=(138686.5312, 137878.6562, 742.3866)\n",
      "Epoch: 3500, eg: 0.8475, (elbo, recon, kl)=(138660.3281, 137800.8281, 782.7833)\n",
      "Epoch: 4000, eg: 0.6676, (elbo, recon, kl)=(138635.7812, 137722.5312, 824.0453)\n",
      "Epoch: 4500, eg: 0.5397, (elbo, recon, kl)=(138618.6406, 137668.4375, 852.0226)\n",
      "Epoch: 5000, eg: 0.4681, (elbo, recon, kl)=(138609.1406, 137639.0156, 866.9617)\n",
      "Epoch: 5500, eg: 0.4331, (elbo, recon, kl)=(138604.3438, 137624.3281, 874.3812)\n",
      "Epoch: 6000, eg: 0.4185, (elbo, recon, kl)=(138602.0938, 137617.1562, 878.0526)\n",
      "Epoch: 6500, eg: 0.4145, (elbo, recon, kl)=(138601.1250, 137613.6406, 879.9229)\n",
      "Epoch: 7000, eg: 0.4152, (elbo, recon, kl)=(138600.7344, 137611.8750, 880.9130)\n",
      "Epoch: 7500, eg: 0.4170, (elbo, recon, kl)=(138600.6094, 137610.9844, 881.4404)\n",
      "Epoch: 8000, eg: 0.4184, (elbo, recon, kl)=(138600.5781, 137610.5625, 881.7044)\n",
      "Epoch: 8500, eg: 0.4191, (elbo, recon, kl)=(138600.5781, 137610.4062, 881.8188)\n",
      "Epoch: 9000, eg: 0.4194, (elbo, recon, kl)=(138600.5781, 137610.3281, 881.8582)\n",
      "Epoch: 9500, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8684)\n",
      "Epoch: 10000, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8704)\n",
      "Epoch: 10500, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8704)\n",
      "Epoch: 11000, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8701)\n",
      "Epoch: 11500, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8703)\n",
      "Epoch: 12000, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8705)\n",
      "Epoch: 12500, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8700)\n",
      "Epoch: 13000, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8704)\n",
      "Epoch: 13500, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8702)\n",
      "Epoch: 14000, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8704)\n",
      "Epoch: 14500, eg: 0.4195, (elbo, recon, kl)=(138600.5781, 137610.3125, 881.8704)\n",
      "Epoch: 0, eg: 1.8653, (elbo, recon, kl)=(139840.7031, 138575.2500, 1022.9203)\n",
      "Epoch: 500, eg: 1.4435, (elbo, recon, kl)=(138648.5781, 137671.4688, 837.5164)\n",
      "Epoch: 1000, eg: 1.2568, (elbo, recon, kl)=(138325.7188, 137459.0000, 768.0613)\n",
      "Epoch: 1500, eg: 1.1186, (elbo, recon, kl)=(138189.8750, 137364.2969, 744.7210)\n",
      "Epoch: 2000, eg: 0.9782, (elbo, recon, kl)=(138118.2812, 137286.6406, 755.0082)\n",
      "Epoch: 2500, eg: 0.8094, (elbo, recon, kl)=(138068.6250, 137199.4062, 787.5419)\n",
      "Epoch: 3000, eg: 0.6287, (elbo, recon, kl)=(138026.8594, 137104.0469, 830.8684)\n",
      "Epoch: 3500, eg: 0.4816, (elbo, recon, kl)=(137994.7812, 137022.5469, 869.5239)\n",
      "Epoch: 4000, eg: 0.3896, (elbo, recon, kl)=(137975.2812, 136968.7188, 895.6137)\n",
      "Epoch: 4500, eg: 0.3416, (elbo, recon, kl)=(137965.7969, 136939.5469, 910.2015)\n",
      "Epoch: 5000, eg: 0.3193, (elbo, recon, kl)=(137961.8906, 136925.7656, 917.3689)\n",
      "Epoch: 5500, eg: 0.3098, (elbo, recon, kl)=(137960.5156, 136919.8750, 920.5808)\n",
      "Epoch: 6000, eg: 0.3061, (elbo, recon, kl)=(137960.1562, 136917.5938, 921.9067)\n",
      "Epoch: 6500, eg: 0.3049, (elbo, recon, kl)=(137960.0312, 136916.7500, 922.3972)\n",
      "Epoch: 7000, eg: 0.3045, (elbo, recon, kl)=(137960.0312, 136916.5312, 922.5490)\n",
      "Epoch: 7500, eg: 0.3044, (elbo, recon, kl)=(137960.0156, 136916.4531, 922.5845)\n",
      "Epoch: 8000, eg: 0.3044, (elbo, recon, kl)=(137960.0156, 136916.4375, 922.5897)\n",
      "Epoch: 8500, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5900)\n",
      "Epoch: 9000, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5900)\n",
      "Epoch: 9500, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5903)\n",
      "Epoch: 10000, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5901)\n",
      "Epoch: 10500, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5900)\n",
      "Epoch: 11000, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5902)\n",
      "Epoch: 11500, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5903)\n",
      "Epoch: 12000, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5881)\n",
      "Epoch: 12500, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5901)\n",
      "Epoch: 13000, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5901)\n",
      "Epoch: 13500, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5901)\n",
      "Epoch: 14000, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5900)\n",
      "Epoch: 14500, eg: 0.3044, (elbo, recon, kl)=(137960.0312, 136916.4531, 922.5904)\n",
      "alpha: 4.80\n",
      "Epoch: 0, eg: 1.9718, (elbo, recon, kl)=(152991.8750, 151532.7812, 1211.1328)\n",
      "Epoch: 500, eg: 1.5088, (elbo, recon, kl)=(151567.1094, 150462.0312, 962.5096)\n",
      "Epoch: 1000, eg: 1.3036, (elbo, recon, kl)=(151171.3594, 150218.5625, 855.0153)\n",
      "Epoch: 1500, eg: 1.1566, (elbo, recon, kl)=(151010.3438, 150132.6094, 803.2159)\n",
      "Epoch: 2000, eg: 1.0319, (elbo, recon, kl)=(150931.5000, 150071.4375, 794.2461)\n",
      "Epoch: 2500, eg: 0.8973, (elbo, recon, kl)=(150881.7656, 149995.7500, 817.3482)\n",
      "Epoch: 3000, eg: 0.7352, (elbo, recon, kl)=(150841.0312, 149900.7812, 861.0424)\n",
      "Epoch: 3500, eg: 0.5715, (elbo, recon, kl)=(150804.3438, 149801.9844, 909.9288)\n",
      "Epoch: 4000, eg: 0.4529, (elbo, recon, kl)=(150775.1094, 149720.6875, 950.2650)\n",
      "Epoch: 4500, eg: 0.3933, (elbo, recon, kl)=(150756.4219, 149667.0938, 976.8590)\n",
      "Epoch: 5000, eg: 0.3743, (elbo, recon, kl)=(150746.8281, 149637.6094, 991.7073)\n",
      "Epoch: 5500, eg: 0.3743, (elbo, recon, kl)=(150742.7344, 149623.6250, 998.9359)\n",
      "Epoch: 6000, eg: 0.3801, (elbo, recon, kl)=(150741.2500, 149617.8281, 1002.0157)\n",
      "Epoch: 6500, eg: 0.3858, (elbo, recon, kl)=(150740.7969, 149615.7656, 1003.1431)\n",
      "Epoch: 7000, eg: 0.3895, (elbo, recon, kl)=(150740.7188, 149615.1562, 1003.4925)\n",
      "Epoch: 7500, eg: 0.3912, (elbo, recon, kl)=(150740.6562, 149614.9844, 1003.5847)\n",
      "Epoch: 8000, eg: 0.3918, (elbo, recon, kl)=(150740.6562, 149614.9375, 1003.6039)\n",
      "Epoch: 8500, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6076)\n",
      "Epoch: 9000, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6080)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 9500, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6080)\n",
      "Epoch: 10000, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6082)\n",
      "Epoch: 10500, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6081)\n",
      "Epoch: 11000, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6081)\n",
      "Epoch: 11500, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6089)\n",
      "Epoch: 12000, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6074)\n",
      "Epoch: 12500, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6060)\n",
      "Epoch: 13000, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6057)\n",
      "Epoch: 13500, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6083)\n",
      "Epoch: 14000, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6078)\n",
      "Epoch: 14500, eg: 0.3920, (elbo, recon, kl)=(150740.6719, 149614.9531, 1003.6097)\n",
      "Epoch: 0, eg: 1.9760, (elbo, recon, kl)=(153351.7812, 151999.2344, 1115.0681)\n",
      "Epoch: 500, eg: 1.5737, (elbo, recon, kl)=(152035.8281, 150993.9688, 906.4750)\n",
      "Epoch: 1000, eg: 1.4415, (elbo, recon, kl)=(151702.4531, 150784.7031, 824.5498)\n",
      "Epoch: 1500, eg: 1.2960, (elbo, recon, kl)=(151572.0469, 150713.0000, 786.8898)\n",
      "Epoch: 2000, eg: 1.1710, (elbo, recon, kl)=(151511.2500, 150664.8438, 782.3864)\n",
      "Epoch: 2500, eg: 1.0320, (elbo, recon, kl)=(151473.5312, 150605.1250, 802.5685)\n",
      "Epoch: 3000, eg: 0.8689, (elbo, recon, kl)=(151439.5156, 150519.1406, 844.6625)\n",
      "Epoch: 3500, eg: 0.7141, (elbo, recon, kl)=(151407.7656, 150426.5625, 892.7913)\n",
      "Epoch: 4000, eg: 0.5970, (elbo, recon, kl)=(151384.2188, 150356.4844, 929.1750)\n",
      "Epoch: 4500, eg: 0.5207, (elbo, recon, kl)=(151370.4844, 150313.2812, 951.8081)\n",
      "Epoch: 5000, eg: 0.4759, (elbo, recon, kl)=(151363.9219, 150289.7656, 964.5231)\n",
      "Epoch: 5500, eg: 0.4520, (elbo, recon, kl)=(151361.3750, 150278.2969, 971.0083)\n",
      "Epoch: 6000, eg: 0.4405, (elbo, recon, kl)=(151360.5156, 150273.2812, 973.9797)\n",
      "Epoch: 6500, eg: 0.4358, (elbo, recon, kl)=(151360.3281, 150271.3594, 975.1808)\n",
      "Epoch: 7000, eg: 0.4341, (elbo, recon, kl)=(151360.2656, 150270.7188, 975.5953)\n",
      "Epoch: 7500, eg: 0.4337, (elbo, recon, kl)=(151360.2812, 150270.5469, 975.7119)\n",
      "Epoch: 8000, eg: 0.4336, (elbo, recon, kl)=(151360.2656, 150270.5000, 975.7375)\n",
      "Epoch: 8500, eg: 0.4336, (elbo, recon, kl)=(151360.2812, 150270.5156, 975.7411)\n",
      "Epoch: 9000, eg: 0.4336, (elbo, recon, kl)=(151360.2656, 150270.5000, 975.7419)\n",
      "Epoch: 9500, eg: 0.4336, (elbo, recon, kl)=(151360.2812, 150270.5000, 975.7422)\n",
      "Epoch: 10000, eg: 0.4336, (elbo, recon, kl)=(151360.2812, 150270.5000, 975.7426)\n",
      "Epoch: 10500, eg: 0.4336, (elbo, recon, kl)=(151360.2656, 150270.5000, 975.7421)\n",
      "Epoch: 11000, eg: 0.4336, (elbo, recon, kl)=(151360.2656, 150270.5000, 975.7419)\n",
      "Epoch: 11500, eg: 0.4336, (elbo, recon, kl)=(151360.2656, 150270.5000, 975.7421)\n",
      "Epoch: 12000, eg: 0.4336, (elbo, recon, kl)=(151360.2812, 150270.5000, 975.7426)\n",
      "Epoch: 12500, eg: 0.4336, (elbo, recon, kl)=(151360.2812, 150270.5000, 975.7424)\n",
      "Epoch: 13000, eg: 0.4336, (elbo, recon, kl)=(151360.2656, 150270.5000, 975.7421)\n",
      "Epoch: 13500, eg: 0.4336, (elbo, recon, kl)=(151360.2812, 150270.5000, 975.7435)\n",
      "Epoch: 14000, eg: 0.4336, (elbo, recon, kl)=(151360.2812, 150270.5000, 975.7427)\n",
      "Epoch: 14500, eg: 0.4336, (elbo, recon, kl)=(151360.2656, 150270.5000, 975.7421)\n",
      "Epoch: 0, eg: 1.8456, (elbo, recon, kl)=(153262.5000, 151803.9062, 1219.7754)\n",
      "Epoch: 500, eg: 1.4785, (elbo, recon, kl)=(151826.6250, 150735.2500, 954.8007)\n",
      "Epoch: 1000, eg: 1.2999, (elbo, recon, kl)=(151442.4062, 150505.2188, 843.8594)\n",
      "Epoch: 1500, eg: 1.1686, (elbo, recon, kl)=(151289.1406, 150429.8594, 789.1415)\n",
      "Epoch: 2000, eg: 1.0662, (elbo, recon, kl)=(151216.5156, 150384.2969, 772.4774)\n",
      "Epoch: 2500, eg: 0.9670, (elbo, recon, kl)=(151174.4062, 150331.2656, 783.6351)\n",
      "Epoch: 3000, eg: 0.8456, (elbo, recon, kl)=(151141.0938, 150255.4844, 818.0252)\n",
      "Epoch: 3500, eg: 0.7018, (elbo, recon, kl)=(151109.3281, 150164.1250, 864.8998)\n",
      "Epoch: 4000, eg: 0.5726, (elbo, recon, kl)=(151082.6250, 150082.0000, 907.8854)\n",
      "Epoch: 4500, eg: 0.4881, (elbo, recon, kl)=(151065.7500, 150027.4688, 936.7169)\n",
      "Epoch: 5000, eg: 0.4430, (elbo, recon, kl)=(151057.5156, 149998.9375, 952.0940)\n",
      "Epoch: 5500, eg: 0.4203, (elbo, recon, kl)=(151054.1094, 149986.0781, 959.1649)\n",
      "Epoch: 6000, eg: 0.4082, (elbo, recon, kl)=(151052.8906, 149980.8281, 962.1376)\n",
      "Epoch: 6500, eg: 0.4014, (elbo, recon, kl)=(151052.4844, 149978.8125, 963.3144)\n",
      "Epoch: 7000, eg: 0.3977, (elbo, recon, kl)=(151052.3594, 149978.0625, 963.7617)\n",
      "Epoch: 7500, eg: 0.3958, (elbo, recon, kl)=(151052.3438, 149977.7969, 963.9308)\n",
      "Epoch: 8000, eg: 0.3950, (elbo, recon, kl)=(151052.3125, 149977.6875, 963.9956)\n",
      "Epoch: 8500, eg: 0.3947, (elbo, recon, kl)=(151052.3125, 149977.6562, 964.0192)\n",
      "Epoch: 9000, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0265)\n",
      "Epoch: 9500, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0283)\n",
      "Epoch: 10000, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0286)\n",
      "Epoch: 10500, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0284)\n",
      "Epoch: 11000, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0285)\n",
      "Epoch: 11500, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0285)\n",
      "Epoch: 12000, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0274)\n",
      "Epoch: 12500, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0277)\n",
      "Epoch: 13000, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0280)\n",
      "Epoch: 13500, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0294)\n",
      "Epoch: 14000, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0284)\n",
      "Epoch: 14500, eg: 0.3946, (elbo, recon, kl)=(151052.3281, 149977.6562, 964.0259)\n",
      "Epoch: 0, eg: 1.9699, (elbo, recon, kl)=(153332.5156, 151848.4219, 1226.5696)\n",
      "Epoch: 500, eg: 1.5596, (elbo, recon, kl)=(151885.8438, 150769.8906, 970.1349)\n",
      "Epoch: 1000, eg: 1.3643, (elbo, recon, kl)=(151480.5156, 150530.5625, 851.9471)\n",
      "Epoch: 1500, eg: 1.2541, (elbo, recon, kl)=(151323.2969, 150457.5312, 792.4475)\n",
      "Epoch: 2000, eg: 1.1882, (elbo, recon, kl)=(151254.7031, 150422.1719, 771.0659)\n",
      "Epoch: 2500, eg: 1.1430, (elbo, recon, kl)=(151218.0312, 150385.7500, 773.7817)\n",
      "Epoch: 3000, eg: 1.0980, (elbo, recon, kl)=(151192.3906, 150335.7188, 794.4025)\n",
      "Epoch: 3500, eg: 1.0273, (elbo, recon, kl)=(151171.3125, 150276.6094, 824.7864)\n",
      "Epoch: 4000, eg: 0.9080, (elbo, recon, kl)=(151153.0000, 150217.5000, 856.7916)\n",
      "Epoch: 4500, eg: 0.7442, (elbo, recon, kl)=(151135.6719, 150160.6719, 887.5506)\n",
      "Epoch: 5000, eg: 0.5787, (elbo, recon, kl)=(151119.0312, 150108.3281, 915.1808)\n",
      "Epoch: 5500, eg: 0.4593, (elbo, recon, kl)=(151105.5938, 150067.7812, 936.0405)\n",
      "Epoch: 6000, eg: 0.3958, (elbo, recon, kl)=(151097.1719, 150042.4688, 948.9623)\n",
      "Epoch: 6500, eg: 0.3698, (elbo, recon, kl)=(151092.9531, 150029.2812, 955.7592)\n",
      "Epoch: 7000, eg: 0.3619, (elbo, recon, kl)=(151091.2188, 150023.3125, 958.9255)\n",
      "Epoch: 7500, eg: 0.3607, (elbo, recon, kl)=(151090.7031, 150020.9688, 960.2698)\n",
      "Epoch: 8000, eg: 0.3612, (elbo, recon, kl)=(151090.5781, 150020.1094, 960.7864)\n",
      "Epoch: 8500, eg: 0.3617, (elbo, recon, kl)=(151090.5469, 150019.8438, 960.9601)\n",
      "Epoch: 9000, eg: 0.3619, (elbo, recon, kl)=(151090.5469, 150019.7656, 961.0082)\n",
      "Epoch: 9500, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0184)\n",
      "Epoch: 10000, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0198)\n",
      "Epoch: 10500, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0192)\n",
      "Epoch: 11000, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0198)\n",
      "Epoch: 11500, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0201)\n",
      "Epoch: 12000, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0202)\n",
      "Epoch: 12500, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0198)\n",
      "Epoch: 13000, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0193)\n",
      "Epoch: 13500, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0181)\n",
      "Epoch: 14000, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0198)\n",
      "Epoch: 14500, eg: 0.3619, (elbo, recon, kl)=(151090.5312, 150019.7500, 961.0197)\n",
      "Epoch: 0, eg: 1.7416, (elbo, recon, kl)=(152445.3594, 151028.9062, 1178.0388)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 500, eg: 1.3648, (elbo, recon, kl)=(151222.8750, 150148.6719, 941.0547)\n",
      "Epoch: 1000, eg: 1.1836, (elbo, recon, kl)=(150884.9688, 149950.0469, 843.3854)\n",
      "Epoch: 1500, eg: 1.0284, (elbo, recon, kl)=(150747.2188, 149863.0000, 810.2669)\n",
      "Epoch: 2000, eg: 0.8690, (elbo, recon, kl)=(150677.9844, 149786.5625, 820.3032)\n",
      "Epoch: 2500, eg: 0.6955, (elbo, recon, kl)=(150629.4375, 149692.9062, 857.8477)\n",
      "Epoch: 3000, eg: 0.5348, (elbo, recon, kl)=(150589.1406, 149593.0000, 905.0266)\n",
      "Epoch: 3500, eg: 0.4182, (elbo, recon, kl)=(150559.8750, 149514.5781, 943.0933)\n",
      "Epoch: 4000, eg: 0.3487, (elbo, recon, kl)=(150542.1406, 149464.8750, 967.4612)\n",
      "Epoch: 4500, eg: 0.3140, (elbo, recon, kl)=(150532.8125, 149436.4531, 981.7744)\n",
      "Epoch: 5000, eg: 0.2997, (elbo, recon, kl)=(150528.4375, 149421.3125, 989.7368)\n",
      "Epoch: 5500, eg: 0.2951, (elbo, recon, kl)=(150526.5938, 149413.7656, 993.8931)\n",
      "Epoch: 6000, eg: 0.2942, (elbo, recon, kl)=(150525.8594, 149410.2031, 995.9427)\n",
      "Epoch: 6500, eg: 0.2945, (elbo, recon, kl)=(150525.5781, 149408.5625, 996.9289)\n",
      "Epoch: 7000, eg: 0.2950, (elbo, recon, kl)=(150525.5000, 149407.8125, 997.4010)\n",
      "Epoch: 7500, eg: 0.2955, (elbo, recon, kl)=(150525.4531, 149407.4688, 997.6178)\n",
      "Epoch: 8000, eg: 0.2958, (elbo, recon, kl)=(150525.4375, 149407.3438, 997.7069)\n",
      "Epoch: 8500, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.3125, 997.7374)\n",
      "Epoch: 9000, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7452)\n",
      "Epoch: 9500, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7467)\n",
      "Epoch: 10000, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7469)\n",
      "Epoch: 10500, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7468)\n",
      "Epoch: 11000, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7472)\n",
      "Epoch: 11500, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7469)\n",
      "Epoch: 12000, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7474)\n",
      "Epoch: 12500, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7476)\n",
      "Epoch: 13000, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7466)\n",
      "Epoch: 13500, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7471)\n",
      "Epoch: 14000, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7503)\n",
      "Epoch: 14500, eg: 0.2959, (elbo, recon, kl)=(150525.4531, 149407.2969, 997.7466)\n",
      "alpha: 5.20\n",
      "Epoch: 0, eg: 1.9010, (elbo, recon, kl)=(165659.6562, 164135.0000, 1280.7950)\n",
      "Epoch: 500, eg: 1.4923, (elbo, recon, kl)=(164213.6875, 163052.4062, 1023.2922)\n",
      "Epoch: 1000, eg: 1.3141, (elbo, recon, kl)=(163812.7656, 162810.2969, 909.4402)\n",
      "Epoch: 1500, eg: 1.1785, (elbo, recon, kl)=(163649.9219, 162718.3125, 859.8783)\n",
      "Epoch: 2000, eg: 1.0395, (elbo, recon, kl)=(163569.5000, 162640.8594, 861.9329)\n",
      "Epoch: 2500, eg: 0.8701, (elbo, recon, kl)=(163511.6094, 162531.7031, 905.3451)\n",
      "Epoch: 3000, eg: 0.6888, (elbo, recon, kl)=(163458.6250, 162403.5781, 966.4017)\n",
      "Epoch: 3500, eg: 0.5415, (elbo, recon, kl)=(163416.4375, 162296.5312, 1018.0637)\n",
      "Epoch: 4000, eg: 0.4486, (elbo, recon, kl)=(163390.5625, 162226.5000, 1052.3557)\n",
      "Epoch: 4500, eg: 0.3987, (elbo, recon, kl)=(163377.8906, 162187.8750, 1072.0052)\n",
      "Epoch: 5000, eg: 0.3741, (elbo, recon, kl)=(163372.7344, 162169.1094, 1082.0568)\n",
      "Epoch: 5500, eg: 0.3623, (elbo, recon, kl)=(163370.9062, 162160.9219, 1086.6941)\n",
      "Epoch: 6000, eg: 0.3568, (elbo, recon, kl)=(163370.3438, 162157.6562, 1088.6339)\n",
      "Epoch: 6500, eg: 0.3543, (elbo, recon, kl)=(163370.1875, 162156.4688, 1089.3756)\n",
      "Epoch: 7000, eg: 0.3534, (elbo, recon, kl)=(163370.1406, 162156.0469, 1089.6392)\n",
      "Epoch: 7500, eg: 0.3532, (elbo, recon, kl)=(163370.1250, 162155.9062, 1089.7283)\n",
      "Epoch: 8000, eg: 0.3531, (elbo, recon, kl)=(163370.1406, 162155.8906, 1089.7576)\n",
      "Epoch: 8500, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7665)\n",
      "Epoch: 9000, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7688)\n",
      "Epoch: 9500, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7681)\n",
      "Epoch: 10000, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7722)\n",
      "Epoch: 10500, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7710)\n",
      "Epoch: 11000, eg: 0.3532, (elbo, recon, kl)=(163370.1250, 162155.8594, 1089.7720)\n",
      "Epoch: 11500, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7681)\n",
      "Epoch: 12000, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7679)\n",
      "Epoch: 12500, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7673)\n",
      "Epoch: 13000, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7689)\n",
      "Epoch: 13500, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7688)\n",
      "Epoch: 14000, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8750, 1089.7673)\n",
      "Epoch: 14500, eg: 0.3532, (elbo, recon, kl)=(163370.1406, 162155.8594, 1089.7742)\n",
      "Epoch: 0, eg: 1.8465, (elbo, recon, kl)=(166214.8906, 164612.3906, 1357.8385)\n",
      "Epoch: 500, eg: 1.5015, (elbo, recon, kl)=(164697.0938, 163511.7969, 1047.9741)\n",
      "Epoch: 1000, eg: 1.3706, (elbo, recon, kl)=(164288.5781, 163282.8906, 912.7609)\n",
      "Epoch: 1500, eg: 1.2995, (elbo, recon, kl)=(164132.1094, 163211.5625, 849.9948)\n",
      "Epoch: 2000, eg: 1.2637, (elbo, recon, kl)=(164060.6875, 163168.5781, 831.4963)\n",
      "Epoch: 2500, eg: 1.2466, (elbo, recon, kl)=(164021.5625, 163123.5938, 838.8643)\n",
      "Epoch: 3000, eg: 1.2253, (elbo, recon, kl)=(163996.9062, 163073.3906, 860.5193)\n",
      "Epoch: 3500, eg: 1.1669, (elbo, recon, kl)=(163979.2656, 163022.3281, 887.5190)\n",
      "Epoch: 4000, eg: 1.0378, (elbo, recon, kl)=(163962.9531, 162968.9688, 917.0300)\n",
      "Epoch: 4500, eg: 0.8314, (elbo, recon, kl)=(163941.6875, 162903.8125, 951.9668)\n",
      "Epoch: 5000, eg: 0.6126, (elbo, recon, kl)=(163914.9062, 162829.1406, 990.0344)\n",
      "Epoch: 5500, eg: 0.4689, (elbo, recon, kl)=(163892.6719, 162767.9531, 1020.6578)\n",
      "Epoch: 6000, eg: 0.4069, (elbo, recon, kl)=(163880.8125, 162732.0000, 1039.2117)\n",
      "Epoch: 6500, eg: 0.3874, (elbo, recon, kl)=(163876.1406, 162714.9844, 1048.5244)\n",
      "Epoch: 7000, eg: 0.3824, (elbo, recon, kl)=(163874.6719, 162707.9531, 1052.6403)\n",
      "Epoch: 7500, eg: 0.3810, (elbo, recon, kl)=(163874.2500, 162705.2344, 1054.3069)\n",
      "Epoch: 8000, eg: 0.3804, (elbo, recon, kl)=(163874.1406, 162704.2500, 1054.9318)\n",
      "Epoch: 8500, eg: 0.3801, (elbo, recon, kl)=(163874.1094, 162703.9219, 1055.1477)\n",
      "Epoch: 9000, eg: 0.3800, (elbo, recon, kl)=(163874.1250, 162703.8281, 1055.2159)\n",
      "Epoch: 9500, eg: 0.3800, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2352)\n",
      "Epoch: 10000, eg: 0.3799, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2396)\n",
      "Epoch: 10500, eg: 0.3799, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2407)\n",
      "Epoch: 11000, eg: 0.3799, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2400)\n",
      "Epoch: 11500, eg: 0.3799, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2397)\n",
      "Epoch: 12000, eg: 0.3799, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2404)\n",
      "Epoch: 12500, eg: 0.3799, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2408)\n",
      "Epoch: 13000, eg: 0.3799, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2402)\n",
      "Epoch: 13500, eg: 0.3799, (elbo, recon, kl)=(163874.1094, 162703.7812, 1055.2423)\n",
      "Epoch: 14000, eg: 0.3799, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2407)\n",
      "Epoch: 14500, eg: 0.3799, (elbo, recon, kl)=(163874.0938, 162703.7812, 1055.2395)\n",
      "Epoch: 0, eg: 1.7768, (elbo, recon, kl)=(165955.1719, 164394.7188, 1314.8480)\n",
      "Epoch: 500, eg: 1.4415, (elbo, recon, kl)=(164466.1875, 163293.0781, 1034.1616)\n",
      "Epoch: 1000, eg: 1.3228, (elbo, recon, kl)=(164049.8594, 163043.6562, 911.4764)\n",
      "Epoch: 1500, eg: 1.2568, (elbo, recon, kl)=(163886.3906, 162961.1719, 852.9827)\n",
      "Epoch: 2000, eg: 1.2333, (elbo, recon, kl)=(163814.0312, 162918.9375, 833.5495)\n",
      "Epoch: 2500, eg: 1.2538, (elbo, recon, kl)=(163777.2812, 162882.3438, 836.2756)\n",
      "Epoch: 3000, eg: 1.3192, (elbo, recon, kl)=(163753.9375, 162838.2969, 854.2703)\n",
      "Epoch: 3500, eg: 1.2755, (elbo, recon, kl)=(163734.9844, 162785.0625, 882.1248)\n",
      "Epoch: 4000, eg: 1.1718, (elbo, recon, kl)=(163716.6406, 162726.9531, 913.8608)\n",
      "Epoch: 4500, eg: 0.9870, (elbo, recon, kl)=(163696.7031, 162664.5781, 947.5051)\n",
      "Epoch: 5000, eg: 0.7609, (elbo, recon, kl)=(163675.9531, 162600.5156, 981.5718)\n",
      "Epoch: 5500, eg: 0.5758, (elbo, recon, kl)=(163659.5938, 162549.7344, 1008.4269)\n",
      "Epoch: 6000, eg: 0.4666, (elbo, recon, kl)=(163650.5000, 162520.4375, 1024.0112)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 6500, eg: 0.4153, (elbo, recon, kl)=(163646.6250, 162507.0625, 1031.2604)\n",
      "Epoch: 7000, eg: 0.3945, (elbo, recon, kl)=(163645.3125, 162502.0469, 1034.0525)\n",
      "Epoch: 7500, eg: 0.3869, (elbo, recon, kl)=(163644.9844, 162500.5000, 1034.9493)\n",
      "Epoch: 8000, eg: 0.3842, (elbo, recon, kl)=(163644.9375, 162500.0938, 1035.2029)\n",
      "Epoch: 8500, eg: 0.3833, (elbo, recon, kl)=(163644.9062, 162499.9844, 1035.2695)\n",
      "Epoch: 9000, eg: 0.3831, (elbo, recon, kl)=(163644.9062, 162499.9688, 1035.2849)\n",
      "Epoch: 9500, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2875)\n",
      "Epoch: 10000, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2877)\n",
      "Epoch: 10500, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2878)\n",
      "Epoch: 11000, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2878)\n",
      "Epoch: 11500, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2877)\n",
      "Epoch: 12000, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2878)\n",
      "Epoch: 12500, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2871)\n",
      "Epoch: 13000, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2877)\n",
      "Epoch: 13500, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2875)\n",
      "Epoch: 14000, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2880)\n",
      "Epoch: 14500, eg: 0.3830, (elbo, recon, kl)=(163644.9219, 162499.9688, 1035.2874)\n",
      "Epoch: 0, eg: 2.0536, (elbo, recon, kl)=(165870.9688, 164375.9375, 1246.3873)\n",
      "Epoch: 500, eg: 1.5561, (elbo, recon, kl)=(164403.4375, 163261.3750, 1001.1448)\n",
      "Epoch: 1000, eg: 1.3316, (elbo, recon, kl)=(164012.2812, 163014.2344, 901.3525)\n",
      "Epoch: 1500, eg: 1.1771, (elbo, recon, kl)=(163856.7969, 162932.3750, 850.5955)\n",
      "Epoch: 2000, eg: 1.0561, (elbo, recon, kl)=(163784.8281, 162886.6875, 835.2014)\n",
      "Epoch: 2500, eg: 0.9357, (elbo, recon, kl)=(163743.7500, 162837.3750, 845.1779)\n",
      "Epoch: 3000, eg: 0.7835, (elbo, recon, kl)=(163709.7656, 162761.4688, 880.3098)\n",
      "Epoch: 3500, eg: 0.6079, (elbo, recon, kl)=(163673.2969, 162656.3750, 935.4543)\n",
      "Epoch: 4000, eg: 0.4661, (elbo, recon, kl)=(163640.1719, 162556.9688, 987.7766)\n",
      "Epoch: 4500, eg: 0.3815, (elbo, recon, kl)=(163617.9531, 162491.5781, 1021.5417)\n",
      "Epoch: 5000, eg: 0.3406, (elbo, recon, kl)=(163606.0312, 162455.9531, 1039.9467)\n",
      "Epoch: 5500, eg: 0.3242, (elbo, recon, kl)=(163600.6719, 162438.6094, 1049.1602)\n",
      "Epoch: 6000, eg: 0.3184, (elbo, recon, kl)=(163598.6094, 162430.9062, 1053.4087)\n",
      "Epoch: 6500, eg: 0.3162, (elbo, recon, kl)=(163597.9062, 162427.7500, 1055.2188)\n",
      "Epoch: 7000, eg: 0.3151, (elbo, recon, kl)=(163597.7031, 162426.5625, 1055.9255)\n",
      "Epoch: 7500, eg: 0.3144, (elbo, recon, kl)=(163597.6406, 162426.1562, 1056.1714)\n",
      "Epoch: 8000, eg: 0.3140, (elbo, recon, kl)=(163597.6406, 162426.0469, 1056.2450)\n",
      "Epoch: 8500, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2638)\n",
      "Epoch: 9000, eg: 0.3138, (elbo, recon, kl)=(163597.6562, 162426.0312, 1056.2675)\n",
      "Epoch: 9500, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2682)\n",
      "Epoch: 10000, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2678)\n",
      "Epoch: 10500, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2682)\n",
      "Epoch: 11000, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2684)\n",
      "Epoch: 11500, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2683)\n",
      "Epoch: 12000, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2681)\n",
      "Epoch: 12500, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2681)\n",
      "Epoch: 13000, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2690)\n",
      "Epoch: 13500, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2686)\n",
      "Epoch: 14000, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2693)\n",
      "Epoch: 14500, eg: 0.3138, (elbo, recon, kl)=(163597.6406, 162426.0156, 1056.2681)\n",
      "Epoch: 0, eg: 1.8828, (elbo, recon, kl)=(165454.1406, 163953.2969, 1263.8823)\n",
      "Epoch: 500, eg: 1.5118, (elbo, recon, kl)=(164036.2188, 162894.6875, 1007.8730)\n",
      "Epoch: 1000, eg: 1.3657, (elbo, recon, kl)=(163614.0469, 162633.1875, 891.5574)\n",
      "Epoch: 1500, eg: 1.3013, (elbo, recon, kl)=(163434.8594, 162525.1719, 840.9021)\n",
      "Epoch: 2000, eg: 1.2947, (elbo, recon, kl)=(163351.2031, 162453.9219, 835.0295)\n",
      "Epoch: 2500, eg: 1.3202, (elbo, recon, kl)=(163308.3125, 162393.8281, 851.0629)\n",
      "Epoch: 3000, eg: 1.3534, (elbo, recon, kl)=(163284.0312, 162345.1719, 871.6936)\n",
      "Epoch: 3500, eg: 1.3824, (elbo, recon, kl)=(163268.6094, 162308.9375, 888.9225)\n",
      "Epoch: 4000, eg: 1.3984, (elbo, recon, kl)=(163257.2656, 162280.2344, 903.1257)\n",
      "Epoch: 4500, eg: 1.3584, (elbo, recon, kl)=(163247.0312, 162251.7500, 917.8329)\n",
      "Epoch: 5000, eg: 1.1444, (elbo, recon, kl)=(163230.7344, 162203.9531, 943.0358)\n",
      "Epoch: 5500, eg: 0.7176, (elbo, recon, kl)=(163189.8906, 162091.9844, 999.8726)\n",
      "Epoch: 6000, eg: 0.4410, (elbo, recon, kl)=(163151.6406, 161989.2656, 1050.6093)\n",
      "Epoch: 6500, eg: 0.3435, (elbo, recon, kl)=(163137.1719, 161944.6562, 1073.5817)\n",
      "Epoch: 7000, eg: 0.3129, (elbo, recon, kl)=(163133.4062, 161929.9219, 1081.6898)\n",
      "Epoch: 7500, eg: 0.3032, (elbo, recon, kl)=(163132.6094, 161925.4219, 1084.3530)\n",
      "Epoch: 8000, eg: 0.3002, (elbo, recon, kl)=(163132.5000, 161924.0938, 1085.2070)\n",
      "Epoch: 8500, eg: 0.2994, (elbo, recon, kl)=(163132.4844, 161923.7188, 1085.4485)\n",
      "Epoch: 9000, eg: 0.2992, (elbo, recon, kl)=(163132.4844, 161923.6406, 1085.5000)\n",
      "Epoch: 9500, eg: 0.2991, (elbo, recon, kl)=(163132.4844, 161923.6406, 1085.5071)\n",
      "Epoch: 10000, eg: 0.2991, (elbo, recon, kl)=(163132.5000, 161923.6406, 1085.5078)\n",
      "Epoch: 10500, eg: 0.2991, (elbo, recon, kl)=(163132.5000, 161923.6406, 1085.5078)\n",
      "Epoch: 11000, eg: 0.2991, (elbo, recon, kl)=(163132.5000, 161923.6406, 1085.5078)\n",
      "Epoch: 11500, eg: 0.2991, (elbo, recon, kl)=(163132.5000, 161923.6406, 1085.5078)\n",
      "Epoch: 12000, eg: 0.2991, (elbo, recon, kl)=(163132.4688, 161923.6250, 1085.5074)\n",
      "Epoch: 12500, eg: 0.2991, (elbo, recon, kl)=(163132.4844, 161923.6406, 1085.5073)\n",
      "Epoch: 13000, eg: 0.2991, (elbo, recon, kl)=(163132.5000, 161923.6406, 1085.5096)\n",
      "Epoch: 13500, eg: 0.2991, (elbo, recon, kl)=(163132.4844, 161923.6406, 1085.5070)\n",
      "Epoch: 14000, eg: 0.2991, (elbo, recon, kl)=(163132.5000, 161923.6406, 1085.5082)\n",
      "Epoch: 14500, eg: 0.2991, (elbo, recon, kl)=(163132.4844, 161923.6406, 1085.5073)\n"
     ]
    }
   ],
   "source": [
    "x_dim, z_dim=250, 1\n",
    "W0=torch.ones(x_dim, z_dim)\n",
    "num_epoch=15000\n",
    "beta, reg_param=1, 1\n",
    "alpha_list = [0.4*i for i in range(1, 14)]\n",
    "results = experiment.replica_reproduce_1rank(x_dim,  alpha_list, 5, device=device, rho=1, eta=1,\n",
    "                                             num_epoch=num_epoch,  beta=beta, lr=0.001, reg_param=reg_param)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "c383911d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "results_np=np.array(results)\n",
    "egs_np = results_np[:, :, -1]\n",
    "fig, ax = plt.subplots(figsize=(6.4, 4.8))\n",
    "ax.errorbar(np.array(alpha_list), egs_np.mean(axis=1), yerr=egs_np.std(axis=1), capsize=3, fmt='o', ecolor='tab:blue', ms=7, mfc='None', mec='tab:blue')\n",
    "ax.set_ylim([0, 2])\n",
    "ax.set_xlabel(r\"$\\alpha$\", fontsize=25)\n",
    "ax.set_ylabel(r\"$\\varepsilon_{g}$\", fontsize=25)\n",
    "ax.set_title(r\"$(\\beta_{\\mathrm{VAE}}, \\rho, \\eta, \\lambda)=(1.0, 1.0, 1.0, 1.0)$\", fontsize=15)\n",
    "ax.grid()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e28d75a",
   "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.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
