{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# PBO linear on Bicycle\n",
    "\n",
    "## Define parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T08:01:55.084841Z",
     "iopub.status.busy": "2022-09-28T08:01:55.083906Z",
     "iopub.status.idle": "2022-09-28T08:01:55.801893Z",
     "shell.execute_reply": "2022-09-28T08:01:55.801369Z"
    }
   },
   "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",
    "add_infinity = False\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 = 100\n",
    "\n",
    "# Search for an unused seed\n",
    "max_used_seed = 0\n",
    "if not os.path.exists(\"figures/data/PBO_linear/\"):\n",
    "    os.makedirs(\"figures/data/PBO_linear/\")\n",
    "for file in os.listdir(\"figures/data/PBO_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-28T08:01:55.804066Z",
     "iopub.status.busy": "2022-09-28T08:01:55.803887Z",
     "iopub.status.idle": "2022-09-28T08:01:56.066401Z",
     "shell.execute_reply": "2022-09-28T08:01:56.065915Z"
    }
   },
   "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-28T08:01:56.068618Z",
     "iopub.status.busy": "2022-09-28T08:01:56.068441Z",
     "iopub.status.idle": "2022-09-28T08:03:27.235009Z",
     "shell.execute_reply": "2022-09-28T08:03:27.234564Z"
    }
   },
   "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-28T08:03:27.238393Z",
     "iopub.status.busy": "2022-09-28T08:03:27.238253Z",
     "iopub.status.idle": "2022-09-28T08:03:32.103607Z",
     "shell.execute_reply": "2022-09-28T08:03:32.103146Z"
    }
   },
   "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-28T08:03:32.105496Z",
     "iopub.status.busy": "2022-09-28T08:03:32.105308Z",
     "iopub.status.idle": "2022-09-28T08:03:32.783019Z",
     "shell.execute_reply": "2022-09-28T08:03:32.782559Z"
    }
   },
   "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-28T08:03:32.784950Z",
     "iopub.status.busy": "2022-09-28T08:03:32.784810Z",
     "iopub.status.idle": "2022-09-28T08:03:33.147150Z",
     "shell.execute_reply": "2022-09-28T08:03:33.146653Z"
    }
   },
   "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 linear PBO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T08:03:33.149263Z",
     "iopub.status.busy": "2022-09-28T08:03:33.149126Z",
     "iopub.status.idle": "2022-09-28T08:34:14.966558Z",
     "shell.execute_reply": "2022-09-28T08:34:14.966085Z"
    }
   },
   "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 LinearPBO\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 = LinearPBO(\n",
    "    q=q,\n",
    "    max_bellman_iterations=max_bellman_iterations,\n",
    "    add_infinity=add_infinity,\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",
    "        if not pbo.add_infinity:\n",
    "            q_weight = validation_weights                \n",
    "            for _ in range(max_bellman_iterations):\n",
    "                q_weight = pbo(pbo.params, q_weight)\n",
    "        else:\n",
    "            q_weight = pbo.fixed_point(pbo.params)\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(), label=f\"Training step {training_step + 1}\")\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-28T08:34:14.968346Z",
     "iopub.status.busy": "2022-09-28T08:34:14.968209Z",
     "iopub.status.idle": "2022-09-28T08:34:15.101886Z",
     "shell.execute_reply": "2022-09-28T08:34:15.101340Z"
    }
   },
   "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(), label=f\"Training step {training_step + 1}\")\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-28T08:34:15.103698Z",
     "iopub.status.busy": "2022-09-28T08:34:15.103558Z",
     "iopub.status.idle": "2022-09-28T08:34:18.233888Z",
     "shell.execute_reply": "2022-09-28T08:34:18.233423Z"
    }
   },
   "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-28T08:34:18.235715Z",
     "iopub.status.busy": "2022-09-28T08:34:18.235543Z",
     "iopub.status.idle": "2022-09-28T08:34:25.192380Z",
     "shell.execute_reply": "2022-09-28T08:34:25.191883Z"
    }
   },
   "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-28T08:34:25.195423Z",
     "iopub.status.busy": "2022-09-28T08:34:25.195226Z",
     "iopub.status.idle": "2022-09-28T08:34:25.205783Z",
     "shell.execute_reply": "2022-09-28T08:34:25.205313Z"
    }
   },
   "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-28T08:34:25.209019Z",
     "iopub.status.busy": "2022-09-28T08:34:25.208831Z",
     "iopub.status.idle": "2022-09-28T08:34:52.762492Z",
     "shell.execute_reply": "2022-09-28T08:34:52.762000Z"
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "110ca478f297424b9d089417ba3750a6",
       "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 + 2, 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)\n",
    "\n",
    "metrics[max_bellman_iterations_validation + 1] = env.evaluate(q, q.to_params(pbo.fixed_point(pbo.params)), horizon, n_simulations)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T08:34:52.764848Z",
     "iopub.status.busy": "2022-09-28T08:34:52.764670Z",
     "iopub.status.idle": "2022-09-28T08:34:52.869280Z",
     "shell.execute_reply": "2022-09-28T08:34:52.868841Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fd19dd39a90>]"
      ]
     },
     "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 + 2), metrics[:, :, 0].mean(axis=1))\n",
    "ax2.plot(range(max_bellman_iterations_validation + 2), metrics[:, :, 1].mean(axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-28T08:34:52.871204Z",
     "iopub.status.busy": "2022-09-28T08:34:52.870937Z",
     "iopub.status.idle": "2022-09-28T08:34:52.881470Z",
     "shell.execute_reply": "2022-09-28T08:34:52.881042Z"
    }
   },
   "outputs": [],
   "source": [
    "np.save(f\"figures/data/PBO_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": {
     "110ca478f297424b9d089417ba3750a6": {
      "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_d619b2c04e3f49ed88913e60d7ac1612",
        "IPY_MODEL_9e2c407387274076ac3d87aa36303725",
        "IPY_MODEL_84d9910b05f141558c586f98048a085a"
       ],
       "layout": "IPY_MODEL_e59ce243561942cf9b48b7616dcfe02d"
      }
     },
     "432347b29c764ef7b794f5bee5694e89": {
      "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
      }
     },
     "84d9910b05f141558c586f98048a085a": {
      "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_432347b29c764ef7b794f5bee5694e89",
       "placeholder": "​",
       "style": "IPY_MODEL_a030de1db0d0429193b0b5614f5d299f",
       "value": " 18/18 [00:27&lt;00:00,  1.26it/s]"
      }
     },
     "8e0c69cf6b9341feb349c3205436aa6f": {
      "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
      }
     },
     "98a09769966044a492223dd811e69433": {
      "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
      }
     },
     "9e2c407387274076ac3d87aa36303725": {
      "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_98a09769966044a492223dd811e69433",
       "max": 18.0,
       "min": 0.0,
       "orientation": "horizontal",
       "style": "IPY_MODEL_b130d93353614e04ab2684c62716530d",
       "value": 18.0
      }
     },
     "a030de1db0d0429193b0b5614f5d299f": {
      "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": ""
      }
     },
     "b130d93353614e04ab2684c62716530d": {
      "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": ""
      }
     },
     "d619b2c04e3f49ed88913e60d7ac1612": {
      "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_8e0c69cf6b9341feb349c3205436aa6f",
       "placeholder": "​",
       "style": "IPY_MODEL_e52d9440ba794e498c72d91a8abaae09",
       "value": "100%"
      }
     },
     "e52d9440ba794e498c72d91a8abaae09": {
      "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": ""
      }
     },
     "e59ce243561942cf9b48b7616dcfe02d": {
      "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
}
