{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "$\n",
    "\\newcommand{\\ud}{\\, \\text{d}}\n",
    "$"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Learning a Gaussian with FML : - )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import time\n",
    "\n",
    "import numpy as np\n",
    "import tensorflow as tf\n",
    "\n",
    "\n",
    "import seaborn as sns\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "%matplotlib inline\n",
    "\n",
    "config = tf.ConfigProto()\n",
    "config.gpu_options.allow_growth = True\n",
    "config.allow_soft_placement=True\n",
    "\n",
    "sess = tf.Session(config=config)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "class flags:\n",
    "    \n",
    "    dim = 1\n",
    "    \n",
    "    # optimization\n",
    "    learning_rate = 1e-3 # Base learning rate\n",
    "    lr_decay = 0.999995 # Learning rate decay, applied every step of the optimization\n",
    "    \n",
    "    batch_size = 128 # Batch size during training per GPU\n",
    "    \n",
    "    \n",
    "FLAGS = flags()\n",
    "args = FLAGS\n",
    "\n",
    "DTYPE = tf.float32"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "code_folding": [
     0,
     28
    ],
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "def tf_eval(tf_tensor,n_samples,feed_dict=None):\n",
    "    \n",
    "    MLOOP = np.int(np.ceil(n_samples/args.batch_size))\n",
    "    \n",
    "    dd = tf_tensor.shape.as_list()[1:]\n",
    "    dd.insert(0,n_samples)\n",
    "    \n",
    "    x = np.zeros(dd)\n",
    "    \n",
    "    for mloop in range(MLOOP):\n",
    "        \n",
    "        st = mloop*args.batch_size\n",
    "        ed = min((mloop+1)*args.batch_size,n_samples)\n",
    "        \n",
    "        if feed_dict is not None:\n",
    "            feed_dict_i = dict()\n",
    "            for key in feed_dict.keys():\n",
    "                feed_dict_i[key] = np.random.randn(*int_shape(key))\n",
    "                feed_dict_i[key][:ed-st] = feed_dict[key][st:ed]\n",
    "            y = sess.run(tf_tensor,feed_dict=feed_dict_i)\n",
    "        else:\n",
    "            y = sess.run(tf_tensor)\n",
    "        \n",
    "        # print([st,ed])\n",
    "        x[st:ed] = y[:ed-st]\n",
    "    \n",
    "    return x\n",
    "\n",
    "def tf_eval_list(tf_tensor_list,n_samples,feed_dict=None):\n",
    "    \n",
    "    if isinstance(tf_tensor_list, list)==False:\n",
    "        print('Input not a list')\n",
    "        return None\n",
    "    \n",
    "    MLOOP = np.int(np.ceil(n_samples/args.batch_size))\n",
    "    \n",
    "    res = dict()\n",
    "\n",
    "    for key in tf_tensor_list:\n",
    "        dd = key.shape.as_list()[1:]\n",
    "        dd.insert(0,n_samples)\n",
    "        res[key] = np.zeros(dd)\n",
    "    \n",
    "    for mloop in range(MLOOP):\n",
    "        \n",
    "        st = mloop*args.batch_size\n",
    "        ed = min((mloop+1)*args.batch_size,n_samples)\n",
    "        \n",
    "        if feed_dict is not None:\n",
    "            feed_dict_i = dict()\n",
    "            for key in feed_dict.keys():\n",
    "                feed_dict_i[key] = np.random.randn(*int_shape(key))\n",
    "                feed_dict_i[key][:ed-st] = feed_dict[key][st:ed]\n",
    "            # print(feed_dict_i)\n",
    "            y = sess.run(tf_tensor_list,feed_dict=feed_dict_i)\n",
    "        else:\n",
    "            y = sess.run(tf_tensor_list)\n",
    "        \n",
    "        for i in range(len(tf_tensor_list)):\n",
    "            res[tf_tensor_list[i]][st:ed] = y[i][:ed-st]\n",
    "    \n",
    "    return res"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "def tf_gauss_logpdf(x,mu=0.,sig2=1.):\n",
    "    \n",
    "    return -tf.square(x-mu)/(2.*sig2)-.5*tf.log(2.*np.pi*sig2)\n",
    "\n",
    "def tf_unnorm_gauss_logpdf(x,mu=0.,sig2=1.):\n",
    "    \n",
    "    return -tf.square(x-mu)/(2.*sig2)\n",
    "\n",
    "\n",
    "def tf_unif_sampler(n_samples,a=0.,b=1.):\n",
    "    \n",
    "    return a+(b-a)*tf.random_uniform([n_samples,])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "mu_0 = -1.\n",
    "sig2_0 = 2.25\n",
    "\n",
    "a_0 = -5.\n",
    "b_0 = 5.\n",
    "\n",
    "n_samples = 1000\n",
    "# x_train = np.random.randn(n_samples,1)\n",
    "# xx,_ = gauss_sampler_n_logpdf(n_samples,mu=mu_0,sig2=sig2_0)\n",
    "\n",
    "x_train = mu_0 + np.sqrt(sig2_0)*np.random.randn(n_samples,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "input_ind = tf.placeholder(tf.int32, shape=[FLAGS.batch_size])\n",
    "input_x = tf.placeholder(tf.float32, shape=[FLAGS.batch_size,FLAGS.dim])\n",
    "\n",
    "\n",
    "with tf.variable_scope('model',reuse=tf.AUTO_REUSE):\n",
    "    embeddings = tf.get_variable('embeddings',shape=[n_samples,1])\n",
    "    mu = tf.get_variable('mu',shape=[1,])\n",
    "    logsig2 = tf.get_variable('logsig2',shape=[1,])\n",
    "    \n",
    "sig2 = tf.exp(logsig2)\n",
    "\n",
    "psi = lambda x: -tf_unnorm_gauss_logpdf(x, mu=mu, sig2=sig2)\n",
    "\n",
    "    \n",
    "u_params = embeddings\n",
    "psi_params = [mu,logsig2]\n",
    "\n",
    "u_x = tf.nn.embedding_lookup(embeddings, input_ind)\n",
    "\n",
    "prop_q = tf_unif_sampler(FLAGS.batch_size,a=a_0,b=b_0)\n",
    "\n",
    "\n",
    "psi_x = psi(input_x)\n",
    "psi_q = psi(prop_q)\n",
    "\n",
    "I_x = tf.exp(psi_x - psi_q)*(b_0-a_0)  # volume of the integral must be accounted for\n",
    "\n",
    "loss = tf.reduce_mean(-u_x-tf.exp(-u_x)*I_x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "learning_rate = tf.placeholder(tf.float32)\n",
    "\n",
    "u_learning_rate = learning_rate\n",
    "u_optimizer = tf.train.AdamOptimizer(u_learning_rate)\n",
    "train_u = u_optimizer.minimize(-loss,var_list=u_params)\n",
    "\n",
    "psi_learning_rate = 1e-1*learning_rate\n",
    "psi_optimizer = tf.train.AdamOptimizer(psi_learning_rate)\n",
    "# train_psi = psi_optimizer.minimize(loss, var_list=psi_params)\n",
    "train_psi = psi_optimizer.minimize(-loss, var_list=psi_params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "initializer = tf.global_variables_initializer()\n",
    "sess.run(initializer)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "true_logp_x = tf_gauss_logpdf(input_x, mu=mu_0, sig2=sig2_0)\n",
    "\n",
    "true_mdl_logp_x = tf_gauss_logpdf(input_x, mu=mu, sig2=sig2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ground Truth: -0.63\n",
      "Current Estimate: -0.04\n"
     ]
    }
   ],
   "source": [
    "inds = np.array(range(FLAGS.batch_size))\n",
    "xx = x_train[inds]\n",
    "\n",
    "ii = 0\n",
    "\n",
    "print('Ground Truth: %.2f' % sess.run(true_mdl_logp_x,{input_x:xx})[ii])\n",
    "print('Current Estimate: %.2f' % -sess.run(u_x, {input_ind:inds})[ii])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "_ = sess.run([tf.assign(mu,[1.]),tf.assign(logsig2,np.log([1.44]))])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ground Truth: N(-1.00, 2.25), Model: N(1.00, 1.44)\n"
     ]
    }
   ],
   "source": [
    "mu_val, sig2_val = sess.run([mu,sig2])\n",
    "\n",
    "print('Ground Truth: N(%.2f, %.2f), Model: N(%.2f, %.2f)' % \\\n",
    "     (mu_0, sig2_0, mu_val, sig2_val))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 3.10\n",
      "Mean Abs Error: 2.98\n",
      "Mean Abs Error: 2.93\n",
      "Mean Abs Error: 2.57\n",
      "Mean Abs Error: 2.55\n",
      "Mean Abs Error: 2.36\n",
      "Mean Abs Error: 2.15\n",
      "Mean Abs Error: 2.28\n",
      "Mean Abs Error: 2.06\n",
      "Mean Abs Error: 2.04\n",
      "Mean Abs Error: 2.07\n",
      "Mean Abs Error: 1.67\n",
      "Mean Abs Error: 1.63\n",
      "Mean Abs Error: 1.59\n",
      "Mean Abs Error: 1.47\n",
      "Mean Abs Error: 1.77\n",
      "Mean Abs Error: 1.16\n",
      "Mean Abs Error: 1.20\n",
      "Mean Abs Error: 1.32\n",
      "Mean Abs Error: 1.28\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX4AAAD8CAYAAABw1c+bAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMi4zLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvIxREBQAAIABJREFUeJzt3Xl8VPX1//HXyU72ZJKwJSGQsAhoWEKAgApqEahLtS6gxaW1FItV29pql19bbftdtF/bqlWLS8UWd1yLCy607GhAkB3CvmcDAgTIdn5/zMXGkJAhmcxkMuf5eMwjk3s/d+7JzeQ9N5/7ufeKqmKMMSZ4hPi7AGOMMb5lwW+MMUHGgt8YY4KMBb8xxgQZC35jjAkyFvzGGBNkLPiNMSbIWPAbY0yQseA3xpggE+bvAhqTkpKiWVlZ/i7DGGMCxvLly0tVNdWTtu0y+LOysigsLPR3GcYYEzBEZIenba2rxxhjgowFvzHGBBkLfmOMCTIW/MYYE2Qs+I0xJshY8BtjTJCx4DfGmCDToYL/0Y83s2bPYX+XYYwx7VqHCf5DlVW88OlOrn58MX9fugO7l7AxxjSuwwR/YnQEc+48n4IcF//vzTX84MXPOXKi2t9lGWNMu9Nhgh8gOSaCZ28exr3j+/Hemv1c/uhC1u61rh9jjKmvQwU/QEiIcPuYbF6aOoIT1XVc9fhiZi2zrh9jjDmlwwX/KcOykplz52hG9nLxizfWcOdLKzl6ssbfZRljjN912OAHcMVG8rdbhvGTS/sy54u9XP7oQtbtrfB3WcYY41cdOvjB3fUzfWwOL353BMdO1vCNxxfxwrKd1vVjjAlazQa/iESJyKciskpE1orI/Y20iRSRl0WkSESWiUhWvXk/c6ZvFJFLvVu+54b3cvHuXeczvGcyP39jNXe/bF0/xpjg5Mke/0ngIlXNBQYB40VkRIM23wEOqmoO8EfgfwFEpD8wCRgAjAceF5FQbxV/tlJiI5l5az73jOvDO6v2csWjC1m/z7p+jDHBpdngV7ejzrfhzqNhP8mVwEzn+WvAxSIizvSXVPWkqm4DioB8r1TeQiEhwh0X9WbWbSM4crKGb/xlES99al0/xpjg4VEfv4iEishKoBj4UFWXNWjSHdgFoKo1wGHAVX+6Y7czrbF1TBWRQhEpLCkpObufogVGZrt4987zGZaVzH2vr+ZHr6zimHX9GGOCgEfBr6q1qjoISAfyRWSgtwtR1RmqmqeqeampHt0vuNVS4yKZ+e18fnhJH95cuYcrHlvIx+sPcKK61ifrN8YYfzirm62r6iERmYe7v35NvVl7gAxgt4iEAQlAWb3pp6Q709qN0BDhrkt6MywribteXsl3ZhYSFR7CqOwULjonjYv6pdE1oZO/yzTGGK9pNvhFJBWodkK/E/A1nIO39bwN3AwsAa4BPlFVFZG3gRdE5GGgG9Ab+NSbP4C3FOSksOCnY1m2rZx5G4r5aP0BPt5QDMA5XeO5uF8aF52TRm56IqEh4udqjTGm5aS5g5oich7uA7ehuLuGXlHVB0TkAaBQVd8WkSjg78BgoByYpKpbneV/AXwbqAHuVtX3misqLy9PCwsLW/FjtZ6qUlR8lI83FPPJhmKW7zhIbZ2SHBPBmL6pXNyvM+f3SSE+KtyvdRpjDICILFfVPI/atsfRLO0h+Bs6VFnFvzeVMG9DMfM2lnD4eDVhIcKwrGQudrqEeqXG+rtMY0yQsuBvYzW1dXy+6xAfry9m3oZiNh44AkCWK5r7rxzIhX18c3DaGGNOseD3sV3llczbWMzTC7YRFip89MMLCbHjAMYYHzqb4O/w1+rxhYzkaG4amcWPvtaHrSXHWFBU6u+SjDGmSRb8XjTx3K6kxkXy3KJt/i7FGGOaZMHvRRFhIdw4PJN5G0vYVnrM3+UYY0yjLPi97IbhmYSHCjMXb/d3KcYY0ygLfi9Li4visvO68dry3Xazd2NMu2TB3wZuKcji6MkaZi/f7e9SjDHmNBb8bSA3I5FBGYnMXLKDurr2N1zWGBPcLPjbyK2jsthWeoz5m9v+EtPGGHM2LPjbyISBztBOO8hrjGlnLPjbSERYCN8a3oN/bSxha8nR5hcwxhgfseBvQ6eGdj6/ZIe/SzHGmC9Z8Leh1LhILj+vG68W7rKhncaYdsOCv43dXJDFsapaXrOhncaYdsKCv43lZiQyJDORmYu329BOY0y70Gzwi0iGiMwTkXUislZE7mqkzU9EZKXzWCMitSKS7MzbLiKrnXmBc61lL7plVE+2l1Xy7002tNMY43+e7PHXAD9W1f7ACGC6iPSv30BVH1LVQao6CPgZ8G9VLa/XZKwz36NrRXc0EwZ2oXN8JH+zoZ3GmHag2eBX1X2qusJ5fgRYD3Q/wyKTgRe9U17HEB4awo3DezB/UwlFxTa00xjjX2fVxy8iWbhvqL6sifnRwHhgdr3JCswVkeUiMrVlZQa+yfmZRISG8PyS7f4uxRgT5DwOfhGJxR3od6tqRRPNLgcWNejmGa2qQ4AJuLuJLmji9aeKSKGIFJaUdLy+8NS4SC7L7cpry3dTYUM7jTF+5FHwi0g47tCfpaqvn6HpJBp086jqHudrMfAGkN/Ygqo6Q1XzVDUvNbVj3qz81oKeVFbV8lqhDe00xviPJ6N6BHgGWK+qD5+hXQJwIfBWvWkxIhJ36jkwDljT2qID1bnpCQztkcTMJTa00xjjP57s8Y8CpgAX1RuyOVFEponItHrtrgLmqmr9ew52BhaKyCrgU2COqr7vteoD0C0FWewoq+Rfm4r9XYoxJkiFNddAVRcC4kG754DnGkzbCuS2sLYOafypoZ2LtnNRv87+LscYE4TszF0fCw8NYcqIHizYXEpR8RF/l2OMCUIW/H4wOT+TiLAQZi62q3YaY3zPgt8PXLGRXJHbjdkrdnP4uA3tNMb4lgW/n9xSkEVlVS2vFu7ydynGmCBjwe8nA7snkNcjieeX7KDWhnYaY3zIgt+PbhmVxc7ySuZtsKGdxhjfseD3o0sHdKFLfJTdkN0Y41MW/H4UHhrClJE9WFhUyuYDNrTTGOMbFvx+NmlYhnto55Lt/i7FGBMkLPj9zBUbyZW53Zi9fI8N7TTG+IQFfztwc0EWx6ttaKcxxjcs+NuBgd0TyM9KZuaS7Ta00xjT5iz424lbRmWxq/w4f5lXxNKtZWwtOcqxkzX+LssY0wE1e3VO4xvj+nemb+c4Hv5w01emx0aGkRYfSVpcJJ3jo+gcH0VaXCRp8VF0dqalxUcSHWG/SmOMZywt2omw0BDeumMUuw9WcqDiJAcqTlB8xPnqfP/5zkMcqDjByZq605aPcz4gvj26JzcO7+GHn8AYEygs+NuRqPBQctLiyEmLa7KNqlJxvIbiIye+/IA4cMT94fD5rkP88s01dEvoxNh+aT6s3BgTSJoNfhHJAJ7HfTctBWao6p8btBmD+5aL25xJr6vqA8688cCfgVDgaVX9H69VH4REhITocBKiw+nd+asfEMerarnmycXc+dLnvDl9FNmpsX6q0hjTnnlycLcG+LGq9gdGANNFpH8j7Rao6iDncSr0Q4G/ABOA/sDkJpY1XtApIpS/ThlKeGgI332+kIoTdl6AMeZ0zQa/qu5T1RXO8yPAeqC7h6+fDxSp6lZVrQJeAq5sabGmeelJ0Tx+4xB2llXyw5dW2k3djTGnOavhnCKSBQwGljUye6SIrBKR90RkgDOtO1D/rKTdeP6hYVpoRC8Xv7q8Px9vKD5tlJAxxnh8cFdEYoHZwN2qWtFg9gqgh6oeFZGJwJtA77MpRESmAlMBMjMzz2ZR04gpI3qwbm8Fj80r4pyu8Xz9vK7+LskY0054tMcvIuG4Q3+Wqr7ecL6qVqjqUef5u0C4iKQAe4CMek3TnWmnUdUZqpqnqnmpqaln+WOYhkSE+68cwJDMRO55dRXr9jb8rDbGBKtmg19EBHgGWK+qDzfRpovTDhHJd163DPgM6C0iPUUkApgEvO2t4s2ZRYaF8uS3hhLfKYypfy+k/FiVv0syxrQDnuzxjwKmABeJyErnMVFEponINKfNNcAaEVkFPAJMUrca4A7gA9wHhV9R1bVt8HOYJqTFR/HXKXkUHznJHS+soKb29JO/jDHBRVTb36iPvLw8LSws9HcZHcrs5bv58auruHVUFr++fEDzCxhjAoqILFfVPE/a2pm7QeKbQ9NZu7eCZxdt45yu8VyXl9H8QsaYDsmuzhlEfj6xH6NyXPzyjTV8vvOgv8sxxviJBX8QCQsN4bHJQ+icEMm0fyynuOKEv0syxviBBX+QSYqJ4Kmb8jhyoobv/WM5J2tq/V2SMcbHLPiDUL8u8fzftbl8vvMQ/+/NNbTHA/zGmLZjwR+kJpzblR9clMMrhbt5fskOf5djjPEhC/4g9sNL+nDJOWk88M91LNlS5u9yjDE+YsEfxEJChD9eP4ieKTFMf2EFu8or/V2SMcYHLPiDXFxUODOmDKW6to6pf19OZZXd4N2Yjs6C39ArNZZHJw9mw/4K7p292g72GtPBWfAbAMb0TeOecX15Z9VeO9hrTAdnwW++dPuF2VzcL43fzVnHCjuz15gOy4LffCkkRHj4ukF0SYjijlkr7DLOxnRQFvzmKxKiw3nixqGUHqvirpc+p9bu2WtMh2PBb04zsHsC918xgAWbS3nk483+LscY42UW/KZRk4Zl8M0h6TzyyWb+tbHY3+UYY7zIgt80SkT43TcG0rdzHHe/vJLdB9v+5K61ew/bSWTG+IAn99zNEJF5IrJORNaKyF2NtLlRRL4QkdUislhEcuvN2+5MXykidlutANIpIpQnvjWU2lpl+qwVbXYlT1Xlb4u2ccVji5g0YykVJ6rbZD3GGDdP9vhrgB+ran9gBDBdRPo3aLMNuFBVzwV+C8xoMH+sqg7y9LZgpv3omRLDQ9eex6rdh/ndP9d7/fVP1tRy3+zV3P/OOvKzktlfcYJfv2W3ZTamLTUb/Kq6T1VXOM+P4L5pevcGbRar6qmB30uBdG8Xavxn/MCufPf8nvx96Q7eWrnHa69bevQkNz61jJcLd3HH2Bxm3TacOy/qzRuf7+HtVXu9th5jzFedVR+/iGQBg4FlZ2j2HeC9et8rMFdElovI1LMt0LQPPx3fj2FZSdw3ezWbDhxp9eut3XuYKx9bxOo9h3l08mDuubQvISHC9LHZDMlM5JdvrGbvoeNeqNwY05DHwS8iscBs4G5VrWiizVjcwX9vvcmjVXUIMAF3N9EFTSw7VUQKRaSwpKTE4x/A+EZ4aAiP3TCEmMgwpv1jOUdPtvxibu+t3sc1Tyyhtk55bVoBl+d2+3JeWGgIf7x+ELV1yo9eWUmdnUdgjNd5FPwiEo479Gep6utNtDkPeBq4UlW/vLi7qu5xvhYDbwD5jS2vqjNUNU9V81JTU8/upzA+0Tk+ikcnD2Z76THunf3FWV/Mra5O+dNHm7h91gr6dY3j7TtGcW56wmnterhi+PUVA1i6tZynF271VvnGGIcno3oEeAZYr6oPN9EmE3gdmKKqm+pNjxGRuFPPgXHAGm8UbvxjZLaLey7ty5wv9vG3Rds9Xq6yqobpL6zgTx9t5uoh3XnxuyNIi49qsv21Q9MZP6ALD32wkbV7D3uhcmPMKZ7s8Y8CpgAXOUMyV4rIRBGZJiLTnDa/AlzA4w2GbXYGForIKuBTYI6qvu/tH8L41rQLsrnknDT+6931LN9R3mz7PYeOc80TS/hg7X5+MfEc/u/aXKLCQ8+4jIjw31efS1J0BHe/tJIT1XZTeGO8Rdrjtdfz8vK0sNCG/LdnhyurueyxBVTXKP+8czQpsZGNtvtseznT/r6cqpo6HrlhMGP7pp3VeuZvKuGmZz/lloIsfnPFAG+UbkyHJCLLPR0yb2fumhY5dTG38sqmL+b28mc7ueGppcR3CueN6aPOOvQBLuiTyq2jsnhu8Xb+vckO+hvjDRb8psUGdk/gt1cOYFFRGX/66MtDO9TU1nH/O2u5d/ZqRvRy8eb3R5GTFtvi9dw7vh99Osdyz6ur7FLRxniBBb9pleuHZXLt0HQe/aSIeRuKOVxZza3PfcbfFm3n26N68rdbhpEQHd6qdUSFh/Kn6wdzuLKa+1owmsgY81Vh/i7ABL7ffmMga/ZWcPfLK0mOiWD3wUoe/OZ5XDcsw2vr6N8tnp9c2pffv7ueVwp3cf2wTK+9tjHBxvb4TatFhYfyxI1DqKtTjpyo5sXvjvBq6J/yndE9Kch2cf8769heeszrr29MsLBRPcZrdh+sJDoijOSYiDZbx77Dx7n0j/PplRrLq9NGEh5q+y7GgI3qMX6SnhTdpqEP0DWhE/919bms3HWIxz4patN1GdNRWfCbgHPZed24enB3HptXxPIdB5tfwBjzFRb8JiDdf+UAuiZE8cOXV7bqgnHGBCMLfhOQ4qLCefi6Qew+WMkD79iNW4w5Gxb8JmDl90zm9jHZvFK4m/fX7PN3OcYEDAt+E9DuvqQP56UncN/rqzlQccLf5RgTECz4TUALd27ccqK6lnteXeXzG7dU1dSxrfQY8zYW89yibXy+0w42m/bPztw1AS87NZZffr0/v3xzDd+ftYI+nWNxxUbiio0gJTaSlNgIXDGRJHQKJyREzvr1T1TXsrO8kh1llewoO8b2smPsKKtke9kx9hw8Tv3Pmu6JnZj/07GEtmA9xviKBb/pEG4cnsn6fRV8sHY/H6zbT2PnJYaFCMkxEbicD4OU2EhcMRGkxDlfYyM5UV3L9gYBv+/wV7uQEjqFk+WKZnBGElcN6k4PVww9XNFsOnCUn7+xmgWbSxjTgiuRGuMrduau6XBq65SDlVWUHa2i9OhJSo+epOxoFWXHTlJ6xPlab96J6rrTXiMlNpIermh6uKLJcoL91NfE6MZPUquqqWPkf39MXlYSf53i0QmUxnjN2Zy52+wev4hkAM/jvpuWAjNU9c8N2gjwZ2AiUAncoqornHk3A790mv5OVWd6+oMY0xKhIeJ08UTSl7hm21dW1VB2tIqSoyeJCA0hKyWG2Miz/2c4IiyEa4am88zCbRRXnDjjrSWN8SdPDu7WAD9W1f7ACGC6iPRv0GYC0Nt5TAWeABCRZODXwHDcN1n/tYgkeal2Y7wiOiKMjORohmQmMbB7QotC/5Trh2VQU6e8uny3Fys0xruaDX5V3Xdq711VjwDrge4Nml0JPK9uS4FEEekKXAp8qKrlqnoQ+BAY79WfwJh2pFdqLCN7uXjps50+H2FkjKfOajiniGQBg4FlDWZ1B3bV+363M62p6cZ0WJOHZ7Kr/DiLtpT6uxRjGuVx8ItILDAbuFtVK7xdiIhMFZFCESksKbF7q5rAdemAziRFh/Pipzv9XYoxjfIo+EUkHHfoz1LV1xtpsgeof+eNdGdaU9NPo6ozVDVPVfNSU1M9KcuYdikyLJRrhqYzd+0BSo6c9Hc5xpym2eB3Ruw8A6xX1YebaPY2cJO4jQAOq+o+4ANgnIgkOQd1xznTjOnQJuVnUlOnvGYHeU075MnwhVHAFGC1iKx0pv0cyARQ1SeBd3EP5SzCPZzzVmdeuYj8FvjMWe4BVS33XvnGtE/ZqbHk90zmpc928r0LerXojGFj2kqzwa+qC4EzvmvVfRbY9CbmPQs826LqjAlgN+RncvfLK1mytYxROSn+LseYL9lF2oxpI+MHdiGhUzgv2EFe085Y8BvTRqLCQ/nmkHTmrt1P2VE7yGvaDwt+Y9rQ5PwMqmuV2SvsIK9pPyz4jWlDvTvHMSwriRc/3UV7vCCiCU4W/Ma0scn5mWwrPcbSrTagzbQPFvzGtLGJ53YlPirMzuQ17YYFvzFtLCo8lKuHpPP+mv2UH6vydznGWPAb4wuT8zOpqq3jdTvIa9oBC35jfKBvlziGZCbywqc77SCv8TsLfmN8ZHJ+JltLjvHpNjvIa/zLgt8YH7nsvG7E2UFe0w5Y8BvjI50iQrlqcHfeXbOfg3aQ1/iRBb8xPjRpWCZVNXW8/nmjt6Uwxics+I3xof7d4hmUkchLdpDX+JEFvzE+dkN+JpuLj7J8x0F/l2KClAW/MT52WW5XYiPD7HLNxm8s+I3xseiIML4xuBtzvtjH4cpqf5djgpAn99x9VkSKRWRNE/N/IiIrnccaEakVkWRn3nYRWe3MK/R28cYEqsn5mZysqeONz+1MXuN7nuzxPweMb2qmqj6kqoNUdRDwM+DfDe6rO9aZn9e6Uo3pOAZ0SyA3PcEu11zP/e+sZfqsFf4uIyg0G/yqOh/w9FTDycCLrarImCAxKT+TjQeOsGLnIX+X4nebDhzhucXbeW/NPipOWPdXW/NaH7+IROP+z2B2vckKzBWR5SIytZnlp4pIoYgUlpSUeKssY9qty3O7ERMRamfyAn/4YCMAdQqf2SUt2pw3D+5eDixq0M0zWlWHABOA6SJyQVMLq+oMVc1T1bzU1FQvlmVM+xQbGcYVg7rzzy/2cvh48O7lrth5kLnrDjB9TA6RYSEs3lLm75I6PG8G/yQadPOo6h7nazHwBpDvxfUZE/BuyM/kRHUdb60MzjN5VZWH3t+IKyaC28dkMywr2YLfB7wS/CKSAFwIvFVvWoyIxJ16DowDGh0ZZEywOjc9gYHd43lhWXCeybuwqJQlW8u446IcYiLDGJntYv2+CrthTRvzZDjni8ASoK+I7BaR74jINBGZVq/ZVcBcVT1Wb1pnYKGIrAI+Beao6vveLN6YjmByfiYb9h9h1e7D/i7Fp1SVhz7YSPfETtwwPBOAgmwXAEu32l5/WwprroGqTvagzXO4h33Wn7YVyG1pYcYEiytyu/H7Oet5cdlOBmUk+rscn3l/zX6+2H2Yh645j8iwUADO7Z5AbGQYi7eUMvHcrn6usOOyM3eN8bO4qHCuyO3G26v2ciRIhjLW1Nbx0NyN9E6L5eoh6V9ODwsNIb+n9fO3NQt+Y9qByfmZHK+u5bXlwXEm7+sr9rC15Bg/HteX0BD5yryCbBdbS46x//AJP1XX8VnwG9MOnJeewHnpCdz/zjrOf/AT7pv9Be+s2kvZ0ZP+Ls3rTlTX8qePNpGbkcilAzqfNn+k08+/ZGupr0sLGs328Rtj2p6I8Owtw5jzxT4WFpUyZ/U+XvpsFwDndI1ndI6LgpwU8rOSiYkM7D/bWct2svfwCR66NhcROW3+OV3iSYwOZ3FRGVcNTm/kFUxrBfY7yJgOJCU2kpsLsri5IIua2jpW7znM4i1lLNxcyszFO3hqwTbCQ4XBGUmMyklhVI6L3IxEwkMD5x/3oydr+Mu8IkbnpDAqJ6XRNiEhwsheLhZvKUNVG/1wMK1jwW9MOxQWGsLgzCQGZyYxfWwOx6tqKdxRzsKiUhYXlfGnjzfxx48gJiKUEb3c/w2MzkmhT+fYdh2UzyzYRvmxKn5yad8ztivIdvHemv3sKj9OpivaR9UFDwt+YwJAp4hQzu+dyvm93ZczOXisiqVby1hYVMqiolI+3lAMQGpcJOf3TuHCPqmMykkhJTbSn2V/RfmxKp5asJXxA7qQ28yw1ZHZ7v8GFm8pJdOV6YvygooFvzEBKCkmggnndmWCM9Z998FKFheVsaColHkbinl9hfsSEAO7x3OB84ExtEcSEWH+6xZ6fF4RlVU13HNpn2bbZqfGkBYXyeItZUzKt+D3Ngt+YzqA9KRorhsWzXXDMqitU9bsOcyCzSXM31TKjPlbefxfW4iJCGVktosL+rg/CLJc0T7rFtp76DjPL93B1UPSyUmLa7a9iFCQ7WJhkfXztwULfmM6mNAQITcjkdyMRO64qDdHTlSzZEsZ850Pgo/Wu7uFMpI7ffnfQEGOi/io8Dar6ZGPN4PC3Zf09niZguwU3ly5l6Lio/Tu3PyHhfGcBb8xHVxcVDjjBnRh3IAuAOwoO8b8TSX8e1Mpb36+h1nLdhIaIgzJTOSbQ9K5fliGV/ewt5Qc5dXlu7lpZA/Skzw/UHtqPP/iLWUW/F5mwW9MkOnhimHKyBimjMyiuraOFTsOMn9zCZ9sKOG+11czb2MxD34zl4Ro7/wH8PDcTUSGhTB9bM5ZLZeRHE1GcicWbynl5oIsr9Ri3AJnALAxxuvCQ0MY3svFTy7tx7t3juaXXz+Hj9cX8/VHF/D5zoOtfv01ew4zZ/U+bhvds0UjjAp6pbB0azm1dcF3yeq2ZMFvjAHcB1RvO78Xr91eAMC1Ty7hqflbW3WfgAc/2EhSdDi3XdCrRcsX5Lg4fLya9fsqWlyDOZ0FvzHmKwZlJDLnzvO5+Jw0fv/uem6bWcjBFtwYZenWMuZvKuH7Y3JafOB4ZK9T/fx23R5vsuA3xpwmoVM4T35rKPdfMYAFm0v5+iMLKNzu+U3QVZUH399Al/gopozs0eI60uKjyEmLtcs0e5knd+B6VkSKRaTR2yaKyBgROSwiK53Hr+rNGy8iG0WkSETu82bhxpi2JSLcXJDF7NsLCA8L4foZS3n8X0XUedDf/tH6YlbsPMRdl/QmKjy0VXUUZLv4dFs51bV1rXod8x+e7PE/B4xvps0CVR3kPB4AEJFQ4C/ABKA/MFlE+remWGOM752bnsA7PxjN+IFdePD9jdzy3GeUnuFy0bV1yh8+2EivlBiuHdr6q2sWZLuorKrli92HWv1axq3Z4FfV+YDn/+P9Rz5QpKpbVbUKeAm4sgWvY4zxs/iocB6bPJjfXzWQpVvLmPjnBU3eF/ftVXvYeOAIPxrXhzAvXDl0eE8XIrC4yLp7vMVbffwjRWSViLwnIgOcad2BXfXa7HamGWMCkIhw4/AevPn9UcRGhnHDU0t55OPNXxlqWVVTx8MfbmJAt3gmDvTOPXOTYiLo3zXe+vm9yBvBvwLooaq5wKPAmy15ERGZKiKFIlJYUlLihbKMMW2hf7d43v7BaK7I7cbDH27ipmeXUXzEfZvElz/bya7y4/zk0r6EhHjv7N+CbBfLdx7kRHWt114zmLU6+FW1QlWPOs/fBcJFJAXYA2TUa5ruTGvqdWaoap6q5qWmpra2LGNMG4qNDOOP1w/iwW+ex/IdB5n45wV8uO4Aj3xSxPCeyVzYx7t/wwXZKVTVuM8EOnvbAAAMHUlEQVQyNq3X6uAXkS7iXNhDRPKd1ywDPgN6i0hPEYkAJgFvt3Z9xpj2QUS4blgGb00fTWJ0BN99vpCSIyf56fh+Xr+a5rCeyYSGiHX3eEmz1+oRkReBMUCKiOwGfg2EA6jqk8A1wO0iUgMcByap+1S/GhG5A/gACAWeVdW1bfJTGGP8pm+XON6+YxT/894GwkNDGNojyevriI0MIzc9wTmR68x37zLNazb4VXVyM/MfAx5rYt67wLstK80YEyiiI8J44MqBbbqOguwUnvj3Fo6erCE2wG8472925q4xJiAUZLuorVM+29aS0eWmPgt+Y0xAGOLcOtKu29N6FvzGmIAQFR7K0MwkO8DrBRb8xpiAUZDtYt2+ihZdLdT8hwW/MSZgFOS4UIVl22yvvzUs+I0xAeO89ESiI0Ktu6eVLPiNMQEjPDSE/J7JFvytZMFvjAkoBdkuioqPUlxxwt+lBCwLfmNMQCnITgFgSROXhTbNs+A3xgSUc7rGk9Ap3K7P3woW/MaYgBIaIozolczirXYiV0tZ8BtjAk5Bdgq7yo+zq7zS36UEJLvSkTEm4BRkuwBYsqWMjORoP1cDJ6pr+Z/3NrBi50Hys5IZ3TuF/J7JREe0z4htn1UZY8wZ5KTFkhIbyeItpVw3LKP5BdrQttJjfH/WCtbvqyA3I5Hnl+zg6YXbiAgNYUiPREbnpDC6dyrndk8g1It3JWsNC35jTMAREQqyXSzeUoaqev3GL556Z9Ve7pv9BeFhIfztlmGM7ZfG8apaPttezqKiUhZsLuUPczfxh7mbiI8KY2S2i9G9Uxmdk0KWK9pvdVvwG2MCUkG2i7dX7WVLyTFy0mJ9uu4T1bX8bs46/rF0J0MyE3nshiF0S+wEQKeIUC7ok8oFfVL5GVB29CSLt5SxcHMpC4tK+WDtAQC6J3Zy/htIoSDbhSs20mf1W/AbYwLSl+P5t5T6NPh3lLm7dtbureB7F/Tinkv7Eh7a9DgZV2wkl+d24/Lcbqgq28sqWVhUysLNJby7Zh8vF+4CYEC3eEbnpPDT8f3avEvIk1svPgtcBhSr6mm32BGRG4F7AQGOALer6ipn3nZnWi1Qo6p53ivdGBPMMpI70T2xE4u3lDFlZJZP1vnu6n3c+9oXhIQIT9+UxyX9O5/V8iJCz5QYeqbEMGVED2pq61i95/CX3ULzN5fys4lt3/3jyR7/c7hvrfh8E/O3AReq6kERmQDMAIbXmz9WVW3ArTHGq07183+4/gB1dUpIG+4ln6yp5b/mrGfmkh0MykjksRsGk57U+tFEYaEhDM5MYnBmEndc1JvaOvVCtc1rdhy/qs4HmrzXmaouVtWDzrdLgXQv1WaMMWdUkOPiUGU16/dXtNk6dpZVcu2TS5i5ZAe3je7JK98b6ZXQb4yvRv14u4//O8B79b5XYK6IKPBXVZ3R1IIiMhWYCpCZmenlsowxHdHIXqf6+csY0C3B66///pr9/OS1VQgwY8pQxg3o4vV1+IPXztwVkbG4g//eepNHq+oQYAIwXUQuaGp5VZ2hqnmqmpeamuqtsowxHViXhCh6pcZ4/TLNVTV13P/OWqb9Yzm9UmKYc+f5HSb0wUt7/CJyHvA0MEFVv/wNqOoe52uxiLwB5APzvbFOY4wB97DON1bsobq27oyjazy1q7ySO178nFW7DnFLQRY/m9iPyLBQL1TafrR6K4lIJvA6MEVVN9WbHiMicaeeA+OANa1dnzHG1FeQncKxqlpW7znc6teau3Y/X39kAVuLj/LEjUP4zRUDOlzog2fDOV8ExgApIrIb+DUQDqCqTwK/AlzA485ZaKeGbXYG3nCmhQEvqOr7bfAzGGOC2Ihe/7luz5DMpLNe/nBlNZ9sPMD7a/bzwdoDDOwez19uGEIPV4y3S203mg1+VZ3czPzbgNsamb4VyG15acYY07zkmAjO6RrP4i2lTB+b49Eyew8d58N1B5i7bj/LtpZTU6ekxkUy7cJs7r6kN1HhHW8vvz47c9cYE/AKsl38Y+kOTlTXNhraqsrGA0eYu9Yd9mv2uId/ZqfG8N0LejGuf2dy0xPb9FyA9sSC3xgT8AqyXTyzcBuf7zzESOeSzTW1dSzfcZC5zp79rvLjiMDgjETum9CPr/XvTHaqb6/x015Y8BtjAl5+z2RCQ4RPNhzgyIlq5q47wMfrD3CwspqI0BBG5bj4/pgcLj4njbS4KH+X63cW/MaYgBcXFc653RN4asE2nlqwjbioMC7ul8bX+nfhwr6pxEZa1NVnW8MY0yHcfUlv5m8q5aJ+aQzvleyVMf0dlQW/MaZDGNM3jTF90/xdRkCwj0RjjAkyFvzGGBNkLPiNMSbIWPAbY0yQseA3xpggY8FvjDFBxoLfGGOCjAW/McYEGVH1zV3dz4aIlAA7Wrh4ClDqxXK8zeprHauvday+1mnP9fVQVY/uW9sug781RKTQuRFMu2T1tY7V1zpWX+u09/o8ZV09xhgTZCz4jTEmyHTE4J/h7wKaYfW1jtXXOlZf67T3+jzS4fr4jTHGnFlH3OM3xhhzBgEb/CIyXkQ2ikiRiNzXyPxIEXnZmb9MRLJ8WFuGiMwTkXUislZE7mqkzRgROSwiK53Hr3xVn7P+7SKy2ll3YSPzRUQecbbfFyIyxIe19a23XVaKSIWI3N2gjU+3n4g8KyLFIrKm3rRkEflQRDY7X5OaWPZmp81mEbnZh/U9JCIbnN/fGyKS2MSyZ3wvtGF9vxGRPfV+hxObWPaMf+ttWN/L9WrbLiIrm1i2zbef16lqwD2AUGAL0AuIAFYB/Ru0+T7wpPN8EvCyD+vrCgxxnscBmxqpbwzwTz9uw+1AyhnmTwTeAwQYASzz4+96P+4xyn7bfsAFwBBgTb1pDwL3Oc/vA/63keWSga3O1yTneZKP6hsHhDnP/7ex+jx5L7Rhfb8B7vHg93/Gv/W2qq/B/P8DfuWv7eftR6Du8ecDRaq6VVWrgJeAKxu0uRKY6Tx/DbhYRMQXxanqPlVd4Tw/AqwHuvti3V50JfC8ui0FEkWkqx/quBjYoqotPaHPK1R1PlDeYHL999hM4BuNLHop8KGqlqvqQeBDYLwv6lPVuapa43y7FEj39no91cT284Qnf+utdqb6nNy4DnjR2+v1l0AN/u7Arnrf7+b0YP2yjfPmPwy4fFJdPU4X02BgWSOzR4rIKhF5T0QG+LQwUGCuiCwXkamNzPdkG/vCJJr+g/Pn9gPorKr7nOf7gc6NtGkv2/HbuP+Da0xz74W2dIfTFfVsE11l7WH7nQ8cUNXNTcz35/ZrkUAN/oAgIrHAbOBuVa1oMHsF7u6LXOBR4E0flzdaVYcAE4DpInKBj9ffLBGJAK4AXm1ktr+331eo+3/+djlETkR+AdQAs5po4q/3whNANjAI2Ie7O6U9msyZ9/bb/d9SQ4Ea/HuAjHrfpzvTGm0jImFAAlDmk+rc6wzHHfqzVPX1hvNVtUJVjzrP3wXCRSTFV/Wp6h7nazHwBu5/qevzZBu3tQnAClU90HCGv7ef48Cp7i/na3Ejbfy6HUXkFuAy4Ebnw+k0HrwX2oSqHlDVWlWtA55qYr3+3n5hwNXAy0218df2a41ADf7PgN4i0tPZK5wEvN2gzdvAqREU1wCfNPXG9zanT/AZYL2qPtxEmy6njjmISD7u34VPPphEJEZE4k49x30QcE2DZm8DNzmje0YAh+t1a/hKk3ta/tx+9dR/j90MvNVImw+AcSKS5HRljHOmtTkRGQ/8FLhCVSubaOPJe6Gt6qt/zOiqJtbryd96W7oE2KCquxub6c/t1yr+Prrc0gfuUSebcB/x/4Uz7QHcb3KAKNxdBEXAp0AvH9Y2Gve//V8AK53HRGAaMM1pcwewFvcohaVAgQ/r6+Wsd5VTw6ntV78+Af7ibN/VQJ6Pf78xuIM8od40v20/3B9A+4Bq3P3M38F9zOhjYDPwEZDstM0Dnq637Led92ERcKsP6yvC3T9+6j14apRbN+DdM70XfFTf35331he4w7xrw/qc70/7W/dFfc7050695+q19fn28/bDztw1xpggE6hdPcYYY1rIgt8YY4KMBb8xxgQZC35jjAkyFvzGGBNkLPiNMSbIWPAbY0yQseA3xpgg8/8B1+ANKfsFtT8AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Estimating likelihood\n",
    "\n",
    "lr = 1e-3\n",
    "\n",
    "max_updates = 500\n",
    "num_iter = 20\n",
    "\n",
    "loss_record = []\n",
    "\n",
    "for iterId in range(num_iter):\n",
    "    \n",
    "    for step in range(max_updates):\n",
    "        \n",
    "        inds = np.random.choice(n_samples,FLAGS.batch_size)\n",
    "        xx = x_train[inds]\n",
    "        \n",
    "        _ = sess.run(train_u,{input_x: xx, input_ind:inds, learning_rate: lr})\n",
    "        \n",
    "    ii = 0\n",
    "    \n",
    "    # inds = np.array(range(FLAGS.batch_size))\n",
    "    inds = np.random.choice(n_samples,FLAGS.batch_size)\n",
    "    xx = x_train[inds]\n",
    "    true_logp_xx = sess.run(true_mdl_logp_x,{input_x:xx})\n",
    "    est_logp_xx = -sess.run(u_x, {input_ind:inds})\n",
    "    mean_abs_err = np.mean(np.abs(true_logp_xx-est_logp_xx))\n",
    "    print('Mean Abs Error: %.2f' % mean_abs_err)\n",
    "    \n",
    "    loss_record.append(mean_abs_err)\n",
    "    \n",
    "_ = plt.plot(loss_record)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.68\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.94, 1.53)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.72\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.91, 1.57)\n",
      "Mean Abs Error: 0.53\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.88, 1.61)\n",
      "Mean Abs Error: 0.45\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.86, 1.65)\n",
      "Mean Abs Error: 0.40\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.84, 1.68)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.36\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.82, 1.70)\n",
      "Mean Abs Error: 0.45\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.81, 1.73)\n",
      "Mean Abs Error: 0.37\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.79, 1.76)\n",
      "Mean Abs Error: 0.39\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.77, 1.78)\n",
      "Mean Abs Error: 0.19\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.76, 1.81)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.29\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.74, 1.84)\n",
      "Mean Abs Error: 0.16\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.72, 1.86)\n",
      "Mean Abs Error: 0.33\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.71, 1.89)\n",
      "Mean Abs Error: 0.17\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.69, 1.91)\n",
      "Mean Abs Error: 0.08\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.68, 1.94)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.13\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.66, 1.96)\n",
      "Mean Abs Error: 0.14\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.65, 1.99)\n",
      "Mean Abs Error: 0.10\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.63, 2.02)\n",
      "Mean Abs Error: 0.13\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.61, 2.04)\n",
      "Mean Abs Error: 0.08\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.60, 2.07)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.19\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.58, 2.10)\n",
      "Mean Abs Error: 0.07\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.56, 2.13)\n",
      "Mean Abs Error: 0.06\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.54, 2.16)\n",
      "Mean Abs Error: 0.03\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.52, 2.19)\n",
      "Mean Abs Error: 0.09\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.50, 2.22)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.07\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.47, 2.25)\n",
      "Mean Abs Error: 0.05\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.45, 2.28)\n",
      "Mean Abs Error: 0.06\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.42, 2.32)\n",
      "Mean Abs Error: 0.08\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.38, 2.35)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.35, 2.39)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.31, 2.43)\n",
      "Mean Abs Error: 0.03\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.26, 2.46)\n",
      "Mean Abs Error: 0.03\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.21, 2.50)\n",
      "Mean Abs Error: 0.04\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.15, 2.54)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.09, 2.58)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.03\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(0.02, 2.61)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.06, 2.64)\n",
      "Mean Abs Error: 0.03\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.14, 2.66)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.22, 2.68)\n",
      "Mean Abs Error: 0.04\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.31, 2.69)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.01\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.40, 2.68)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.49, 2.66)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.57, 2.61)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.66, 2.56)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.73, 2.49)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.80, 2.42)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.86, 2.36)\n",
      "Mean Abs Error: 0.03\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.91, 2.30)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.94, 2.28)\n",
      "Mean Abs Error: 0.02\n",
      "Ground Truth: N(-1.00, 2.25), Model: N(-0.96, 2.26)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x144 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "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": [
    "# Maximizing likelihood\n",
    "\n",
    "lr = 3e-3\n",
    "max_updates = 500\n",
    "num_iter = 50\n",
    "\n",
    "\n",
    "\n",
    "loss_record = []\n",
    "\n",
    "for iterId in range(num_iter):\n",
    "    \n",
    "    for step in range(max_updates):\n",
    "        \n",
    "        inds = np.random.choice(n_samples,FLAGS.batch_size)\n",
    "        xx = x_train[inds]\n",
    "        \n",
    "        # _ = sess.run(train_u,{input_x: xx, input_ind:inds, learning_rate: lr})\n",
    "        _,_ = sess.run([train_u, train_psi],{input_x: xx, input_ind:inds, learning_rate: lr})\n",
    "        \n",
    "    # ii = np.random.choice()\n",
    "    ii = 0\n",
    "    \n",
    "    # inds = np.array(range(FLAGS.batch_size))\n",
    "    inds = np.random.choice(n_samples,FLAGS.batch_size)\n",
    "    xx = x_train[inds]\n",
    "    true_logp_xx = sess.run(true_mdl_logp_x,{input_x:xx})\n",
    "    est_logp_xx = -sess.run(u_x, {input_ind:inds})\n",
    "    mean_abs_err = np.mean(np.abs(true_logp_xx-est_logp_xx))\n",
    "    print('Mean Abs Error: %.2f' % mean_abs_err)\n",
    "    \n",
    "    mu_val, sig2_val = sess.run([mu,sig2])\n",
    "\n",
    "    print('Ground Truth: N(%.2f, %.2f), Model: N(%.2f, %.2f)' % \\\n",
    "         (mu_0, sig2_0, mu_val, sig2_val))\n",
    "    \n",
    "    if (iterId+1)%5==0 or iterId==0:\n",
    "        \n",
    "        _ = plt.figure(figsize=(6,2))\n",
    "    \n",
    "        m_samples = 5000\n",
    "        true_samples = mu_0 + np.sqrt(sig2_0)*np.random.randn(m_samples,)\n",
    "        mdl_samples = mu_val + np.sqrt(sig2_val)*np.random.randn(m_samples,)\n",
    "        _ = plt.hist([true_samples,mdl_samples],range=[-5.5,5.5],bins=30)\n",
    "\n",
    "        _ = plt.show()\n",
    "    \n",
    "    loss_record.append(mean_abs_err)\n",
    "    \n",
    "_ = plt.plot(loss_record)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.5.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
