{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "pycharm": {
     "is_executing": false
    }
   },
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "\n",
    "import matplotlib\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import glob as glob\n",
    "import sys\n",
    "import os\n",
    "import mpld3\n",
    "from tqdm import tqdm\n",
    "mpld3.enable_notebook()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv(\"ref_lap_f2_barcelona.csv\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "df.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot( df.pos_x, df.pos_z, linewidth=5, color='black')\n",
    "plt.axis('equal')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.plot(df.angle_y_from_pos)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "start = 0 #4680\n",
    "end = -1#start + 450\n",
    "plt.plot( df.pos_x[start:end], df.pos_z[start:end], linewidth=4, color='black')\n",
    "plt.scatter(df.pos_x[start:end].values[0],  df.pos_z[start:end].values[0], linewidth=6, color='red')\n",
    "\n",
    "# 'main_straight', 0, 0+620\n",
    "start = 0; end = 0+620\n",
    "plt.plot( df.pos_x[start:end], df.pos_z[start:end], linewidth=4)\n",
    "\n",
    "# 'c1', 500, 500 + 250\n",
    "start = 500; end = 500 + 250\n",
    "plt.plot( df.pos_x[start:end], df.pos_z[start:end], linewidth=4)\n",
    "\n",
    "# 'c14'\n",
    "start = 5000; end = 5000 + 2000\n",
    "plt.plot( df.pos_x[start:end], df.pos_z[start:end], linewidth=4)\n",
    "\n",
    "# 'chicane'\n",
    "start = 4680; end = 4680 + 450\n",
    "plt.plot( df.pos_x[start:end], df.pos_z[start:end], linewidth=4)\n",
    "\n",
    "plt.axis('off')\n",
    "   \n",
    "plt.savefig('full_track_barcelona.png', bbox_inches='tight', pad_inches=0)\n",
    "    \n",
    "plt.show('equal')\n"
   ]
  },
  {
   "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": [
    "\n"
   ]
  },
  {
   "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": [
    "racing_line = df[['pos_x', 'pos_z', 'pos_y', 'angle_y_from_pos']]\n",
    "racing_line = racing_line.rename(columns={'angle_y_from_pos': 'angle_y'})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "len(racing_line)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    " def save_maneuver(racing_line, name, start, end, invert_y=False, hard_crop=-1, color='black'):\n",
    "    racing_line = racing_line.copy()[start:end]\n",
    "        \n",
    "    # extend the last point 300 meters\n",
    "    racing_line.iloc[len(racing_line) - 1].pos_x += np.cos(racing_line.angle_y.values[-1]) * 300     \n",
    "    racing_line.iloc[len(racing_line) - 1].pos_z += np.sin(racing_line.angle_y.values[-1]) * 300    \n",
    "    \n",
    "    if invert_y:\n",
    "        racing_line['pos_z'] = -racing_line['pos_z']   \n",
    "        \n",
    "    racing_line = racing_line.iloc[:hard_crop]\n",
    "        \n",
    "    plt.plot(racing_line.pos_x, racing_line.pos_z, linewidth=4, color=color)\n",
    "    plt.scatter(racing_line.pos_x.values[0], racing_line.pos_z.values[0], linewidth=6, color='red')\n",
    "    pd.DataFrame(racing_line).to_csv(name + '.csv', index=None)\n",
    "    print('saved to', name)\n",
    "    plt.axis('off')\n",
    "   \n",
    "    plt.savefig(name + '.png', bbox_inches='tight', pad_inches=0)\n",
    "    \n",
    "    plt.show()\n",
    "    \n",
    "    return racing_line"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_maneuver(racing_line, 'full_track_barcelona', 0, 0+5474, invert_y=False, hard_crop=5350)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_maneuver(racing_line, 'sector_1', 0, 0+1500, invert_y=False)"
   ]
  },
  {
   "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": [
    "save_maneuver(racing_line, 'main_straight', 0, 0+620, color='blue')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_maneuver(racing_line, 'sector_1', 0, 0+1500, invert_y=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_maneuver(racing_line, 'sector_1_i', 0, 0+1500, invert_y=True)"
   ]
  },
  {
   "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": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_maneuver(racing_line, 'sector_1', 0, 0+1500)\n",
    "\n",
    "save_maneuver(racing_line, 'sector_1_i', 0, 0+1500, invert_y=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_maneuver(racing_line, 'c1', 500, 500 + 250, color='#F39C12')\n",
    "\n",
    "save_maneuver(racing_line, 'c1_i', 500, 500 + 250, invert_y=True, color='#F39C12')"
   ]
  },
  {
   "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": [
    "save_maneuver(racing_line, 'c14', 5000, 5000 + 2000, color='green')\n",
    "save_maneuver(racing_line, 'c14_i', 5000, 5000 + 2000, invert_y=True, color='green')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "save_maneuver(racing_line, 'chicane', 4680, 4680 + 450, color='red')\n",
    "save_maneuver(racing_line, 'chicane_i', 4680, 4680 + 450, invert_y=True, color='red')"
   ]
  },
  {
   "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": "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": []
  }
 ],
 "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.6.13"
  },
  "pycharm": {
   "stem_cell": {
    "cell_type": "raw",
    "metadata": {
     "collapsed": false
    },
    "source": []
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
