{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "zdgemk5nHdbL",
    "outputId": "332d9159-5b7e-488d-cdf1-803b67f11603"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:\n",
      "The TensorFlow contrib module will not be included in TensorFlow 2.0.\n",
      "For more information, please see:\n",
      "  * https://github.com/tensorflow/community/blob/master/rfcs/20180907-contrib-sunset.md\n",
      "  * https://github.com/tensorflow/addons\n",
      "  * https://github.com/tensorflow/io (for I/O related ops)\n",
      "If you depend on functionality not listed there, please file an issue.\n",
      "\n",
      "1.15.0\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline\n",
    "import os\n",
    "os.environ[\"CUDA_DEVICE_ORDER\"]=\"PCI_BUS_ID\"   # see issue #152\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]=\"0\"\n",
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "from IPython.display import display, clear_output\n",
    "import tensorflow as tf\n",
    "import tensorflow.keras.initializers as initializers\n",
    "import numpy as np\n",
    "import seaborn as sns; \n",
    "import imageio\n",
    "import glob\n",
    "import tensorflow_probability as tfp\n",
    "tfd = tfp.distributions\n",
    "from scipy.stats import norm, uniform, multivariate_normal, multivariate_t\n",
    "from scipy.special import softmax\n",
    "from sklearn.mixture import GaussianMixture\n",
    "import sys\n",
    "import gc\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "slim = tf.contrib.slim\n",
    "from tqdm.notebook import tqdm\n",
    "import sys\n",
    "from scipy.linalg import block_diag\n",
    "sys.path.append('../models/')\n",
    "sys.path.append('../')\n",
    "from ratio_utils_highdim_exp_fam import *\n",
    "tf.keras.backend.set_floatx('float32')\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_config(save_path,lrate=5e-3):    \n",
    "    data = [tf.placeholder(tf.float32, shape=[None,n_dims]) for _ in range(K)]\n",
    "\n",
    "    dloss = get_loss(data, bs, K, n_dims)\n",
    "    optim = get_optim(dloss,lr=lrate,steps=1500,alpha=0.0)\n",
    "\n",
    "    gt_log_ratio_p_q, gt_kl_p_q = get_gt_ratio_kl(p,q,data[0])\n",
    "    kl_from_cob = get_kl_from_cob(data[0], data[1], K, n_dims)\n",
    "\n",
    "    logit_store = [get_logits(d,K,n_dims) for d in data]\n",
    "\n",
    "    init = tf.global_variables_initializer()\n",
    "    sess = tf.Session()\n",
    "    sess.run(init)\n",
    "\n",
    "    loss_store=[]\n",
    "    test_loss_store=[]\n",
    "    test_loss_store1=[]\n",
    "    kld_store=[]\n",
    "    acc_store=[]\n",
    "    pbar = range(0,N)\n",
    "    plotted=False\n",
    "    for j in pbar:\n",
    "        for i in range(num_samples//bs):\n",
    "            feed_dict = {data[tr]:train_samples[tr][np.random.choice(range(num_samples),bs)] for tr in range(K)}\n",
    "\n",
    "            kl_gt,l,_ = sess.run([gt_kl_p_q, dloss, optim],feed_dict=feed_dict)\n",
    "            loss_store.append(l)\n",
    "\n",
    "            if plotted==False:\n",
    "                plotted=True\n",
    "\n",
    "                fig, [ax1,ax2,ax3,ax4,ax5] = plt.subplots(1, 5,figsize=(16,4))\n",
    "\n",
    "                line, = ax1.plot([0,1],[0,1])\n",
    "                test_line, = ax4.plot([0,1],[0,1],label='Test Loss')\n",
    "                test_line1, = ax4.plot([0,1],[0,1],label='Train Loss')\n",
    "                kld_line, = ax3.plot([0],[0],label='GT KLD: '+str(kl_gt))\n",
    "                x, y = np.random.random((2, 500))\n",
    "                np.random.randint\n",
    "                scat = ax2.scatter(x,y,label='GT LR vs CoB ',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "                acc_line, = ax5.plot([0,K],[0,100],marker='o',label='Accuracy')\n",
    "\n",
    "                ax1.set_xlabel(\"Iteration\")\n",
    "                ax1.set_ylabel(\"Train Loss\")\n",
    "                ax1.set_xlim([0,N*(num_samples//bs)])\n",
    "                ax1.set_ylim([-5,10])\n",
    "\n",
    "                ax2.set_xlabel(\"Log Ratio\")\n",
    "                ax2.set_ylabel(\"Log Ratio CoB\")\n",
    "                ax2.legend(loc='best')\n",
    "\n",
    "                ax3.set_ylabel(\"KLD\")\n",
    "                ax3.legend(loc='best')\n",
    "\n",
    "                ax4.set_xlabel(\"Epoch\")\n",
    "                ax4.set_ylabel(\"Test Loss\")\n",
    "                ax4.set_xlim([0,N//50])\n",
    "                ax4.set_ylim([-5,10])\n",
    "                ax4.legend(loc='best')\n",
    "\n",
    "                ax5.set_xlabel(\"Distributions\")\n",
    "                x_ticks_labels = ['p','q']+['m'+str(k+1) for k in range(K-2)]\n",
    "                ax5.set_xticks(range(K))\n",
    "                ax5.set_xticklabels(x_ticks_labels)\n",
    "                ax5.set_ylabel(\"Accuracy\")\n",
    "                ax5.legend(loc='best')\n",
    "\n",
    "\n",
    "                plt.tight_layout()\n",
    "\n",
    "            if i%100==0:\n",
    "                line.set_data(range(len(loss_store)), loss_store)\n",
    "                ax1.set_xlim( 0, len(loss_store) )\n",
    "\n",
    "                feed_dict = {data[te]:test_samples[te][np.random.choice(range(num_samples),bs)] for te in range(K)}\n",
    "\n",
    "                testl, kl_cob, lpq = sess.run([dloss, kl_from_cob, gt_log_ratio_p_q],feed_dict=feed_dict)\n",
    "                logit_store_np = sess.run(logit_store,feed_dict=feed_dict)\n",
    "\n",
    "                kld_store.append(kl_cob)\n",
    "                test_loss_store.append(testl)\n",
    "                test_loss_store1.append(l)\n",
    "\n",
    "                lpqm = logit_store_np[0]\n",
    "                cob=lpqm[:,0] - lpqm[:,1]\n",
    "                scat.set_offsets(np.asarray([lpq,cob]).T)\n",
    "                ax2.set_xlim( lpq.min(), lpq.max() )\n",
    "                ax2.set_ylim( cob.min(), cob.max()+10 )\n",
    "\n",
    "                kld_line.set_data(range(len(kld_store)),kld_store)\n",
    "                ax3.set_xlim( 0, len(kld_store) )\n",
    "                ax3.set_ylim( 0, kl_gt+50 )\n",
    "\n",
    "                test_line1.set_data(range(len(test_loss_store1)), test_loss_store1)\n",
    "                test_line.set_data(range(len(test_loss_store)), test_loss_store)\n",
    "                ax4.set_xlim( 0, len(test_loss_store) )\n",
    "                ax4.set_ylim([l.min()-5,testl.max()+5])\n",
    "\n",
    "                acc = [np.sum([np.argmax(logits_,1)==k])*100/bs for k,logits_ in enumerate(logit_store_np)]\n",
    "                acc_line.set_data(range(len(acc)), acc)\n",
    "\n",
    "                clear_output(wait=True)\n",
    "\n",
    "                display(fig)\n",
    "\n",
    "    print(np.std(kld_store[-10:]),np.mean(kld_store[-10:]))\n",
    "    with open(save_path+'/kld_store.npy', 'wb') as f:\n",
    "        np.save(f, kld_store)\n",
    "    plt.savefig(save_path+'/diagnostics.png')\n",
    "    clear_output()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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WYmJiaxataokwZOfn8+MGTMoKipi8eLFHHnkkfz1r39l/fr1bNy4kdTU1EpNNFDs8MMP59VXX2Xz5s1s2rSJV155hcMOO4xly5bRqFEjLrzwQm6++Wa+/fZbNm7cSE5ODieccAL3338/U6dOraG7rjvc/Tx3b+Pu8e7e3t0fc/c17j7M3btGnteW2v/P7r6vu3d3d1WFr0NuObY7yfE7zlqfHB/LLcd23+Nzvvjii1x88cUsXLiQBQsWsHjxYjp16sQBBxzAv//975L3trVr17LffvuxbNkyvvnmGwByc3MpKCggMzOTqVOnlrTpr78uu9NXceKnRYsWbNy4sWQWzrS0NNq3b19S1y4vL6/kb49LLrmk5P2zZ8/qSVhHZw8eJXhEpK4bPhyefbbaavCYGa+++io33ngjf/3rX2nZsiUpKSklwzYq609/+tMOH8R2Lojav39/+vbty/jx47nooot22NazZ09yc3Np165dSZ2O7Oxs7r33XuLj42ncuDFPP/10mdf83e9+R48ePUhKSiIlJYW7776bNm3acM8995TU2jnhhBNKPlBCUIMnNjaW/Px8xowZQ0ZGRpXuVWRn1dWOil111VX8/PPPnHLKKWRlZbF582bat29fsv2mm24C4L777uPZZ58tGav/wQcfUFy0s7waPHfffTdr1qwpqXsVFxfHpEmTiIuL45///CfHHnsshYWFXHbZZSV/FP773/8uieuEE07grbfeokuXLjRq1IgnnngCCOrsFHcTLygo4Pzzz+e4444DguKs55xzDo899hgdO3bkf//7HxAMERkzZgzx8fHExMTwr3/9ixYtWrBkyRL+/Oc/s99++5XUNrrmmmu44oor9ujfUwgSPFvXw9YcSGpSslrTpNddMTExJbM95uTkUFBQwA033EC3bt248MILycnJwd258cYbSU9P5+STT+ass85iwoQJPPTQQxx22GE7nO/JJ58s+SAI8OWXX3LJJZeU9GC94oor6N+/P++++y633HILMTExxMfH88gjj5Cbm8upp55a0mvgvvvuq81/CpG9clr/YEKze9+dxbL1W2ibnswtx3YvWb8nxo0bx6hRo3ZYd+aZZzJz5kw6duxInz59iI+P58orr+Saa67h+eef59prr2XLli0kJyfz/vvvM2TIEDp16lQyKUh5tfzS09O58sor6d27N5mZmTsM/37mmWf45S9/ye9//3vi4+P53//+R+fOncnIyGD//fcvqT9ZHayyXeTrgsQ2Xb3NiPv5/q7hpCXFhx2OCGY22d33foxMPTBgwAAvPd1ufTNz5kz233//sMOQCpT1f6Q2ul1daKNqRw2X2mfFStrn9JfhxUvhqs+gda+S7Q+8P4f73p/NT//vBGJjGnaZAv0eqX5qnxWrC++f0UrttWKbN2+md+/efPvttzRp0qTc/arSRqNyiJaKLIuIiIhIvVPOVOkJccGf7BqmJSJSP7z//vvst99+XHvttRUmd6pKQ7REREREROqC9I7Bc87iHVaXTvAkJ8TufJSIiESZo48+mkWLyp7+fW9EZQ+ewigaViYSDcws1symmNkbkeVmZvaemc2JPDcNO8a6IJqGtDY0+r+JHvq/anj0f14FKS0gLrncHjx5hZrwR0Sii94D9k5V//2iMsFTpN6pItXtemBmqeVRwER37wpMjCw3aElJSaxZs0ZvUnWQu7NmzRqSkpLCDkV2Q+2o4VH7rCKzyExaC3dYnRgbSfDk649gEYkeet/fO3vyHhqVQ7QKlOERqTZm1h44EfgzcFNk9anA0Mjrp4Bs4Nbajq0uad++PUuWLGHVqlVhhyJlSEpK2mH2Iqmb1I4aJrXPKkrvUH4NHs2kJSJRRO/7e6+q76FRmeBRfkekWt0P/BZILbUuw92XA7j7cjNrVdaBZjYSGAnQsWPHGg4zXPHx8XTq1CnsMESimtqRSCWkd4Slk3dYpSLLIhKN9L5f+6JyiJZq8IhUDzM7CVjp7pN3u3MZ3H2suw9w9wEtW7as5uhEREQaoPSOsGUd5OWWrEqIVYKnrlizZg39+vWjX79+tG7dmnbt2pUsb9u2rcJjJ02axHXXXVel62VmZrJ69eq9CVlEGpCo7MGjWbREqs0Q4BQzOwFIAtLM7FlghZm1ifTeaQOsDDVKERGRhqJ4Jq31iyGjB6AhWnVJ8+bNmTp1KgB33XUXjRs35uabby7ZXlBQQFxc2R+xBgwYwIABA2ojTBFpoKKyB0+RevCIVAt3H+3u7d09EzgX+MDdLwReA0ZEdhsBTAgpRBERkYYlfZ/guVQdHg3RqtsuueQSbrrpJo488khuvfVWvv76awYPHkz//v0ZPHgws2bNAiA7O5uTTjoJCJJDl112GUOHDqVz5848+OCDlb7ewoULGTZsGH369GHYsGElUy3/73//o1evXvTt25fDDz8cgBkzZjBw4ED69etHnz59mDNnTjXfvYjUJaH24DGzG4ErAAemAZe6+9bdHacePCI1bgzwgpldDiwCzg45HhERkYahSYfgWQme3Xt7FPw8rXrP2bo3HD+myofNnj2b999/n9jYWDZs2MDHH39MXFwc77//PrfddhsvvfTSLsf8+OOPfPjhh+Tm5tK9e3d+9atfER8fv9trXXPNNVx88cWMGDGCxx9/nOuuu45XX32Vu+++m3fffZd27dqxfv16AP79739z/fXXc8EFF7Bt2zYKCwurfG8iEj1CS/CYWTvgOqCHu28xsxcIehA8ubtjleARqX7unk0wWxbuvgYYFmY8IiIiDVLjVhCXBDmlEjzF06QrwVNnnX322cTGxgKQk5PDiBEjmDNnDmZGfn5+mceceOKJJCYmkpiYSKtWrVixYkWlZsv54osvePnllwG46KKL+O1vfwvAkCFDuOSSSzjnnHM444wzADjkkEP485//zJIlSzjjjDPo2rVrddyuiNRRYdfgiQOSzSwfaAQsq8xBSvCIiEhDYWbpwKNAL4Ier5cBs4DngUxgAXCOu68LJ0IRqVZmQS+eUj14kuJVg6dMe9DTpqakpKSUvL7jjjs48sgjeeWVV1iwYAFDhw4t85jExMSS17GxsRQUFOzRtc0MCHrrfPXVV7z55pv069ePqVOncv755zNo0CDefPNNjj32WB599FGOOuqoPbqOiNR9odXgcfelwN8Ihn8sB3LcPWvn/cxspJlNMrNJqbFBl0LNoiUiIg3IA8A77r4f0BeYCYwCJrp7V2BiZFlE6ov0jjsO0Yr0DNEQreiQk5NDu3btAHjyySer/fyDBw9m/PjxADz33HMceuihAPz0008MGjSIu+++mxYtWrB48WLmzZtH586due666zjllFP4/vvvqz0eEak7QkvwmFlT4FSgE9AWSDGzC3fer/Q0zC3S0wAoUg8eERFpAMwsDTgceAzA3be5+3qC98+nIrs9BZwWRnwiUkPSO6gGTxT77W9/y+jRoxkyZEi11Lzp06cP7du3p3379tx00008+OCDPPHEE/Tp04dnnnmGBx54AIBbbrmF3r1706tXLw4//HD69u3L888/T69evejXrx8//vgjF1988V7HIyJ1V5hDtI4G5rv7KgAzexkYDDxb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\n",
      "text/plain": [
       "<Figure size 1152x288 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-36-50bde6e3a09b>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     91\u001b[0m         \u001b[0m_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0m_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtest_samples\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mget_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmu_1\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mmu_2\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mscale_p\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mscale_q\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     92\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 93\u001b[0;31m         \u001b[0mrun_config\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msave_path\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mlrate\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     94\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     95\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-9-9bff0056cc9e>\u001b[0m in \u001b[0;36mrun_config\u001b[0;34m(save_path, lrate)\u001b[0m\n\u001b[1;32m     23\u001b[0m     \u001b[0;32mfor\u001b[0m \u001b[0mj\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpbar\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     24\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnum_samples\u001b[0m\u001b[0;34m//\u001b[0m\u001b[0mbs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 25\u001b[0;31m             \u001b[0mfeed_dict\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mtrain_samples\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrandom\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mchoice\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnum_samples\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mbs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mtr\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     26\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     27\u001b[0m             \u001b[0mkl_gt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0ml\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0m_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msess\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mgt_kl_p_q\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdloss\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0moptim\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mfeed_dict\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mfeed_dict\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-9-9bff0056cc9e>\u001b[0m in \u001b[0;36m<dictcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m     23\u001b[0m     \u001b[0;32mfor\u001b[0m \u001b[0mj\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mpbar\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     24\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnum_samples\u001b[0m\u001b[0;34m//\u001b[0m\u001b[0mbs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 25\u001b[0;31m             \u001b[0mfeed_dict\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mtrain_samples\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mtr\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrandom\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mchoice\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnum_samples\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mbs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mtr\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mK\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     26\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     27\u001b[0m             \u001b[0mkl_gt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0ml\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0m_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msess\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mgt_kl_p_q\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdloss\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0moptim\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mfeed_dict\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mfeed_dict\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32mmtrand.pyx\u001b[0m in \u001b[0;36mnumpy.random.mtrand.RandomState.choice\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32m<__array_function__ internals>\u001b[0m in \u001b[0;36mprod\u001b[0;34m(*args, **kwargs)\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    },
    {
     "data": {
      "image/png": "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WYmJiaxataokwZOfn8+MGTMoKipi8eLFHHnkkfz1r39l/fr1bNy4kdTU1EpNNFDs8MMP59VXX2Xz5s1s2rSJV155hcMOO4xly5bRqFEjLrzwQm6++Wa+/fZbNm7cSE5ODieccAL3338/U6dOraG7rjvc/Tx3b+Pu8e7e3t0fc/c17j7M3btGnteW2v/P7r6vu3d3d1WFr0NuObY7yfE7zlqfHB/LLcd23+Nzvvjii1x88cUsXLiQBQsWsHjxYjp16sQBBxzAv//975L3trVr17LffvuxbNkyvvnmGwByc3MpKCggMzOTqVOnlrTpr78uu9NXceKnRYsWbNy4sWQWzrS0NNq3b19S1y4vL6/kb49LLrmk5P2zZ8/qSVhHZw8eJXhEpK4bPhyefbbaavCYGa+++io33ngjf/3rX2nZsiUpKSklwzYq609/+tMOH8R2Lojav39/+vbty/jx47nooot22NazZ09yc3Np165dSZ2O7Oxs7r33XuLj42ncuDFPP/10mdf83e9+R48ePUhKSiIlJYW7776bNm3acM8995TU2jnhhBNKPlBCUIMnNjaW/Px8xowZQ0ZGRpXuVWRn1dWOil111VX8/PPPnHLKKWRlZbF582bat29fsv2mm24C4L777uPZZ58tGav/wQcfUFy0s7waPHfffTdr1qwpqXsVFxfHpEmTiIuL45///CfHHnsshYWFXHbZZSV/FP773/8uieuEE07grbfeokuXLjRq1IgnnngCCOrsFHcTLygo4Pzzz+e4444DguKs55xzDo899hgdO3bkf//7HxAMERkzZgzx8fHExMTwr3/9ixYtWrBkyRL+/Oc/s99++5XUNrrmmmu44oor9ujfUwgSPFvXw9YcSGpSslrTpNddMTExJbM95uTkUFBQwA033EC3bt248MILycnJwd258cYbSU9P5+STT+ass85iwoQJPPTQQxx22GE7nO/JJ58s+SAI8OWXX3LJJZeU9GC94oor6N+/P++++y633HILMTExxMfH88gjj5Cbm8upp55a0mvgvvvuq81/CpG9clr/YEKze9+dxbL1W2ibnswtx3YvWb8nxo0bx6hRo3ZYd+aZZzJz5kw6duxInz59iI+P58orr+Saa67h+eef59prr2XLli0kJyfz/vvvM2TIEDp16lQyKUh5tfzS09O58sor6d27N5mZmTsM/37mmWf45S9/ye9//3vi4+P53//+R+fOncnIyGD//fcvqT9ZHayyXeTrgsQ2Xb3NiPv5/q7hpCXFhx2OCGY22d33foxMPTBgwAAvPd1ufTNz5kz233//sMOQCpT1f6Q2ul1daKNqRw2X2mfFStrn9JfhxUvhqs+gda+S7Q+8P4f73p/NT//vBGJjGnaZAv0eqX5qnxWrC++f0UrttWKbN2+md+/efPvttzRp0qTc/arSRqNyiJaKLIuIiIhIvVPOVOkJccGf7BqmJSJSP7z//vvst99+XHvttRUmd6pKQ7REREREROqC9I7Bc87iHVaXTvAkJ8TufJSIiESZo48+mkWLyp7+fW9EZQ+ewigaViYSDcws1symmNkbkeVmZvaemc2JPDcNO8a6IJqGtDY0+r+JHvq/anj0f14FKS0gLrncHjx5hZrwR0Sii94D9k5V//2iMsFTpN6pItXtemBmqeVRwER37wpMjCw3aElJSaxZs0ZvUnWQu7NmzRqSkpLCDkV2Q+2o4VH7rCKzyExaC3dYnRgbSfDk649gEYkeet/fO3vyHhqVQ7QKlOERqTZm1h44EfgzcFNk9anA0Mjrp4Bs4Nbajq0uad++PUuWLGHVqlVhhyJlSEpK2mH2Iqmb1I4aJrXPKkrvUH4NHs2kJSJRRO/7e6+q76FRmeBRfkekWt0P/BZILbUuw92XA7j7cjNrVdaBZjYSGAnQsWPHGg4zXPHx8XTq1CnsMESimtqRSCWkd4Slk3dYpSLLIhKN9L5f+6JyiJZq8IhUDzM7CVjp7pN3u3MZ3H2suw9w9wEtW7as5uhEREQaoPSOsGUd5OWWrEqIVYKnrlizZg39+vWjX79+tG7dmnbt2pUsb9u2rcJjJ02axHXXXVel62VmZrJ69eq9CVlEGpCo7MGjWbREqs0Q4BQzOwFIAtLM7FlghZm1ifTeaQOsDDVKERGRhqJ4Jq31iyGjB6AhWnVJ8+bNmTp1KgB33XUXjRs35uabby7ZXlBQQFxc2R+xBgwYwIABA2ojTBFpoKKyB0+RevCIVAt3H+3u7d09EzgX+MDdLwReA0ZEdhsBTAgpRBERkYYlfZ/guVQdHg3RqtsuueQSbrrpJo488khuvfVWvv76awYPHkz//v0ZPHgws2bNAiA7O5uTTjoJCJJDl112GUOHDqVz5848+OCDlb7ewoULGTZsGH369GHYsGElUy3/73//o1evXvTt25fDDz8cgBkzZjBw4ED69etHnz59mDNnTjXfvYjUJaH24DGzG4ErAAemAZe6+9bdHacePCI1bgzwgpldDiwCzg45HhERkYahSYfgWQme3Xt7FPw8rXrP2bo3HD+myofNnj2b999/n9jYWDZs2MDHH39MXFwc77//PrfddhsvvfTSLsf8+OOPfPjhh+Tm5tK9e3d+9atfER8fv9trXXPNNVx88cWMGDGCxx9/nOuuu45XX32Vu+++m3fffZd27dqxfv16AP79739z/fXXc8EFF7Bt2zYKCwurfG8iEj1CS/CYWTvgOqCHu28xsxcIehA8ubtjleARqX7unk0wWxbuvgYYFmY8IiIiDVLjVhCXBDmlEjzF06QrwVNnnX322cTGxgKQk5PDiBEjmDNnDmZGfn5+mceceOKJJCYmkpiYSKtWrVixYkWlZsv54osvePnllwG46KKL+O1vfwvAkCFDuOSSSzjnnHM444wzADjkkEP485//zJIlSzjjjDPo2rVrddyuiNRRYdfgiQOSzSwfaAQsq8xBSvCIiEhDYWbpwKNAL4Ier5cBs4DngUxgAXCOu68LJ0IRqVZmQS+eUj14kuJVg6dMe9DTpqakpKSUvL7jjjs48sgjeeWVV1iwYAFDhw4t85jExMSS17GxsRQUFOzRtc0MCHrrfPXVV7z55pv069ePqVOncv755zNo0CDefPNNjj32WB599FGOOuqoPbqOiNR9odXgcfelwN8Ihn8sB3LcPWvn/cxspJlNMrNJqbFBl0LNoiUiIg3IA8A77r4f0BeYCYwCJrp7V2BiZFlE6ov0jjsO0Yr0DNEQreiQk5NDu3btAHjyySer/fyDBw9m/PjxADz33HMceuihAPz0008MGjSIu+++mxYtWrB48WLmzZtH586due666zjllFP4/vvvqz0eEak7QkvwmFlT4FSgE9AWSDGzC3fer/Q0zC3S0wAoUg8eERFpAMwsDTgceAzA3be5+3qC98+nIrs9BZwWRnwiUkPSO6gGTxT77W9/y+jRoxkyZEi11Lzp06cP7du3p3379tx00008+OCDPPHEE/Tp04dnnnmGBx54AIBbbrmF3r1706tXLw4//HD69u3L888/T69evejXrx8//vgjF1988V7HIyJ1V5hDtI4G5rv7KgAzexkYDDxb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\n",
      "text/plain": [
       "<Figure size 1152x288 with 5 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Config\n",
    "n_dims = 40\n",
    "K=4\n",
    "num_samples=100000\n",
    "mi = 20\n",
    "bs=500\n",
    "N=10\n",
    "random_means=False\n",
    "mean_range=[[0,0],[-1.,1.]] #[0,0],[-0.5,0.5],\n",
    "lrate=5e-2\n",
    "\n",
    "\n",
    "reset(1)\n",
    "\n",
    "def get_rho_from_mi(mi, n_dims):\n",
    "    \"\"\"Get correlation coefficient from true mutual information\"\"\"\n",
    "    x = (4 * mi) / n_dims\n",
    "    return (1 - np.exp(-x)) ** 0.5  # correlation coefficient\n",
    "        \n",
    "def get_data(mu_1=0.,mu_2=2.,scale_p=0.1,scale_q=0.1,K=5):\n",
    "    \n",
    "    p_dist = multivariate_normal(mean=mu_1,cov=scale_p)\n",
    "    q_dist = multivariate_normal(mean=mu_2,cov=scale_q)\n",
    "        \n",
    "    p_samples_ = p_dist.rvs(size=num_samples) \n",
    "    q_samples_ = q_dist.rvs(size=num_samples)\n",
    "    \n",
    "    if K==5:\n",
    "        alpha = [0.,0.35,0.5,.85,1.]\n",
    "        if np.sum(mu_1)==0:\n",
    "            alpha = [0.,0.25,0.5,.75,1.]\n",
    "    else:\n",
    "        alpha = [0.,0.15,0.35,0.5,.75,.95,1.]\n",
    "\n",
    "    samples=[0]*len(alpha)\n",
    "    samples[0]=p_samples_\n",
    "    samples[1]=q_samples_\n",
    "    for i,a in enumerate(alpha[1:-1]):\n",
    "        samples[i+2] = np.sqrt(1-a**2)*p_samples_ + a*q_samples_ \n",
    "#         samples[i+2] = (1-a)*p_samples_ + a*q_samples_\n",
    "\n",
    "    p_dist_return = tfd.MultivariateNormalFullCovariance(\n",
    "        loc=mu_1,\n",
    "        covariance_matrix=scale_p)\n",
    "    \n",
    "    q_dist_return = tfd.MultivariateNormalDiag(\n",
    "        loc=mu_2,\n",
    "        scale_diag=scale_q)\n",
    "    \n",
    "    return p_dist_return,q_dist_return,samples\n",
    "\n",
    "def get_params(means,random_means,mi,n_dims):\n",
    "    \n",
    "    if random_means==False:\n",
    "        mu_1=means[0]+np.zeros((n_dims), dtype=\"float32\")\n",
    "        mu_2=means[1]+np.zeros((n_dims), dtype=\"float32\")\n",
    "    else:\n",
    "        mu_1=np.float32(np.random.uniform(low=means[0],high=means[1],size=(n_dims)))\n",
    "        mu_2=np.float32(np.random.uniform(low=means[0],high=means[1],size=(n_dims)))\n",
    "   \n",
    "    rho = get_rho_from_mi(mi, n_dims)  # correlation coefficient\n",
    "    rhos = np.ones(n_dims // 2, dtype=\"float32\") * rho\n",
    "\n",
    "    scale_p = block_diag(*[[[1, rho], [rho, 1]] for _ in range(n_dims // 2)])\n",
    "    scale_p = np.float32(scale_p)\n",
    "    scale_q = np.ones(n_dims, dtype=\"float32\")\n",
    "    \n",
    "    return mu_1,mu_2,scale_p,scale_q\n",
    "\n",
    "for means in mean_range:\n",
    "    mu_1,mu_2,scale_p,scale_q = get_params(means,random_means,mi,n_dims)\n",
    "    \n",
    "    for run in range(3):\n",
    "        save_path = '../results/'+str(K)+'--'+str(n_dims)+'--'+str(mi)+'--'+str(random_means)+','+str(means)+'-LR:-'+str(lrate)+'--'+'run_number'+str(run)\n",
    "\n",
    "        # Check whether the specified path exists or not\n",
    "        isExist = os.path.exists(save_path)\n",
    "\n",
    "        if not isExist:\n",
    "            # Create a new directory because it does not exist \n",
    "            os.makedirs(save_path)\n",
    "            print(\"The new directory is created!\")\n",
    "            \n",
    "        if random_means:    \n",
    "            with open(save_path+'/mu_1.npy', 'wb') as f1:\n",
    "                np.save(f1, mu_1)\n",
    "            with open(save_path+'/mu_2.npy', 'wb') as f2:\n",
    "                np.save(f2, mu_2)\n",
    "            \n",
    "        p, q, train_samples = get_data(mu_1,mu_2,scale_p,scale_q,K)\n",
    "        _, _, test_samples = get_data(mu_1,mu_2,scale_p,scale_q,K)\n",
    "            \n",
    "        run_config(save_path,lrate)\n",
    "    \n",
    "\n",
    "        gc.collect()\n",
    "        reset(run)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2.4944372 204.89926\n"
     ]
    }
   ],
   "source": [
    "print(np.std(kld_store[-10:]),np.mean(kld_store[-10:]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8495261 143.33646\n"
     ]
    }
   ],
   "source": [
    "print(np.std(kld_store[-10:]),np.mean(kld_store[-10:]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.74326473 86.66087\n"
     ]
    }
   ],
   "source": [
    "print(np.std(kld_store[-10:]),np.mean(kld_store[-10:]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.3766673 242.76453\n"
     ]
    }
   ],
   "source": [
    "print(np.std(kld_store[-10:]),np.mean(kld_store[-10:]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.20557813 35.241768\n"
     ]
    }
   ],
   "source": [
    "print(np.std(kld_store[-10:]),np.mean(kld_store[-10:]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def kl(m1, s1, m2, s2):\n",
    "    return np.log(s2)-np.log(s1)+(s1**2 + (m1-m2)**2)/(2*s2**2)-1/2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f202410ff90>]"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(test_loss_store1[:])\n",
    "plt.plot(test_loss_store[:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "/disk_c/han/cob/notebooks/<ipython-input-9-9bff0056cc9e>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "code = 'def run_config(save_path,lrate=5e-3):    \\n    data = [tf.placeholder(tf.float32, shape=[None,n_dims]) for _ in range(K)]\\n\\n    dloss = get_loss(data, bs, K, n_dims)\\n    optim = get_optim(dloss,lr=lrate,steps=1500,alpha=0.0)\\n\\n    gt_log_ratio_p_q, gt_kl_p_q = get_gt_ratio_kl(p,q,data[0])\\n    kl_from_cob = get_kl_from_cob(data[0], data[1], K, n_dims)\\n\\n    logit_store = [get_logits(d,K,n_dims) for d in data]\\n\\n    init = tf.global_variables_initializer()\\n    sess = tf.Session()\\n    sess.run(init)\\n\\n    loss_store=[]\\n    test_loss_store=[]\\n    test_loss_store1=[]\\n    kld_store=[]\\n    acc_store=[]\\n    pbar = range(0,N)\\n    plotted=False\\n    for j in pbar:\\n        for i in range(num_samples//bs):\\n            feed_dict = {data[tr]:train_samples[tr][np.random.choice(range(num_samples),bs)] for tr in range(K)}\\n\\n            kl_gt,l,_ = sess.run([gt_kl_p_q, dloss, optim],feed_dict=feed_dict)\\n            loss_store.append(l)\\n\\n            if plotted==False:\\n                plotted=True\\n\\n                fig, [ax1,ax2,ax3,ax4,ax5] = plt.subplots(1, 5,figsize=(16,4))\\n\\n                line, = ax1.plot([0,1],[0,1])\\n                test_line, = ax4.plot([0,1],[0,1],label=\\'Test Loss\\')\\n                test_line1, = ax4.plot([0,1],[0,1],label=\\'Train Loss\\')\\n                kld_line, = ax3.plot([0],[0],label=\\'GT KLD: \\'+str(kl_gt))\\n                x, y = np.random.random((2, 500))\\n                np.random.randint\\n                scat = ax2.scatter(x,y,label=\\'GT LR vs CoB \\',alpha=0.9,s=10.,c=\\'r\\')\\n\\n                acc_line, = ax5.plot([0,K],[0,100],marker=\\'o\\',label=\\'Accuracy\\')\\n\\n                ax1.set_xlabel(\"Iteration\")\\n                ax1.set_ylabel(\"Train Loss\")\\n                ax1.set_xlim([0,N*(num_samples//bs)])\\n                ax1.set_ylim([-5,10])\\n\\n                ax2.set_xlabel(\"Log Ratio\")\\n                ax2.set_ylabel(\"Log Ratio CoB\")\\n                ax2.legend(loc=\\'best\\')\\n\\n                ax3.set_ylabel(\"KLD\")\\n                ax3.legend(loc=\\'best\\')\\n\\n                ax4.set_xlabel(\"Epoch\")\\n                ax4.set_ylabel(\"Test Loss\")\\n                ax4.set_xlim([0,N//50])\\n                ax4.set_ylim([-5,10])\\n                ax4.legend(loc=\\'best\\')\\n\\n                ax5.set_xlabel(\"Distributions\")\\n                x_ticks_labels = [\\'p\\',\\'q\\']+[\\'m\\'+str(k+1) for k in range(K-2)]\\n                ax5.set_xticks(range(K))\\n                ax5.set_xticklabels(x_ticks_labels)\\n                ax5.set_ylabel(\"Accuracy\")\\n                ax5.legend(loc=\\'best\\')\\n\\n\\n                plt.tight_layout()\\n\\n            if i%100==0:\\n                line.set_data(range(len(loss_store)), loss_store)\\n                ax1.set_xlim( 0, len(loss_store) )\\n\\n                feed_dict = {data[te]:test_samples[te][np.random.choice(range(num_samples),bs)] for te in range(K)}\\n\\n                testl, kl_cob, lpq = sess.run([dloss, kl_from_cob, gt_log_ratio_p_q],feed_dict=feed_dict)\\n                logit_store_np = sess.run(logit_store,feed_dict=feed_dict)\\n\\n                kld_store.append(kl_cob)\\n                test_loss_store.append(testl)\\n                test_loss_store1.append(l)\\n\\n                lpqm = logit_store_np[0]\\n                cob=lpqm[:,0] - lpqm[:,1]\\n                scat.set_offsets(np.asarray([lpq,cob]).T)\\n                ax2.set_xlim( lpq.min(), lpq.max() )\\n                ax2.set_ylim( cob.min(), cob.max()+10 )\\n\\n                kld_line.set_data(range(len(kld_store)),kld_store)\\n                ax3.set_xlim( 0, len(kld_store) )\\n                ax3.set_ylim( 0, kl_gt+50 )\\n\\n                test_line1.set_data(range(len(test_loss_store1)), test_loss_store1)\\n                test_line.set_data(range(len(test_loss_store)), test_loss_store)\\n                ax4.set_xlim( 0, len(test_loss_store) )\\n                ax4.set_ylim([l.min()-5,testl.max()+5])\\n\\n                acc = [np.sum([np.argmax(logits_,1)==k])*100/bs for k,logits_ in enumerate(logit_store_np)]\\n                acc_line.set_data(range(len(acc)), acc)\\n\\n                clear_output(wait=True)\\n\\n                display(fig)\\n\\n    print(np.std(kld_store[-10:]),np.mean(kld_store[-10:]))\\n    with open(save_path+\\'/kld_store.npy\\', \\'wb\\') as f:\\n        np.save(f, kld_store)\\n    plt.savefig(save_path+\\'/diagnostics.png\\')\\n    clear_output()'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "def run_config(save_path,lrate=5e-3):    \n",
      "    data = [tf.placeholder(tf.float32, shape=[None,n_dims]) for _ in range(K)]\n",
      "\n",
      "    dloss = get_loss(data, bs, K, n_dims)\n",
      "    optim = get_optim(dloss,lr=lrate,steps=1500,alpha=0.0)\n",
      "\n",
      "    gt_log_ratio_p_q, gt_kl_p_q = get_gt_ratio_kl(p,q,data[0])\n",
      "    kl_from_cob = get_kl_from_cob(data[0], data[1], K, n_dims)\n",
      "\n",
      "    logit_store = [get_logits(d,K,n_dims) for d in data]\n",
      "\n",
      "    init = tf.global_variables_initializer()\n",
      "    sess = tf.Session()\n",
      "    sess.run(init)\n",
      "\n",
      "    loss_store=[]\n",
      "    test_loss_store=[]\n",
      "    test_loss_store1=[]\n",
      "    kld_store=[]\n",
      "    acc_store=[]\n",
      "    pbar = range(0,N)\n",
      "    plotted=False\n",
      "    for j in pbar:\n",
      "        for i in range(num_samples//bs):\n",
      "            feed_dict = {data[tr]:train_samples[tr][np.random.choice(range(num_samples),bs)] for tr in range(K)}\n",
      "\n",
      "            kl_gt,l,_ = sess.run([gt_kl_p_q, dloss, optim],feed_dict=feed_dict)\n",
      "            loss_store.append(l)\n",
      "\n",
      "            if plotted==False:\n",
      "                plotted=True\n",
      "\n",
      "                fig, [ax1,ax2,ax3,ax4,ax5] = plt.subplots(1, 5,figsize=(16,4))\n",
      "\n",
      "                line, = ax1.plot([0,1],[0,1])\n",
      "                test_line, = ax4.plot([0,1],[0,1],label='Test Loss')\n",
      "                test_line1, = ax4.plot([0,1],[0,1],label='Train Loss')\n",
      "                kld_line, = ax3.plot([0],[0],label='GT KLD: '+str(kl_gt))\n",
      "                x, y = np.random.random((2, 500))\n",
      "                np.random.randint\n",
      "                scat = ax2.scatter(x,y,label='GT LR vs CoB ',alpha=0.9,s=10.,c='r')\n",
      "\n",
      "                acc_line, = ax5.plot([0,K],[0,100],marker='o',label='Accuracy')\n",
      "\n",
      "                ax1.set_xlabel(\"Iteration\")\n",
      "                ax1.set_ylabel(\"Train Loss\")\n",
      "                ax1.set_xlim([0,N*(num_samples//bs)])\n",
      "                ax1.set_ylim([-5,10])\n",
      "\n",
      "                ax2.set_xlabel(\"Log Ratio\")\n",
      "                ax2.set_ylabel(\"Log Ratio CoB\")\n",
      "                ax2.legend(loc='best')\n",
      "\n",
      "                ax3.set_ylabel(\"KLD\")\n",
      "                ax3.legend(loc='best')\n",
      "\n",
      "                ax4.set_xlabel(\"Epoch\")\n",
      "                ax4.set_ylabel(\"Test Loss\")\n",
      "                ax4.set_xlim([0,N//50])\n",
      "                ax4.set_ylim([-5,10])\n",
      "                ax4.legend(loc='best')\n",
      "\n",
      "                ax5.set_xlabel(\"Distributions\")\n",
      "                x_ticks_labels = ['p','q']+['m'+str(k+1) for k in range(K-2)]\n",
      "                ax5.set_xticks(range(K))\n",
      "                ax5.set_xticklabels(x_ticks_labels)\n",
      "                ax5.set_ylabel(\"Accuracy\")\n",
      "                ax5.legend(loc='best')\n",
      "\n",
      "\n",
      "                plt.tight_layout()\n",
      "\n",
      "            if i%100==0:\n",
      "                line.set_data(range(len(loss_store)), loss_store)\n",
      "                ax1.set_xlim( 0, len(loss_store) )\n",
      "\n",
      "                feed_dict = {data[te]:test_samples[te][np.random.choice(range(num_samples),bs)] for te in range(K)}\n",
      "\n",
      "                testl, kl_cob, lpq = sess.run([dloss, kl_from_cob, gt_log_ratio_p_q],feed_dict=feed_dict)\n",
      "                logit_store_np = sess.run(logit_store,feed_dict=feed_dict)\n",
      "\n",
      "                kld_store.append(kl_cob)\n",
      "                test_loss_store.append(testl)\n",
      "                test_loss_store1.append(l)\n",
      "\n",
      "                lpqm = logit_store_np[0]\n",
      "                cob=lpqm[:,0] - lpqm[:,1]\n",
      "                scat.set_offsets(np.asarray([lpq,cob]).T)\n",
      "                ax2.set_xlim( lpq.min(), lpq.max() )\n",
      "                ax2.set_ylim( cob.min(), cob.max()+10 )\n",
      "\n",
      "                kld_line.set_data(range(len(kld_store)),kld_store)\n",
      "                ax3.set_xlim( 0, len(kld_store) )\n",
      "                ax3.set_ylim( 0, kl_gt+50 )\n",
      "\n",
      "                test_line1.set_data(range(len(test_loss_store1)), test_loss_store1)\n",
      "                test_line.set_data(range(len(test_loss_store)), test_loss_store)\n",
      "                ax4.set_xlim( 0, len(test_loss_store) )\n",
      "                ax4.set_ylim([l.min()-5,testl.max()+5])\n",
      "\n",
      "                acc = [np.sum([np.argmax(logits_,1)==k])*100/bs for k,logits_ in enumerate(logit_store_np)]\n",
      "                acc_line.set_data(range(len(acc)), acc)\n",
      "\n",
      "                clear_output(wait=True)\n",
      "\n",
      "                display(fig)\n",
      "\n",
      "    print(np.std(kld_store[-10:]),np.mean(kld_store[-10:]))\n",
      "    with open(save_path+'/kld_store.npy', 'wb') as f:\n",
      "        np.save(f, kld_store)\n",
      "    plt.savefig(save_path+'/diagnostics.png')\n",
      "    clear_output()\n"
     ]
    }
   ],
   "source": [
    "print(code)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Config: -120, -120, -200, 4000"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "Experiment_CoB_Simple.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "tf1.15",
   "language": "python",
   "name": "tf1.15"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
