{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import driving_gridworld.road as dg_road\n",
    "import driving_gridworld.car as dg_car\n",
    "import driving_gridworld.obstacles as dg_obstacles\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib as mpl\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "def add_decorations(img, ax=None):\n",
    "    if ax is None:\n",
    "        ax = plt.gca()\n",
    "    incr = 0.55\n",
    "    y = -0.60\n",
    "    for i in range(2 * img.shape[0]):\n",
    "      ax.add_patch(\n",
    "          mpl.patches.Rectangle(\n",
    "              (1.47, y),\n",
    "              0.03,\n",
    "              0.33,\n",
    "              0,\n",
    "              color='yellow',\n",
    "              alpha=0.8\n",
    "          )\n",
    "      )\n",
    "      y += incr\n",
    "    direction_offsets = np.array(\n",
    "        [(-0.5, -0.5), (0, -0.5 - 0.5 / 3), (0.5, -0.5)]\n",
    "    )\n",
    "    for i in range(img.shape[0] - 1):\n",
    "      ax.add_patch(\n",
    "          mpl.patches.Polygon(\n",
    "              np.array([4, i + 1]) + direction_offsets,\n",
    "              closed=True,\n",
    "              alpha=0.8,\n",
    "              facecolor='grey'\n",
    "          )\n",
    "      )\n",
    "    return ax"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "from pycolab.rendering import ObservationToArray\n",
    "\n",
    "\n",
    "def color256_to_1000(c):\n",
    "  return int(c / 256.0 * 1000)\n",
    "\n",
    "\n",
    "COLOUR_FG = {\n",
    "    ' ': (color256_to_1000(205), color256_to_1000(205), color256_to_1000(193)),\n",
    "    '|': (0, 0, 0),\n",
    "    'd': (color256_to_1000(c) for c in (102, 102, 0)),\n",
    "    'C': (0, 999, 999),\n",
    "    'b': (color256_to_1000(256), color256_to_1000(50), color256_to_1000(50)),\n",
    "    'p': (987, 623, 145),\n",
    "    '^': (color256_to_1000(c) for c in (39, 232, 51))\n",
    "}\n",
    "COLOUR_BG = {}\n",
    "obs_to_rgb = ObservationToArray(COLOUR_FG)\n",
    "\n",
    "\n",
    "def observation_to_img(o, obs_to_rgb=obs_to_rgb):\n",
    "  return np.swapaxes(obs_to_rgb(o) / 1000.0, 1, 2).T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "my_road = dg_road.Road(\n",
    "    2, dg_car.Car(2, 2), [dg_obstacles.Bump(0, 1), dg_obstacles.Bump(1, 3)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "img = observation_to_img(my_road.observation())\n",
    "img = img[:, 1:]\n",
    "img = np.concatenate([img[:, :4], img[:, -1:]], axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "PDFCROP 1.38, 2012/11/02 - Copyright (c) 2002-2012 by Heiko Oberdiek.\n",
      "==> 1 page written on `driving_gridworld-crop.pdf'.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure()\n",
    "ax = fig.add_subplot(111)\n",
    "\n",
    "ax.grid(False)\n",
    "\n",
    "# Remove ticks and tick labels\n",
    "plt.axis('off')\n",
    "ax.set_xticklabels([])\n",
    "ax.set_yticklabels([])\n",
    "for tic in ax.xaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "for tic in ax.yaxis.get_major_ticks():\n",
    "    tic.tick1On = tic.tick2On = False\n",
    "\n",
    "add_decorations(img, ax)\n",
    "ax.imshow(img)\n",
    "plt.savefig('driving_gridworld.pdf')\n",
    "!pdfcrop driving_gridworld.pdf && rm driving_gridworld.pdf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
