{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2023-06-06 21:16:05.625977: I tensorflow/core/platform/cpu_feature_guard.cc:193] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  AVX2 FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "2023-06-06 21:16:06.165238: W tensorflow/compiler/xla/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library 'libnvinfer.so.7'; dlerror: libnvinfer.so.7: cannot open shared object file: No such file or directory; LD_LIBRARY_PATH: /usr/local/cuda-11.4/lib64:\n",
      "2023-06-06 21:16:06.165303: W tensorflow/compiler/xla/stream_executor/platform/default/dso_loader.cc:64] Could not load dynamic library 'libnvinfer_plugin.so.7'; dlerror: libnvinfer_plugin.so.7: cannot open shared object file: No such file or directory; LD_LIBRARY_PATH: /usr/local/cuda-11.4/lib64:\n",
      "2023-06-06 21:16:06.165307: W tensorflow/compiler/tf2tensorrt/utils/py_utils.cc:38] TF-TRT Warning: Cannot dlopen some TensorRT libraries. If you would like to use Nvidia GPU with TensorRT, please make sure the missing libraries mentioned above are installed properly.\n"
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "import shapely\n",
    "from pathlib import Path\n",
    "from collections import defaultdict\n",
    "from trajdata import MapAPI, VectorMap\n",
    "from trajdata.maps.vec_map_elements import MapElementType"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "map_dict = {\n",
    "    \"nusc_trainval\": [\"boston-seaport\", \"singapore-hollandvillage\", \"singapore-onenorth\", \"singapore-queenstown\"],\n",
    "    \"interaction_multi\": [\n",
    "        \"CHN_Merging_ZS0\",\n",
    "        \"CHN_Merging_ZS2\",\n",
    "        \"CHN_Roundabout_LN\",\n",
    "        \"DEU_Merging_MT\",\n",
    "        \"DEU_Roundabout_OF\",\n",
    "        \"Intersection_CM\",\n",
    "        \"LaneChange_ET0\",\n",
    "        \"LaneChange_ET1\",\n",
    "        \"Merging_TR0\",\n",
    "        \"Merging_TR1\",\n",
    "        \"Roundabout_RW\",\n",
    "        \"USA_Intersection_EP0\",\n",
    "        \"USA_Intersection_EP1\",\n",
    "        \"USA_Intersection_GL\",\n",
    "        \"USA_Intersection_MA\",\n",
    "        \"USA_Roundabout_EP\",\n",
    "        \"USA_Roundabout_FT\",\n",
    "        \"USA_Roundabout_SR\"\n",
    "    ],\n",
    "    \"lyft_sample\": [\"palo_alto\"],\n",
    "    \"nuplan_mini\": [\"boston\", \"singapore\", \"las_vegas\", \"pittsburgh\"],\n",
    "}\n",
    "\n",
    "map_api = MapAPI(Path(\"~/.unified_data_cache\").expanduser())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "nusc_trainval:boston-seaport Total Road Lane Length: 75.48 km\n",
      "nusc_trainval:boston-seaport Total Road Area: 445206.64 m^2\n",
      "nusc_trainval:boston-seaport Total Pedestrian Area: 116439.98 m^2\n",
      "\n",
      "nusc_trainval:singapore-hollandvillage Total Road Lane Length: 36.08 km\n",
      "nusc_trainval:singapore-hollandvillage Total Road Area: 132087.40 m^2\n",
      "nusc_trainval:singapore-hollandvillage Total Pedestrian Area: 27906.21 m^2\n",
      "\n",
      "nusc_trainval:singapore-onenorth Total Road Lane Length: 52.90 km\n",
      "nusc_trainval:singapore-onenorth Total Road Area: 204656.37 m^2\n",
      "nusc_trainval:singapore-onenorth Total Pedestrian Area: 59399.70 m^2\n",
      "\n",
      "nusc_trainval:singapore-queenstown Total Road Lane Length: 48.39 km\n",
      "nusc_trainval:singapore-queenstown Total Road Area: 164324.62 m^2\n",
      "nusc_trainval:singapore-queenstown Total Pedestrian Area: 46417.85 m^2\n",
      "\n",
      "nusc_trainval\n",
      "defaultdict(<class 'float'>, {'road_length': 212.85123336855483, 'road_area': 946275.0245755002, 'ped_area': 250163.74102299998})\n",
      "interaction_multi:CHN_Merging_ZS0 Total Road Lane Length: 0.96 km\n",
      "interaction_multi:CHN_Merging_ZS0 Total Road Lane Area: 3519.83 m^2\n",
      "\n",
      "interaction_multi:CHN_Merging_ZS2 Total Road Lane Length: 0.96 km\n",
      "interaction_multi:CHN_Merging_ZS2 Total Road Lane Area: 3519.83 m^2\n",
      "\n",
      "interaction_multi:CHN_Roundabout_LN Total Road Lane Length: 1.25 km\n",
      "interaction_multi:CHN_Roundabout_LN Total Road Lane Area: 5949.22 m^2\n",
      "\n",
      "interaction_multi:DEU_Merging_MT Total Road Lane Length: 0.19 km\n",
      "interaction_multi:DEU_Merging_MT Total Road Lane Area: 600.14 m^2\n",
      "\n",
      "interaction_multi:DEU_Roundabout_OF Total Road Lane Length: 0.44 km\n",
      "interaction_multi:DEU_Roundabout_OF Total Road Lane Area: 2073.41 m^2\n",
      "\n",
      "interaction_multi:Intersection_CM Total Road Lane Length: 0.62 km\n",
      "interaction_multi:Intersection_CM Total Road Lane Area: 3275.23 m^2\n",
      "\n",
      "interaction_multi:LaneChange_ET0 Total Road Lane Length: 1.65 km\n",
      "interaction_multi:LaneChange_ET0 Total Road Lane Area: 5422.79 m^2\n",
      "\n",
      "interaction_multi:LaneChange_ET1 Total Road Lane Length: 1.65 km\n",
      "interaction_multi:LaneChange_ET1 Total Road Lane Area: 5422.79 m^2\n",
      "\n",
      "interaction_multi:Merging_TR0 Total Road Lane Length: 2.09 km\n",
      "interaction_multi:Merging_TR0 Total Road Lane Area: 6665.03 m^2\n",
      "\n",
      "interaction_multi:Merging_TR1 Total Road Lane Length: 2.09 km\n",
      "interaction_multi:Merging_TR1 Total Road Lane Area: 6665.03 m^2\n",
      "\n",
      "interaction_multi:Roundabout_RW Total Road Lane Length: 0.45 km\n",
      "interaction_multi:Roundabout_RW Total Road Lane Area: 1474.84 m^2\n",
      "\n",
      "interaction_multi:USA_Intersection_EP0 Total Road Lane Length: 0.78 km\n",
      "interaction_multi:USA_Intersection_EP0 Total Road Lane Area: 3202.02 m^2\n",
      "\n",
      "interaction_multi:USA_Intersection_EP1 Total Road Lane Length: 1.21 km\n",
      "interaction_multi:USA_Intersection_EP1 Total Road Lane Area: 5089.16 m^2\n",
      "\n",
      "interaction_multi:USA_Intersection_GL Total Road Lane Length: 1.35 km\n",
      "interaction_multi:USA_Intersection_GL Total Road Lane Area: 6302.23 m^2\n",
      "\n",
      "interaction_multi:USA_Intersection_MA Total Road Lane Length: 1.21 km\n",
      "interaction_multi:USA_Intersection_MA Total Road Lane Area: 6245.79 m^2\n",
      "\n",
      "interaction_multi:USA_Roundabout_EP Total Road Lane Length: 0.77 km\n",
      "interaction_multi:USA_Roundabout_EP Total Road Lane Area: 3766.96 m^2\n",
      "\n",
      "interaction_multi:USA_Roundabout_FT Total Road Lane Length: 0.57 km\n",
      "interaction_multi:USA_Roundabout_FT Total Road Lane Area: 3710.92 m^2\n",
      "\n",
      "interaction_multi:USA_Roundabout_SR Total Road Lane Length: 0.56 km\n",
      "interaction_multi:USA_Roundabout_SR Total Road Lane Area: 3596.30 m^2\n",
      "\n",
      "interaction_multi\n",
      "defaultdict(<class 'float'>, {'road_length': 18.779138416182246, 'road_area': 76501.5295605})\n",
      "lyft_sample:palo_alto Total Road Lane Length: 185.42 km\n",
      "lyft_sample:palo_alto Total Road Lane Area: 591332.52 m^2\n",
      "lyft_sample:palo_alto Total Pedestrian Area: 17359.40 m^2\n",
      "\n",
      "lyft_sample\n",
      "defaultdict(<class 'float'>, {'road_length': 185.4201197614395, 'road_area': 591332.519890001, 'ped_area': 17359.40222250003})\n",
      "nuplan_mini:boston Total Road Lane Length: 81.69 km\n",
      "nuplan_mini:boston Total Road Area: 465665.68 m^2\n",
      "nuplan_mini:boston Total Pedestrian Area: 136103.64 m^2\n",
      "\n",
      "nuplan_mini:singapore Total Road Lane Length: 62.90 km\n",
      "nuplan_mini:singapore Total Road Area: 219214.67 m^2\n",
      "nuplan_mini:singapore Total Pedestrian Area: 63708.98 m^2\n",
      "\n",
      "nuplan_mini:las_vegas Total Road Lane Length: 148.79 km\n",
      "nuplan_mini:las_vegas Total Road Area: 499220.49 m^2\n",
      "nuplan_mini:las_vegas Total Pedestrian Area: 43039.27 m^2\n",
      "\n",
      "nuplan_mini:pittsburgh Total Road Lane Length: 32.57 km\n",
      "nuplan_mini:pittsburgh Total Road Area: 143864.65 m^2\n",
      "nuplan_mini:pittsburgh Total Pedestrian Area: 28425.24 m^2\n",
      "\n",
      "nuplan_mini\n",
      "defaultdict(<class 'float'>, {'road_length': 325.95177665884063, 'road_area': 1327965.4978187585, 'ped_area': 271277.1200242194})\n"
     ]
    }
   ],
   "source": [
    "# Calculating the \"arc-length\" of the map. If you strung out all the lanes end-to-end, this is the total length.\n",
    "for env_name, maps_list in map_dict.items():\n",
    "    totals = defaultdict(float)\n",
    "    for map_name in maps_list:\n",
    "        vec_map: VectorMap = map_api.get_map(\n",
    "            f\"{env_name}:{map_name}\",\n",
    "            incl_road_lanes=True,\n",
    "            incl_road_areas=True,\n",
    "            incl_ped_crosswalks=True,\n",
    "            incl_ped_walkways=True,\n",
    "        )\n",
    "        \n",
    "        road_length = 0.0\n",
    "        for road_lane in vec_map.elements[MapElementType.ROAD_LANE].values():\n",
    "            pos_diffs = np.diff(road_lane.center.xy, axis=0)\n",
    "            lengths = np.linalg.norm(pos_diffs, axis=1)\n",
    "            road_length += lengths.sum().item()\n",
    "        \n",
    "        totals[\"road_length\"] += road_length/1000\n",
    "        print(f\"{env_name}:{map_name} Total Road Lane Length: {road_length/1000:.2f} km\")\n",
    "        \n",
    "        total_road_area = 0.0\n",
    "        if MapElementType.ROAD_AREA in vec_map.elements:\n",
    "            for road_area_obj in vec_map.elements[MapElementType.ROAD_AREA].values():\n",
    "                polygon = shapely.Polygon(\n",
    "                    shell=road_area_obj.exterior_polygon.xy,\n",
    "                    holes=[hole.xy for hole in road_area_obj.interior_holes]\n",
    "                )\n",
    "                total_road_area += polygon.area\n",
    "            \n",
    "            totals[\"road_area\"] += total_road_area\n",
    "            print(f\"{env_name}:{map_name} Total Road Area: {total_road_area:.2f} m^2\")\n",
    "        else:\n",
    "            for road_lane in vec_map.elements[MapElementType.ROAD_LANE].values():\n",
    "                polygon = shapely.Polygon(\n",
    "                    shell=np.concatenate((road_lane.left_edge.xy, road_lane.right_edge.xy[::-1]), axis=0),\n",
    "                )\n",
    "                total_road_area += polygon.area\n",
    "    \n",
    "            totals[\"road_area\"] += total_road_area\n",
    "            print(f\"{env_name}:{map_name} Total Road Lane Area: {total_road_area:.2f} m^2\")\n",
    "            \n",
    "        if vec_map.elements[MapElementType.PED_CROSSWALK] or vec_map.elements[MapElementType.PED_WALKWAY]:\n",
    "            total_ped_area = 0.0\n",
    "            for ped_crosswalk in vec_map.elements[MapElementType.PED_CROSSWALK].values():\n",
    "                polygon = shapely.Polygon(\n",
    "                    shell=ped_crosswalk.polygon.xy,\n",
    "                )\n",
    "                total_ped_area += polygon.area\n",
    "                \n",
    "            for ped_walkway in vec_map.elements[MapElementType.PED_WALKWAY].values():\n",
    "                polygon = shapely.Polygon(\n",
    "                    shell=ped_walkway.polygon.xy,\n",
    "                )\n",
    "                total_ped_area += polygon.area\n",
    "        \n",
    "            totals[\"ped_area\"] += total_ped_area\n",
    "            print(f\"{env_name}:{map_name} Total Pedestrian Area: {total_ped_area:.2f} m^2\")\n",
    "\n",
    "        print()\n",
    "    \n",
    "    print(env_name)\n",
    "    print(totals)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "nuplan",
   "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.13"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
