{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PBO deep on Bicycle\n",
    "\n",
    "## Define parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T14:00:08.279841Z",
     "iopub.status.busy": "2022-09-28T14:00:08.279678Z",
     "iopub.status.idle": "2022-09-28T14:00:08.962948Z",
     "shell.execute_reply": "2022-09-28T14:00:08.962465Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING:absl:No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import warnings\n",
    "warnings.simplefilter(action='ignore', category=FutureWarning)\n",
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import os\n",
    "import json\n",
    "\n",
    "parameters = json.load(open(\"parameters.json\"))\n",
    "env_seed = parameters[\"env_seed\"]\n",
    "gamma = parameters[\"gamma\"]\n",
    "# Sample collection\n",
    "n_samples = parameters[\"n_samples\"]\n",
    "n_weights = parameters[\"n_weights\"]\n",
    "\n",
    "# Trainings\n",
    "layers_dimension = parameters[\"layers_dimension\"]\n",
    "max_bellman_iterations = parameters[\"max_bellman_iterations\"]\n",
    "training_steps = parameters[\"training_steps\"]\n",
    "fitting_steps = parameters[\"fitting_steps_pbo\"]\n",
    "batch_size_samples = parameters[\"batch_size_samples\"]\n",
    "batch_size_weights = parameters[\"batch_size_weights\"]\n",
    "initial_weight_std = parameters[\"initial_weight_std\"]\n",
    "learning_rate = {\"first\": parameters[\"starting_lr_pbo\"], \"last\": parameters[\"ending_lr_pbo\"], \"duration\": training_steps * fitting_steps * n_samples // batch_size_samples}\n",
    "\n",
    "# Visualisation of errors and performances\n",
    "n_omegas = parameters[\"n_omegas\"]\n",
    "n_thetas = parameters[\"n_thetas\"]\n",
    "n_simulations = parameters[\"n_simulations\"]\n",
    "horizon = parameters[\"horizon\"]\n",
    "max_bellman_iterations_validation = max_bellman_iterations + 10\n",
    "plot_freq = 10\n",
    "\n",
    "# Search for an unused seed\n",
    "max_used_seed = 0\n",
    "if not os.path.exists(\"figures/data/PBO_linear_max_linear/\"):\n",
    "    os.makedirs(\"figures/data/PBO_linear_max_linear/\")\n",
    "for file in os.listdir(\"figures/data/PBO_linear_max_linear/\"):\n",
    "    if int(file.split(\"_\")[0]) == max_bellman_iterations and int(file.split(\"_\")[2][:-4]) > max_used_seed:\n",
    "        max_used_seed = int(file.split(\"_\")[2][:-4])\n",
    "max_used_seed\n",
    "\n",
    "# keys\n",
    "seed = max_used_seed + 1\n",
    "env_key = jax.random.PRNGKey(env_seed)\n",
    "env_key, sample_key = jax.random.split(env_key)\n",
    "key = jax.random.PRNGKey(seed)\n",
    "shuffle_key, q_network_key, pbo_network_key = jax.random.split(key, 3)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T14:00:08.965487Z",
     "iopub.status.busy": "2022-09-28T14:00:08.965301Z",
     "iopub.status.idle": "2022-09-28T14:00:09.232406Z",
     "shell.execute_reply": "2022-09-28T14:00:09.231967Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "from pbo.environments.bicycle import BicycleEnv\n",
    "\n",
    "\n",
    "env = BicycleEnv(env_key, gamma)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Collect samples"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Samples on the mesh and with a uniform policy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T14:00:09.234957Z",
     "iopub.status.busy": "2022-09-28T14:00:09.234816Z",
     "iopub.status.idle": "2022-09-28T14:01:41.100449Z",
     "shell.execute_reply": "2022-09-28T14:01:41.100016Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of episodes: 3500\n"
     ]
    }
   ],
   "source": [
    "from pbo.sample_collection.replay_buffer import ReplayBuffer\n",
    "\n",
    "\n",
    "replay_buffer = ReplayBuffer()\n",
    "\n",
    "env.reset()\n",
    "n_episodes = 0\n",
    "n_steps = 0\n",
    "positions = [[env.position]]\n",
    "\n",
    "for idx_sample in range(n_samples):\n",
    "    state = env.state\n",
    "    \n",
    "    sample_key, key = jax.random.split(sample_key)\n",
    "    action = jax.random.choice(key, env.actions_on_max)\n",
    "    \n",
    "    next_state, reward, absorbing, _ = env.step(action)\n",
    "    n_steps += 1\n",
    "    positions[n_episodes].append(env.position)\n",
    "\n",
    "    replay_buffer.add(state, action, reward, next_state, absorbing)\n",
    "\n",
    "    if absorbing[0] or n_steps >= 20:\n",
    "        sample_key, key = jax.random.split(sample_key)\n",
    "        env.reset(\n",
    "            jax.random.multivariate_normal(\n",
    "                key,\n",
    "                jnp.zeros(4),\n",
    "                jnp.array([[1e-4, -1e-4, 0, 0], [-1e-4, 1e-3, 0, 0], [0, 0, 1e-3, -1e-4], [0, 0, -1e-4, 1e-2]]),\n",
    "            )\n",
    "            / 10\n",
    "        )      \n",
    "        positions[n_episodes] = np.array(positions[n_episodes])\n",
    "        positions.append([])\n",
    "        n_episodes += 1\n",
    "        n_steps = 0\n",
    "\n",
    "replay_buffer.cast_to_jax_array()\n",
    "# assert sum(replay_buffer.rewards == -1) > 0, \"No negative reward has been sampled, please do something!\"\n",
    "print(f\"Number of episodes: {n_episodes}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualize samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T14:01:41.104457Z",
     "iopub.status.busy": "2022-09-28T14:01:41.104313Z",
     "iopub.status.idle": "2022-09-28T14:01:45.886035Z",
     "shell.execute_reply": "2022-09-28T14:01:45.885524Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig, (ax1, ax2) = plt.subplots(2, 1, sharex=True)\n",
    "\n",
    "for episode in range(n_episodes // 10):\n",
    "    ax1.plot(positions[episode][:, 0], positions[episode][:, 1], color=\"black\")\n",
    "\n",
    "    for step in range(len(positions[episode])):\n",
    "        ax2.plot(positions[episode][step, [0, 2]], positions[episode][step, [1, 3]], color=\"black\")\n",
    "\n",
    "\n",
    "ax1.get_xaxis().set_visible(False)\n",
    "ax1.spines[\"bottom\"].set_visible(False)\n",
    "ax1.set_ylabel(\"y\")\n",
    "ax1.set_title(f\"Back tire\")\n",
    "ax2.set_xlabel(\"x\")\n",
    "ax2.set_ylabel(\"y\")\n",
    "ax2.set_title(f\"Bicycle\", y=0, pad=-30, verticalalignment=\"top\")\n",
    "\n",
    "plt.subplots_adjust(hspace=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T14:01:45.887883Z",
     "iopub.status.busy": "2022-09-28T14:01:45.887653Z",
     "iopub.status.idle": "2022-09-28T14:01:46.549629Z",
     "shell.execute_reply": "2022-09-28T14:01:46.549278Z"
    }
   },
   "outputs": [
    {
     "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": [
    "omegas = jnp.linspace(-replay_buffer.states[:, 0].max(), replay_buffer.states[:, 0].max(), n_omegas)\n",
    "omega_dots = jnp.linspace(-replay_buffer.states[:, 1].max() / 2, replay_buffer.states[:, 1].max() / 2, n_omegas)\n",
    "\n",
    "sample_key, key = jax.random.split(sample_key)\n",
    "sample_omegas_omega_dots = jax.random.choice(key, replay_buffer.states[:, :2], shape=(min(n_samples // 100, 50),), replace=False) / 10\n",
    "\n",
    "thetas = jnp.linspace(-replay_buffer.states[:, 2].max() / 2, replay_buffer.states[:, 2].max() / 2, n_thetas)\n",
    "theta_dots = jnp.linspace(-replay_buffer.states[:, 3].max() / 2, replay_buffer.states[:, 3].max() / 2, n_thetas)\n",
    "\n",
    "sample_key, key = jax.random.split(sample_key)\n",
    "sample_thetas_theta_dots = jax.random.choice(key, replay_buffer.states[:, 2:5], shape=(min(n_samples // 100, 50),), replace=False) / 10\n",
    "\n",
    "_ = plt.hist(np.array(replay_buffer.rewards.flatten()), 100)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Collect weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T14:01:46.551482Z",
     "iopub.status.busy": "2022-09-28T14:01:46.551316Z",
     "iopub.status.idle": "2022-09-28T14:01:46.909033Z",
     "shell.execute_reply": "2022-09-28T14:01:46.908545Z"
    }
   },
   "outputs": [],
   "source": [
    "from pbo.weights_collection.weights_buffer import WeightsBuffer\n",
    "from pbo.networks.learnable_q import FullyConnectedQ\n",
    "\n",
    "\n",
    "weights_buffer = WeightsBuffer()\n",
    "\n",
    "# Add the validation weights\n",
    "q = FullyConnectedQ(\n",
    "    state_dim=4,\n",
    "    action_dim=2,\n",
    "    actions_on_max=env.actions_on_max,\n",
    "    gamma=gamma,\n",
    "    network_key=q_network_key,\n",
    "    layers_dimension=layers_dimension,\n",
    "    zero_initializer=True,\n",
    "    learning_rate=learning_rate\n",
    ")\n",
    "validation_weights = q.to_weights(q.params)\n",
    "weights_buffer.add(validation_weights)\n",
    "\n",
    "# Add random weights\n",
    "while len(weights_buffer) < n_weights:\n",
    "    weights = q.random_init_weights()\n",
    "    weights_buffer.add(weights)\n",
    "\n",
    "weights_buffer.cast_to_jax_array()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train deep PBO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T14:01:46.911225Z",
     "iopub.status.busy": "2022-09-28T14:01:46.911047Z",
     "iopub.status.idle": "2022-09-28T15:01:25.620853Z",
     "shell.execute_reply": "2022-09-28T15:01:25.620379Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 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": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from pbo.utils.two_dimesions_mesh import TwoDimesionsMesh\n",
    "from pbo.sample_collection.dataloader import SampleDataLoader\n",
    "from pbo.weights_collection.dataloader import WeightsDataLoader\n",
    "from pbo.networks.learnable_pbo import DeepPBO\n",
    "\n",
    "\n",
    "omega_visu_mesh = TwoDimesionsMesh(omegas, omega_dots, sleeping_time=0, axis_equal=False, zero_centered=True)\n",
    "theta_visu_mesh = TwoDimesionsMesh(thetas, theta_dots, sleeping_time=0, axis_equal=False, zero_centered=True)\n",
    "data_loader_samples = SampleDataLoader(replay_buffer, batch_size_samples, shuffle_key)\n",
    "data_loader_weights = WeightsDataLoader(weights_buffer, batch_size_weights, shuffle_key)\n",
    "pbo = DeepPBO(\n",
    "    q=q,\n",
    "    max_bellman_iterations=max_bellman_iterations,\n",
    "    network_key=pbo_network_key,\n",
    "    learning_rate=learning_rate,\n",
    "    initial_weight_std=initial_weight_std\n",
    ")\n",
    "importance_iteration = jnp.ones(max_bellman_iterations + 1)\n",
    "\n",
    "l2_losses = np.ones((training_steps, fitting_steps)) * np.nan\n",
    "\n",
    "for training_step in range(training_steps):\n",
    "    params_target = pbo.params\n",
    "\n",
    "    for fitting_step in range(fitting_steps):\n",
    "        cumulative_l2_loss = 0\n",
    "\n",
    "        data_loader_weights.shuffle()\n",
    "        for batch_weights in data_loader_weights:\n",
    "            data_loader_samples.shuffle()\n",
    "            for batch_samples in data_loader_samples:\n",
    "                pbo.params, pbo.optimizer_state, l2_loss = pbo.learn_on_batch(\n",
    "                    pbo.params, params_target, pbo.optimizer_state, batch_weights, batch_samples, importance_iteration\n",
    "                )\n",
    "                cumulative_l2_loss += l2_loss\n",
    "        \n",
    "        l2_losses[training_step, fitting_step] = cumulative_l2_loss\n",
    "\n",
    "    if (training_step + 1) % plot_freq == 0 or training_step + 1 == training_steps:\n",
    "        q_weight = validation_weights\n",
    "        for _ in range(max_bellman_iterations):\n",
    "            q_weight = pbo(pbo.params, q_weight.reshape((1, -1)))[0]\n",
    "\n",
    "        metric = env.evaluate(q, q.to_params(q_weight), horizon, n_simulations=1)\n",
    "\n",
    "        d_on_omegas = env.best_action_on_omegas(q, q.to_params(q_weight), omegas, omega_dots, sample_thetas_theta_dots)\n",
    "        T_on_thetas = env.best_action_on_thetas(q, q.to_params(q_weight), sample_omegas_omega_dots, thetas, theta_dots)\n",
    "\n",
    "        omega_visu_mesh.set_values(d_on_omegas)\n",
    "        omega_visu_mesh.show(r\"d on some sampled $\\theta$ and $\\dot{\\theta}$,\" + f\"\\nl2 loss: {str(jnp.round(cumulative_l2_loss, 5))}, iteration {training_step + 1}.\", xlabel=r\"$\\omega$\", ylabel=r\"$\\dot{\\omega}$\")\n",
    "        theta_visu_mesh.set_values(T_on_thetas)\n",
    "        theta_visu_mesh.show(r\"T on some sampled $\\omega$ and $\\dot{\\omega}$\" + f\"\\n{metric[:, 0].mean()} steps, V = {str(jnp.round(metric[:, 1].mean(), 1))}.\", xlabel=r\"$\\theta$\", ylabel=r\"$\\dot{\\theta}$\", clear=False)\n",
    "\n",
    "plt.plot(l2_losses.flatten())\n",
    "\n",
    "plt.xlabel(\"training step x fitting step\")\n",
    "plt.ylabel(r\"$\\sum_{k} \\left(\\Gamma^*Q_{\\Gamma_{\\phi_i}^k(w)} - Q_{\\Gamma_{\\phi_{i + 1}}^{k + 1}(w)} \\right)^2$\")\n",
    "plt.title(\"Training losses\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T15:01:25.622704Z",
     "iopub.status.busy": "2022-09-28T15:01:25.622528Z",
     "iopub.status.idle": "2022-09-28T15:01:25.726930Z",
     "shell.execute_reply": "2022-09-28T15:01:25.726450Z"
    }
   },
   "outputs": [
    {
     "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(l2_losses.flatten())\n",
    "\n",
    "plt.xlabel(\"training step x fitting step\")\n",
    "plt.ylabel(r\"$\\sum_{k} \\left(\\Gamma^*Q_{\\Gamma_{\\phi_i}^k(w)} - Q_{\\Gamma_{\\phi_{i + 1}}^{k + 1}(w)} \\right)^2$\")\n",
    "plt.title(\"Training losses\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T15:01:25.728708Z",
     "iopub.status.busy": "2022-09-28T15:01:25.728569Z",
     "iopub.status.idle": "2022-09-28T15:01:28.862916Z",
     "shell.execute_reply": "2022-09-28T15:01:28.862445Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "test_bellman_iterations = max_bellman_iterations\n",
    "\n",
    "q_weight = validation_weights\n",
    "for _ in range(test_bellman_iterations):\n",
    "    q_weight = pbo(pbo.params, q_weight.reshape((1, -1)))[0]\n",
    "\n",
    "metric = env.evaluate(q, q.to_params(q_weight), horizon, n_simulations=1)\n",
    "\n",
    "d_on_omegas = env.best_action_on_omegas(q, q.to_params(q_weight), omegas, omega_dots, sample_thetas_theta_dots)\n",
    "T_on_thetas = env.best_action_on_thetas(q, q.to_params(q_weight), sample_omegas_omega_dots, thetas, theta_dots)\n",
    "\n",
    "omega_visu_mesh.set_values(d_on_omegas)\n",
    "omega_visu_mesh.show(r\"d on some sampled $\\theta$ and $\\dot{\\theta}$,\" + f\"\\nBellman iteration {test_bellman_iterations}\", xlabel=r\"$\\omega$\", ylabel=r\"$\\dot{\\omega}$\")\n",
    "theta_visu_mesh.set_values(T_on_thetas)\n",
    "theta_visu_mesh.show(r\"T on some sampled $\\omega$ and $\\dot{\\omega}$\" + f\"\\n{metric[:, 0].mean()} steps, V = {str(jnp.round(metric[:, 1].mean(), 1))}.\", xlabel=r\"$\\theta$\", ylabel=r\"$\\dot{\\theta}$\", clear=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T15:01:28.864745Z",
     "iopub.status.busy": "2022-09-28T15:01:28.864573Z",
     "iopub.status.idle": "2022-09-28T15:01:35.639875Z",
     "shell.execute_reply": "2022-09-28T15:01:35.639226Z"
    }
   },
   "outputs": [
    {
     "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": [
    "positions = env.collect_positions(q, q.to_params(q_weight), horizon)\n",
    "\n",
    "plt.plot(positions[:, 0], positions[:, 1], color=\"black\")\n",
    "plt.axis(\"equal\")\n",
    "_ = plt.title(f\"{positions.shape[0]} steps\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T15:01:35.642290Z",
     "iopub.status.busy": "2022-09-28T15:01:35.642000Z",
     "iopub.status.idle": "2022-09-28T15:01:35.665038Z",
     "shell.execute_reply": "2022-09-28T15:01:35.664597Z"
    }
   },
   "outputs": [],
   "source": [
    "# env.simulate(q, q.to_params(q_weight), horizon, 0)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Save the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T15:01:35.666734Z",
     "iopub.status.busy": "2022-09-28T15:01:35.666600Z",
     "iopub.status.idle": "2022-09-28T15:06:42.053763Z",
     "shell.execute_reply": "2022-09-28T15:06:42.053331Z"
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "4578b213ba944a1d95a4a90ec074c298",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/18 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from tqdm.notebook import tqdm\n",
    "\n",
    "\n",
    "metrics = np.ones((max_bellman_iterations_validation + 1, n_simulations, 2)) * np.nan\n",
    "q_weights = validation_weights\n",
    "\n",
    "metrics[0] = env.evaluate(q, q.to_params(q_weights), horizon, n_simulations)\n",
    "\n",
    "for bellman_iteration in tqdm(range(1, max_bellman_iterations_validation + 1)):\n",
    "    q_weights = pbo(pbo.params, q_weights.reshape((1, -1)))[0]\n",
    "\n",
    "    metrics[bellman_iteration] = env.evaluate(q, q.to_params(q_weights), horizon, n_simulations)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T15:06:42.055489Z",
     "iopub.status.busy": "2022-09-28T15:06:42.055313Z",
     "iopub.status.idle": "2022-09-28T15:06:42.177167Z",
     "shell.execute_reply": "2022-09-28T15:06:42.176697Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fc4c5f7d160>]"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "\n",
    "ax1.plot(range(max_bellman_iterations_validation + 1), metrics[:, :, 0].mean(axis=1))\n",
    "ax1.set_xticks(range(max_bellman_iterations_validation + 1))\n",
    "ax2.plot(range(max_bellman_iterations_validation + 1), metrics[:, :, 1].mean(axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T15:06:42.178904Z",
     "iopub.status.busy": "2022-09-28T15:06:42.178728Z",
     "iopub.status.idle": "2022-09-28T15:06:42.189273Z",
     "shell.execute_reply": "2022-09-28T15:06:42.188820Z"
    }
   },
   "outputs": [],
   "source": [
    "np.save(f\"figures/data/PBO_linear_max_linear/{max_bellman_iterations}_metrics_{seed}.npy\", metrics)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.10 ('env_cpu': venv)",
   "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.8.10"
  },
  "vscode": {
   "interpreter": {
    "hash": "af5525a3273d35d601ae265c5d3634806dd61a1c4d085ae098611a6832982bdb"
   }
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {
     "2af19b94683947e1910ee573387507b2": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "DescriptionStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "DescriptionStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "StyleView",
       "description_width": ""
      }
     },
     "4578b213ba944a1d95a4a90ec074c298": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "HBoxModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "HBoxModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "1.5.0",
       "_view_name": "HBoxView",
       "box_style": "",
       "children": [
        "IPY_MODEL_45890a5910a84f7baaad10bd51157523",
        "IPY_MODEL_4ecbe893315543cc8b8d94db2a0f9ac4",
        "IPY_MODEL_cc903822c5bb410b9ff47a8e6621be36"
       ],
       "layout": "IPY_MODEL_5858d19039e84ed3ab3cd2c7261974c7"
      }
     },
     "45890a5910a84f7baaad10bd51157523": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "1.5.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_tooltip": null,
       "layout": "IPY_MODEL_45f2851b20594212b3a0bca47fc13f1b",
       "placeholder": "​",
       "style": "IPY_MODEL_9e31e8bd82a647ac98aaec83dc779361",
       "value": "100%"
      }
     },
     "45f2851b20594212b3a0bca47fc13f1b": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "1.2.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "1.2.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "overflow_x": null,
       "overflow_y": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "4ecbe893315543cc8b8d94db2a0f9ac4": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "FloatProgressModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "FloatProgressModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "1.5.0",
       "_view_name": "ProgressView",
       "bar_style": "success",
       "description": "",
       "description_tooltip": null,
       "layout": "IPY_MODEL_f8d4653befbf48fd80c3a501131e5221",
       "max": 18.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_f3208b512c1b4ebf96e0ed26db540cc8",
       "value": 18.0
      }
     },
     "5858d19039e84ed3ab3cd2c7261974c7": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "1.2.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "1.2.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "overflow_x": null,
       "overflow_y": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "9e31e8bd82a647ac98aaec83dc779361": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "DescriptionStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "DescriptionStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "StyleView",
       "description_width": ""
      }
     },
     "bd23f653c63c41eb83822b8c159b673d": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "1.2.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "1.2.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "overflow_x": null,
       "overflow_y": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     },
     "cc903822c5bb410b9ff47a8e6621be36": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "HTMLModel",
      "state": {
       "_dom_classes": [],
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "HTMLModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/controls",
       "_view_module_version": "1.5.0",
       "_view_name": "HTMLView",
       "description": "",
       "description_tooltip": null,
       "layout": "IPY_MODEL_bd23f653c63c41eb83822b8c159b673d",
       "placeholder": "​",
       "style": "IPY_MODEL_2af19b94683947e1910ee573387507b2",
       "value": " 18/18 [05:06&lt;00:00, 25.01s/it]"
      }
     },
     "f3208b512c1b4ebf96e0ed26db540cc8": {
      "model_module": "@jupyter-widgets/controls",
      "model_module_version": "1.5.0",
      "model_name": "ProgressStyleModel",
      "state": {
       "_model_module": "@jupyter-widgets/controls",
       "_model_module_version": "1.5.0",
       "_model_name": "ProgressStyleModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "StyleView",
       "bar_color": null,
       "description_width": ""
      }
     },
     "f8d4653befbf48fd80c3a501131e5221": {
      "model_module": "@jupyter-widgets/base",
      "model_module_version": "1.2.0",
      "model_name": "LayoutModel",
      "state": {
       "_model_module": "@jupyter-widgets/base",
       "_model_module_version": "1.2.0",
       "_model_name": "LayoutModel",
       "_view_count": null,
       "_view_module": "@jupyter-widgets/base",
       "_view_module_version": "1.2.0",
       "_view_name": "LayoutView",
       "align_content": null,
       "align_items": null,
       "align_self": null,
       "border": null,
       "bottom": null,
       "display": null,
       "flex": null,
       "flex_flow": null,
       "grid_area": null,
       "grid_auto_columns": null,
       "grid_auto_flow": null,
       "grid_auto_rows": null,
       "grid_column": null,
       "grid_gap": null,
       "grid_row": null,
       "grid_template_areas": null,
       "grid_template_columns": null,
       "grid_template_rows": null,
       "height": null,
       "justify_content": null,
       "justify_items": null,
       "left": null,
       "margin": null,
       "max_height": null,
       "max_width": null,
       "min_height": null,
       "min_width": null,
       "object_fit": null,
       "object_position": null,
       "order": null,
       "overflow": null,
       "overflow_x": null,
       "overflow_y": null,
       "padding": null,
       "right": null,
       "top": null,
       "visibility": null,
       "width": null
      }
     }
    },
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
