{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [],
   "source": [
    "# A sanity check for the implementation of MADE.\n",
    "import optax\n",
    "from jaxrl.networks.policies import NormalTanhMixturePolicy\n",
    "from jaxrl.networks.autoregressive_policy import MADETanhMixturePolicy\n",
    "import matplotlib.pyplot as plt\n",
    "import jax\n",
    "import numpy as np\n",
    "import jax.numpy as jnp\n",
    "import matplotlib\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [],
   "source": [
    "@jax.jit\n",
    "def sample(rng, inputs, std=0.1):\n",
    "    num_points = len(inputs)\n",
    "    rng, key = jax.random.split(rng)\n",
    "    n = jnp.sqrt(jax.random.uniform(key, shape=(num_points // 2,))\n",
    "                 ) * 540 * (2 * np.pi) / 360\n",
    "    rng, key = jax.random.split(rng)\n",
    "    d1x = -jnp.cos(n) * n + jax.random.uniform(key,\n",
    "                                               shape=(num_points // 2,)) * 0.5\n",
    "    rng, key = jax.random.split(rng)\n",
    "    d1y = jnp.sin(n) * n + jax.random.uniform(key,\n",
    "                                              shape=(num_points // 2,)) * 0.5\n",
    "    x = jnp.concatenate(\n",
    "        [\n",
    "            jnp.stack([d1x, d1y], axis=-1),\n",
    "            jnp.stack([-d1x, -d1y], axis=-1)\n",
    "        ]\n",
    "    )\n",
    "\n",
    "    rng, key = jax.random.split(rng)\n",
    "    x = x / 3 + jax.random.normal(key, x.shape) * std\n",
    "    return jnp.clip(x / 5 + inputs, -0.9999, 0.9999)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tmp = sample(jax.random.PRNGKey(1), jnp.zeros((10024, 2)))\n",
    "x = plt.hist2d(tmp[:, 0], tmp[:, 1], bins=128)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "rng = jax.random.PRNGKey(1)\n",
    "made = NormalTanhMixturePolicy((128, 128), 2)  # Fails\n",
    "made = MADETanhMixturePolicy((128, 128), 2)  # Works\n",
    "rng, key = jax.random.split(rng)\n",
    "params = made.init(key, jnp.zeros(2))['params']\n",
    "\n",
    "optim = optax.adamw(3e-4)\n",
    "optim_state = optim.init(params)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [],
   "source": [
    "@jax.jit\n",
    "def train_step(rng, params, optim_state):\n",
    "    rng, key1, key2 = jax.random.split(rng, 3)\n",
    "    xs = jax.random.normal(key1, shape=(1024, 2)) * 0.1\n",
    "    ys = sample(key2, xs)\n",
    "\n",
    "    def loss_fn(params):\n",
    "        dist = made.apply_fn({'params': params}, xs)\n",
    "        log_probs = dist.log_prob(ys)\n",
    "        return -log_probs.mean()\n",
    "\n",
    "    loss_fn(params)\n",
    "    value, grads = jax.value_and_grad(loss_fn)(params)\n",
    "\n",
    "    updates, new_optim_state = optim.update(grads, optim_state, params)\n",
    "    new_params = optax.apply_updates(params, updates)\n",
    "\n",
    "    return value, rng, new_params, new_optim_state\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2.6660337\n",
      "-0.5110734\n",
      "-0.48464105\n"
     ]
    }
   ],
   "source": [
    "for i in range(100000):\n",
    "    value, rng, params, optim_state = train_step(rng, params, optim_state)\n",
    "    if i % 10000 == 0:\n",
    "        print(value)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "@jax.jit\n",
    "def get_log_probs(xs, ys, params):\n",
    "    dist = made.apply_fn({'params': params}, xs)\n",
    "    return dist.log_prob(ys)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7ff11c173e80>"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = jnp.linspace(-0.9, 0.9, 256)\n",
    "y = jnp.linspace(-0.9, 0.9, 256)\n",
    "xv, yv = jnp.meshgrid(x, y)\n",
    "\n",
    "ys = jnp.stack([xv, yv], -1)\n",
    "xs = jnp.zeros_like(ys) - 0.2\n",
    "\n",
    "log_probs = get_log_probs(xs, ys, params)\n",
    "\n",
    "plt.imshow(jnp.exp(log_probs))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "38f7c99d05bfe7d77e649bfb8f47ca948b73394324f0bd69c65b710f207690dc"
  },
  "kernelspec": {
   "display_name": "Python 3.8.5 64-bit ('base': conda)",
   "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.8.5"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
