{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "from pathlib import Path\n",
    "from os import path as osp\n",
    "import numpy as np\n",
    "from nuscenes.nuscenes import NuScenes\n",
    "from nuscenes.map_expansion.map_api import NuScenesMap, NuScenesMapExplorer\n",
    "from shapely.geometry import Polygon, MultiPolygon\n",
    "from copy import deepcopy\n",
    "from nusc_to_wgs_conversion import convert_city_coords_to_wgs84\n",
    "import requests"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "overpass_useragent = 'FZI'\n",
    "overpass_headers = {\n",
    "    'Connection': 'keep-alive',\n",
    "    'sec-ch-ua': '\"Google Chrome 80\"',\n",
    "    'Accept': '*/*',\n",
    "    'Sec-Fetch-Dest': 'empty',\n",
    "    'User-Agent': overpass_useragent,\n",
    "    'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8',\n",
    "    'Origin': 'https://overpass-turbo.eu',\n",
    "    'Sec-Fetch-Site': 'cross-site',\n",
    "    'Sec-Fetch-Mode': 'cors',\n",
    "    'Referer': 'https://overpass-turbo.eu/',\n",
    "    'Accept-Language': '',\n",
    "    'dnt': '1',\n",
    "}\n",
    "\n",
    "nusc_root_path = \"/tmp/nuscenes\"\n",
    "\n",
    "out_path = \"out\"\n",
    "\n",
    "nusc = NuScenes(version='v1.0-trainval', dataroot=nusc_root_path, verbose=True)\n",
    "MAPS = ['boston-seaport', 'singapore-hollandvillage',\n",
    "                 'singapore-onenorth', 'singapore-queenstown']\n",
    "nusc_maps = {}\n",
    "map_explorer = {}\n",
    "for loc in MAPS:\n",
    "    nusc_maps[loc] = NuScenesMap(dataroot=nusc_root_path, map_name=loc)\n",
    "    map_explorer[loc] = NuScenesMapExplorer(nusc_maps[loc])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import nusc_to_wgs_conversion as nusc_to_wgs\n",
    "from importlib import reload\n",
    "reload(nusc_to_wgs)\n",
    "\n",
    "for loc in MAPS:\n",
    "    print(loc)\n",
    "    xmin, ymin, xmax, ymax = float(\"inf\"), float(\"inf\"), float(\"-inf\"), float(\"-inf\")\n",
    "    for area in nusc_maps[loc].drivable_area:\n",
    "        xmin_area, ymin_area, xmax_area, ymax_area = nusc_maps[loc].get_bounds('drivable_area', area['token'])\n",
    "        xmin = min(xmin, xmin_area)\n",
    "        ymin = min(ymin, ymin_area)\n",
    "        xmax = max(xmax, xmax_area)\n",
    "        ymax = max(ymax, ymax_area)\n",
    "\n",
    "    print(np.array([[xmin - 100, ymin - 100], [xmax + 100, ymax + 100]]))\n",
    "    bounds_latlon = nusc_to_wgs.convert_city_coords_to_wgs84(np.array([[xmin - 100, ymin - 100], [xmax + 100, ymax + 100]]), loc)\n",
    "    print(bounds_latlon)\n",
    "\n",
    "    query_str = \"(node({0},{1},{2},{3}); rel(bn)->.x; way({0},{1},{2},{3}); node(w)->.x; rel(bw);); out meta;\".format(bounds_latlon[0, 0], bounds_latlon[0, 1], bounds_latlon[1, 0], bounds_latlon[1, 1])\n",
    "    data = {\n",
    "      'data': query_str\n",
    "    }\n",
    "    response = requests.post('https://overpass-api.de/api/interpreter', headers=overpass_headers, data=data)\n",
    "    save_path = osp.join(out_path)\n",
    "    Path(save_path).mkdir(parents=True, exist_ok=True)\n",
    "    with open(osp.join(save_path, loc + '.osm'), 'w') as f:\n",
    "        f.write(response.text)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sd_map_encoding",
   "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.20"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
