{
 "cells": [
  {
   "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: 87.00 s | AWT: 57.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 90.00 s | AWT: 57.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 89.00 s | AWT: 58.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 94.00 s | AWT: 59.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 91.00 s | AWT: 58.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 88.50 s | AWT: 59.50 s\n",
      "\n",
      "✅ Simulation route.rou7.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 90.00 s | AWT: 59.00 s\n",
      "\n",
      "✅ Simulation route.rou8.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 89.50 s | AWT: 60.00 s\n",
      "\n",
      "✅ Simulation route.rou9.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 88.00 s | AWT: 59.00 s\n",
      "\n",
      "✅ Simulation route.rou10.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 86.50 s | AWT: 59.00 s\n",
      "\n",
      "✅ Simulation route.rou11.xml ended\n",
      "📈 High congestion detected in NT+ST at 53%\n",
      "⏱️ ATT: 157.00 s | AWT: 78.00 s\n",
      "\n",
      "✅ Simulation route.rou12.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 90.00 s | AWT: 61.00 s\n",
      "\n",
      "✅ Simulation route.rou13.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 88.00 s | AWT: 59.00 s\n",
      "\n",
      "✅ Simulation route.rou14.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 90.00 s | AWT: 59.50 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in NT+ST at 54%\n",
      "⏱️ ATT: 87.00 s | AWT: 62.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in NT+ST at 56%\n",
      "⏱️ ATT: 93.00 s | AWT: 64.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 90.00 s | AWT: 60.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in NT+ST at 55%\n",
      "⏱️ ATT: 93.00 s | AWT: 59.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in NT+ST at 54%\n",
      "⏱️ ATT: 86.00 s | AWT: 60.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in NT+ST at 54%\n",
      "⏱️ ATT: 153.00 s | AWT: 77.00 s\n",
      "✅ Saved: C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\\final_congestion_results_north_to_south_for_metrics.csv\n",
      "\n",
      "🔁 Running simulations for burst: route_east_to_west\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\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\"\n",
    "SUMO_BINARY = r\"C:\\Program Files (x86)\\Eclipse\\Sumo\\bin\\sumo.exe\"\n",
    "STEP = 1\n",
    "CYCLE_SEC = 90\n",
    "NETWORK_FOLDER = os.path.join(BASE_DIR, \"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",
    "                if not os.path.exists(dst):\n",
    "                    shutil.copy(src, dst)\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",
    "            \"ATT\": float(f\"{ATT:.2f}\"),\n",
    "            \"AWT\": float(f\"{AWT:.2f}\")\n",
    "        })\n",
    "\n",
    "    return results\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# ─────────── OUTER LOOP OVER 12 BURST ROUTES ───────────\n",
    "burst_routes = [\n",
    " \"route_north_to_south\",\"route_east_to_west\", \"route_east_to_south\",\n",
    " \"route_north_to_east\"\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": "code",
   "execution_count": 2,
   "id": "55540e25",
   "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 46%\n",
      "⏱️ ATT: 21.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in NT+ST at 43%\n",
      "⏱️ ATT: 63.00 s | AWT: 35.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in NT+ST at 46%\n",
      "⏱️ ATT: 55.00 s | AWT: 33.50 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in NT+ST at 46%\n",
      "⏱️ ATT: 28.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in NT+ST at 46%\n",
      "⏱️ ATT: 22.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in NT+ST at 46%\n",
      "⏱️ ATT: 20.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou7.xml ended\n",
      "📈 High congestion detected in NT+ST at 46%\n",
      "⏱️ ATT: 19.50 s | AWT: 0.50 s\n",
      "\n",
      "✅ Simulation route.rou8.xml ended\n",
      "📈 High congestion detected in NT+ST at 45%\n",
      "⏱️ ATT: 26.00 s | AWT: 1.00 s\n",
      "\n",
      "✅ Simulation route.rou9.xml ended\n",
      "📈 High congestion detected in NT+ST at 46%\n",
      "⏱️ ATT: 55.00 s | AWT: 33.50 s\n",
      "\n",
      "✅ Simulation route.rou10.xml ended\n",
      "📈 High congestion detected in NT+ST at 44%\n",
      "⏱️ ATT: 65.00 s | AWT: 33.00 s\n",
      "\n",
      "✅ Simulation route.rou11.xml ended\n",
      "📈 High congestion detected in NT+ST at 47%\n",
      "⏱️ ATT: 22.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou12.xml ended\n",
      "📈 High congestion detected in NT+ST at 45%\n",
      "⏱️ ATT: 18.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in NT+ST at 44%\n",
      "⏱️ ATT: 60.00 s | AWT: 34.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in NT+ST at 46%\n",
      "⏱️ ATT: 14.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in NT+ST at 46%\n",
      "⏱️ ATT: 20.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in NT+ST at 47%\n",
      "⏱️ ATT: 16.00 s | AWT: 1.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in NT+ST at 46%\n",
      "⏱️ ATT: 66.50 s | AWT: 32.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in NT+ST at 44%\n",
      "⏱️ ATT: 65.00 s | AWT: 34.00 s\n",
      "✅ Saved: C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\\mmmmfinal_congestion_results_north_to_south_for_metrics.csv\n",
      "\n",
      "🔁 Running simulations for burst: route_east_to_west\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 45%\n",
      "⏱️ ATT: 68.00 s | AWT: 33.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 45%\n",
      "⏱️ ATT: 15.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in ET+WT at 43%\n",
      "⏱️ ATT: 62.00 s | AWT: 31.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in ET+WT at 44%\n",
      "⏱️ ATT: 63.00 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in ET+WT at 44%\n",
      "⏱️ ATT: 59.50 s | AWT: 31.50 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in ET+WT at 45%\n",
      "⏱️ ATT: 66.50 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou7.xml ended\n",
      "📈 High congestion detected in ET+WT at 42%\n",
      "⏱️ ATT: 61.00 s | AWT: 33.50 s\n",
      "\n",
      "✅ Simulation route.rou8.xml ended\n",
      "📈 High congestion detected in ET+WT at 42%\n",
      "⏱️ ATT: 60.00 s | AWT: 35.00 s\n",
      "\n",
      "✅ Simulation route.rou9.xml ended\n",
      "📈 High congestion detected in ET+WT at 45%\n",
      "⏱️ ATT: 63.00 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou10.xml ended\n",
      "📈 High congestion detected in ET+WT at 46%\n",
      "⏱️ ATT: 65.00 s | AWT: 32.00 s\n",
      "\n",
      "✅ Simulation route.rou11.xml ended\n",
      "📈 High congestion detected in ET+WT at 46%\n",
      "⏱️ ATT: 15.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou12.xml ended\n",
      "📈 High congestion detected in ET+WT at 43%\n",
      "⏱️ ATT: 63.00 s | AWT: 33.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 46%\n",
      "⏱️ ATT: 22.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 46%\n",
      "⏱️ ATT: 15.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in ET+WT at 47%\n",
      "⏱️ ATT: 63.00 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in ET+WT at 46%\n",
      "⏱️ ATT: 55.00 s | AWT: 28.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in ET+WT at 42%\n",
      "⏱️ ATT: 63.00 s | AWT: 33.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in ET+WT at 43%\n",
      "⏱️ ATT: 60.00 s | AWT: 28.00 s\n",
      "✅ Saved: C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\\mmmmfinal_congestion_results_east_to_west_for_metrics.csv\n",
      "\n",
      "🔁 Running simulations for burst: route_east_to_south\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 46%\n",
      "⏱️ ATT: 49.00 s | AWT: 21.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 45%\n",
      "⏱️ ATT: 31.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 45%\n",
      "⏱️ ATT: 52.00 s | AWT: 25.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 45%\n",
      "⏱️ ATT: 60.00 s | AWT: 21.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 46%\n",
      "⏱️ ATT: 26.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 45%\n",
      "⏱️ ATT: 54.00 s | AWT: 24.00 s\n",
      "\n",
      "✅ Simulation route.rou7.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 45%\n",
      "⏱️ ATT: 53.00 s | AWT: 23.00 s\n",
      "\n",
      "✅ Simulation route.rou8.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 46%\n",
      "⏱️ ATT: 58.00 s | AWT: 24.00 s\n",
      "\n",
      "✅ Simulation route.rou9.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 45%\n",
      "⏱️ ATT: 57.00 s | AWT: 22.00 s\n",
      "\n",
      "✅ Simulation route.rou10.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 45%\n",
      "⏱️ ATT: 24.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou11.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 46%\n",
      "⏱️ ATT: 19.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou12.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 46%\n",
      "⏱️ ATT: 57.00 s | AWT: 23.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 47%\n",
      "⏱️ ATT: 29.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 47%\n",
      "⏱️ ATT: 31.00 s | AWT: 1.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 47%\n",
      "⏱️ ATT: 24.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 44%\n",
      "⏱️ ATT: 55.00 s | AWT: 23.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 47%\n",
      "⏱️ ATT: 51.00 s | AWT: 22.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 46%\n",
      "⏱️ ATT: 48.00 s | AWT: 19.00 s\n",
      "✅ Saved: C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\\mmmmfinal_congestion_results_east_to_south_for_metrics.csv\n",
      "\n",
      "🔁 Running simulations for burst: route_north_to_east\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 47%\n",
      "⏱️ ATT: 66.00 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 47%\n",
      "⏱️ ATT: 65.00 s | AWT: 36.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 47%\n",
      "⏱️ ATT: 66.00 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 48%\n",
      "⏱️ ATT: 64.00 s | AWT: 34.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 48%\n",
      "⏱️ ATT: 58.00 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 47%\n",
      "⏱️ ATT: 61.00 s | AWT: 36.00 s\n",
      "\n",
      "✅ Simulation route.rou7.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 48%\n",
      "⏱️ ATT: 20.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou8.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 60%\n",
      "⏱️ ATT: 1754.00 s | AWT: 51.00 s\n",
      "\n",
      "✅ Simulation route.rou9.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 47%\n",
      "⏱️ ATT: 66.00 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou10.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 48%\n",
      "⏱️ ATT: 26.00 s | AWT: 0.00 s\n",
      "\n",
      "✅ Simulation route.rou11.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 47%\n",
      "⏱️ ATT: 64.00 s | AWT: 34.00 s\n",
      "\n",
      "✅ Simulation route.rou12.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 47%\n",
      "⏱️ ATT: 66.00 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 47%\n",
      "⏱️ ATT: 62.00 s | AWT: 30.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 49%\n",
      "⏱️ ATT: 61.00 s | AWT: 33.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 60%\n",
      "⏱️ ATT: 1829.00 s | AWT: 54.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 48%\n",
      "⏱️ ATT: 62.00 s | AWT: 32.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 49%\n",
      "⏱️ ATT: 62.00 s | AWT: 29.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in NS-LEFTS at 48%\n",
      "⏱️ ATT: 21.00 s | AWT: 0.00 s\n",
      "✅ Saved: C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\\mmmmfinal_congestion_results_north_to_east_for_metrics.csv\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\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\"\n",
    "SUMO_BINARY = r\"C:\\Program Files (x86)\\Eclipse\\Sumo\\bin\\sumo.exe\"\n",
    "STEP = 1\n",
    "CYCLE_SEC = 90\n",
    "NETWORK_FOLDER = os.path.join(BASE_DIR, \"new_road_network\")\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",
    "    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",
    "                if not os.path.exists(dst):\n",
    "                    shutil.copy(src, dst)\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, burst_route):\n",
    "    route_map = {\n",
    "        \"route_north_to_south\": \"add1.xml\",\n",
    "        \"route_east_to_west\": \"add2.xml\",\n",
    "        \"route_north_to_east\": \"add_ns_left.xml\",\n",
    "        \"route_east_to_south\": \"add_ew_left.xml\"\n",
    "    }\n",
    "\n",
    "    additional_file = route_map.get(burst_route)\n",
    "\n",
    "    tree = ET.parse(cfg_path)\n",
    "    root = tree.getroot()\n",
    "\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",
    "\n",
    "        if additional_file:\n",
    "            ET.SubElement(elem, \"additional-files\", {\"value\": additional_file})\n",
    "\n",
    "    tree.write(cfg_path, encoding=\"utf-8\", xml_declaration=True)\n",
    "\n",
    "\n",
    "def run_simulation(cfg_file, combined_folder, burst_route):\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, burst_route)\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\n",
    "                waiting_times[veh_id] = traci.vehicle.getAccumulatedWaitingTime(veh_id)\n",
    "\n",
    "            if t >= next_cut:\n",
    "                next_cut += CYCLE_SEC\n",
    "\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",
    "            \"ATT\": float(f\"{ATT:.2f}\"),\n",
    "            \"AWT\": float(f\"{AWT:.2f}\")\n",
    "        })\n",
    "\n",
    "    return results\n",
    "\n",
    "\n",
    "# ─────────── OUTER LOOP OVER BURST ROUTES ───────────\n",
    "burst_routes = [\n",
    "    \"route_north_to_south\",\n",
    "    \"route_east_to_west\",\n",
    "    \"route_east_to_south\",\n",
    "    \"route_north_to_east\"\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, burst_route)\n",
    "            for r in results:\n",
    "                r[\"duration_folder\"] = subfolder\n",
    "            all_results.extend(results)\n",
    "\n",
    "    short_name = burst_route.replace(\"route_\", \"\")\n",
    "    csv_path = os.path.join(TARGET_FOLDER, f\"mmmmfinal_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}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "009723be",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average ATT across both days: 47.55\n",
      "Average AWT across both days: 20.82\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "\n",
    "# Load both day files\n",
    "day1_df = pd.read_csv(r\"C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\\mmmmfinal_congestion_results_east_to_west_for_metrics.csv\")\n",
    "day2_df = pd.read_csv(r\"C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\\mmmmfinal_congestion_results_east_to_west_for_metrics.csv\")\n",
    "\n",
    "# Combine both days' data\n",
    "combined_df = pd.concat([day1_df, day2_df], ignore_index=True)\n",
    "\n",
    "# Compute overall average ATT and AWT\n",
    "avg_ATT = combined_df[\"ATT\"].mean()\n",
    "avg_AWT = combined_df[\"AWT\"].mean()\n",
    "\n",
    "# Print results\n",
    "print(f\"Average ATT across both days: {avg_ATT:.2f}\")\n",
    "print(f\"Average AWT across both days: {avg_AWT:.2f}\")\n",
    "\n",
    "# Save to CSV\n",
    "avg_metrics = pd.DataFrame({\n",
    "    \"Metric\": [\"Average ATT\", \"Average AWT\"],\n",
    "    \"Value\": [round(avg_ATT, 2), round(avg_AWT, 2)]\n",
    "})\n",
    "avg_metrics.to_csv(r\"C:\\Users\\tasfi\\Downloads\\code_for_sudden_burst\\old_pc_in_ull\\Finish_by_today\\Finish_by_today\\mmmmavg_metrics_for_east_west.csv\", index=False)\n",
    "\n",
    "\n",
    "# Load the CSVs\n"
   ]
  }
 ],
 "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
}
