{
    "cells": [
        {
            "cell_type": "markdown",
            "metadata": {},
            "source": [
                "# Samples on Bicycle\n",
                "\n",
                "## Define parameters"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 1,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-09-09T17:47:01.044515Z",
                    "iopub.status.busy": "2022-09-09T17:47:01.043728Z",
                    "iopub.status.idle": "2022-09-09T17:47:01.685665Z",
                    "shell.execute_reply": "2022-09-09T17:47:01.685182Z"
                }
            },
            "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",
                "n_samples = parameters[\"n_samples\"]\n",
                "\n",
                "# Visualisation of errors and performances\n",
                "n_omegas = parameters[\"n_omegas\"]\n",
                "n_thetas = parameters[\"n_thetas\"]\n",
                "\n",
                "# keys\n",
                "env_key = jax.random.PRNGKey(env_seed)\n",
                "env_key, sample_key = jax.random.split(env_key)"
            ]
        },
        {
            "cell_type": "markdown",
            "metadata": {},
            "source": [
                "## Define environment"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 2,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-09-09T17:47:01.688227Z",
                    "iopub.status.busy": "2022-09-09T17:47:01.688020Z",
                    "iopub.status.idle": "2022-09-09T17:47:01.749254Z",
                    "shell.execute_reply": "2022-09-09T17:47:01.748770Z"
                }
            },
            "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-09T17:47:01.752962Z",
                    "iopub.status.busy": "2022-09-09T17:47:01.752823Z",
                    "iopub.status.idle": "2022-09-09T17:47:06.231206Z",
                    "shell.execute_reply": "2022-09-09T17:47:06.230686Z"
                }
            },
            "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": "code",
            "execution_count": 4,
            "metadata": {},
            "outputs": [
                {
                    "data": {
                        "text/plain": [
                            "DeviceArray(0, dtype=int32)"
                        ]
                    },
                    "execution_count": 4,
                    "metadata": {},
                    "output_type": "execute_result"
                }
            ],
            "source": [
                "(replay_buffer.absorbing == 1).sum()"
            ]
        },
        {
            "cell_type": "markdown",
            "metadata": {},
            "source": [
                "### Visualize samples"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 5,
            "metadata": {},
            "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",
                "fig, (ax1, ax2) = plt.subplots(2, 1, sharex=True)\n",
                "\n",
                "for episode in range(n_episodes):\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": 6,
            "metadata": {},
            "outputs": [],
            "source": [
                "min_omega = - replay_buffer.states[:, 0].max(); max_omega = replay_buffer.states[:, 0].max()\n",
                "omegas = jnp.linspace(min_omega, max_omega, n_omegas)\n",
                "boxes_omega_size = (max_omega - min_omega) / (n_omegas - 1)\n",
                "omega_boxes = (np.linspace(min_omega , max_omega + boxes_omega_size, n_omegas + 1) - boxes_omega_size / 2)\n",
                "\n",
                "min_theta = - replay_buffer.states[:, 2].max() / 2; max_theta = replay_buffer.states[:, 2].max() / 2\n",
                "thetas = jnp.linspace(min_theta , max_theta , n_thetas)\n",
                "boxes_theta_size = (max_theta - min_theta) / (n_thetas - 1)\n",
                "theta_boxes = (np.linspace(min_theta , max_theta  + boxes_theta_size, n_thetas + 1) - boxes_theta_size / 2)"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 7,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-09-09T17:47:06.311183Z",
                    "iopub.status.busy": "2022-09-09T17:47:06.311007Z",
                    "iopub.status.idle": "2022-09-09T17:47:09.186465Z",
                    "shell.execute_reply": "2022-09-09T17:47:09.186089Z"
                }
            },
            "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": [
                "from pbo.sample_collection.count_samples import count_samples\n",
                "from pbo.utils.two_dimesions_mesh import TwoDimesionsMesh\n",
                "\n",
                "\n",
                "zero_order_count, n_outside_boxes, rewards_count = count_samples(replay_buffer.states[:, 0], replay_buffer.states[:, 2], omega_boxes, theta_boxes, replay_buffer.rewards)\n",
                "zero_order_visu_mesh = TwoDimesionsMesh(omegas, thetas, sleeping_time=0, axis_equal=False)\n",
                "\n",
                "zero_order_visu_mesh.set_values(zero_order_count, zeros_to_nan=True)\n",
                "zero_order_visu_mesh.show(\n",
                "    f\"Samples repartition, \\n{np.around(100 * n_outside_boxes / n_samples)}% are outside the box.\", xlabel=r\"$\\omega$\", ylabel=r\"$\\theta$\"\n",
                ")"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 8,
            "metadata": {
                "execution": {
                    "iopub.execute_input": "2022-09-09T17:47:09.188664Z",
                    "iopub.status.busy": "2022-09-09T17:47:09.188481Z",
                    "iopub.status.idle": "2022-09-09T17:47:09.379409Z",
                    "shell.execute_reply": "2022-09-09T17:47:09.378983Z"
                }
            },
            "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": [
                "zero_order_visu_mesh.set_values(rewards_count, zeros_to_nan=True)\n",
                "zero_order_visu_mesh.show(\n",
                "    f\"Rewards repartition, \\n{np.around(100 * n_outside_boxes / n_samples)}% are outside the box.\", xlabel=r\"$\\omega$\", ylabel=r\"$\\theta$\"\n",
                ")"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 9,
            "metadata": {},
            "outputs": [],
            "source": [
                "min_omega_dot = - replay_buffer.states[:, 1].max() / 2; max_omega_dot = replay_buffer.states[:, 1].max() / 2\n",
                "omega_dots = jnp.linspace(min_omega_dot, max_omega_dot, n_omegas)\n",
                "boxes_omega_dots_size = (max_omega_dot - min_omega_dot) / (n_omegas - 1)\n",
                "omega_dots_boxes = (np.linspace(min_omega_dot, max_omega_dot + boxes_omega_dots_size, n_omegas + 1) - boxes_omega_dots_size / 2)"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 10,
            "metadata": {},
            "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": [
                "omega_count, n_outside_boxes, rewards_omega_count = count_samples(replay_buffer.states[:, 0], replay_buffer.states[:, 1], omega_boxes, omega_dots_boxes, replay_buffer.rewards)\n",
                "omega_visu_mesh = TwoDimesionsMesh(omegas, omega_dots, sleeping_time=0, axis_equal=False)\n",
                "\n",
                "omega_visu_mesh.set_values(omega_count, zeros_to_nan=True)\n",
                "omega_visu_mesh.show(\n",
                "    f\"Samples repartition, \\n{np.around(100 * n_outside_boxes / n_samples)}% are outside the box.\", xlabel=r\"$\\omega$\", ylabel=r\"$\\dot{\\omega}$\"\n",
                ")"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 11,
            "metadata": {},
            "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": [
                "omega_visu_mesh.set_values(rewards_omega_count, zeros_to_nan=True)\n",
                "omega_visu_mesh.show(\n",
                "    f\"Rewards repartition, \\n{np.around(100 * n_outside_boxes / n_samples)}% are outside the box.\", xlabel=r\"$\\omega$\", ylabel=r\"$\\dot{\\omega}$\"\n",
                ")"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 12,
            "metadata": {},
            "outputs": [],
            "source": [
                "min_theta_dot = - replay_buffer.states[:, 3].max() / 2; max_theta_dot = replay_buffer.states[:, 3].max() / 2\n",
                "theta_dots = jnp.linspace(min_theta_dot, max_theta_dot, n_thetas)\n",
                "boxes_theta_dots_size = (max_theta_dot - min_theta_dot) / (n_thetas - 1)\n",
                "theta_dots_boxes = (np.linspace(min_theta_dot, max_theta_dot + boxes_theta_dots_size, n_thetas + 1) - boxes_theta_dots_size / 2)"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 13,
            "metadata": {},
            "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": [
                "theta_count, n_outside_boxes, rewards_theta_count = count_samples(replay_buffer.states[:, 2], replay_buffer.states[:, 3], theta_boxes, theta_dots_boxes, replay_buffer.rewards)\n",
                "theta_visu_mesh = TwoDimesionsMesh(thetas, theta_dots, sleeping_time=0, axis_equal=False)\n",
                "\n",
                "theta_visu_mesh.set_values(theta_count, zeros_to_nan=True)\n",
                "theta_visu_mesh.show(\n",
                "    f\"Samples repartition, \\n{np.around(100 * n_outside_boxes / n_samples)}% are outside the box.\", xlabel=r\"$\\theta$\", ylabel=r\"$\\dot{\\theta}$\"\n",
                ")"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 14,
            "metadata": {},
            "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": [
                "theta_visu_mesh.set_values(rewards_theta_count, zeros_to_nan=True)\n",
                "theta_visu_mesh.show(\n",
                "    f\"Rewards repartition, \\n{np.around(100 * n_outside_boxes / n_samples)}% are outside the box.\", xlabel=r\"$\\theta$\", ylabel=r\"$\\dot{\\theta}$\"\n",
                ")"
            ]
        },
        {
            "cell_type": "markdown",
            "metadata": {},
            "source": [
                "## Analysis on the reward"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 15,
            "metadata": {},
            "outputs": [
                {
                    "data": {
                        "image/png": "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",
                        "text/plain": [
                            "<Figure size 432x288 with 1 Axes>"
                        ]
                    },
                    "metadata": {
                        "needs_background": "light"
                    },
                    "output_type": "display_data"
                }
            ],
            "source": [
                "diff_omega = np.array(jnp.abs(replay_buffer.states[:, 0]) - jnp.abs(replay_buffer.next_states[:, 0]))\n",
                "\n",
                "reward_balance = 1000 * diff_omega\n",
                "_ = plt.hist(reward_balance, 100)"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 16,
            "metadata": {},
            "outputs": [
                {
                    "data": {
                        "image/png": "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",
                        "text/plain": [
                            "<Figure size 432x288 with 1 Axes>"
                        ]
                    },
                    "metadata": {
                        "needs_background": "light"
                    },
                    "output_type": "display_data"
                }
            ],
            "source": [
                "diff_psi = np.array(jnp.square(replay_buffer.states[:, 4]))\n",
                "\n",
                "reward_direction = -5e-2 * diff_psi\n",
                "_ = plt.hist(reward_direction, 100)"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 17,
            "metadata": {},
            "outputs": [
                {
                    "data": {
                        "image/png": "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",
                        "text/plain": [
                            "<Figure size 432x288 with 1 Axes>"
                        ]
                    },
                    "metadata": {
                        "needs_background": "light"
                    },
                    "output_type": "display_data"
                }
            ],
            "source": [
                "total_reward = reward_balance + reward_direction\n",
                "_ = plt.hist(total_reward, 100)"
            ]
        },
        {
            "cell_type": "code",
            "execution_count": 18,
            "metadata": {},
            "outputs": [
                {
                    "data": {
                        "image/png": "iVBORw0KGgoAAAANSUhEUgAAAX0AAAD4CAYAAAAAczaOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAAAPhklEQVR4nO3dbYxcV33H8e+PmIeqUByI60a21Y2EpSq05UErJxWVSuPiOAmq8wJQaAUujeQ3QQIJCRx4ERVIZVSJFNRCZRGrBlFCxINiEdrghqCqLxKygRBIQpptcBpbCV5wCCAElem/L/Y4DPFudtYez+z6fD/Sau4998zd/x3bvzk+986dVBWSpD48Z9IFSJLGx9CXpI4Y+pLUEUNfkjpi6EtSR9ZMuoBnc95559XU1NSky5CkVeWee+75QVWtW2jbig79qakpZmZmJl2GJK0qSR5dbJvTO5LUEUNfkjpi6EtSRwx9SeqIoS9JHTH0Jakjhr4kdcTQl6SOGPqS1JEV/YlcSadmavetTy8f2nPFBCvRSuNIX5I6YuhLUkcMfUnqiKEvSR0x9CWpI4a+JHXE0Jekjhj6ktSRoUI/yaEk305yb5KZ1vaSJAeTPNwez23tSfLRJLNJ7kvy6oH97Gz9H06y88wckiRpMcsZ6f9pVb2yqqbb+m7g9qraDNze1gEuAza3n13Ax2H+TQK4DrgI2AJcd+KNQpI0HqdzG4YdwGvb8n7ga8B7Wvsnq6qAO5OsTXJ+63uwqo4BJDkIbAc+cxo1SGoGb70gLWbYkX4BX0lyT5JdrW19VT3elp8A1rflDcBjA8893NoWa/81SXYlmUkyMzc3N2R5kqRhDDvS/+OqOpLkt4GDSb47uLGqKkmNoqCq2gvsBZienh7JPqWeefM1DRpqpF9VR9rjUeCLzM/Jf79N29Aej7buR4BNA0/f2NoWa5ckjcmSoZ/kN5O86MQysA34DnAAOHEFzk7glrZ8AHhru4rnYuCpNg10G7AtybntBO621iZJGpNhpnfWA19McqL/v1TVvyW5G7g5ydXAo8CbWv8vA5cDs8DPgLcBVNWxJB8A7m793n/ipK4kaTyWDP2qegR4xQLtPwS2LtBewDWL7GsfsG/5ZUqSRsFvzpJWseVepulJXXkbBknqiKEvSR0x9CWpI4a+JHXE0Jekjhj6ktQRQ1+SOmLoS1JHDH1J6oihL0kdMfQlqSOGviR1xNCXpI4Y+pLUEUNfkjpi6EtSRwx9SeqIoS9JHTH0Jakjhr4kdcTQl6SOGPqS1BFDX5I6smbSBUhanqndt458P4f2XDGSfWrlc6QvSR0x9CWpI4a+JHXE0Jekjhj6ktSRoUM/yTlJvpnkS239giR3JZlN8tkkz2vtz2/rs2371MA+rm3tDyW5dORHI0l6VssZ6b8DeHBg/UPADVX1MuBJ4OrWfjXwZGu/ofUjyYXAVcDLge3Ax5Kcc3rlS5KWY6jQT7IRuAL4RFsPcAnwudZlP3BlW97R1mnbt7b+O4CbquoXVfU9YBbYMoJjkCQNadiR/t8D7wb+r62/FPhRVR1v64eBDW15A/AYQNv+VOv/dPsCz3lakl1JZpLMzM3NDX8kkqQlLRn6SV4PHK2qe8ZQD1W1t6qmq2p63bp14/iVktSNYW7D8Brgz5NcDrwA+C3gI8DaJGvaaH4jcKT1PwJsAg4nWQO8GPjhQPsJg8+RJI3BkiP9qrq2qjZW1RTzJ2K/WlV/CdwBvKF12wnc0pYPtHXa9q9WVbX2q9rVPRcAm4Gvj+xIJElLOp0brr0HuCnJB4FvAje29huBTyWZBY4x/0ZBVd2f5GbgAeA4cE1V/fI0fr8kaZmWFfpV9TXga235ERa4+qaqfg68cZHnXw9cv9wiJUmj4SdyJakjhr4kdcTQl6SOGPqS1BFDX5I6YuhLUkcMfUnqiKEvSR0x9CWpI6dzGwZJYzK1+9ZJl6CzhCN9SeqIoS9JHXF6R9JJ00eH9lwxoUp0pjnSl6SOGPqS1BFDX5I6YuhLUkcMfUnqiKEvSR0x9CWpI4a+JHXE0Jekjhj6ktQRQ1+SOmLoS1JHDH1J6oihL0kdMfQlqSOGviR1xNCXpI4sGfpJXpDk60m+leT+JH/T2i9IcleS2SSfTfK81v78tj7btk8N7Ova1v5QkkvP2FFJkhY0zEj/F8AlVfUK4JXA9iQXAx8CbqiqlwFPAle3/lcDT7b2G1o/klwIXAW8HNgOfCzJOSM8FknSEpYM/Zr307b63PZTwCXA51r7fuDKtryjrdO2b02S1n5TVf2iqr4HzAJbRnEQkqThDDWnn+ScJPcCR4GDwH8DP6qq463LYWBDW94APAbQtj8FvHSwfYHnDP6uXUlmkszMzc0t+4AkSYsbKvSr6pdV9UpgI/Oj8987UwVV1d6qmq6q6XXr1p2pXyNJXVrW1TtV9SPgDuCPgLVJ1rRNG4EjbfkIsAmgbX8x8MPB9gWeI0kag2Gu3lmXZG1b/g3gdcCDzIf/G1q3ncAtbflAW6dt/2pVVWu/ql3dcwGwGfj6iI5DkjSENUt34Xxgf7vS5jnAzVX1pSQPADcl+SDwTeDG1v9G4FNJZoFjzF+xQ1Xdn+Rm4AHgOHBNVf1ytIcjnT2mdt866RJ0Floy9KvqPuBVC7Q/wgJX31TVz4E3LrKv64Hrl1+mJGkU/ESuJHXE0Jekjhj6ktQRQ1+SOmLoS1JHDH1J6oihL0kdMfQlqSPDfCJXUmcGPw18aM8VE6xEo+ZIX5I6YuhLUkcMfUnqiKEvSR0x9CWpI4a+JHXE0Jekjhj6ktQRQ1+SOuIncqUVxO/F1ZnmSF+SOmLoS1JHDH1J6oihL0kdMfQlqSOGviR1xNCXpI4Y+pLUEUNfkjpi6EtSRwx9SerIkqGfZFOSO5I8kOT+JO9o7S9JcjDJw+3x3NaeJB9NMpvkviSvHtjXztb/4SQ7z9xhSZIWMsxI/zjwrqq6ELgYuCbJhcBu4Paq2gzc3tYBLgM2t59dwMdh/k0CuA64CNgCXHfijUKSNB5Lhn5VPV5V32jLPwEeBDYAO4D9rdt+4Mq2vAP4ZM27E1ib5HzgUuBgVR2rqieBg8D2UR6MJOnZLWtOP8kU8CrgLmB9VT3eNj0BrG/LG4DHBp52uLUt1v7M37EryUySmbm5ueWUJ0lawtChn+SFwOeBd1bVjwe3VVUBNYqCqmpvVU1X1fS6detGsUtJUjNU6Cd5LvOB/+mq+kJr/n6btqE9Hm3tR4BNA0/f2NoWa5ckjcmS35yVJMCNwINV9eGBTQeAncCe9njLQPvbk9zE/Enbp6rq8SS3AX87cPJ2G3DtaA5DWr1W+rdlDdZ3aM8VE6xEozDM1yW+BngL8O0k97a29zIf9jcnuRp4FHhT2/Zl4HJgFvgZ8DaAqjqW5APA3a3f+6vq2CgOQpI0nCVDv6r+E8gim7cu0L+AaxbZ1z5g33IKlCSNjp/IlaSOGPqS1BFDX5I6YuhLUkcMfUnqiKEvSR0x9CWpI8N8OEvSiK30T+Hq7OVIX5I6YuhLUkcMfUnqiKEvSR0x9CWpI4a+JHXE0JekjnidvqSh+S1aq58jfUnqiKEvSR1xekcaE2+9oJXAkb4kdcTQl6SOGPqS1BFDX5I6YuhLUkcMfUnqiKEvSR3xOn3pDPLafK00jvQlqSOGviR1xNCXpI4sGfpJ9iU5muQ7A20vSXIwycPt8dzWniQfTTKb5L4krx54zs7W/+EkO8/M4Ugal6ndtz79o9VjmJH+PwPbn9G2G7i9qjYDt7d1gMuAze1nF/BxmH+TAK4DLgK2ANedeKOQJI3PkqFfVf8BHHtG8w5gf1veD1w50P7JmncnsDbJ+cClwMGqOlZVTwIHOfmNRJJ0hp3qnP76qnq8LT8BrG/LG4DHBvodbm2LtZ8kya4kM0lm5ubmTrE8SdJCTvs6/aqqJDWKYtr+9gJ7Aaanp0e2X2lcnOPWSnaqI/3vt2kb2uPR1n4E2DTQb2NrW6xdkjRGpxr6B4ATV+DsBG4ZaH9ru4rnYuCpNg10G7AtybntBO621iZJGqMlp3eSfAZ4LXBeksPMX4WzB7g5ydXAo8CbWvcvA5cDs8DPgLcBVNWxJB8A7m793l9Vzzw5LEk6w5YM/ap68yKbti7Qt4BrFtnPPmDfsqqTJI2UN1yTRsCTt1otvA2DJHXE0Jekjhj6ktQR5/SlU+Q8/q8MvhaH9lwxwUq0FEf6ktQRQ1+SOmLoS1JHDH1J6ogncqVl8OStVjtH+pLUEUf6kkbKyzdXNkNfWoJTOjqbOL0jSR1xpC8twNG9zlaGvtQY9OqBoS/pjPGk7srjnL4kdcTQl6SOOL2jrjmPr94Y+uqKIa/eGfqSxsKTuiuDoa+znqN76VcMfZ2VDPqVzVH/5Bj6OmsY9NLSDH2tOo4Szy7+eY6Xoa9VzdG9tDyGvlYsA70/jvrPPENfK4pBrxN8AzgzDH1NhOGu5fANYHTGHvpJtgMfAc4BPlFVe8Zdg0bPENe4+AZwesYa+knOAf4ReB1wGLg7yYGqemCcdejUGe5aSYb5++gbw68b90h/CzBbVY8AJLkJ2AEY+iNmOEvzTuffwrO9YazW/3GMO/Q3AI8NrB8GLhrskGQXsKut/jTJQ2OqbTU5D/jBpItYYXxNTuZrsrChX5d8aLgdDttvjH53sQ0r7kRuVe0F9k66jpUsyUxVTU+6jpXE1+RkviYL6/11GfeXqBwBNg2sb2xtkqQxGHfo3w1sTnJBkucBVwEHxlyDJHVrrNM7VXU8yduB25i/ZHNfVd0/zhrOEk5/nczX5GS+Jgvr+nVJVU26BknSmPjF6JLUEUNfkjpi6K9iSd6VpJKcN+laVoIkf5fku0nuS/LFJGsnXdOkJNme5KEks0l2T7qeSUuyKckdSR5Icn+Sd0y6pkkx9FepJJuAbcD/TLqWFeQg8PtV9YfAfwHXTrieiRi43cllwIXAm5NcONmqJu448K6quhC4GLim19fE0F+9bgDeDXgmvqmqr1TV8bZ6J/OfA+nR07c7qar/BU7c7qRbVfV4VX2jLf8EeJD5OwR0x9BfhZLsAI5U1bcmXcsK9tfAv066iAlZ6HYnXQbcQpJMAa8C7ppwKROx4m7DoHlJ/h34nQU2vQ94L/NTO915ttelqm5pfd7H/H/nPz3O2rTyJXkh8HngnVX140nXMwmG/gpVVX+2UHuSPwAuAL6VBOanML6RZEtVPTHGEidisdflhCR/Bbwe2Fr9fgjF250sIMlzmQ/8T1fVFyZdz6T44axVLskhYLqqur+bYvuCng8Df1JVc5OuZ1KSrGH+RPZW5sP+buAvev70e+ZHSPuBY1X1zgmXM1HO6ets8g/Ai4CDSe5N8k+TLmgS2snsE7c7eRC4uefAb14DvAW4pP3duDfJ5ZMuahIc6UtSRxzpS1JHDH1J6oihL0kdMfQlqSOGviR1xNCXpI4Y+pLUkf8HlL0Tjw0rr9AAAAAASUVORK5CYII=",
                        "text/plain": [
                            "<Figure size 432x288 with 1 Axes>"
                        ]
                    },
                    "metadata": {
                        "needs_background": "light"
                    },
                    "output_type": "display_data"
                }
            ],
            "source": [
                "_ = plt.hist(np.array(replay_buffer.rewards.flatten()), 100)"
            ]
        }
    ],
    "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
}
