{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "931e4396",
   "metadata": {},
   "source": [
    "refresh every time when running new train data by copying from network folder to combined folder"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7eede1a7",
   "metadata": {},
   "source": [
    "total 6 target folders/train data"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2745eb8c",
   "metadata": {},
   "source": [
    "copy code"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9fc3dccd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "✅ Copied Video_1/route.rou.xml → 1min/combined/route.rou1.xml\n",
      "✅ Copied Video_10/route.rou.xml → 1min/combined/route.rou2.xml\n",
      "✅ Copied Video_11/route.rou.xml → 1min/combined/route.rou3.xml\n",
      "✅ Copied Video_12/route.rou.xml → 1min/combined/route.rou4.xml\n",
      "✅ Copied Video_13/route.rou.xml → 1min/combined/route.rou5.xml\n",
      "✅ Copied Video_14/route.rou.xml → 1min/combined/route.rou6.xml\n",
      "✅ Copied Video_2/route.rou.xml → 1min/combined/route.rou7.xml\n",
      "✅ Copied Video_3/route.rou.xml → 1min/combined/route.rou8.xml\n",
      "✅ Copied Video_4/route.rou.xml → 1min/combined/route.rou9.xml\n",
      "✅ Copied Video_5/route.rou.xml → 1min/combined/route.rou10.xml\n",
      "✅ Copied Video_6/route.rou.xml → 1min/combined/route.rou11.xml\n",
      "✅ Copied Video_7/route.rou.xml → 1min/combined/route.rou12.xml\n",
      "✅ Copied Video_8/route.rou.xml → 1min/combined/route.rou13.xml\n",
      "✅ Copied Video_9/route.rou.xml → 1min/combined/route.rou14.xml\n",
      "📄 Copied add1.xml → 1min/combined\n",
      "📄 Copied add2.xml → 1min/combined\n",
      "📄 Copied add_ew_left.xml → 1min/combined\n",
      "📄 Copied add_ns_left.xml → 1min/combined\n",
      "📄 Copied edg.xml → 1min/combined\n",
      "📄 Copied faulty_traffic_lights.xml → 1min/combined\n",
      "📄 Copied generated_broken_nleft.add.xml → 1min/combined\n",
      "📄 Copied generated_broken_sleft.add.xml → 1min/combined\n",
      "📄 Copied generated_broken_wleft.add.xml → 1min/combined\n",
      "📄 Copied nod.xml → 1min/combined\n",
      "📄 Copied simple_nw_se.net.xml → 1min/combined\n",
      "📄 Copied sumo_config.sumocfg → 1min/combined\n",
      "📄 Copied type.xml → 1min/combined\n",
      "✅ Copied Video_1/route.rou.xml → 2min/combined/route.rou1.xml\n",
      "✅ Copied Video_2/route.rou.xml → 2min/combined/route.rou2.xml\n",
      "✅ Copied Video_3/route.rou.xml → 2min/combined/route.rou3.xml\n",
      "✅ Copied Video_4/route.rou.xml → 2min/combined/route.rou4.xml\n",
      "✅ Copied Video_5/route.rou.xml → 2min/combined/route.rou5.xml\n",
      "✅ Copied Video_6/route.rou.xml → 2min/combined/route.rou6.xml\n",
      "📄 Copied add1.xml → 2min/combined\n",
      "📄 Copied add2.xml → 2min/combined\n",
      "📄 Copied add_ew_left.xml → 2min/combined\n",
      "📄 Copied add_ns_left.xml → 2min/combined\n",
      "📄 Copied edg.xml → 2min/combined\n",
      "📄 Copied faulty_traffic_lights.xml → 2min/combined\n",
      "📄 Copied generated_broken_nleft.add.xml → 2min/combined\n",
      "📄 Copied generated_broken_sleft.add.xml → 2min/combined\n",
      "📄 Copied generated_broken_wleft.add.xml → 2min/combined\n",
      "📄 Copied nod.xml → 2min/combined\n",
      "📄 Copied simple_nw_se.net.xml → 2min/combined\n",
      "📄 Copied sumo_config.sumocfg → 2min/combined\n",
      "📄 Copied type.xml → 2min/combined\n",
      "✅ Copied Video_1/route.rou.xml → 3min/combined/route.rou1.xml\n",
      "✅ Copied Video_2/route.rou.xml → 3min/combined/route.rou2.xml\n",
      "✅ Copied Video_3/route.rou.xml → 3min/combined/route.rou3.xml\n",
      "✅ Copied Video_4/route.rou.xml → 3min/combined/route.rou4.xml\n",
      "📄 Copied add1.xml → 3min/combined\n",
      "📄 Copied add2.xml → 3min/combined\n",
      "📄 Copied add_ew_left.xml → 3min/combined\n",
      "📄 Copied add_ns_left.xml → 3min/combined\n",
      "📄 Copied edg.xml → 3min/combined\n",
      "📄 Copied faulty_traffic_lights.xml → 3min/combined\n",
      "📄 Copied generated_broken_nleft.add.xml → 3min/combined\n",
      "📄 Copied generated_broken_sleft.add.xml → 3min/combined\n",
      "📄 Copied generated_broken_wleft.add.xml → 3min/combined\n",
      "📄 Copied nod.xml → 3min/combined\n",
      "📄 Copied simple_nw_se.net.xml → 3min/combined\n",
      "📄 Copied sumo_config.sumocfg → 3min/combined\n",
      "📄 Copied type.xml → 3min/combined\n",
      "✅ Copied Video_1/route.rou.xml → 4min/combined/route.rou1.xml\n",
      "✅ Copied Video_2/route.rou.xml → 4min/combined/route.rou2.xml\n",
      "✅ Copied Video_3/route.rou.xml → 4min/combined/route.rou3.xml\n",
      "📄 Copied add1.xml → 4min/combined\n",
      "📄 Copied add2.xml → 4min/combined\n",
      "📄 Copied add_ew_left.xml → 4min/combined\n",
      "📄 Copied add_ns_left.xml → 4min/combined\n",
      "📄 Copied edg.xml → 4min/combined\n",
      "📄 Copied faulty_traffic_lights.xml → 4min/combined\n",
      "📄 Copied generated_broken_nleft.add.xml → 4min/combined\n",
      "📄 Copied generated_broken_sleft.add.xml → 4min/combined\n",
      "📄 Copied generated_broken_wleft.add.xml → 4min/combined\n",
      "📄 Copied nod.xml → 4min/combined\n",
      "📄 Copied simple_nw_se.net.xml → 4min/combined\n",
      "📄 Copied sumo_config.sumocfg → 4min/combined\n",
      "📄 Copied type.xml → 4min/combined\n",
      "✅ Copied Video_1/route.rou.xml → 5min/combined/route.rou1.xml\n",
      "✅ Copied Video_2/route.rou.xml → 5min/combined/route.rou2.xml\n",
      "📄 Copied add1.xml → 5min/combined\n",
      "📄 Copied add2.xml → 5min/combined\n",
      "📄 Copied add_ew_left.xml → 5min/combined\n",
      "📄 Copied add_ns_left.xml → 5min/combined\n",
      "📄 Copied edg.xml → 5min/combined\n",
      "📄 Copied faulty_traffic_lights.xml → 5min/combined\n",
      "📄 Copied generated_broken_nleft.add.xml → 5min/combined\n",
      "📄 Copied generated_broken_sleft.add.xml → 5min/combined\n",
      "📄 Copied generated_broken_wleft.add.xml → 5min/combined\n",
      "📄 Copied nod.xml → 5min/combined\n",
      "📄 Copied simple_nw_se.net.xml → 5min/combined\n",
      "📄 Copied sumo_config.sumocfg → 5min/combined\n",
      "📄 Copied type.xml → 5min/combined\n",
      "✅ Copied Video_1/route.rou.xml → 6min/combined/route.rou1.xml\n",
      "✅ Copied Video_2/route.rou.xml → 6min/combined/route.rou2.xml\n",
      "📄 Copied add1.xml → 6min/combined\n",
      "📄 Copied add2.xml → 6min/combined\n",
      "📄 Copied add_ew_left.xml → 6min/combined\n",
      "📄 Copied add_ns_left.xml → 6min/combined\n",
      "📄 Copied edg.xml → 6min/combined\n",
      "📄 Copied faulty_traffic_lights.xml → 6min/combined\n",
      "📄 Copied generated_broken_nleft.add.xml → 6min/combined\n",
      "📄 Copied generated_broken_sleft.add.xml → 6min/combined\n",
      "📄 Copied generated_broken_wleft.add.xml → 6min/combined\n",
      "📄 Copied nod.xml → 6min/combined\n",
      "📄 Copied simple_nw_se.net.xml → 6min/combined\n",
      "📄 Copied sumo_config.sumocfg → 6min/combined\n",
      "📄 Copied type.xml → 6min/combined\n",
      "\n",
      "🎯 All files copied successfully.\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import shutil\n",
    "\n",
    "# ─────────── USER CONFIG ───────────\n",
    "BASE_DIR = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\\NE12_50\"\n",
    "#TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\\Bellevue_150th_Newport__2017-09-11_17-08-32\"\n",
    "\n",
    "#TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\\Bellevue_150th_Newport__2017-09-11_08-08-31\"\n",
    "\n",
    "##TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\\Bellevue_150th_Newport__2017-09-10_18-08-24\"\n",
    "#total 6 folders/days\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network\"\n",
    "DURATION_FOLDERS = [\"1min\",\"2min\"]\n",
    "\n",
    "# ─────────── PROCESS EACH FOLDER ───────────\n",
    "for duration in DURATION_FOLDERS:\n",
    "    duration_path = os.path.join(TARGET_FOLDER, duration)\n",
    "    combined_dir = os.path.join(duration_path, \"combined\")\n",
    "    os.makedirs(combined_dir, exist_ok=True)\n",
    "\n",
    "    # Copy route.rou.xml files from each Video folder\n",
    "    counter = 1\n",
    "    for folder in sorted(os.listdir(duration_path)):\n",
    "        if folder.lower().startswith(\"video\"):\n",
    "            route_src = os.path.join(duration_path, folder, \"route.rou.xml\")\n",
    "            if os.path.exists(route_src):\n",
    "                route_dst = os.path.join(combined_dir, f\"route.rou{counter}.xml\")\n",
    "                shutil.copy(route_src, route_dst)\n",
    "                print(f\"✅ Copied {folder}/route.rou.xml → {duration}/combined/route.rou{counter}.xml\")\n",
    "                counter += 1\n",
    "\n",
    "    # Copy all network files except route.rou.xml\n",
    "    # Copy all network files except route.rou.xml\n",
    "    for file in os.listdir(NETWORK_FOLDER):\n",
    "      if (file.endswith(\".xml\") and not file.startswith(\"route.rou\")) or file == \"sumo_config.sumocfg\":\n",
    "        src = os.path.join(NETWORK_FOLDER, file)\n",
    "        dst = os.path.join(combined_dir, file)\n",
    "        shutil.copy(src, dst)\n",
    "        print(f\"📄 Copied {file} → {duration}/combined\")\n",
    "\n",
    "\n",
    "print(\"\\n🎯 All files copied successfully.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e0b9340b",
   "metadata": {},
   "source": [
    "calculate average occupancy for maximum congested phase\n",
    "run copy code and change target folder to calculate occupancy  for each day's data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d27df080",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "🔁 Running simulations for burst: route_north_to_south\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 90.00 s | AWT: 61.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 90.00 s | AWT: 60.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 88.00 s | AWT: 59.50 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 91.00 s | AWT: 58.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in NT+ST at 53%\n",
      "⏱️ ATT: 153.00 s | AWT: 76.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in NT+ST at 54%\n",
      "⏱️ ATT: 87.00 s | AWT: 64.00 s\n",
      "\n",
      "✅ Simulation route.rou7.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 92.00 s | AWT: 58.00 s\n",
      "\n",
      "✅ Simulation route.rou8.xml ended\n",
      "📈 High congestion detected in NT+ST at 54%\n",
      "⏱️ ATT: 88.50 s | AWT: 60.00 s\n",
      "\n",
      "✅ Simulation route.rou9.xml ended\n",
      "📈 High congestion detected in NT+ST at 54%\n",
      "⏱️ ATT: 86.00 s | AWT: 61.00 s\n",
      "\n",
      "✅ Simulation route.rou10.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 88.00 s | AWT: 58.50 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in NT+ST at 54%\n",
      "⏱️ ATT: 86.50 s | AWT: 62.50 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 87.00 s | AWT: 62.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in NT+ST at 54%\n",
      "⏱️ ATT: 86.50 s | AWT: 61.50 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 89.00 s | AWT: 59.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in NT+ST at 53%\n",
      "⏱️ ATT: 152.00 s | AWT: 76.00 s\n",
      "✅ Saved: C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\\NE12_50\\final_congestion_results_north_to_south_for_metrics.csv\n",
      "\n",
      "🔁 Running simulations for burst: route_north_to_east\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import shutil\n",
    "import xml.etree.ElementTree as ET\n",
    "import traci\n",
    "import pandas as pd\n",
    "\n",
    "# ─────────── USER CONFIG ───────────\n",
    "BASE_DIR = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\\NE12_50\"\n",
    "#run the copy code then run this code  with new target folder \n",
    "#TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\\Bellevue_150th_Newport__2017-09-11_17-08-32\"\n",
    "#run the copy code then run this code  with new target folder \n",
    "#TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\\Bellevue_150th_Newport__2017-09-11_08-08-31\"\n",
    "#run the copy code then run this code  with new target folder \n",
    "##TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\\Bellevue_150th_Newport__2017-09-10_18-08-24\"\n",
    "#total 6 folders or days\n",
    "SUMO_BINARY = r\"C:\\Program Files (x86)\\Eclipse\\Sumo\\bin\\sumo.exe\"\n",
    "STEP = 1\n",
    "CYCLE_SEC = 90\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network\" # NEW folder path\n",
    "\n",
    "lane_groups = {\n",
    "    'NT': ['north_to_center_0', 'north_to_center_1'],\n",
    "    'ST': ['south_to_center_0', 'south_to_center_1'],\n",
    "    'N-L': ['north_to_center_2'],\n",
    "    'S-L': ['south_to_center_2'],\n",
    "    'ET': ['east_to_center_0', 'east_to_center_1'],\n",
    "    'WT': ['west_to_center_0', 'west_to_center_1'],\n",
    "    'E-L': ['east_to_center_2'],\n",
    "    'W-L': ['west_to_center_2']\n",
    "}\n",
    "\n",
    "phase_groups = {\n",
    "    'NS': ['NT', 'ST'],\n",
    "    'NS-L': ['N-L', 'S-L'],\n",
    "    'EW': ['ET', 'WT'],\n",
    "    'EW-L': ['E-L', 'W-L']\n",
    "}\n",
    "\n",
    "phrase_map = {\n",
    "    'NS': \"High congestion detected in NT+ST\",\n",
    "    'NS-L': \"High congestion detected in NS-LEFTS\",\n",
    "    'EW': \"High congestion detected in ET+WT\",\n",
    "    'EW-L': \"High congestion detected in EW-LEFTS\"\n",
    "}\n",
    "\n",
    "\n",
    "def move_routes_and_setup_combined(day_path, duration_folder):\n",
    "    combined_dir = os.path.join(day_path, duration_folder, \"combined\")\n",
    "    os.makedirs(combined_dir, exist_ok=True)\n",
    "    duration_path = os.path.join(day_path, duration_folder)\n",
    "    counter = 1\n",
    "    sumo_config_copied = False\n",
    "\n",
    "    for folder in sorted(os.listdir(duration_path)):\n",
    "        if folder.lower().startswith(\"video\"):\n",
    "            video_path = os.path.join(duration_path, folder)\n",
    "            route_src = os.path.join(video_path, \"route.rou.xml\")\n",
    "            if os.path.exists(route_src):\n",
    "                shutil.copy(route_src, os.path.join(combined_dir, f\"route.rou{counter}.xml\"))\n",
    "                counter += 1\n",
    "            config_src = os.path.join(video_path, \"sumo_config.sumocfg\")\n",
    "            config_dst = os.path.join(combined_dir, \"sumo_config.sumocfg\")\n",
    "            if not sumo_config_copied and os.path.exists(config_src):\n",
    "                shutil.copy(config_src, config_dst)\n",
    "                sumo_config_copied = True\n",
    "\n",
    "    # Copy all network files (excluding route.rou.xml) from new_road_network\n",
    "    if os.path.exists(NETWORK_FOLDER):\n",
    "     for file in os.listdir(NETWORK_FOLDER):\n",
    "        if file != \"route.rou.xml\":\n",
    "            src = os.path.join(NETWORK_FOLDER, file)\n",
    "            dst = os.path.join(combined_dir, file)\n",
    "            shutil.copy(src, dst)  # Force overwrite\n",
    "\n",
    "\n",
    "    return combined_dir\n",
    "\n",
    "\n",
    "def insert_burst_flow_ordered(xml_path, burst_route, burst_begin=10, burst_end=300):\n",
    "    tree = ET.parse(xml_path)\n",
    "    root = tree.getroot()\n",
    "    burst_flow = ET.Element(\"flow\", {\n",
    "        \"id\": f\"burst_{burst_route}\",\n",
    "        \"begin\": str(burst_begin),\n",
    "        \"end\": str(burst_end),\n",
    "        \"number\": \"270\",\n",
    "        \"route\": burst_route,\n",
    "        \"departLane\": \"best\",\n",
    "        \"departPos\": \"free\",\n",
    "        \"speedFactor\": \"1.0\",\n",
    "        \"speedDev\": \"0.0\"\n",
    "    })\n",
    "\n",
    "    others, vehicles_before, vehicles_after = [], [], []\n",
    "    for elem in root:\n",
    "        if elem.tag == \"vehicle\":\n",
    "            depart = float(elem.attrib.get(\"depart\", \"0\"))\n",
    "            (vehicles_before if depart < burst_begin else vehicles_after).append(elem)\n",
    "        else:\n",
    "            others.append(elem)\n",
    "\n",
    "    root.clear()\n",
    "    for e in others + vehicles_before + [burst_flow] + vehicles_after:\n",
    "        root.append(e)\n",
    "\n",
    "    tree.write(xml_path, encoding=\"utf-8\", xml_declaration=True)\n",
    "\n",
    "\n",
    "def update_sumo_config(cfg_path, route_file):\n",
    "    tree = ET.parse(cfg_path)\n",
    "    root = tree.getroot()\n",
    "    for elem in root.findall(\".//input\"):\n",
    "        to_remove = []\n",
    "        for child in elem:\n",
    "            if child.tag == \"route-files\":\n",
    "                child.set(\"value\", route_file)\n",
    "            elif child.tag == \"additional-files\":\n",
    "                to_remove.append(child)\n",
    "        for child in to_remove:\n",
    "            elem.remove(child)\n",
    "    tree.write(cfg_path, encoding=\"utf-8\", xml_declaration=True)\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "def run_simulation(cfg_file, combined_folder):\n",
    "    results = []\n",
    "\n",
    "    for i in range(1, 50):\n",
    "        route_file = f\"route.rou{i}.xml\"\n",
    "        route_path = os.path.join(combined_folder, route_file)\n",
    "        if not os.path.exists(route_path):\n",
    "            continue\n",
    "\n",
    "        update_sumo_config(cfg_file, route_file)\n",
    "\n",
    "        traci.start([\n",
    "            SUMO_BINARY, \"-c\", cfg_file,\n",
    "            \"--step-length\", str(STEP),\n",
    "            \"--no-step-log\", \"true\",\n",
    "            \"--time-to-teleport\", \"-1\"\n",
    "        ])\n",
    "\n",
    "        occupancy_history = {grp: [] for grp in lane_groups}\n",
    "        depart_times = {}\n",
    "        arrival_times = {}\n",
    "        waiting_times = {}\n",
    "\n",
    "        next_cut = CYCLE_SEC\n",
    "\n",
    "        while traci.simulation.getMinExpectedNumber() > 0:\n",
    "            traci.simulationStep()\n",
    "            t = traci.simulation.getTime()\n",
    "\n",
    "            for grp, lanes in lane_groups.items():\n",
    "                lane_occs = [traci.lane.getLastStepOccupancy(ln) for ln in lanes]\n",
    "                avg_lane_occ = sum(lane_occs) / len(lane_occs) if lane_occs else 0\n",
    "                occupancy_history[grp].append(avg_lane_occ)\n",
    "\n",
    "            for veh_id in traci.vehicle.getIDList():\n",
    "                if veh_id not in depart_times:\n",
    "                    depart_times[veh_id] = t  # vehicle enters the simulation\n",
    "                waiting_times[veh_id] = traci.vehicle.getAccumulatedWaitingTime(veh_id)\n",
    "\n",
    "            if t >= next_cut:\n",
    "                next_cut += CYCLE_SEC\n",
    "\n",
    "        # Get arrival time for each vehicle\n",
    "        for veh_id in traci.simulation.getArrivedIDList():\n",
    "            arrival_times[veh_id] = traci.simulation.getTime()\n",
    "\n",
    "        traci.close()\n",
    "\n",
    "        travel_times = []\n",
    "        wait_times = []\n",
    "\n",
    "        for veh_id in arrival_times:\n",
    "            if veh_id in depart_times:\n",
    "                travel_time = arrival_times[veh_id] - depart_times[veh_id]\n",
    "                wait_time = waiting_times.get(veh_id, 0)\n",
    "                travel_times.append(travel_time)\n",
    "                wait_times.append(wait_time)\n",
    "\n",
    "        ATT = sum(travel_times) / len(travel_times) if travel_times else 0\n",
    "        AWT = sum(wait_times) / len(wait_times) if wait_times else 0\n",
    "\n",
    "        avg_occ_per_group = {\n",
    "            grp: sum(values) / len(values) if values else 0\n",
    "            for grp, values in occupancy_history.items()\n",
    "        }\n",
    "\n",
    "        avg_occ_per_phase = {\n",
    "            phase: max(avg_occ_per_group[g] for g in groups)\n",
    "            for phase, groups in phase_groups.items()\n",
    "        }\n",
    "\n",
    "        most_congested_phase = max(avg_occ_per_phase, key=avg_occ_per_phase.get)\n",
    "        max_value = avg_occ_per_phase[most_congested_phase] * 100\n",
    "        message = phrase_map[most_congested_phase]\n",
    "\n",
    "        print(f\"\\n✅ Simulation {route_file} ended\")\n",
    "        print(f\"📈 {message} at {int(max_value)}%\")\n",
    "        print(f\"⏱️ ATT: {ATT:.2f} s | AWT: {AWT:.2f} s\")\n",
    "\n",
    "        results.append({\n",
    "            \"route_file\": route_file,\n",
    "            \"congested_phase\": most_congested_phase,\n",
    "            \"max_occupancy_percent\": int(max_value),\n",
    "           \n",
    "        })\n",
    "\n",
    "    return results\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# ─────────── OUTER LOOP OVER 12 BURST ROUTES ───────────\n",
    "burst_routes = [\n",
    "    \"route_north_to_south\",\n",
    "    \"route_north_to_east\",\n",
    "    \"route_north_to_west\",\n",
    "    \n",
    "    \"route_east_to_south\",\n",
    "    \"route_east_to_west\",\n",
    "    \"route_east_to_north\",\n",
    "    \n",
    "    \"route_south_to_north\",\n",
    "    \"route_south_to_east\",\n",
    "    \"route_south_to_west\",\n",
    "    \n",
    "    \"route_west_to_north\",\n",
    "    \"route_west_to_east\",\n",
    "    \"route_west_to_south\"\n",
    "]\n",
    "\n",
    "\n",
    "day_path = os.path.join(BASE_DIR, TARGET_FOLDER)\n",
    "\n",
    "for burst_route in burst_routes:\n",
    "    print(f\"\\n🔁 Running simulations for burst: {burst_route}\")\n",
    "    all_results = []\n",
    "\n",
    "    for subfolder in os.listdir(day_path):\n",
    "        if subfolder.lower() in [\"1min\",\"2min\"]:\n",
    "            combined_dir = move_routes_and_setup_combined(day_path, subfolder)\n",
    "            cfg_file_path = os.path.join(combined_dir, \"sumo_config.sumocfg\")\n",
    "\n",
    "            for f in os.listdir(combined_dir):\n",
    "                if f.startswith(\"route.rou\") and f.endswith(\".xml\"):\n",
    "                    insert_burst_flow_ordered(os.path.join(combined_dir, f), burst_route)\n",
    "\n",
    "            results = run_simulation(cfg_file_path, combined_dir)\n",
    "            for r in results:\n",
    "                r[\"duration_folder\"] = subfolder\n",
    "            all_results.extend(results)\n",
    "\n",
    "    # Save results for current burst route\n",
    "    short_name = burst_route.replace(\"route_\", \"\")\n",
    "    csv_path = os.path.join(TARGET_FOLDER, f\"final_congestion_results_{short_name}_for_metrics.csv\")\n",
    "    results_df = pd.DataFrame(all_results)\n",
    "    results_df.to_csv(csv_path, index=False, float_format=\"%.2f\")\n",
    "\n",
    "    print(f\"✅ Saved: {csv_path}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "46e14ecf",
   "metadata": {},
   "source": [
    "need to collect data from all 6 target folders/day's"
   ]
  }
 ],
 "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.13.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
