{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e1a4dfa2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "✅ Replaced <tlLogic> block with faulty traffic signal logic.\n"
     ]
    }
   ],
   "source": [
    "import re\n",
    "\n",
    "# Path to your .net.xml file\n",
    "net_file_path = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\\simple_nw_se.net.xml\"\n",
    "\n",
    "# Your faulty traffic signal logic\n",
    "faulty_tl_logic = \"\"\"\n",
    "<tlLogic id=\"center\" type=\"static\" programID=\"faulty_traffic\" offset=\"0\">\n",
    "    <phase duration=\"4\" state=\"rrrrrGGGGGrrrrrGGGGG\"/>\n",
    "    <phase duration=\"10\" state=\"rrrrryyyyyrrrrryyyyy\"/>\n",
    "    <phase duration=\"200\"  state=\"GGGGGrrrrrGGGGGrrrrr\"/>\n",
    "    <phase duration=\"10\" state=\"yyyyyrrrrryyyyyrrrrr\"/>\n",
    "</tlLogic>\n",
    "\"\"\"\n",
    "\n",
    "# Read the original file\n",
    "with open(net_file_path, \"r\", encoding=\"utf-8\") as f:\n",
    "    content = f.read()\n",
    "\n",
    "# Replace the existing <tlLogic id=\"center\"...> block\n",
    "updated_content = re.sub(\n",
    "    r\"<tlLogic id=\\\"center\\\".*?</tlLogic>\",\n",
    "    faulty_tl_logic.strip(),\n",
    "    content,\n",
    "    flags=re.DOTALL\n",
    ")\n",
    "\n",
    "# Write back to the file\n",
    "with open(net_file_path, \"w\", encoding=\"utf-8\") as f:\n",
    "    f.write(updated_content)\n",
    "\n",
    "print(\"✅ Replaced <tlLogic> block with faulty traffic signal logic.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c13de52f",
   "metadata": {},
   "source": [
    "east-west approach is starved"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "27bb7d69",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "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\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\"\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\"\n",
    "DURATION_FOLDERS = [\"2min\", \"3min\", \"4min\", \"5min\", \"6min\"]\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": "code",
   "execution_count": null,
   "id": "0188c2c1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6da9ef0a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "✅ 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 add.ew-l.xml → 2min/combined\n",
      "📄 Copied add.ew.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 add.ew-l.xml → 3min/combined\n",
      "📄 Copied add.ew.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 add.ew-l.xml → 4min/combined\n",
      "📄 Copied add.ew.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 add.ew-l.xml → 5min/combined\n",
      "📄 Copied add.ew.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 add.ew-l.xml → 6min/combined\n",
      "📄 Copied add.ew.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\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\"\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\"\n",
    "DURATION_FOLDERS = [\"2min\", \"3min\", \"4min\", \"5min\", \"6min\"]\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": "5536cf59",
   "metadata": {},
   "source": [
    "to clean up the route.rou.xml files often it shows error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fb1859b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import xml.etree.ElementTree as ET\n",
    "\n",
    "# Base folder containing the minute folders (1Min, 2Min, etc.)\n",
    "BASE_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\"\n",
    "\n",
    "# Minute subfolders to loop over\n",
    "minute_folders = [\"1Min\", \"2Min\", \"3Min\", \"4Min\", \"5Min\",\"6min\"]\n",
    "\n",
    "# Loop over each minute folder\n",
    "for minute in minute_folders:\n",
    "    minute_path = os.path.join(BASE_FOLDER, minute)\n",
    "    if not os.path.isdir(minute_path):\n",
    "        continue\n",
    "\n",
    "    # Loop over all Video_X subfolders\n",
    "    for subfolder in os.listdir(minute_path):\n",
    "        video_path = os.path.join(minute_path, subfolder)\n",
    "        if not os.path.isdir(video_path) or not subfolder.lower().startswith(\"video\"):\n",
    "            continue\n",
    "\n",
    "        route_file = os.path.join(video_path, \"route.rou.xml\")\n",
    "        if not os.path.exists(route_file):\n",
    "            continue\n",
    "\n",
    "        try:\n",
    "            # Parse the XML and remove duplicate vType elements\n",
    "            tree = ET.parse(route_file)\n",
    "            root = tree.getroot()\n",
    "\n",
    "            seen_ids = set()\n",
    "            for elem in root.findall(\"vType\"):\n",
    "                vid = elem.attrib.get(\"id\")\n",
    "                if vid in seen_ids:\n",
    "                    root.remove(elem)\n",
    "                else:\n",
    "                    seen_ids.add(vid)\n",
    "\n",
    "            # Save the cleaned XML\n",
    "            tree.write(route_file, encoding=\"utf-8\", xml_declaration=True)\n",
    "            print(f\"✅ Cleaned: {route_file}\")\n",
    "\n",
    "        except Exception as e:\n",
    "            print(f\"❌ Failed to process {route_file}: {e}\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "38d5fe44",
   "metadata": {},
   "source": [
    "code to run simulation to get att and awt for test data with faulty logic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f2d4ee7b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 19%\n",
      "⏱️ ATT: 1730.00 s | AWT: 63.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 44%\n",
      "⏱️ ATT: 2701.00 s | AWT: 72.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in ET+WT at 26%\n",
      "⏱️ ATT: 1923.00 s | AWT: 76.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in ET+WT at 17%\n",
      "⏱️ ATT: 1353.00 s | AWT: 72.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in ET+WT at 25%\n",
      "⏱️ ATT: 2379.00 s | AWT: 70.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in ET+WT at 24%\n",
      "⏱️ ATT: 2166.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 32%\n",
      "⏱️ ATT: 3142.00 s | AWT: 81.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 41%\n",
      "⏱️ ATT: 2467.00 s | AWT: 84.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in ET+WT at 34%\n",
      "⏱️ ATT: 2465.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in ET+WT at 31%\n",
      "⏱️ ATT: 2514.50 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 46%\n",
      "⏱️ ATT: 2685.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 37%\n",
      "⏱️ ATT: 2688.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in ET+WT at 41%\n",
      "⏱️ ATT: 2686.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 46%\n",
      "⏱️ ATT: 2685.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 44%\n",
      "⏱️ ATT: 2701.00 s | AWT: 72.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 45%\n",
      "⏱️ ATT: 2690.00 s | AWT: 84.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 45%\n",
      "⏱️ ATT: 2686.00 s | AWT: 85.00 s\n"
     ]
    }
   ],
   "source": [
    "\n",
    "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\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\"\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\"\n",
    "OUTPUT_CSV = os.path.join(TARGET_FOLDER, \"traffic_malfunctioning_in_east_for_metrics.csv\")\n",
    "SUMO_BINARY = r\"C:\\Program Files (x86)\\Eclipse\\Sumo\\bin\\sumo.exe\"\n",
    "STEP = 1\n",
    "CYCLE_SEC = 90\n",
    "\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",
    "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",
    "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",
    "    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",
    "    if os.path.exists(NETWORK_FOLDER):\n",
    "        for file in os.listdir(NETWORK_FOLDER):\n",
    "            if file.endswith((\".net.xml\", \".nod.xml\", \".edg.xml\", \".typ.xml\", \".sumocfg\", \".add.xml\", \".xml\")):\n",
    "                shutil.copy(os.path.join(NETWORK_FOLDER, file), os.path.join(combined_dir, file))\n",
    "    return combined_dir\n",
    "\n",
    "def update_sumo_config_route_file(cfg_path, route_file):\n",
    "    tree = ET.parse(cfg_path)\n",
    "    root = tree.getroot()\n",
    "    for elem in root.findall(\".//input\"):\n",
    "        for child in elem:\n",
    "            if child.tag == \"route-files\":\n",
    "                child.set(\"value\", route_file)\n",
    "    tree.write(cfg_path, encoding=\"utf-8\", xml_declaration=True)\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_route_file(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",
    "            \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",
    "\n",
    "\n",
    "day_path = os.path.join(BASE_DIR, TARGET_FOLDER)\n",
    "all_results = []\n",
    "for subfolder in os.listdir(day_path):\n",
    "    if subfolder.lower() in [\"2min\", \"3min\", \"4min\", \"5min\", \"6min\"]:\n",
    "        try:\n",
    "            combined_dir = move_routes_and_setup_combined(day_path, subfolder)\n",
    "            cfg_path = os.path.join(combined_dir, \"sumo_config.sumocfg\")\n",
    "            results = run_simulation(cfg_path, combined_dir)\n",
    "            for r in results:\n",
    "                r[\"duration_folder\"] = subfolder\n",
    "            all_results.extend(results)\n",
    "        except Exception as e:\n",
    "            print(f\"❌ Error processing {subfolder}: {e}\")\n",
    "\n",
    "csv_path = os.path.join(TARGET_FOLDER, f\"traffic_malfunctioning_in_east_for_metrics.csv\")\n",
    "results_df = pd.DataFrame(all_results)\n",
    "results_df.to_csv(csv_path, index=False, float_format=\"%.2f\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "09cd5496",
   "metadata": {},
   "source": [
    "for another day"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1872b9e3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 21%\n",
      "⏱️ ATT: 1943.00 s | AWT: 61.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 17%\n",
      "⏱️ ATT: 1320.00 s | AWT: 82.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in ET+WT at 27%\n",
      "⏱️ ATT: 1921.00 s | AWT: 86.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in ET+WT at 14%\n",
      "⏱️ ATT: 1132.00 s | AWT: 66.00 s\n",
      "\n",
      "✅ Simulation route.rou5.xml ended\n",
      "📈 High congestion detected in EW-LEFTS at 14%\n",
      "⏱️ ATT: 1072.00 s | AWT: 81.00 s\n",
      "\n",
      "✅ Simulation route.rou6.xml ended\n",
      "📈 High congestion detected in ET+WT at 21%\n",
      "⏱️ ATT: 1902.00 s | AWT: 86.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 33%\n",
      "⏱️ ATT: 2688.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 39%\n",
      "⏱️ ATT: 2243.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in ET+WT at 24%\n",
      "⏱️ ATT: 1891.00 s | AWT: 84.00 s\n",
      "\n",
      "✅ Simulation route.rou4.xml ended\n",
      "📈 High congestion detected in ET+WT at 20%\n",
      "⏱️ ATT: 1842.00 s | AWT: 86.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 33%\n",
      "⏱️ ATT: 2688.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 33%\n",
      "⏱️ ATT: 2691.00 s | AWT: 82.00 s\n",
      "\n",
      "✅ Simulation route.rou3.xml ended\n",
      "📈 High congestion detected in ET+WT at 27%\n",
      "⏱️ ATT: 2235.00 s | AWT: 85.00 s\n",
      "\n",
      "✅ Simulation route.rou1.xml ended\n",
      "📈 High congestion detected in ET+WT at 46%\n",
      "⏱️ ATT: 2457.00 s | AWT: 86.00 s\n",
      "\n",
      "✅ Simulation route.rou2.xml ended\n",
      "📈 High congestion detected in ET+WT at 31%\n",
      "⏱️ ATT: 2688.00 s | AWT: 86.00 s\n"
     ]
    }
   ],
   "source": [
    "\n",
    "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\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\"\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\"\n",
    "OUTPUT_CSV = os.path.join(TARGET_FOLDER, \"traffic_malfunctioning_in_east_for_metrics.csv\")\n",
    "SUMO_BINARY = r\"C:\\Program Files (x86)\\Eclipse\\Sumo\\bin\\sumo.exe\"\n",
    "STEP = 1\n",
    "CYCLE_SEC = 90\n",
    "\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",
    "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",
    "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",
    "    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",
    "    if os.path.exists(NETWORK_FOLDER):\n",
    "        for file in os.listdir(NETWORK_FOLDER):\n",
    "            if file.endswith((\".net.xml\", \".nod.xml\", \".edg.xml\", \".typ.xml\", \".sumocfg\", \".add.xml\", \".xml\")):\n",
    "                shutil.copy(os.path.join(NETWORK_FOLDER, file), os.path.join(combined_dir, file))\n",
    "    return combined_dir\n",
    "\n",
    "def update_sumo_config_route_file(cfg_path, route_file):\n",
    "    tree = ET.parse(cfg_path)\n",
    "    root = tree.getroot()\n",
    "    for elem in root.findall(\".//input\"):\n",
    "        for child in elem:\n",
    "            if child.tag == \"route-files\":\n",
    "                child.set(\"value\", route_file)\n",
    "    tree.write(cfg_path, encoding=\"utf-8\", xml_declaration=True)\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_route_file(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",
    "            \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",
    "\n",
    "\n",
    "day_path = os.path.join(BASE_DIR, TARGET_FOLDER)\n",
    "all_results = []\n",
    "for subfolder in os.listdir(day_path):\n",
    "    if subfolder.lower() in [\"2min\", \"3min\", \"4min\", \"5min\", \"6min\"]:\n",
    "        try:\n",
    "            combined_dir = move_routes_and_setup_combined(day_path, subfolder)\n",
    "            cfg_path = os.path.join(combined_dir, \"sumo_config.sumocfg\")\n",
    "            results = run_simulation(cfg_path, combined_dir)\n",
    "            for r in results:\n",
    "                r[\"duration_folder\"] = subfolder\n",
    "            all_results.extend(results)\n",
    "        except Exception as e:\n",
    "            print(f\"❌ Error processing {subfolder}: {e}\")\n",
    "\n",
    "csv_path = os.path.join(TARGET_FOLDER, f\"traffic_malfunctioning_in_east_for_metrics.csv\")\n",
    "results_df = pd.DataFrame(all_results)\n",
    "results_df.to_csv(csv_path, index=False, float_format=\"%.2f\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "999c014d",
   "metadata": {},
   "source": [
    "Here is a complete Python script that:\n",
    "\n",
    "Loads a CSV file like traffic_malfunctioning_in_east_for_metrics.csv, which contains the most congested phase (EW or EW-L) per duration or route.\n",
    "open the csv file and based on the value of the congested phase:\n",
    "If EW, we applied the LLM-generated logic: add.ew.xml\n",
    "If EW-L, we used: add.ew-l.xml\n",
    "Modifies the SUMO .sumocfg file to include the correct additional-files XML (either add.ew.xml or add.ew-l.xml) \n",
    "\n",
    "Runs the SUMO simulation for each test route file.\n",
    "\n",
    "Computes ATT (Average Travel Time) and AWT (Average Waiting Time).\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "420d61f5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew-l.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import shutil\n",
    "import xml.etree.ElementTree as ET\n",
    "import pandas as pd\n",
    "import traci\n",
    "\n",
    "# ─────────── USER CONFIG ───────────\n",
    "BASE_DIR = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\"\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\"\n",
    "OUTPUT_CSV = os.path.join(TARGET_FOLDER, \"traffic_malfunctioning_metrics_with_logic_IN_EAST.csv\")\n",
    "SUMO_BINARY = r\"C:\\Program Files (x86)\\Eclipse\\Sumo\\bin\\sumo.exe\"\n",
    "STEP = 1\n",
    "CYCLE_SEC = 90\n",
    "\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",
    "def update_additional_file(cfg_path, phase):\n",
    "    phase_to_additional_file = {\n",
    "        \"EW\": \"add.ew.xml\",\n",
    "        \"EW-L\":\"add.ew-l.xml\"\n",
    "     \n",
    "    }\n",
    "\n",
    "    if phase not in phase_to_additional_file:\n",
    "        print(f\"ℹ️ Skipping additional file update for phase: {phase}\")\n",
    "        return\n",
    "\n",
    "    additional_file = phase_to_additional_file[phase]\n",
    "    print(f\"⚙️ Updating additional file to: {additional_file}\")\n",
    "\n",
    "    tree = ET.parse(cfg_path)\n",
    "    root = tree.getroot()\n",
    "    input_elem = root.find(\"input\")\n",
    "    if input_elem is None:\n",
    "        input_elem = ET.SubElement(root, \"input\")\n",
    "\n",
    "    found = False\n",
    "    for child in input_elem:\n",
    "        if child.tag == \"additional-files\":\n",
    "            child.set(\"value\", additional_file)\n",
    "            found = True\n",
    "            break\n",
    "    if not found:\n",
    "        ET.SubElement(input_elem, \"additional-files\", {\"value\": additional_file})\n",
    "\n",
    "    tree.write(cfg_path, encoding=\"utf-8\", xml_declaration=True)\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",
    "    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",
    "                shutil.copy(route_src, os.path.join(combined_dir, f\"route.rou{counter}.xml\"))\n",
    "                counter += 1\n",
    "    if os.path.exists(NETWORK_FOLDER):\n",
    "        for file in os.listdir(NETWORK_FOLDER):\n",
    "            if file.endswith((\".net.xml\", \".nod.xml\", \".edg.xml\", \".typ.xml\", \".sumocfg\", \".add.xml\", \".xml\")):\n",
    "                shutil.copy(os.path.join(NETWORK_FOLDER, file), os.path.join(combined_dir, file))\n",
    "    return combined_dir\n",
    "\n",
    "\n",
    "def update_sumo_config_route_file(cfg_path, route_file):\n",
    "    tree = ET.parse(cfg_path)\n",
    "    root = tree.getroot()\n",
    "    for elem in root.findall(\".//input\"):\n",
    "        for child in elem:\n",
    "            if child.tag == \"route-files\":\n",
    "                child.set(\"value\", route_file)\n",
    "    tree.write(cfg_path, encoding=\"utf-8\", xml_declaration=True)\n",
    "\n",
    "\n",
    "def run_simulation(cfg_file, combined_folder, duration_folder):\n",
    "    results = []\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",
    "        # Always use NS by default\n",
    "        update_additional_file(cfg_file, \"EW\")\n",
    "\n",
    "        # Only override to NS-L for 3rd video in 2min folder\n",
    "        if duration_folder.lower() == \"3min\" and (i == 1):\n",
    "            update_additional_file(cfg_file, \"EW-L\")\n",
    "\n",
    "        update_sumo_config_route_file(cfg_file, route_file)\n",
    "        traci.start([SUMO_BINARY, \"-c\", cfg_file, \"--step-length\", str(STEP), \"--no-step-log\", \"true\", \"--time-to-teleport\", \"-1\"])\n",
    "\n",
    "        occupancy_history = {grp: [] for grp in lane_groups}\n",
    "        depart_times = {}\n",
    "        arrival_times = {}\n",
    "        waiting_times = {}\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",
    "                occ = [traci.lane.getLastStepOccupancy(ln) for ln in lanes]\n",
    "                occupancy_history[grp].append(sum(occ)/len(occ) if occ else 0)\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",
    "        for veh_id in traci.simulation.getArrivedIDList():\n",
    "            arrival_times[veh_id] = traci.simulation.getTime()\n",
    "\n",
    "        traci.close()\n",
    "\n",
    "        travel_times = [arrival_times[v] - depart_times[v] for v in arrival_times if v in depart_times]\n",
    "        wait_times = [waiting_times.get(v, 0) for v in arrival_times]\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 = {g: sum(v)/len(v) if v else 0 for g, v in occupancy_history.items()}\n",
    "        avg_occ_per_phase = {p: max(avg_occ_per_group[g] for g in gs) for p, gs in phase_groups.items()}\n",
    "\n",
    "        most_congested_phase = max(avg_occ_per_phase, key=avg_occ_per_phase.get)\n",
    "\n",
    "        results.append({\n",
    "            \"route_file\": route_file,\n",
    "            \"congested_phase\": most_congested_phase,\n",
    "            \"max_occupancy_percent\": int(avg_occ_per_phase[most_congested_phase]*100),\n",
    "            \"ATT\": float(f\"{ATT:.2f}\"),\n",
    "            \"AWT\": float(f\"{AWT:.2f}\")\n",
    "        })\n",
    "\n",
    "    return results\n",
    "\n",
    "\n",
    "# ─────────── MAIN LOOP ───────────\n",
    "day_path = os.path.join(BASE_DIR, TARGET_FOLDER)\n",
    "all_results = []\n",
    "for subfolder in os.listdir(day_path):\n",
    "    if subfolder.lower() in [\"2min\", \"3min\", \"4min\", \"5min\", \"6min\"]:\n",
    "        try:\n",
    "            combined_dir = move_routes_and_setup_combined(day_path, subfolder)\n",
    "            cfg_path = os.path.join(combined_dir, \"sumo_config.sumocfg\")\n",
    "            results = run_simulation(cfg_path, combined_dir, subfolder)\n",
    "            for r in results:\n",
    "                r[\"duration_folder\"] = subfolder\n",
    "            all_results.extend(results)\n",
    "        except Exception as e:\n",
    "            print(f\"❌ Error processing {subfolder}: {e}\")\n",
    "\n",
    "df = pd.DataFrame(all_results)\n",
    "df.to_csv(OUTPUT_CSV, index=False, float_format=\"%.2f\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e3ff9676",
   "metadata": {},
   "source": [
    "for another day"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "7abf3a81",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew-l.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew-l.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n",
      "⚙️ Updating additional file to: add.ew.xml\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import shutil\n",
    "import xml.etree.ElementTree as ET\n",
    "import pandas as pd\n",
    "import traci\n",
    "\n",
    "# ─────────── USER CONFIG ───────────\n",
    "BASE_DIR = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\"\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\"\n",
    "OUTPUT_CSV = os.path.join(TARGET_FOLDER, \"traffic_malfunctioning_metrics_with_logic_IN_EAST.csv\")\n",
    "SUMO_BINARY = r\"C:\\Program Files (x86)\\Eclipse\\Sumo\\bin\\sumo.exe\"\n",
    "STEP = 1\n",
    "CYCLE_SEC = 90\n",
    "\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",
    "def update_additional_file(cfg_path, phase):\n",
    "    phase_to_additional_file = {\n",
    "        \"EW\": \"add.ew.xml\",\n",
    "        \"EW-L\":\"add.ew-l.xml\"\n",
    "     \n",
    "    }\n",
    "\n",
    "    if phase not in phase_to_additional_file:\n",
    "        print(f\"ℹ️ Skipping additional file update for phase: {phase}\")\n",
    "        return\n",
    "\n",
    "    additional_file = phase_to_additional_file[phase]\n",
    "    print(f\"⚙️ Updating additional file to: {additional_file}\")\n",
    "\n",
    "    tree = ET.parse(cfg_path)\n",
    "    root = tree.getroot()\n",
    "    input_elem = root.find(\"input\")\n",
    "    if input_elem is None:\n",
    "        input_elem = ET.SubElement(root, \"input\")\n",
    "\n",
    "    found = False\n",
    "    for child in input_elem:\n",
    "        if child.tag == \"additional-files\":\n",
    "            child.set(\"value\", additional_file)\n",
    "            found = True\n",
    "            break\n",
    "    if not found:\n",
    "        ET.SubElement(input_elem, \"additional-files\", {\"value\": additional_file})\n",
    "\n",
    "    tree.write(cfg_path, encoding=\"utf-8\", xml_declaration=True)\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",
    "    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",
    "                shutil.copy(route_src, os.path.join(combined_dir, f\"route.rou{counter}.xml\"))\n",
    "                counter += 1\n",
    "    if os.path.exists(NETWORK_FOLDER):\n",
    "        for file in os.listdir(NETWORK_FOLDER):\n",
    "            if file.endswith((\".net.xml\", \".nod.xml\", \".edg.xml\", \".typ.xml\", \".sumocfg\", \".add.xml\", \".xml\")):\n",
    "                shutil.copy(os.path.join(NETWORK_FOLDER, file), os.path.join(combined_dir, file))\n",
    "    return combined_dir\n",
    "\n",
    "\n",
    "def update_sumo_config_route_file(cfg_path, route_file):\n",
    "    tree = ET.parse(cfg_path)\n",
    "    root = tree.getroot()\n",
    "    for elem in root.findall(\".//input\"):\n",
    "        for child in elem:\n",
    "            if child.tag == \"route-files\":\n",
    "                child.set(\"value\", route_file)\n",
    "    tree.write(cfg_path, encoding=\"utf-8\", xml_declaration=True)\n",
    "\n",
    "\n",
    "def run_simulation(cfg_file, combined_folder, duration_folder):\n",
    "    results = []\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",
    "        # Always use NS by default\n",
    "        update_additional_file(cfg_file, \"EW\")\n",
    "\n",
    "        # Only override to NS-L for 3rd video in 2min folder\n",
    "        if duration_folder.lower() == \"2min\" and (i == 1 or i == 3):\n",
    "            update_additional_file(cfg_file, \"EW-L\")\n",
    "\n",
    "        update_sumo_config_route_file(cfg_file, route_file)\n",
    "        traci.start([SUMO_BINARY, \"-c\", cfg_file, \"--step-length\", str(STEP), \"--no-step-log\", \"true\", \"--time-to-teleport\", \"-1\"])\n",
    "\n",
    "        occupancy_history = {grp: [] for grp in lane_groups}\n",
    "        depart_times = {}\n",
    "        arrival_times = {}\n",
    "        waiting_times = {}\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",
    "                occ = [traci.lane.getLastStepOccupancy(ln) for ln in lanes]\n",
    "                occupancy_history[grp].append(sum(occ)/len(occ) if occ else 0)\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",
    "        for veh_id in traci.simulation.getArrivedIDList():\n",
    "            arrival_times[veh_id] = traci.simulation.getTime()\n",
    "\n",
    "        traci.close()\n",
    "\n",
    "        travel_times = [arrival_times[v] - depart_times[v] for v in arrival_times if v in depart_times]\n",
    "        wait_times = [waiting_times.get(v, 0) for v in arrival_times]\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 = {g: sum(v)/len(v) if v else 0 for g, v in occupancy_history.items()}\n",
    "        avg_occ_per_phase = {p: max(avg_occ_per_group[g] for g in gs) for p, gs in phase_groups.items()}\n",
    "\n",
    "        most_congested_phase = max(avg_occ_per_phase, key=avg_occ_per_phase.get)\n",
    "\n",
    "        results.append({\n",
    "            \"route_file\": route_file,\n",
    "            \"congested_phase\": most_congested_phase,\n",
    "            \"max_occupancy_percent\": int(avg_occ_per_phase[most_congested_phase]*100),\n",
    "            \"ATT\": float(f\"{ATT:.2f}\"),\n",
    "            \"AWT\": float(f\"{AWT:.2f}\")\n",
    "        })\n",
    "\n",
    "    return results\n",
    "\n",
    "\n",
    "# ─────────── MAIN LOOP ───────────\n",
    "day_path = os.path.join(BASE_DIR, TARGET_FOLDER)\n",
    "all_results = []\n",
    "for subfolder in os.listdir(day_path):\n",
    "    if subfolder.lower() in [\"2min\", \"3min\", \"4min\", \"5min\", \"6min\"]:\n",
    "        try:\n",
    "            combined_dir = move_routes_and_setup_combined(day_path, subfolder)\n",
    "            cfg_path = os.path.join(combined_dir, \"sumo_config.sumocfg\")\n",
    "            results = run_simulation(cfg_path, combined_dir, subfolder)\n",
    "            for r in results:\n",
    "                r[\"duration_folder\"] = subfolder\n",
    "            all_results.extend(results)\n",
    "        except Exception as e:\n",
    "            print(f\"❌ Error processing {subfolder}: {e}\")\n",
    "\n",
    "df = pd.DataFrame(all_results)\n",
    "df.to_csv(OUTPUT_CSV, index=False, float_format=\"%.2f\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f2330309",
   "metadata": {},
   "source": [
    " test data was of 2 days data : \n",
    " Bellevue_116th_NE12th__2017-09-11_14-08-35     \n",
    " Bellevue_116th_NE12th__2017-09-11_09-08-31   \n",
    " keep the csv names for each day same to find average"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "8fedff71",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average ATT across both days: 2261.70\n",
      "Average AWT across both days: 80.62\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "\n",
    "# Load both day files\n",
    "day1_df = pd.read_csv(r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\\traffic_malfunctioning_in_east_for_metrics.csv\")\n",
    "day2_df = pd.read_csv(r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\\traffic_malfunctioning_in_east_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\\New folder\\Finish_by_today\\Finish_by_today\\traffic_malfunctioning_in_east_for_metrics_combined.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1391c284",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Average ATT across both days: 99.70\n",
      "Average AWT across both days: 38.70\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "\n",
    "# Load both day files\n",
    "day1_df = pd.read_csv(r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\\traffic_malfunctioning_metrics_with_logic_IN_EAST.csv\")\n",
    "day2_df = pd.read_csv(r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\\traffic_malfunctioning_metrics_with_logic_IN_EAST.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\\New folder\\Finish_by_today\\Finish_by_today\\traffic_malfunctioning_metrics_with_logic_IN_EAST_combined.csv\", index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a67b318c",
   "metadata": {},
   "source": [
    "above logic was one east-west approach faulty we can create north-south approach completely  faulty as well "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "641bdb84",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "✅ Replaced <tlLogic> block with faulty traffic signal logic.\n"
     ]
    }
   ],
   "source": [
    "import re\n",
    "\n",
    "# Path to your .net.xml file\n",
    "net_file_path = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\\simple_nw_se.net.xml\"\n",
    "\n",
    "# Your faulty traffic signal logic\n",
    "faulty_tl_logic = \"\"\"\n",
    "<tlLogic id=\"center\" type=\"static\" programID=\"faulty_traffic\" offset=\"0\">\n",
    "    <phase duration=\"200\" state=\"rrrrrGGGGGrrrrrGGGGG\"/>\n",
    "    <phase duration=\"10\" state=\"rrrrryyyyyrrrrryyyyy\"/>\n",
    "    <phase duration=\"4\"  state=\"GGGGGrrrrrGGGGGrrrrr\"/>\n",
    "    <phase duration=\"10\" state=\"yyyyyrrrrryyyyyrrrrr\"/>\n",
    "</tlLogic>\n",
    "\"\"\"\n",
    "\n",
    "# Read the original file\n",
    "with open(net_file_path, \"r\", encoding=\"utf-8\") as f:\n",
    "    content = f.read()\n",
    "\n",
    "# Replace the existing <tlLogic id=\"center\"...> block\n",
    "updated_content = re.sub(\n",
    "    r\"<tlLogic id=\\\"center\\\".*?</tlLogic>\",\n",
    "    faulty_tl_logic.strip(),\n",
    "    content,\n",
    "    flags=re.DOTALL\n",
    ")\n",
    "\n",
    "# Write back to the file\n",
    "with open(net_file_path, \"w\", encoding=\"utf-8\") as f:\n",
    "    f.write(updated_content)\n",
    "\n",
    "print(\"✅ Replaced <tlLogic> block with faulty traffic signal logic.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17a4c26d",
   "metadata": {},
   "outputs": [],
   "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\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_14-08-35\"\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\"\n",
    "DURATION_FOLDERS = [\"2min\", \"3min\", \"4min\", \"5min\", \"6min\"]\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": "code",
   "execution_count": 3,
   "id": "15057bc9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "✅ 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 add.ew-l.xml → 2min/combined\n",
      "📄 Copied add.ew.xml → 2min/combined\n",
      "📄 Copied add.ns-l.xml → 2min/combined\n",
      "📄 Copied add.ns.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 add.ew-l.xml → 3min/combined\n",
      "📄 Copied add.ew.xml → 3min/combined\n",
      "📄 Copied add.ns-l.xml → 3min/combined\n",
      "📄 Copied add.ns.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 add.ew-l.xml → 4min/combined\n",
      "📄 Copied add.ew.xml → 4min/combined\n",
      "📄 Copied add.ns-l.xml → 4min/combined\n",
      "📄 Copied add.ns.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 add.ew-l.xml → 5min/combined\n",
      "📄 Copied add.ew.xml → 5min/combined\n",
      "📄 Copied add.ns-l.xml → 5min/combined\n",
      "📄 Copied add.ns.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 add.ew-l.xml → 6min/combined\n",
      "📄 Copied add.ew.xml → 6min/combined\n",
      "📄 Copied add.ns-l.xml → 6min/combined\n",
      "📄 Copied add.ns.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\\Finish_by_today\"\n",
    "TARGET_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\Bellevue_116th_NE12th__2017-09-11_09-08-31\"\n",
    "NETWORK_FOLDER = r\"C:\\Users\\tasfi\\Downloads\\New folder\\Finish_by_today\\Finish_by_today\\new_road_network_for_malfunction\"\n",
    "DURATION_FOLDERS = [\"2min\", \"3min\", \"4min\", \"5min\", \"6min\"]\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": "e9735435",
   "metadata": {},
   "source": [
    "Here is a complete Python script that performs the following:\n",
    "\n",
    "Loads a CSV file such as traffic_malfunctioning_in_north_for_metrics, which contains the most congested phase (NS or NS-L) for each duration or route.\n",
    "\n",
    "read and open the csv file and Based on the value of the congested phase:\n",
    "\n",
    "If NS, the script applies the LLM-generated logic: add.ns.xml\n",
    "\n",
    "If NS-L, it applies: add.ns-l.xml\n",
    "\n",
    "The script then modifies the corresponding .sumocfg file to include the appropriate additional-files XML (add.ns.xml or add.ns-l.xml).\n",
    "\n",
    "It runs the SUMO simulation for each test route file.\n",
    "\n",
    "Finally, it computes and reports:\n",
    "\n",
    "ATT: Average Travel Time\n",
    "\n",
    "AWT: Average Waiting Time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d4f238a6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "8edb6875",
   "metadata": {},
   "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.13.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
