{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "cxAqUGugzFnH"
   },
   "source": [
    "# RacerCar HJ-Reachability Notebook -- Don't Clear Output!\n",
    "\n",
    "Notebook dependencies:\n",
    "- System: python3, ffmpeg (for rendering animations)\n",
    "- Python: jupyter, jax, numpy, matplotlib, plotly, tqdm, hj_reachability\n",
    "\n",
    "Example setup for a Ubuntu system (Mac users, maybe `brew` instead of `sudo apt`; Windows users, learn to love [WSL](https://docs.microsoft.com/en-us/windows/wsl/install-win10)):\n",
    "```\n",
    "sudo apt install ffmpeg\n",
    "/usr/bin/python3 -m pip install --upgrade pip\n",
    "pip install --upgrade jupyter jax[cpu] numpy matplotlib plotly tqdm hj-reachability\n",
    "jupyter notebook  # from the directory of this notebook\n",
    "```\n",
    "Alternatively, view this notebook on [Google Colab](https://colab.research.google.com/github/StanfordASL/hj_reachability/blob/main/examples/quickstart.ipynb) and run a cell containing this command:\n",
    "```\n",
    "!pip install --upgrade hj-reachability\n",
    "```"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "id": "mgKB0FrTzFnM"
   },
   "outputs": [],
   "source": [
    "import jax\n",
    "import jax.numpy as jnp\n",
    "import numpy as np\n",
    "import math\n",
    "\n",
    "from IPython.display import HTML\n",
    "import matplotlib.animation as anim\n",
    "import matplotlib.pyplot as plt\n",
    "# import plotly.graph_objects as go\n",
    "\n",
    "import hj_reachability as hj"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import PolynomialFeatures\n",
    "from sklearn import linear_model"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "3gZHSzLfzFnR"
   },
   "source": [
    "## Defining your own dynamics: `DubinsDog`"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "uPckPKqEzFnS"
   },
   "outputs": [],
   "source": [
    "class DubinsDog(hj.ControlAndDisturbanceAffineDynamics):\n",
    "\n",
    "    def __init__(self,\n",
    "                 dt = 0.1,                                   # dt per step: 0.1 seconds   \n",
    "                 fixed_speed=0.5,                            # nominal speed: 0.4 m/s\n",
    "                 max_turn_rate=40.0*np.pi/180.0,             # 60 deg/s\n",
    "                 control_mode=\"min\",\n",
    "                 disturbance_mode=\"max\",\n",
    "                 control_space=None,\n",
    "                 disturbance_space=None):\n",
    "        \n",
    "        self.v = fixed_speed\n",
    "        self.dt = dt\n",
    "        max_turn_rate_disturbance = (40.0*self.v)*np.pi/180.0\n",
    "        self.max_pos_disturbance = 0.5*self.v*self.dt\n",
    "        \n",
    "        if control_space is None:\n",
    "            control_space = hj.sets.Box(jnp.array([-max_turn_rate]),\n",
    "                                        jnp.array([max_turn_rate]))\n",
    "        if disturbance_space is None:\n",
    "            disturbance_space = hj.sets.Box(jnp.array([-max_turn_rate_disturbance, -self.max_pos_disturbance]),\n",
    "                                        jnp.array([max_turn_rate_disturbance, self.max_pos_disturbance]))\n",
    "        \n",
    "        super().__init__(control_mode, disturbance_mode, control_space, disturbance_space)\n",
    "\n",
    "    def open_loop_dynamics(self, state, time):\n",
    "        _, _, theta = state\n",
    "        return jnp.array([self.v * jnp.cos(theta), self.v * jnp.sin(theta), 0.])\n",
    "\n",
    "    def control_jacobian(self, state, time):\n",
    "        theta = state[2]\n",
    "        return jnp.array([\n",
    "            [0.],\n",
    "            [0.],\n",
    "            [1.],\n",
    "        ])\n",
    "\n",
    "    def disturbance_jacobian(self, state, time):\n",
    "        theta = state[2]\n",
    "        return jnp.array([\n",
    "            [0., -jnp.sin(theta)],\n",
    "            [0., jnp.cos(theta)],\n",
    "            [1., 0.],\n",
    "        ])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "uPckPKqEzFnS"
   },
   "outputs": [],
   "source": [
    "class DubinsDog3(hj.ControlAndDisturbanceAffineDynamics):\n",
    "\n",
    "    def __init__(self,\n",
    "                 dt = 0.1,                                   # dt per step: 0.1 seconds   \n",
    "                 fixed_speed=0.5,                            # nominal speed: 0.4 m/s\n",
    "                 max_turn_rate=40.0*np.pi/180.0,             # 60 deg/s\n",
    "                 control_mode=\"min\",\n",
    "                 disturbance_mode=\"max\",\n",
    "                 control_space=None,\n",
    "                 disturbance_space=None):\n",
    "        \n",
    "        self.v = fixed_speed\n",
    "        self.dt = dt\n",
    "        max_turn_rate_disturbance = (40.0*self.v)*np.pi/180.0\n",
    "        self.max_pos_disturbance = 5.*self.v*self.dt\n",
    "        \n",
    "        if control_space is None:\n",
    "            control_space = hj.sets.Box(jnp.array([-max_turn_rate]),\n",
    "                                        jnp.array([max_turn_rate]))\n",
    "        if disturbance_space is None:\n",
    "            disturbance_space = hj.sets.Box(jnp.array([-max_turn_rate_disturbance, -self.max_pos_disturbance]),\n",
    "                                        jnp.array([max_turn_rate_disturbance, self.max_pos_disturbance]))\n",
    "        \n",
    "        super().__init__(control_mode, disturbance_mode, control_space, disturbance_space)\n",
    "\n",
    "    def open_loop_dynamics(self, state, time):\n",
    "        _, _, theta = state\n",
    "        return jnp.array([self.v * jnp.cos(theta), self.v * jnp.sin(theta), 0.])\n",
    "\n",
    "    def control_jacobian(self, state, time):\n",
    "        theta = state[2]\n",
    "        return jnp.array([\n",
    "            [self.v*-jnp.sin(theta)],\n",
    "            [self.v*jnp.cos(theta)],\n",
    "            [1.],\n",
    "        ])\n",
    "\n",
    "    def disturbance_jacobian(self, state, time):\n",
    "        theta = state[2]\n",
    "        return jnp.array([\n",
    "            [-self.v*jnp.sin(theta), -jnp.cos(theta)],\n",
    "            [self.v*jnp.cos(theta), -jnp.sin(theta)],\n",
    "            [1., 0.],\n",
    "        ])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "id": "uPckPKqEzFnS"
   },
   "outputs": [],
   "source": [
    "class DubinsDog4(hj.ControlAndDisturbanceAffineDynamics):\n",
    "\n",
    "    def __init__(self,\n",
    "                 dt = 0.1,                                   # dt per step: 0.1 seconds   \n",
    "                 fixed_speed=0.5,                            # nominal speed: 0.4 m/s\n",
    "                 max_turn_rate=40.0*np.pi/180.0,             # 60 deg/s\n",
    "                 control_mode=\"min\",\n",
    "                 disturbance_mode=\"max\",\n",
    "                 control_space=None,\n",
    "                 disturbance_space=None):\n",
    "        \n",
    "        self.v = fixed_speed\n",
    "        self.dt = dt\n",
    "        max_turn_rate_disturbance = (40.0*self.v)*np.pi/180.0\n",
    "        self.max_pos_disturbance = 5.*self.v*self.dt\n",
    "        \n",
    "        if control_space is None:\n",
    "            control_space = hj.sets.Box(jnp.array([-max_turn_rate]),\n",
    "                                        jnp.array([max_turn_rate]))\n",
    "        if disturbance_space is None:\n",
    "            disturbance_space = hj.sets.Box(jnp.array([-max_turn_rate_disturbance, -self.max_pos_disturbance]),\n",
    "                                        jnp.array([max_turn_rate_disturbance, self.max_pos_disturbance]))\n",
    "        \n",
    "        super().__init__(control_mode, disturbance_mode, control_space, disturbance_space)\n",
    "\n",
    "    def open_loop_dynamics(self, state, time):\n",
    "        _, _, theta, theta_dot = state\n",
    "        return jnp.array([self.v * jnp.cos(theta), self.v * jnp.sin(theta), theta_dot, 0.])\n",
    "\n",
    "    def control_jacobian(self, state, time):\n",
    "        theta = state[2]\n",
    "        return jnp.array([\n",
    "            [self.v*-jnp.sin(theta)],\n",
    "            [self.v*jnp.cos(theta)],\n",
    "            [1.],\n",
    "        ])\n",
    "\n",
    "    def disturbance_jacobian(self, state, time):\n",
    "        theta = state[2]\n",
    "        return jnp.array([\n",
    "            [-self.v*jnp.sin(theta), -jnp.cos(theta)],\n",
    "            [self.v*jnp.cos(theta), -jnp.sin(theta)],\n",
    "            [1., 0.],\n",
    "        ])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "id": "3txvuuMu2ZNG"
   },
   "outputs": [],
   "source": [
    "# Define low end of values for x, y, theta\n",
    "lo_x = 0. \n",
    "lo_y = -2.5\n",
    "lo_theta = -np.pi\n",
    "\n",
    "# Concatenate above into a single numpy array object\n",
    "lo_xx = np.array([lo_x, lo_y, lo_theta])\n",
    "\n",
    "# Define the ranges for x, y, theta\n",
    "r_x = 10. \n",
    "r_y = 5. \n",
    "r_theta = 2.0*np.pi\n",
    "\n",
    "# Derive upper end of values for x, y, theta from low end values and range, and concatenate into single numpy array\n",
    "hi_xx = np.array([lo_x+r_x, lo_y+r_y, lo_theta+r_theta])\n",
    "\n",
    "# Define the number of discretization points in x, y, theta\n",
    "n_x = 1+round(r_x)*10\n",
    "n_y = 1+round(r_y)*10\n",
    "n_theta = 181\n",
    "\n",
    "# Generate constants giving information on the grid resolution (points per unit measure (meters, radians))\n",
    "k_x = n_x/r_x\n",
    "k_y = n_y/r_y\n",
    "k_theta = n_theta/r_theta\n",
    "\n",
    "# Define some necessary parameters relating to physical objects\n",
    "spacerVal = 13.\n",
    "firstObs = 5.\n",
    "rObs = 0.35\n",
    "rStrelka = 0.35\n",
    "g_x = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'\\ndef processLayout(layout_number, obstacle_list, dog_class, rObs=0.35, rStrelka=0.35, grid,solver_accuracy=\"medium\"):\\n    \\n    ###############################\\n    # Set up necessary parameters #\\n    ###############################\\n    \\n    # Define low end of values for x, y, theta\\n    lo_x = 0. \\n    lo_y = -2.5\\n    lo_theta = -np.pi\\n\\n    # Concatenate above into a single numpy array object\\n    lo_xx = np.array([lo_x, lo_y, lo_theta])\\n\\n    # Define the ranges for x, y, theta\\n    r_x = 10. \\n    r_y = 5. \\n    r_theta = 2.0*np.pi\\n\\n    # Derive upper end of values for x, y, theta from low end values and range, and concatenate into single numpy array\\n    hi_xx = np.array([lo_x+r_x, lo_y+r_y, lo_theta+r_theta])\\n\\n    # Define the number of discretization points in x, y, theta\\n    n_x = 1+round(r_x)*10\\n    n_y = 1+round(r_y)*10\\n    n_theta = 181\\n\\n    # Generate constants giving information on the grid resolution (points per unit measure (meters, radians))\\n    k_x = n_x/r_x\\n    k_y = n_y/r_y\\n    k_theta = n_theta/r_theta\\n\\n    # Define some necessary parameters relating to physical objects\\n    spacerVal = 13.\\n    firstObs = 5.\\n    rObs = 0.35\\n    rStrelka = 0.35\\n    g_x = 10\\n    \\n    ###############################\\n    #             END             #\\n    ###############################\\n    L_obs = len(obstacle_list)\\n    \\n    # print(grid.states[..., 0].shape)\\n    x_values = grid.states[..., 0]\\n    y_values = grid.states[..., 1]\\n\\n    if L_obs <= 1:\\n        raise ValueError(\\'Must have at least two obstacles!\\')\\n    elif L_obs == 2:\\n        x0, y0 = obstacles[0]\\n        states0 = jnp.hypot(x_values-x0, y_values-y0)\\n\\n        x1, y1 = obstacles[1]\\n        states1 = jnp.hypot(x_values-x1, y_values-y1)\\n\\n        statesFull = jnp.stack((states0, states1), axis=0)\\n    else:\\n        x0, y0 = obstacles[0]\\n        states0 = jnp.hypot(x_values-x0, y_values-y0)\\n\\n        x1, y1 = obstacles[1]\\n        states1 = jnp.hypot(x_values-x1, y_values-y1)\\n\\n        statesFull = jnp.stack((states0, states1), axis=0)\\n\\n        for k in range(2, L_obs):\\n            x, y = obstacles[k]\\n            states_tmp = jnp.hypot(x_values-x, y_values-y)\\n            statesFull = jnp.concatenate((statesFull, jnp.expand_dims(states_tmp, 0)), axis=0)\\n    \\n    values = rObs + rStrelka - jnp.min(statesFull, axis=0)\\n    \\n    # Define the arguments to hj.solve\\n    time = 0.\\n    target_time = -5.0\\n    times = np.linspace(0, target_time, 25)\\n    initial_values = values\\n    \\n    return jnp.max(hj.solve(solver_settings, dynamics, grid, times, initial_values), axis=0)\\n    \\n'"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "'''\n",
    "def processLayout(layout_number, obstacle_list, dog_class, rObs=0.35, rStrelka=0.35, grid,solver_accuracy=\"medium\"):\n",
    "    \n",
    "    ###############################\n",
    "    # Set up necessary parameters #\n",
    "    ###############################\n",
    "    \n",
    "    # Define low end of values for x, y, theta\n",
    "    lo_x = 0. \n",
    "    lo_y = -2.5\n",
    "    lo_theta = -np.pi\n",
    "\n",
    "    # Concatenate above into a single numpy array object\n",
    "    lo_xx = np.array([lo_x, lo_y, lo_theta])\n",
    "\n",
    "    # Define the ranges for x, y, theta\n",
    "    r_x = 10. \n",
    "    r_y = 5. \n",
    "    r_theta = 2.0*np.pi\n",
    "\n",
    "    # Derive upper end of values for x, y, theta from low end values and range, and concatenate into single numpy array\n",
    "    hi_xx = np.array([lo_x+r_x, lo_y+r_y, lo_theta+r_theta])\n",
    "\n",
    "    # Define the number of discretization points in x, y, theta\n",
    "    n_x = 1+round(r_x)*10\n",
    "    n_y = 1+round(r_y)*10\n",
    "    n_theta = 181\n",
    "\n",
    "    # Generate constants giving information on the grid resolution (points per unit measure (meters, radians))\n",
    "    k_x = n_x/r_x\n",
    "    k_y = n_y/r_y\n",
    "    k_theta = n_theta/r_theta\n",
    "\n",
    "    # Define some necessary parameters relating to physical objects\n",
    "    spacerVal = 13.\n",
    "    firstObs = 5.\n",
    "    rObs = 0.35\n",
    "    rStrelka = 0.35\n",
    "    g_x = 10\n",
    "    \n",
    "    ###############################\n",
    "    #             END             #\n",
    "    ###############################\n",
    "    L_obs = len(obstacle_list)\n",
    "    \n",
    "    # print(grid.states[..., 0].shape)\n",
    "    x_values = grid.states[..., 0]\n",
    "    y_values = grid.states[..., 1]\n",
    "\n",
    "    if L_obs <= 1:\n",
    "        raise ValueError('Must have at least two obstacles!')\n",
    "    elif L_obs == 2:\n",
    "        x0, y0 = obstacles[0]\n",
    "        states0 = jnp.hypot(x_values-x0, y_values-y0)\n",
    "\n",
    "        x1, y1 = obstacles[1]\n",
    "        states1 = jnp.hypot(x_values-x1, y_values-y1)\n",
    "\n",
    "        statesFull = jnp.stack((states0, states1), axis=0)\n",
    "    else:\n",
    "        x0, y0 = obstacles[0]\n",
    "        states0 = jnp.hypot(x_values-x0, y_values-y0)\n",
    "\n",
    "        x1, y1 = obstacles[1]\n",
    "        states1 = jnp.hypot(x_values-x1, y_values-y1)\n",
    "\n",
    "        statesFull = jnp.stack((states0, states1), axis=0)\n",
    "\n",
    "        for k in range(2, L_obs):\n",
    "            x, y = obstacles[k]\n",
    "            states_tmp = jnp.hypot(x_values-x, y_values-y)\n",
    "            statesFull = jnp.concatenate((statesFull, jnp.expand_dims(states_tmp, 0)), axis=0)\n",
    "    \n",
    "    values = rObs + rStrelka - jnp.min(statesFull, axis=0)\n",
    "    \n",
    "    # Define the arguments to hj.solve\n",
    "    time = 0.\n",
    "    target_time = -5.0\n",
    "    times = np.linspace(0, target_time, 25)\n",
    "    initial_values = values\n",
    "    \n",
    "    return jnp.max(hj.solve(solver_settings, dynamics, grid, times, initial_values), axis=0)\n",
    "    \n",
    "'''"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "TBmRsBm1zFnS",
    "outputId": "fe67d246-df6a-4351-8cae-016d67c51265"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "No GPU/TPU found, falling back to CPU. (Set TF_CPP_MIN_LOG_LEVEL=0 and rerun for more info.)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(101, 51, 181)\n",
      "0.69999975\n",
      "-3.6011627\n"
     ]
    }
   ],
   "source": [
    "# Instantiate the dynamics\n",
    "dynamics = DubinsDog()\n",
    "\n",
    "# Instantiate the grid \n",
    "grid = hj.Grid.from_lattice_parameters_and_boundary_conditions(hj.sets.Box(lo=lo_xx,\n",
    "                                                                           hi=hi_xx),\n",
    "                                                               (n_x, n_y, n_theta),\n",
    "                                                               periodic_dims=2\n",
    "                                                               )\n",
    "\n",
    "\n",
    "\n",
    "if True:\n",
    "    \n",
    "    # Define the obstacles\n",
    "    run_number = 1\n",
    "    if run_number == 1:\n",
    "        obstacles = [[3.5, 0.], [7.5, 0.]]\n",
    "    elif run_number == 2:\n",
    "        obstacles = [[3.5, 0.], [5.5, 1.], [5.5, -1.], [7.5, 0.]]\n",
    "    elif run_number == 3:\n",
    "        obstacles = [[4., 1.], [4., -1.], [6., 0.], [8., -1.], [8., 1.]]\n",
    "    elif run_number == 4:\n",
    "        obstacles = [[5.43, 2.04], [7.05, 0.45], [4.44, -1.56], [4, 1.66], [7.51, -1.30], [5.11, 0.11]]\n",
    "    elif run_number == 5:\n",
    "        obstacles = [[4.26, 0.49], [4.34, -1.18], [5.22, 1.63], [6.75, 0.19], [7.66, -1.26], [5.57, -0.83]]\n",
    "    elif run_number == 6:\n",
    "        obstacles = [[7.52, -1.79], [7.11, -0.63], [5.36, 0.49], [8.09, -0.20], [5.67, -1.75], [4.72, 2.07], [8.01, 1.73]]\n",
    "    elif run_number == 7:\n",
    "        obstacles = [[4.5, -2.5], [5.5, -1.5], [6.5, -0.5], [7.5, 0.5], [8.6, -0.2], [8., -2.]]\n",
    "    else:\n",
    "        raise ValueError('Invalid run number; must be in the set {1, 2, 3, 4, 5, 6, 7}')\n",
    "    ################################################\n",
    "    # Process obstacles to get state-action values #\n",
    "    ################################################\n",
    "\n",
    "    L_obs = len(obstacles)\n",
    "\n",
    "    # print(grid.states[..., 0].shape)\n",
    "    x_values = grid.states[..., 0]\n",
    "    y_values = grid.states[..., 1]\n",
    "\n",
    "    if L_obs <= 1:\n",
    "        raise ValueError('Must have at least two obstacles!')\n",
    "    elif L_obs == 2:\n",
    "        x0, y0 = obstacles[0]\n",
    "        states0 = jnp.hypot(x_values-x0, y_values-y0)\n",
    "\n",
    "        x1, y1 = obstacles[1]\n",
    "        states1 = jnp.hypot(x_values-x1, y_values-y1)\n",
    "\n",
    "        statesFull = jnp.stack((states0, states1), axis=0)\n",
    "    else:\n",
    "        x0, y0 = obstacles[0]\n",
    "        states0 = jnp.hypot(x_values-x0, y_values-y0)\n",
    "\n",
    "        x1, y1 = obstacles[1]\n",
    "        states1 = jnp.hypot(x_values-x1, y_values-y1)\n",
    "\n",
    "        statesFull = jnp.stack((states0, states1), axis=0)\n",
    "\n",
    "        for k in range(2, L_obs):\n",
    "            x, y = obstacles[k]\n",
    "            states_tmp = jnp.hypot(x_values-x, y_values-y)\n",
    "            statesFull = jnp.concatenate((statesFull, jnp.expand_dims(states_tmp, 0)), axis=0)\n",
    "    \n",
    "    \n",
    "    # Continue\n",
    "    if False:\n",
    "        x0, y0 = obstacles[0]\n",
    "        states0 = jnp.hypot(x_values-x0, y_values-y0)\n",
    "\n",
    "        x1, y1 = obstacles[1]\n",
    "        states1 = jnp.hypot(x_values-x1, y_values-y1)\n",
    "\n",
    "        x2, y2 = obstacles[2]\n",
    "        states2 = jnp.hypot(x_values-x2, y_values-y2)\n",
    "\n",
    "        statesFull = jnp.stack((states0, states1, states2), axis=0)\n",
    "    \n",
    "\n",
    "    # Construct Values array for the HJB propagation\n",
    "    values = rObs + rStrelka - jnp.min(statesFull, axis=0)\n",
    "\n",
    "    ################################################\n",
    "    ################################################\n",
    "\n",
    "    '''\n",
    "    # states1 = jnp.stack(((grid.states[..., 0] - firstObs - spacerVal) % spacerVal, spacerVal - ((grid.states[..., 0] - firstObs) % spacerVal)), axis=-1)\n",
    "    # states2 = jnp.min(states1, axis=-1)\n",
    "\n",
    "    #values = jnp.linalg.norm(grid.states[..., :2], axis=-1) - 1\n",
    "    #print(values.shape)\n",
    "\n",
    "    #tmp = jnp.stack((states2, grid.states[..., 1]), axis=-1)\n",
    "    #values = rObs - jnp.linalg.norm(tmp, axis=-1)  # + jnp.linalg.norm(grid.states[..., :1], axis=-1) + \n",
    "    # values = 100.0*(((1.0+rObs)/(1.0+jnp.linalg.norm(tmp, axis=-1))) - 1.0) + 0.05*jnp.linalg.norm(grid.states[..., :1], axis=-1)\n",
    "    #valueMin = -3.0*jnp.ones(values.shape)\n",
    "    #values = jnp.max(jnp.stack((values, valueMin), axis=-1), axis=-1)\n",
    "    '''\n",
    "\n",
    "    # Print shapes and max/min values to verify that calculations are working\n",
    "    print(values.shape)\n",
    "    print(jnp.max(values))\n",
    "    print(jnp.min(values))\n",
    "\n",
    "    # Specify solver setting accuracy (\"low\", \"medium\", \"high\", \"very high\")\n",
    "    solver_settings = hj.SolverSettings.with_accuracy(\"medium\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "cu1buKTm9EJ1",
    "outputId": "d2b272c3-0814-4467-da85-5e98028b5b9d"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|###########################################################|  5.0000/5.0 [00:26<00:00,  5.29s/sim_s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(25, 101, 51, 181)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# Compute the backwards reachable sets for the obstacles [the full unsafe set that the robot needs to avoid]\n",
    "\n",
    "# Define the arguments to hj.solve\n",
    "time = 0.\n",
    "target_time = -5.0\n",
    "times = np.linspace(0, target_time, 25)\n",
    "initial_values = values\n",
    "\n",
    "# Solve for the values\n",
    "all_values = hj.solve(solver_settings, dynamics, grid, times, initial_values)\n",
    "\n",
    "# Confirm size of output for debugging purposes\n",
    "print(all_values.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "LIdzWddpjaDE",
    "outputId": "752aff0f-fc0a-4e47-d6e8-989c7011e553"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(25, 101, 51, 181)\n",
      "(101, 51, 181)\n",
      "(101, 51, 181)\n",
      "(101, 51, 181)\n",
      "(101, 51, 181, 3)\n",
      "0.69999975\n",
      "-3.6011627\n"
     ]
    }
   ],
   "source": [
    "# Process angle-mixing results as well to allow us to simulate discrete \n",
    "# shocks in angles (hard with continuous-time dynamics)\n",
    "print(all_values.shape)\n",
    "Vmax = jnp.max(all_values, axis=0)\n",
    "\n",
    "Vmax_np = np.array(Vmax)\n",
    "Vmax_np_angles = np.zeros(Vmax_np.shape)\n",
    "print(Vmax_np.shape)\n",
    "\n",
    "for k in range(Vmax_np.shape[0]):\n",
    "    for j in range(Vmax_np.shape[1]):\n",
    "        for i in range(Vmax_np.shape[2]):\n",
    "            if i >= 5 and i < Vmax_np.shape[2]-5:\n",
    "                Vmax_np_angles[k,j,i] = np.max(Vmax_np[k,j,i-5:i+6])\n",
    "            elif i < 5:\n",
    "                Vmax_np_angles[k,j,i] = np.max(np.concatenate((Vmax_np[k,j,:i+6], Vmax_np[k, j, Vmax_np.shape[2]-i:])))\n",
    "            else:\n",
    "                c = Vmax_np.shape[2] - i\n",
    "                Vmax_np_angles[k,j,i] = np.max(np.concatenate((Vmax_np[k,j,i-5:], Vmax_np[k, j, :c])))\n",
    "\n",
    "# Try using Vmax_np_angles                \n",
    "print(Vmax.shape)\n",
    "print(Vmax_np_angles.shape)\n",
    "print(grid.states.shape)\n",
    "\n",
    "print(jnp.max(Vmax))\n",
    "print(jnp.min(Vmax))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 632
    },
    "id": "vi6UmqMfjjCo",
    "outputId": "cbbde3a5-e8a6-417c-8a8b-49b32fb734d5"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 10.0)"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot vanilla backwards-reachable-set (BRS)\n",
    "\n",
    "plt.jet()\n",
    "plt.figure(figsize=(r_x, r_y))\n",
    "plt.contourf(grid.coordinate_vectors[0], grid.coordinate_vectors[1], Vmax[:, :, int((n_theta-1)/2)].T)\n",
    "plt.colorbar()\n",
    "plt.contour(grid.coordinate_vectors[0],\n",
    "            grid.coordinate_vectors[1],\n",
    "            Vmax[:, :, int((n_theta-1)/2)].T,\n",
    "            levels=0,\n",
    "            colors=\"black\",\n",
    "            linewidths=3)\n",
    "for obs in obstacles:\n",
    "    xi, yi = obs\n",
    "    plt.plot(xi + rObs*np.cos(np.arange(360)*math.pi/180.0), yi+rObs*np.sin(np.arange(360)*math.pi/180.0), 'k--')\n",
    "    \n",
    "plt.ylim([lo_y, lo_y+r_y])\n",
    "plt.xlim([lo_x, lo_x+r_x])\n",
    "# plt.savefig('HJ_Strelka_BRS.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 10.0)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.jet()\n",
    "plt.figure(figsize=(r_x, r_y))\n",
    "plt.contourf(grid.coordinate_vectors[0], grid.coordinate_vectors[1], Vmax_np_angles[:, :, int((n_theta-1)/2)].T)\n",
    "plt.colorbar()\n",
    "plt.contour(grid.coordinate_vectors[0],\n",
    "            grid.coordinate_vectors[1],\n",
    "            Vmax_np_angles[:, :, int((n_theta-1)/2)].T,\n",
    "            levels=0,\n",
    "            colors=\"black\",\n",
    "            linewidths=3)\n",
    "for obs in obstacles:\n",
    "    xi, yi = obs\n",
    "    plt.plot(xi + rObs*np.cos(np.arange(360)*math.pi/180.0), yi+rObs*np.sin(np.arange(360)*math.pi/180.0), 'k--')\n",
    "    \n",
    "plt.ylim([lo_y, lo_y+r_y])\n",
    "plt.xlim([lo_x, lo_x+r_x])\n",
    "# plt.savefig('HJ_Strelka_BRS_AngleMixed_layout'+str(run_number)+'.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(101, 51, 181)\n",
      "(101, 51, 181)\n",
      "(101, 51, 181)\n"
     ]
    }
   ],
   "source": [
    "print(Vmax.shape)\n",
    "print(x_values.shape)\n",
    "print(y_values.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pyastar2d"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "positions_x = x_values[:, :, 0]\n",
    "positions_y = y_values[:, :, 0]\n",
    "\n",
    "astar_values = np.zeros(positions_x.shape)\n",
    "for i in range(positions_x.shape[0]):\n",
    "    for j in range(positions_x.shape[1]):\n",
    "        if Vmax_np_angles[i, j, int((n_theta-1)/2)] >= 0:\n",
    "            astar_values[i, j] = np.hypot(positions_x[i,j]-g_x, positions_y[i,j]-0.0) + 51.0\n",
    "        else:\n",
    "            astar_values[i, j] = np.hypot(positions_x[i,j]-g_x, positions_y[i,j]-0.0) + 1.0\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "def position2indices(x, y, x_vec, y_vec):\n",
    "    x_idx = np.argmin(np.abs(x-x_vec))\n",
    "    y_idx = np.argmin(np.abs(y-y_vec))\n",
    "    return [x_idx, y_idx]\n",
    "\n",
    "def indices2position(x_idx, y_idx, x_vec, y_vec):\n",
    "    assert x_idx <= len(x_vec) - 1\n",
    "    assert y_idx <= len(y_vec) - 1\n",
    "    return [x_vec[x_idx], y_vec[y_idx]]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 0.          0.09999999  0.19999999  0.29999998  0.39999998  0.49999997\n",
      "  0.59999996  0.6999999   0.79999995  0.9         0.99999994  1.0999999\n",
      "  1.1999999   1.3         1.3999999   1.4999999   1.5999999   1.6999999\n",
      "  1.8         1.8999999   1.9999999   2.1         2.1999998   2.3\n",
      "  2.3999999   2.4999998   2.6         2.6999998   2.7999997   2.8999999\n",
      "  2.9999998   3.1         3.1999998   3.2999997   3.3999999   3.4999998\n",
      "  3.6         3.6999998   3.7999997   3.8999999   3.9999998   4.1\n",
      "  4.2         4.2999997   4.3999996   4.4999995   4.6         4.7\n",
      "  4.7999997   4.8999996   4.9999995   5.1         5.2         5.2999997\n",
      "  5.3999996   5.4999995   5.5999994   5.7         5.7999997   5.8999996\n",
      "  5.9999995   6.0999994   6.2         6.2999997   6.3999996   6.4999995\n",
      "  6.5999994   6.7         6.7999997   6.8999996   6.9999995   7.0999994\n",
      "  7.2         7.2999997   7.3999996   7.4999995   7.5999994   7.6999993\n",
      "  7.7999997   7.8999996   7.9999995   8.099999    8.2         8.299999\n",
      "  8.4         8.499999    8.599999    8.7         8.799999    8.9\n",
      "  8.999999    9.099999    9.2         9.299999    9.4         9.499999\n",
      "  9.599999    9.7         9.799999    9.9        10.        ]\n",
      "[-2.50000000e+00 -2.40000010e+00 -2.29999995e+00 -2.20000005e+00\n",
      " -2.10000014e+00 -2.00000000e+00 -1.89999998e+00 -1.80000007e+00\n",
      " -1.70000005e+00 -1.60000002e+00 -1.50000000e+00 -1.40000010e+00\n",
      " -1.29999995e+00 -1.20000005e+00 -1.10000014e+00 -1.00000000e+00\n",
      " -9.00000095e-01 -8.00000072e-01 -6.99999988e-01 -6.00000083e-01\n",
      " -5.00000119e-01 -4.00000006e-01 -3.00000101e-01 -2.00000077e-01\n",
      " -1.00000024e-01 -1.19209290e-07  9.99999046e-02  1.99999884e-01\n",
      "  2.99999863e-01  3.99999887e-01  4.99999881e-01  5.99999905e-01\n",
      "  6.99999869e-01  7.99999833e-01  8.99999857e-01  9.99999881e-01\n",
      "  1.09999990e+00  1.19999981e+00  1.29999983e+00  1.39999986e+00\n",
      "  1.49999988e+00  1.59999990e+00  1.69999981e+00  1.79999983e+00\n",
      "  1.89999974e+00  1.99999976e+00  2.09999990e+00  2.19999981e+00\n",
      "  2.29999971e+00  2.39999986e+00  2.50000000e+00]\n"
     ]
    }
   ],
   "source": [
    "astar_values_float32 = np.array(astar_values, dtype=np.float32)\n",
    "\n",
    "print(positions_x[:,0])\n",
    "print(positions_y[0,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "path = pyastar2d.astar_path(astar_values_float32, (position2indices(0.0, 0.0, positions_x[:,0], positions_y[0,:])[0], position2indices(0.0, 0.0, positions_x[:,0], positions_y[0,:])[1]), (position2indices(g_x, 0.0, positions_x[:,0], positions_y[0,:])[0], position2indices(g_x, 0.0, positions_x[:,0], positions_y[0,:])[1]), allow_diagonal=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "path_xy_array = np.zeros((len(path), 2))\n",
    "for k in range(len(path)):\n",
    "    path_xy_array[k, 0], path_xy_array[k, 1] = indices2position(path[k][0], path[k][1], positions_x[:,0], positions_y[0,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "path_length_total = 0\n",
    "for k in range(len(path)-1):\n",
    "    path_length_total += np.hypot(path_xy_array[k+1, 0]-path_xy_array[k, 0], path_xy_array[k+1, 1]-path_xy_array[k, 1])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run number:  1\n",
      "Path length:  11.325483530085192\n",
      "Maximal Deviation:  0.8000000715255737\n"
     ]
    }
   ],
   "source": [
    "# Print path length\n",
    "print(\"Run number: \", run_number)\n",
    "print(\"Path length: \",path_length_total)\n",
    "print(\"Maximal Deviation: \", np.max(np.abs(path_xy_array[:,1])))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.0, 10.0)"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 0 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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/fTTvPjii7Rv375mj1BeXh6tW7c2HJ04qX379vWOBWnbti3777+/jhEJqeuvv54BAwZw++2387Of/Yx3332XyZMnM3nyZNOhiQvOOOMMxo8fT9euXTniiCNYunQp9957L7/+9a9NhyYO2LZtG59++mnN49WrV7Ns2TI6duxI165dGT16NLfffjuHHHIIhxxyCLfffjtt2rThoosuMhi1NCnmYw888ECsW7dusVatWsWOOeaY2Ny5c02HJC4AEt4effRR06GJBwYNGhS77rrrTIchLnrppZdivXr1imVnZ8d69uwZmzx5sumQxCUVFRWx6667Lta1a9dYTk5O7MADD4yNHTs2VllZaTo0ccDs2bMTfl9fcsklsVgsFtuzZ09s3LhxscLCwlh2dnZs4MCBseXLl5sNWprk2+sMiIiIiIiIu3x5zICIiIiIiLhPzYCIiIiISESpGRARERERiSg1AyIiIiIiEaVmQEREREQkotQMiIiIiIhElJoBEREREZGIUjMgIiIiIhJRagZERERERCJKzYCIiIiISESpGRARERERiSg1AyIiIiIiEfX/AQsSx6u1U70KAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.jet()\n",
    "plt.figure(figsize=(r_x, r_y))\n",
    "plt.contourf(grid.coordinate_vectors[0], grid.coordinate_vectors[1], Vmax_np_angles[:, :, int((n_theta-1)/2)].T)\n",
    "plt.colorbar()\n",
    "plt.contour(grid.coordinate_vectors[0],\n",
    "            grid.coordinate_vectors[1],\n",
    "            Vmax_np_angles[:, :, int((n_theta-1)/2)].T,\n",
    "            levels=0,\n",
    "            colors=\"black\",\n",
    "            linewidths=3)\n",
    "for obs in obstacles:\n",
    "    xi, yi = obs\n",
    "    plt.plot(xi + rObs*np.cos(np.arange(360)*math.pi/180.0), yi+rObs*np.sin(np.arange(360)*math.pi/180.0), 'k--')\n",
    "    \n",
    "plt.plot(path_xy_array[:,0],path_xy_array[:,1], 'r') \n",
    "plt.ylim([lo_y, lo_y+r_y])\n",
    "plt.xlim([lo_x, lo_x+r_x])\n",
    "# plt.savefig('HJ_Strelka_BRS_AngleMixed_withPath_layout'+str(run_number)+'.png')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Do Not Run! Saves a lot of files! See Output image below for example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle as pkl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'np' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-2-707049e1cbc9>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msave\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'all_values_modified_5s_two_dist_channel.npy'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mall_values\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mallow_pickle\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      2\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msave\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'v_max_modified_5s_two_dist_channel.npy'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mVmax\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mallow_pickle\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msave\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'v_max_modified_5s_anglesMixed_two_dist_channel.npy'\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mVmax_np_angles\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mallow_pickle\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'np' is not defined"
     ]
    }
   ],
   "source": [
    "np.save('all_values_modified_5s_two_dist_channel.npy', all_values, allow_pickle=True)\n",
    "np.save('v_max_modified_5s_two_dist_channel.npy', Vmax, allow_pickle=True)\n",
    "np.save('v_max_modified_5s_anglesMixed_two_dist_channel.npy', Vmax_np_angles, allow_pickle=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "JAXpkjN4oLuq",
    "outputId": "ccb54427-d80e-4e57-9fab-142f70e1ff84"
   },
   "outputs": [],
   "source": [
    "left_grad_values, right_grad_values = grid.upwind_grad_values(solver_settings.upwind_scheme, Vmax)\n",
    "grad_values=(left_grad_values+right_grad_values)/2."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "eCsSiNmVkg0P",
    "outputId": "7ce2c18f-1ca1-4818-cbf0-9e2bc89f6992"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-2\n",
      "-6\n",
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n",
      "20\n",
      "21\n",
      "22\n",
      "23\n",
      "24\n",
      "25\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(31415926)\n",
    "\n",
    "Runs = 25\n",
    "off1 = int(np.random.poisson(60, 1) - 60)\n",
    "off3 = int(np.random.poisson(35, 1) - 35)\n",
    "\n",
    "tmp = np.zeros(2)\n",
    "n_check = 20\n",
    "VALUE = np.zeros((2, 2*n_check+1))\n",
    "COST = np.zeros(Runs*(n_y-1))\n",
    "\n",
    "# Toggle adversarial and non-adversarial\n",
    "adversarialW = False\n",
    "\n",
    "print(off1)\n",
    "print(off3)\n",
    "\n",
    "g1, g3 = int((n_x-1)/2)+off1, int((n_xd-1)/2)+off3\n",
    "X = grid.states[g1, 0, g3]\n",
    "X = jnp.reshape(X,(1, 3))\n",
    "\n",
    "for r in range(1, Runs+1):\n",
    "    #if r % 5 ==0:\n",
    "    #    print(r)\n",
    "    print(r)\n",
    "    \n",
    "    x = grid.states[g1, 0, g3]\n",
    "    gv = grad_values[g1, 0, g3]\n",
    "\n",
    "    for t in range(n_y-1):\n",
    "        #u0, w = dynamics.optimal_control_and_disturbance(x, float(t)-25., gv)\n",
    "        #print(u, w)\n",
    "        #print(x)\n",
    "        x0 = x\n",
    "        for j in range(2*n_check+1):\n",
    "            for k in range(2):\n",
    "                u = jnp.array([float(0.75*((float(j)/float(n_check)) - 1.0))])\n",
    "                w = jnp.array([float(float(k)-0.5)])\n",
    "                x = x0 + dynamics.open_loop_dynamics(x0, target_time) + dynamics.control_jacobian(x0, target_time)@u + dynamics.disturbance_jacobian(x0, target_time)@w\n",
    "                xnp = np.array(x)\n",
    "\n",
    "                g1 = int(jnp.round((x[0]-lo_x)*k_x)-1)\n",
    "                g3 = int(jnp.round((x[2]-lo_xdot)*k_xd)-1)\n",
    "                VALUE[k,j] = Vmax[g1, int(t+1), g3] + 0.15*np.absolute(xnp[0])**2 + 0.05*np.linalg.norm(u)**2\n",
    "                '''\n",
    "                # print(x0)\n",
    "                xnp = np.array(x)\n",
    "                tmp[0] = (xnp[1] - firstObs) % spacerD\n",
    "                tmp[1] = spacerD - tmp[0]\n",
    "                xnp2 = xnp\n",
    "                xnp2[1] = np.min(tmp)\n",
    "\n",
    "                VALUE[k, j] = 0.5*np.absolute(xnp[0])**2 + 0.1*np.absolute(u)**2\n",
    "                if xnp2[1] <= 4.*rObs:\n",
    "                    VALUE[k,j] += 75.0*(((rObs+1.)**2/np.sqrt(1.0+(rObs+2.0)*np.linalg.norm(xnp2[:2]))) - (1.0+rObs))\n",
    "                # VALUE[k,j] += -np.linalg.norm(xnp2[:2])**2\n",
    "                '''\n",
    "\n",
    "            # print(np.max(VALUE, axis=0).shape)\n",
    "            jj = np.argmin(np.max(VALUE, axis=0))\n",
    "            \n",
    "            if adversarialW:\n",
    "                # Adversarial\n",
    "                if np.argmax(VALUE[:,jj]) == 0:\n",
    "                    w = jnp.array([-0.5])\n",
    "                elif np.argmax(VALUE[:,jj]) == 1:\n",
    "                    w = jnp.array([0.5])\n",
    "                else:\n",
    "                    print('Hmmm, argmax might be malfunctioning')\n",
    "                    w = jnp.array([0.5])\n",
    "            elif 0:\n",
    "                # Sinusoid + random else\n",
    "                # w = jnp.array([float(np.argmax(VALUE[:,jj])-0.5)])\n",
    "                if (int(t/2) % spacerD <= firstObs) and (int(t/2) % spacerD >= firstObs-2.0*rObs):\n",
    "                    w = jnp.array([0.5])\n",
    "                elif (int(t/2) % spacerD <= firstObs+3.0*rObs) and (int(t/2) % spacerD >= firstObs):\n",
    "                    w = jnp.array([-0.5])\n",
    "                else:\n",
    "                    w = jnp.array([float(np.random.rand(1)[0]-0.5)])\n",
    "            else:\n",
    "                # Stochastic\n",
    "                w = jnp.array([float(np.random.rand(1)[0]-0.5)])\n",
    "\n",
    "        # breakpoint()\n",
    "        u = jnp.array([float(0.75*((float(jj)/float(n_check)) - 1.0))])\n",
    "        if r==1 and t==0:\n",
    "            U = u\n",
    "        else:\n",
    "            U = jnp.concatenate((U, u), axis=0)\n",
    "        #print(u, w)\n",
    "        #print(x0)\n",
    "        #print(x)\n",
    "        #print()\n",
    "        # u = u0*float(jj)/float(n_check)\n",
    "        x = x0 + dynamics.open_loop_dynamics(x0, target_time) + dynamics.control_jacobian(x0, target_time)@u + dynamics.disturbance_jacobian(x0, target_time)@w\n",
    "        # print(x[0]-x0[0])\n",
    "        xnp = np.array(x)\n",
    "        COST[(r-1)*(n_y-1) + t] = 0.15*np.absolute(xnp[0])**2 + 0.05*np.linalg.norm(u)**2\n",
    "        # breakpoint()\n",
    "        g1 = int(jnp.round((x[0]-lo_x)*k_x)-1)\n",
    "        g3 = int(jnp.round((x[2]-lo_xdot)*k_xd)-1)\n",
    "        x = grid.states[g1, int(t+1), g3]\n",
    "        gv = grad_values[g1, int(t+1), g3]\n",
    "        #print(x)\n",
    "        #print()\n",
    "        X = jnp.concatenate((X, jnp.reshape(x, (1, 3))), axis=0)\n",
    "\n",
    "        # breakpoint()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 863
    },
    "id": "9eVU0Dxz9oXk",
    "outputId": "a2a60d20-3ad4-4e49-83b4-2d47d05e46bd"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYwAAATpCAYAAADDOCQEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdd3hT1f8H8HfSvaEUWvZWVikbGbJkyFAUEFkyRUUQUXEgMlSEn6i4EEERQUAQWQ5QhC97I0uGIDIrlJbZvXN+f5wmbdqkvTfNvWnL+/U890l677nJJ2mbT849yyCEECAiIiqA0dUBEBFR8cCEQUREijBhEBGRIkwYRESkCBMGEREpwoRBRESKMGEQEZEiTBhERKQIEwYRESnChEHFQocOHWAwGNChQwebxw0GAwwGA6ZPn65rXPeqxYsXW97zS5cuuTqcYqe4/r0yYRRSeno6Vq5ciWHDhqFu3booU6YMPDw8EBISgqZNm2LMmDHYsmULTCaTq0OlIiznB7Cjm71kSuQsTBiF8NNPP6FOnToYOHAgvvvuO5w5cwa3b99GRkYGbt26hSNHjmD+/Pno0qUL6tatiw0bNrg6ZLu2b99u+eDZvn27q8MhKhT+PWvD3dUBFFezZs3C5MmTYZ67sXPnzujduzfq1auHUqVK4fbt2zh79ix++eUXbN68Gf/88w8mT56Mnj17ujjykqm4z6H52GOPoVmzZjaPXbt2Dd26dQMA9O7dGzNmzLBZzs/PT7P4chs+fDiGDx+u2/OVNMX175UJwwFLly7Fm2++CQAoW7YsfvjhB3Ts2DFPuc6dO2Ps2LE4ceIEJkyYgFu3bukdKhUTpUqVQqlSpWwe8/f3tyrXoEEDnaIissaEodK1a9cwZswYAICvry+2b9+OevXq5XtOeHg4Nm/ejO+//16PEImINME2DJU+/vhjJCYmAgDefvvtApOFmdFoxJAhQ+wev3PnDmbMmIFWrVohJCQEXl5eqFChAnr37o21a9fm+9i5e1wcOnQIAwcORKVKleDl5YWKFSviqaeewt9//53n3EuXLsFgMFjVkDp27JinQXXx4sU2n/vgwYMYPXo07rvvPvj7+8PPzw916tTB2LFjce7cObsx5+5lk5qaik8++QQPPPAAQkJCVPcgya/XSe7nMplM+Oqrr9C6dWuULl0afn5+aNiwId577z0kJSUV+FxCCKxevRp9+/ZF5cqV4e3tjdKlS6NFixZ49913cffuXcVxO0vu179161Y88cQTqFy5Mjw8PFCtWjWr8idPnsSMGTPQrVs3y9+Jv78/ateujWHDhmH//v35Pp/SXlLOeq82btyIIUOGoEaNGvDz80NQUBDq16+PAQMGYM2aNUhOTgZQuL/ntLQ0zJs3Dx07dkTZsmXh6emJsLAw9OjRA8uWLcu348rw4cNhMBgs73NUVBRef/111K9fHwEBAXnaUpT2kjp79izGjx+P+vXrIygoCD4+PqhRowZGjBiBI0eO5HtuSkoKPvvsM3To0AEhISHw8PBAcHAw6tSpgx49euDjjz9W38NNkGImk0mULVtWABB+fn4iNjbWKY+7YcMGUapUKQHA7tazZ08RHx9v83xzmWnTponPP/9cuLu723wMX19fsWPHDqtzL168mO/zmrdvv/3W6rz09HQxZsyYfM/x8PAQX331lc2Yv/32W0u5Q4cOiUaNGuU5f9q0aZby7du3FwBE+/btC3wP8nuukydPik6dOtmNuUWLFiIhIcHu7yomJka0adMm39cdGhoq9u/fb/cx1Mr5Oxo2bJjNMjlf/5tvvpknpqpVq1rKbtu2TdHv/I033rAbU8739OLFizbLOOO9unnzpnjooYcU/306+vd86dIlUbdu3XzPadu2rbh165bNOIcNG2Z5n/ft2ydCQkLynL9t2zabvy973nnnHbv/ywCEwWAQU6dOtXnutWvXRL169Qp8H1555RW7z28LL0mpcPr0ady4cQMA8OCDDyIwMLDQj7l582Y8+uijyMzMRLVq1TBmzBi0bNkSgYGBuHr1Kn744QcsW7YMGzZswLBhw7BmzRq7j7Vp0yYcOHAADRs2xIsvvojw8HAkJydj3bp1+PTTT5GUlISnnnoK586dg6enJwCgYsWKOHHiBA4dOoSRI0cCABYtWoTmzZtbPXalSpWsfh41ahS+++47AED37t0xePBg3HfffTAYDDh27Bg++eQTnDp1Cs888wzCwsLwyCOP2I171KhROHHiBIYOHYonn3wSYWFhuHLlCry8vBx6T/PzzDPPYP/+/Rg2bBj69+9vea7Zs2dj3759OHjwIGbMmIFZs2blOTcxMRHt27fH33//DU9PT4wYMQI9evRA5cqVkZiYiJ07d2LOnDmIjo5G9+7dcfToUVStWtXp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0WGUKm3bthXPPPOM2b4GDRqIV155xUERlT4zZswQzZs3d3QYpRoA8csvv5i+zsnJEcHBweKtt94y7UtLSxN+fn7i888/V/XavMPQ2K5du9CkSROz4l59+/ZFeno69u/f78DIHO/tt99G1apV0aJFC8yePbtCN9MZS/D36dPHbL+tEvwV1ZkzZxAaGorw8HA8+OCDiI6OdnRIpdr58+cRGxtr9rvl7u6Obt26qf7dqjAzvR0lNja2UIHDypUrw83NzWpp9Ypg4sSJaNWqFSpXrow9e/Zg6tSpOH/+PBYsWODo0ByiOCX4K6J27dph8eLFqF+/Pq5du4ZZs2ahY8eOOHbsGKpWrero8Eol4++Ppd+tixcvqnot3mFYYKljreC2b98+xa9nqYS6sFFavaxS83N7/vnn0a1bNzRr1gxPPvkkPv/8c3z99ddISEhw8HfhWGpK8FdE/fv3x5AhQ9C0aVP06tULq1evBgB8++23Do6s9LPH7xbvMCwYP348HnzwQZvn1K5dW9FrBQcH459//jHbd/PmTWRmZlotrV5WleTn1r59ewDA2bNnK+RfisUpwU+At7c3mjZtijNnzjg6lFLLOIosNjYWIfnWhi/O7xYThgUBAQEICAiwy2t16NABs2fPRkxMjOkfa/369XB3d8ddd91ll/coLUryczt48CAAmP1CVyT5S/Dfd999pv0bNmzAPffc48DISrf09HScOHECXbp0cXQopVZ4eDiCg4OxYcMGtGzZEoDsM9uyZQvefvttVa/FhFFCly5dwo0bN3Dp0iVkZ2fj0KFDAIB69erBx8cHffr0QaNGjfDoo4/inXfewY0bNzB58mQ89dRTFXbRl127dmH37t3o3r07/Pz8sHfvXjz//PMYPHgwatWq5ejwHIYl+Is2efJkDBo0CLVq1UJcXBxmzZqFpKQkjBw50tGhOVRycjLOnj1r+vr8+fM4dOgQqlSpglq1amHSpEl48803ERERgYiICLz55pvw8vLCQw89pO6N7DKOqwIbOXKkAFBo27Rpk+mcixcvigEDBghPT09RpUoVMX78eJGWlua4oB1s//79ol27dsLPz094eHiIyMhIMWPGDJGSkuLo0Bzu008/FWFhYcLNzU20atVKbNmyxdEhlSrDhw8XISEhwtXVVYSGhor7779fHDt2zNFhOdymTZssfg6NHDlSCCGH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\n",
      "text/plain": [
       "<Figure size 400x1500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average Cost:  27.508344340371046\n",
      "Average Cost High:  32.51145735805547\n",
      "Average Cost Low:  22.481939416821678\n"
     ]
    }
   ],
   "source": [
    "CostMat = np.zeros(4*Runs)\n",
    "plt.figure(figsize=(4,15))\n",
    "for kk in range(4):\n",
    "    plt.plot(rObs*np.cos(np.arange(360)*math.pi/180.0), spacerD*kk+firstObs+rObs*np.sin(np.arange(360)*math.pi/180.0), 'k')\n",
    "# plt.plot(3.0*np.cos(np.arange(360)*math.pi/180.0), 112.5+3.0*np.sin(np.arange(360)*math.pi/180.0), 'k')\n",
    "for r in range(Runs):\n",
    "    plt.plot(X[r*(n_y-1)+1:(r+1)*(n_y-1)-1,0], X[r*(n_y-1)+1:(r+1)*(n_y-1)-1,1], 'r')\n",
    "    for k in range(4):\n",
    "        CostMat[4*r+k] = np.sum(COST[(n_y-1)*r + k*100:(n_y-1)*r + (k+1)*100])\n",
    "        \n",
    "plt.plot([0, 0], [0, 200], 'k--')\n",
    "plt.title('Centerline Trajectories', fontsize=20)\n",
    "plt.xlabel('Deviation in x (m)', fontsize=16)\n",
    "plt.ylabel('Progress in y (m)', fontsize=16)\n",
    "plt.xlim([-10.5, 10.5])\n",
    "plt.ylim([0, 200])\n",
    "plt.savefig('images/HJ_Racer_Centerline_FinalRandom.png')\n",
    "plt.show()\n",
    "\n",
    "print('Average Cost: ', np.mean(CostMat))\n",
    "print('Average Cost High: ', np.mean(np.sort(CostMat)[-5:]))\n",
    "print('Average Cost Low: ', np.mean(np.sort(CostMat)[:5]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savetxt('StochRuns'+str(Runs)+'_CostMat.csv', CostMat, delimiter=',')\n",
    "np.savetxt('StochRuns'+str(Runs)+'_X.csv', X, delimiter=',')\n",
    "np.savetxt('StochRuns'+str(Runs)+'_COST.csv', COST, delimiter=',')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "Ufilt = \n",
    "for i in r"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(5)\n",
    "plt.plot(np.arange(1, n_y)/2., U)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(4)\n",
    "s = np.random.poisson(25, 10000)\n",
    "count, bins, ignored = plt.hist(s, 10, density=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "1woHapmemAOc"
   },
   "outputs": [],
   "source": [
    "### Deprecated from Quickstart.ipynb\n",
    "#\n",
    "#\n",
    "#\n",
    "#\n",
    "\n",
    "target_values = hj.step(solver_settings, dynamics, grid, time, values, target_time)\n",
    "print(target_values.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 523
    },
    "id": "TPBt--AB50cX",
    "outputId": "ba90e89e-3874-48d6-a0ae-7bcd4f993a88"
   },
   "outputs": [],
   "source": [
    "plt.jet()\n",
    "plt.figure(figsize=(13, 8))\n",
    "plt.contourf(grid.coordinate_vectors[0], grid.coordinate_vectors[1], target_values[:, :, int((n_xd-1)/2)].T)\n",
    "plt.colorbar()\n",
    "plt.contour(grid.coordinate_vectors[0],\n",
    "            grid.coordinate_vectors[1],\n",
    "            target_values[:, :, int((n_xd-1)/2)].T,\n",
    "            levels=0,\n",
    "            colors=\"black\",\n",
    "            linewidths=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "rk7kb-FM9OeE"
   },
   "outputs": [],
   "source": [
    "vmin, vmax = all_values.min(), all_values.max()\n",
    "levels = np.linspace(round(vmin), round(vmax), round(vmax) - round(vmin) + 1)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "yC9Nfek2hLDF"
   },
   "outputs": [],
   "source": [
    "def render_frame(i, colorbar=False):\n",
    "    plt.contourf(grid.coordinate_vectors[0],\n",
    "                 grid.coordinate_vectors[1],\n",
    "                 all_values[i, :, :, 30].T,\n",
    "                 vmin=vmin,\n",
    "                 vmax=vmax,\n",
    "                 levels=levels)\n",
    "    if colorbar:\n",
    "        plt.colorbar()\n",
    "    plt.contour(grid.coordinate_vectors[0],\n",
    "                grid.coordinate_vectors[1],\n",
    "                target_values[:, :, 30].T,\n",
    "                levels=0,\n",
    "                colors=\"black\",\n",
    "                linewidths=3)\n",
    "\n",
    "fig = plt.figure(figsize=(13, 8))\n",
    "render_frame(0, True)\n",
    "animation = HTML(anim.FuncAnimation(fig, render_frame, all_values.shape[0], interval=50).to_html5_video())\n",
    "plt.close(); animation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "kT4cwF25zFnS"
   },
   "outputs": [],
   "source": [
    "go.Figure(data=go.Isosurface(x=grid.states[:, :, -1, :, 0].ravel(),\n",
    "                             y=grid.states[:, :, -1, :, 1].ravel(),\n",
    "                             z=grid.states[:, :, -1, :, 3].ravel(),\n",
    "                             value=target_values[:, :, -1, :].ravel(),\n",
    "                             colorscale='jet',\n",
    "                             isomin=0,\n",
    "                             surface_count=1,\n",
    "                             isomax=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "BJlafT5qCcY0"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "colab": {
   "collapsed_sections": [],
   "provenance": []
  },
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
