{
 "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 warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "from IPython.display import display, clear_output\n",
    "from time import sleep\n",
    "from livelossplot import PlotLosses\n",
    "import tensorflow as tf\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\n",
    "import sys\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",
    "sys.path.append('../models/')\n",
    "sys.path.append('../')\n",
    "from kl_utils import *\n",
    "\n",
    "print(tf.__version__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "QH5eP5NclBEf",
    "outputId": "1c6f6465-8bb3-4583-c235-2c914da988fb"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:tensorflow:From ../models/kl_utils.py:34: The name tf.reset_default_graph is deprecated. Please use tf.compat.v1.reset_default_graph instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:35: The name tf.random.set_random_seed is deprecated. Please use tf.compat.v1.random.set_random_seed instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:48: The name tf.variable_scope is deprecated. Please use tf.compat.v1.variable_scope instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:48: The name tf.AUTO_REUSE is deprecated. Please use tf.compat.v1.AUTO_REUSE instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:50: The name tf.get_variable is deprecated. Please use tf.compat.v1.get_variable instead.\n",
      "\n",
      "WARNING:tensorflow:From /disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_probability/python/layers/util.py:104: Layer.add_variable (from tensorflow.python.keras.engine.base_layer) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "Please use `layer.add_weight` method instead.\n",
      "WARNING:tensorflow:From /disk_c/akash/anaconda/envs/iclr/lib/python3.7/site-packages/tensorflow_core/python/ops/resource_variable_ops.py:1630: calling BaseResourceVariable.__init__ (from tensorflow.python.ops.resource_variable_ops) with constraint is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "If using Keras pass *_constraint arguments to layers.\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:121: softmax_cross_entropy_with_logits (from tensorflow.python.ops.nn_ops) is deprecated and will be removed in a future version.\n",
      "Instructions for updating:\n",
      "\n",
      "Future major versions of TensorFlow will allow gradients to flow\n",
      "into the labels input on backprop by default.\n",
      "\n",
      "See `tf.nn.softmax_cross_entropy_with_logits_v2`.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:131: The name tf.trainable_variables is deprecated. Please use tf.compat.v1.trainable_variables instead.\n",
      "\n",
      "WARNING:tensorflow:From ../models/kl_utils.py:134: The name tf.train.AdamOptimizer is deprecated. Please use tf.compat.v1.train.AdamOptimizer instead.\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 936x288 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "KL :  89.15971\n",
      "KL from samples :  88.7306\n",
      "KL from CoB:  0.5355875\n",
      "Taking 500 samples from prior distributions on weights\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "reset()\n",
    "\n",
    "mu_1=-1.\n",
    "mu_2=1.\n",
    "mu_3=0.\n",
    "scale_p=0.08\n",
    "scale_q=0.15\n",
    "scale_m=2.\n",
    "N=40000\n",
    "\n",
    "p, q, m, p_samples, q_samples, m_samples = get_data(mu_1,mu_2,mu_3,scale_p,scale_q,scale_m)\n",
    "dloss = get_loss(p_samples, q_samples, m_samples)\n",
    "optim = get_optim(dloss, lr=0.05)\n",
    "\n",
    "log_ratio_p_q, _, kld = get_gt_ratio_kl(p,q,m_samples)\n",
    "_, kl_from_pq, _ = get_gt_ratio_kl(p,q,p_samples)\n",
    "kl_from_cob = get_kl_from_cob(p_samples)\n",
    "\n",
    "log_ratio_p_m = get_logits(m_samples)\n",
    "\n",
    "init = tf.global_variables_initializer()\n",
    "sess = tf.Session()\n",
    "sess.run(init)\n",
    "\n",
    "%matplotlib inline\n",
    "sample_and_plot(sess, kl_from_pq, kl_from_cob, kld, p_samples, q_samples, m_samples, log_ratio_p_q, log_ratio_p_m, mu_1, mu_2, scale_p, scale_q, mu_3, scale_m, training=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# plotlosses = PlotLosses()\n",
    "# train(sess, dloss, optim, plotlosses, N=N)\n",
    "\n",
    "\n",
    "loss_store=[]\n",
    "fig, [ax1,ax2] = plt.subplots(1, 2,figsize=(10,4))\n",
    "\n",
    "line, = ax1.plot([0,1],[0,1])\n",
    "x, y = np.random.random((2, 500))\n",
    "scat1 = ax2.scatter(x,y,label='True p/q',alpha=0.9,s=10.,c='b')\n",
    "scat2 = ax2.scatter(x,y,label='CoB p/q',alpha=0.9,s=10.,c='r')\n",
    "\n",
    "ax1.set_xlabel(\"Iteration\")\n",
    "ax1.set_ylabel(\"Loss\")\n",
    "ax1.set_xlim([0,N])\n",
    "ax1.set_ylim([0,10])\n",
    "\n",
    "ax2.set_xlabel(\"Samples\")\n",
    "ax2.set_ylabel(\"Log Ratio\")\n",
    "ax2.legend(loc='best')\n",
    "ax2.set_xlim([mu_1-2,mu_2+2])\n",
    "ax2.set_ylim([-1000,1000])\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "pbar = range(0,N)\n",
    "for i in pbar:\n",
    "\n",
    "    feed_dict = {}\n",
    "    l,_ = sess.run([dloss, optim],feed_dict=feed_dict)\n",
    "    loss_store.append(l)\n",
    "    if i%500==0:\n",
    "        line.set_data(range(len(loss_store)), loss_store)\n",
    "        xs, lpq, lpqm = sess.run([m_samples, log_ratio_p_q, log_ratio_p_m],feed_dict={})\n",
    "        scat1.set_offsets(np.asarray([xs, lpq]).T)\n",
    "        scat2.set_offsets(np.asarray([xs,lpqm[:,0]-lpqm[:,1]]).T)\n",
    "        \n",
    "        \n",
    "        \n",
    "        clear_output(wait=True)\n",
    "        display(fig)\n",
    "        \n",
    "sample_and_plot(sess, kl_from_pq, kl_from_cob, kld, p_samples, q_samples, m_samples, log_ratio_p_q, log_ratio_p_m, mu_1, mu_2, scale_p, scale_q, mu_3, scale_m)\n",
    "# with open(\"../models/kl_utils.py\", \"a\") as f:\n",
    "#     f.write(\" \")\n",
    "#     f.close()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"../models/kl_utils.py\", \"a\") as f:\n",
    "    f.write(\" \")\n",
    "    f.close()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "t_vars = tf.trainable_variables()\n",
    "c_vars = [var for var in t_vars if 'critic' in var.name]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "tv = sess.run([c_vars],feed_dict=feed_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "tv = [np.float32(x[0]) for x in tv[0]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[-0.9420838,\n",
       " -0.84332186,\n",
       " 0.8749779,\n",
       " 0.99371773,\n",
       " 0.027365789,\n",
       " 0.038094923,\n",
       " 1.1597745,\n",
       " 0.44518286,\n",
       " 3.8614638,\n",
       " -3.9492648,\n",
       " 1.6647927,\n",
       " -0.0069192187,\n",
       " -0.1234835,\n",
       " -5.4032235]"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "with tf.variable_scope('critic', reuse=tf.AUTO_REUSE) as scope:\n",
    "    q1 = tf.get_variable('q1',1.)\n",
    "    q2 = tf.get_variable('q2',1.)\n",
    "    q3 = tf.get_variable('q3',1.)\n",
    "    q4 = tf.get_variable('q4',1.)\n",
    "    q5 = tf.get_variable('q5',1.)\n",
    "\n",
    "    b1 = tf.get_variable('b1',1.)\n",
    "    b2 = tf.get_variable('b2',1.)\n",
    "    b3 = tf.get_variable('b3',1.)\n",
    "\n",
    "    s1 = tf.get_variable('s1',1.)\n",
    "    s2 = tf.get_variable('s2',1.)\n",
    "\n",
    "    t1 = tf.get_variable('t1',1.)\n",
    "    t2 = tf.get_variable('t2',1.)\n",
    "    t3 = tf.get_variable('t3',1.)\n",
    "\n",
    "\n",
    "\n",
    "tv = sess.run([q1,q2,q3,q4,q5,s1,s2,t1,t2,t3,b1,b2,b3],feed_dict=feed_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[-0.9420838, -0.84332186, 0.8749779, 0.99371773, 0.027365789, 3.8614638, -3.9492648, -0.0069192187, -0.1234835, -5.4032235, 0.038094923, 1.1597745, 0.44518286]\n"
     ]
    }
   ],
   "source": [
    "tv = [np.float32(x[0]) for x in tv]\n",
    "print(tv)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[array([-0.9420838], dtype=float32),\n",
       " array([-0.84332186], dtype=float32),\n",
       " array([0.8749779], dtype=float32),\n",
       " array([0.99371773], dtype=float32),\n",
       " array([0.02736579], dtype=float32),\n",
       " array([3.8614638], dtype=float32),\n",
       " array([-3.9492648], dtype=float32),\n",
       " array([-0.00691922], dtype=float32),\n",
       " array([-0.1234835], dtype=float32),\n",
       " array([-5.4032235], dtype=float32),\n",
       " array([0.03809492], dtype=float32),\n",
       " array([1.1597745], dtype=float32),\n",
       " array([0.44518286], dtype=float32)]"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "Experiment_CoB_Simple.ipynb",
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
