{
    "cells": [
        {
            "cell_type": "markdown",
            "metadata": {},
            "source": [
                "# Samples on Car On Hill\n",
                "\n",
                "## Define parameters"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 6,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-08-18T14:43:05.331617Z",
                    "iopub.status.busy": "2022-08-18T14:43:05.331255Z",
                    "iopub.status.idle": "2022-08-18T14:43:06.174988Z",
                    "shell.execute_reply": "2022-08-18T14:43:06.174248Z"
                }
            },
            "outputs": [
                {
                    "name": "stdout",
                    "output_type": "stream",
                    "text": [
                        "The autoreload extension is already loaded. To reload it, use:\n",
                        "  %reload_ext autoreload\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",
                "# Visualisation of errors and performances\n",
                "n_states_x = parameters[\"n_states_x\"]\n",
                "n_states_v = parameters[\"n_states_v\"]\n",
                "horizon = 100\n",
                "\n",
                "\n",
                "# keys\n",
                "sample_key = jax.random.PRNGKey(env_seed)"
            ]
        },
        {
            "cell_type": "markdown",
            "metadata": {},
            "source": [
                "## Define environment"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 7,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-08-18T14:43:06.178718Z",
                    "iopub.status.busy": "2022-08-18T14:43:06.178300Z",
                    "iopub.status.idle": "2022-08-18T14:43:06.266811Z",
                    "shell.execute_reply": "2022-08-18T14:43:06.266076Z"
                }
            },
            "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": 8,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-08-18T14:43:06.272479Z",
                    "iopub.status.busy": "2022-08-18T14:43:06.272138Z",
                    "iopub.status.idle": "2022-08-18T14:43:11.091335Z",
                    "shell.execute_reply": "2022-08-18T14:43:11.090829Z"
                }
            },
            "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": 9,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-08-18T14:43:11.093058Z",
                    "iopub.status.busy": "2022-08-18T14:43:11.092919Z",
                    "iopub.status.idle": "2022-08-18T14:43:11.166673Z",
                    "shell.execute_reply": "2022-08-18T14:43:11.166246Z"
                }
            },
            "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": 9,
                    "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": 10,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-08-18T14:43:11.168469Z",
                    "iopub.status.busy": "2022-08-18T14:43:11.168332Z",
                    "iopub.status.idle": "2022-08-18T14:43:14.131574Z",
                    "shell.execute_reply": "2022-08-18T14:43:14.131014Z"
                }
            },
            "outputs": [
                {
                    "data": {
                        "image/png": "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",
                        "text/plain": [
                            "<Figure size 432x288 with 2 Axes>"
                        ]
                    },
                    "metadata": {
                        "needs_background": "light"
                    },
                    "output_type": "display_data"
                }
            ],
            "source": [
                "import matplotlib.pyplot as plt\n",
                "\n",
                "plt.rc(\"font\", size=15)\n",
                "\n",
                "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",
                "    \"\", xlabel=\"x\", ylabel=\"v\", plot=False, ticks_freq=2\n",
                ")\n",
                "if not os.path.exists(\"figures/\"):\n",
                "    os.makedirs(\"figures/\")\n",
                "_ = plt.savefig(f\"figures/samples.pdf\", bbox_inches='tight')"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 11,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-08-18T14:43:14.134050Z",
                    "iopub.status.busy": "2022-08-18T14:43:14.133730Z",
                    "iopub.status.idle": "2022-08-18T14:43:14.341455Z",
                    "shell.execute_reply": "2022-08-18T14:43:14.341002Z"
                }
            },
            "outputs": [
                {
                    "data": {
                        "image/png": "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",
                        "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",
                "    \"\", xlabel=\"x\", ylabel=\"v\", plot=False, ticks_freq=2\n",
                ")\n",
                "_ = plt.savefig(f\"figures/rewards.pdf\", bbox_inches='tight')"
            ]
        },
        {
            "cell_type": "markdown",
            "metadata": {},
            "source": [
                "## Save the data"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 12,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-08-18T14:46:16.412433Z",
                    "iopub.status.busy": "2022-08-18T14:46:16.412249Z",
                    "iopub.status.idle": "2022-08-18T14:46:16.425401Z",
                    "shell.execute_reply": "2022-08-18T14:46:16.424896Z"
                }
            },
            "outputs": [],
            "source": [
                "if not os.path.exists(\"figures/data/\"):\n",
                "    os.mkdir(\"figures/data/\")\n",
                "np.save(f\"figures/data/samples_count.npy\", samples_count)"
            ]
        }
    ],
    "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
}
