{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# FQI on Car On Hill\n",
    "\n",
    "## Define parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:43:12.679860Z",
     "iopub.status.busy": "2022-09-20T17:43:12.679067Z",
     "iopub.status.idle": "2022-09-20T17:43:13.300849Z",
     "shell.execute_reply": "2022-09-20T17:43:13.300344Z"
    }
   },
   "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",
    "\n",
    "# Sample collection\n",
    "oriented_states = jnp.array(parameters[\"oriented_state\"])\n",
    "n_random_samples = parameters[\"n_random_samples\"]\n",
    "n_oriented_samples = parameters[\"n_oriented_samples\"]\n",
    "n_samples = n_random_samples + n_oriented_samples\n",
    "\n",
    "# Trainings\n",
    "layers_dimension = parameters[\"layers_dimension\"]\n",
    "max_bellman_iterations = parameters[\"max_bellman_iterations\"]\n",
    "batch_size_samples = n_samples\n",
    "fitting_steps = parameters[\"fitting_steps_fqi\"]\n",
    "learning_rate = {\"first\": parameters[\"starting_lr_fqi\"], \"last\": parameters[\"ending_lr_fqi\"], \"duration\": fitting_steps * n_samples // batch_size_samples}\n",
    "max_patience = parameters[\"patience\"]\n",
    "\n",
    "# Visualisation of errors and performances\n",
    "n_states_x = parameters[\"n_states_x\"]\n",
    "n_states_v = parameters[\"n_states_v\"]\n",
    "horizon = parameters[\"horizon\"]\n",
    "\n",
    "# Search for an unused seed\n",
    "max_used_seed = 0\n",
    "if not os.path.exists(\"figures/data/FQI/\"):\n",
    "    os.makedirs(\"figures/data/FQI/\")\n",
    "for file in os.listdir(\"figures/data/FQI/\"):\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",
    "sample_key = jax.random.PRNGKey(env_seed)\n",
    "key = jax.random.PRNGKey(seed)\n",
    "shuffle_key, q_network_key, _ = jax.random.split(key, 3) # 3 keys are generated to be coherent with the other trainings"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:43:13.304298Z",
     "iopub.status.busy": "2022-09-20T17:43:13.304092Z",
     "iopub.status.idle": "2022-09-20T17:43:13.379355Z",
     "shell.execute_reply": "2022-09-20T17:43:13.378870Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "from pbo.environments.car_on_hill import CarOnHillEnv\n",
    "\n",
    "\n",
    "env = CarOnHillEnv(gamma)\n",
    "\n",
    "states_x = jnp.linspace(-env.max_position, env.max_position, n_states_x)\n",
    "boxes_x_size = (2 * env.max_position) / (n_states_x - 1)\n",
    "states_x_boxes = (np.linspace(-env.max_position, env.max_position + boxes_x_size, n_states_x + 1) - boxes_x_size / 2)\n",
    "states_v = jnp.linspace(-env.max_velocity, env.max_velocity, n_states_v)\n",
    "boxes_v_size = (2 * env.max_velocity) / (n_states_v - 1)\n",
    "states_v_boxes = (np.linspace(-env.max_velocity, env.max_velocity + boxes_v_size, n_states_v + 1) - boxes_v_size / 2)"
   ]
  },
  {
   "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-20T17:43:13.381536Z",
     "iopub.status.busy": "2022-09-20T17:43:13.381404Z",
     "iopub.status.idle": "2022-09-20T17:43:18.593603Z",
     "shell.execute_reply": "2022-09-20T17:43:18.593128Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of episodes: 173\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",
    "for idx_sample in range(n_random_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",
    "    next_state, reward, absorbing, _ = env.step(action)\n",
    "    n_steps += 1\n",
    "\n",
    "    replay_buffer.add(state, action, reward, next_state, absorbing)\n",
    "\n",
    "    if absorbing or n_steps > horizon:\n",
    "        env.reset()\n",
    "        n_episodes += 1\n",
    "        n_steps = 0\n",
    "\n",
    "\n",
    "env.reset(oriented_states[1])\n",
    "n_episodes += 1\n",
    "n_steps = 0\n",
    "for idx_sample in range(n_oriented_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",
    "    next_state, reward, absorbing, _ = env.step(action)\n",
    "    n_steps += 1\n",
    "\n",
    "    replay_buffer.add(state, action, reward, next_state, absorbing)\n",
    "\n",
    "    if absorbing or n_steps > horizon:\n",
    "        sample_key, key = jax.random.split(sample_key)\n",
    "        alpha = jax.random.uniform(key)\n",
    "        env.reset(alpha * oriented_states[0] + (1 - alpha) * oriented_states[1])\n",
    "\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 positive reward has been sampled, please do something!\"\n",
    "print(f\"Number of episodes: {n_episodes}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:43:18.595418Z",
     "iopub.status.busy": "2022-09-20T17:43:18.595279Z",
     "iopub.status.idle": "2022-09-20T17:43:18.669357Z",
     "shell.execute_reply": "2022-09-20T17:43:18.668899Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "DeviceArray([[-1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [-1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [ 1],\n",
       "             [-1],\n",
       "             [-1]], dtype=int32)"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "replay_buffer.actions[(replay_buffer.rewards == 1).flatten()]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Visualize samples"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:43:18.671216Z",
     "iopub.status.busy": "2022-09-20T17:43:18.671084Z",
     "iopub.status.idle": "2022-09-20T17:43:22.268268Z",
     "shell.execute_reply": "2022-09-20T17:43:22.267800Z"
    }
   },
   "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": [
    "from pbo.sample_collection.count_samples import count_samples\n",
    "from pbo.utils.two_dimesions_mesh import TwoDimesionsMesh\n",
    "\n",
    "\n",
    "samples_count, n_outside_boxes, rewards_count = count_samples(replay_buffer.states[:, 0], replay_buffer.states[:, 1], states_x_boxes, states_v_boxes, replay_buffer.rewards)\n",
    "samples_visu_mesh = TwoDimesionsMesh(states_x, states_v, sleeping_time=0, axis_equal=False)\n",
    "\n",
    "samples_visu_mesh.set_values(samples_count, zeros_to_nan=True)\n",
    "samples_visu_mesh.show(\n",
    "    f\"Samples repartition, \\n{int(100 * n_outside_boxes / n_samples)}% are outside the box.\", xlabel=\"x\", ylabel=\"v\"\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:43:22.270167Z",
     "iopub.status.busy": "2022-09-20T17:43:22.269977Z",
     "iopub.status.idle": "2022-09-20T17:43:22.449366Z",
     "shell.execute_reply": "2022-09-20T17:43:22.448908Z"
    }
   },
   "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": [
    "samples_visu_mesh.set_values(rewards_count, zeros_to_nan=True)\n",
    "samples_visu_mesh.show(\n",
    "    f\"Rewards repartition, \\n{int(100 * n_outside_boxes / n_samples)}% are outside the box.\", xlabel=\"x\", ylabel=\"v\"\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Train FQI"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:43:22.451267Z",
     "iopub.status.busy": "2022-09-20T17:43:22.451132Z",
     "iopub.status.idle": "2022-09-20T17:47:39.024950Z",
     "shell.execute_reply": "2022-09-20T17:47:39.024489Z"
    }
   },
   "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 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from pbo.sample_collection.dataloader import SampleDataLoader\n",
    "from pbo.networks.learnable_q import FullyConnectedQ\n",
    "\n",
    "\n",
    "data_loader_samples = SampleDataLoader(replay_buffer, batch_size_samples, shuffle_key)\n",
    "q = FullyConnectedQ(\n",
    "    state_dim=2,\n",
    "    action_dim=1,\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",
    "iterated_q = np.zeros((max_bellman_iterations + 1, n_states_x, n_states_v, 2))\n",
    "iterated_v = np.zeros((max_bellman_iterations + 1, n_states_x, n_states_v))\n",
    "\n",
    "iterated_q[0] = env.q_mesh(q, q.params, states_x, states_v)\n",
    "iterated_v[0] = env.v_mesh(q, horizon, states_x, states_v)\n",
    "\n",
    "q_visu_mesh = TwoDimesionsMesh(states_x, states_v, sleeping_time=0, axis_equal=False, zero_centered=True)\n",
    "l2_losses = np.ones((max_bellman_iterations, fitting_steps)) * np.nan\n",
    "\n",
    "for bellman_iteration in range(1, max_bellman_iterations + 1):\n",
    "    q.reset_optimizer()\n",
    "    params_target = q.params\n",
    "    best_loss = float('inf')\n",
    "    patience = 0\n",
    "\n",
    "    for step in range(fitting_steps):\n",
    "        cumulative_l2_loss = 0\n",
    "        \n",
    "        data_loader_samples.shuffle()\n",
    "        for batch_samples in data_loader_samples:\n",
    "            q.params, q.optimizer_state, l2_loss = q.learn_on_batch(q.params, params_target, q.optimizer_state, batch_samples)\n",
    "            cumulative_l2_loss += l2_loss\n",
    "\n",
    "        l2_losses[bellman_iteration - 1, step] = cumulative_l2_loss\n",
    "        if cumulative_l2_loss < best_loss:\n",
    "            patience = 0\n",
    "            best_loss = cumulative_l2_loss\n",
    "        else:\n",
    "            patience += 1\n",
    "\n",
    "        if patience > max_patience:\n",
    "            break\n",
    "\n",
    "    diff_q = env.diff_q_mesh(q, q.params, states_x, states_v)\n",
    "\n",
    "    q_visu_mesh.set_values(diff_q)\n",
    "    q_visu_mesh.show(f\"Q differences, \\nl2 loss: {str(jnp.round(cumulative_l2_loss, 3))}, iteration {bellman_iteration}, step {step + 1}\", xlabel=\"x\", ylabel=\"v\")\n",
    "\n",
    "    iterated_q[bellman_iteration] = env.q_mesh(q, q.params, states_x, states_v)\n",
    "    iterated_v[bellman_iteration] = env.v_mesh(q, horizon, states_x, states_v)\n",
    "\n",
    "for bellman_iteration in range(0, max_bellman_iterations, max(max_bellman_iterations // 10, 1)):\n",
    "    plt.plot(l2_losses[bellman_iteration], label=f\"Iteration {bellman_iteration + 1}\")\n",
    "    params_target = q.params\n",
    "\n",
    "plt.legend()\n",
    "plt.xlabel(\"fitting step\")\n",
    "plt.ylabel(r\"$(\\Gamma^*Q_i - Q_{i +  1})^2$\")\n",
    "plt.title(\"Training losses\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:47:39.026685Z",
     "iopub.status.busy": "2022-09-20T17:47:39.026550Z",
     "iopub.status.idle": "2022-09-20T17:47:39.212727Z",
     "shell.execute_reply": "2022-09-20T17:47:39.212286Z"
    }
   },
   "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": [
    "bellman_iteration = -1\n",
    "\n",
    "q_visu_mesh.set_values((iterated_q[bellman_iteration, :, :, 1] > iterated_q[bellman_iteration, :, :, 0]).astype(float))\n",
    "q_visu_mesh.show(f\"FQI Q policy, {max_bellman_iterations} iterations\", xlabel=\"x\", ylabel=\"v\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:47:39.214581Z",
     "iopub.status.busy": "2022-09-20T17:47:39.214363Z",
     "iopub.status.idle": "2022-09-20T17:47:39.224663Z",
     "shell.execute_reply": "2022-09-20T17:47:39.224173Z"
    }
   },
   "outputs": [],
   "source": [
    "# env.simulate(q, horizon, jnp.array([-0.5, 0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:47:39.226356Z",
     "iopub.status.busy": "2022-09-20T17:47:39.226221Z",
     "iopub.status.idle": "2022-09-20T17:47:46.089730Z",
     "shell.execute_reply": "2022-09-20T17:47:46.089255Z"
    }
   },
   "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": [
    "final_v = env.v_mesh(q, horizon, states_x, states_v)\n",
    "\n",
    "average_performance = final_v * samples_count\n",
    "\n",
    "q_visu_mesh.set_values(average_performance)\n",
    "q_visu_mesh.show(r\"$V^{\\pi_{fqi}}, \\mathbb{E}\\left[ V^{\\pi_{fqi}} \\right] =$\" + str(np.round(np.mean(average_performance), 2)), xlabel=\"x\", ylabel=\"v\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Save the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "execution": {
     "iopub.execute_input": "2022-09-20T17:47:46.091757Z",
     "iopub.status.busy": "2022-09-20T17:47:46.091619Z",
     "iopub.status.idle": "2022-09-20T17:47:46.102293Z",
     "shell.execute_reply": "2022-09-20T17:47:46.101886Z"
    }
   },
   "outputs": [],
   "source": [
    "np.save(f\"figures/data/FQI/{max_bellman_iterations}_Q_{seed}.npy\", iterated_q)\n",
    "np.save(f\"figures/data/FQI/{max_bellman_iterations}_V_{seed}.npy\", iterated_v)"
   ]
  }
 ],
 "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"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
